@charset "UTF-8";
/***************************************
 *
 *base CSS
 *
 *2019/XX
 *
 ****************************************** */
/*****************************
 *
 *settings
 *
 ***************************** */
.dnone {
  display: none !important; }
  .dnone.show {
    display: block !important; }

.mgt0 {
  margin-top: 0 !important; }

.mgb0 {
  margin-bottom: 0 !important; }

.pdb0 {
  padding-bottom: 0 !important; }

.bdt {
  border-top: 1px solid #ccc !important; }

.bdb {
  border-bottom: 1px solid #ccc !important; }

.fz20 {
  font-size: 1.9rem !important; }

.trans_txt_parent .inner {
  overflow: hidden; }
.trans_txt_parent s {
  display: inline-block;
  transform: translateY(100px); }

.scroll_fadein {
  transform: translateY(100px);
  opacity: 0; }

.serif {
  font-family: "Noto Serif jp", serif !important; }

a.button, button {
  margin: 40px 0;
  border: none;
  cursor: pointer;
  display: flex;
  font-size: 1.8rem;
  padding: 17px 22px;
  border-radius: 8px;
  background: linear-gradient(to right, #396afc, #2948ff);
  color: #fff;
  align-items: center;
  justify-content: space-between;
  align-items: center;
  max-width: 100%;
  width: 283px;
  font-weight: bold;
  position: relative;
  letter-spacing: 0.1em;
  transition: 0.4s ease;
  z-index: 11;
  box-shadow: 0px 5px 5px rgba(0, 0, 0, 0.2); }
  a.button .material-icons, button .material-icons {
    position: relative;
    top: 4px;
    line-height: 0.5; }
  a.button.s, button.s {
    width: auto !important;
    display: table; }
  a.button.l, button.l {
    width: 300px; }
  a.button.dl:after, button.dl:after {
    content: "";
    position: absolute;
    right: 15px;
    top: calc(50% - 15px);
    font-size: 26px;
    font-weight: normal;
    font-family: "material symbols outlined";
    display: inline-block; }
  a.button.center, button.center {
    margin: 50px auto; }
  a.button.emp, button.emp {
    background: linear-gradient(#FE985F, #FF596F);
    padding: 20px 30px;
    border-radius: 50px;
    width: 280px;
    font-size: 2rem; }
  a.button.internal:after, button.internal:after {
    position: absolute;
    content: "";
    font-family: "material symbols outlined";
    display: inline-block;
    right: 20px;
    font-weight: normal;
    top: calc(50% - 12px); }
  a.button.external:after, button.external:after {
    position: absolute;
    content: "";
    font-family: "material symbols outlined";
    display: inline-block;
    right: 20px;
    font-weight: normal;
    top: calc(50% - 12px); }
  a.button:hover, button:hover {
    transform: translateY(5px);
    box-shadow: 0px 0px 0px rgba(0, 0, 0, 0.2); }
    a.button:hover i, button:hover i {
      transform: translateX(10px);
      background: #FF596F; }
      a.button:hover i svg path, button:hover i svg path {
        fill: #fff; }
  a.button i, button i {
    height: 32px;
    width: 32px;
    padding: 5px;
    border-radius: 50%;
    background: #fff;
    align-items: center;
    justify-content: center;
    display: flex;
    box-shadow: 3px 3px 6px rgba(0, 0, 0, 0.3);
    transition: 0.4s ease; }
  a.button.or, button.or {
    background: #FF7B67;
    border-radius: 50px; }
  a.button.green, button.green {
    background: linear-gradient(to right, #43B897, #20E3B2);
    border-radius: 50px; }
  a.button.grey, button.grey {
    background: #999 !important;
    pointer-events: none; }

#content .color_txt .color_bg s {
  -webkit-background-clip: text !important;
  background: linear-gradient(#FE985F, #FF596F);
  -webkit-text-fill-color: transparent; }

/***********************
 *
 *common
 *
 ********************** */
* {
  box-sizing: border-box; }

a {
  text-decoration: none;
  color: inherit; }

li {
  list-style: none;
  font-size: 1.6rem;
  line-height: 1.5; }

i, em {
  font-style: normal; }

body, html {
  margin: 0px;
  padding: 0px;
  font-family: "Roboto", "Noto Sans JP", "Yu Gothic", sans-serif;
  font-feature-settings: "palt";
  color: #333;
  font-weight: 400;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%; }

html {
  font-size: 10px; }
  html.font_size_small {
    font-size: 7px; }
  html.font_size_large {
    font-size: 14px; }

body {
  overflow-x: hidden;
  color: #333;
  width: 100vw; }

ul {
  margin: 0;
  padding: 0; }

h2, h3, h4, h5 {
  font-weight: bold;
  width: 100%; }

p {
  font-size: 1.6rem;
  margin: 20px 0;
  line-height: 1.9;
  letter-spacing: .1rem; }
  p.emp {
    font-size: 1.8rem; }
  p.harf {
    width: 49%;
    line-height: 2.2; }

.ib {
  width: 1160px;
  margin: 0 auto;
  position: relative;
  max-width: 100%; }

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 .2s linear;
    background: #000;
    transition-delay: 0s; }
  .btn_border:hover::before, .btn_border:hover::after {
    width: 100%;
    transition-delay: .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 .2s linear;
      background: #000;
      transition-delay: .2s; }

/*************************************
 *
 *404
 *
 ************************************* */
p.p404 {
  padding: 40px;
  text-align: center;
  font-size: 32px;
  font-weight: bold;
  background: #f1f1f1;
  margin: 40px 0; }

/***************************************
 *
 *header
 *
 ************************************* */
body.scrolled header {
  background: #fff; }
  body.scrolled header .pr_links .nav span.parent {
    color: #396afc !important; }
    body.scrolled header .pr_links .nav span.parent svg path {
      fill: #396afc !important; }

.sub_nav_outer {
  position: fixed;
  z-index: -9;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  opacity: 0;
  transition: 0.4s ease; }
  .sub_nav_outer.active {
    z-index: 99999999;
    opacity: 1; }

.sub_nav {
  position: absolute;
  width: 100%;
  height: 100%;
  background: #fff;
  top: 0;
  left: 0; }
  .sub_nav.active {
    z-index: 99;
    opacity: 1; }
  .sub_nav .search_container {
    margin-top: 40px; }
  .sub_nav .close {
    position: absolute;
    background: #f5f5f5;
    top: 0;
    right: 0;
    height: 80px;
    width: 80px;
    z-index: 2;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    display: flex; }
    .sub_nav .close:before {
      content: "";
      font-size: 32px;
      font-weight: 600;
      font-family: "material symbols outlined";
      display: inline-block; }
  .sub_nav .ib {
    height: 100%;
    width: 1000px;
    padding: 100px 0; }
    .sub_nav .ib .policy {
      flex-wrap: wrap;
      width: 100%;
      justify-content: flex-end;
      display: flex;
      font-size: 1.6rem;
      color: #fff;
      margin: 40px 0; }
      .sub_nav .ib .policy a {
        color: #212121;
        margin-right: 30px; }
        .sub_nav .ib .policy a:last-child {
          margin-right: 0px; }
    .sub_nav .ib p.copy {
      font-size: 1.4rem;
      text-align: center; }
    .sub_nav .ib .bd {
      width: 100%;
      margin: 30px 0 40px;
      border: 1px solid #ccc; }
    .sub_nav .ib .row a.logo {
      flex-wrap: wrap;
      display: flex;
      align-items: center; }
      .sub_nav .ib .row a.logo .img {
        margin-right: 15px;
        width: 110px;
        height: 110px;
        background: url(../img/logo.svg);
        background-size: cover; }
      .sub_nav .ib .row a.logo span {
        font-size: 1.6rem;
        font-weight: bold; }
    .sub_nav .ib .df {
      display: flex;
      flex-wrap: wrap;
      margin-top: 50px; }
      .sub_nav .ib .df .col {
        width: 24%;
        margin-right: 1%; }
        .sub_nav .ib .df .col a {
          display: block;
          font-size: 1.6rem;
          font-weight: 500;
          padding: 5px 0 10px;
          transition: 0.4s ease; }
          .sub_nav .ib .df .col a:hover {
            color: #396afc; }
          .sub_nav .ib .df .col a:before {
            content: "-";
            display: inline-block;
            margin-right: 5px; }
          .sub_nav .ib .df .col a.parent {
            font-weight: bold;
            font-size: 2.4rem;
            padding-bottom: 10px; }
            .sub_nav .ib .df .col a.parent:before {
              display: none; }
          .sub_nav .ib .df .col a.tel {
            font-size: 28px;
            font-weight: bold;
            align-items: center;
            display: flex;
            display: none; }
            .sub_nav .ib .df .col a.tel:before {
              content: "";
              font-family: "material symbols outlined";
              display: inline-block; }
          .sub_nav .ib .df .col a.contact {
            display: block;
            width: 100%;
            padding: 20px;
            text-align: center;
            color: #fff;
            background: linear-gradient(to right, #396afc, #2948ff);
            border-radius: 8px;
            font-size: 22px;
            font-weight: bold;
            align-items: center;
            margin: 0px 0 20px;
            display: flex; }
            .sub_nav .ib .df .col a.contact:before {
              content: "";
              font-family: "material symbols outlined";
              display: inline-block;
              margin-right: 8px; }
        .sub_nav .ib .df .col .lang p {
          font-size: 18px;
          font-weight: bold; }
        .sub_nav .ib .df .col .lang a {
          display: inline-block;
          font-size: 15px;
          margin-right: 10px; }
          .sub_nav .ib .df .col .lang a:before {
            display: none; }

body.scrolled header {
  background: #fff; }
  body.scrolled header .txt_size {
    bottom: -38px; }
  body.scrolled header h1 span {
    color: #000; }
  body.scrolled header nav a {
    color: #000; }
    body.scrolled header nav a:after, body.scrolled header nav a:before {
      color: #000; }
  body.scrolled header .pr_links {
    transform: scale(.88) translateY(-10px); }
    body.scrolled header .pr_links .nav a:not(.parent) {
      color: #396afc;
      background: #396afc; }
      body.scrolled header .pr_links .nav a:not(.parent) svg path {
        fill: #396afc !important; }
      body.scrolled header .pr_links .nav a:not(.parent):after {
        background: #396afc; }

.lang_remark_btn {
  position: fixed;
  z-index: 99999;
  right: 195px;
  bottom: 0;
  height: 38px;
  border-radius: 2px 2px 0 0;
  border: 1px solid #e0e0e0;
  background: #eee;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  padding: 10px 13px;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  cursor: pointer; }
  .lang_remark_btn:before {
    content: "";
    font-family: material icons;
    display: inline-block;
    margin-right: 10px;
    font-size: 18px; }

.bg_layer {
  position: fixed;
  z-index: 999999;
  background: rgba(0, 0, 0, 0.5);
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: none; }
  .bg_layer.active {
    display: block; }

iframe button {
  border-radius: 0; }

.lang_popup {
  position: fixed;
  width: 1000px;
  height: 600px;
  z-index: 999999999999999999;
  display: none;
  background: #fff;
  border-radius: 20px;
  padding: 25px;
  display: flex;
  box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.2);
  top: calc(50% - 300px);
  left: calc(50% - 500px);
  flex-wrap: wrap;
  align-items: center;
  max-width: 100%;
  align-content: center;
  display: none; }
  .lang_popup.active {
    display: flex; }
  .lang_popup .close {
    width: 40px;
    height: 40px;
    position: absolute;
    right: 20px;
    top: 20px;
    background: #eee;
    border-radius: 50%;
    cursor: pointer;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    display: flex; }
  .lang_popup h3 {
    font-size: 24px;
    width: 100%;
    text-align: center;
    color: #396afc; }
  .lang_popup p {
    width: 100%;
    text-align: center; }

header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  height: 117px;
  width: 100%;
  align-items: center;
  justify-content: space-between;
  transition: 0.4s ease; }
  header form {
    height: 50px;
    width: 200px;
    position: absolute;
    top: 15px;
    right: 20px; }
    header form input {
      display: block;
      width: 100%;
      height: 100%;
      border-radius: 50px;
      background: #fff;
      border: 1px solid #d3e9f5;
      padding: 15px; }
    header form button {
      width: 50px;
      height: 100%;
      position: absolute;
      top: 0;
      right: 0;
      border-radius: 50%;
      margin: 0;
      padding: 15px;
      align-items: center;
      justify-content: center;
      display: flex;
      box-shadow: none; }
      header form button:hover {
        transform: none; }
      header form button svg {
        display: block;
        width: 100%; }
        header form button svg path {
          fill: #fff !important; }
  header.front h1 span {
    color: #fff; }
  header.front nav a, header.front nav span {
    color: #fff; }
    header.front nav a:after, header.front nav a:before, header.front nav span:after, header.front nav span:before {
      color: #fff; }
  header.front .pr_links .nav span.parent, header.front .pr_links .nav a.parent {
    color: #fff;
    background: none; }
    header.front .pr_links .nav span.parent svg path, header.front .pr_links .nav a.parent svg path {
      fill: #f6f9fc !important; }
    header.front .pr_links .nav span.parent:after, header.front .pr_links .nav a.parent:after {
      background: #fff; }
  header .inner {
    position: relative;
    height: 80px;
    padding: 0 20px;
    width: 100%;
    align-items: center;
    display: flex;
    z-index: 3;
    justify-content: space-between; }
  header .pr_links {
    height: 50px;
    text-align: center;
    display: block;
    transition: 0.4s ease;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%; }
    header .pr_links .nav {
      justify-content: center;
      display: flex;
      padding: 12px;
      align-items: center;
      margin: 0 auto;
      position: relative; }
      header .pr_links .nav span.parent, header .pr_links .nav a.parent {
        font-size: 2rem;
        font-weight: bold;
        color: #fff;
        padding: 20px 20px;
        position: relative;
        color: #396afc;
        margin-right: 5px;
        display: flex;
        margin-top: -10px;
        align-items: center;
        transition: 0.4s ease;
        cursor: pointer; }
        header .pr_links .nav span.parent:hover, header .pr_links .nav a.parent:hover {
          color: #43B897; }
          header .pr_links .nav span.parent:hover svg path, header .pr_links .nav a.parent:hover svg path {
            fill: #43B897; }
        header .pr_links .nav span.parent:last-child:after, header .pr_links .nav a.parent:last-child:after {
          display: none; }
        header .pr_links .nav span.parent:nth-of-type(2) i.child, header .pr_links .nav a.parent:nth-of-type(2) i.child {
          left: -152px; }
        header .pr_links .nav span.parent:nth-of-type(3) i.child, header .pr_links .nav a.parent:nth-of-type(3) i.child {
          left: -357px; }
        header .pr_links .nav span.parent:nth-of-type(4) i.child, header .pr_links .nav a.parent:nth-of-type(4) i.child {
          left: -470px; }
        header .pr_links .nav span.parent:nth-of-type(5) i.child, header .pr_links .nav a.parent:nth-of-type(5) i.child {
          left: -770px; }
        header .pr_links .nav span.parent:nth-of-type(6) i.child, header .pr_links .nav a.parent:nth-of-type(6) i.child {
          left: auto;
          right: 0; }
        header .pr_links .nav span.parent:after, header .pr_links .nav a.parent:after {
          position: absolute;
          content: "";
          height: 21px;
          width: 1px;
          display: block;
          background: #396afc;
          transform: rotate(15deg);
          right: -5px;
          top: calc(50% - 8px); }
        header .pr_links .nav span.parent img, header .pr_links .nav span.parent svg, header .pr_links .nav a.parent img, header .pr_links .nav a.parent svg {
          height: 30px;
          width: auto;
          margin-right: 10px;
          display: inline-block;
          transition: 0.4s ease; }
          header .pr_links .nav span.parent img svg, header .pr_links .nav span.parent svg svg, header .pr_links .nav a.parent img svg, header .pr_links .nav a.parent svg svg {
            fill: #396afc; }
          header .pr_links .nav span.parent img#lib, header .pr_links .nav span.parent svg#lib, header .pr_links .nav a.parent img#lib, header .pr_links .nav a.parent svg#lib {
            height: 28px; }
          header .pr_links .nav span.parent img .cls-1, header .pr_links .nav span.parent svg .cls-1, header .pr_links .nav a.parent img .cls-1, header .pr_links .nav a.parent svg .cls-1 {
            stroke: none !important; }
          header .pr_links .nav span.parent img#lib, header .pr_links .nav span.parent svg#lib, header .pr_links .nav a.parent img#lib, header .pr_links .nav a.parent svg#lib {
            height: 24px; }
          header .pr_links .nav span.parent img#icon_next, header .pr_links .nav span.parent svg#icon_next, header .pr_links .nav a.parent img#icon_next, header .pr_links .nav a.parent svg#icon_next {
            height: 22px; }
        header .pr_links .nav span.parent i.child, header .pr_links .nav a.parent i.child {
          width: 1000px;
          padding: 30px;
          position: absolute;
          top: 60px;
          left: 0;
          border: 4px solid #396afc;
          background: #fff;
          border-radius: 10px;
          display: none; }
          header .pr_links .nav span.parent i.child a, header .pr_links .nav a.parent i.child a {
            color: #212121;
            background: none;
            margin-right: 20px;
            font-size: 1.8rem;
            display: inline-block;
            transition: 0.4s ease; }
            header .pr_links .nav span.parent i.child a:hover, header .pr_links .nav a.parent i.child a:hover {
              color: #396afc; }
  header nav {
    display: flex;
    padding-right: 210px;
    height: 100%;
    align-items: center; }
    header nav a:not(.txt), header nav span.parent {
      height: 100%;
      align-items: center;
      display: flex;
      justify-content: center;
      font-size: 1.6rem;
      font-weight: bold;
      padding: 0;
      margin: 0 14px;
      transition: 0.4s ease;
      position: relative;
      cursor: pointer; }
      header nav a:not(.txt) i, header nav span.parent i {
        width: 230px;
        padding: 20px;
        background: linear-gradient(to right, #396afc, #2948ff);
        position: absolute;
        left: calc(50% - 115px);
        border-radius: 8px;
        top: 80px;
        display: none; }
        header nav a:not(.txt) i a, header nav span.parent i a {
          display: block;
          font-size: 1.6rem;
          font-weight: bold;
          padding: 5px 0;
          color: #fff;
          margin: 0; }
          header nav a:not(.txt) i a:hover, header nav span.parent i a:hover {
            color: #fff; }
          header nav a:not(.txt) i a:after, header nav span.parent i a:after {
            height: 1px;
            background: #fff; }
      header nav a:not(.txt):after, header nav span.parent:after {
        position: absolute;
        bottom: 0;
        left: 0;
        height: 2px;
        background: #396afc;
        content: "";
        width: 100%;
        transform: scale(0, 1);
        transform-origin: right top;
        transition: transform .3s; }
      header nav a:not(.txt):hover, header nav span.parent:hover {
        color: #396afc; }
        header nav a:not(.txt):hover:after, header nav span.parent:hover:after {
          transform: scale(1, 1);
          transform-origin: left; }
    header nav span.parent {
      margin-right: 23px; }
      header nav span.parent:before {
        font-family: "material symbols outlined";
        display: inline-block;
        content: "";
        position: absolute;
        right: -20px;
        font-size: 20px;
        top: calc(50% - 11px); }
      header nav span.parent:hover i {
        display: block; }
        header nav span.parent:hover i:after {
          background: #fff; }
  header .txt_size {
    position: absolute;
    bottom: -50px;
    background: #fff;
    padding: 5px 10px;
    align-items: center;
    justify-content: center;
    display: flex;
    right: 0;
    width: 80px;
    flex-wrap: wrap;
    border-radius: 50px 0 0 50px; }
    header .txt_size.font_size_large div a.large {
      text-decoration: none;
      font-size: 15px;
      color: #396afc;
      font-weight: bold; }
    header .txt_size.font_size_medium div a.medium {
      text-decoration: none;
      font-size: 15px;
      color: #396afc;
      font-weight: bold; }
    header .txt_size.font_size_small div a.small {
      text-decoration: none;
      font-size: 15px;
      color: #396afc;
      font-weight: bold; }
    header .txt_size p {
      width: 100%;
      margin: 0;
      font-size: 12px;
      line-height: 1;
      text-align: center;
      letter-spacing: 0; }
    header .txt_size div {
      width: 100%;
      justify-content: space-between;
      display: flex;
      align-items: center; }
      header .txt_size div a {
        font-size: 13px;
        text-decoration: underline; }
        header .txt_size div a.active {
          text-decoration: none;
          font-size: 15px;
          color: #396afc;
          font-weight: bold; }
  header h1 {
    margin-top: 10px;
    align-items: center;
    display: flex; }
    header h1 img {
      display: inline-block;
      width: 100px; }
    header h1 span {
      font-weight: bold;
      display: inline-block;
      padding-left: 10px; }
      header h1 span i {
        display: block;
        font-size: 13px; }
      header h1 span em {
        display: block;
        font-size: 18px; }
  header .spbtn {
    cursor: pointer;
    width: 80px;
    height: 100%;
    top: 0;
    right: 10px;
    padding: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(#FE985F, #FF596F);
    position: absolute;
    display: none !important; }
    header .spbtn.cr {
      width: 60px;
      height: 60px;
      border-radius: 50%;
      right: 15px;
      top: 10px; }
    header .spbtn:before {
      color: #fff;
      font-size: 27px;
      content: "";
      font-family: "material symbols outlined";
      display: inline-block; }
    header .spbtn.search {
      background: none;
      right: 80px; }
      header .spbtn.search:before {
        content: url(../img/icon_search.svg); }

/*****************************
 *
 *settings
 *
 ***************************** */
.dnone {
  display: none !important; }
  .dnone.show {
    display: block !important; }

.mgt0 {
  margin-top: 0 !important; }

.mgb0 {
  margin-bottom: 0 !important; }

.pdb0 {
  padding-bottom: 0 !important; }

.bdt {
  border-top: 1px solid #ccc !important; }

.bdb {
  border-bottom: 1px solid #ccc !important; }

.fz20 {
  font-size: 1.9rem !important; }

.trans_txt_parent .inner {
  overflow: hidden; }
.trans_txt_parent s {
  display: inline-block;
  transform: translateY(100px); }

.scroll_fadein {
  transform: translateY(100px);
  opacity: 0; }

.serif {
  font-family: "Noto Serif jp", serif !important; }

a.button, button {
  margin: 40px 0;
  border: none;
  cursor: pointer;
  display: flex;
  font-size: 1.8rem;
  padding: 17px 22px;
  border-radius: 8px;
  background: linear-gradient(to right, #396afc, #2948ff);
  color: #fff;
  align-items: center;
  justify-content: space-between;
  align-items: center;
  max-width: 100%;
  width: 283px;
  font-weight: bold;
  position: relative;
  letter-spacing: 0.1em;
  transition: 0.4s ease;
  z-index: 11;
  box-shadow: 0px 5px 5px rgba(0, 0, 0, 0.2); }
  a.button .material-icons, button .material-icons {
    position: relative;
    top: 4px;
    line-height: 0.5; }
  a.button.s, button.s {
    width: auto !important;
    display: table; }
  a.button.l, button.l {
    width: 300px; }
  a.button.dl:after, button.dl:after {
    content: "";
    position: absolute;
    right: 15px;
    top: calc(50% - 15px);
    font-size: 26px;
    font-weight: normal;
    font-family: "material symbols outlined";
    display: inline-block; }
  a.button.center, button.center {
    margin: 50px auto; }
  a.button.emp, button.emp {
    background: linear-gradient(#FE985F, #FF596F);
    padding: 20px 30px;
    border-radius: 50px;
    width: 280px;
    font-size: 2rem; }
  a.button.internal:after, button.internal:after {
    position: absolute;
    content: "";
    font-family: "material symbols outlined";
    display: inline-block;
    right: 20px;
    font-weight: normal;
    top: calc(50% - 12px); }
  a.button.external:after, button.external:after {
    position: absolute;
    content: "";
    font-family: "material symbols outlined";
    display: inline-block;
    right: 20px;
    font-weight: normal;
    top: calc(50% - 12px); }
  a.button:hover, button:hover {
    transform: translateY(5px);
    box-shadow: 0px 0px 0px rgba(0, 0, 0, 0.2); }
    a.button:hover i, button:hover i {
      transform: translateX(10px);
      background: #FF596F; }
      a.button:hover i svg path, button:hover i svg path {
        fill: #fff; }
  a.button i, button i {
    height: 32px;
    width: 32px;
    padding: 5px;
    border-radius: 50%;
    background: #fff;
    align-items: center;
    justify-content: center;
    display: flex;
    box-shadow: 3px 3px 6px rgba(0, 0, 0, 0.3);
    transition: 0.4s ease; }
  a.button.or, button.or {
    background: #FF7B67;
    border-radius: 50px; }
  a.button.green, button.green {
    background: linear-gradient(to right, #43B897, #20E3B2);
    border-radius: 50px; }
  a.button.grey, button.grey {
    background: #999 !important;
    pointer-events: none; }

#content .color_txt .color_bg s {
  -webkit-background-clip: text !important;
  background: linear-gradient(#FE985F, #FF596F);
  -webkit-text-fill-color: transparent; }

#fv.top2 {
  background: url(../img/pt2.png);
  background-blend-mode: multiply;
  animation: bg-scrolling linear 0.92s infinite; }
@keyframes bg-scrolling {
  0% {
    background-position: 50px 50px, 0 0; }
  100% {
    background-position: 100px 100px, 0 0; } }
  #fv.top2 .grad_bg {
    display: none; }
  #fv.top2 .bg_cover {
    background: #fff;
    opacity: 0;
    box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.15); }
  #fv.top2 .ib .txt h2 span {
    color: #212121; }
    #fv.top2 .ib .txt h2 span:before {
      background: #212121; }
  #fv.top2 .ib .txt h2 svg path {
    fill: #396afc; }
  #fv.top2 .cycle {
    opacity: 0; }
  #fv.top2 #globe {
    left: calc(50% - 500px); }
  #fv.top2 #svg_shape {
    opacity: 1; }
    #fv.top2 #svg_shape path {
      fill: #f6f9fc !important; }
      #fv.top2 #svg_shape path#shape2, #fv.top2 #svg_shape path#shape3 {
        fill: rgba(0, 0, 0, 0) !important; }

#fv {
  height: 100vh;
  background: #f6f9fc;
  position: relative;
  overflow: hidden; }
  #fv.latest {
    background: #d3e9f5; }
    #fv.latest #star_bg, #fv.latest .grad_bg, #fv.latest .bg_cover {
      display: none; }
    #fv.latest #globe {
      transform: scale(1.2);
      left: calc(50% - 600px); }
    #fv.latest .ib .txt h2 span {
      color: #000; }
      #fv.latest .ib .txt h2 span:before {
        background: #000; }
    #fv.latest .ib .txt h2 svg path {
      fill: #fff; }
  #fv #skycontainer {
    z-index: -1;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    overflow: hidden;
    transform: scale(1.5); }
    #fv #skycontainer #sky {
      position: absolute;
      width: 100%;
      height: 100%;
      top: 0;
      left: 0; }
  #fv .bg_cover {
    opacity: 1; }
  #fv .ib {
    height: 100%;
    display: flex;
    z-index: 5;
    justify-content: space-between;
    position: relative; }
    #fv .ib .slide {
      align-items: center;
      display: flex;
      width: 600px;
      right: -70px;
      position: absolute;
      top: 0px;
      height: 100%;
      z-index: 3; }
      #fv .ib .slide .pr_active {
        width: 300px;
        position: absolute;
        left: 0;
        top: calc(50% - 230px);
        height: 420px; }
        #fv .ib .slide .pr_active .box {
          align-items: center;
          justify-content: center;
          width: 100%;
          height: 100%;
          position: absolute;
          top: 0;
          left: 0;
          padding-top: 100px;
          display: flex;
          opacity: 0;
          transition: 0.6s ease; }
          #fv .ib .slide .pr_active .box a.button {
            position: absolute;
            bottom: -52px;
            right: -50px;
            z-index: 2;
            width: 180px;
            justify-content: center;
            font-size: 19px; }
          #fv .ib .slide .pr_active .box.active {
            opacity: 1;
            z-index: 2; }
          #fv .ib .slide .pr_active .box.freon img {
            width: 90%; }
          #fv .ib .slide .pr_active .box.lib img {
            width: 90%; }
          #fv .ib .slide .pr_active .box.asr img {
            width: 56%; }
          #fv .ib .slide .pr_active .box.next img {
            width: 85%; }
          #fv .ib .slide .pr_active .box img {
            width: 100%;
            height: auto; }
      #fv .ib .slide .pr_name {
        position: absolute;
        top: calc(50% - 200px);
        left: 0;
        width: 100%;
        align-items: center;
        display: flex;
        z-index: 3; }
        #fv .ib .slide .pr_name em {
          display: inline-block;
          font-size: 38px;
          font-weight: 400;
          color: #666;
          margin-top: -15px; }
        #fv .ib .slide .pr_name span {
          display: inline-block;
          width: 100px;
          display: flex;
          height: 100px;
          justify-content: center;
          align-items: center;
          position: relative;
          margin-right: 20px; }
          #fv .ib .slide .pr_name span i {
            position: relative;
            z-index: 2;
            font-size: 60px;
            font-weight: 400;
            color: #FF7B67; }
          #fv .ib .slide .pr_name span .inner {
            position: absolute;
            width: 100%;
            height: 100%;
            top: 0;
            left: 0;
            background: url(../img/cr4.svg) no-repeat;
            background-size: cover;
            animation: 10s rotate linear forwards infinite; }
      #fv .ib .slide .swiper .swiper-pagination {
        bottom: auto;
        text-align: left;
        bottom: 17px;
        left: 50px; }
        #fv .ib .slide .swiper .swiper-pagination .swiper-pagination-bullet {
          width: 12px;
          height: 12px;
          border-radius: 50%; }
          #fv .ib .slide .swiper .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
            background: #FF7B67; }
      #fv .ib .slide .swiper .swiper-slide {
        height: 400px;
        width: 130px;
        align-items: center;
        display: flex;
        opacity: 0.2;
        cursor: pointer;
        transform: translateX(150px); }
        #fv .ib .slide .swiper .swiper-slide.swiper-slide-active, #fv .ib .slide .swiper .swiper-slide.swiper-slide-prev {
          opacity: 0; }
        #fv .ib .slide .swiper .swiper-slide.asr img {
          width: 75%; }
        #fv .ib .slide .swiper .swiper-slide.next img {
          width: 85%; }
        #fv .ib .slide .swiper .swiper-slide img {
          transition: 0.4s ease;
          width: 100%;
          display: block;
          margin: 0 auto;
          opacity: 1;
          position: relative;
          top: 50px; }
    #fv .ib .txt {
      height: 100%;
      width: 49%;
      align-items: center;
      display: flex;
      margin-left: -30px; }
      #fv .ib .txt h2 {
        line-height: 1.4;
        position: relative;
        letter-spacing: 0.1rem; }
        #fv .ib .txt h2 .tit, #fv .ib .txt h2 svg {
          position: absolute;
          left: -20px;
          top: -50px;
          transform: scale(1.2);
          display: none; }
        #fv .ib .txt h2 span {
          display: block;
          font-size: 33px;
          letter-spacing: 0.1rem;
          margin-top: 20px;
          color: #fff;
          align-items: center;
          display: flex;
          display: none; }
          #fv .ib .txt h2 span:before {
            content: "";
            width: 60px;
            height: 1px;
            background: #fff;
            display: block;
            margin-right: 20px; }
        #fv .ib .txt h2 s {
          position: relative;
          z-index: 2;
          font-size: 59px;
          -webkit-background-clip: text !important;
          background: linear-gradient(#FE985F, #FF596F);
          -webkit-text-fill-color: transparent;
          opacity: 0; }
  #fv #globe {
    top: 60vh;
    left: calc(50% - 830px);
    transform: scale(1.1);
    transform-origin: center;
    position: absolute;
    z-index: 4; }
  #fv .cycle {
    position: absolute;
    width: 800px;
    bottom: -550px;
    left: calc(50% - 200px);
    z-index: 3;
    animation: rotate 20s linear forwards infinite; }
  #fv .grad_bg {
    position: absolute;
    left: 0;
    top: 0;
    width: 100vw;
    content: "";
    display: block;
    height: 100vh;
    z-index: 1;
    background: linear-gradient(230deg, #a24bcf, #4b79cf, #4bc5cf);
    animation: MoveBG 60s ease infinite; }
  #fv .bg_cover {
    position: absolute;
    z-index: 2;
    width: calc(50vw - 15px);
    height: 516px;
    position: absolute;
    top: calc(50% - 260px);
    right: 0;
    border-radius: 100px 0 0 100px;
    background: #f6f9fc; }
