@charset "utf-8";
/*------------------------------------

top set css
underlayer set css

-------------------------------------*/


/* underlayer_box
----------------------------------------------------------- */
.underlayer_box {
  width: 91.768%;
  max-width: 1200px;
  padding: 10px 0 60px;
  margin: 0 auto;
  height: auto;
}
.underlayer_box .inner {
  padding: 0 50px 15px 50px;
}


/* TOP mvスタイル
----------------------------------------------------------- */
.mv {
  width: 100%;
  height: auto;
  overflow: hidden;
  border-bottom: 0 solid #F9F5F3;
  padding-bottom: 0;
}
.mv img {
  width: 100%;
  height: auto;
  position: relative;
}
.mv .inner {
  position: relative;
  width: 100vw;
  height: 100svh;
  min-height: 700px;
}
.mv .mv_ttl {
  position: absolute;
  top: 57%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  width: 85.768%;
  padding: 0 0;
  opacity: 0;
  animation: fadeInUp 1s ease-out forwards;
}
.mv .ttl_h1 {
  font-weight: 700;
  font-size: clamp(30px, 5vw, 70px);
  letter-spacing: 0.05em;
  line-height: 1.43;
  text-align: left;
  color: #fff;
  position: relative;
  display: inline-block;
}
.mv .ttl_h1::after {
  content: '';
  display: block;
  width: 100%;
  height: 1px;
  background-color: #fff;
  position: absolute;
  bottom: -9px;
  left: 0;
}
.mv_copy {
  font-weight: 700;
  font-size: clamp(12px, 3vw, 24px);
  letter-spacing: 0.05em;
  line-height: 1.63;
  color: #fff;
  margin: 40px 0 0 0;
}
/* video */
.video_area,
.video_area video {
  width: 100vw;
  height: 100vh;
  min-height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  -o-object-fit: cover;
  object-fit: cover;
  z-index: -1;
  overflow: hidden;
}
.video_area img{
  /* display: none; */
}
.video_area::before,
.video_area::after {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.video_area::after {
  background-color: rgba(0, 0, 0, 0.34);
}

/* 動画エリアの設定 */
.mv .inner .video_area {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* 動画の表示制御 */
.video_area .pc_video,
.video_area .sp_video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.video_area .pc_video {
  display: block;
}

.video_area .sp_video {
  display: none;
}

/* スマートフォン表示時の切り替え */
@media screen and (max-width: 767px) {
  .video_area,
  .video_area video {
    height: auto;
  }
  .video_area video{
    display: block;
  }
  .video_area {
    min-height: 450px; /* スマートフォン表示時の最小高さを設定 */
    height: auto;
  }
  .video_area .pc_video {
    display: none;
  }
  .video_area .sp_video {
    display: block;
  }
}


/* ポスター画像のスタイル */
.poster-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  opacity: 1; /* 初期値は1（完全に表示）に */
  transition: opacity 0.5s ease;
}

.poster-wrapper picture {
  display: block;
  width: 100%;
  height: 100%;
}

.poster-wrapper picture img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* 動画のスタイル */
.video_area {
  position: relative;
  width: 100%;
  height: 100%;
}

.video_area .pc_video,
.video_area .sp_video {
  position: relative;
  z-index: 2;
  width: 100%;
  height: 100%;
  object-fit: cover;
  background: transparent;
}

.video_area .pc_video.playing,
.video_area .sp_video.playing {
  opacity: 1;
}

/* レスポンシブ対応 */
.video_area .pc_video {
  display: block;
}

.video_area .sp_video {
  display: none;
}

/* ポスター画像が表示されるまでの背景色を設定 */
.video_area::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: transparent;
}

@media screen and (max-width: 1024px) {
  .video_area .pc_video {
    display: none;
  }
  .video_area .sp_video {
    display: block;
  }
}


/* TOP news
----------------------------------------------------------- */
.top_news {
  position: relative;
  padding-top: 0;
  padding-bottom: 100px;
  margin-top: 0;
}
.top_news .inner {
  width: 85.768%;
  /* max-width: unset; */
  padding: 44px 0 0;
  margin: 0 auto;
  height: auto;
}
.top_news .flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid #d7d7d7;
  padding: 0 0 44px 0;
}
.top_news .flex.news_list {
  padding: 0 0 0 0;
  margin: 0 0 44px 0;
}
.top_news .flex.news_list .ttl_h2 {
  padding: 0 0 0 0;
  width: calc(270px - 0px);
  display: flex;
  font-weight: 700;
}
.top_news .ttl_h2 {
  width: 270px;
}
.top_news .info_box_important {
  width: calc(100% - 270px);
}
.top_news .info_box {
  width: calc(100% - 270px);
}
.top_news .ttl_h2 {
  font-weight: 700;
  font-size: 33px;
  letter-spacing: 0em;
  line-height: 1.0;
  text-align: left;
  color: #b7054b;
  padding: 0 0 0 0;
  margin: 0 0;
}
.top_news .sub_txt {
  font-weight: normal;
  font-size: 12px;
  line-height: 24px;
  text-align: left;
  color: #333;
  margin: 20px 10% 0;
}
.top_news .info_box_important {
  margin: 0 0 0;
}
.top_news .info_box_important li:not(:first-child) {
  margin: 20px 0 0 0;
}
.top_news .info_box_important li a {
  font-weight: 600;
  font-size: 18px;
  line-height: 30px;
  text-align: left;
  text-decoration: none;
  color: #924;
  opacity: 1;
  transition: all .3s;
  position: relative;
  padding:  0 20px 0 0;
}
/**/
.top_news .info_box_important li.caution a{
  font-size: 18px;
  line-height: 30px;
  text-align: left;
  text-decoration: none;
  color: #fff;
  background-color: #924;
    padding:  0 5px 0 0;
}
.top_news .info_box_important li.caution  a .icon {
  display: inline-block;
  width: 16px;
  height: auto;
  margin: 0 0 0 10px;
  transition: all 0.3s ease;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translate(20px, -50%);
}
/**/
.top_news .info_box_important li a .icon {
  width: 16px;
  height: auto;
  display: inline-block;
  position: absolute;
  transition: all 0.3s ease;
  top: 50%;
  right: 0;
  transform: translate(0, -50%);
}
.top_news .info_box_important li a:hover .icon {
  right: -8px;
}
.top_news .info_box_important li a .icon img {
  width: 100%;
  height: auto;
  margin: 0;
  transform: translate(0, -40%);
}
.top_news .info_box li {
  border-top: 1px solid #C9C6C6;
}
.top_news .info_box li:first-child {
  border-top: 0px solid #C9C6C6;
}
.top_news .info_box li p {
  display: block;
  margin: 15px 0 16px;
  font-weight: normal;
  font-size: 18px;
  line-height: 30px;
  text-align: left;
  color: #000;
  opacity: 1;
  transition: opacity .3s;
}
.top_news .info_box li .link {
  font-weight: normal;
  font-size: 18px;
  line-height: 30px;
  text-align: left;
  color: #000;
  text-decoration: none;
}
.top_news .more_link {
  margin: 30px 10% 0;
  text-align: right;
}
.top_news .more_link a {
  width: auto;
  height: auto;
  padding: 10px 30px 10px 60px;
  border-radius: 10px;
  background: #fff;
  border: 1px solid #CC0066;
  display: inline-block;

  font-weight: 600;
  font-size: 16px;
  line-height: 30px;
  text-align: left;
  text-decoration: none;
  color: #B7054B;
  opacity: 1;
  transition: all .3s;
}
.top_news .more_link a .icon {
  position: relative;
  top: 0;
  display: inline-block;
  margin: 0 0 0 30px;
  width: 8px;
  height: 12px;
}
.top_news .more_link a .icon img.off {
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  right: 0;
  width: 8px;
  height: 12px;
  z-index: 1;
  opacity: 1;
  transition: opacity .3s;
}
.top_news .more_link a .icon img.ov {
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  right: 0;
  width: 8px;
  height: 12px;
  z-index: 0;
  opacity: 0;
  transition: opacity .3s;
}

.top_news .mgtop {
  margin: 60px 10% 0;
}

.top_news .info_box li .link a:hover {
  text-decoration: underline;
}
.top_news .info_box li .link a {
  position: relative;
  padding: 0 20px 0 0;
  color: #000;
  display: inline-block;
  text-decoration: none;
}
.top_news .info_box li .link a .icon {
  width: 16px;
  height: auto;
  display: inline-block;
  position: absolute;
  transition: all 0.3s ease;
  top: 50%;
  right: 0;
  transform: translate(0, -50%);
}
.top_news .info_box li .link:hover .icon {
  right: -10px;
}
.top_news .info_box li .link .icon img {
  width: 100%;
  height: auto;
  margin: 0;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translate(0, -50%);
}

