@charset "utf-8";

/*--------------------------------------
	WEBフォント
--------------------------------------*/
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@500;700;800&family=Poppins:wght@500;600;700&display=swap');
/* @import url('webfont.css');開発環境用 */

/*--------------------------------------
	共通
--------------------------------------*/
:root {--s: 1px;}
@media (max-width: 767px) {
/* sp */
:root {--s: 0.13038vw;}
/* sp end */
}

.d-inline-block {display: inline-block;}

* { margin: 0; padding: 0; }

body {
	margin: 0;
	padding: 0;
	width: 100%;
	background-color: #fff;
	color: #333;
	font-family: 'Poppins', sans-serif;
	font-size: 65%; font-weight: 500;
	line-height: 1.7;
}
img {
	max-width: 100%;
	border: none;
}
a {
	color: #2d89dc;
	text-decoration: none;
}
a:hover {
	text-decoration: underline;
}

.wrap {
	width: 100%;
	margin: 0;
	padding: 0;
	font-size: 1.25em;
}

/* 新規ウィンドウアイコン */
.windowBtn {
	position: relative;
	top: 3px;
	border: none;
}
.fltR {
	float: right;
}
.fltL {
	float: left;
	padding: 0px 5px 10px 0;
 }
.clearB {
	clear: both; width: 100%;
}
.clearW {
	overflow:hidden; width:100%;
}

.alignC {
	text-align: center;
}
.alignR {
	text-align: right;
}

.bg-gray {
	background: #f4f5f6;
}

.bg-white {
	background: #fff;
}

.text-normal {
	font-weight: normal;
}

.text-bold {
	font-weight: 70;
}

.text-gray {
	color: #6f6f6f;
}
.text-blue {
	color: #2975d6;
}
.text-red {
	color: #dc387d;
}
.text-orange {
	color: #e54916;
}
.text-green {
	color: #70AD47;
}

a#fancybox-close {
	top: 15px !important;
	right: 15px !important;
	background-image: url(../img/fancybox_close.png) !important;
	background-position: center center !important;
	background-repeat: no-repeat !important;
}

a#fancybox-close:hover {
	background-image: url(../img/fancybox_close_on.png) !important;
}

#fancybox-outer {
	box-shadow: none!important;
	-moz-box-shadow: none!important;
	-webkit-box-shadow: none!important;
}

.goSP {
	background: #4db9da;
}

.goSP a {
	display: block;
	width: 100%;
	line-height: 3em;
	color: #fff;
	font-size: 150%;
	text-align: center;
}

/*--------------------------------------
	ヘッダー
--------------------------------------*/
.head {
	display: block;
	max-width: 952px;
	margin: 0 auto;
	padding: 0;
}
.headInner {
	overflow: hidden;
	display: block;
	max-width: 952px;
	margin: 0 auto;
	padding: 0;
	text-align: left;
}

/* メインロゴ */
.headLogo {
	position: relative;
	display: block;
	width: 179px;
	height: 21px;
	margin-top: 35px;
	margin-bottom: 40px;
	float: left;
}

.headLogo a {
	display: block;
	height: 100%;
	width: 100%;
}

.headCopyJ,
.headCopyE {
	float: right;
	position: relative;
	display: block;
	width: 190px;
	text-indent: -9999px;
}

.headCopyJ {
	background: url(img/head_copy_j.png) 0 0 no-repeat;
	background-size: contain;
}
.headCopyE {
	background: url(img_en/head_copy_e.png) 0 0 no-repeat;
	background-size: contain;
}

/*--------------------------------------
	グローバルナビ
--------------------------------------*/
.globalNav {
	display: block;
	width: 100%;
	margin: 0;
	padding: 0;
}

.globalNav li {
	position: relative;
	margin: 0;
	padding: 0;
	height: 40px;
	line-height: 40px;
	list-style: none;
}

.globalNav li a {
	display: block;
	width: 100%;
	height: 100%;
	text-align: center;
	box-sizing: border-box;
	color: #6f6f6f;
	font-size: 115%;
}

.globalNav li a:hover {
	text-decoration: none;
}

/*--------------------------------------
	コンテンツ
--------------------------------------*/
.contents {
	position: relative;
	margin: 80px auto 0;
}
@media (max-width: 768px) {
/* sp */
.contents {margin-top: calc(var(--s)*100);}
/* sp end */
}
.contentsInner {
	position: relative;
	overflow: hidden;
	display: block;
	margin: 0 auto;
	max-width: 1200px;
	padding: 20px 20px 0px;
	font-size: calc(var(--s)*16);
}

