@charset "UTF-8";
/* CSS Document */

/*
Theme Name: Food Science
Theme URI: https://example.com
Description: M's soleilのテーマです。
Version: 1.0
Author: Kawabata
Author URI: https://gihyo.jp
*/

/* ---------------------------------------------------------
初期設定
----------------------------------------------------------*/

a {
  display: inline-block;
  text-decoration: none;
  color: #1a1a1a;
  transition: 0.2s;
}

a:hover {
  opacity: 0.8;
  transition: 0.2s;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}


/* ---------------------------------------------------------
フォント
----------------------------------------------------------*/

body{
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 16px;
	line-height: 2.1;
	color: #1a1a1a;
	letter-spacing: 0.05em;
}

.outfit {
  font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
	letter-spacing: 0.1em;
	line-height: 1.5;
	color:#e87e1f;
}

.noto-serif {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
	letter-spacing: 0.14em;
	color: #1a1a1a;
}

.orange{
	color:#e87e1f;
}

/* ---------------------------------------------------------
共通パーツ
----------------------------------------------------------*/

body{
	background-color:#f2f2f2;
}

.section{
	padding: 0;
}

.section .section_inner{
	padding: 0 20px;
}

.dot{
      background-color: #4d4d4d; /* 黒背景 */
      background-image: url("../img/home/bg_01.png");  /* 画像のパスを指定 */
      background-repeat: repeat; /* 縦横リピート */
      background-size: 350px; 
      width: 100%;
      height: 100%; /* 画面全体に表示 */
}

.sec_ttl{
	font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
	letter-spacing: 0.07em;
	font-size: 60px;
	margin-bottom: 30px;
	color:#e87e1f;
	line-height: 1;
}

/*横線アニメーション*/
/* アニメーションの初期スタイル */
.line::before,
.line2::before,
.line3::before,
.line4::before,
.line5::before,
.line6::before,
.line7::before,
.line8::before,
.line9::before,
.line10::before{
  content: "";
  display: inline-block;
  width: 0;
  height: 2px;
  background-color: #e87e1f;
  transition: none;
  --line-width: 80px; /* デフォルト幅 */
}

/* アニメーションを開始するクラス */
.animate-line::before,
.animate-line2::before,
.animate-line3::before,
.animate-line4::before,
.animate-line5::before,
.animate-line6::before,
.animate-line7::before,
.animate-line8::before,
.animate-line9::before,
.animate-line10::before {
  animation: lineGrow 0.3s cubic-bezier(0.6, 0, 1, 1) forwards;
  animation-delay: 0.3s;
}

/* アニメーション定義 */
@keyframes lineGrow {
  from {
    width: 0;
  }
  to {
    width: var(--line-width);
  }
}

/* 画面幅が840px以下の場合に幅を20pxに変更 */
@media screen and (max-width: 840px) {
  .line::before,
  .line2::before,
  .line3::before,
  .line4::before,
  .line5::before,
  .line6::before,
  .line7::before,
  .line8::before,
  .line9::before,
.line10::before{
    --line-width: 50px;
  }
}




    /* 画面スクロール確認用に上下の余白を追加 */
    body {
      height: 150vh;
      padding-top: 120vh; /* スクロールしてから見える位置に */
      margin: 0;
    }

/*@keyframes lineGrow {
  from {
	width: 0;
  }
  to {
	width: 80%; 
  }
}*/

.sec_ttl_sub{
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
	letter-spacing: 0.14em;
	font-size: 16px;
	display: block;
	color: #1a1a1a;
	margin-top: 20px;
}

.sec_text{
	margin-bottom: 40px;
}

.sec_btn{
	
}

.sec_img{
	width: 100%;
}

/*フレックス*/

.flexbox{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: top;
}

/*矢印*/

.view-more-btn {
  display: inline-flex;
  align-items: center;
　font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
	letter-spacing: 0.1em;
  font-size: 16px;
  color: #1a1a1a;
  text-decoration: none;
  position: relative;
  gap: 10px;
}

.arrow-wrapper {
  display: inline-flex;
  align-items: center;
  position: relative;
  width: 42px;
  height: 42px;
}

.circle {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border: 1px solid #1a1a1a;
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: none;
}


.yoko {
  width: 30px;
  height: 1px;
  border-top: 1px solid #1a1a1a;
  position: absolute;
  left: 22px;
  top: 20px;
  transition: transform 0.3s ease;
}

.arrow {
  width: 7px;
  height: 7px;
  border-top: 1px solid #1a1a1a;
  transform: rotate(45deg);
  position: absolute;
  left: 44px;
  top: 17px;
  transition: transform 0.3s ease;
}

/* ホバーで矢印だけ右に移動 */
.view-more-btn:hover .arrow {
  transform: translateX(10px) rotate(45deg);
}

.view-more-btn:hover .yoko {
  transform: translateX(10px) ;
}

/* ホバー時：矢印だけ右にスライド + 色をオレンジに */
.view-more-btn:hover {
  color: #e87e1f; /* テキストも変えたい場合 */
	opacity: 1;
}

.view-more-btn:hover .arrow,
.view-more-btn:hover .yoko,
.view-more-btn:hover .circle {
  border-color: #e87e1f;
}

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

.header .header_menu{
	display: block;
}

.header{
	background-color: transparent;
	border-bottom: none;
	height: 80px;
}

.header.is-active{
	background-color: rgba(242,242,242,0.9);
	border-bottom: none;
	box-shadow:none;
	height: 76px;
}

.header.is-active .logo-white{
	display: none;
}

.header.is-active .logo-gold{
	display: block;
	width:160px;
	height: auto;
}

.header .logo-gold{
	display: none;
}

.header .logo-white{
	display: block;
}

.logo{
	width:190px;
	height: auto;
}

.header .header_nav{
	/*width:auto;*/
}
.gnav>ul>li{
	padding:0 20px;
}
.gnav>ul>li>a{
	/*font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
	letter-spacing: 0.1em;
	line-height: 1.5;*/
	/*font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
	letter-spacing: 0.14em;*/
	color: #fff;
	font-size: 15px;
	font-weight: 400;
	letter-spacing: 0.1em;
	
}
/*.gnav {
  display: block; 
  opacity: 0;
  transform: translateY(-20px);
  pointer-events: none;
  transition: opacity 0.2s ease-in-out, transform 0.2s ease-in-out;
}

.gnav.is-active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}*/
.header.is-active .gnav>ul>li>a{
	color: #1a1a1a;
	font-weight: 400;
}

.header.is-active .gnav>ul>li>a:hover {
	color: #e87e1f;
}

.header .header_logo{
	margin-right: 50px;
}

/*ヘッダー問い合わせ*/


/*.header_contact a {
  display: inline-block;
  background-color: #e87e1f; 
  color: #fff;
  padding: 7px 24px;
  border-radius: 999px; 
  text-decoration: none;
  transition: background-color 0.3s ease;
	margin-right: 20px;
	font-size: 14px;
	font-weight: 300;
	letter-spacing: 0.1em;
}*/

/*.header_contact span {
  display: inline-block;
}*/



.header_contact a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background-color: #e87e1f; 
  color: #fff;
  padding: 6px 24px;
  border-radius: 9999px;
  text-decoration: none;
  transition: background-color 0.3s ease;
	margin-right: 20px;
	margin-left: 20px;
	font-size: 15px;
	font-weight: 400;
	letter-spacing: 0.1em;
}

.header_contact a:hover {
  background-color: #4d4d4d;
	opacity: 1;
}

.header_contact .mail-icon {
  width: 17px;   /* サイズ調整 */
  height: 12px;
  display: inline-block;
}

.header_contact_sp{
		display: none;
	}
	
.header_tel{
		display: none;
	}

@media (max-width: 1180px) {
  .gnav>ul>li{
	padding:0 10px;
}
	
	.header .header_logo{
	margin-right: 0px;
		padding-right: 5px;
}
	
}


@media (max-width: 840px) {
	
	.gnav{
		background-color: #f2f2f2;
		top:0;
		height:100%;
		text-align:center;
		padding-top: 100px;
		padding-bottom: 20px;
	}
	
  .gnav>ul>li{
	padding:25px 20px;
	  border-bottom: 1px solid #BABABA;
	  position: relative;
	  width:90%;
	  margin: 0 auto;
}
	
	.gnav > ul > li::after {
  content: "";
  display: inline-block;
  width: 30px;   /* 矢印画像の幅 */
  height: 12px;  /* 矢印画像の高さ */
  background: url("../img/common/ico_02.png") no-repeat center center;
  background-size: contain;
  position: absolute;
  right: 20px;   /* liの右端に配置 */
  top: 50%;
  transform: translateY(-50%);
}
	
	.gnav>ul>li>a{
		color: #1a1a1a;
		font-size: 16px;
		text-align: left;
	}
	
	
	
	.gnav>ul{
		margin-bottom: 50px;
	}
	
	
	
	/*.header_contact a span{
		margin: 0 auto;
	}*/
	
	.header_contact{
		display: none;
	}
	
	.header_contact_sp{
		display: block;
	}
	
	.header_contact_sp a{
		width: 300px;
		text-align: center;
		margin-bottom: 20px;
	}
	.header_tel{
		display: block;
	}
	
	.header_tel a{
		width: 300px;
		text-align: center;
	}
	
	
	.header .header_menu{
		top:25px
	}
	
	.header .header_menu.is-active{
		top:25px
	}
	
	.header .header_menu span, .header .header_menu:after, .header .header_menu:before{
		background-color:#fff;
		height:1px;
		margin: 6px 0;
	}
	
	.header_menu.is-active::after,
	.header_menu.is-active::before{
  background-color: #1a1a1a;
}
	
	.is-active .header_menu span,
	.is-active .header_menu:after,
	.is-active .header_menu:before {
		background-color:#1a1a1a;
		height:1px;
	}
}

@media (max-width: 540px) {
 
.logo{
	width:140px;
}
	
.header.is-active .logo-gold{
	width:140px;
}
	.gnav{
		height:100%;
		padding-top: 60px;
	}
	
	  .gnav>ul>li{
	padding:15px 20px;
}
	
	

	
}



