@charset "utf-8";
/* -----------------------------------------
common.css
----------------------------------------- */


/* reset
----------------------------------------- */

html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,
a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,
small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,
fieldset,form,label,legend,input,textarea,table,caption,tbody,tfoot,thead,tr,th,td,
article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,
menu,nav,output,ruby,section,summary,time,mark,audio,video {
	margin: 0px;
	padding: 0px;
}

h1,h2,h3,h4,h5,h6,th,input,textarea,select {
	font-family: inherit;
	font-size: 100%;
	font-weight: normal;
}

table {
	border-spacing: 0;
	border-collapse: collapse;
}

table,th,td {
	text-align: left;
	border: none;
}

ol,ul,li {
	list-style: none;
}

img {
	border: none;
	vertical-align: top;
	max-width: 100%;
}


/* 初期設定
----------------------------------------- */

body {
	min-width: 320px;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 87.5%;
	color: #333;
	line-height: 1.3;
	-webkit-text-size-adjust: 100%;
}

a {
	color: inherit;
	text-decoration: none;
}

em, strong {
	font-weight: bold;
}

sub {
	vertical-align: baseline;
	font-size: 50%;
}

/* 汎用クラス
----------------------------------------- */

.clearfix { zoom: 1; }
.clearfix:after {
	content: "";
	display: block;
	clear: both;
	height: 0.01px;
}

.floatL { float: left; }
.floatR { float: right; }

.fontL  { font-size: 116.7%; }	/* 14px */
.fontLL { font-size: 133.3%; }	/* 16px */
.fontXL { font-size: 150%; }	/* 18px */
.fontS  { font-size: 91.7%; }	/* 11px */
.fontSS { font-size: 83.3%; }	/* 10px */

.txtBold { font-weight: bold; }

.taLeft { text-align: left !important; }
.taCenter { text-align: center !important; }
.taRight { text-align: right !important; }

.vaTop { vertical-align: top !important; }
.vaBtm { vertical-align: bottom !important; }

.hide { display: none; }

.indent { text-indent: 1em; }


.mt0  { margin-top:  0px !important; }
.mt3  { margin-top:  3px !important; }
.mt5  { margin-top:  5px !important; }
.mt10 { margin-top: 10px !important; }
.mt15 { margin-top: 15px !important; }
.mt20 { margin-top: 20px !important; }
.mt25 { margin-top: 25px !important; }
.mt30 { margin-top: 30px !important; }
.mt35 { margin-top: 35px !important; }
.mt40 { margin-top: 40px !important; }
.mt45 { margin-top: 45px !important; }
.mt50 { margin-top: 50px !important; }

.ml0  { margin-left:  0px !important; }
.ml3  { margin-left:  3px !important; }
.ml5  { margin-left:  5px !important; }
.ml10 { margin-left: 10px !important; }
.ml15 { margin-left: 15px !important; }
.ml20 { margin-left: 20px !important; }
.ml25 { margin-left: 25px !important; }
.ml30 { margin-left: 30px !important; }
.ml35 { margin-left: 35px !important; }
.ml40 { margin-left: 40px !important; }
.ml45 { margin-left: 45px !important; }
.ml50 { margin-left: 50px !important; }

.mr0  { margin-right:  0px !important; }
.mr3  { margin-right:  3px !important; }
.mr5  { margin-right:  5px !important; }
.mr10 { margin-right: 10px !important; }
.mr15 { margin-right: 15px !important; }
.mr20 { margin-right: 20px !important; }
.mr25 { margin-right: 25px !important; }
.mr30 { margin-right: 30px !important; }
.mr35 { margin-right: 35px !important; }
.mr40 { margin-right: 40px !important; }
.mr45 { margin-right: 45px !important; }
.mr50 { margin-right: 50px !important; }