.top_news .more_link a:hover {
  background: #CC0066;
  color: #fff;
  opacity: 1;
}
.top_news .ttl_h2 a {
  position: relative;
  padding: 0 20px 0 0;
}
.top_news .ttl_h2 a .icon {
  width: 16px;
  height: auto;
  display: inline-block;
  position: absolute;
  transition: all 0.3s ease;
  top: 50%;
  right: -8px;
  transform: translate(0, -50%);
}
.top_news .ttl_h2 a:hover .icon {
  right: -16px;
}
.top_news .ttl_h2 a .icon img {
  width: 100%;
  height: auto;
  margin: 0;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translate(0, -50%);
}
.top_news .ttl_h2 a:hover .icon img.off {
  opacity: 0;
}
.top_news .ttl_h2 a:hover .icon img.ov {
  opacity: 1;
}

.news_list {
  margin: 0 0;
}
.news_list .ttl_h2 {
  font-weight: 600;
  font-size: 24px;
  line-height: 1.0;
  text-align: left;
  color: #000;
  margin: 0 0 0 0;
  display: flex;
  align-items: center;
}
.news_list .ttl_h2 a {
  font-weight: normal;
  font-size: 14px;
  line-height: 24px;
  display: inline-block;
  text-decoration: none;
  color: #000;
  margin: 0 0 0 35px;
}




/* TOP radius_box
----------------------------------------------------------- */
.radius_box {
  padding-bottom: 180px;
}
.radius_box .inner {
  width: 85.768%;
  max-width: unset;
  padding: 0 30px 105px;
  margin: 0 auto;
  height: auto;
  position: relative;
}
.radius_box .inner:before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 50px;
  background: #fcf6f9;
  position: absolute;
  top: 0;
  left: -17.24%;
  z-index: -1;
}
.radius_box .ttl_h2 {
  font-weight: 700;
  font-size: 60px;
  letter-spacing: 0em;
  color: #000;
  position: relative;
  padding: 90px 0 63px;
}
.radius_box .ttl_h3 {
  font-weight: 700;
  font-size: 36px;
  letter-spacing: 0em;
  color: #b7054b;
}
.radius_box .txt {
  font-weight: normal;
  font-size: 18px;
  line-height: 34px;
  text-align: left;
  color: #000;
  margin: 10px 0 0;
}
.radius_box .ttl_h2 .jp {
  z-index: 2;
  position: relative;
}
.radius_box .ttl_h2 .en {
  font-weight: 700;
  font-size: 104px;
  letter-spacing: 0em;
  line-height: 1.0;
  color: #b7054b;
  position: absolute;
  bottom: 0;
  left: 0;
  opacity: 0.08;
  z-index: 1;
}
.radius_box .cont {
  margin: 0 0 0;
}
.radius_box .cont picture img {
  width: 103%;
  max-width: unset;
  margin: 0 0 0 0;
  position: relative;
  top: -20px;
  right: -11%;
}
.radius_box .cont .flex {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin: 2px 0 0 0;
  position: relative;
}
.radius_box .cont .flex_item {
  width: calc(59.5% - 25px);
  position: relative;
}
.radius_box .cont .flex_item.photo {
  width: calc(40.5% - 25px);
  position: relative;
}

.radius_box .cont .flex ul {
  margin: 24px 0 0 0;
  position: relative;
}
.radius_box .cont .flex ul li {
  width: calc(100% / 1 - 0px);
  margin: 50px 0 0;
  padding: 0 0 50px;
  border-bottom: 1px solid #f5dde7;
}
.radius_box .cont .flex ul li a {
  display: flex;
  align-items: center;
  width: 100%;
  font-weight: normal;
  font-size: 18px;
  line-height: 30px;
  text-align: left;
  color: #333;
  text-decoration: none;
  position: relative;
  padding: 18px 0 12px 0;
  opacity: 1;
  transition: opacity .3s;
}

.radius_box .cont .flex ul li a:hover {
  opacity: 0.6;
}

.radius_box .cont .flex ul li a .icon {
  position: absolute;
  top: 0;
  right: 0;
  width: 60px;
  height: 100%;
}
.radius_box .cont .flex ul li a .icon img {
  position: absolute;
  top: 56%;
  left: 0;
  transform: translate(0, -50%);
}
.link_box {
  margin: 50px 0 0 0;
  text-align: right;
}
.link_box a {
  display: inline-block;
  width: auto;
  padding: 15px 40px 15px 35px;
  font-size: 14px;
  letter-spacing: 0;
  font-weight: 600;
  text-align: center;
  text-decoration: none;
  color: #FFF;
  background: #000;
  position: relative;
}
.link_box a .icon {
  display: inline-block;
  margin: 0 0 0 10px;
  transition: all 0.3s ease;
  position: absolute;
  top: 14px;
  right: 14px;
}
.link_box a img {
  width: 16px;
  height: auto;
  filter: invert(100%) brightness(200%) saturate(0);
  margin: 0;
}
.link_box a:hover .icon {
  position: absolute;
  top: 14px;
  right: 8px;
}




/* TOP business
----------------------------------------------------------- */
.business_box {
  padding-bottom: 180px;
}
.business_box .inner {
  width: 85.768%;
  max-width: unset;
  padding: 0 30px 0;
  margin: 0 auto;
  height: auto;
  border-radius: 15px;
}
.business_box .ttl_h2 {
  font-weight: 700;
  font-size: 60px;
  letter-spacing: 0em;
  color: #000;
  position: relative;
}
.business_box .sub_txt {
  font-weight: normal;
  font-size: 18px;
  line-height: 1.4;
  text-align: left;
  color: #333;
  margin: 46px 0 0;
  padding: 0 0 30px;
}
.business_box .ttl_h2 .jp {
  z-index: 2;
  position: relative;
}
.business_box .ttl_h2 .en {
  font-weight: 600;
  font-size: 18px;
  letter-spacing: 0em;
  line-height: 1.0;
  color: #000;
  display: block;
}
.business_box .cont {
  margin: 50px 0 0;
}
.business_box .cont picture img {
  width: 113%;
  max-width: unset;
  margin: 0 0 0 0;
  position: relative;
  left: -17.24%;
}
.business_box .cont .flex {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin: 2px 0 0 0;
  position: relative;
}
.business_box .cont .flex_item {
  width: calc(33.5% - 25px);
  position: relative;
}
.business_box .cont .flex_item.photo {
  width: calc(68.5% - 25px);
  position: relative;
}
.business_box .cont .flex ul {
  margin: 0 0 0 0;
  position: relative;
}
.business_box .cont .flex ul li {
  width: calc(100% / 1 - 0px);
  margin: 0;
  padding: 0;
  border-bottom: 1px solid #d7d7d7;
}
.business_box .cont .flex ul li a {
  display: flex;
  align-items: center;
  width: calc(100% - 40px);
  font-weight: normal;
  font-size: 18px;
  line-height: 30px;
  text-align: left;
  color: #000;
  text-decoration: none;
  position: relative;
  padding: 12px 40px 12px 0;
  opacity: 1;
  transition: opacity .3s;
}

.business_box .cont .flex ul li a:hover {
  color: #B7054B;
}

.business_box .cont .flex ul li a .arrow {
  width: 15px;
  height: 14px;
  background: url(/assets/images/arrow_right_black.svg) no-repeat center center/contain;
  margin: 15px 10px 0 0;
  transition: all 0.3s ease;
  position: absolute;
  top: 6px;
  right: 0;
}

.business_box .cont .flex ul li a:hover .arrow {
  background-image: url(/assets/images/arrow_right_logocolor.svg);
  right: -9px;
}

.business_box .cont .flex ul li a .arrow img {
  position: absolute;
  top: 56%;
  left: 0;
  transform: translate(0, -50%);
}
.business_box .link_box {
  margin: 28px 0 0 0;
  text-align: left;
}
.business_box .link_box a  {
  display: inline-block;
  width: auto;
  padding: 15px 40px 15px 35px;
  font-size: 14px;
  letter-spacing: 0;
  font-weight: 600;
  text-align: center;
  text-decoration: none;
  color: #FFF;
  background: #000;
}
.business_box .link_box a .icon {
  display: inline-block;
  margin: 0 0 0 10px;
}
.business_box.link_box a img {
  width: 16px;
  height: auto;
  filter: invert(100%) brightness(200%) saturate(0);
}
.business_box .link_box a:hover .icon {
  position: absolute;
  top: 14px;
  right: 8px;
}