/* ---------------------------------------------------------
メインビジュアル
----------------------------------------------------------*/
/* 全体レイアウト */
.main-visual {
  position: relative;
  width: 100vw;
  height: 100vh;
  overflow: hidden;
}

.main-visual__images {
  display: flex;
  width: 100%;
  height: 100%;
}

/*.img-box {
  position: relative;
  width: 33.3333%;
  height: 100%;
  overflow: hidden;
}*/

.img-box {
  position: relative;
  width: 33.3333%;
  height: 100%;
  overflow: hidden;
}

.img-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
	position: relative;
  z-index: 1;
}

/* 黒いオーバーレイ */
.img-box::after {
  /*content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
	background: rgba(242,242,242,0.5);
	
  z-index: 2;
  transform: translateX(0%);
	animation: slideOut 0.8s cubic-bezier(0.25, 1, 0.5, 1) 0.1s forwards;
	animation-fill-mode: forwards;*/
	/*background: rgba(51,51,51,0.8);*/
  /*animation: slideOut 1.5s cubic-bezier(0.77, 0, 0.175, 1) forwards;*/
}

/* 個別にアニメーション時間と遅延を変えて順番に消す */
/*.img-box:nth-child(1)::after {
  animation: slideOut 0.7s cubic-bezier(0.25, 1, 0.5, 1) 0.1s forwards;
}

.img-box:nth-child(2)::after {
  animation: slideOut 0.7s cubic-bezier(0.25, 1, 0.5, 1) 0.1s forwards;
}

.img-box:nth-child(3)::after {
  animation: slideOut 0.7s cubic-bezier(0.25, 1, 0.5, 1) 0.1s forwards;
}*/
/* オーバーレイのアニメーション */
@keyframes slideOut {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(100%);
  }
}

@media (max-width: 840px) {
  .main-visual__images {
    flex-direction: column;
  }

  .img-box {
    width: 100% !important;
    height: 33.33vh; /* 高さを3分割 */
  }
}

@media (max-width: 840px) {
  .main-visual__images {
    flex-direction: column;
  }

  .img-box {
    width: 100% !important;
    height: 33.33vh;
  }

  /* スマホ用：オーバーレイは上から下にスライドアウト */
  .img-box::after {
    animation: slideOutY 1s cubic-bezier(0.25, 1, 0.5, 1) forwards;
  }

  .img-box:nth-child(1)::after {
    animation-delay: 0.3s;
  }

  .img-box:nth-child(2)::after {
    animation-delay: 0.5s;
  }

  .img-box:nth-child(3)::after {
    animation-delay: 0.7s;
  }
}

/* 縦方向にスライドアウト */
@keyframes slideOutY {
  0% {
    transform: translateY(0%);
  }
  100% {
    transform: translateY(100%);
  }
}


/* 白い斜め四角（透過） */
/*.main-visual::before {
  content: "";
  position: absolute;
  top: -20%;
  left: -70%;
  width: 200%;
  height: 50%; 
  background: rgba(255, 255, 255, 0.2);
  transform: rotate(50deg);
  opacity: 0;
  z-index: 10;
  animation: showWhiteOverlay 1s ease-out forwards;
  animation-delay: 0.9s;
}*/

.main-visual::before {
  content: "";
  position: absolute;
  top: -20%;
  left: -130%;
  width: 300%;
  height: 50%;
  background: rgba(255, 255, 255, 0.2);
  transform: rotate(50deg) translateY(calc(var(--parallax-offset, 0px) * -1));
  opacity: 0;
  z-index: 10;
  animation: showWhiteOverlay 1s ease-out forwards;
  animation-delay: 0.6s;
  transition: transform 0.2s ease-out;
  pointer-events: none;
}


/* アニメーション */
@keyframes showWhiteOverlay {
  to {
    opacity: 1;
  }
}



/*サンプル*/


/*.img-box {
  position: relative;
  width: 100%;
  height: 100vh;
  overflow: hidden;
}

.img-box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  position: relative;
  z-index: 1;
}

.img-box::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.5); 
  z-index: 2;
}*/









/* テキスト中央寄せ */
.main-visual__text {
  position: absolute;
  top: 49%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 3;
  color: white;
  text-align: center;
  opacity: 0;
  animation: fadeInText 1s ease 1.5s forwards;
	width:100%;
}

@keyframes fadeInText {
  to {
    opacity: 1;
  }
}

.main-visual__text h1 {
  margin: 0;
	font-family: "Outfit", sans-serif;
	font-weight: 300;
	letter-spacing: 0.07em;
	font-size: 74px;
	padding-bottom: 30px;
	text-shadow: 0 0 8px rgba(0, 0, 0, 0.4);
	line-height: 1.2;
}

.main-visual__text p {
  font-family: "Noto Serif JP", serif;
	font-weight: 500;
	letter-spacing: 0.14em;
	font-size: 20px;
	text-shadow: 0 0 6px rgba(0, 0, 0, 0.6);
}







.main-visual {
	margin-top: -86px;
}
	
/*.kv .kv_title{
	 font-family: "Outfit", sans-serif;
	font-weight: 300;
	letter-spacing: 0.07em;
	font-size: 74px;
	padding-bottom: 50px;
}

.kv .kv_subtitle{
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
	letter-spacing: 0.14em;
	font-size: 20px;
}
*/


@media (max-width: 840px) {
  .main-visual__text h1 {
	  padding: 50px;
}
	
  .main-visual::before {
  content: "";
  position: absolute;
  top: -20%;
  left: -190%;
  width: 400%;
  height: 40%;
  background: rgba(255, 255, 255, 0.2);
  transform: rotate(55deg) translateY(calc(var(--parallax-offset, 0px) * -1));
  opacity: 0;
  z-index: 10;
  animation: showWhiteOverlay 1s ease-out forwards;
  animation-delay: 0.6s;
  transition: transform 0.2s ease-out;
  pointer-events: none;
}
	
}

@media (max-width: 540px) {
	
	.img-box img{
		width:150%;
		height: 150%;
	}
	
  .main-visual__text h1 {
	  padding: 10px;
	  font-size: 44px;
}
	.main-visual__text p {
		font-size: 14px;
	}
	
  .main-visual::before {
  content: "";
  position: absolute;
  top: 0%;
  left: -190%;
  width: 400%;
  height: 40%;
  background: rgba(255, 255, 255, 0.3);
  transform: rotate(55deg) translateY(calc(var(--parallax-offset, 0px) * -1));
  opacity: 0;
  z-index: 10;
  animation: showWhiteOverlay 1s ease-out forwards;
  animation-delay: 0.6s;
  transition: transform 0.2s ease-out;
  pointer-events: none;
}
	
}




/* ---------------------------------------------------------
イントロダクション
----------------------------------------------------------*/

.sec-intro{
	text-align: center;
	padding: 60px 50px 110px;
}

.intro_ttlWrapper{
	margin-bottom: 30px;
}

.intro_ico{
	width: 60px;
	height: auto;
	margin-bottom: 10px;
}

.intro_ttl{
	font-size: 22px;
	color: #1a1a1a;
	line-height: 1.8;
}

.intro_body{
	
}


.intro_text{
	margin-bottom: 40px;
	line-height: 2.3;
}

.intro_eng{
	font-size: 42px;
	z-index: 2;
}

.sec-intro {
  position: relative;
	overflow: hidden; /* 擬似要素のはみ出し防止 */
}


.sec-intro::after {
  content: "";
  position: absolute;
  top: 40%;
  left: -40%;
  width: 100%;
  height: 70%;
  background: rgba(204, 204, 204, 0.2); 
  /*transform: rotate(50deg);*/
	transform: translateY(calc(var(--parallax-offset, 0px))) rotate(50deg);
}

@media (max-width: 1040px) {
 .intro_ttl{
	font-size: 20px;
}
}

@media (max-width: 540px) {
 
.sec-intro{
	padding: 60px 0px 70px;
}
	.intro_ico{
		width: 50px;
	}
	
	.intro_ttl{
	font-size: 18px;
}
		
	.intro_eng{
	font-size: 28px;
}
	
	.sec-intro::after {
  content: "";
  position: absolute;
  top: 70%;
  left: -90%;
  width: 200%;
  height: 40%;
  background: rgba(204, 204, 204, 0.2); 
  /*transform: rotate(50deg);*/
	transform: translateY(calc(var(--parallax-offset, 0px))) rotate(50deg);
}
	
}


/* ---------------------------------------------------------
サービス
----------------------------------------------------------*/

.sec-service{
	position: relative;
	z-index: 2;
}

.service_body{
	width: 100%;
	height:583px;
}

.service_inner{
	width: 50%;
	padding:80px 100px 80px 80px;
}


.service_ttlWrapper{
	
}

.line{
	width:20%;
	padding-top: 10px;
}
.line-r{
	width: 80%;
}

.service_ttl{
	color: #fff;
}

.service_ttl_sub{
	color: #fff;
}

.service_text{
	color: #fff;
}

.service_btn{
	color: #fff;
}

.service_imgWrapper{
	width: 50%;
  overflow: hidden;   /* はみ出し防止（任意） */
	margin-top:-40px;
	position: absolute;
	top:0;
	right:0;
}

.service_img{
	height: 543px;      /* 高さを固定（例：300px） */
  width: 100%;       /* 横幅は親要素いっぱいに広げる */
  object-fit: cover; /* 縦横比を保ちながら拡大・切り取り */
  display: block;    /* 下の余白除去 */
	object-position: top; /* 画像の表示基準を上に */
}


/*矢印*/

.service_btn .view-more-btn {
  color: #fff;
}

.service_btn .circle {
  border: 1px solid #fff;
}


.service_btn .yoko {
  border-top: 1px solid #fff;
}

.service_btn .arrow {
  border-top: 1px solid #fff;
}

/* ホバー時：矢印だけ右にスライド + 色をオレンジに */
.service_btn .view-more-btn:hover {
  color: #FFA500; /* テキストも変えたい場合 */
}


@media (max-width: 1040px) {
	
	
 .service_inner{
	width: 50%;
	padding:80px 40px 80px 20px;
}
	
	.line{
	width:20%;
	padding-top: 10px;
}
.line-r{
	width: 80%;
}
}