@keyframes MoveBG {
  0% {
    background-position: 0% 84%; }
  50% {
    background-position: 100% 16%; }
  100% {
    background-position: 0% 84%; } }
  #fv #dots_bg, #fv #abs, #fv #star_bg {
    position: absolute;
    width: 100vw;
    height: 100vh;
    top: 0;
    left: 0;
    z-index: 3;
    pointer-events: none; }
    #fv #dots_bg canvas, #fv #abs canvas, #fv #star_bg canvas {
      position: absolute;
      width: 100vw;
      height: 100vh;
      top: 0;
      left: 0; }

body .searchwp-live-search-results {
  z-index: 9999999999999999999999999; }
  body .searchwp-live-search-results * {
    font-size: 1.4rem;
    font-weight: bold;
    color: #396afc; }
body .large .searchwp-live-search-results * {
  font-size: 1.8rem; }

.search_container {
  width: 100%; }
  .search_container form {
    display: block;
    width: 100%;
    position: relative; }
    .search_container form button {
      position: absolute;
      z-index: 2;
      width: 70px;
      height: 70px;
      border-radius: 50%;
      top: 0;
      right: 0;
      border: none;
      box-shadow: none;
      background: linear-gradient(to right, #396afc, #2948ff);
      color: #fff;
      margin: 0;
      align-items: center;
      justify-content: center;
      display: flex;
      cursor: pointer; }
      .search_container form button:before {
        content: "";
        font-family: "material symbols outlined";
        display: inline-block;
        font-size: 40px; }
    .search_container form input[type="text"] {
      width: 100%;
      display: block;
      padding: 20px;
      height: 70px;
      font-size: 26px;
      background: #f5f5f5;
      border-radius: 50px;
      border: none;
      box-shadow: none; }

s {
  text-decoration: none; }

.top_info_outer {
  z-index: 999;
  width: 100%;
  height: 130px;
  position: absolute;
  left: 0;
  bottom: 0; }
  .top_info_outer h4 {
    position: absolute;
    top: -36px;
    margin: 0;
    text-align: center;
    width: 100%;
    left: 0px;
    font-size: 18px;
    font-weight: bold;
    color: #396afc;
    z-index: 2;
    display: table;
    background: #fff;
    padding: 10px 15px 10px 20px;
    width: auto;
    left: calc(50% - 600px);
    border-radius: 16px 16px 0 0; }
    .top_info_outer h4:after {
      font-family: "material icons";
      content: "";
      display: inline-block;
      margin-left: 7px;
      position: relative;
      top: 2px; }

#top_fixed_info {
  height: 140px;
  border-radius: 0;
  padding: 10px 0;
  background: #fff;
  width: 100vw; }
  #top_fixed_info .swiper-button-next:after, #top_fixed_info .swiper-button-prev:after {
    transform: scale(.6);
    color: #FF596F; }
  #top_fixed_info .row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    padding: 7px 0;
    width: 1160px;
    max-width: 100%;
    margin: 0 auto; }
    #top_fixed_info .row .date {
      font-weight: bold;
      font-size: 1.8rem;
      color: #FF596F;
      margin-right: 10px; }
    #top_fixed_info .row p {
      margin: 0;
      line-height: 1.5;
      font-size: 1.6rem;
      font-weight: bold; }