/* パンくず */
.pankzPath {
	margin: 0;
	padding: 0 0 30px 0;
	color: #333;
	font-size: 13px;
	letter-spacing: 1px;
}
.pankzPath a {
	display: inline-block;
	color: #2d89dc;
	text-decoration: none;
}
.pankzPath a:hover { text-decoration: underline; }

/*--------------------------------------
	コンテンツ（IT-EX流用）
--------------------------------------*/
.contents li.kome {
	text-indent: -1.2em;
}

/*--------------------------------------
	基本ページ用
--------------------------------------*/

/* 基本タイトル */
.sectionTitle {
	margin: 0 0 20px 0;
	padding: 0 0 5px 0;
	font-size: 1.5em;
	font-weight: 700;
}

/* 基本タイトル（■付） */
.sectionTitle2 {
	margin: 0 0 20px 0;
	font-size: 1.5em;
	font-weight: 700;
}

/* 基本タイトル（縄付） */
.sectionTitleRope {
	margin-bottom: 0 0 20px 0;
	padding-bottom: 0 0 5px 0;
	font-size: 1.5em;
	font-weight: 70;
	background: url(img/rope_bg.png) 0 100% repeat-x;
}

/*--------------------------------------
	フッター
--------------------------------------*/
.footer {
  color: #333; font-size: calc(var(--s)*16); line-height: 1.75; font-weight: 500;
	float: left;
	display: block;
	position: relative;
	width: 100%;
	margin: 0 auto;
	padding: calc(var(--s)*20) 0;
	text-align: center;
}
.footer .border {
	clear: both;
	width: 100%;
	margin: 0 auto;
	padding: 0;
	border-top: solid 2px #cbcbcb;
	border-bottom: solid 2px #e0e0e0;
}
.footerInner {
	overflow: hidden;
	display: block;
	max-width: 1160px;
	margin: 0 auto;
	padding: 0;
	text-align: left;
}

/* コピーライト */
.footerCopyJ {
	/* width: 188px;
	height: 10px;
	margin: 0 0 1px 0;
	background: url(../img/footer_copy_j.png) 0 0 no-repeat;
	background-size: contain; */
	font-size: calc(var(--s)*14); font-weight: 700;
}
/* .footerCopyEn {
	width: 194px;
	height: 10px;
	margin: 0 0 1px 0;
	background: url(../img_en/footer_copy_e.png) 0 0 no-repeat;
	background-size: contain;
} */
.footerCopyE {
	font-size: calc(var(--s)*10);
}

/* ページの先頭へ戻る */
.toTop {
	clear: both;
	position:relative;
	max-width: 1158px;
	margin: 0 auto -10px !important;
	top: 10px;
	font-size: 0.8em;
	text-align: right;
	letter-spacing: -0.5px; /*-0.09em;*/
}
.toTop a {
	position: relative;
	display: inline-block; height: calc(var(--s)*20); padding: 0 0 0 2.5em;
	color: #585858; font-size: calc(var(--s)*10); line-height: 2; text-align: left;
	background: url(../img/footer_toTop.svg) left top/calc(var(--s)*17) no-repeat;
}
/* .toTop a:before {
	position: relative;
	display: inline-block;
	width: 12px;
	height: 12px;
	margin: 0;
	top: 1px;
	background: url(../img/to_top_arrow.png) 0 50% no-repeat;
	content: "";
} */
.tagline {
	text-align: right;
	margin-bottom: 20px;
}

@media (min-width: 768px) and (max-width: 980px){
/* mini pc */
.headInner {
	padding-left: 15px;
	padding-right: 15px;
	box-sizing: border-box;
}
.footerInner {
	padding-left: 15px;
	padding-right: 15px;
	box-sizing: border-box;
}
/* mini pc end */
}