@media (max-width: 840px) {
	.service_body{
	width: 100%;
	height:650px;
}
	
 .service_inner{
	width: 50%;
	padding:80px 40px 80px 0px;
}
	
	.line{
	width:20%;
	padding-top: 10px;
}
.line-r{
	width: 80%;
}
}

@media (max-width: 540px) {
 
	.service_imgWrapper{
		position:inherit;
	}
	
	.service_body{
	width: 100%;
	height:auto;
}
	
	.service_inner{
		width: 100%;
		padding: 60px 35px 90px 0px
	}
	
	.line{
	width:15%;
	padding-top: 10px;
}
.line-r{
	width: 85%;
}
	
	.service_img{
		height: 300px;
	}
	
}



/* ---------------------------------------------------------
スライダー
----------------------------------------------------------*/
.service-slider-wrapper {
  position: relative;
  overflow: hidden;
  padding: 0 40px;
	z-index: 5;
}

.service-slider {
  overflow: visible;
}

.service-slide {
  display: flex;
  gap: 40px;
  transition: transform 0.5s ease;
	margin-left: 95px;
}

.service-box {
  flex: 0 0 calc((100% - 2 * 20px) / 4); /* 3個表示＋余白考慮 */
	/*flex: 0 0 auto;*/ /* 固定幅 */
  background: #f9f9f9;
  padding: 25px 35px 0px 35px;
  text-align: center;
  border-radius: 6px;
	margin-bottom: 100px;
}

.service-box img {
  width: 105px;
  height: 85px;
  margin-bottom: 15px;
}


.service-box h3{
	font-size: 18px;
	margin-bottom: 10px;
}

.service-list-text{
	font-size: 14px;
	line-height: 2;
}

.service-num{
	font-size: 22px;
	margin-bottom: 10px;
}

.service-list_btn{
	padding-left:220px;
}

.service-list_btn .yoko,
.service-list_btn .arrow{
	border-top: 1px solid #1a1a1a;
	
}

.view-more-btn .arrow-wrapper {
  display: inline-block;
  transition: transform 0.3s ease;
}

.service-box:hover .view-more-btn .arrow-wrapper {
  transform: translateX(10px); /* 矢印を少し右に動かす */
}

.service-box:hover .view-more-btn .arrow-wrapper .yoko,
.service-box:hover .view-more-btn .arrow-wrapper .arrow{
  border-top: 1px solid #e87e1f;
}


.service-box-link:hover {
  opacity: 1;
}

.service-box {
  /* 通常状態 */
  transition: box-shadow 0.3s ease, transform 0.1s ease;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
  transform: translateY(0);
}

.service-box:hover {
  /* ホバーで「押したような」効果 */
  box-shadow: 0 1px 4px rgba(0,0,0,0.05);
  transform: translateY(2px);
}