#content {
  position: relative;
  background: #fff; }
  #content.gray {
    background: #f7f7f7; }
  #content .feature_post .ib {
    padding: 20px 0 35px; }
    #content .feature_post .ib .fp_list {
      display: flex; }
    #content .feature_post .ib .row {
      width: 140px;
      margin-right: 30px; }
      #content .feature_post .ib .row .date {
        font-size: 1.6rem;
        font-weight: bold;
        margin-top: 10px; }
      #content .feature_post .ib .row p {
        font-weight: bold;
        margin: 10px 0;
        line-height: 1.5; }
      #content .feature_post .ib .row .img {
        width: 100%;
        height: auto;
        aspect-ratio: 1/1; }
        #content .feature_post .ib .row .img a {
          display: block;
          width: 100%;
          height: 100%; }
        #content .feature_post .ib .row .img img {
          object-fit: cover;
          width: 100%;
          height: 100%; }
  #content .top_shadow {
    height: 300px;
    background: url(../img/white_bg2.png);
    background-size: 100% 100%;
    display: none; }
  #content section {
    position: relative;
    z-index: 13; }
    #content section.products {
      z-index: 8; }
  #content.toppage:after {
    content: "";
    background: #fff;
    height: calc(100% - 400px);
    position: absolute;
    z-index: 1;
    bottom: 0;
    left: 0;
    width: 100%;
    display: block; }
  #content.toppage:before {
    content: "";
    position: absolute;
    height: 500px;
    width: 100vw;
    top: 0px;
    left: 0;
    background: url(../img/white_bg.png);
    background-size: 100% 100%;
    z-index: 12; }
  #content #top_road {
    top: 100px;
    left: calc(50% - 650px);
    position: absolute;
    z-index: 7; }
  #content .move_car {
    z-index: 8;
    position: absolute;
    width: 100px;
    top: 60px;
    left: calc(50% - 650px); }
  #content .ib {
    padding: 70px 0; }
  #content .trans_txt_parent .inner {
    overflow: hidden; }
    #content .trans_txt_parent .inner s {
      display: inline-block;
      transform: translateY(50px);
      opacity: 0; }
  #content h2 {
    letter-spacing: .12em;
    margin: 60px 0;
    position: relative;
    font-size: 3.2rem; }
    #content h2.center {
      text-align: center; }
    #content h2:before {
      content: "";
      width: 5px;
      height: 40px;
      display: block;
      position: absolute;
      top: -50px;
      left: calc(50% - 2.5px);
      background: linear-gradient(#FE985F, #FF596F); }
    #content h2 .inner {
      font-size: 5.6rem;
      color: #396afc; }
    #content h2 span {
      font-size: 2rem;
      color: #123d83; }
    #content h2.emp {
      margin-bottom: 80px; }
      #content h2.emp:before {
        display: none; }
      #content h2.emp .inner {
        font-size: 7rem; }
      #content h2.emp span {
        display: block;
        font-size: 3.2rem; }
  #content h3 {
    font-size: 2.2rem;
    margin: 50px 0;
    line-height: 1;
    position: relative;
    padding-left: 20px; }
    #content h3.open_next {
      padding: 10px;
      background: #f7f7f7;
      cursor: pointer;
      padding: 20px 15px;
      padding-left: 35px;
      border-radius: 6px; }
      #content h3.open_next.active {
        background: #396afc;
        color: #fff; }
        #content h3.open_next.active:before {
          background: none;
          color: #fff; }
      #content h3.open_next:before {
        left: 5px;
        content: "";
        font-family: "material icons";
        color: #396afc;
        height: auto;
        width: auto;
        background: none; }
    #content h3:before {
      position: absolute;
      height: 30px;
      width: 5px;
      content: "";
      background: #396afc;
      left: 0;
      border-radius: 50px;
      top: calc(50% - 15px); }
  #content h4 {
    font-size: 2.2rem;
    margin: 40px 0 30px;
    color: #396afc;
    border-bottom: 1px solid #396afc;
    padding-bottom: 10px; }
    #content h4.emp {
      font-size: 2.8rem; }
  #content h5 {
    font-size: 1.9rem;
    color: #396afc;
    margin: 30px 0;
    position: relative;
    align-items: center;
    display: flex; }
    #content h5:before {
      content: "";
      font-family: "material icons";
      margin-right: 4px;
      font-size: 120%; }
  #content .mgt-100 {
    margin-top: -100px;
    margin-bottom: 130px; }
  #content a.link_out {
    align-items: center;
    justify-content: center;
    display: flex; }
    #content a.link_out:after {
      content: "";
      margin-left: 10px;
      font-family: "material icons"; }
  #content p {
    font-size: 1.6rem;
    line-height: 1.9;
    margin: 20px 0;
    width: 100%;
    color: #091531; }
    #content p span {
      font-size: 1.4rem;
      display: block;
      font-weight: normal; }
    #content p em {
      display: inline-block;
      margin-left: 10px; }
    #content p.center {
      text-align: center; }
    #content p.red {
      font-size: 1.5rem;
      color: #FF596F; }
    #content p.emp {
      font-weight: bold;
      font-size: 2rem; }
      #content p.emp.l {
        font-size: 2.4rem; }
    #content p.harf {
      line-height: 2.4; }
    #content p a {
      text-decoration: underline;
      display: inline-block;
      color: #396afc; }
    #content p.small {
      font-size: 1.4rem;
      font-weight: normal; }
  #content .error {
    padding: 30px;
    background: #FFEFF1;
    border: 2px solid #FF596F;
    border-radius: 12px; }
    #content .error p {
      margin: 0; }
  #content .openbox .trigger {
    padding: 15px;
    text-align: center;
    font-size: 1.8rem;
    color: #396afc;
    font-weight: bold;
    border-bottom: 2px solid #396afc;
    padding-top: 0;
    position: relative; }
    #content .openbox .trigger:before {
      content: "";
      position: absolute;
      right: 0;
      top: calc(50% - 20px);
      font-size: 30px;
      line-height: 1;
      cursor: pointer;
      font-family: "material symbols outlined";
      display: inline-block; }
      #content .openbox .trigger:before.active:before {
        content: ""; }
  #content .openbox .box {
    display: none;
    background: #f5f5f5;
    padding: 30px;
    margin-top: 30px; }
    #content .openbox .box div {
      display: inline-block;
      margin-right: 20px;
      font-size: 1.6rem;
      line-height: 1.8; }

