@charset "utf-8";

/* corporate のみ　コンテンツサイズを変更 */
.container {
	max-width: 1200px;
}
.sp-br {
	display: none;
}

/* Path: common.css */
.corporate-layout-parts-1 {
	position: relative;
	color: #333;
	margin: 64px 0 0;
}
.corporate-layout-parts-1.first-content {
	margin: 64px 0 0;
}
.corporate-layout-parts-1-inner {
	padding: 100px 0;
	background-repeat: no-repeat;
	background-size: auto 720px;
	background-position: right top;
}
.corporate-layout-parts-1 h2 {
	font-size: 34px;
	font-weight: 500;
	line-height: 48px;
	border-bottom: 1px solid #a0a3aa;
}
.corporate-layout-parts-1 h2::after {
	content: "";
	display: block;
	width: 70px;
	height: 3px;
	background-color: #0062c2;
	transform: translateY(3px);
}
.corporate-layout-parts-1 h2 + p {
	font-size: 16px;
	font-weight: bold;
	margin: 24px 0 32px;
}
.corporate-layout-parts-1.bg-F7F7F8 {
	background-color: #f7f7f8;
}
.col-3 {
	display: grid;
	gap: 24px;
	grid-template-columns: repeat(3, 1fr);
	width: 100%;
}

.corporate-layout-parts-1 dl {
	background: #fff;
	padding: 20px;
	border: 1px solid #bdc1c4;
}
.corporate-layout-parts-1 dl dt {
	font-size: 16px;
	font-weight: bold;
	border-bottom: 1px solid #0f2350;
	text-align: center;
	padding: 0 8px 12px;
	margin: 0 0 20px;
}
.corporate-layout-parts-1 dl dd {
	font-size: 16px;
	font-weight: bold;
}
.corporate-layout-parts-1 dl dd::before {
	content: "・";
}
.corporate-layout-parts-1 dl dd + dd {
	margin: 8px 0 0;
}
.corporate-layout-parts-1 dl dd.text-color-red {
	color: #e83133;
}
.corporate-layout-parts-1 dl dd span {
	font-weight: 500;
	display: block;
	color: #333;
}
.corporate-layout-parts-1 dl dd img {
	width: auto;
	margin: 24px auto;
	display: block;
}

@media only screen and (max-width: 991px) {
	.corporate-layout-parts-1 {
		margin: 0;
	}
	.corporate-layout-parts-1.first-content {
		margin: 32px 0 0;
	}
	.corporate-layout-parts-1-inner {
		background-size: auto 157px;
		background-position: right top;
		padding: 20px 0;
	}
	.corporate-layout-parts-1 h2 {
		font-size: 26px;
		line-height: 40px;
		padding: 0 0 20px;
		min-height: 86px;
		position: relative;
		display: flex;
		align-items: center;
	}
	.corporate-layout-parts-1 h2::after {
		transform: translateY(0);
		position: absolute;
		bottom: -3px;
	}
	.corporate-layout-parts-1 h2 + p {
		margin: 32px 0;
	}
	.sp-col-1 {
		gap: 10px 0;
		grid-template-columns: repeat(1, 1fr);
	}
}
@media only screen and (max-width: 719px) {
	.container {
		margin: 0 auto;
		overflow: hidden;
	}
	.sp-br {
		display: block;
	}
}

/* display */
.only-pc {
	display: block;
}
.only-sp {
	display: none;
}
@media only screen and (max-width: 750px) {
	.only-pc {
		display: none;
	}
	.only-sp {
		display: block;
	}
}

/* -------------------------------
h2（スマホ用）
--------------------------------*/
.page-title-sp {
	display: none;
}
@media only screen and (max-width: 750px) {
	.page-title-sp {
		display: block;
		margin: 20px;
		font-size: 32px;
		font-weight: 400;
		letter-spacing: 7.04px;
		color: #333;
	}
}

