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

/********************************************スマホレイアウト*******************************************/
@media screen and (max-width:1367px) { 

html {
	/* 常時スクロールバー領域を確保 */
	overflow-y: scroll;
	scrollbar-gutter: stable;
	}

body {
	margin-top: 100px; /* メニュー高さ分 */
	overflow-x: hidden;
	}

.bxslider__container{
	background-color: #FFFFFF;
	text-align:center;
	position: relative;
	overflow: hidden;
	margin-bottom:40px;
	}

.common-section__container {
        width: 100%;
        padding: 0 2%;           /* 外側コンテナの左右2%余白 */
        box-sizing: border-box;
        margin: 0 auto;
        }

.common-section__content {
        width: 100%;
        background-color: #FFFFFF;
        text-align: left;
        overflow-x: hidden;
        overflow-y: auto;
        padding-top: 30px;        /* 上余白30px */
        padding-bottom: 30px;     /* 下余白30px */
        padding-left: 0;          /* 左右余白は.containerに任せる */
        padding-right: 0;
        }

.section-title__wrapper{
        display: flex;
        justify-content: center; /* 水平方向の中央寄せ */
	overflow: auto;
	}

.section-title__content{
	width:100%;
	min-height:90px;
	margin: 0px 2%; /* 左右の余白を2%に設定 */
	}

.section-subtitle__wrapper{
	width:100%;
	height: auto;
	overflow: auto;
        margin-top:-20px;
	}

.section-subtitle__content{
	width:300px;
	color: #3261B9;
	border-bottom-style: solid;
	border-width: 2px;
	border-color: #3261B9;
	}

.trust-section__wrapper {
	display: block; /* 縦並びなので blockに */
	background-color: #83B7E6;
	overflow-x: hidden;
	overflow-y: auto;
	margin: 50px 0;
	padding: 30px 2%; /* 左右2%余白を確保 */
	box-sizing: border-box;
	}

.trust-section__content {
	width: 100%;
	max-width: 1436px;
	background-color: #FFFFFF;
	text-align: justify;
	hyphens: auto;
	overflow-x: hidden;
	overflow-y: auto;
	margin: 10px auto 0 auto; /* 上に30px、左右は中央寄せ */
	padding: 30px 2%;
	box-sizing: border-box;
	border-radius: 10px;
	}

.features-section__wrapper {
	display: block; /* 中身1個だけなのでblockでOK */
	background-color: #F0F0F0;
	overflow-x: hidden;
	overflow-y: auto;
	margin: 50px 0 30px 0; /* 上50px、下30px、左右はなし */
	padding: 0 2%; /* 左右2%の余白を確保 */
	box-sizing: border-box;
	}

.features-section__content {
	width: 100%;
	background-color: #F0F0F0;
	text-align: left;
	margin: 0 auto; /* 中央寄せ */
	padding: 50px 0 30px 0; /* 上50px・下30px、左右paddingはwrapperで確保してるので不要 */
	overflow-x: hidden;
	overflow-y: auto;
	box-sizing: border-box;
	}

.flow-section__wrapper {
	display: block; /* 1カラムならblockで十分 */
	width: 100%;
	background-color: #F0F0F0;
	overflow-x: hidden;
	overflow-y: auto;
	margin: 50px 0; /* 上下50px、左右はなし */
	padding: 0 2%; /* 左右2%の余白を確保 */
	box-sizing: border-box;
	}

.flow-section__content {
	width: 100%;
	background-color: #F0F0F0;
	text-align: left;
	margin: 0 auto; /* 中央寄せ */
	box-sizing: border-box;
    	}

.testimonial-section__wrapper {	width: 96%;
	display: flex;
	justify-content: center;
	background-color: #FFFFFF;
	overflow-x: hidden;
	overflow-y: auto;
	margin-top: 50px;
	margin-bottom: 50px;
}

.testimonial-section__box {
	width: 100%;
	display: flex;
	flex-direction: column; /* 縦並び */
	align-items: center; /* 中央寄せ */
	background-color: #3261B9;
	text-align: left;
	margin: 0 auto;
	border-radius: 9px;
	padding: 10px 2%;
	box-sizing: border-box;
}

.testimonial__icon {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100px;
	height: 100px;
	font-size: 3.75rem;
	background-color: #FFFFFF;
	border-radius: 10px;
	margin: 20px 0;
	padding: 20px;
	box-sizing: border-box;
}

.testimonial__text-box--right,
.testimonial__text-box--left {
	width: 96%;
	position: relative;
	margin: 20px auto; /* 中央寄せ */
	padding: 20px;
	font-size: 1.0rem;
	background-color: #FFFFFF;
	border-radius: 10px;
	box-sizing: border-box;
}

/* 右吹き出し（上に矢印） */
.testimonial__text-box--right::before {
	content: "";
	position: absolute;
	top: -15px; /* 上に矢印 */
	left: 50%;
	transform: translateX(-50%); /* 中央寄せ */
	border-width: 0 15px 15px 15px;
	border-style: solid;
	border-color: transparent transparent #FFFFFF transparent;
}

/* 左吹き出し（下に矢印） */
.testimonial__text-box--left::before {
	content: "";
	position: absolute;
	bottom: -15px; /* 下に矢印 */
	left: 50%;
	transform: translateX(-50%); /* 中央寄せ */
	border-width: 15px 15px 0 15px;
	border-style: solid;
	border-color: #FFFFFF transparent transparent transparent;
}

/*pickup******************************************/

/* 1) 外側：背景＋中央寄せ */
.pickup-section__wrapper {
  background-color: #F0F0F0;
  margin: 50px 0;
  padding: 20px 2%; /* 左右2%ずつのpaddingに変更 */
  display: block;   /* 中身1カラムなのでblockで十分 */
  box-sizing: border-box;
}

/* 2) 内側：max-widthだけ指定、幅は自動、自動マージンで中央寄せ */
.pickup-section__content {
  width: 100%;
  margin: 0 auto;
  padding: 0; /* wrapperで余白管理するのでpaddingはリセット */
  box-sizing: border-box; /* border-boxにしておいた方が自然！ */
  background: none;
}

/* 3) カード部分はこれまで通り */
.pickup-section__card {
  position: relative;
  background-color: #FFFFFF;
  border-radius: 10px;
  margin-bottom: 30px;
  padding: 10px;
  overflow: hidden;
}

/* 三角形ラベルもそのまま */
.triangle {
  position: absolute;
  top: 0;
  left: 0;
  border-bottom: 70px solid transparent;
  border-left:   70px solid #3261B9;
}
.label {
  position: absolute;
  top: 8px;
  left: 5px;
  transform: rotate(-45deg);
  /* …色・フォントは省略… */
}

.triangle {
	position: absolute;
	border-bottom: 70px solid transparent;
	border-left: 70px solid #3261B9;
	}

.label {
	position: absolute;
	top: 4px;
	left: 12px;
	font-size: 1.25rem;
	font-weight:bold;
	color: #fff;
	transform: rotate(-45deg);
	}
/*contact_area**********************************************/

.cta-banner__wrapper {
	width: 100%;
	display: block; /* 縦並びに変更 */
	background-color: #F0F0F0;
	margin-top: 50px;
	margin-bottom: 30px;
	padding: 50px 0;
	}

.cta-banner__image {
	width: 100%;
	text-align: center;
	padding: 0 2%;
	margin-bottom: 40px;
	}

.contact_banner {
	max-width: 100%;
	height: auto;
	border-radius: 12px; /* 任意で角丸 */
	}

.cta-banner__form {
	width: 100%;
	display: flex;
	justify-content: center;
	padding: 0 2%;
	}

/*company_overview******************************************/

.company-section__wrapper {
  width: 96%; /* 左右2%ずつ余白にする */
  max-width: 1436px;
  margin: 50px auto 0;
  padding: 0;
  display: block; /* flex解除（中身縦並びだからblockで十分） */
  box-sizing: border-box;
}

.company-overview__dl {
  width: 100%;
  border-left: 1px solid #CCCCCC;
  border-right: 1px solid #CCCCCC;
  border-bottom: 1px solid #CCCCCC;
  margin: 15px 0 20px 0; /* 左右marginはリセット */
  box-sizing: border-box;
}

dl.company-overview__dl > div {
  display: block; /* flex解除してblockにして縦並び */
}

dl.company-overview__dl dt,
dl.company-overview__dl dd {
  border-top: 1px solid #CCCCCC;
  line-height: 24px;
  padding: 12px;
  margin: 0;
  font-weight: normal;
  width: 100%; /* 縦並びだからどちらも幅100%に */
  box-sizing: border-box;
}

dl.company-overview__dl dt {
  background: #EDEDED;
  font-size: 0.875rem;
}

dl.company-overview__dl dd {
  background-color: #FAFAFA;
  font-size: 0.875rem;
}

.company-overview__dl dd ul {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.company-btn-wrap {
  display: flex;
  justify-content: center;
  margin-top: 30px;
}

.company-btn {
  display: inline-block;
  background-color: #007ACC;
  color: #fff;
  font-size: 1.0rem;
  padding: 12px 24px;
  margin-bottom: 30px;
  border-radius: 30px;
  text-decoration: none;
  font-weight: bold;
  transition: 
    background-color 0.3s,
    color 0.3s,
    transform 0.2s,
    text-decoration 0.3s;
  box-shadow: 0 4px 6px rgba(0,0,0,0.1);
}

.company-btn:hover {
  background-color: #005B99;
  color: #FFFFFF;
  text-decoration: none;
  transform: translateY(-2px);
}

/* 住所部分 */
.footer_address {
  padding: 0.75em;
  border-radius: 4px;
  font-style: normal;
  font-size: 0.875rem;
  line-height: 1.6;
  color: #FFF;
  max-width: 1200px;
  margin: 1em auto 0 auto;
}

/*copyright**************************************************/

.copyright-section__wrapper
	{
        clear:both;
	background-color: #3261B9;
	overflow: auto;
	margin-top: 10px;
	padding-bottom: 110px;
	}

.copyright-section__content
	{
	width:100%;
	max-width:1200px;
	background-color: #3261B9;
	padding: 20px;
	}

/*sp-bottom-nav**********************************************/

.sp-bottom-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 70px;
  padding: 0 8px;
  background-color: rgba(51, 51, 51, 0.6);
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 1000;
  gap: 8px;
  backdrop-filter: blur(6px); /* ←背景をほんのりぼかすと洗練感UP */
}

.sp-bottom-btn {
  flex: 1;
  margin: 4px 2px;
  padding: 6px 0;
  display: flex;
  justify-content: center;
  align-items: center;
  height: auto;
  border-radius: 10px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
  transition: all 0.3s ease;
}

.sp-bottom-btn img {
  display: block;
  height: 44px;
  width: auto;
  max-width: 100%;
  pointer-events: none;
}

.sp-bottom-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

/* 個別ボタンカラー（＋ホバーエフェクト） */
.sp-btn-tel {
  background-color: #FF8000;
  color: #fff;
}
.sp-btn-tel:hover {
  background-color: #FF9900;
  color: #fff;
}

.sp-btn-mail {
  background-color: #098EF3;
  color: #fff;
}
.sp-btn-mail:hover {
  background-color: #1BA5F8;
  color: #fff;
}

.sp-btn-line {
  background-color: #00b900;
  color: #fff;
}
.sp-btn-line:hover {
  background-color: #00d200;
  color: #fff;
}

/***************************************************テキスト***************************************************/

h1{

	max-width: 252px; /* ロゴ画像に合わせて制限 */
	width: 100%; /* 親要素に応じて幅を調整 */
	height: auto;
	font-weight: normal;
	text-align: left;
	margin: 0;
	}


h1 img {
	display: block;
	max-width: 100%; /* 親要素に収める */
	height: auto; /* アスペクト比を維持 */

	}

h2{
	font-size: 2rem;
	letter-spacing: 0em;
	font-weight:bold;
	text-align:left;
	}

h3{
	font-size: 2rem;
	letter-spacing: 0em;
	font-weight:bold;
	text-align:left;
	}

.highlight-header__wrapper{
	height: auto;
	overflow: auto;
	}

.highlight-header__inner--right{
	float: right;
	width:94%;
	margin-left:6%;
	height: auto;
	background-image: -webkit-gradient(linear, left top, right top, from(#6E9DF5), to(#3261B9));
	background-image: linear-gradient(90deg, #6E9DF5 0%, #3261B9 100%);
	border-radius: 10px 0px 0px 10px;
	}

.highlight-header__inner--left{
	float: left;
	width:94%;
	margin-right:6%;
	height: auto;
	background-image: -webkit-gradient(linear, left top, right top, from(#3261B9), to(#6E9DF5));
	background-image: linear-gradient(90deg, #3261B9 0%, #6E9DF5 100%);
	border-radius: 0px 10px 10px 0px;
	}

.highlight-header__text{
	width:100%;
	height: auto;
	font-size: 1.5rem;
	letter-spacing: 0em;
	font-weight:bold;
	text-align:left;
        padding:30px;
        position: relative;
	}

.section-subtitle__text{
	font-size: 1.2rem;
	letter-spacing: 0em;
	font-weight:bold;
	text-align:center;
        margin-bottom:10px;
	}

.text_contact {
	font-size: 26px;
	font-weight: bold;
	color: #FFFFFF;
	line-height: 1.5;
	text-align: center; /* テキスト中央揃え */
	}

.text_navi{
	font-size: 0.875rem;
	letter-spacing: 0.03em;
	font-weight:normal;
	text-align:center;
	color: #222222;
	}

.h_headline{
	font-size: 1.5rem;
	line-height:1.5;
	letter-spacing: 0em;
	font-weight:bold;
	text-align: justify;
	hyphens: auto;
	color: #222222;
	border-left: solid 10px #3261B9;
        padding:10px;
        margin:20px;
	}

.text-paragraph--about{
	font-size: 1.125rem;
	line-height:1.5;
	letter-spacing: 0.03em;
	font-weight:normal;
	text-align: justify;
	hyphens: auto;
        margin:20px;
	}

.text-paragraph--photo-bg{
	font-size: 1.125rem;
	line-height:1.5;
	letter-spacing: 0.03em;
	font-weight:normal;
	text-align: justify;
	hyphens: auto;
        margin:20px;
	}

.text-paragraph--standard_headline{
	font-size: 1.5rem;
	line-height:1.5;
	letter-spacing: 0em;
	font-weight:bold;
	text-align: justify;
	hyphens: auto;
	color: #222222;
	border-left: solid 10px #3261B9;
        padding:10px;
	}

.text-paragraph--standard {
	font-size: 1.125rem;
	line-height:1.5;
	letter-spacing: 0.03em;
        font-weight: normal;
        text-align: justify;
        hyphens: auto;
        color: #222222;
        margin: 20px 2%; /* 上下20px、左右2%に変更 */
        box-sizing: border-box;
        }

.text-paragraph--trust{
	font-size: 1.125rem;
	line-height:1.5;
	letter-spacing: 0.03em;
	font-weight:normal;
	text-align: justify;
	hyphens: auto;
	color: #222222;
        margin:20px;
	}

.text-paragraph--testimonial{
	font-size: 1.125rem;
	line-height:1.5;
	letter-spacing: 0.03em;
	font-weight:normal;
	text-align: justify;
	hyphens: auto;
	color: #222222;
	}

.text__features_number_headline{
	counter-increment: counter1;
	padding-top:10px;
	padding-left:78px;
	padding-right:6px;
	padding-bottom:10px;
	font-weight: bold;
	font-size: 1.2rem;
	line-height:1.5;
	letter-spacing: 0em;
	border: 2px solid #3261B9;
	color: #222222;
	}

.text__features_number_headline:before{
	content: counter(counter1);
	position: absolute;
	display: flex;
	align-items: center;
	justify-content:center;
	left: 0px;
	width: 58px;
	height: 100%;
	color: #fff;
	line-height:48px;
	background: #3261B9;
	top: 50%;
	-moz-transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-o-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
	}

.text__features_number_headline:after{
	content:"";
	display: block;
	position: absolute;
	left: 58px;
	height: 0;
	width: 0;
	border-top: 5px solid transparent;
	border-bottom: 5px solid transparent;
	border-left: 7px solid #3261B9;
	top: 50%;
	-moz-transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-o-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
	}

.text-paragraph--pickup-intro{
	font-size: 1.125rem;
	line-height:1.5;
	letter-spacing: 0.03em;
	font-weight:normal;
	text-align: justify;
	hyphens: auto;
	color: #222222;
        margin-top:20px;
        margin-bottom:50px;
	}

.text-headline--pickup{
	font-size: 2.0rem;
	letter-spacing: 0em;
	font-weight:bold;
	text-align: justify;
	hyphens: auto;
	color: #3261B9;
        margin-left:70px;
        padding-top:14px;
	}

.text-paragraph--pickup-card{
	font-size: 1.125rem;
	line-height:1.5;
	letter-spacing: 0.03em;
	font-weight:normal;
	text-align: justify;
	hyphens: auto;
	color: #222222;
        padding:30px;
	}

.text-headline--service{
	position: relative;
	font-size: 1.5rem;
	line-height:1.5;
	letter-spacing: 0.03em;
	font-weight:bold;
	text-align:center;
	color: #222222;
        margin:20px;
	padding: 1rem 2rem;
	border: solid 2px #3261B9;
	border-radius: 10px;
	}

.text-headline--service:after {
	position: absolute;
	content: "Service";
	top: -10px;
	left: 15px;
	background: #fff;
	font-size: 0.75rem;
	letter-spacing: 0.03em;
	color: #27acd9;
	padding: 0 10px;
	}

.text-meta--date {
	display: block; /* ← blockに変更 */
	min-width: 110px;
	font-size: 1.125rem;
	line-height: 30px;
	letter-spacing: 0.03em;
	font-weight: normal;
	color: #3261B9;
	margin-bottom: 4px; /* 下にちょっと余白つけると自然 */
	}

.text-meta--text {
	display: block; /* ← blockに変更 */
	font-size: 1rem;
	line-height:1.5;
	letter-spacing: 0.03em;
	}

.text-footer--copyright{
	font-size: 1.0rem;
	letter-spacing: 0.03em;
	color: #FFFFFF;
	text-align:center;
	}

/********************************************ドロップダウンメニュー********************************************/

.dropdown_nav {
    display: none !important;
}

li.menu__contact.btn-shine.a {
    display: none !important;
}

/****************************************************リスト****************************************************/

.step-list {
	list-style: none;
	margin: 50px 20px 50px 20px;
	}

.step-list li {
	position: relative;
	font-size: 1.125rem;
	margin: 40px 0 40px 0;
	padding: 0 0 0 40px;
	text-align: justify;
	}

.step-list li::before{
	position: absolute;
	left: 0;
	font-family: "Font Awesome 5 Free";
	font-size: 1.375rem;
	font-weight: 900;
	content: '\f058';
	color: #3261B9;
	}

/****************************************************マップ****************************************************/

.g_map{
        margin-top:20px;
        margin-left:20px;
        margin-right:20px;
        margin-bottom:20px;
	text-align:left;
	}
}