@media (min-width: 768px){
/* pc */

.sp {
	display: none!important;
}

.pc-center {
	text-align: center;
}

.headNavWrap {
	float: right;
	position: relative;
	display: block;
	margin: 0;
	padding: 0;
	top: 19px;
	left: 0;
}
.headNav {
	position: relative;
	display: block;
	width: 245px;
	text-align: left;
}
.headNav ul {
	position: relative;
	margin: 0;
	padding: 0;
	font-size: 10px;
	text-align: right;
}
.headNav li {
	display: inline-block;
	margin: 0 0 0 5px;
	padding: 0 0 0 5px;
	border-left: 1px solid #d8dadc;
	text-align: left;
	list-style: none;
}
.headNav li:first-child {
	padding: 0;
	border-left: 0;
}

.headNav a {
	font-size: 11px;
	color: #6f6f6f;
	padding-left: 12px;
	background-image: url(img/icon_arrow.png);
	background-repeat: no-repeat;
	background-position: left center;
}
.headNav a:hover {
	color: #333;
	text-decoration: none;
}

.mainLead {
	padding-bottom: 1.5em;
	margin-bottom: 30px;
}
.mainLead:after {
	left: 0;
	right: 0;
	width: 240px;
	margin: auto;
}

.sns {
	float:right;
	position: relative;
	display: block;
	width: 44px;
	height: 20px;
	margin-right: 0;
	padding-top: 5px;
	text-align: left;
}
.sns ul {
	margin: 0;
	padding: 0;
}
.sns li {
	float: left;
	height: 20px;
	margin: 0 0 0 2px;
	padding: 0;
	list-style: none;
}
.twitterBtn a {
	display: block;
	width: 20px;
	height: 20px;
	text-indent: -9999px;
	background: url(img/icon_twitter.png) 0 0 no-repeat;
	background-size: contain;
}
.twitterBtn a:hover {
	opacity: 0.8;
}

.facebookBtn a {
	display: block;
	width: 20px;
	height: 20px;
	text-indent: -9999px;
	background: url(img/icon_facebook.png) 0 0 no-repeat;
	background-size: contain;
}

.facebookBtn a:hover {
	opacity: 0.8;
}

.globalNav {
	height: 40px;
	background: #f4f5f6;
	border-top: 1px solid #e4e5e6;
}

.globalNav ul {
	position: relative;
	max-width: 952px;
	margin: 0 auto;
	padding: 0;
}
.globalNav ul:after {
	content: "";
	display: block;
	clear: both;
}
.globalNav li {
	float: left;
}
.globalNav li:first-child:before {
	content: "";
	display: block;
	position: absolute;
	left: 0;
	top: 20%;
	height: 60%;
	width: 1px;
	background: #e4e5e6;
}
.globalNav li:after {
	content: "";
	display: block;
	position: absolute;
	right: 0;
	top: 20%;
	height: 60%;
	width: 1px;
	background: #e4e5e6;
}

.globalNav li a {
	border-top: 3px solid #f4f5f6;
	line-height: 34px;
}
.globalNav li a:hover,
.globalNav li.active a {
	border-top: 3px solid #b9bcbd;
}
.globalNav .Ja li {
	width: calc(100% / 6);
}
_:-ms-lang(x)::backdrop, .globalNav .Ja li {
	width:16.66%;
}
.globalNav .En li {
	width: calc(100% / 3);
}
.globalNav li.spBtn {
	display: none;
}
.globalNav li.spLink {
	display: none;
}

.footerNav {
	display: block;
	margin: 10px 0 5px 0;
	padding: 0;
	text-align: left;
}

.footerNav ul {
	display: flex; flex-wrap: wrap;
	position: relative;
	margin: 0;
	padding: 0;
	text-align: left;
}

.footerNav li {
	position: relative;
	margin: 0 10px 0 0;
	padding: 0 0 0 10px;
	list-style: none;
}
.footerNav li::after {
	content: '';
	position: absolute; top: 0; bottom: 0; left: 0;
	display: block; margin: auto 0; width: 1px; height: 1.25em;
	background: #989898;
}
.footerNav li:first-child {
	padding: 0;
}
.footerNav li:first-child::after {
	display: none;
}

.footerNav a {
	font-size: 14px; letter-spacing: 0;
	color: #333; white-space: nowrap; font-weight: 600;
}
.footerNav a:hover {
	color: #000;
	text-decoration: none;
}

/* pc end */
}

@media (min-width: 768px) and (-ms-high-contrast:none){
/* pc ie */
.globalNav .Ja li {
	width: 16%;
}
.globalNav .Ja li:first-child {
	margin-left: 2%;
}
.globalNav .Ja li:last-child {
	margin-right: 2%;
}
.globalNav .En li {
	width: 32%;
}
.globalNav .En li:first-child {
	margin-left: 2%;
}
.globalNav .En li:last-child {
	margin-right: 2%;
}
/* pc ie end */
}