.mb0  { margin-bottom:  0px !important; }
.mb3  { margin-bottom:  3px !important; }
.mb5  { margin-bottom:  5px !important; }
.mb10 { margin-bottom: 10px !important; }
.mb15 { margin-bottom: 15px !important; }
.mb20 { margin-bottom: 20px !important; }
.mb25 { margin-bottom: 25px !important; }
.mb30 { margin-bottom: 30px !important; }
.mb35 { margin-bottom: 35px !important; }
.mb40 { margin-bottom: 40px !important; }
.mb45 { margin-bottom: 45px !important; }
.mb50 { margin-bottom: 50px !important; }

img.sp {
	display: none;
}

/* ページフレーム
----------------------------------------- */

html {
	overflow-y: scroll;
}
html, body {
	height: 100%;
}

.f_pageArea {
	position: relative;
	width: 100%;
	height: 100%;
	padding-top: 70px;
	min-height: 650px;
	box-sizing: border-box;
	background-color: #000;
}
body.s_top .f_pageArea {
	overflow: hidden;
}
body.s_evolution .f_pageArea {
	min-height: 0;
	background-color: #fff;
}
body.s_challenge .f_pageArea {
	min-height: 320px;
}
body.s_ambition .f_pageArea {
	height: auto;
	overflow: hidden;
}
body.s_word .f_pageArea {
	min-height: 820px;
}
@media screen and (max-width: 1000px){
	body.s_challenge .f_pageArea {
		height: auto;
	}
}
@media screen and (max-width: 600px){
	body.s_challenge .f_pageArea {
		padding-bottom: 66px;
	}
}
@media screen and (max-width: 440px){
	body.s_challenge .f_pageArea {
		padding-bottom: 81px;
	}
}
@media screen and (max-width: 800px){
	.f_pageArea {
		padding-top: 45px;
	}
	body.s_top .f_pageArea {
		height: auto;
		min-height: 0;
	}
}