#content .df {
  justify-content: space-between;
  display: flex; }
  #content .df .box {
    width: 49%; }
  #content .df .l, #content .df .r {
    width: 49%; }
    #content .df .l.img img, #content .df .r.img img {
      object-fit: cover;
      width: 100%;
      height: 100%; }
#content section.intro {
  position: relative; }
  #content section.intro .ib {
    padding-bottom: 150px; }
  #content section.intro:after {
    content: "";
    position: absolute;
    bottom: -200px;
    width: 100vw;
    height: 200px;
    left: 0;
    display: block;
    background: url(../img/b_grad1.png);
    background-size: 100% 100%; }
  #content section.intro .df {
    justify-content: space-between;
    display: flex; }
    #content section.intro .df .l {
      width: 47%; }
    #content section.intro .df .illust {
      width: 48%;
      position: relative;
      mix-blend-mode: multiply; }
      #content section.intro .df .illust img {
        display: block;
        width: 100%; }

#content section.products {
  position: relative;
  margin-top: 50px; }
  #content section.products:before {
    content: "";
    height: 100%;
    width: 100vw;
    position: absolute;
    top: 0;
    left: 0;
    background: #f6f9fc;
    mix-blend-mode: multiply;
    opacity: .4; }
  #content section.products .ib {
    padding-top: 20px;
    padding-bottom: 220px;
    padding-top: 80px; }
  #content section.products .df {
    justify-content: space-between;
    display: flex; }
    #content section.products .df .r {
      width: 49%; }
      #content section.products .df .r p {
        margin-top: 0; }
      #content section.products .df .r a.button {
        margin-top: 60px; }
    #content section.products .df .l {
      width: 48%;
      justify-content: center;
      display: flex;
      flex-wrap: wrap; }
      #content section.products .df .l .box {
        height: 144px;
        width: 144px;
        background: #fff;
        border-radius: 50%;
        display: flex;
        flex-wrap: wrap;
        align-content: center;
        align-items: center;
        margin-right: 30px;
        box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.1); }
        #content section.products .df .l .box.asr img {
          height: 54px; }
        #content section.products .df .l .box.lib img {
          height: 50px; }
        #content section.products .df .l .box.nex img {
          height: 41px; }
        #content section.products .df .l .box img {
          display: block;
          margin: 0 auto;
          height: 50px; }
        #content section.products .df .l .box p {
          font-size: 1.4rem;
          margin-top: 15px;
          letter-spacing: 0;
          text-align: center;
          width: 100%;
          line-height: 1.3;
          font-weight: bold;
          margin-bottom: 0; }

