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

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

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

body {
	margin-top: 110px; /* ヘッダー高さに合わせる */
	padding-top: 0;
	overflow-x: hidden;
	}

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

.navi{
	background-color: #F0F0F0;
	padding: 5px 0;
	}

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

/*author-section******************************************/

/* 全体（外側） */
.c-author {
	display: flex;
	justify-content: center;
	margin: 0 10px;
	}

/* inner調整 */
.c-author-inner {
	padding: 0 16px;
	gap: 24px; /* ←ブロック間の余白 */
	}

/* 各ブロック */
	.c-author-box {
	width: 100%;
	}

/* 役割ラベル */
.c-author-role-label {
	display: table;
	font-size: 14px;
	font-weight: bold;
	line-height: 1.4;
	color: #FFFFFF;
	background-color: #3261B9;
	padding: 8px 16px;
	border-radius: 9px 9px 0 0;
	margin: 20px 0 0 16px;
	}

/* 本体（青） */
.c-author-main,
.c-author-main.is-reverse {
	flex-direction: column;
	align-items: center;
	padding: 20px 16px;
	gap: 16px;
	margin: 0 auto;
	width: 100%;
	box-sizing: border-box;
	}

/* 青背景をしっかり出す */
.c-author-main {
	background-color: #3261B9;
	border-radius: 12px;
	}

.c-author-icon {
	background-color: #FFFFFF;
	width: 150px;
	height: 150px;
	padding: 6px;
	border-radius: 12px;
	box-shadow: 0 0 0 3px #3261B9;
	margin: 0 auto 32px auto;
	display: inline-block;
	overflow: hidden;
	transition: background-color 0.25s ease, transform 0.15s ease; /* ←追加 */
	}

.c-author-icon:hover {
	background-color: #e6f0ff;
	transform: translateY(-2px);
	}

.c-author-icon:active {
	transform: scale(0.97);
	}

.c-author-icon img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 10px;
	display: block;
	transition: transform 0.2s ease; /* ←追加 */
	}

.c-author-icon:hover img {
	transform: scale(0.95);
	}

/* 吹き出し */
.c-author-content {
	width: 100%;
	margin: 0;
	padding: 16px;
	background-color: #FFFFFF;
	border-radius: 10px;
	box-sizing: border-box;
	position: relative;
	z-index: 1;
	}

/* 吹き出し三角（上） */

.c-author-content.is-left::before,
.c-author-content.is-right::before {
	content: "";
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, -100%);
	border: 10px solid transparent;
	border-bottom: 10px solid #FFFFFF;
}

/* テキスト */
.c-author-name {
	font-size: 1.25rem;;
	font-weight: bold;
	margin-bottom: 8px;
	}

.c-author-name a {
	text-decoration: none;
	}

.c-author-name a:hover {
	text-decoration: underline;
	}

.c-author-desc {
	font-size: 1rem;
	line-height: 1.8;
	text-align: justify;
	}

/*common-section******************************************/

.common-section__content {
	width: 100%;
	background-color: #FFFFFF;
	text-align: left;
	padding-top: 30px;
	padding-bottom: 30px;
	padding-left: 0;
	padding-right: 0;
}

/*summary-section******************************************/

.c-summary-box {
	background: #f5f8ff;
	border-left: 4px solid #3b82f6;
	padding: 16px;
	margin: 0 2%;
	}

.c-summary-list {
	list-style: none;
	margin: 20px;
	}

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

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

.c-toc-box {
	background: #f5f8ff;
	border-left: 4px solid #3b82f6;
	padding: 16px;
	margin: 0 2%;
	}

.c-toc-list {
	list-style: none;
	margin: 20px;
	}

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

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

.c-toc-list a {
	text-decoration: none;
	}

.c-toc-list a:hover {
	text-decoration: underline;
	}

/*title-section******************************************/

.titles-ection__wrapper{
        display: flex;
        justify-content: center; /* 水平方向の中央寄せ */
	margin-bottom: 0;
	}

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

.article-date__wrapper{
	width:100%;
	height: auto;
        margin-top: 20px;
	}

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

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

.subtitle-section__wrapper{
	width:100%;
	height: auto;
        margin-top: 20px;
	}

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

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

/*column-section******************************************/
/*------------------------------------------
  column-section（スマホ専用）
-------------------------------------------*/

.column-section__wrapper {
	display: block;
	background-color: #83B7E6;
	overflow-x: hidden;
	margin: 50px 0 0 0; /* 下を消す */
	padding: 30px 2%;
	box-sizing: border-box;
}

.column-section__content {
	width: 100%;
	max-width: 1436px;
	background-color: #FFFFFF;
	text-align: justify;
	hyphens: auto;
	margin: 10px auto 0 auto;
	padding: 30px 2%;
	box-sizing: border-box;
	border-radius: 10px;
}

.column-section__image {
	max-width: 1436px;
	margin: 0 auto 30px;
	padding: 0 20px;
	}