/* スライダー矢印 */
.slider-btn {
  position: absolute;
  top: 44%;
  transform: translateY(-90%);
  width: 48px;                 /* 丸のサイズ */
  height: 48px;
  background: #fff;
  border: none;
  border-radius: 50%;          /* 丸くする */
  cursor: pointer;
  font-size: 24px;
  z-index: 1;
  box-shadow: 0 2px 6px rgba(0,0,0,0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.3s ease, transform 0.2s ease;
	color: #1a1a1a;
}

.slider-btn:hover {
  background-color: #f0f0f0;   /* ホバー時の色 */
  transform: translateY(-90%) scale(1.05);  /* 拡大してクリック感 */
}

.slider-btn.prev {
  left: 20px;
}

.slider-btn.next {
  right: 20px;
}

.service-slider-about{
	position: relative;
	overflow: hidden;
	margin-top: -50px;
}

.service-slider-about::after {
  content: "";
  position: absolute;
  top: 30%;
  right: -90%;
  width: 150%;
  height: 70%;
  background: rgba(204, 204, 204, 0.2); 
  /*transform: rotate(50deg);*/
	transform: translateY(calc(var(--parallax-offset, 0px))) rotate(50deg);
}


@media (max-width: 840px) {
	
.service-slider-about::after {
  content: "";
  position: absolute;
  top: -10%;
  right: -90%;
  width: 150%;
  height: 70%;
  background: rgba(204, 204, 204, 0.2); 
  /*transform: rotate(50deg);*/
	transform: translateY(calc(var(--parallax-offset, 0px))) rotate(50deg);
}

}

@media (max-width: 540px) {
 
	.service-slider-wrapper {
  padding: 0 20px;
	height: 350px;

}

	.service-slide {
  gap: 20px;
}
	
.service-box {
	flex: 0 0 calc((100% - 2 * 20px) / 4); /* 3個表示＋余白考慮 */
  padding: 20px 20px 0px 20px;
	margin-bottom: 100px;
}

.service-box img {
  width: 65px;
  height: 55px;
  margin-bottom: 15px;
}


.service-box h3{
	font-size: 16px;
	margin-bottom: 10px;
}
	.service-slider-about{
		margin-top: -30px;
	}
	
	.service-slider-about::after {
  content: "";
  position: absolute;
  top: -30%;
  right: -110%;
  width: 200%;
  height: 70%;
  background: rgba(204, 204, 204, 0.2); 
  /*transform: rotate(50deg);*/
	transform: translateY(calc(var(--parallax-offset, 0px))) rotate(50deg);
}

	.slider-btn {
  width: 38px;   
  height: 38px;
  font-size: 18px;
}
	
	.slider-btn.prev {
  left: 10px;
}

.slider-btn.next {
  right: 10px;
}

	
}



/* ---------------------------------------------------------
アバウトアス
----------------------------------------------------------*/

.sec-about{
	flex-direction:row-reverse;
}

.about_body{
	width: 50%;
	padding:30px 180px 0px 40px;
	height:468px;
}

.line2{
	width: 22%;
	padding-top: 10px;
}
.line2-r{
	width: 78%;
}

.about_ttlWrapper{
	
}

.about_ttl{
	
}

.about_ttl_sub{
	
}
.about_text{
	
}

.about_btn{
	
}

.about_imgWrapper{
	width: 50%;
  overflow: hidden;   /* はみ出し防止（任意） */
	/*position: relative;*/ 
}

.sec_imgWrapper {
  will-change: transform;
  transition: transform 0.1s linear;
}

.about_img{
	height: 468px;      /* 高さを固定（例：300px） */
  width: 100%;       /* 横幅は親要素いっぱいに広げる */
  object-fit: cover; /* 縦横比を保ちながら拡大・切り取り */
  display: block;    /* 下の余白除去 */
	
	/*height: 120%;
	position: relative;
  transform: translateY(calc(var(--img-parallax-offset, 0px)));
  transition: transform 0.1s linear;
  will-change: transform;*/ 
	
}

@media (max-width: 1180px) {
  .about_body{
	width: 50%;
	padding:30px 40px 0px 40px;
	height:auto;
}
}



@media (max-width: 840px) {


.about_body{
	width: 50%;
	padding:40px 40px 80px 0px;
}
	
	.line2{
	width:20%;
	padding-top: 10px;
}
.line2-r{
	width: 80%;
}

}


@media (max-width: 540px) {


.about_body{
	width: 100%;
	padding:0px 40px 80px 0px;
}
	
	
	.line2{
	width:15%;
	padding-top: 10px;
}
.line2-r{
	width: 85%;
}
	.about_img{
		height: 300px;
	}
	
}

/*.sec-about {
  position: relative;
	overflow: hidden;
}

.sec-about::after {
  content: "";
  position: absolute;
  top: 40%;
  right: -90%;
  width: 150%;
  height: 70%;
  background: rgba(204, 204, 204, 0.2); 
	transform: translateY(calc(var(--parallax-offset, 0px))) rotate(50deg);
}*/

/* ---------------------------------------------------------
アバウトアス　リスト
----------------------------------------------------------*/

.sec-aboutList{
	margin-top: -30px;
}

.aboutList_body{
	display: flex; 
	padding:90px 150px 90px 150px;
	/*height:300px;*/
	height: auto; /* 高さを固定せず中身に合わせる */
  gap: 30px; /* カード同士の間隔（任意） */
}

.dot2{
      background-color: #4d4d4d; /* 黒背景 */
      background-image: url("../img/home/bg_01.png");  /* 画像のパスを指定 */
      background-repeat: repeat; /* 縦横リピート */
      background-size: 350px; 
      width: 100%;
      height: 310px; /* 画面全体に表示 */
}

.aboutList_card{
	width: 30%;
	background-color: #f2f2f2;
	padding: 30px;
	border-radius: 4px;
}

	.aboutList_ttl{
	line-height: 2;
}

.aboutList_ttl span{
	font-size: 18px;
	display: block;
}

.aboutList_btn{
	padding-top: 20px;
}

.view-more-btn .arrow-wrapper {
  display: inline-block;
  transition: transform 0.3s ease;
	margin-right: 10px;
}

.aboutList_card:hover .view-more-btn .arrow-wrapper {
  transform: translateX(10px); /* 矢印を少し右に動かす */
}

.aboutList_card:hover .view-more-btn .arrow-wrapper .yoko,
.aboutList_card:hover .view-more-btn .arrow-wrapper .arrow{
  border-top: 1px solid #e87e1f;
}

.aboutList_card:hover .view-more-btn .arrow-wrapper {
  transform: translateX(10px); /* 矢印を少し右に動かす */
}

.aboutList_card:hover .view-more-btn .arrow-wrapper .yoko,
.aboutList_card:hover .view-more-btn .arrow-wrapper .arrow{
  border-top: 1px solid #e87e1f;
}


.aboutList_card:hover {
  opacity: 1;
}

.aboutList_card {
  /* 通常状態 */
  transition: box-shadow 0.3s ease, transform 0.1s ease;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
  transform: translateY(0);
}

.aboutList_card:hover {
  /* ホバーで「押したような」効果 */
  box-shadow: 0 1px 4px rgba(0,0,0,0.05);
  transform: translateY(2px);
}

@media (max-width: 1180px) {
  .aboutList_body{
	padding:60px 24px;
	height:200px;
}
	.dot2{
      height: 260px; /* 画面全体に表示 */
}
}


@media (max-width: 840px) {
  .aboutList_body{
	padding:60px 24px;
	height:200px;
}
	.dot2{
      height: 260px; /* 画面全体に表示 */
}
	
	.aboutList_card{
		width: 30%;
	padding: 20px 20px 10px;
}
	
	.aboutList_ttl{
		width: 100%;
	}
	
	.aboutList_btn{
	padding-top:0;	
	margin-left: -20px;
	}

}
/*@media (max-width: 840px) {
 .aboutList_body{
	 flex-direction: column;
	}
}*/

/* レスポンシブ対応：スマホで1列表示にする */
@media screen and (max-width: 540px) {
  .aboutList_body {
    padding: 60px 20px;
	  gap:20px;
  }

  .aboutList_card {
    width: 100%;
	 padding: 20px 20px 10px;
  }
	
	.dot2{
      height: 440px; /* 画面全体に表示 */
}
	
	.aboutList_ttl{
		width: 70%;
	}
	
	.aboutList_btn{
	padding-top:10px;	
	margin-left: 0px;
	}
}

/* ---------------------------------------------------------
カンパニー
----------------------------------------------------------*/

.sec-company{
	padding-top: 80px;
	padding-bottom: 80px;
}

.line3{
	width: 22%;
	padding-top: 10px;
	z-index: 2;
}

.line3-r{
	width: 78%;
	z-index: 2;
}

.company_body{
	width: 50%;
	padding:30px 180px 0px 40px;
	height:468px;
}

.company_ttlWrapper{
	
}

.company_ttl{
	
}

.company_ttl_sub{
	
}
.company_text{
	
}

.company_btn{
	
}

.company_imgWrapper{
	width: 50%;
  /*overflow: hidden;*/ 
}

.company_img{
	height: 468px;      /* 高さを固定（例：300px） */
  width: 100%;       /* 横幅は親要素いっぱいに広げる */
  object-fit: cover; /* 縦横比を保ちながら拡大・切り取り */
  display: block;    /* 下の余白除去 */
}

.sec-company {
  position: relative;
	overflow: hidden; /* 擬似要素のはみ出し防止 */
}


.sec-company::after {
  content: "";
  position: absolute;
  top: 30%;
  left: -50%;
  width: 100%;
  height: 60%;
  background: rgba(204, 204, 204, 0.2); 
  /*transform: rotate(50deg);*/
	transform: translateY(calc(var(--parallax-offset, 0px))) rotate(50deg);
}

@media (max-width: 1180px) {
  .company_body{
	width: 50%;
	padding:30px 40px 0px 40px;
	height:468px;
}
}


@media (max-width: 840px) {


  .company_body{
	width: 50%;
	padding:40px 40px 80px 0px;
}
	
	.line3{
	width:20%;
	padding-top: 10px;
}
.line3-r{
	width: 80%;
}
	
	.sec-company::after {
  content: "";
  position: absolute;
  top: 50%;
  left: -50%;
  width: 100%;
  height: 60%;
  background: rgba(204, 204, 204, 0.2); 
  /*transform: rotate(50deg);*/
	transform: translateY(calc(var(--parallax-offset, 0px))) rotate(50deg);
}

}


@media (max-width: 540px) {

	.sec-company{
		padding-bottom: 50px;
	}
	
  .company_body{
	width: 100%;
	padding:0px 40px 80px 0px;
	  height: auto;
}
	
	.line3{
	width:15%;
	padding-top: 10px;
}
.line3-r{
	width: 85%;
}
	.company_img{
		height: 300px;
	}
	
	
	.sec-company::after {
  content: "";
  position: absolute;
  top: 50%;
  left: -100%;
  width: 200%;
  height: 60%;
  background: rgba(204, 204, 204, 0.2); 
  /*transform: rotate(50deg);*/
	transform: translateY(calc(var(--parallax-offset, 0px))) rotate(50deg);
}

}

/* ---------------------------------------------------------
推薦者の声
----------------------------------------------------------*/

.sec-testimonials{
	
}

.testimonials_body{
	padding: 80px 0px 0px 80px;
	z-index: 2;
	justify-content:flex-start;
	width: 100%;
}

.line4{
	width: 100px;
	padding-top: 10px;
}
.line4-r{
	width: auto;
}

.testimonials_ttl{
	
}

.testimonials_ttl_sub{
	color: #fff;
}

.testimonials_list{
	width: 100%;
	justify-content:space-between;
	padding: 0px 30px 90px 30px;
	max-width: 1180px;
	margin:  0 auto;
}

.testimonials_card{
	width: 45%;
	text-align: center;
}

.testimonials_img{
	width: 38%;
	margin-bottom: 10px;
}

.testimonials_position{
	font-size: 12px;
	color: #fff;
	line-height: 1.3;
}

.testimonials_name{
	font-size: 15px;
	color: #fff;
	margin-bottom: 15px;
}

.testimonials_text{
	font-size: 15px;
	color: #fff;
	text-align: left;
	line-height: 1.6;
}

.dot3{
      background-color: #4d4d4d; /* 黒背景 */
      background-image: url("../img/home/bg_01.png");  /* 画像のパスを指定 */
      background-repeat: repeat; /* 縦横リピート */
      background-size: 350px; 
      width: 100%;
      height: auto; /* 画面全体に表示 */
}


/* 白い斜めの四角形（左上から中央右下へ） */
.sec-testimonials {
  position: relative;
	overflow: hidden; /* 擬似要素のはみ出し防止 */
}

/*
.sec-testimonials::after {
  content: "";
  position: absolute;
  top: 20%;
  right: -65%;
  width: 100%;
  height: 60%;
  background: rgba(255, 255, 255, 0.1); 
  transform: rotate(50deg);
  z-index: 0;
}

*/
.sec-testimonials::before {
  content: "";
  position: absolute;
  top: 20%;
  left: -80%;
  width: 150%;
  height: 60%;
  background: rgba(255, 255, 255, 0.1); 
 /* transform: rotate(50deg);*/
	transform: translateY(calc(var(--parallax-offset, 0px))) rotate(50deg);
  z-index: 0;
}


@media (max-width: 1180px) {
 
.testimonials_body{
	padding: 50px 100px 50px 20px;
	z-index: 2;
}

}


@media (max-width: 840px) {


.testimonials_body{
	padding:50px 40px 20px 0px;
}
	
.line4{
	width: 8%;
	padding-top: 10px;
}
.line4-r{
	width: 92%;
}
	
	.sec-testimonials::before {
  content: "";
  position: absolute;
  top: 50%;
  left: -80%;
  width: 150%;
  height: 60%;
  background: rgba(255, 255, 255, 0.1); 
 /* transform: rotate(50deg);*/
	transform: translateY(calc(var(--parallax-offset, 0px))) rotate(50deg);
  z-index: 0;
}
	
.testimonials_card{
	width: 47%;
}
.testimonials_text{
	font-size: 14px;
}
}


@media (max-width: 540px) {

	.testimonials_card{
		width: 100%;
	}
	
	.testimonials_list{
		gap:30px;
	}
	
	.line4{
	width:15%;
	padding-top: 10px;
}
.line4-r{
	width: 85%;
}
	
.sec-testimonials::before {
  content: "";
  position: absolute;
  top: 40%;
  left: -90%;
  width: 300%;
  height: 30%;
  background: rgba(255, 255, 255, 0.1); 
 /* transform: rotate(50deg);*/
	transform: translateY(calc(var(--parallax-offset, 0px))) rotate(50deg);
  z-index: 0;
}

	
}


/* ---------------------------------------------------------
お客様の声
----------------------------------------------------------*/

.voice_body{
	padding: 80px 20px 30px 20px;
	justify-content:flex-start;
	max-width: 1280px;
	margin: 0 auto;
	
}

.line5{
	width: 100px;
	padding-top: 10px;
}
.line5-r{
	width: auto;
	
}

.voice_ttl{
	margin-bottom: 0;
}
.cardList .cardList_item{
	padding:0 45px 80px;
}

@media (max-width: 1180px) {
.cardList.cardList-1row .cardList_item{
	padding:0 20px 0px;
}

}

@media (max-width: 840px) {


.voice_body{
	padding:50px 40px 40px 0px;
}
	
.line5{
	width: 8%;
	padding-top: 10px;
}
.line5-r{
	width: 92%;
}
	
	.cardList{
	/*max-width: 400px;*/
		margin: 0 auto;
		flex-direction: row;
		
}
	
.cardList.cardList-1row .cardList_item{
	margin-bottom: 0px;
		 width:33%;
}


}

@media (max-width: 540px) {

	.voice_body{
	padding:50px 40px 0px 0px;
}
	
	.line5{
	width:15%;
	padding-top: 10px;
}
.line5-r{
	width: 85%;
}
.cardList{
	/*max-width: 400px;*/
		margin: 0 auto;
		flex-direction: column;
		
}	
.cardList.cardList-1row .cardList_item{
	margin-bottom: 40px;
		 width:100%;
}
}


/* ---------------------------------------------------------
お客様の声　CMS部分
----------------------------------------------------------*/

.voice_btn{
	text-align: right;
	padding: 0 30px 50px 0;
	margin-top: -70px;		
}

.card .card_title{
		font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 16px;
	line-height: 1.7;
	color: #1a1a1a;
}

.card .card_company{
	font-size: 13px;
	color: #666666;
}
.card .card_pic{
	margin-bottom: 25px;
	padding-bottom: 66.6667%; /* ← 2 ÷ 3 × 100（3:2の比率） */
}


@media (max-width: 840px) {

.voice_btn{
	padding-bottom: 30px;
}
}

@media (max-width: 540px) {

.voice_btn{
	text-align: right;
	padding: 0 20px 30px 0;
	margin-top: 0px;		
}
}

/* ---------------------------------------------------------
お知らせ
----------------------------------------------------------*/

.news_body{
	padding: 60px 20px 0px 20px;
	justify-content:flex-start;
	max-width: 1280px;
	margin: 0 auto;
}

.line6{
	width: 100px;
	padding-top: 10px;
}
.line6-r{
	width: auto;
}

@media (max-width: 840px) {


.news_body{
	padding:50px 40px 20px 0px;
}
	
.line6{
	width: 8%;
	padding-top: 10px;
}
.line6-r{
	width: 92%;
}
	

}


@media (max-width: 540px) {
.news_body{
	padding:50px 40px 0px 0px;
}
	.news_ttl{
		margin-bottom: 0;
	}
	
	.line6{
	width:15%;
	padding-top: 10px;
}
.line6-r{
	width: 85%;
}
	

}

/* ---------------------------------------------------------
バナーエリア
----------------------------------------------------------*/

.bnrArea_body{
	margin: 0 auto;
	padding: 80px 70px;
	max-width: 1200px;
}


.bnrArea_card {
  position: relative;
  display: block;
  width: 48%;
  height: 220px;
  overflow: hidden;
  text-decoration: none;
  border-radius: 4px;
	margin-bottom: 40px;
}

.bnrArea_card2 {
  position: relative;
  display: block;
  width: 100%;
  height: 220px;
  overflow: hidden;
  text-decoration: none;
  border-radius: 4px;
	z-index: 3;
}


.bnrArea_card img,
.bnrArea_card2 img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
  display: block;
}