/* -------------------------------
フォトボックス 
--------------------------------*/
.photobox {
	display: flex;
	justify-content: flex-start;
	gap: 24px;
}
.photobox .photobox-item {
	text-decoration: none;
	color: #fff;
	display: flex;
	flex-direction: column;
}
.photobox img {
	width: 100%;
	height: auto;
}
.photobox .text-area {
	background: #333;
	padding: 20px 25px;
	flex-grow: 1;
}
.photobox a:hover .text-area {
	background: #0062c2;
}
.photobox .text-area h2 {
	font-size: 18px;
	margin-bottom: 10px;
	font-weight: 700;
	letter-spacing: 0.06em;
	display: inline-block;
}
.photobox .text-area h2 img[src*="icn_right_w"] {
	width: 10px;
	margin-left: 15px;
	vertical-align: middle;
}
.photobox .text-area.link_arrow-w h2:after {
  content: "";
  background: url("../images/icon-bullet-link-w.svg") no-repeat 0 0;
  background-size: contain;
  display: inline-block;
  margin-left: 10px;
  position: relative;
  top: 3px;
  width: 20px;
  height: 20px;
}
.photobox .text-area p {
	font-size: 16px;
	font-weight: 400;
}
/* 2カラム */
.photobox.column-2 .photobox-item {
	width: calc((100% - 24px) / 2);
}
/* 3カラム */
.photobox.column-3 .photobox-item {
	width: calc((100% - 24px - 24px) / 3);
}
/* 4カラム */
.photobox.column-4 .photobox-item {
	width: calc((100% - 24px - 24px - 24px) / 4);
}
/* 画像とテキストが横並びのボックス */
.photobox.photobox-row .photobox-item {
	background: #333;
	padding: 25px;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	flex-direction: row;
}
.photobox.photobox-row .photobox-item figure {
	width: 47%;
}
.photobox.photobox-row .photobox-item .text-area {
	width: 49%;
	padding: 0;
	flex-grow: unset;
}
.photobox.photobox-row .photobox-item:hover {
	background: #0062c2;
}

/* ページタイトルのみボックス */
.photobox.name-only .photobox-item .text-area {
	padding-right: 58px;
}
.photobox.name-only .text-area h2 {
	margin-bottom: 0;
}
@media only screen and (max-width: 1200px) {
	.photobox.name-only .photobox-item .text-area {
		padding-right: 25px;
	}
}
@media only screen and (max-width: 750px) {
	.photobox {
		flex-direction: column;
		justify-content: center;
		gap: 10px;
	}
	.photobox .text-area {
		padding: 20px;
	}
	.photobox.column-2 .photobox-item,
	.photobox.column-3 .photobox-item,
	.photobox.column-4 .photobox-item {
		width: 100%;
		max-width: 600px;
		margin: 0 auto;
	}
	/* 画像とテキストが横並びのボックス */
	.photobox.photobox-row .photobox-item {
		padding: 0;
		flex-direction: column;
	}
	.photobox.photobox-row .photobox-item figure {
		width: 100%;
	}
	.photobox.photobox-row .photobox-item .text-area {
		width: 100%;
		padding: 20px;
		box-sizing: border-box;
	}
}

/* -------------------------------
バナー画像
--------------------------------*/
.photobox-banner {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
}
@media only screen and (max-width: 750px) {
	.photobox-banner {
		max-width: 600px;
		margin: 0 auto;
	}
}