@media (max-width: 767px){
/* sp */

.no-sp {
	display: none!important;
}

.sp-center {
	text-align: center;
}

.head {
	border-bottom: 1px solid #c5c7c8;
}

.pankzPath {
	display: none;
}

.headNavWrap {
	display: none;
}
.headInner {
	padding-left: 15px;
	padding-right: 15px;
}
.headNavSP {
	position: relative;
	float: right;
	width: 32px;
	height: 28px;
	margin-top: 30px;
}
.headNavSP a {
	display: block;
	width: 100%;
	height: 100%;
}
.headNavSP span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 4px;
	background-color: #4D4D4D;
	border-radius: 4px;
	transition: all .4s;
	box-sizing: border-box;
}
.headNavSP span:nth-child(3n+0){
	top: 0;
}
.headNavSP span:nth-child(3n+1){
	top: 12px;
}
.headNavSP span:nth-child(3n+2){
	top: 24px;
}
.headNavSP a.active span:nth-child(3n+0){
	-webkit-transform: translateY(12px) rotate(-45deg);
	transform: translateY(12px) rotate(-45deg);
}
.headNavSP a.active span:nth-child(3n+1){
	opacity: 0;
}
.headNavSP a.active span:nth-child(3n+2){
	-webkit-transform: translateY(-12px) rotate(45deg);
	transform: translateY(-12px) rotate(45deg);
}
.globalNav {
	display: none;
	position: absolute;
	top: 0;
	left: 0;
	background: rgba(255, 255, 255, 0.9);
	z-index: 99999;
}
.globalNav ul {
	border-top: 1px solid #000;
	margin: 0;
	padding: 0;
}
.globalNav li {
	border-bottom: 1px solid #000;
}
.globalNav li.spBtn {
	height: auto;
	padding-bottom: 20px;
}
.globalNav li.spBtn:after {
	content: "";
	display: block;
	clear: both;
}
.globalNav li.spBtn a {
	float: left;
	width: 42%;
	margin: 20px 0 0 5%;
	padding-left: 12%;
	border: 1px solid #000;
	border-radius: 5px;
	box-sizing: border-box;
	text-align: left;
}
.globalNav .officeListBtn {
	background-image: url(img/icon_offiecelist.png);
	background-position: 5% center;
	background-repeat: no-repeat;
	background-size: auto 75%;
	box-sizing: border-box;
}
.globalNav .siteMapBtn {
	background-image: url(img/icon_sitemap.png);
	background-position: 5% center;
	background-repeat: no-repeat;
	background-size: auto 75%;
	box-sizing: border-box;
}
.globalNav .twitterBtn {
	background-image: url(img/icon_twitter_sp-menu.png);
	background-position: 5% center;
	background-repeat: no-repeat;
	background-size: auto 75%;
	box-sizing: border-box;
}
.globalNav .facebookBtn {
	background-image: url(img/icon_facebook_sp-menu.png);
	background-position: 5% center;
	background-repeat: no-repeat;
	background-size: auto 75%;
	box-sizing: border-box;
}
.globalNav .englishBtn,
.globalNav .japaneseBtn {
	background-image: url(img/icon_translation.png);
	background-position: 5% center;
	background-repeat: no-repeat;
	background-size: auto 75%;
	box-sizing: border-box;
}
.globalNav li.spLink {
	height: auto;
	padding: 20px 0 20px 20px;
	box-sizing: border-box;
}
.globalNav li.spLink a {
	text-align: left;
}
.mainLead {
	padding-bottom: 1em;
	padding-left: 15px;
    padding-right: 15px;
}
.mainLead:after {
	left: 35%;
	width: 30%;
}
.contentsInner {
	padding-left: 15px;
	padding-right: 15px;
}
.goPC {
	width: 90%;
	margin: 0 auto 2em auto;
	font-size: 15px;
}
.goPC a {
	display: block;
	color: #fff;
	border-radius: 3px;
	line-height: 3em;
	text-align: center;
	text-decoration: none;
	background-color: #6f6f6f;
}
.footer {
	position: relative;
	height: calc(var(--s)*140);
	padding-top: 0; padding-bottom: 0;
}
.footerCopyJ {
	padding-top: calc(var(--s)*25); padding-left: calc(var(--s)*40);
	font-size: calc(var(--s)*28);
}
.footerCopyE {
	padding-top: calc(var(--s)*50); padding-left: calc(var(--s)*40);
	font-size: calc(var(--s)*20);
}
.toTop {
	position: absolute; top: calc(var(--s)*40); right: calc(var(--s)*40); bottom: 0;
	display: block; width: calc(var(--s)*60); height: auto; aspect-ratio: 1/1;
}
.toTop a {
	position: relative; left: 0; top: 0;
	display: block; width: calc(var(--s)*60); height: auto; aspect-ratio: 1/1; padding: 0;
	background-size: contain;
	text-indent: -9999px;
}
.footerNav {
	display: none;
}
.footerInner {
	padding: 0;
}
/* sp end */
}