.column-section__image img {
	width: 100%;
	height: auto;
	display: block;
	aspect-ratio: 1396 / 785;
	border-radius: 8px;
	}

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

/*tags-section******************************************/

.tags-section__wrapper {
	clear: both;
	background-color: #83B7E6;
	margin-bottom: 50px;
	padding: 0 20px 30px;
	}

.tags-section__inner {
	display: flex;
	flex-direction: column; /* ←縦並び */
	align-items: center;   /* ←中央寄せ */
	text-align: center;
	gap: 20px;
	max-width: 1436px;
	margin: 0 auto;
	}

/* リード文 */
.cta-area__lead {
	color: #fff;
	font-size: 1rem;
	font-weight: 500;
	line-height: 1.6;
	margin: 0;
	}

/* タグ */
.c-column-tags {
	margin: 0;
	}

.c-column-tags__list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center; /* ←これだけでOK */
	gap: 10px;
	padding: 0;
	margin: 0;
	list-style: none;
	}

/* タグボタン */
.c-column-tags__link {
	display: inline-block;
	padding: 6px 12px;
	font-size: 0.875rem;
	color: #333;
	background: #fff;
	border-radius: 20px;
	text-decoration: none;
	transition: all 0.2s ease;
	}

.c-column-tags__link:hover {
	background: #3261B9;
	color: #fff;
	}

/*trust-section******************************************/

/* 1) 外側：グレー背景＋中央寄せ */
.trust-section__wrapper {
	background-color: #F0F0F0;
	margin: 50px 0;
	padding: 20px 2%;
	display: block;
	box-sizing: border-box;
	}

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

/* 3) カード部分はこれまで通り */
.trust-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: 14px;
	left: 0px;
	font-size: 1rem;
	font-weight:bold;
	color: #fff;
	transform: rotate(-45deg);
	}

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

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

/* 補足ボックス */
.trust-block__note {
	margin: 28px 0 24px;
	padding: 22px 24px;
	background-color: #F7F9FC;
	border-radius: 6px;
	}

.trust-block__note-title {
	margin: 0 0 10px;
	font-size: 1.25rem;
	font-weight: bold;
	text-align: justify;
	color: #222222;
	}

.trust-block__note-text {
	margin: 0;
	font-size: 1.0rem;
	line-height: 1.9;
	text-align: justify;
	color: #333333;
	padding: 10px 0 0 10px;
	}

/* 出典リンク */
.trust-block__source {
	margin: 0;
	font-size: 1.0rem;
	line-height: 1.8;
	text-align: justify;
	color: #555555;
	border-top: 1px solid #DDDDDD;
	padding: 30px 0 20px 30px;
	}

.trust-block__source a {
	color: #3261B9;
	text-decoration: underline;
	}

.trust-block__source a:hover {
	text-decoration: none;
	}

/*cta-banner******************************************/

.cta-banner__wrapper {
	display: flex;
	justify-content: center;
	background-color: #F0F0F0;
	margin: 50px 0 30px;
	overflow: hidden; /* ホバー拡大用 */
	}

.cta-banner__content {
	width: 100%;
	max-width: 1436px;
	background-color: #F0F0F0;
	padding: 30px 2%; /* ←固定px→%にしてCLS対策 */
	box-sizing: border-box;
	}

/* 画像ラッパー（追加推奨） */
.cta-banner__image {
	position: relative;
	width: 100%;
	aspect-ratio: 1536 / 1024; /* ←これ超重要（CLS対策） */
	overflow: hidden;
	border-radius: 10px; /* 任意 */
	}

/* 実画像 */
.cta-banner__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	will-change: transform;
	transform: scale(1);
	transition: transform 0.4s ease;
	}

/* ホバー拡大 */
.cta-banner__image:hover img {
	transform: scale(1.05); /* ←軽めに（GPU負荷抑える） */
	}


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

.company-section__wrapper {
	width: 100%;
	max-width: 1436px;
	margin: 50px auto 0;
	padding: 0 2%;
	display: 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;
	margin-top: 10px;
	padding-bottom: 110px;
	}

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

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

/*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; /* アスペクト比を維持 */
	}

.l-header__inner h1 {
	max-width: 252px;
	width: 252px;
	height: 85px; /* ← ヘッダーに合わせる */
	margin: 0;
	display: flex;
	align-items: center;
	}

/* テキストは非表示 */
.site-title__text {
	display: none;
	}

/* ロゴ */
.l-header__inner h1 img,
.site-title__logo {
	display: block;
	max-width: 100%;
	height: auto;
	}

h2 {
	font-size: 1.75rem;
	font-weight: bold;
	text-align: left;
	}

h3 {
	font-size: 1.5rem;
	font-weight: bold;
	text-align: left;
	}

.highlight-header__wrapper{
	height: auto;
	overflow: auto;
        margin-top:30px;
	}

.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;
	}

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

.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;
	}

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

.dropdown_nav {
    display: none !important;
    }

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