.f_header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 2000;
	background-color: #fff;
	height: 70px;
	box-shadow: 0 3px 10px rgba(0,0,0,0.35);
}
.f_header .p_logo {
	float: left;
}
.f_header .p_logo a {
	display: block;
	padding: 25px 30px 24px;
}
.f_header .p_backLink {
	float: left;
	margin-top: 27px;
}
.f_header .p_backLink a {
	position: relative;
	padding-left: 13px;
	font-size: 12px;
}
.f_header .p_backLink a:before {
	content: "";
	position: absolute;
	top: 5px;
	left: 0;
	width: 4px;
	height: 4px;
	border-right: 2px solid #22439c;
	border-bottom: 2px solid #22439c;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.f_header .p_menuBtn {
	display: none;
}
.f_header .p_gnavi {
	float: right;
}
.f_header .p_gnavi > ul {
	float: left;
}
.f_header .p_gnavi > ul > li {
	float: left;
}
.f_header .p_gnavi > ul > li > a {
	position: relative;
	display: block;
	padding: 18px 28px 9px;
	text-align: center;
	transition: opacity 0.3s;
}
body.s_english .f_header .p_gnavi > ul > li > a {
	padding-top: 23px;
	padding-bottom: 22px;
}
.f_header .p_gnavi a:hover {
	opacity: 0.7;
}
.f_header .p_gnavi a.s_current:after {
	content: "";
	position: absolute;
	left: 36px;
	right: 36px;
	bottom: 0;
	border-bottom: 5px solid #22439c;
	opacity: 1;
}
.f_header .p_gnavi .p_english {
	color: #22439c;
	font-family: Arial;
	font-size: 18px;
	font-weight: bold;
	line-height: 25px;
}
.f_header .p_gnavi .p_title {
	color: #ccc;
	font-size: 12px;
	line-height: 18px;
}
.f_header .p_gnavi li:nth-child(2) .p_title {
	margin: 0 -8px;
}
.f_header .p_gnavi .p_lower {
	display: none;
	position: absolute;
	top: 70px;
	left: 0;
	right: 0;
	background-color: rgba(34,67,156,0.9);
	text-align: center;
}
.f_header .p_gnavi .p_lower ul {
	max-width: 1016px;
	margin: 0 auto;
	padding: 10px 10px 0;
}
.f_header .p_gnavi .p_lower li {
	display: inline-block;
	vertical-align: top;
	text-align: left;
	color: #fff;
	font-size: 107.1%;
}
.f_header .p_gnavi .p_lower.s_challenge li {
	width: 23.62%;
	padding: 2% 0.69%;
}
.f_header .p_gnavi .p_lower.s_philosophy li {
	width: 31.5%;
	padding: 2% 0.91% 3%;
}
.f_header .p_gnavi .p_lower li.s_text {
	display: none;
}
.f_header .p_gnavi .p_lower a {
	display: block;
	transition: opacity 0.3s;
}
.f_header .p_gnavi .p_lower .p_img {
	position: relative;
	margin-bottom: 10px;
}
.f_header .p_gnavi .p_lower .p_img .on {
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	transition: opacity 0.3s;
}
.f_header .p_gnavi .p_lower.s_challenge a:hover .on {
	opacity: 1;
}
.f_header .p_gnavi .p_lower .p_num {
	display: none;
}
.f_header .p_language {
	position: relative;
	float: left;
	width: 150px;
}
.f_header .p_language .p_menu {
	text-align: center;
	padding: 26px 0;
}
.f_header .p_language .p_menu span {
	position: relative;
	padding-left: 15px;
	line-height: 18px;
	cursor: pointer;
}
.f_header .p_language .p_menu span:before {
	content: "";
	position: absolute;
	top: 5px;
	left: 0;
	width: 4px;
	height: 4px;
	border-left: 2px solid #22439c;
	border-bottom: 2px solid #22439c;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.f_header .p_language ul {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	background-color: #fff;
	padding: 5px 10px 15px 26px;
	display: none;
}
.f_header .p_language ul.s_show {
	display: block;
}
.f_header .p_language li {
	margin-bottom: 12px;
}
.f_header .p_language li a {
	position: relative;
	padding-left: 13px;
}
.f_header .p_language li a:before {
	content: "";
	position: absolute;
	top: 5px;
	left: 0;
	width: 4px;
	height: 4px;
	border-right: 2px solid #22439c;
	border-bottom: 2px solid #22439c;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.f_header .p_spClose {
	display: none;
}
@media screen and (max-width: 1200px){
	.f_header .p_gnavi > ul > li > a {
		padding: 18px 20px 9px;
	}
	.f_header .p_gnavi a.s_current:after {
		left: 20px;
		right: 20px;
	}
	.f_header .p_language {
		width: 130px;
	}
	.f_header .p_language ul {
		padding: 5px 5px 8px 16px;
	}
}
@media screen and (max-width: 1000px){
	.f_header .p_gnavi > ul > li > a {
		padding: 18px 16px 9px;
	}
	.f_header .p_gnavi a.s_current:after {
		left: 17px;
		right: 17px;
	}
	.f_header .p_gnavi .p_english {
		font-size: 16px;
	}
	.f_header .p_gnavi .p_title {
		font-size: 11px;
	}
	.f_header .p_language {
		width: 115px;
	}
	.f_header .p_language .p_menu {
		font-size: 12px;
	}
	.f_header .p_language .p_menu span:before {
		top: 3px;
	}
	.f_header .p_language ul {
		padding: 5px 5px 8px 15px;
	}
	.f_header .p_language li {
		font-size: 12px;
	}
}
@media screen and (max-width: 900px){
	.f_header .p_logo a {
		padding: 25px 20px 24px 20px;
	}
	.f_header .p_gnavi > ul > li > a {
		padding: 18px 12px 9px;
	}
	.f_header .p_language {
		width: 100px;
	}
	.f_header .p_language ul {
		padding: 5px 3px 8px 10px;
	}
}
@media screen and (max-width: 800px){
	.f_header {
		height: 45px;
		overflow: visible;
	}
	.f_header .p_logo a {
		padding: 14px 12px 13px 10px;
		width: 63px;
	}
	.f_header .p_backLink {
		margin-top: 13px;
	}
	.f_header .p_backLink a {
		font-size: 11px;
	}
	.f_header .p_menuBtn {
		position: relative;
		display: block;
		float: right;
		width: 45px;
		height: 45px;
		cursor: pointer;
	}
	.f_header .p_menuBtn::before,
	.f_header .p_menuBtn::after {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		width: 24px;
		height: 3px;
		margin: auto;
		background-color: #22439c;
		transition: all 0.2s;
	}
	.f_header .p_menuBtn::before {
		bottom: 12px;
		box-shadow: 0 6px 0 #22439c;
	}
	.f_header .p_menuBtn::after {
		top: 12px;
	}
	.f_header .p_menuBtn.s_close::before {
		bottom: 0;
		box-shadow: none;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	.f_header .p_menuBtn.s_close::after {
		top: 0;
		-webkit-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}
	.f_header .p_gnavi {
		float: none;
		position: fixed;
		top: 45px;
		left: 0;
		right: 0;
		bottom: 0;
		display: none;
		overflow-y: auto;
	}
	.f_header .p_gnavi a:hover {
		opacity: 1;
	}
	.f_header .p_gnavi > ul {
		float: none;
	}
	.f_header .p_gnavi > ul > li {
		float: none;
	}
	.f_header .p_gnavi > ul > li > a {
		position: relative;
		padding: 15px 25px 15px 10px;
		background-color: rgba(30,52,154,0.9);
		border-bottom: 1px solid #5261a7;
		text-align: left;
	}
	.f_header .p_gnavi a:before {
		content: "";
		position: absolute;
		top: 50%;
		right: 14px;
		width: 9px;
		height: 9px;
		border-top: 2px solid #fff;
		border-right: 2px solid #fff;
		-webkit-transform-origin: right top;
		transform-origin: right top;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	.f_header .p_gnavi a.s_hasLower:before {
		content: "＋";
		position: absolute;
		top: 0;
		right: 10px;
		bottom: 0;
		width: 16px;
		height: 16px;
		margin: auto 0;
		border: 1px solid #fff;
		text-align: center;
		color: #fff;
		font-size: 12px;
		line-height: 16px;
		-webkit-transform: rotate(0);
		transform: rotate(0);
	}
	.f_header .p_gnavi a.s_hasLower.s_open:before {
		content: "－";
	}
	.f_header .p_gnavi a.s_current:after {
		display: none;
	}
	.f_header .p_gnavi .p_english {
		color: #fff;
		font-size: 17px;
		line-height: 1.5;
	}
	.f_header .p_gnavi .p_title {
		color: #fff;
		font-size: 8px;
		line-height: 1.5;
	}
	.f_header .p_gnavi li:nth-child(2) .p_title {
		margin: 0;
	}
	.f_header .p_gnavi .p_lower {
		position: static;
		background-color: rgba(54,75,171,0.9);
	}
	.f_header .p_gnavi .p_lower ul {
		padding: 0;
	}
	.f_header .p_gnavi .p_lower li {
		display: block;
		border-bottom: 1px solid #5261a7;
		font-size: 100%;
	}
	.f_header .p_gnavi .p_lower.s_challenge li,
	.f_header .p_gnavi .p_lower.s_philosophy li {
		width: auto;
		padding: 0;
	}
	.f_header .p_gnavi .p_lower li.s_comingsoon {
		display: none;
	}
	.f_header .p_gnavi .p_lower li.s_text {
		display: block;
		padding: 10px;
		color: #fff;
		font-size: 12px;
	}
	.f_header .p_gnavi .p_lower a {
		position: relative;
		display: block;
		padding: 15px 25px 15px 10px;
	}
	.f_header .p_gnavi .p_lower .p_img {
		display: none;
	}
	.f_header .p_gnavi .p_lower .p_num {
		display: inline;
	}
	.f_header .p_language {
		float: none;
		width: auto;
	}
	.f_header .p_language .p_menu {
		display: none;
	}
	.f_header .p_language ul {
		display: block;
		position: static;
		background-color: rgba(30,52,154,0.9);
		padding: 18px 0 10px;
		text-align: center;
	}
	.f_header .p_language li {
		display: inline-block;
		border-left: 1px solid #fff;
		margin-bottom: 0;
		font-size: 14px;
	}
	.f_header .p_language li:first-child {
		border-left: none;
	}
	.f_header .p_language li a {
		display: block;
		padding: 0 10px;
		color: #fff;
	}
	.f_header .p_language li a:before {
		display: none;
	}
	.f_header .p_spClose {
		display: block;
		position: relative;
		padding: 34px 0 8px;
		background-color: rgba(30,52,154,0.9);
		text-align: center;
		color: #fff;
		font-size: 9px;
		font-weight: bold;
	}
	.f_header .p_spClose:before,
	.f_header .p_spClose:after {
		content: "";
		position: absolute;
		top: 16px;
		left: 0;
		right: 0;
		width: 24px;
		height: 3px;
		margin: 0 auto;
		background-color: #fff;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	.f_header .p_spClose:after {
		-webkit-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}
}
@media screen and (min-width: 801px){
	.f_header .p_gnavi {
		display: block !important;
	}
}
@media screen and (max-width: 500px){
	.f_pageArea {
		min-height: 540px;
	}
}

.f_footer {
	background-color: #000;
	padding: 15px 30px;
	color: #fff;
	font-size: 85.7%;
}
.f_footer.s_fix {
	position: fixed;
	left: 30px;
	bottom: 30px;
	z-index: 1000;
	background-color: transparent;
	padding: 0;
	color: #ccc;
	font-size: 85.7%;
}
.f_footer .p_note {
	margin-bottom: 10px;
	text-align: left;
	font-size: 91.7%;
}
@media screen and (max-width: 1000px){
	.f_footer.s_fix.s_challenge {
		position: relative;
		left: 0;
		bottom: 0;
		background-color: #000;
		padding: 10px 150px 10px 0;
		text-align: center;
		color: #fff;
		font-size: 10px;
	}
}
@media screen and (max-width: 800px){
	.f_footer {
		padding: 10px;
		text-align: center;
		font-size: 10px;
	}
	.f_footer.s_fix {
		left: 10px;
		bottom: 10px;
	}
}
@media screen and (max-width: 600px){
	.f_footer.s_fix.s_challenge {
		padding: 10px 0;
	}
}

.f_modal {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 3000;
	background-color: rgba(0,0,0,0.7);
	display: none;
}
.f_modal .p_window {
	position: absolute;
	background-color: #fff;
}
.f_modal iframe {
	border: none;
	width: 100%;
	height: 100%;
}
.f_modal .p_closeBtn {
	position: absolute;
	top: 10px;
	right: 10px;
	z-index: 10;
	width: 50px;
	height: 50px;
	cursor: pointer;
}
.f_modal .p_closeBtn:before,
.f_modal .p_closeBtn:after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 40px;
	height: 5px;
	background-color: #fff;
	margin: auto;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.f_modal .p_closeBtn:after {
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}


.m_scroll {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 15px;
	z-index: 1000;
	width: 40px;
	margin: 0 auto;
}
.m_scroll.s_top {
}
.m_scroll.s_challenge {
	right: 150px;
	display: none;
}
body.s_tap .m_scroll > img {
	opacity: 0;
}
.m_scroll .p_prev {
	position: relative;
	animation: scrollPrev 1s infinite;
	cursor: pointer;
}
@keyframes scrollPrev {
	0% { top: 0; }
	50% { top: -5px; }
	100% { top: 0; }
}
.m_scroll .p_next {
	position: relative;
	animation: scrollNext 1s infinite;
	cursor: pointer;
}
@keyframes scrollNext {
	0% { top: 0; }
	50% { top: 5px; }
	100% { top: 0; }
}
.m_scroll .p_prev.s_hide,
.m_scroll .p_next.s_hide {
	visibility: hidden;
}
@media screen and (max-width: 800px){
	.m_scroll.s_top {
		bottom: -15px;
	}
	.m_scroll.s_top > img {
		display: none;
	}
	.m_scroll.s_ambition {
		display: none;
	}
}