.bnrArea_card:hover img,
.bnrArea_card2:hover img {
  transform: scale(1.05);
}

/* オーバーレイ（暗い透過） */
.bnrArea_card::before,
.bnrArea_card2::before{
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.4); /* ここで暗さを調整 */
  z-index: 1;
  transition: background 0.3s ease;
}

.image-text .line7,
.image-text .line8,
.image-text .line9{
  position: absolute;
  top: 50%;
  left: 0px;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
	z-index: 2;
}

.image-text .bnrArea_ttl{
  position: absolute;
  top: 50%;
  left: 100px;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  padding: 8px 16px;
	z-index: 2;
	color: #fff;
}

.image-text .bnrArea_ttl span{
  color: #fff;
	font-size: 16px;
	padding:25px 0 0 10px;
}



.image-text .line7 {
  /*display: inline-block;
  width: 6px;
  height: 24px;
  background-color: orange;
  margin-right: 10px;
  border-radius: 3px;*/
}


/*.line7{
	width: 30%;
}
.line7-r{
	width: 70%;
}*/


.dot4{
      background-color: #d3d3d3; /* 黒背景 */
      background-image: url("../img/home/bg_02.png");  /* 画像のパスを指定 */
      background-repeat: repeat; /* 縦横リピート */
      background-size: 350px; 
      width: 100%;
      height: auto; /* 画面全体に表示 */
}

@media (max-width: 840px) {
	
.bnrArea_body{
	padding: 40px 40px;
}

	
.bnrArea_card {
  height: 160px;
	margin-bottom: 40px;
}

.bnrArea_card2 {
  height: 160px;
}
	
.image-text .bnrArea_ttl{
  left: 40px;
  transform: translateY(-50%);
  padding: 8px 16px;
	font-size: 40px;
	display: block;
}

.image-text .bnrArea_ttl span{
	padding:10px 0 0 0px;
	display: block;
}


}

@media (max-width: 540px) {
	.bnrArea_card{
		width: 100%;
		margin-bottom:20px;
		height: 130px;
	}
	
	.bnrArea_card2{
		height: 130px;
	}
	
	.image-text .bnrArea_ttl span{
		font-size: 13px;
	}

}


/* ---------------------------------------------------------
お問い合わせ
----------------------------------------------------------*/

.full-width-banner {
  width: 100%;
  height: auto;
	padding:90px 20px 110px 20px;
  background-image: url("../img/home/contact_img_01.jpg"); /* 画像パスを指定 */
  background-size: cover;
  background-position: center;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  text-align: center;
	overflow: hidden; 
}

/* オーバーレイ（暗くする） */
.full-width-banner::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: rgba(0, 0, 0, 0.4);
  z-index: 1;
}

/* コンテンツ部分 */
.banner-content {
  position: relative;
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

/* テキスト */
.contact_ttl {
  color: #fff;
  margin: 0;
}

.banner-content p {
  margin-bottom: 30px;
}

/* ボタングループ横並び */
.button-group {
  display: flex;
  gap: 50px;
  flex-wrap: wrap;
  justify-content: center;
}

/* ボタン共通 */
.contact-button {
  display: inline-block;
  padding: 22px 60px;
  background-color: #e87e1f;
  color: #fff;
  text-decoration: none;
  border-radius: 44px;
  transition: background 0.3s ease;
  white-space: nowrap;
	width: 300px;
}

.contact-button:hover {
  background-color: #4d4d4d;
	opacity: 1;
}


/* 白い斜めの四角形（左上から中央右下へ） */
/*.full-width-banner::after {
  content: "";
  position: absolute;
  top: 0%;
  left: -20%;
  width: 100%;
  height: 70%;
  background: rgba(255, 255, 255, 0.3); 
  transform: rotate(50deg);
  z-index: 2;
}*/



/*.full-width-banner::after {
  content: "";
  position: absolute;
  top: 0%;
  left: -20%;
  width: 100%;
  height: 70%;
  background: rgba(255, 255, 255, 0.2);
  transform: translateY(-100px) rotate(50deg);
  opacity: 0;
  transition: transform 0.5s ease, opacity 0.5s ease;
  transition-delay: 0.5s;
  z-index: 2;
}

.full-width-banner.animate::after {
  transform: translateY(0) rotate(50deg);
  opacity: 1;
}
*/

.full-width-banner::after {
  content: "";
  position: absolute;
  top: 0%;
  left: -40%;
  width: 130%;
  height: 75%;
  background: rgba(255, 255, 255, 0.2);
  /*transform: rotate(50deg);*/
	transform: translateY(calc(var(--parallax-offset, 0px))) rotate(50deg);
	z-index: 2;
}


@media (max-width: 540px) {
	.button-group{
		gap:20px;
	}
	.contact-button{
		padding: 15px 40px;	
	}
	
	
.full-width-banner::after {
  content: "";
  position: absolute;
  top: 20%;
  left: -100%;
  width: 300%;
  height: 60%;
  background: rgba(255, 255, 255, 0.2);
  /*transform: rotate(50deg);*/
	transform: translateY(calc(var(--parallax-offset, 0px))) rotate(50deg);
	z-index: 2;
}
}
/* ---------------------------------------------------------
フッター
----------------------------------------------------------*/

.site-footer {
  background-color: #4d4d4d;
  color: #fff;
  padding: 60px 20px 40px;
}

.footer-inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  max-width: 1180px;
  margin: 0 auto;
}

.footer-logo img {
  width: 130px;
  height: auto;
	margin-bottom: 30px;
}

.footer-logo {
  text-align: center;
}

.footer-social {
  display: flex;
  justify-content: center;
  gap: 20px; /* アイコン間の余白 */
}

.footer-social a img {
  width: 30px; /* アイコンサイズ（調整OK） */
  height: auto;
  transition: opacity 0.3s ease;
}

.footer-social a:hover img {
  opacity: 0.7;
  cursor: pointer;
}


.footer-menu {
  display: flex;
  gap: 80px;
  flex-wrap: wrap;
}

.menu-column ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.menu-column li {
  margin-bottom: 8px;
}

.menu-column a {
  color: #fff;
  text-decoration: none;
  font-size: 15px;
}

.menu-column a:hover {
}


@media (max-width: 840px) {
	.footer-logo{
		margin:0 auto;
	}
	
.footer-logo img {
  width: 120px;
}
	
}


@media (max-width: 540px) {
	.footer-menu{
		display: none;
	}
	
	
}


/*店舗情報*/
.footer-addresses {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  max-width: 1200px;
  margin: 40px auto 0;
  padding-top: 20px;
  gap: 80px;
  color: #fff;
  font-size: 14px;
}

.footer-addresses__column {
  flex: 1 1 45%;
  min-width: 280px;
}

.footer-heading {
  font-size: 16px;
  margin-bottom: 16px;
  position: relative;
  padding-bottom: 10px;
}

.footer-heading::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  height: 1px;
  width: 100%;
  background-color: #e87e1f;
}

.office-row {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}

.office-info {
  flex: 1 1 48%;
  line-height: 1.7;
}

.office-info p {
  margin: 0 0 14px 0;
}

.office-info p span{
  font-size: 15px;
	line-height: 2;
}

.office-title {
  position: relative;
  padding-left: 16px;
  display: inline-block;
}

.office-title::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.95em;
  width: 6px;
  height: 6px;
  background-color: #e87e1f;
  border-radius: 50%;
}


/* スマホ対応 */
@media screen and (max-width: 840px) {
  .footer-addresses {
    flex-direction: column;
    gap: 40px; /* 縦の間隔を適度に */
  }

  .footer-addresses__column {
    flex: 1 1 20%;
    max-width: 100%;
  }
	
	.office-row{
		margin-bottom: -150px;
	}
}

@media (max-width: 540px) {
	.footer-addresses{
		margin-top: 0;
	}
	
	.office-row{
		margin-bottom: 0px;
	}
	
}


/*@media (max-width: 840px) {
  .footer-addresses {
    flex-direction: column;
    padding-left: 20px;
    padding-right: 20px;
  }

  .footer-addresses__column {
    width: 100%;
  }

  .office-row {
    flex-direction: column;
  }

  .office-info {
    flex: 1 1 100%;
  }
}*/

.footer-bottom {
  padding: 40px 0 0;
  text-align: center;
  color: #fff;
  font-size: 14px;
}

@media (max-width: 1040px) {
 
.footer-bottom {
  padding: 90px 0 0;
}
}


@media (max-width: 540px) {
 
	.sec_imgWrapper{
		width: 100%;
	}
	
	.sec_imgWrapper{
		width: 100%;
	}
	
	.sec_ttl{
		font-size: 46px;
	}
	
	.sec_ttl_sub{
		font-size: 13px;
	}
}




/* ---------------------------------------------------------
下層ページ共通
----------------------------------------------------------*/

.c_mv {
  width: 100%;
  height: 400px;
	padding:60px 20px 0 20px;
  background-image: url("../img/home/contact_img_01.jpg"); /* 画像パスを指定 */
  background-size: cover;
  background-position: center;
  position: relative;
  display: flex;
  align-items: center;
  /*justify-content: center;*/
  color: #fff;
  text-align: left;
	overflow: hidden; 
	margin-top: -86px;
}

