@charset "UTF-8";
/* box-sizing: border-box;を設定 */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* フォントサイズの拡大を防ぐ */
html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
  word-break: break-word;
}

/* リストのスタイルを削除、これはデフォルトのスタイルが削除されることを示唆します */
ul,
ol {
  list-style: none;
}

/* 見出しやインタラクティブ要素のline-heightを設定 */
h1,
h2,
h3,
h4,
button,
input,
label {
  line-height: inherit;
}

/* 画像の扱いを簡単にする */
img,
picture {
  max-width: 100%;
  display: block;
  height: auto;
}

/* inputやbuttonなどのfontは継承 */
input,
button,
textarea,
select {
  font: inherit;
}

table {
  border-collapse: collapse;
}

body,
button,
input,
textarea {
  font-family: "Noto Sans JP", sans-serif;
}

html,
body {
  position: relative;
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
  min-height: 100vh;
}

html {
  font-size: 62.5%;
  scroll-padding-top: 120px;
  overflow-y: scroll;
}

body {
  font-size: 16px;
  line-height: 1.6875;
  color: #333;
  font-family: "BIZ UDPGothic", sans-serif;
  position: relative;
}

body.no-scroll {
  overflow: hidden;
  max-height: 100vh;
}

:where(body, button, input, textarea, select) {
  color: #333;
  font-size: inherit;
  line-height: inherit;
}

label,
select,
input[type=checkbox],
input[type=radio],
button {
  cursor: pointer;
}

.mb5 {
  margin-bottom: 5px;
}

.mb10 {
  margin-bottom: 10px;
}

.mb15 {
  margin-bottom: 15px;
}

.mb20 {
  margin-bottom: 20px;
}

.mb25 {
  margin-bottom: 25px;
}

.mb30 {
  margin-bottom: 30px;
}

.mb35 {
  margin-bottom: 35px;
}

.mb40 {
  margin-bottom: 40px;
}

.mb45 {
  margin-bottom: 45px;
}

.mb50 {
  margin-bottom: 50px;
}

.mb55 {
  margin-bottom: 55px;
}

.mb60 {
  margin-bottom: 60px;
}

.mb65 {
  margin-bottom: 65px;
}

.mb70 {
  margin-bottom: 70px;
}

.mb75 {
  margin-bottom: 75px;
}

.mb80 {
  margin-bottom: 80px;
}

.mb85 {
  margin-bottom: 85px;
}

.mb90 {
  margin-bottom: 90px;
}

.mb95 {
  margin-bottom: 95px;
}

.mb100 {
  margin-bottom: 100px;
}

.mb110 {
  margin-bottom: 110px;
}

.mb120 {
  margin-bottom: 120px;
}

.mb125 {
  margin-bottom: 125px;
}

.mb130 {
  margin-bottom: 130px;
}

.mb140 {
  margin-bottom: 140px;
}

.mb150 {
  margin-bottom: 150px;
}

.mb160 {
  margin-bottom: 160px;
}

.mb170 {
  margin-bottom: 170px;
}

.mb180 {
  margin-bottom: 180px;
}

.mb190 {
  margin-bottom: 190px;
}

.mb200 {
  margin-bottom: 200px;
}

.centerBox {
  max-width: 1082px;
  margin-inline: auto;
  padding-inline: 25px;
}

html::-webkit-scrollbar {
  width: 12px;
}

html::-webkit-scrollbar-track {
  width: 12px;
  background-color: #eee;
}

html::-webkit-scrollbar-thumb {
  background-color: #ccc;
}
.spOnly {
  display: none;
}

.pcOnly {
  display: block;
}

/*-----------------------
        fontsize
------------------------*/
.fs18 {
  font-size: 18px;
}

.fs19 {
  font-size: 19px;
}

.fs20 {
  font-size: 20px;
}

.fs21 {
  font-size: 21px;
}

.fs22 {
  font-size: 22px;
}

.fs23 {
  font-size: 23px;
}

.fs24 {
  font-size: 24px;
}

.fs25 {
  font-size: 25px;
}

.fs26 {
  font-size: 26px;
}

.fs27 {
  font-size: 27px;
}