#content section.aboutus {
  position: relative;
  z-index: 10; }
  #content section.aboutus:before {
    content: "";
    position: absolute;
    height: 200px;
    width: 100vw;
    top: 0;
    left: 0;
    background: url(../img/white_bg.png);
    background-size: 100% 100%;
    z-index: 12; }
  #content section.aboutus:after {
    content: "";
    position: absolute;
    top: -200px;
    width: 100vw;
    height: 200px;
    left: 0;
    display: block;
    background: url(../img/b_grad2.png);
    background-size: 100% 100%; }
  #content section.aboutus .factory {
    position: absolute;
    left: -120px;
    top: 570px;
    width: 250px; }
  #content section.aboutus .ib {
    padding-bottom: 100px;
    position: relative;
    z-index: 13;
    padding-top: 120px; }
    #content section.aboutus .ib p {
      padding-left: 50px;
      z-index: 3;
      position: relative; }
    #content section.aboutus .ib .obj1 {
      position: absolute;
      top: -240px;
      right: 30px;
      width: 270px; }
    #content section.aboutus .ib .obj2 {
      position: absolute;
      top: 80px;
      left: 50px;
      width: 200px;
      display: none; }
  #content section.aboutus .df a.button {
    margin-top: 60px; }
  #content section.aboutus a.button {
    margin-left: 50px;
    float: right; }

