@charset "utf-8";

/*****************************************
	original.css
	企業固有のスタイルを指定
******************************************/
body {
  -webkit-text-size-adjust: 100% !important;
}

body,
#header {
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
}

/*コンテンツ幅設定用（依頼指示の幅+20px）*/
#main .content {
  max-width: 1020px;
}

/*404エラー画面（依頼指示の幅+20px）*/
#errorContent {
  max-width: 1020px;
  box-sizing: border-box;
  margin: 0 auto;
  padding: 0 10px;
}

@media only screen and (max-width: 767px) {
  #errorContent {
    padding: 0 15px;
  }
}

/*for Android copyrightマークの色 */
footer span.copy {
  font-family: Verdana, "Droid Sans" !important;
}

/*******************************
 スクリーンリーダー
*******************************/
.screen-reader-wrap {
  position: relative;
}

.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  -webkit-clip-path: inset(50%);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
}

/*******************************
 スキップリンク
 *******************************/
.skip-hidden-text {
  position: relative;
}

.skip-hidden-text a,
.skip-hidden-text span {
  display: block;
  position: absolute;
  width: 1px;
  height: 1px;
  clip: rect(1px, 1px, 1px, 1px);
}

.skip-hidden-text a:focus,
.skip-hidden-text a:active {
  display: block;
  width: 15em;
  height: auto;
  top: 10px;
  left: 10px;
  clip: auto;
  z-index: 1000;
  font-size: 1rem;
  padding: 5px;
  background-color: #FFF;
  border: 1px solid #999;
  border-radius: 10px;
  text-align: center;
}

/*******************************
 loading=lazy画像
 *******************************/
img {
  height: auto;
}

img[loading="lazy"] {
  width: auto;
  max-width: 100%;
  height: auto;
}


/*******************************
 ヘッダー
*******************************/

/* 固定ヘッダ */

#header .content div.regular {
  background-color: #ffffff;
  /* 背景 */
  color: #000000;
  /* 文字色 */
  height: 69px;
  /* 高さ */
}

#header .content div.regular div.logo {
  padding-top: 10px;
  /* 企業ロゴ表示開始位置 上 */
  padding-left: 20px;
  /* 企業ロゴ表示開始位置 左 */
}

#header .content div.regular .note {
  bottom: 5px;
  /* フリーコメント開始位置 下 */
  right: 10px;
  /* フリーコメント開始位置 右 */
}

/*******************************
 フッター
*******************************/

/* フッタ関連の高さ指定 */
#footer .content .free {
  height: 80px;
  /* ★1 自由フッタの高さ */
}

#footer .content .regular {
  height: 100px;
  /* ★2 固定フッタの高さ */
}

#footer {
  height: 180px;
  /* footerの高さ（ ★1＋★2 ）分指定する*/
}

#main .space {
  padding-bottom: 180px;
  /* footerの高さ（★1＋★2）分指定する */
}

/* 固定フッタ */
#footer .content .regular {
  background-color: #d50000;
  /* 背景 */
  color: #ffffff;
  /* 文字色 */
}

/*******************************
 自由ヘッダー
*******************************/
#header .content .free {}

/*******************************
 自由コンテンツ上
*******************************/
#headContent .free {}

/*******************************
 自由サイドコンテンツ
*******************************/
#sideContent .free {}

/*******************************
 自由コンテンツ中
*******************************/
#bottomContent .freeHead {}

/*******************************
 自由コンテンツ下
*******************************/
#bottomContent .freeBottom {}

/*******************************
 自由フッター
*******************************/
#footer .content .free {}

/*******************************
 追加スタイル
*******************************/


.visualBlock .copyWrap__main span {
  font-weight: bold !important;
  font-family: serif !important;
}

.visualBlock .visualBlock__btn {
  font-family: var(--main-font) !important;
}

.modalBlock .videoBlock__video video {
  width: 100%;
  height: auto;
}

.modalBlock .videoBlock.modalWrap__item[hidden="hidden"] {
  display: none;
}

.wrapper .visualBlock .copyWrap__main span,
.wrapper .visualBlock .copyWrap__main {
  font-family: "reiher-headline", "ryo-display-plusn", serif;
  font-weight: 500;
  font-style: normal;
}

.wrapper .visualBlock .copyWrap__main {
  padding-top: 35px;
}

.wrapper .visualBlock .copyWrap__main a {
  display: inline-block;
  font-family: sans-serif;
  font-weight: normal;
  z-index: 2;
  pointer-events: auto;
  position: relative;
  color: white;
  font-size: 1.2vw;
  margin-top: 20px;
  padding: 10px 40px 10px 30px;
  border: 1px solid white;
  border-radius: 99px;
  scroll-behavior: smooth;
}

.wrapper .visualBlock .copyWrap__main a:after {
  content: "";
  position: absolute;
  margin: auto;
  top: 0;
  bottom: 0;
  right: 15px;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 5px solid #fff;
}

@media screen and (max-width: 767px) {
  .wrapper .visualBlock .copyWrap__main a {
    font-size: 12px;

  }
}

.messageBlock {
  font-family: "reiher-headline", "ryo-display-plusn", serif;
  font-weight: 500;
  font-style: normal;
  text-align: center;
  padding: 30px 0;
}

.messageBlock .title {
  margin-top: 10px;
  font-size: 25px;
}

@media screen and (max-width: 600px) {
  .messageBlock .title {
    font-size: 5vw;
  }
}

.noteBlock {
  margin-bottom: 100px;
}

@media screen and (max-width: 767px) {
  .noteBlock {
    padding-bottom: 25.6vw;
  }
}

.noteBlock__list .list {
  width: 25%;
}

.noteBlock__list .list a {
  position: relative;
  display: block;
}

.noteList__text {
  position: absolute;
  width: calc(100% - 20px);
  padding: 10px;
  bottom: 0;
  color: white;
}

.noteList__text .title {
  font-weight: normal;
  font-size: 16px;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.noteList__text .sub {
  font-size: 10px;
}

@media screen and (max-width: 500px) {
  .noteBlock__list .list {
    width: 80vw;
  }
}

.visualBlock {
  background: #555555;
}

.visualBlock__video {
  background: url(../images/visual.jpg) no-repeat center center;
  background-size: cover;
}