.fs28 {
  font-size: 28px;
}

.fs29 {
  font-size: 29px;
}

.fs30 {
  font-size: 30px;
}

.fs31 {
  font-size: 31px;
}

.fs32 {
  font-size: 32px;
}

.fs33 {
  font-size: 33px;
}

.fs34 {
  font-size: 34px;
}

.fs35 {
  font-size: 35px;
}

.fs36 {
  font-size: 36px;
}

.fs37 {
  font-size: 37px;
}

.fs38 {
  font-size: 38px;
}

.fs39 {
  font-size: 39px;
}

.fs40 {
  font-size: 40px;
}

/*-----------------------
          fv
------------------------*/
.fv {
  width: 100%;
  height: 174px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #F5F5F5;
}

.fv_title {
  font-size: 32px;
  font-weight: bold;
}

.main {
  width: 100%;
}

.page_outer {
  max-width: 1440px;
  margin: 0 auto;
  position: relative;
  padding: 80px 75px 180px;
}

/*-----------------------
      breadcrumb
------------------------*/
.breadcrumb {
  position: absolute;
  top: 25px;
  left: 80px;
  width: calc(100% - 150px);
  -webkit-overflow-scrolling: touch;
  overflow-x: auto;
  display: flex;
  justify-content: left;
  align-items: center;
  gap: 36px;
}

.crumbli {
  font-size: 13px;
  line-height: 1;
  color: #7B7B7B;
  white-space: nowrap;
  position: relative;
}
.crumbli::after {
  display: block;
  position: absolute;
  content: "";
  top: 50%;
  right: -21px;
  width: 6px;
  aspect-ratio: 4.33/8.66;
  transform: translateY(-50%);
  background-image: url(../images/crumb_arrow.svg);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}
.crumbli:nth-last-child(1)::after {
  content: none;
}