.c_mv::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 1;
}

.c_mv::after {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background-image: url("../img/common/bg_02.png");
  background-size: 400px;
  background-position: center;
  z-index: 2;
	opacity: 0.3;
}

.c_mv_content {
  /*position: relative;*/
  z-index: 3;
  display: flex;
	width: 100%;
  /*flex-direction: column;
  gap: 20px;*/
	align-items: center;
	max-width: 1280px;
	margin: 0 auto;
}

.line10::before{
  content: "";
  display: inline-block;
  width: 0;
  height: 3px;
  background-color: #e87e1f;
  transition: none;
  --line-width: 110px; 
}

.animate-line10::before {
  animation: lineGrow 0.3s cubic-bezier(0.6, 0, 1, 1) forwards;
  animation-delay: 0.3s;
}

/* アニメーション定義 */
/*@keyframes lineGrow {
  from {
    width: 0;
  }
  to {
    width: var(--line-width);
  }
}*/

/* 画面幅が840px以下の場合に幅を20pxに変更 */
@media screen and (max-width: 840px) {
.line10::before{
    --line-width: 50px;
  }
}

.line10{
	width: 12%;
	/*padding-top: 10px;*/
}
.line10-r{
	width: 88%;
}

.c_ttl{
	color: #fff;
	font-size: 70px;
}

.c_ttl_sub{
	color: #fff;
	font-size: 18px;
}

.c_section{
	padding-top: 60px;
	padding-bottom: 80px;
}

.section .c_section_inner{
	padding-top: 80px;
	padding-bottom: 20px;
}

@media (max-width: 1180px) {
	
.section .c_section_inner{
	padding-top: 40px;
	padding-bottom: 20px;
}

}

@media (max-width: 540px) {
 .c_mv {
	 height: 300px;
	 padding:100px 20px 0 0px;
}
	
.line10{
	width: 15%;
}
	
.line10-r{
	width: 85%;
}

.c_ttl{
	font-size: 44px;
}
	
.c_ttl_sub{
	font-size: 16px;
}
	
	.c-text{
		font-size: 14px;
	}
}

/* ---------------------------------------------------------
お客様の声ページ
----------------------------------------------------------*/

.c_mv_voice {
  background-image: url("../img/voice/mv_01.jpg"); 
}

.section .section_header{
	padding: 0;
}

.section_header:after {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    content: "";
    background: #e87e1f;
}

.section_header_inner{
	padding:0 20px 50px 20px;
	max-width: 936px;
	margin: 0 auto;
}

.heading-primary {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
	letter-spacing: 0.14em;
	color: #1a1a1a;
	font-size: 22px;
	line-height: 1.7;
	margin-bottom:20px;
	padding-bottom: 0;
}

.heading-primary:after{
	height:0;
}

.post_companyName{
	color: #666666;
}

.post .post_content{
	padding:60px 20px 0 20px;
	max-width: 936px;
	margin: 0 auto;
}

.content *{
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 400;
	font-style: normal;
	font-size: 16px;
	line-height: 2;
	color: #1a1a1a;
}

.content h2{
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
	letter-spacing: 0.14em;
	color: #1a1a1a;
	border-left:3px solid #e87e1f;
}

.prevNext{
	max-width: 936px;
	margin: 0 auto;
	padding:70px 20px 20px 20px;
}

.prevNext .prevNext_item a{
	color:#1a1a1a;
}

.prevNext .prevNext_item a span{
	padding:0 20px;
  font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
	letter-spacing: 0.1em;
	line-height: 1.5;
	transition: 0.2s;
}

.prevNext .prevNext_item a:hover span{
	text-decoration: none;
	color:#e87e1f;
}

.prevNext .prevNext_item-prev{
	border-right:none;
}

@media (max-width: 1180px) {
.cardList .cardList_item{
	padding:0 20px 20px;
	width:33%;
}

}

@media (max-width: 540px) {
 
.heading-primary {
	font-size: 18px;
}
	
.content h2{
	font-size: 18px;
}
	
	.cardList .cardList_item{
	padding:0 20px 20px;
	width:100%;
}

}


/* ---------------------------------------------------------
お知らせページ
----------------------------------------------------------*/

.sec-newsList{
	margin-bottom: 80px;
}

.section .news_inner{
	padding:0 40px;
}

.newsList_item{
	width: 100%;
	padding: 20px;
	border-bottom: 1px solid #cccccc;
}

.newsCard a{
	width: 100%;
}

.newsCard_body{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: top;
	width: 100%;
}

.newsCard_time{
	width: 15%;
	line-height: 1.7;
}

.newsCard_title{
	width: 85%;
	line-height: 1.7;
}

.c_mv_news {
  background-image: url("../img/news/mv_01.jpg"); 
}

.post_time{
	color: #666666;
}

.back-to-archive{
	margin: 0 auto;
	text-align: center;
}

.btn-back {
	
  display: inline-block;
  padding: 12px 30px;
	width: 200px;
  color: #1a1a1a;
  text-decoration: none;
  border-radius: 30px;
	border: 1px solid #1a1a1a;
	transition: all 0.3s ease;
	font-size: 14px;
}
.btn-back:hover {
	border: 1px solid #e87e1f;
  color: #e87e1f;
}


@media (max-width: 1040px) {
.newsCard_time{
	width: 20%;
}

.newsCard_title{
	width: 80%;
}
}

@media (max-width: 540px) {
	
	.section .news_inner{
	padding:0 20px;
}
	
	.newsList_item{
	padding: 20px 0;
}
	
.newsCard_time{
	width: 100%;
	font-size: 13px;
}

.newsCard_title{
	width: 100%;
}
}


/* ---------------------------------------------------------
FAQページ
----------------------------------------------------------*/
.c_mv_faq{
	background-image: url("../img/faq/mv_01.jpg"); 
}

.c_inner{
	margin: 0 auto;
	max-width: 1160px;
	padding-right: 40px;
	padding-left: 40px;
}

.faq_category_ttl {
  position: relative;
  padding-left: 50px; 
  font-size: 24px;
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
	letter-spacing: 0.14em;
	color: #1a1a1a;
}

.faq_category_ttl::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%); /* 中央揃え */
  width: 35px;  
  height: 2px; 
  background-color: #e87e1f; 
}

.qa {
  max-width: 1016px;
  margin: 40px auto 60px;
}

.qa-item {
  background-color: #e6e6e6;
	margin-bottom: 15px;
}

.qa-question {
	background-color: #e6e6e6;
  width: 100%;
  text-align: left;
  border: none;
  cursor: pointer;
  position: relative;
  transition: background 0.3s ease;
display: flex;
	flex-wrap: wrap;
	align-items:center;
  padding: 10px 30px 10px 30px;
}


/*.qa-question::before {
  content: 'Q';
  position: absolute;
  left: 0;
  font-size: 34px;
	color: #e87e1f; 
}*/

/*.qa-question::after {
  content: '+';
  position: absolute;
  right: 20px;
  font-size: 30px;
  transition: transform 0.3s ease;
	color: #1a1a1a;
}

.qa-question.active::after {
  content: '-';
  transform: rotate(180deg);
	font-size: 40px;
	color: #1a1a1a;
}*/

.qa-question::before,
.qa-question::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 20px;
  width: 20px;
  height: 1px;
  background: #1a1a1a;
  transition: transform 0.3s ease;
  transform-origin: center center;
}

/* 縦棒 */
.qa-question::after {
  transform: rotate(90deg);
}

/* 開いたとき（縦棒を消す＝回転して横棒と重なる） */
.qa-question.active::after {
  transform: rotate(0deg);
}

.qa-label{
	width: 6%;
	font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
	letter-spacing: 0.1em;
	line-height: 1.5;
	color:#e87e1f;
	font-size: 34px;
}

.qa-ttl{
	width: 94%;
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
	letter-spacing: 0.14em;
	color: #1a1a1a;
	font-size: 18px;
	line-height: 1.7;
}

.qa-text{
	width: 94%;
	font-size: 16px;
	padding-top: 7px;
}

.qa-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease, padding 0.3s ease;
  padding: 0 30px 0px 30px;
display: flex;
	flex-wrap: wrap;
	align-items: top;
	line-height: 1.8;
}

.qa-answer.open {
  max-height: 500px; 
  padding: 0 30px 20px 30px;
}


@media (max-width: 1040px) {
.c_inner{
	/*padding-right: 40px;
	padding-left: 40px;*/
}
	
	.faq_category_ttl {
  padding-left: 50px; 
  font-size: 20px;
}
	
	.qa-question {
  padding: 10px 30px 10px 10px;
}
	
	.qa-label{
	width: 40px;
	line-height: 1.5;
	font-size: 25px;
}

	.qa-ttl{
	width: calc(100% - 40px);
	font-size: 16px;
}
	
	.qa-text{
	width: calc(100% - 40px);
	font-size: 14px;
}
	
.qa-answer {
  padding: 0px 30px 0px 10px;
}

.qa-answer.open {
  padding: 0px 30px 10px 10px;
}
	
.qa-question::before,
.qa-question::after {
  content: '';
  position: absolute;
  top: 50%;
  right: 10px;
  width: 15px;
  height: 1px;
  background: #1a1a1a;
  transition: transform 0.3s ease;
  transform-origin: center center;
}

}

@media (max-width: 540px) {
.c_inner{
	padding-right: 20px;
	padding-left: 20px;
}
		
	.qa-label{
	width: 40px;
	line-height: 1.5;
	font-size: 25px;
}

	.qa-ttl{
	width: calc(100% - 40px);
	font-size: 15px;
}
	
	.qa-text{
	width: calc(100% - 40px);
	font-size: 14px;
}
	
	
}

/* ---------------------------------------------------------
ご契約の流れページ
----------------------------------------------------------*/
.c_mv_flow{
	background-image: url("../img/flow/mv_01.jpg"); 
}