.serif {
  font-family: "Noto Serif jp", serif !important; }

section.btm_bnr {
  background: #EEF7FF;
  background-blend-mode: multiply;
  position: relative;
  z-index: 9; }
  section.btm_bnr.front {
    margin-top: 80px;
    background: #EEF7FF;
    display: none; }
    section.btm_bnr.front .ib {
      padding: 180px 0 30px;
      padding-left: 50px; }
      section.btm_bnr.front .ib .box {
        margin-top: -300px;
        height: 220px; }
  section.btm_bnr .ib {
    padding: 100px 0;
    justify-content: space-between;
    display: flex;
    flex-wrap: wrap; }
    section.btm_bnr .ib .box {
      width: 31.6%;
      height: 230px;
      position: relative;
      overflow: hidden;
      align-items: center;
      justify-content: center;
      display: flex;
      padding: 30px;
      flex-wrap: wrap; }
      section.btm_bnr .ib .box:hover .img:before {
        opacity: 0; }
      section.btm_bnr .ib .box:hover .img img {
        transform: scale(1.1); }
      section.btm_bnr .ib .box h2 {
        width: 100%;
        color: #fff !important;
        position: relative;
        z-index: 2;
        text-align: center;
        color: #fff; }
        section.btm_bnr .ib .box h2:before {
          display: none; }
        section.btm_bnr .ib .box h2 .inner {
          color: #fff;
          font-size: 4rem;
          color: #396afc; }
          section.btm_bnr .ib .box h2 .inner:before {
            display: none; }
        section.btm_bnr .ib .box h2 span {
          display: block;
          font-size: 2.4rem; }
      section.btm_bnr .ib .box a.button {
        position: relative;
        z-index: 2; }
      section.btm_bnr .ib .box .img {
        z-index: 1;
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        overflow: hidden; }
        section.btm_bnr .ib .box .img:before {
          content: "";
          z-index: 2;
          width: 100%;
          height: 100%;
          position: absolute;
          mix-blend-mode: multiply;
          top: 0;
          left: 0;
          transition: 0.4s ease;
          background: url(../img/pattern9.png);
          display: block; }
        section.btm_bnr .ib .box .img img {
          object-fit: cover;
          width: 100%;
          height: 100%;
          position: absolute;
          top: 0;
          left: 0;
          transition: 0.4s ease; }

.scrub_box_parent .scrub_box {
  opacity: 0;
  transform: translateY(10px); }

section.top_info {
  background: url(../img/city2.png) 100% 100% no-repeat fixed, #EEF7FF;
  background-size: 100% auto, cover;
  z-index: 8;
  position: relative;
  padding-top: 300px;
  padding-bottom: 100px;
  margin-top: -350px;
  display: none; }
  section.top_info:before {
    content: "";
    height: 500px;
    background: url(../img/b_grad3.png);
    width: 100%;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
    background-size: 100% 100%; }
  section.top_info .ib {
    padding: 20px 0 40px;
    position: relative;
    z-index: 3; }
    section.top_info .ib:before {
      content: "";
      width: calc(50vw + 600px);
      height: 100%;
      background: #fff;
      left: calc(0px - calc(50vw - 580px));
      position: absolute;
      top: 0;
      display: block;
      border-radius: 0 50px 50px 0; }
    section.top_info .ib h3 {
      font-size: 3.8rem;
      letter-spacing: .15rem;
      font-weight: bold;
      z-index: 2;
      margin-top: -45px;
      color: #123d83;
      position: relative; }
      section.top_info .ib h3 span {
        font-size: 1.6rem;
        display: inline-block;
        margin-left: 15px; }

.info_list {
  position: relative;
  z-index: 2;
  padding-right: 60px; }
  .info_list .row {
    justify-content: space-between;
    display: flex;
    font-size: 2rem;
    align-items: center;
    padding: 20px 0;
    margin-bottom: 15px;
    border-bottom: 1px dashed #123d83; }
    .info_list .row span {
      font-weight: bold;
      width: 110px;
      color: #123d83; }
    .info_list .row .txt {
      font-size: 1.8rem;
      letter-spacing: .1rem;
      width: calc(100% - 240px); }
    .info_list .row .cat {
      text-align: center;
      padding: 5px 12px;
      font-size: 1.5rem;
      color: #fff;
      width: 110px;
      font-weight: bold;
      background: linear-gradient(to right, #396afc, #2948ff);
      border-radius: 50px; }

@keyframes rotate {
  0% {
    transform: rotate(0deg); }
  100% {
    transform: rotate(360deg); } }
.country-selector.weglot-default {
  display: none; }

/*************************************
 *
 *footer
 *
 ************************************** */
.dnone {
  display: none; }

.pen {
  pointer-events: none; }

#pagetop {
  transition: 0.4s ease;
  width: 80px;
  height: 80px;
  bottom: 55px;
  right: 40px;
  cursor: pointer;
  z-index: 999;
  position: fixed;
  background: linear-gradient(#FE985F, #FF596F);
  align-items: center;
  justify-content: center;
  display: flex;
  padding: 10px; }
  #pagetop.subpage {
    bottom: 55px; }

.rel_links {
  background: none;
  position: relative;
  z-index: 2; }
  .rel_links .ib {
    padding: 0px 0 30px !important; }
    .rel_links .ib h3 {
      text-align: center;
      font-size: 22px;
      margin: 30px 0 20px;
      color: #fff; }
  .rel_links .links {
    justify-content: space-between;
    display: flex;
    flex-wrap: wrap; }
    .rel_links .links .box {
      width: 21%; }
      .rel_links .links .box:nth-of-type(2), .rel_links .links .box:nth-of-type(3) {
        width: 27%; }
      .rel_links .links .box p {
        text-align: center;
        font-size: 17.2px;
        color: #fff;
        font-weight: bold;
        border-bottom: 1px solid #ccc;
        padding-bottom: 15px;
        position: relative;
        cursor: pointer;
        align-items: center;
        display: flex; }
        .rel_links .links .box p:after {
          content: "";
          font-family: "material icons";
          display: inline-block;
          margin-left: 15px;
          font-size: 22px; }
      .rel_links .links .box .inner {
        display: none; }
        .rel_links .links .box .inner a {
          display: block;
          font-size: 16px;
          font-weight: bold;
          color: #fff;
          padding: 7px 0;
          position: relative;
          align-items: center;
          display: flex; }
          .rel_links .links .box .inner a.sub:before {
            content: "";
            font-family: "material icons";
            transform: rotate(45deg);
            display: inline-block;
            font-size: 120%; }

footer {
  position: relative;
  z-index: 99; }
  footer .sub_nav {
    height: auto;
    position: relative;
    background: #123d83; }
    footer .sub_nav .close {
      display: none; }
    footer .sub_nav .search_container {
      display: none; }
    footer .sub_nav .ib {
      width: 1200px;
      padding: 60px 0; }
      footer .sub_nav .ib .bd {
        border-color: #174a82; }
      footer .sub_nav .ib p.copy {
        color: #fff; }
      footer .sub_nav .ib .policy a {
        color: #fff; }
      footer .sub_nav .ib .row a.logo .img {
        background: url(../img/logo_w.svg);
        background-size: cover; }
      footer .sub_nav .ib .row a.logo span {
        color: #fff; }
      footer .sub_nav .ib .df .col .lang p {
        color: #fff; }
      footer .sub_nav .ib .df .col a {
        color: #fff; }
        footer .sub_nav .ib .df .col a.contact {
          background: #fff;
          color: #123d83; }

@media (max-width: 1400px) {
  #fv .cycle {
    width: 740px;
    bottom: -600px; }
  #fv .pr_active {
    transform: scale(.9); }
  #fv .bg_cover {
    height: 480px;
    top: calc(50% - 240px); }
  #fv .ib .txt {
    position: relative;
    right: -80px;
    transform: scale(.88); } }

/*# sourceMappingURL=style.css.map */