/* TOP otoiawase
----------------------------------------------------------- */
.otoiawase {
  padding-bottom: 200px;
  background: url(/assets/images/top_icon_bg_image.webp) no-repeat bottom -48px center;
  background-size: contain;
}
.otoiawase .inner {
  width: 85.768%;
  max-width: unset;
  padding: 0 30px 0;
  margin: 0 auto;
  height: auto;
  position: relative;
}
.otoiawase .ttl_h2 {
  font-weight: 700;
  font-size: 60px;
  letter-spacing: 0em;
  line-height: 1.4;
  text-align: center;
  color: #000;
  padding: 0 0 0 0;
  position: relative;
  font-feature-settings: "palt";
}
.otoiawase .ttl_h2 .en {
  font-weight: 600;
  font-size: 18px;
  letter-spacing: 0em;
  line-height: 1.4;
  display: block;
}
.otoiawase .ttl_h3 {
  font-weight: 700;
  font-size: 30px;
  letter-spacing: 0em;
  color: #b7054b;
}
.otoiawase .flex {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  background-color: rgba(255, 245, 249, 0.9);
  border-radius: 50px;
  padding: 70px 50px 120px;
  margin: 50px 0 0;
}
.otoiawase .cont {
}
.otoiawase .flex_item {
  width: calc(50% - 25px);
  text-align: center;
}
.otoiawase .flex_item .photo {
  width: 100%;
  height: auto;
  margin: 20px 0 0;
}
.otoiawase .flex_item .photo img {
  width: 100%;
  height: auto;
}
.otoiawase .flex_item .name {
  font-weight: 700;
  font-size: 24px;
  line-height: 1.2;
  color: #000;
  margin: 40px 0 0;
  font-feature-settings: "palt";
}
.otoiawase .flex_item .number,
.otoiawase .flex_item .number a {
  font-weight: 700;
  font-size: 50px;
  line-height: 1.0;
  margin: 5px 0 0;
  color: #b7054b;
  font-feature-settings: "palt";
}
.otoiawase .flex_item .number.fax {
  font-weight: 700;
  font-size: 30px;
  line-height: 1.2;
  margin: 10px 0 0 0;
  color: #000;
  font-feature-settings: "palt";
}
.otoiawase .flex_item .txt {
  font-weight: 600;
  font-size: 18px;
  line-height: 1.8;
  text-align: left;
  color: #000;
  margin: 38px 60px 0;
  font-feature-settings: unset;
}
.otoiawase .flex_item .number .number_fonts {
  font-family: "Oswald", serif;
  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased;
  font-optical-sizing: none;
  font-weight: 700;
  font-style: normal;
}
.otoiawase .flex_item .number .number_fonts a {
  color: #333;
}
.otoiawase .btn {
  width: calc(100% - 160px);
  height: auto;
  padding: 21px 20px;
  margin: 40px 0 0;
  background: #b7054b;
  border: 1px solid #b7054b;

  font-weight: 600;
  font-size: 22px;
  line-height: 1.2;
  text-align: center;
  color: #fff;
  text-decoration: none;
  display: inline-block;
  opacity: 1;
  transition: all .3s;
}
.otoiawase .btn .icon {
  position: relative;
  top: 0;
  display: inline-block;
  margin: 0 0 0 32px;
  width: 16px;
  height: 16px;
}
.otoiawase .btn .icon img.off {
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  right: 0;
  width: 16px;
  height: auto;
  filter: invert(100%) brightness(200%) saturate(0);
  z-index: 1;
  opacity: 1;
  transition: opacity .3s;
}
.otoiawase .btn .icon img.ov {
  position: absolute;
  top: 50%;
  transform: translate(0, -50%);
  right: 0;
  width: 16px;
  height: auto;
  z-index: 0;
  opacity: 0;
  transition: opacity .3s;
}

.otoiawase .btn:hover {
  background: #fff;
  color: #B7054B;
  opacity: 1;
}
.otoiawase .btn:hover .icon img.off {
  opacity: 0;
}
.otoiawase .btn:hover .icon img.ov {
  opacity: 1;
}



/* TOP jiko_center
----------------------------------------------------------- */
.jiko_center {
  background:#F9F5F3 url(/assets/images/line_bg_white.svg) no-repeat;
  background-position: -160px;
  background-size: cover;
  padding-bottom: 0;
}
.jiko_center .inner {
  margin: 80px auto 0;
  padding: 0 10% 94px;
  max-width: 960px;
  text-align: center;
}
.jiko_center .alert img {
  padding-top: 0;
  padding-bottom: 35px;
  margin-top: -32px;
}
.jiko_center .ttl_h2 {
  font-weight: 600;
  font-size: 30px;
  letter-spacing: 0.06em;
  line-height: 1.2;
  padding: 10px 0;
  text-align: center;
  color: #333;

  width: 314px;
  height: auto;
  border-radius: 30px;
  background: #fff;
  border: 3px solid #c06;
  margin: 0 auto;
}
.jiko_center .center_set {
  width: auto;
  height: auto;
  border-radius: 15px;
  background: #fff;
  margin: 36px 0 0;
  padding: 36px 0 47px;
}
.jiko_center .center_set .name {
  font-weight: 600;
  font-size: 24px;
  line-height: 46px;
  text-align: center;
  color: #333;
}
.jiko_center .number {
  margin: 14px 0 0;
}
.jiko_center .tel_number {
  display: block;
}
.jiko_center .fax_number {
  display: block;
  margin: 30px 0 0;
}
.jiko_center .fax_number img {
  margin: 0 34px 0 0;
}


/* TOP hoken_list
----------------------------------------------------------- */
.hoken_list {
}
.hoken_list .inner {
  margin: 120px auto 88px;
  padding: 0 10%;
  max-width: 960px;
}
.hoken_list .ttl_h2 {
  font-weight: 600;
  font-size: 36px;
  letter-spacing: 0.06em;
  line-height: 1.4;
  text-align: left;
  color: #333;
  padding: 0 0 0 20px;
  border-left: solid 5px #B7054B;
}
.hoken_list .sub_txt {
  font-weight: normal;
  font-size: 15px;
  line-height: 30px;
  text-align: left;
  color: #333;
  margin: 21px 0 0;
}
.hoken_list .logo_list {
  display: flex;
  flex-wrap: wrap;
  margin-left: -20px;
}
.hoken_list .logo_list li {
  width: calc( 33.33333% - 22px );
  margin-left: 20px;
  margin-bottom: 20px;
  border-radius: 10px;
  background: #fff;
  border: 1px solid #e8e8e8;
  box-shadow: 1px 2px 1px rgba(0, 0, 0, 0.16);
}
.hoken_list .logo_list li a {
  position: relative;
  display: block;
  text-align: center;
  padding: 12px 0;
  opacity: 1;
  transition: opacity .3s;
}
.hoken_list .logo_list li a:hover {
  opacity: 0.6;
}

.hoken_list .logo_list li .logo {
  width: 100%;
  height: auto;
}
.hoken_list .logo_list li .icon {
  position: absolute;
  top: 50%;
  right: 10px;
  transform: translate(0, -50%);
  width: 15px;
  display: flex;
}
.hoken_list .logo_list li .icon img {
  width: 15px;
  height: 15px;
}
.hoken_list .ttl_h3 {
  font-weight: 600;
  font-size: 24px;
  line-height: 46px;
  text-align: left;
  color: #333;
  margin: 22px 0 10px;
}
.hoken_list .ttl_h3.next_list_ttl {
  margin: 11px 0 10px;
}

/* TOP banner
----------------------------------------------------------- */
.banner {
  background:#fff url(/assets/images/line_bg_color.svg) no-repeat;
  background-position: -160px;
  padding-bottom: 0;
}
.banner .inner {
  margin: 0 auto;
  padding: 80px 10%;
  max-width: 960px;
}
.banner .inner a {
  display: block;
  opacity: 1;
  transition: opacity .3s;
}

.banner .inner a:hover {
  opacity: 0.6;
}

.banner img {
  width: 100%;
}

/* other
----------------------------------------------------------- */

/* for IE 11 */
@media all and (-ms-high-contrast:none) {
  *::-ms-backdrop, .info_txt:before {
    content: "...";
    background: #fff;
    width: 1em;
    padding: 0 2px;
    font-size: 14px;
    right: 0px;
    top: 66px;
  }
}
/* for Microsoft Edge */
@supports (-ms-ime-align:auto) {
  .info_txt:before {
    content: "...";
    background: #fff;
    width: 1em;
    padding: 0 2px;
    font-size: 14px;
    right: 0px;
    top: 66px;
  }
}

.panel.is-show {
  display: block;
  animation: anime 0.3s linear 0s;
  margin-bottom: 20px;
}