/* -------------------------------
下部ローカルナビ
--------------------------------*/
.under-local-nav {
	padding: 40px;
	border-radius: 10px;
	border: solid 1px #75757c;
	max-width: 1200px;
	margin: 55px auto 0;
	box-sizing: border-box;
}
.under-local-nav .h2 {
	padding-bottom: 20px;
	border-bottom: solid 1px #75757c;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	margin-bottom: 30px;
	color: #333;
}
.under-local-nav .h2 .link {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	color: #333;
	text-decoration: none;
  position: relative;
  padding-right: 30px;
}
.under-local-nav .h2 .link:hover {
  color: #0062c2;
}
.under-local-nav .h2 .link::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0%;
  height: 1px;
  transition: all 0.2s ease;
}
.under-local-nav .h2 .link:hover::before {
  width: 100%;
  border-bottom: 1px solid #0062c2;
}
.under-local-nav .h2 .link::after {
  content: "";
  background: url(/jp-ja/corporate/img/icon-bullet-link.svg) 20px 20px;
  width: 20px;
  height: 20px;
  position: absolute;
  right: -5px;
  bottom: 10px;
}
.under-local-nav .h2 .link:hover::after {
  background: url(/jp-ja/corporate/img/icon-bullet-link-b.svg) 20px 20px;
}
.under-local-nav .h2 span {
	display: inline-block;
	letter-spacing: 2.2px;
	font-size: 22px;
}
.under-local-nav .h2 img[src*="icn_right_b"] {
	width: 8px;
	margin-left: 10px;
}
.under-local-nav ul {
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
	gap: 20px 10px;
}
.under-local-nav ul li {
	list-style: none;
}
.under-local-nav ul li a::after {
	content: "";
	background: url("/shared/unchangeable/img/icn_right_b.png");
	background-size: 8px;
	background-repeat: no-repeat;
	width: 8px;
	height: 16px;
	position: absolute;
	top: 50%;
	right: 20px;
	transform: translateY(-50%);
	z-index: 0;
}
.under-local-nav ul li a {
	display: inline-block;
	font-size: 16px;
	color: #333;
	text-decoration: none;
	padding: 8px 38px 8px 10px;
	position: relative;
	z-index: 1;
	border-radius: 5px;
	border: solid 1px #75757c;
	position: relative;
}
/*hoverデザイン*/
.under-local-nav ul li a:hover {
	background: #0062c2;
	border-color: #0062c2;
	color: #fff;
	box-shadow: 0 3px 6px rgba(0, 0, 0, 0.4);
}
.under-local-nav ul li a:hover::after {
	background: url("/shared/unchangeable/img/icn_right_w.png");
	background-size: 8px;
	background-repeat: no-repeat;
	width: 8px;
	height: 16px;
	position: absolute;
	top: 50%;
	right: 20px;
	transform: translateY(-50%);
}
/*現在ページのデザイン*/
.under-local-nav ul li.active a {
	border: solid 1px #f2f3f0;
	background: #f2f3f0;
	padding-right: 10px;
	pointer-events: none;
	cursor: default;
}
.under-local-nav ul li.active a::after {
	display: none;
}
.under-local-nav ul li.active a:hover {
	background: #f2f3f0;
	border-color: #f2f3f0;
	color: #333;
	box-shadow: none;
}
/*外部リンクのデザイン*/
.under-local-nav ul li.extra-link a::after {
	background: url("/shared/unchangeable/img/icn_list_external.png");
	background-size: 16px;
	background-repeat: no-repeat;
	width: 16px;
	height: 13px;
	position: absolute;
	top: 50%;
	right: 10px;
	transform: translateY(-50%);
}
.under-local-nav ul li.extra-link a:hover::after {
	background: url("/shared/unchangeable/img/icn_list_external_w.png");
	background-size: 16px;
	background-repeat: no-repeat;
	width: 16px;
	height: 13px;
	position: absolute;
	top: 50%;
	right: 10px;
	transform: translateY(-50%);
}
@media only screen and (max-width: 750px) {
	.under-local-nav {
		margin-top: 30px;
		padding: 30px 20px;
	}
	.under-local-nav ul {
		gap: 10px;
	}
	.under-local-nav .h2 {
		padding-bottom: 13px;
		margin-bottom: 20px;
	}
}

/* -------------------------------
ボタン
--------------------------------*/
.cm-btn {
	display: block;
	background: url(/shared/corporate_opt/images/icon-bullet-link.svg) no-repeat right
		20px center #fff;
	border: 1px solid #75757c;
	font-size: 18px;
	font-weight: bold;
	padding: 23px 25px;
	max-width: 384px;
	margin: auto;
	box-sizing: border-box;
	color: #333333;
	text-decoration: none;
}
/* 黒 */
.cm-btn.cm-btn-bk {
	background: url(/shared/corporate_opt/images/icon-bullet-link-w.svg) no-repeat right
		25px center #333;
	color: #fff;
}
.cm-btn:hover {
	background: url(/shared/corporate_opt/images/icon-bullet-link-w.svg) no-repeat right
		25px center #0062c2;
	color: #fff;
	box-shadow: 3px 3px 6px 0px rgba(0, 0, 0, 0.4);
	background-size: 10px;
}
@media only screen and (max-width: 750px) {
	.cm-btn {
		padding: 21px 25px;
	}
}

/* -------------------------------
見出し
--------------------------------*/
.module-h2 {
	font-size: 34px;
	font-weight: 400;
	color: #000;
	letter-spacing: 3.4px;
	padding-bottom: 5px;
	margin-bottom: 40px;
	border-bottom: solid 1px #333;
	position: relative;
}
.module-h2::after {
	content: "";
	background: #0062c2;
	width: 70px;
	height: 3px;
	position: absolute;
	bottom: -3px;
	left: 0;
}
/* @media only screen and (max-width: 1200px){
  .module-h2 h3 {
      font-size: 28px;
  }
} */
@media only screen and (max-width: 750px) {
	.corporate-link-block-l .img {
		width: 100%;
	}
	.module-h2 {
		font-size: 26px;
		letter-spacing: 2.6px;
		padding-bottom: 10px;
		margin-bottom: 20px;
	}
}