.flow {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.steps {
  position: relative;
  max-width: 1016px;
  margin: 0 auto;
}

.steps::before {
  content: "";
  position: absolute;
  top: 100px;
  bottom: 0;
  left: 50%;   /* 中央に配置 */
  transform: translateX(-50%);
  width: 2px;
  background-color: #e87e1f;
  z-index: 0;
}

.step-box {
  position: relative;
  background: #e6e6e6;
  margin-bottom: 40px;
	margin-left: 200px;
  padding: 25px;
  display: flex;
  align-items: center;
  border-radius: 4px;
}

.step-box:last-child {
  margin-bottom: 0;
}

.step-image {
  /*flex: 0 0 150px;
  margin-right: 20px;*/
	/*flex: 1;*/
	width: 30%;
	max-width: 244px;
  text-align: center;
	margin-left: -200px;
}

.step-image img {
  width: 100%;
  height: auto;
}

.step-content {
  /*flex: 1;
  display: flex;
  flex-direction: column;
  gap: 8px;*/
	/*flex: 2;*/
	width: calc(70% + 200px);
  padding-left: 50px;
}

.step-number {
	font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
	letter-spacing: 0.1em;
	line-height: 1.5;
	color:#e87e1f;
	font-size: 22px;
}

.step-title {
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
	letter-spacing: 0.14em;
	color: #1a1a1a;
  font-size: 22px;
  margin: 0 0 10px 0;
}

.step-text {
  margin: 0;
  line-height: 1.6;
}




@media (max-width: 1040px) {
  .step-box {
    margin-left: 100px;
  }

	.step-image {
  margin-left: -100px;
  }

  .step-content {
   width: calc(70% + 100px);
  }
}

@media (max-width: 540px) {
  .step-box {
    flex-direction: column;
    text-align: center;
	  margin-left: 0;
	  margin-top: 80px;
  }

	.step-image {
  margin-right: 0px;
		margin-left: 0;
		margin-top: -80px;
		width: 100%;
		max-width: 180px;
		
}

  .step-image img {
    width: 100%;
    max-width: 240px;
    margin: 0 auto 15px;
  }

  .step-content {
    text-align: left;
	width: 100%;
  padding-left: 0px;
  }
	
.step-number {
	font-size: 18px;
}

.step-title {
  font-size: 18px;
  margin: 0 0 10px 0;
}
	
	.step-text {
  font-size: 14px;
}

	
}


/* ---------------------------------------------------------
会社案内ページ
----------------------------------------------------------*/

.c_mv_company{
	background-image: url("../img/company/mv_01.jpg"); 
}

.c_ttl_h3{
	font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 200;
  font-style: normal;
	letter-spacing: 0.1em;
	line-height: 1.2;
	color:#e87e1f;
	font-size: 50px;
	position: relative;
	padding-left: 50px;
	margin-bottom: 40px;
}

.c_ttl_h3::before {
  content: '・';
  position: absolute;
  left: 0;
	top: 0;
  font-size: 60px;
	color: #e87e1f;
}

.c_ttl_h3 span{
	display: block;
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
	letter-spacing: 0.14em;
	color: #1a1a1a;
	font-size: 16px;
	padding-top:10px;
}

.c_underLine{
	border-bottom: 1px solid #e87e1f;
}

.company_box{
	padding-top: 40px;
}

.c_ttl_h4 {
  position: relative;
  padding-left: 50px; 
  font-size: 22px;
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
	letter-spacing: 0.14em;
	color: #1a1a1a;
	margin-left: 50px;
}

.c_ttl_h4::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%); /* 中央揃え */
  width: 35px;  
  height: 2px; 
  background-color: #e87e1f; 
}

.company-profile {
  max-width: 930px;
  margin: 20px auto;
  padding: 0 20px;
}

.profile-table {
  display: flex;
  flex-direction: column;
}

.profile-row {
  display: flex;
  flex-wrap: wrap;
  padding: 15px 20px;
  border-bottom: 1px solid #ccc; /* 項目の間の仕切り線 */
}

.profile-label {
  flex: 0 0 200px; /* 左側のカテゴリ幅 */
  font-weight: bold;
	line-height: 1.7;
}

.profile-content {
  flex: 1;
	line-height: 1.7;
}

.sec_access{
	padding-top:20px;
}

@media (max-width: 1040px) {
	
	.c_ttl_h4 {
  padding-left: 50px; 
  font-size: 20px;
}
	
}

@media (max-width: 540px) {
	
.c_ttl_h3{
	font-size: 32px;
	padding-left: 14px;
	margin-bottom: 40px;
}

.c_ttl_h3::before {
  content: '・';
  position: absolute;
  left: -20px;
	top: -8px;
  font-size: 44px;
	color: #e87e1f;
}
	
.c_ttl_h4 {
  padding-left: 50px; 
  font-size: 18px;
	margin-left: 0px;
}
	
.company-profile{
	padding:0;
}
	
  .profile-row {
    flex-direction: column;
	  padding:13px 0;
  }
	
  .profile-label {
    flex: 1 1 100%;
    margin-bottom: 5px;
	  font-size: 15px;
  }
	
  .profile-content {
    flex: 1 1 100%;
	  font-size: 14px;
  }
	
	.sec_access{
	padding-top:0px;
}

}

/*アクセス*/

.access {
  display: flex;
  /*align-items: center;*/
  justify-content: space-between;
  gap: 3rem;
  margin: 2rem 0;
}

.access-text {
  width: 55%;
}

.access-text-inner{
	/*margin-top: 20px;*/
	padding-left: 100px;
}

.access-text p{
  margin-bottom: 20px;
	line-height: 1.7;
}

.access-image {
  width: 45%;
	margin-bottom: 20px;
	margin-top: -60px;
}

.access-image img {
  width: 100%;
  height: auto;
  display: block;
}

.map-wrapper{
	padding:0px 0px;
}

@media (max-width: 1040px) {
 .access-text-inner{
	padding-left: 40px;
}
	
	.access-image {
  padding-right: 40px;
}
	
.map-wrapper{
	padding:0px 40px;
	
}
	
	.map-wrapper iframe{
		height: 240px;
	}

}


@media (max-width: 540px) {
  .access {
    flex-direction: column;
	  gap:2rem;
  }

  .access-text,
  .access-image {
    width: 100%;
  }
	
 .access-text-inner{
	padding-left: 0px;
}
	
	.access-image {
  padding-right: 0px;
		margin-top: 0px;
		
}
	
.map-wrapper{
	padding:0px;
}
	
}



/* ---------------------------------------------------------
お問い合わせページ
----------------------------------------------------------*/


.form_group > div select {
  width: 100%;
  padding: 14px;
  font-size: 16px;
}

.form_group_btn{
	margin-bottom: 50px;
}

.form_group_send{
	margin-top: 30px;
	margin-bottom: 70px;
}

.form_btn-back{
	padding:0;
}

h2.form_ttl{
	font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
	letter-spacing: 0.07em;
	font-size: 60px;
	margin-bottom: 30px;
	color:#e87e1f;
	line-height: 1;
	border-left:none;
	margin-top: 50px;
}


.form_ttl_sub{
	color: #1a1a1a;
	font-size: 18px;
	margin-top:10px;
}

@media (max-width: 540px) {
    h2.form_ttl {
        font-size: 44px;
		padding:0;
    }
	.form_ttl_sub{
		font-size: 16px;
	}
}

/*プライバシーポリシー*/

.privacy-box {
  max-width: 800px;
  margin: 40px auto;
  padding: 20px;
  background-color: #fff;
	border:1px solid #1a1a1a;
}

.privacy-box h2 {
  margin-top: 0;
  font-size: 16px;
  margin-bottom: 10px;
	border-left: none;
	padding:0;
}

.privacy-box h3 {
  margin-top: 20px;
  font-size: 16px;
  color: #1a1a1a;
	font-weight: bold;
}

.privacy-content {
  max-height: 400px; /* ボックス内スクロール */
  overflow-y: auto;
  padding-right: 10px; /* スクロールバーと重ならないように */
}

.privacy-content p,
.privacy-content ul,
.privacy-content li{
  font-size: 14px;
  line-height: 1.7;
}

.privacy-content ul {
  padding-left: 20px;
  list-style-type: disc;
}

/* スクロールバーのカスタマイズ（Webkit系） */
.privacy-content::-webkit-scrollbar {
  width: 6px;
}

.privacy-content::-webkit-scrollbar-thumb {
  background-color: #828282;
  border-radius: 4px;
}

.privacy-content::-webkit-scrollbar-track {
  background-color: rgba(0,0,0,0.05);
}

@media (max-width: 540px) {
  .privacy-box {
    padding: 15px;
  }

  .privacy-box h2 {
    font-size: 16px;
  }

  .privacy-box h3 {
    font-size: 15px;
  }

  .privacy-content {
    max-height: 300px;
  }
	
}

.thanks{
	max-width: 1060px;
	margin-top: 20px;
}

.toHomeBtn{
	text-align: center;
	margin-top: 50px;
	margin-bottom: 60px;
}


/* ---------------------------------------------------------
私たちについてページ
----------------------------------------------------------*/

.c_mv_about{
	background-image: url("../img/about/mv_01.jpg"); 
}

.aboutus-box{
  padding: 80px 0 110px;
	border-top: 1px solid #e87e1f;
}

.aboutus-inner,
.aboutus-inner3  {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 90px;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 40px;
	margin-top: -110px;
}

.aboutus-inner.reverse {
  flex-direction: row-reverse; /* ← 並び順を反転 */
}

.aboutus-text {
  flex: 1.2;
	margin-top: 100px;
}

.aboutus-image {
  flex: 0.8;
}

.aboutus-image img {
  width: 100%;
  height: auto;
  border-radius: 4px;
}

.aboutus-heading {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 30px;
}

.aboutus-label {
  text-align: center;
	background-color: #e6e6e6;
  border-radius: 50%;
  width: 82px;
  height: 82px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  font-weight: bold;
  line-height: 0.3;
}

.aboutus-label .reason {
	font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
	letter-spacing: 0.1em;
	line-height: 1;
	color:#e87e1f;
  font-size: 12px;
}

.aboutus-label .number {
	font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
	letter-spacing: 0.1em;
	line-height: 1;
	color:#e87e1f;
  font-size: 32px;
}

.aboutus-heading h4,
.aboutus-heading2 h4{
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-size: 24px;
	line-height: 1.7;
}

.aboutus-desc {
  font-size: 16px;
  line-height: 1.8;
  color: #333;
}