/*-----------------------
      Common title
------------------------*/
.title_h2 {
  background-color: #F5F5F5;
  font-size: 24px;
  font-weight: bold;
  width: 100%;
  line-height: 1.4;
  padding: 33px 35px;
  margin-bottom: 30px;
  position: relative;
}
.title_h2.mb60 {
  margin-bottom: 60px;
}
.title_h2::before {
  display: block;
  content: "";
  position: absolute;
  width: 8px;
  height: 40px;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  background: linear-gradient(to bottom, #BB1C21 0%, #BB1C21 50%, #000 50%, #000 100%);
}

.title_h3 {
  font-size: 24px;
  font-weight: bold;
  padding-bottom: 16px;
  width: 100%;
  line-height: 1.4;
  position: relative;
  margin-bottom: 30px;
}
.title_h3::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 3px;
  bottom: 0;
  left: 0;
  background: linear-gradient(to right, #BB1C21 0px, #BB1C21 57px, #D9D9D9 57px, #D9D9D9 100%);
}

.title_h4 {
  font-size: 20px;
  font-weight: bold;
  line-height: 1.4;
  padding-left: 18px;
  margin-bottom: 20px;
  position: relative;
}
.title_h4::before {
  position: absolute;
  width: 8px;
  height: 28px;
  content: "";
  top: calc(50% - 14px);
  left: 0;
  background-color: #BB1C21;
}

.title_h5 {
  font-size: 24px;
  font-weight: bold;
}

/*-----------------------
      Table common
------------------------*/
.table_outer {
  display: block;
  width: 100%;
  overflow-x: auto;
}

.table {
  width: 100%;
  border-collapse: collapse;
}

tr {
  width: 100%;
}

th, td {
  border: 1px solid #D9D9D9;
  padding: 15px;
}

th {
  font-weight: bold;
  background-color: #F5F5F5;
}

/*-----------------------
    Image (width 100%)
------------------------*/
.img_basic {
  display: block;
  width: 100%;
  object-fit: cover;
  object-position: center;
}

/*-----------------------
          Link
------------------------*/
.link {
  width: fit-content;
  color: #BB1C21;
  line-height: 1.4;
  word-break: break-all;
  overflow-wrap: break-word;
  text-decoration-line: underline;
  text-decoration-color: #BB1C21;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.link.icon {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.link.icon::after {
  content: "";
  width: 15px;
  height: 15px;
  background-image: url(../images/icon_link.svg);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  flex-shrink: 0;
  text-decoration: none;
}
.link.dot {
  position: relative;
  margin-left: 16px;
}
.link.dot::before {
  position: absolute;
  content: "";
  width: 4px;
  height: 4px;
  border-radius: 2px;
  background-color: #BB1C21;
  top: 10px;
  left: -14px;
}
.link.out {
  position: relative;
}
.link.out::after {
  position: absolute;
  content: "";
  top: calc(50% - 10px);
  width: 20px;
  height: 20px;
  margin-left: 5px;
  background-image: url(../images/icon_outlink.svg);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  flex-shrink: 0;
  text-decoration: none;
}
.link:hover {
  text-decoration: none;
}

/*-----------------------
          list
------------------------*/
.list_dot {
  line-height: 1.4;
  padding-left: 20px;
  margin-bottom: 10px;
  position: relative;
}
.list_dot::before {
  position: absolute;
  content: "";
  top: 8px;
  left: 7px;
  border-radius: 2px;
  width: 4px;
  height: 4px;
  background-color: #333;
}

.num_list_outer {
  counter-reset: numCount;
}
.num_list_outer .num_list {
  counter-increment: numCount;
  padding-left: 20px;
  position: relative;
}
.num_list_outer .num_list::before {
  position: absolute;
  content: counter(numCount) ". ";
  top: 0;
  left: 0;
}

/*-----------------------
        Oter item
------------------------*/
.bold {
  font-weight: bold;
}

.red {
  color: #BB1C21;
}

.blue {
  color: #0035A8;
}

.small {
  font-size: 14px;
  font-weight: 400;
}

.center {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

.text_center {
  text-align: center;
}

.greyback {
  padding: 20px;
  background-color: #F5F5F5;
}

.sp {
  display: none;
}

.tb {
  display: none;
}

.spn {
  display: block;
}

.tbn {
  display: block;
}

.data_link {
  display: block;
  width: fit-content;
  padding-left: 63px;
  padding: 12px 20px 12px 60px;
  background-color: #F5F5F5;
  border: solid 1px #D9D9D9;
  border-radius: 5px;
  position: relative;
  transition: background-color 0.3s;
}
.data_link:hover {
  background-color: rgb(207, 207, 207);
}
.data_link::before {
  position: absolute;
  content: "";
  width: 33px;
  aspect-ratio: 1/1;
  top: 50%;
  left: 20px;
  transform: translateY(-50%);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}
.data_link.pdf::before {
  background-image: url(../images/icon_pdf.svg);
}
.data_link.xlsx::before {
  background-image: url(../images/icon_xlsx.svg);
}
.data_link.docx::before {
  background-image: url(../images/icon_docx.svg);
}

.right {
  width: fit-content;
  margin-left: auto;
  margin-right: 0;
}

/*
.font{
  font-family: "Josefin Sans", serif;
  font-family: "Montserrat", sans-serif;
  font-family: 'BIZ UDPGothic', sans-serif;
  font-family: "Yu Gothic", sans-serif;
  font-family: 'DINBEK', sans-serif;
  font-family: 'Noto Sans JP', sans-serif;
  font-family: 'Zen Kurenaido', sans-serif;
}
*/
.header_height {
  position: relative;
  z-index: 98;
  display: block;
  width: 100%;
  height: 140px;
  background-color: #fff;
}

.header {
  position: fixed;
  z-index: 99;
  top: 0;
  left: 0;
  width: 100%;
  height: 140px;
  background-color: rgba(255, 255, 255, 0.8549019608);
  transition: height 0.3s;
}

.header_inner {
  width: 100%;
  height: 100%;
  margin: 0 auto;
  padding: 0 75px;
  position: relative;
}

/*---------------------
    header_logo_line
----------------------*/
.header_logo_line {
  width: 100%;
  max-width: 1290px;
  margin-left: auto;
  margin-right: auto;
  height: 90px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

/*---------------------
        Logo
----------------------*/
.header_logo {
  display: block;
  width: 254px;
  flex-shrink: 0;
}

/*---------------------
  header_logo_line_link
----------------------*/
.header_logo_line_link {
  width: fit-content;
  display: flex;
  justify-content: right;
  align-items: center;
  gap: 20px;
}

.header_link_block {
  width: fit-content;
  margin-left: 19px;
  color: #000;
  font-size: 14px;
  position: relative;
  transition: color 0.3s;
}
.header_link_block.current {
  pointer-events: none;
}
.header_link_block:hover {
  color: #BB1C21;
}
.header_link_block::before {
  position: absolute;
  content: "";
  top: calc(50% - 8px);
  left: -19px;
  width: 14px;
  height: 14px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}
.header_link_block.sit::before {
  background-image: url(../images/header_icon_sitemap.svg);
}
.header_link_block.inq::before {
  background-image: url(../images/header_icon_inq.svg);
}

/*---------------------
      Navigation
----------------------*/
.header_nav {
  width: 100%;
  max-width: 1290px;
  margin-left: auto;
  margin-right: auto;
  height: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.header_nav_li {
  display: block;
  width: 12.5%;
  height: 100%;
  line-height: 35px;
  font-size: 15px;
  font-weight: bold;
  white-space: nowrap;
  transition: 0.3s;
  cursor: default;
  text-align: center;
  /*Accordion menu*/
}
.header_nav_li.pointer {
  cursor: pointer;
}
.header_nav_li .header_nav_li_line {
  width: 100%;
  height: calc(100% - 15px);
  position: relative;
}
.header_nav_li .header_nav_li_line::before {
  display: block;
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 1px;
  height: 100%;
  background-color: #D4D4D4;
}
.header_nav_li .header_nav_li_line.last::after {
  display: block;
  position: absolute;
  content: "";
  top: 0;
  right: 0;
  width: 1px;
  height: 100%;
  background-color: #D4D4D4;
}
.header_nav_li .header_nav_a {
  display: block;
  cursor: pointer;
  width: 100%;
  height: 100%;
}
.header_nav_li .acd_menu {
  width: 100vw;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  background-color: #BB1C21;
  z-index: 99;
  padding: 0px 40px;
  height: 0;
  opacity: 0;
  transition: color, height 0.3s ease, padding 0.3s ease, opacity 0.3s ease;
  overflow: hidden;
  cursor: default;
}
.header_nav_li:hover {
  color: #BB1C21;
}
.header_nav_li:hover .acd_menu {
  height: fit-content;
  padding: 46px 40px;
  opacity: 1;
}
.header_nav_li .acd_menu_inner {
  max-width: 1360px;
  margin-left: auto;
  margin-right: auto;
  display: flex;
  justify-content: left;
  align-items: flex-start;
  gap: 36px;
  line-height: 1.2;
}
.header_nav_li .acd_section {
  display: flex;
  justify-content: left;
  align-items: flex-start;
  gap: 30px 20px;
  flex-wrap: wrap;
  padding-bottom: 40px;
}
.header_nav_li .acd_block {
  width: calc((100% - 64px) / 5);
  width: 260px;
  padding-bottom: 26px;
  border-bottom: solid 1px #FE9497;
}
.header_nav_li .acd_block .acd_list {
  padding: 6px 0;
  letter-spacing: -0.5px;
}
.header_nav_li .acd_block .acd_list::after {
  bottom: 5px;
}
.header_nav_li .acd_title {
  font-size: 20px;
  font-weight: bold;
  text-align: left;
  color: #fff;
  width: 160px;
  flex-shrink: 0;
  line-height: 1;
  padding-top: 18px;
}
.header_nav_li .acd_subtitle {
  font-size: 16px;
  font-weight: bold;
  color: #fff;
  line-height: 1;
  padding-top: 18px;
  margin-bottom: 30px;
}
.header_nav_li .acd_list {
  width: fit-content;
  margin-left: 21px;
  font-size: 16px;
  color: #fff;
  display: block;
  padding: 20px 0;
  position: relative;
}
.header_nav_li .acd_list::before {
  display: block;
  position: absolute;
  content: "";
  top: 50%;
  left: -21px;
  width: 16px;
  height: 16px;
  transform: translateY(-50%);
  background-image: url(../images/icon_acd_arrow.svg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.header_nav_li .acd_list::after {
  position: absolute;
  content: "";
  bottom: 19px;
  left: 0;
  width: 100%;
  height: 1px;
  transition: background-color 0.3s;
  background-color: inherit;
}
.header_nav_li .acd_list:hover::after {
  background-color: #ffdcdd;
}
.header_nav_li .acd_list:nth-last-child(1) {
  margin-bottom: 0;
}

/*------------------------------
  Header link(recruit,inquiry)
-------------------------------*/
.header_link {
  height: 100%;
  display: flex;
  justify-content: center;
}

.header_link_li {
  width: 130px;
  height: 100%;
  color: #fff;
  font-size: 15px;
  font-weight: bold;
  transition: 0.3s;
  display: flex;
  justify-content: center;
  align-items: center;
}
.header_link_li.red {
  background-color: #BB1C21;
}
.header_link_li.red:hover {
  color: #BB1C21;
  background-color: #f7dcdd;
}
.header_link_li.black {
  background-color: #000;
}
.header_link_li.black:hover {
  color: #000;
  background-color: #cfcfcf;
}
.header_link_li.current {
  pointer-events: none;
}

.header_link_li_text {
  text-align: center;
  line-height: 120px;
  transition: 0.3s;
}

#hamburger_area * {
  display: none;
}

/* Toggle Button */
.hamburger_menu {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 38px;
  height: 24px;
  position: fixed;
  top: 20px;
  right: 24px;
  z-index: 999;
  cursor: pointer;
}

.hamburger_menu span {
  position: absolute;
  width: 100%;
  height: 3px;
  transition: 0.3s;
}
.hamburger_menu span:first-of-type {
  top: 0;
}
.hamburger_menu span:nth-of-type(2) {
  top: 50%;
}
.hamburger_menu span:last-of-type {
  top: 100%;
}

.hamburger_menu.active span:first-of-type {
  top: 50%;
  transform: rotate(225deg);
}
.hamburger_menu.active span:nth-of-type(2) {
  opacity: 0;
}
.hamburger_menu.active span:last-of-type {
  top: 50%;
  transform: rotate(-225deg);
}

#bar_color.hamburger_menu span {
  background-color: #444;
}

#bar_color.hamburger_menu.active span {
  background-color: #444;
}

.hbg_menu_text {
  font-size: 12px;
  color: #333;
  position: absolute;
  top: 120%;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}

/* Slide Menu */
.slide_menu {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  overflow-y: auto;
  background-color: #BB1C21;
  transition: right 0.3s ease-in-out;
  z-index: 97;
  transform: translateX(100%);
  transition: 0.3s;
  padding: 140px 40px;
}
.slide_menu .hbg_ul {
  list-style: none;
  height: fit-content;
}
.slide_menu .hbg_li {
  width: 100%;
  height: 60px;
  line-height: 60px;
  color: #fff;
  font-size: 16px;
  font-weight: 500;
  border-bottom: solid 1px #FE9497;
  border-collapse: collapse;
  display: flex !important;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
}
.slide_menu .hbg_li .hbg_li_title {
  display: block;
  width: fit-content;
}
.slide_menu .hbg_li .plus {
  display: block;
  position: relative;
  width: 18px;
  aspect-ratio: 1/1;
  height: auto;
  margin-right: 10px;
}
.slide_menu .hbg_li .plus::before, .slide_menu .hbg_li .plus::after {
  position: absolute;
  content: "";
  background-color: #ffffff;
}
.slide_menu .hbg_li .plus::before {
  top: calc(50% - 1px);
  left: 0;
  width: 100%;
  height: 2px;
}
.slide_menu .hbg_li .plus::after {
  top: 0;
  left: calc(50% - 1px);
  width: 2px;
  height: 100%;
  transition: transform 0.3s, opacity 0.3s ease-out;
}
.slide_menu .hbg_li .plus.open::after {
  transform: rotate(-90deg);
  opacity: 0;
}
.slide_menu .acd {
  padding-top: 0;
  width: 100%;
  height: fit-content;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: 0.3s;
  border-bottom: solid 1px #FE9497;
}
.slide_menu .acd.open {
  max-height: 2000px;
  padding: 10px 0;
  opacity: 1;
}
.slide_menu .acd.open .acd_subtitle {
  height: 40px;
  line-height: 40px;
}
.slide_menu .acd.open .acd_li {
  height: 40px;
  line-height: 40px;
}
.slide_menu .acd_subtitle {
  color: #fff;
  font-size: 15px;
  font-weight: 500;
  height: 0;
  line-height: 0;
  transition: 0.3s;
}
.slide_menu .acd_li {
  color: #fff;
  font-size: 14px;
  height: 0;
  line-height: 0;
  margin-left: 21px;
  cursor: pointer;
  transition: 0.3s;
  position: relative;
}
.slide_menu .acd_li::before {
  display: block;
  position: absolute;
  content: "";
  top: 50%;
  left: -21px;
  width: 16px;
  height: 16px;
  transform: translateY(-50%);
  background-image: url(../images/icon_acd_arrow.svg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.slide_menu .acd_li:hover {
  background-color: #d63a3f;
}
.slide_menu .acd_block {
  padding: 10px 0;
  width: 100%;
  border-bottom: dotted 1px #FE9497;
}
.slide_menu .acd_block.last {
  border-bottom: none;
}

.slide_menu.active {
  transform: translateX(0);
  box-shadow: -2px 0 2px rgba(0, 0, 0, 0.2);
}

.footer {
  width: 100%;
  padding: 60px 0 40px;
  background-color: #BB1C21;
}

.footer_inner {
  width: 100%;
  max-width: 1440px;
  height: 100%;
  margin: 0 auto;
  padding: 0 40px;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  position: relative;
}

.footer_logo {
  display: block;
  width: fit-content;
  margin-bottom: 25px;
}

.footer_text {
  font-size: 14px;
  color: #fff;
  margin-bottom: 40px;
}

small {
  display: block;
  width: fit-content;
  font-size: 12px;
  color: #fff;
}

.footer_link {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 50px;
  position: relative;
}

.yt_link {
  display: block;
  width: fit-content;
  position: relative;
  padding-left: 40px;
  margin-left: auto;
  margin-bottom: 30px;
  color: #fff;
  font-size: 14px;
}
.yt_link::after {
  position: absolute;
  display: block;
  content: "";
  top: calc(50% - 18px);
  left: 0;
  width: 35px;
  height: 35px;
  background-image: url(../images/icon_youtube.svg);
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}

.footer_link_li {
  font-size: 14px;
  color: #fff;
  width: fit-content;
  position: relative;
}
.footer_link_li::before {
  position: absolute;
  content: "";
  bottom: 3px;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #FE9497;
  opacity: 0;
  transition: opacity 0.3s;
}
.footer_link_li:hover::before {
  opacity: 1;
}
.footer_link_li::after {
  position: absolute;
  content: "";
  width: 1px;
  height: calc(100% + 4px);
  top: -2px;
  right: -25px;
  background-color: #D74C51;
  pointer-events: none;
}
.footer_link_li:nth-last-child(1)::after {
  background-color: inherit;
}

.pagetop {
  font-size: 15px;
  font-weight: bold;
  color: #BB1C21;
  position: absolute;
  bottom: calc(100% + 72px);
  right: 40px;
  cursor: pointer;
}
.pagetop::before {
  display: inline-block;
  content: "";
  width: 9px;
  height: 6px;
  background-image: url(../images/icon_pagetop.svg);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  margin-right: 5px;
  margin-bottom: 3px;
}
@media (max-width: 1400px){
  .header_link_li {
    width: 110px;
  }
}
@media (max-width: 1300px){
  .header_logo {
    width: 230px;
  }
}
@media (max-width: 1200px){
  .fv {
    height: 140px;
  }
  .fv_title {
    font-size: 28px;
  }
  .page_outer {
    padding: 80px 40px 160px;
  }
  .breadcrumb {
    width: calc(100% - 80px);
    left: 40px;
  }
  .title_h2 {
    font-size: 20px;
    padding: 26px 25px;
  }
  .title_h2::before {
    height: 32px;
  }
  .title_h3 {
    font-size: 20px;
    padding-bottom: 14px;
  }
  .header_inner {
    padding: 0 20px;
  }
  .header_logo {
    width: 210px;
  }
  .header_nav_li {
    font-size: 14px;
  }
  .header_nav_li:hover .acd_menu {
    padding: 20px 40px;
  }
  .header_nav_li .acd_section {
    padding-bottom: 25px;
  }
  .header_nav_li .acd_block {
    width: 240px;
  }
  .header_nav_li .acd_title {
    font-size: 18px;
    width: 120px;
  }
  .header_nav_li .acd_subtitle {
    font-size: 15px;
    margin-bottom: 20px;
  }
  .header_nav_li .acd_list {
    font-size: 14px;
  }
  .header_link_li {
    width: 90px;
    font-size: 13px;
  }
  .header_link_li_text {
    line-height: 100px;
  }
}
@media (max-width: 1023px){
  .header_logo {
    width: 200px;
  }
  .header_nav_li {
    font-size: 13px;
  }
}
@media (max-width: 960px){
  .mb15 {
    margin-bottom: 10px;
  }
  .mb20 {
    margin-bottom: 10px;
  }
  .mb25 {
    margin-bottom: 15px;
  }
  .mb30 {
    margin-bottom: 20px;
  }
  .mb35 {
    margin-bottom: 25px;
  }
  .mb40 {
    margin-bottom: 25px;
  }
  .mb45 {
    margin-bottom: 35px;
  }
  .mb50 {
    margin-bottom: 30px;
  }
  .mb55 {
    margin-bottom: 30px;
  }
  .mb60 {
    margin-bottom: 30px;
  }
  .mb65 {
    margin-bottom: 35px;
  }
  .mb70 {
    margin-bottom: 35px;
  }
  .mb75 {
    margin-bottom: 35px;
  }
  .mb80 {
    margin-bottom: 40px;
  }
  .mb85 {
    margin-bottom: 40px;
  }
  .mb90 {
    margin-bottom: 45px;
  }
  .mb95 {
    margin-bottom: 50px;
  }
  .mb100 {
    margin-bottom: 50px;
  }
  .mb110 {
    margin-bottom: 55px;
  }
  .mb120 {
    margin-bottom: 60px;
  }
  .mb125 {
    margin-bottom: 65px;
  }
  .mb130 {
    margin-bottom: 60px;
  }
  .mb140 {
    margin-bottom: 60px;
  }
  .mb150 {
    margin-bottom: 60px;
  }
  .mb160 {
    margin-bottom: 80px;
  }
  .mb170 {
    margin-bottom: 80px;
  }
  .mb180 {
    margin-bottom: 90px;
  }
  .mb190 {
    margin-bottom: 90px;
  }
  .mb200 {
    margin-bottom: 100px;
  }
  .fs18 {
    font-size: 16px;
  }
  .fs19 {
    font-size: 17px;
  }
  .fs20 {
    font-size: 18px;
  }
  .fs21 {
    font-size: 19px;
  }
  .fs22 {
    font-size: 20px;
  }
  .fs23 {
    font-size: 19px;
  }
  .fs24 {
    font-size: 20px;
  }
  .fs25 {
    font-size: 21px;
  }
  .fs26 {
    font-size: 22px;
  }
  .fs27 {
    font-size: 23px;
  }
  .fs28 {
    font-size: 24px;
  }
  .fs29 {
    font-size: 23px;
  }
  .fs30 {
    font-size: 24px;
  }
  .fs31 {
    font-size: 25px;
  }
  .fs32 {
    font-size: 26px;
  }
  .fs33 {
    font-size: 27px;
  }
  .fs34 {
    font-size: 28px;
  }
  .fs35 {
    font-size: 27px;
  }
  .fs36 {
    font-size: 28px;
  }
  .fs37 {
    font-size: 29px;
  }
  .fs38 {
    font-size: 30px;
  }
  .fs39 {
    font-size: 31px;
  }
  .fs40 {
    font-size: 32px;
  }
  .title_h4 {
    font-size: 18px;
  }
  .title_h5 {
    font-size: 20px;
  }
  .tb {
    display: block;
  }
  .tbn {
    display: none;
  }
  .header_height {
    height: 80px;
  }
  .header {
    height: 80px;
  }
  .header_link_block {
    display: none;
  }
  .header_nav {
    display: none;
  }
  #hamburger_area * {
    display: block;
  }
  .footer_link {
    gap: 30px;
    margin-bottom: 40px;
    flex-wrap: wrap;
  }
  .footer_link_li {
    font-size: 13px;
  }
  .footer_link_li::after {
    right: -15px;
  }
}
@media (max-width: 767px){
  body {
    font-size: 14px;
    text-align: justify;
  }
  .spOnly {
    display: block;
  }
  .pcOnly {
    display: none;
  }
  .fs18 {
    font-size: 14px;
  }
  .fs19 {
    font-size: 15px;
  }
  .fs20 {
    font-size: 16px;
  }
  .fs21 {
    font-size: 17px;
  }
  .fs22 {
    font-size: 18px;
  }
  .fs23 {
    font-size: 15px;
  }
  .fs24 {
    font-size: 16px;
  }
  .fs25 {
    font-size: 17px;
  }
  .fs26 {
    font-size: 18px;
  }
  .fs27 {
    font-size: 19px;
  }
  .fs28 {
    font-size: 20px;
  }
  .fs29 {
    font-size: 17px;
  }
  .fs30 {
    font-size: 18px;
  }
  .fs31 {
    font-size: 19px;
  }
  .fs32 {
    font-size: 20px;
  }
  .fs33 {
    font-size: 21px;
  }
  .fs34 {
    font-size: 22px;
  }
  .fs35 {
    font-size: 19px;
  }
  .fs36 {
    font-size: 20px;
  }
  .fs37 {
    font-size: 21px;
  }
  .fs38 {
    font-size: 22px;
  }
  .fs39 {
    font-size: 23px;
  }
  .fs40 {
    font-size: 24px;
  }
  .fv {
    height: 120px;
  }
  .fv_title {
    font-size: 24px;
  }
  .page_outer {
    padding: 80px 20px 120px;
  }
  .breadcrumb {
    width: calc(100% - 40px);
    left: 20px;
  }
  .crumbli {
    font-size: 12px;
  }
  .title_h2 {
    font-size: 18px;
    margin-bottom: 20px;
  }
  .title_h2.mb60 {
    margin-bottom: 30px;
  }
  .title_h3 {
    font-size: 18px;
    padding-bottom: 10px;
    margin-bottom: 20px;
  }
  .title_h4::before {
    width: 6px;
    height: 24px;
    top: calc(50% - 12px);
  }
  .title_h4 {
    font-size: 16px;
    padding-left: 14px;
    margin-bottom: 15px;
  }
  .title_h5 {
    font-size: 16px;
  }
  th, td {
    padding: 12px;
  }
  .link.dot::before {
    top: 8px;
  }
  .list_dot {
    padding-left: 16px;
  }
  .list_dot::before {
    top: 7px;
    left: 5px;
  }
  .small {
    font-size: 12px;
  }
  .greyback {
    padding: 15px;
  }
  .sp {
    display: block;
  }
  .spn {
    display: none;
  }
  .data_link {
    padding-left: 56px;
    padding-right: 18px;
    padding: 10px 18px 10px 56px;
  }
  .data_link::before {
    width: 26px;
    left: 18px;
  }
  .hamburger_menu {
    top: 20px;
    right: 22px;
  }
  .slide_menu {
    padding: 120px 20px;
  }
  .footer_inner {
    padding: 0 20px;
    flex-direction: column;
    align-items: center;
    gap: 30px;
  }
  .footer_logo {
    margin-bottom: 0;
  }
  .footer_text {
    text-align: center;
    margin-bottom: 30px;
  }
  small.pc {
    display: none;
  }
  small {
    margin: 0 auto;
  }
  .yt_link {
    margin-right: auto;
    margin-top: 30px;
  }
  .footer_link_li {
    font-size: 12px;
    letter-spacing: -0.5px;
  }
  .pagetop {
    right: 20px;
  }
}
@media print{
  body {
    width: 960px;
    margin: 0 auto;
  }
}