@keyframes anime {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes slideDownFadeIn {
  0% {
    opacity: 0;
    transform: translateY(-10px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

.bottom_nav_inner {
  animation: slideDownFadeIn 0.3s ease-out forwards;
}

/*------------------------------------
画面サイズ 768px 以上 1024px 未満
-------------------------------------*/
@media screen and (min-width: 768px) and (max-width: 1023px) {
  .daihyo_messe_box .photo img {
    margin-top: 0;
  }
  /* mv
  tablet mv_ttl
  ----------------------------------------------------------- */
  .mv .mv_ttl {
    position: absolute;
    top: unset;
    bottom: 46px;
    left: 50%;
    transform: translateY(0%) translateX(-50%);
    width: calc(100% - 50px);
    padding: 0 0;
    animation: fadeInUpSp 1s ease-out forwards;
  }
  .mv .ttl_h1 {
    font-weight: 700;
    /* font-size: 30px; */
    /* font-size: clamp(30px, 3vw, 30px); */
    letter-spacing: 0.05em;
    line-height: 1.43;
    text-align: left;
    color: #fff;
    position: relative;
    display: inline-block;
  }
  .mv .ttl_h1::after {
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    background-color: #fff;
    position: absolute;
    bottom: -18px;
    left: 0;
  }
  .mv_copy {
    font-weight: 700;
    /* font-size: 12px; */
    font-size: clamp(12px, 3vw, 24px);
    letter-spacing: 0.05em;
    line-height: 1.63;
    margin: 30px 0 0 0;
  }
  .mv .inner {
    min-height: 100svh;
    height: auto;
  }
  
  .video_area .pc_video {
    display: none;
  }
  
  .video_area .sp_video {
    display: block;
  }


  /* TOP
  tablet top_news
  ----------------------------------------------------------- */
  .top_news {
    position: relative;
    padding-top: 0;
    padding-bottom: 82px;
    margin-top: 0;
  }
  .top_news .inner {
    width: auto;
    max-width: 956px;
    padding: 73px 15px 0;
    margin: 0 10px;
    height: auto;
  }
  .top_news .flex {
    display: block;
    margin: 0 0 44px 0;
    padding: 0 0 0 0;
    border-bottom: 0px solid #d7d7d7;
    position: relative;
  }
  .top_news .flex.news_list {
    padding: 0 0 0 0;
    margin: 0 0 0 0;
    border-bottom: 1px solid #d7d7d7;
  }
  .top_news .flex.news_list .ttl_h2 {
    padding: 0 0 0 0;
    width: calc(100% - 0px);
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    font-weight: 700;
  }
  .top_news .ttl_h2 {
    width: auto;
    font-weight: 700;
    font-size: 28px;
    letter-spacing: 0em;
    line-height: 1.0;
    text-align: left;
    color: #b7054b;
  }
  .news_list .ttl_h2 {
    font-weight: 600;
    font-size: 28px;
    line-height: 1.0;
    text-align: left;
    color: #000;
    margin: 0 0 0 0;
    display: flex;
    align-items: center;
  }
  .news_list .ttl_h2 a {
    font-weight: 600;
    font-size: 11px;
    line-height: 24px;
    display: inline-block;
    text-decoration: none;
    color: #000;
    margin: 0 0 0 10px;
}
  .news_list .ttl_h2 .icon {
    width: 13px !important;
    height: 13px;
    margin: 0 10px 0 0;
    position: relative;
    top: -3px;
  }
  .news_list .ttl_h2 .icon img {
    width: 13px !important;
    height: auto;
  }
  .top_news .sub_txt {
    font-weight: normal;
    font-size: 11px;
    line-height: 18px;
    text-align: left;
    color: #333;
    margin: 17px 0 0;
  }
  .top_news .info_box_important {
    margin: 25px 0 0 0;
    width: calc(100% - 0px);
  }
  .top_news .info_box_important li {
    margin: 0 0 15px 0;
  }
  .top_news .info_box_important li:not(:first-child) {
    margin: 16px 0 0 0;
  }
  .top_news .info_box_important li a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-weight: 600;
    font-size: 16px;
    line-height: 28px;
    text-align: left;
    text-decoration: none;
    color: #924;
    opacity: 1;
    transition: opacity .3s;
  }
  .top_news .info_box_important li .icon {
    position: relative;
    width: 13px !important;
    height: auto;
  }
  .top_news .info_box_important li a .icon img {
    margin: 0 0 0 0;
    position: relative;
    width: 13px;
    height: auto;
  }
  .top_news .info_box {
    width: calc(100% - 0px);
    margin: 14px 0 0 0;
  }
  .top_news .info_box li:first-child {
    border-top: 1px solid #C9C6C6;
  }
  .top_news .info_box li p {
    display: block;
    margin: 19px 0 19px;
    font-weight: normal;
    font-size: 14px;
    line-height: 22px;
    text-align: left;
    color: #000;
    opacity: 1;
    transition: opacity .3s;
  }
  .top_news .info_box li .link {
    font-weight: normal;
    font-size: 14px;
    line-height: 22px;
    text-align: left;
    color: #000;
    text-decoration: none;
  }

  /* .top_news .info_box li p {
    display: block;
    margin: 19px 0 19px;
    font-weight: normal;
    font-size: 14px;
    line-height: 22px;
    text-align: left;
    color: #000;
    opacity: 1;
    transition: opacity .3s;
  } */

  .top_news .info_box li .link a {
    position: relative;
    padding: 0 20px 0 0;
    color: #000;
    display: flex;
    align-items: center;
    justify-content: space-between;
    text-decoration: none;
  }
  .top_news .info_box li .link a .icon {
    width: 13px;
    height: auto;
    display: inline-block;
    position: absolute;
    transition: all 0.3s ease;
    top: 50%;
    right: 0;
    transform: translate(0, -50%);
  }
  .top_news .info_box li .link .icon img {
    width: 100%;
    height: auto;
    margin: 0;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translate(0, -50%);
  }

  .top_news .more_link {
    margin: 18px 0 0 0;
    text-align: center;
  }
  .top_news .more_link a {
    width: auto;
    height: auto;
    padding: 11px 30px 11px 60px;
    border-radius: 10px;
    background: transparent;
    border: 1px solid #CC0066;
    display: inline-block;

    font-weight: 600;
    font-size: 16px;
    line-height: 30px;
    text-align: left;
    text-decoration: none;
    color: #B7054B;
  }
  .top_news .more_link a .icon {
    position: relative;
    top: 0;
    display: inline-block;
    margin: 0 0 0 30px;
    width: 8px;
    height: 12px;
  }
  .top_news .more_link a .icon img.off {
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    right: 0;
    width: 8px;
    height: 12px;
    z-index: 1;
  }
  .top_news .more_link a .icon img.ov {
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    right: 0;
    width: 8px;
    height: 12px;
    z-index: 0;
  }
  .top_news .more_link a:hover {
    background: #fff;
    color: #CC0066;
    opacity: 1;
  }
  .top_news .more_link a:hover .icon img.off {
    opacity: 1;
  }
  .top_news .more_link a:hover .icon img.ov {
    opacity: 0;
  }

  .top_news .mgtop {
    margin: 38px 0 0 0;
  }
  .top_news .more_link .js-morebtn .open {
    width: 80px;
    height: 30px;
  }
  .top_news .more_link .js-morebtn .close {
    width: 48px;
    height: 30px;
  }
  .top_news .more_link .js-morebtn .open {
    display: inline-block;
  }
  .top_news .more_link .js-morebtn .close {
    display: none;
  }
  .top_news .more_link .js-morebtn.is-show .open {
    display: none;
  }
  .top_news .more_link .js-morebtn.is-show .close {
    display: inline-block;
  }




  /* TOP 
  tablet radius_box
  ----------------------------------------------------------- */
  .radius_box {
    padding-bottom: 120px;
  }
  .radius_box .inner {
    width: auto;
    max-width: unset;
    padding: 0 20px 0;
    margin: 0 auto;
    height: auto;
    position: relative;
  }
  .radius_box .inner:before {
    content: '';
    display: block;
    width: 100%;
    height: 93%;
    border-radius: 20px;
    background: #fcf6f9;
    position: absolute;
    top: 0;
    left: -20px;
    z-index: -1;
  }
  .radius_box .ttl_h2 {
    font-weight: 700;
    font-size: 28px;
    letter-spacing: 0em;
    color: #000;
    position: relative;
    padding: 54px 0 26px;
  }
  .radius_box .ttl_h3 {
    font-weight: 700;
    font-size: 20px;
    letter-spacing: 0em;
    color: #b7054b;
  }
  .radius_box .txt {
    font-weight: normal;
    font-size: 16px;
    line-height: 1.8;
    text-align: left;
    color: #000;
    margin: 10px 0 0;
  }
  .radius_box .ttl_h2 .jp {
    z-index: 2;
    position: relative;
  }
  .radius_box .ttl_h2 .en {
    font-weight: 700;
    font-size: 45px;
    letter-spacing: 0em;
    line-height: 1.0;
    color: #b7054b;
    position: absolute;
    bottom: 0;
    left: 0;
    opacity: 0.08;
    z-index: 1;
  }
  .radius_box .cont {
    margin: 0;
  }
  .radius_box .cont picture img {
    width: 100%;
    margin: 29px 0 0 0;
  }
  .radius_box .cont .flex {
    display: block;
    align-items: flex-start;
    justify-content: space-between;
    margin: 24px 0 0 0;
    position: relative;
  }
  .radius_box .cont .flex_item {
    width: calc(100% - 20px);
    position: relative;
  }
  .radius_box .cont .flex_item.photo {
    width: auto;
    position: relative;
  }
  .radius_box .cont .flex_item.photo img {
    width: calc(100% + 20px);
    max-width: unset;
    margin: 60px 0 0 0;
    position: relative;
    top: 0;
    right: 0;
  }
  .radius_box .cont .flex ul {
    margin: 0;
    padding: 0;
  }
  .radius_box .cont .flex ul li {
    display: block;
    width: calc(100% / 1 - 0px);
    margin: 46px 0 0;
    padding: 0 0 46px;
    border-top: 0px solid #C9C6C6;
  }
  .radius_box .cont .flex ul li a {
    display: flex;
    align-items: center;
    width: 100%;
    font-weight: normal;
    font-size: 16px;
    line-height: 30px;
    text-align: left;
    color: #333;
    text-decoration: none;
    position: relative;
    padding: 12px 0 12px 35px;
    opacity: 1;
    transition: opacity .3s;
  }
  .radius_box .cont .flex ul li a .icon img {
    width: 18px;
    height: auto;
  }
  .radius_box .cont .flex ul li a .icon img {
    position: absolute;
    top: 50%;
    left: 0;
    transform: translate(0, -50%);
  }
  .link_box {
    margin: 20px 0 0 0;
    text-align: right;
  }
  .link_box a  {
    display: inline-block;
    width: auto;
    padding: 12px 32px 13px 27px;
    font-size: 11px;
    letter-spacing: 0;
    font-weight: 600;
    text-align: center;
    text-decoration: none;
    color: #FFF;
    background: #000;
  }
  .link_box a .icon {
    display: inline-block;
    margin: 0 0 0 10px;
  }
  .link_box a img {
    width: 13px;
    height: auto;
    filter: invert(100%) brightness(200%) saturate(0);
    position: relative;
    top: -1px;
  }




  /* TOP
  tablet business
  ----------------------------------------------------------- */
  .business_box {
    padding-bottom: 125px;
  }
  .business_box .inner {
    width: auto;
    max-width: unset;
    padding: 0 20px 0;
    margin: 0 auto;
    height: auto;
    border-radius: 15px;
  }
  .business_box .ttl_h2 {
    font-weight: 700;
    font-size: 28px;
    letter-spacing: 0em;
    color: #000;
    position: relative;
  }
  .business_box .sub_txt {
    font-weight: normal;
    font-size: 16px;
    line-height: 1.4;
    text-align: left;
    color: #333;
    margin: 46px 0 0;
    padding: 0 0 30px;
  }
  .business_box .ttl_h2 .jp {
    z-index: 2;
    position: relative;
  }
  .business_box .ttl_h2 .en {
    font-weight: 600;
    font-size: 14px;
    letter-spacing: 0em;
    line-height: 1.0;
    color: #000;
    display: block;
  }
  .business_box .cont {
    margin: 50px 0 0;
  }
  .business_box .cont picture img {
    width: calc(100% + 20px);
    max-width: unset;
    margin: 0 0 0 0;
    position: relative;
    left: -20px;
  }
  .business_box .cont .flex {
    display: block;
    align-items: flex-start;
    justify-content: space-between;
    margin: 2px 0 0 0;
    position: relative;
  }
  .business_box .cont .flex_item {
    width: calc(100% - 0px);
    position: relative;
  }
  .business_box .cont .flex_item.photo {
    width: calc(100% - 0px);
    position: relative;
  }
  .business_box .cont .flex ul {
    margin: 30px 0 0 0;
    position: relative;
  }
  .business_box .cont .flex ul li {
    width: calc(100% / 1 - 0px);
    margin: 0;
    padding: 0;
    border-bottom: 1px solid #d7d7d7;
  }
  .business_box .cont .flex ul li a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    font-weight: normal;
    font-size: 16px;
    line-height: 24px;
    text-align: left;
    color: #000;
    text-decoration: none;
    position: relative;
    padding: 12px 0 12px 0;
    opacity: 1;
    transition: opacity .3s;
  }

  .business_box .cont .flex ul li a:hover {
    color: #B7054B;
  }

  .business_box .cont .flex ul li a .arrow {
    width: 15px;
    height: 14px;
    background: url(/assets/images/arrow_right_black.svg) no-repeat center center/contain;
    margin: 0 0 0 0;
    transition: all 0.3s ease;
    position: relative;
    top: 0;
  }

  .business_box .cont .flex ul li a:hover .arrow {
    background-image: url(/assets/images/arrow_right_logocolor.svg);
    right: -9px;
  }

  .business_box .cont .flex ul li a .arrow img {
    position: absolute;
    top: 56%;
    left: 0;
    transform: translate(0, -50%);
  }
  .business_box .link_box {
    margin: 20px 0 0 0;
    text-align: right;
  }
  .business_box .link_box a  {
    display: inline-block;
    width: auto;
    padding: 12px 32px 13px 27px;
    font-size: 11px;
    letter-spacing: 0;
    font-weight: 600;
    text-align: center;
    text-decoration: none;
    color: #FFF;
    background: #000;
  }
  .business_box .link_box a .icon {
    display: inline-block;
    margin: 0 0 0 10px;
  }
  .business_box .link_box a img {
    width: 13px;
    height: auto;
    filter: invert(100%) brightness(200%) saturate(0);
    position: relative;
    top: -1px;
  }



  /* TOP
  tablet otoiawase
  ----------------------------------------------------------- */
  .otoiawase {
    padding-bottom: 140px;
    background: url(/assets/images/top_icon_bg_image_sp.webp) no-repeat bottom -14px center;
    background-size: contain;
  }
  .otoiawase .ttl_h2 {
    width: 100%;
    font-weight: 700;
    font-size: 28px;
    letter-spacing: 0;
    line-height: 1.4;
    text-align: center;
    color: #000;
    padding: 0 0 0 0;
    position: relative;
    height: auto;
  }
  .otoiawase .ttl_h2 .en {
    font-weight: 600;
    font-size: 14px;
    letter-spacing: 0;
    line-height: 1.4;
    display: block;
  }
  .otoiawase .cont {
    width: 100%;
    margin: 13px 0 0 0;
  }
  .otoiawase .inner {
    margin: 0 auto;
    padding: 0 20px 0;
    max-width: unset;
    display: block;
    width: auto;
    height: auto;
    position: relative;
  }
  .otoiawase .ttl_h2 .text {
    position: absolute;
    top: 80px;
    left: 50%;
    z-index: 1;
    transform: translate(-50%, 0);
  }
  .otoiawase .flex {
    display: block;
    align-items: flex-start;
    justify-content: space-between;
    background-color: rgba(244, 0, 102, 0.04);
    border-radius: 20px;
    padding: 50px 20px 65px;
    margin: 44px 0 0;
  }
  .otoiawase .ttl_h3 {
    font-weight: 700;
    font-size: 20px;
    letter-spacing: 0;
    color: #b7054b;
  }
  .otoiawase .flex_item {
    width: calc(100% - 0px);
    text-align: center;
  }
  .otoiawase .flex_item:nth-child(2) {
    margin-top: 44px;
    padding-top: 44px;
    border-top: 1px solid #f5dde7;
  }
  .otoiawase .flex_item .photo {
    width: 100%;
    height: auto;
    margin: 18px 0 0;
  }
  .otoiawase .flex_item .photo img {
    width: 100%;
    height: auto;
  }
  .otoiawase .flex_item .name {
    font-weight: 700;
    font-size: 20px;
    line-height: 1.2;
    color: #000;
    margin: 40px 0 0;
    font-feature-settings: "palt";
  }
  .otoiawase .flex_item .number,
  .otoiawase .flex_item .number a {
    font-weight: 700;
    font-size: 30px;
    line-height: 1.0;
    margin: 5px 0 0;
    color: #b7054b;
    text-decoration: none;
    font-feature-settings: "palt";
  }
  .otoiawase .flex_item .number.fax {
    font-weight: 700;
    font-size: 18px;
    line-height: 1.2;
    margin: 10px 0 0 0;
    color: #000;
    font-feature-settings: "palt";
  }

  .otoiawase .center_set .number .number_fonts {
    font-family: "Oswald", serif;
    -webkit-font-smoothing: antialiased;
    font-smoothing: antialiased;
    font-optical-sizing: none;
    font-weight: 700;
    font-style: normal;
  }
  .otoiawase .center_set .number .number_fonts a {
    color: #333;
    text-decoration: none;
  }
  .otoiawase .flex_item .txt {
    font-weight: normal;
    font-size: 14px;
    line-height: 1.8;
    letter-spacing: 0.04em;
    text-align: left;
    color: #000;
    margin: 15px 0 0;
    font-feature-settings: unset;
  }
  .otoiawase .btn {
    max-width: unset;
    width: auto;
    height: auto;
    padding: 20px 0 20px 0;
    margin: 15px 0 0;
    background: #b7054b;
    border: 1px solid #b7054b;
  
    font-weight: 600;
    font-size: 20px;
    line-height: 1.2;
    text-align: center;
    color: #fff;
    text-decoration: none;
    display: block;
    opacity: 1;
  }
  .otoiawase .btn .icon {
    position: relative;
    top: 0;
    display: inline-block;
    margin: 0 0 0 18px;
    width: 14px;
    height: 14px;
  }
  .otoiawase .btn .icon img.off {
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    right: 0;
    width: 14px;
    height: 14px;
    z-index: 1;
    opacity: 1;
  }
  .otoiawase .btn .icon img.ov {
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    right: 0;
    width: 14px;
    height: 14px;
    z-index: 0;
    opacity: 0;
  }
  .otoiawase .btn:hover {
    background: #B7054B;
    color: #fff;
    opacity: 1;
  }
  .otoiawase .btn:hover .icon img.off {
    opacity: 1;
  }
  .otoiawase .btn:hover .icon img.ov {
    opacity: 0;
  }

}



/*------------------------------------
画面サイズ 768px 未満 (SP)
-------------------------------------*/
@media screen and (max-width: 768px) {

  /*
  SP underlayer_box
  ----------------------------------------------------------- */
  .underlayer_box {
    /* width: 85.768%; */
    width: unset;
    max-width: unset;
    /* padding: 0 7.116%; */
    padding: 0;
    margin: 0 auto;
  }
  .underlayer_box .inner {
    padding: 0 50px 15px 50px;
  }

  /*
  SP TOPメイン
  ----------------------------------------------------------- */
  .mv {
    height: auto;
    border-bottom: 0 solid #F9F5F3;
  }
  .mv img {
    width: 100%;
    height: auto;
    opacity: 0;
  }
  .mv .inner {
    position: relative;
    width: 100vw;
    min-height: 470px !important; /* スマートフォン表示時の最小高さを設定 */
    height: auto;
    min-height: unset;
  }
  .mv .mv_ttl {
    position: absolute;
    top: unset;
    bottom: 46px;
    left: 50%;
    transform: translateY(0%) translateX(-50%);
    width: calc(100% - 50px);
    padding: 0 0;
    animation: fadeInUpSp 1s ease-out forwards;
  }
  .mv .ttl_h1 {
    font-weight: 700;
    font-size: clamp(30px, 3vw, 30px);
    letter-spacing: 0.05em;
    line-height: 1.43;
    text-align: left;
    color: #fff;
    position: relative;
    display: inline-block;
  }
  .mv .ttl_h1::after {
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    background-color: #fff;
    position: absolute;
    bottom: -18px;
    left: 0;
  }
  .mv_copy {
    font-weight: 700;
    font-size: clamp(12px, 3vw, 24px);
    letter-spacing: 0.05em;
    line-height: 1.63;
    margin: 30px 0 0 0;
  }
  .video_area {
    width: 100vw;
    height: unset;
    min-height: 470px;
    position: relative;
    top: 0;
    left: 0;
    -o-object-fit: cover;
    object-fit: cover;
    z-index: -1;
    overflow: hidden;
  }

  /*
  SP TOP news
  ----------------------------------------------------------- */
  .top_news {
    position: relative;
    padding-top: 0;
    padding-bottom: 82px;
    margin-top: 0;
  }
  .top_news .inner {
    width: auto;
    max-width: 956px;
    padding: 73px 15px 0;
    margin: 0 10px;
    height: auto;
  }
  .top_news .flex {
    display: block;
    margin: 0 0 44px 0;
    padding: 0 0 0 0;
    border-bottom: 0px solid #d7d7d7;
    position: relative;
  }
  .top_news .flex.news_list {
    padding: 0 0 0 0;
    margin: 0 0 0 0;
    border-bottom: 1px solid #d7d7d7;
  }
  .top_news .flex.news_list .ttl_h2 {
    padding: 0 0 0 0;
    width: calc(100% - 0px);
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    font-weight: 700;
  }
  .top_news .ttl_h2 {
    width: auto;
    font-weight: 700;
    font-size: 28px;
    letter-spacing: 0em;
    line-height: 1.0;
    text-align: left;
    color: #b7054b;
  }
  .news_list .ttl_h2 {
    font-weight: 600;
    font-size: 28px;
    line-height: 1.0;
    text-align: left;
    color: #000;
    margin: 0 0 0 0;
    display: flex;
    align-items: center;
  }
  .news_list .ttl_h2 a {
    font-weight: 600;
    font-size: 11px;
    line-height: 24px;
    display: inline-block;
    text-decoration: none;
    color: #000;
    margin: 0 0 0 10px;
}
  .news_list .ttl_h2 .icon {
    width: 13px !important;
    height: 13px;
    margin: 0 10px 0 0;
    position: relative;
    top: -3px;
  }
  .news_list .ttl_h2 .icon img {
    width: 13px !important;
    height: auto;
  }
  .top_news .sub_txt {
    font-weight: normal;
    font-size: 11px;
    line-height: 18px;
    text-align: left;
    color: #333;
    margin: 17px 0 0;
  }
  .top_news .info_box_important {
    margin: 25px 0 0 0;
    width: calc(100% - 0px);
  }
  .top_news .info_box_important li {
    margin: 0 0 15px 0;
  }
  .top_news .info_box_important li:not(:first-child) {
    margin: 16px 0 0 0;
  }
  .top_news .info_box_important li a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-weight: 600;
    font-size: 16px;
    line-height: 28px;
    text-align: left;
    text-decoration: none;
    color: #924;
    opacity: 1;
    transition: opacity .3s;
  }
  .top_news .info_box_important li .icon {
    position: relative;
    width: 13px !important;
    height: auto;
  }
  .top_news .info_box_important li a .icon img {
    margin: 0 0 0 0;
    position: relative;
    width: 13px;
    height: auto;
  }
  .top_news .info_box {
    width: calc(100% - 0px);
    margin: 14px 0 0 0;
  }
  .top_news .info_box li:first-child {
    border-top: 1px solid #C9C6C6;
  }
  .top_news .info_box li p {
    display: block;
    margin: 19px 0 19px;
    font-weight: normal;
    font-size: 14px;
    line-height: 22px;
    text-align: left;
    color: #000;
    opacity: 1;
    transition: opacity .3s;
  }
  .top_news .info_box li .link {
    font-weight: normal;
    font-size: 14px;
    line-height: 22px;
    text-align: left;
    color: #000;
    text-decoration: none;
  }

  .top_news .info_box li .link a {
    position: relative;
    padding: 0 20px 0 0;
    color: #000;
    display: flex;
    align-items: center;
    justify-content: space-between;
    text-decoration: none;
  }
  .top_news .info_box li .link a .icon {
    width: 13px;
    height: auto;
    display: inline-block;
    position: absolute;
    transition: all 0.3s ease;
    top: 50%;
    right: 0;
    transform: translate(0, -50%);
  }
  .top_news .info_box li .link .icon img {
    width: 100%;
    height: auto;
    margin: 0;
    position: absolute;
    top: 50%;
    right: 0;
    transform: translate(0, -50%);
  }

  .top_news .more_link {
    margin: 18px 0 0 0;
    text-align: center;
  }
  .top_news .more_link a {
    width: auto;
    height: auto;
    padding: 11px 30px 11px 60px;
    border-radius: 10px;
    background: transparent;
    border: 1px solid #CC0066;
    display: inline-block;

    font-weight: 600;
    font-size: 16px;
    line-height: 30px;
    text-align: left;
    text-decoration: none;
    color: #B7054B;
  }
  .top_news .more_link a .icon {
    position: relative;
    top: 0;
    display: inline-block;
    margin: 0 0 0 30px;
    width: 8px;
    height: 12px;
  }
  .top_news .more_link a .icon img.off {
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    right: 0;
    width: 8px;
    height: 12px;
    z-index: 1;
  }
  .top_news .more_link a .icon img.ov {
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    right: 0;
    width: 8px;
    height: 12px;
    z-index: 0;
  }
  .top_news .more_link a:hover {
    background: #fff;
    color: #CC0066;
    opacity: 1;
  }
  .top_news .more_link a:hover .icon img.off {
    opacity: 1;
  }
  .top_news .more_link a:hover .icon img.ov {
    opacity: 0;
  }

  .top_news .mgtop {
    margin: 38px 0 0 0;
  }
  .top_news .more_link .js-morebtn .open {
    width: 80px;
    height: 30px;
  }
  .top_news .more_link .js-morebtn .close {
    width: 48px;
    height: 30px;
  }
  .top_news .more_link .js-morebtn .open {
    display: inline-block;
  }
  .top_news .more_link .js-morebtn .close {
    display: none;
  }
  .top_news .more_link .js-morebtn.is-show .open {
    display: none;
  }
  .top_news .more_link .js-morebtn.is-show .close {
    display: inline-block;
  }


  /* TOP 
  SP radius_box
  ----------------------------------------------------------- */
  .radius_box {
    padding-bottom: 120px;
  }
  .radius_box .inner {
    width: auto;
    max-width: unset;
    padding: 0 20px 0;
    margin: 0 auto;
    height: auto;
    position: relative;
  }
  .radius_box .inner:before {
    content: '';
    display: block;
    width: 100%;
    height: 93%;
    border-radius: 20px;
    background: #fcf6f9;
    position: absolute;
    top: 0;
    left: -20px;
    z-index: -1;
  }
  .radius_box .ttl_h2 {
    font-weight: 700;
    font-size: 28px;
    letter-spacing: 0em;
    color: #000;
    position: relative;
    padding: 54px 0 26px;
  }
  .radius_box .ttl_h3 {
    font-weight: 700;
    font-size: 20px;
    letter-spacing: 0em;
    color: #b7054b;
  }
  .radius_box .txt {
    font-weight: normal;
    font-size: 16px;
    line-height: 1.8;
    text-align: left;
    color: #000;
    margin: 10px 0 0;
  }
  .radius_box .ttl_h2 .jp {
    z-index: 2;
    position: relative;
  }
  .radius_box .ttl_h2 .en {
    font-weight: 700;
    font-size: 45px;
    letter-spacing: 0em;
    line-height: 1.0;
    color: #b7054b;
    position: absolute;
    bottom: 0;
    left: 0;
    opacity: 0.08;
    z-index: 1;
  }
  .radius_box .cont {
    margin: 0;
  }
  .radius_box .cont picture img {
    width: 100%;
    margin: 29px 0 0 0;
  }
  .radius_box .cont .flex {
    display: block;
    align-items: flex-start;
    justify-content: space-between;
    margin: 24px 0 0 0;
    position: relative;
  }
  .radius_box .cont .flex_item {
    width: calc(100% - 20px);
    position: relative;
  }
  .radius_box .cont .flex_item.photo {
    width: auto;
    position: relative;
  }
  .radius_box .cont .flex_item.photo img {
    width: calc(100% + 20px);
    max-width: unset;
    margin: 60px 0 0 0;
    position: relative;
    top: 0;
    right: 0;
  }
  .radius_box .cont .flex ul {
    margin: 0;
    padding: 0;
  }
  .radius_box .cont .flex ul li {
    display: block;
    width: calc(100% / 1 - 0px);
    margin: 46px 0 0;
    padding: 0 0 46px;
    border-top: 0px solid #C9C6C6;
  }
  .radius_box .cont .flex ul li a {
    display: flex;
    align-items: center;
    width: 100%;
    font-weight: normal;
    font-size: 16px;
    line-height: 30px;
    text-align: left;
    color: #333;
    text-decoration: none;
    position: relative;
    padding: 12px 0 12px 35px;
    opacity: 1;
    transition: opacity .3s;
  }
  .radius_box .cont .flex ul li a .icon img {
    width: 18px;
    height: auto;
  }
  .radius_box .cont .flex ul li a .icon img {
    position: absolute;
    top: 50%;
    left: 0;
    transform: translate(0, -50%);
  }
  .link_box {
    margin: 20px 0 0 0;
    text-align: right;
  }
  .link_box a  {
    display: inline-block;
    width: auto;
    padding: 12px 32px 13px 27px;
    font-size: 11px;
    letter-spacing: 0;
    font-weight: 600;
    text-align: center;
    text-decoration: none;
    color: #FFF;
    background: #000;
  }
  .link_box a .icon {
    display: inline-block;
    margin: 0 0 0 10px;
  }
  .link_box a img {
    width: 13px;
    height: auto;
    filter: invert(100%) brightness(200%) saturate(0);
    position: relative;
    top: -1px;
  }


  /* TOP
  SP business
  ----------------------------------------------------------- */
  .business_box {
    padding-bottom: 125px;
  }
  .business_box .inner {
    width: auto;
    max-width: unset;
    padding: 0 20px 0;
    margin: 0 auto;
    height: auto;
    border-radius: 15px;
  }
  .business_box .ttl_h2 {
    font-weight: 700;
    font-size: 28px;
    letter-spacing: 0em;
    color: #000;
    position: relative;
  }
  .business_box .sub_txt {
    font-weight: normal;
    font-size: 16px;
    line-height: 1.4;
    text-align: left;
    color: #333;
    margin: 46px 0 0;
  }
  .business_box .ttl_h2 .jp {
    z-index: 2;
    position: relative;
  }
  .business_box .ttl_h2 .en {
    font-weight: 600;
    font-size: 14px;
    letter-spacing: 0em;
    line-height: 1.0;
    color: #000;
    display: block;
  }
  .business_box .cont {
    margin: 30px 0 0;
  }
  .business_box .cont picture img {
    width: calc(100% + 20px);
    max-width: unset;
    margin: 0 0 0 0;
    position: relative;
    left: -20px;
  }
  .business_box .cont .flex {
    display: block;
    align-items: flex-start;
    justify-content: space-between;
    margin: 2px 0 0 0;
    position: relative;
  }
  .business_box .cont .flex_item {
    width: calc(100% - 0px);
    position: relative;
  }
  .business_box .cont .flex_item.photo {
    width: calc(100% - 0px);
    position: relative;
  }
  .business_box .cont .flex ul {
    margin: 30px 0 0 0;
    position: relative;
  }
  .business_box .cont .flex ul li {
    width: calc(100% / 1 - 0px);
    margin: 0;
    padding: 0;
    border-bottom: 1px solid #d7d7d7;
  }
  .business_box .cont .flex ul li a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    font-weight: normal;
    font-size: 16px;
    line-height: 24px;
    text-align: left;
    color: #000;
    text-decoration: none;
    position: relative;
    padding: 12px 0 12px 0;
    opacity: 1;
    transition: opacity .3s;
  }

  .business_box .cont .flex ul li a:hover {
    color: #B7054B;
  }

  .business_box .cont .flex ul li a .arrow {
    width: 15px;
    height: 14px;
    background: url(/assets/images/arrow_right_black.svg) no-repeat center center/contain;
    margin: 0 0 0 0;
    transition: all 0.3s ease;
    position: relative;
    top: 0;
  }

  .business_box .cont .flex ul li a:hover .arrow {
    background-image: url(/assets/images/arrow_right_logocolor.svg);
    right: -9px;
  }

  .business_box .cont .flex ul li a .arrow img {
    position: absolute;
    top: 56%;
    left: 0;
    transform: translate(0, -50%);
  }
  .business_box .link_box {
    margin: 20px 0 0 0;
    text-align: right;
  }
  .business_box .link_box a  {
    display: inline-block;
    width: auto;
    padding: 12px 32px 13px 27px;
    font-size: 11px;
    letter-spacing: 0;
    font-weight: 600;
    text-align: center;
    text-decoration: none;
    color: #FFF;
    background: #000;
  }
  .business_box .link_box a .icon {
    display: inline-block;
    margin: 0 0 0 10px;
  }
  .business_box .link_box a img {
    width: 13px;
    height: auto;
    filter: invert(100%) brightness(200%) saturate(0);
    position: relative;
    top: -1px;
  }



  /* TOP
  SP otoiawase
  ----------------------------------------------------------- */
  .otoiawase {
    padding-bottom: 60px;
    background: url(/assets/images/top_icon_bg_image_sp.webp) no-repeat bottom -14px center;
    background-size: contain;
  }
  .otoiawase .ttl_h2 {
    width: 100%;
    font-weight: 700;
    font-size: 28px;
    letter-spacing: 0;
    line-height: 1.4;
    text-align: center;
    color: #000;
    padding: 0 0 0 0;
    position: relative;
    height: auto;
  }
  .otoiawase .ttl_h2 .en {
    font-weight: 600;
    font-size: 14px;
    letter-spacing: 0;
    line-height: 1.4;
    display: block;
  }
  .otoiawase .cont {
    width: 100%;
    margin: 13px 0 0 0;
  }
  .otoiawase .inner {
    margin: 0 auto;
    padding: 0 20px 0;
    max-width: unset;
    display: block;
    width: auto;
    height: auto;
    position: relative;
  }
  .otoiawase .ttl_h2 .text {
    position: absolute;
    top: 80px;
    left: 50%;
    z-index: 1;
    transform: translate(-50%, 0);
  }
  .otoiawase .flex {
    display: block;
    align-items: flex-start;
    justify-content: space-between;
    background-color: rgba(244, 0, 102, 0.04);
    border-radius: 20px;
    padding: 50px 20px 65px;
    margin: 44px 0 0;
  }
  .otoiawase .ttl_h3 {
    font-weight: 700;
    font-size: 20px;
    letter-spacing: 0;
    color: #b7054b;
  }
  .otoiawase .flex_item {
    width: calc(100% - 0px);
    text-align: center;
  }
  .otoiawase .flex_item:nth-child(2) {
    margin-top: 44px;
    padding-top: 44px;
    border-top: 1px solid #f5dde7;
  }
  .otoiawase .flex_item .photo {
    width: 100%;
    height: auto;
    margin: 18px 0 0;
  }
  .otoiawase .flex_item .photo img {
    width: 100%;
    height: auto;
  }
  .otoiawase .flex_item .name {
    font-weight: 700;
    font-size: 20px;
    line-height: 1.2;
    color: #000;
    margin: 40px 0 0;
    font-feature-settings: "palt";
  }
  .otoiawase .flex_item .number,
  .otoiawase .flex_item .number a {
    font-weight: 700;
    font-size: 30px;
    line-height: 1.0;
    margin: 5px 0 0;
    color: #b7054b;
    text-decoration: none;
    font-feature-settings: "palt";
  }
  .otoiawase .flex_item .number.fax {
    font-weight: 700;
    font-size: 18px;
    line-height: 1.2;
    margin: 10px 0 0 0;
    color: #000;
    font-feature-settings: "palt";
  }

  .otoiawase .center_set .number .number_fonts {
    font-family: "Oswald", serif;
    -webkit-font-smoothing: antialiased;
    font-smoothing: antialiased;
    font-optical-sizing: none;
    font-weight: 700;
    font-style: normal;
  }
  .otoiawase .center_set .number .number_fonts a {
    color: #333;
    text-decoration: none;
  }
  .otoiawase .flex_item .txt {
    font-weight: normal;
    font-size: 14px;
    line-height: 1.8;
    letter-spacing: 0.04em;
    text-align: left;
    color: #000;
    margin: 15px 0 0;
    font-feature-settings: unset;
  }
  .otoiawase .btn {
    max-width: unset;
    width: auto;
    height: auto;
    padding: 20px 0 20px 0;
    margin: 15px 0 0;
    background: #b7054b;
    border: 1px solid #b7054b;
  
    font-weight: 600;
    font-size: 20px;
    line-height: 1.2;
    text-align: center;
    color: #fff;
    text-decoration: none;
    display: block;
    opacity: 1;
  }
  .otoiawase .btn .icon {
    position: relative;
    top: 0;
    display: inline-block;
    margin: 0 0 0 18px;
    width: 14px;
    height: 14px;
  }
  .otoiawase .btn .icon img.off {
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    right: 0;
    width: 14px;
    height: 14px;
    z-index: 1;
    opacity: 1;
  }
  .otoiawase .btn .icon img.ov {
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    right: 0;
    width: 14px;
    height: 14px;
    z-index: 0;
    opacity: 0;
  }
  .otoiawase .btn:hover {
    background: #B7054B;
    color: #fff;
    opacity: 1;
  }
  .otoiawase .btn:hover .icon img.off {
    opacity: 1;
  }
  .otoiawase .btn:hover .icon img.ov {
    opacity: 0;
  }



  /* TOP
  SP jiko_center
  ----------------------------------------------------------- */
  .jiko_center {
    background:#F9F5F3 url(/assets/images/line_bg_white.svg) no-repeat;
    background-position: -160px;
    background-size: cover;
  }
  .jiko_center .inner {
    margin: 80px 10px 0;
    padding: 0 0 52px;
    max-width: 960px;
    text-align: left;
  }
  .jiko_center .alert {
    text-align: center;
  }
  .jiko_center .alert img {
    padding-top: 0;
    padding-bottom: 18px;
    margin-top: -32px;
  }
  .jiko_center .center_set {
    width: auto;
    height: auto;
    border-radius: 15px;
    background: #fff;
    margin: 30px 0 0;
    padding: 20px 15px 30px;
  }
  .jiko_center .number {
    margin: 15px 0 0;
    text-align: center;
  }
  .jiko_center .tel_number {
    display: block;
  }
  .jiko_center .tel_number img {
    width: 99.5%;
    max-width: 390px;
  }
  .jiko_center .fax_number {
    display: block;
    margin: 24px 0 0;
    text-align: center;
  }
  .jiko_center .fax_number img {
    margin: 0 0 0 5px;
  }


  /* TOP 
  SP hoken_list
  ----------------------------------------------------------- */
  .hoken_list .ttl_h3 {
    font-weight: 600;
    font-size: 18px;
    line-height: 1.2;
    text-align: left;
    color: #333;
    margin: 22px 0 12px;
  }
  .hoken_list .ttl_h3 {
    font-weight: 600;
    font-size: 18px;
    line-height: 1.2;
    text-align: left;
    color: #333;
    margin: 22px 0 12px;
  }
  .hoken_list .sub_txt {
    font-weight: normal;
    font-size: 11px;
    line-height: 18px;
    text-align: left;
    color: #333;
    margin: 19px 0 0;
  }
  .hoken_list .inner {
    margin: 43px 10px 20px;
    padding: 0 15px;
    max-width: 960px;
  }
  .hoken_list .logo_list {
    display: flex;
    flex-wrap: wrap;
    margin-left: -20px;
  }
  .hoken_list .logo_list li {
    width: calc( 50% - 22px );
    margin-left: 20px;
    margin-bottom: 23px;
    border-radius: 10px;
    background: #fff;
    border: 1px solid #e8e8e8;
    box-shadow: 1px 2px 1px rgba(0, 0, 0, 0.16);
  }
  .hoken_list .logo_list li a {
    position: relative;
    display: block;
    text-align: center;
    padding: 12px 0;
  }
  .hoken_list .logo_list li .logo {
    width: 100%;
    height: auto;
  }
  .hoken_list .logo_list li .icon {
    position: absolute;
    top: 50%;
    right: 10px;
    transform: translate(0, -50%);
    width: 15px;
    display: flex;
  }
  .hoken_list .logo_list li .icon img {
    width: 15px;
    height: 15px;
  }

  /* TOP 
  SP banner
  ----------------------------------------------------------- */
  .hoken_list .ttl_h2 {
    font-weight: 600;
    font-size: 24px;
    letter-spacing: 0.00em;
    line-height: 1.4;
    text-align: left;
    color: #333;
    padding: 0 0 0 10px;
    border-left: solid 5px #B7054B;
  }
  .banner .inner {
    margin: 0 10px;
    padding: 93px 15px;
    max-width: 960px;
  }

}/* END SP */

/*--------------------------------------------------------------------------------------
  iPhone5 320px
--------------------------------------------------------------------------------------*/
@media screen and (max-width: 320px) {

}/* END iPhone5 */

.pc_menu .menu_li a:hover {
  color: #b7054b;
}

@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translateY(-50%) translateX(-50%) translateY(30px);
  }
  100% {
    opacity: 1;
    transform: translateY(-50%) translateX(-50%) translateY(0);
  }
}

@keyframes fadeInUpSp {
  0% {
    opacity: 0;
    transform: translateY(0%) translateX(-50%) translateY(30px);
  }
  100% {
    opacity: 1;
    transform: translateY(0%) translateX(-50%) translateY(0);
  }
}