.aboutus-box2{
  padding: 60px 0 60px;
	border-top: 1px solid #e87e1f;
}

.aboutus-inner2 {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 100px;
  max-width: 1020px;
  margin: 0 auto;
  padding: 0 40px;
}

.aboutus-text2 {
  flex: 1.1;
	margin-top: 0px;
}

.aboutus-heading2 {
  margin-bottom: 30px;
}

.aboutus-sub{
	font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
	letter-spacing: 0.1em;
	line-height: 1;
	color:#e87e1f;
  font-size: 20px;
	margin-bottom: 15px;
}

.aboutus-image2 {
	margin-top: 30px;
	flex: 0.9;
}

.aboutus-value {
  display: flex;
  flex-wrap: wrap; /* 折り返し有効 */
  gap: 40px; /* ボックス間の余白 */
}

.aboutus-value > div {
  flex: 1 1 calc(50% - 40px); /* 2列表示 */
  background: #f2f2f2;
  padding: 24px;
  border-radius: 4px;
  box-sizing: border-box;
}

.aboutus-value h5 {
  font-size: 1.2rem;
  margin-bottom: 12px;
  color: #333;
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
	line-height: 1.7;
}

.aboutus-ceo .name{
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-size: 24px;
	line-height: 1.7;
}

.aboutus-ceo .position{
  font-size: 16px;
	line-height: 1.7;
}

.aboutus-ceo-sub{
	font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
	letter-spacing: 0.1em;
	line-height: 1;
	color:#e87e1f;
  font-size: 18px;
	margin-bottom: 15px;
}

.aboutus-box3{
  padding: 80px 0 40px;
	border-top: 1px solid #e87e1f;
}

.aboutus-text3 {
  flex: 1.1;
	margin-top: 70px;
}

.aboutus-ceo-image{
	font-size: 14px;
	line-height: 1.6;
	margin-top: 20px;
}

.section_about1{
	padding-bottom: 0;
}

.section_about2{
	background-color: #e6e6e6;
	padding-bottom: 30px;
}

@media (max-width: 1040px) {
 
.aboutus-box {
  padding: 150px 0 100px;
}
	
.aboutus-inner {
  gap: 40px;
	margin-top: -180px;
}
	
	.aboutus-inner2 {
  gap: 40px;
}
	
	.aboutus-inner3 {
  gap: 40px;
		
}
	
	.aboutus-box2{
  padding: 60px 0 60px;
}

.aboutus-text {
	margin-top: 70px;
}

}


@media (max-width: 540px) {
	
	.aboutus-box {
  padding: 130px 0 60px;
}
	
	.aboutus-box2 {
  padding: 60px 0 60px;
}
	
  .aboutus-inner,
	.aboutus-inner2,
		.aboutus-inner3{
    flex-direction: column;
	  padding: 0 20px;
  }	
	
	.aboutus-inner2 {
  gap: 30px;
}
	 .aboutus-inner.reverse {
    flex-direction: column;
	  padding: 0 20px;
  }	
	
  .aboutus-label {
    width: 65px;
    height: 65px;
  }

  .aboutus-heading h4 {
    font-size: 20px;
  }
	
.aboutus-label .reason {
  font-size: 10px;
}

	.aboutus-label .number {
		font-size: 28px;
}
	
	.aboutus-image2 {
	max-width: 300px;
		margin:0 auto;
}
	.aboutus-value > div {
    flex: 1 1 100%;
  }

}

/* ---------------------------------------------------------
業務案内ページ
----------------------------------------------------------*/

.c_mv_service{
	background-image: url("../img/service/mv_01.jpg"); 
}

.serviceAll-box{
  padding: 80px 0 0px;
	border-top: 1px solid #e87e1f;
}

.serviceAll-inner{
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 100px;
  max-width: 1080px;
  margin: 0 auto;
  padding: 0;
padding: 0 40px;
}


.serviceAll-text {
  flex: 1;
}

.serviceAll-image {
  flex: 1;
}

.serviceAll-image img {
  width: 100%;
  height: auto;
  border-radius: 4px;
}

.serviceAll-heading {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 30px;
}


.serviceAll-heading h4{
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-size: 24px;
	line-height: 1.7;
}

.serviceAll-desc {
  font-size: 16px;
  line-height: 1.8;
  color: #333;
}

.plan-inner {
  padding: 0px 0;
}

.plan-wrapper {
  display: flex;
  flex-wrap: wrap;
  gap: 100px;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 40px;
}

.plan-box {
  position: relative;
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 480px;
  color: #fff;
  text-align: center;
  text-decoration: none;
  overflow: hidden;
  border-radius: 6px;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

/* 背景画像とオーバーレイ */
.plan-box::before {
  content: "";
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  z-index: 1;
  transition: transform 0.4s ease;
}

.plan01::before {
  background-image: url("../img/service/service_pic_02.jpg"); 
}

.plan02::before {
  background-image: url("../img/service/service_pic_03.jpg"); 
}

.plan-box::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45); /* 暗くする */
  z-index: 2;
}

/* 中央テキスト */
.plan-content {
  position: relative;
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 20px;
  max-width: 80%;
}

.plan-label {
  background: #e87e1f;
  color: #fff;
  padding: 4px 10px;
  font-size: 0.9rem;
	font-family: "Outfit", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
	letter-spacing: 0.1em;
	line-height: 1.5;
}

.plan-title {
  font-size: 1.6rem;
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
	letter-spacing: 0.14em;
	line-height: 1.6;
}

.plan-text {
  font-size: 1rem;
  line-height: 1.8;
	padding-bottom: 20px;
}

/* 右下の矢印 */
.plan-arrow {
  position: absolute;
  right: 30px;
  bottom: 30px;
  z-index: 3;
}

.plan-arrow img {
  width: 32px;
  height: auto;
  transition: transform 0.3s ease;
}

/* ホバー時の動き */


.plan-box:hover::before {
  transform: scale(1.05);
}




@media (max-width: 1040px) {
 
.serviceAll-box {
  padding: 80px 0 0px;
}
	
.serviceAll-inner {
  gap: 40px;
}
	
	.plan-wrapper {
  gap: 40px;
}
	
.plan-title {
  font-size: 1.2rem;
}


}

/* スマホ表示（1カラム） */
@media screen and (max-width: 768px) {
  .plan-box {
    flex: 1 1 100%;
    height: 350px;
  }

  .plan-title {
    font-size: 1.3rem;
  }

  .plan-text {
    font-size: 0.95rem;
  }
	
	.plan-wrapper {
  padding: 0 20px;
}
}


@media (max-width: 540px) {
	
	.serviceAll-box {
  padding: 40px 0 0px;
}
	
  .serviceAll-inner{
    flex-direction: column;
	  padding: 0 20px;
  }	
	
  .serviceAll-heading h4 {
    font-size: 20px;
  }
	

}

/* ---------------------------------------------------------
プランページ
----------------------------------------------------------*/

.c_plan_ttl{
	color: #fff;
	font-size: 16px;
	line-height: 1.5;
}

.c_plan_ttl_sub{
	color: #fff;
	font-size: 32px;
	line-height: 1.5;
}


.c_mv_plan1{
	background-image: url("../img/plan1/mv_01.jpg"); 
}

.c_mv_plan2{
	background-image: url("../img/plan1/mv_02.jpg"); 
}

.plan_ttl_h3{
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
	letter-spacing: 0.14em;
	color: #1a1a1a;
	font-size: 26px;
	position: relative;
	padding-left: 30px;
	margin-bottom: 20px;
	line-height: 1.7;
}


.plan_ttl_h3::before {
  content: '・';
  position: absolute;
  left: 0;
	top: 0;
  font-size: 30px;
	color: #e87e1f;
	line-height: 1.5;
}

.plan_ttl_h3 span{
	display: block;
	font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-weight: 500;
  font-style: normal;
	letter-spacing: 0.14em;
	color: #1a1a1a;
	font-size: 16px;
	padding-top:10px;
}

.plan_ttl_text{
	margin-bottom: 80px;
}


.plan-detail-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.plan-detail-list li {
  display: flex;
  align-items: flex-start;
  gap: 15px;
  margin-bottom: 20px;
}

.check-icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
}

.check-icon img {
  width: 100%;
  height: auto;
}

.plan-detail-list li p {
  margin: 0;
  line-height: 1.6;
  font-size: 1rem;
}

.outline-btn-wrapper {
  display: flex;             /* 横並びのフレックスに */
  justify-content: center;   /* 親要素で中央寄せ */
  margin: 0 20px;
}

.outline-btn {
  display: flex;
  align-items: center;       /* 矢印を上下中央に */
  justify-content: space-between; /* テキストと矢印を左右に配置 */
  padding: 16px 36px;
  border: 1px solid #333;
  background-color: transparent;
  color: #333;
  text-decoration: none;
  font-size: 16px;
  border-radius: 10px;
  line-height: 1.4;
  max-width: 480px;
  width: 100%;
  box-sizing: border-box;
  transition: background-color 0.3s ease, color 0.3s ease;
}

.outline-btn:hover {
  background-color: #333;
  color: #fff;
}

.outline-btn .btn-text {
  text-align: left; /* 左寄せで複数行のテキストを整列 */
}

.outline-btn .btn-arrow img {
  width: 30px; 
  height: auto;
  transition: transform 0.3s ease;
	vertical-align:middle;
}

.outline-btn:hover .btn-arrow img {
  transform: translateX(6px);
}

/* スマホ対応 */
@media screen and (max-width: 540px) {
	
	.c_plan_ttl{
	color: #fff;
	font-size: 12px;
}

.c_plan_ttl_sub{
	color: #fff;
	font-size: 24px;
}

	
	.plan_ttl_h3{
		font-size: 20px;
	}
	
  .plan-detail-list li {
    flex-direction: row;
    gap: 10px;
  }

  .plan-detail-title {
    font-size: 1.5rem;
  }

  .plan-detail-list li p {
    font-size: 0.95rem;
  }
	
	
  .outline-btn {
    font-size: 14px;
    padding: 18px 24px;
    max-width: 100%;
  }

  .outline-btn .btn-arrow img {
    width: 26px;
  }
}
