@charset "utf-8";

:root {
	
}

/* モバイル　ALL */
@media screen and (max-width: 425px) {
	:root {

		--padding: var(--Size_12);

		/* セクション */
		--SectionContents_margin: var(--Size_36) 0 0;
		--SectionContents_padding: var(--Size_24) var(--padding);

		/* メインイメージ */
		--MainImage_height: 30vh;
		--MainImage_Img_width: var(--Size_60);
		--MainImage_Div_padding: 0 var(--padding);

		/* Flex 制御*/
		--Flex-direction_CRRRRR: column;
		--Flex-direction_CCRRRR: column;
		--Flex-direction_CCCRRR: column;
	}
}

/* タブレット */
@media screen and (min-width:426px) and (max-width: 768px) {
	:root {

		--padding: var(--Size_12);

		/* セクション */
		--SectionContents_margin: var(--Size_36) 0 0;
		--SectionContents_padding: var(--Size_24) var(--padding);

		/* メインイメージ */
		--MainImage_height: 30vh;
		--MainImage_Img_width: var(--Size_140);
		--MainImage_Div_padding: 0 var(--padding);

		/* Flex 制御*/
		--Flex-direction_CRRRRR: row;
		--Flex-direction_CCRRRR: column;
		--Flex-direction_CCCRRR: column;
	}
}

/* ノートパソコン */
@media screen and (min-width:769px) and ( max-width:1024px) {
	:root {

		--padding: var(--Size_12);

		/* セクション */
		--SectionContents_margin: var(--Size_36) 0 0;
		--SectionContents_padding: var(--Size_36) var(--padding);

		/* メインイメージ */
		--MainImage_height: 240px;
		--MainImage_Img_width: var(--Size_140);
		--MainImage_Div_padding: 0 var(--padding);

		/* Flex 制御*/
		--Flex-direction_CRRRRR: row;
		--Flex-direction_CCRRRR: row;
		--Flex-direction_CCCRRR: column;
	}
}

/* ノートパソコン L */
@media screen and (min-width:1025px) and ( max-width:1440px) {
	:root {

		--padding: calc( calc( 100% - 1024px) / 2);

		/* セクション */
		--SectionContents_margin: var(--Size_36) 0 0;
		--SectionContents_padding: var(--Size_36) var(--padding);

		/* メインイメージ */
		--MainImage_height: 240px;
		--MainImage_Img_width: var(--Size_140);
		--MainImage_Div_padding: 0 var(--padding);

		/* Flex 制御*/
		--Flex-direction_CRRRRR: row;
		--Flex-direction_CCRRRR: row;
		--Flex-direction_CCCRRR: row;
	}
}

/* 2K以上 */
@media screen and (min-width:1441px) and ( max-width:2560px) {
	:root {

		--padding: calc( calc( 100% - 1024px) / 2);

		/* セクション */
		--SectionContents_margin: var(--Size_36) 0 0;
		--SectionContents_padding: var(--Size_36) var(--padding);

		/* メインイメージ */
		--MainImage_height: 240px;
		--MainImage_Img_width: var(--Size_140);
		--MainImage_Div_padding: 0 var(--padding);

		/* Flex 制御*/
		--Flex-direction_CRRRRR: row;
		--Flex-direction_CCRRRR: row;
		--Flex-direction_CCCRRR: row;
	}
}

/* 4K以上 */
@media screen and (min-width:2561px) {
	:root {

		--padding: calc( calc( 100% - 1024px) / 2);

		/* セクション */
		--SectionContents_margin: var(--Size_36) 0 0;
		--SectionContents_padding: var(--Size_36) var(--padding);

		/* メインイメージ */
		--MainImage_height: 240px;
		--MainImage_Img_width: var(--Size_140);
		--MainImage_Div_padding: 0 var(--padding);

		/* Flex 制御*/
		--Flex-direction_CRRRRR: row;
		--Flex-direction_CCRRRR: row;
		--Flex-direction_CCCRRR: row;
	}
}




/* Set */

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, 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 {
	position: relative;
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 62.5%;
	font: inherit;
	vertical-align: baseline;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
}

*,
*:before,
*:after {
	box-sizing: inherit;
}

html {
	max-width: 100%;
	background: #fafafa;
	background: #fdfcf7;
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}

body {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	animation: fadeIn 1s ease 0s 1 normal;
	-webkit-animation: fadeIn 1s ease 0s 1 normal;
}

header, article, section, div, footer,
table, tr, th, td, ol, ul, li, dl, dt, dd,
h1, h2, h3, h4, h5, h6, p, span, b, i, a {
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}

body.jp {
	font-family: "Noto Sans JP", sans-serif !important;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
}

body.en {
	font-family: "Noto Sans", sans-serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	font-variation-settings:
    "wdth" 100;
}

body.ko {
	font-family: "Noto Sans KR", sans-serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
}

body.ct {
	font-family: "Noto Sans TC", sans-serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
}

body.cs {
	font-family: "Noto Sans SC", sans-serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
}

@keyframes fadeIn         { 0% { opacity: 0 } 100% { opacity: 1 } }
@-webkit-keyframes fadeIn { 0% { opacity: 0 } 100% { opacity: 1 } }

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
	content: '';
	content: none;
}

p, ol, ul, dl {
	color: var(--Color_1D100);
	line-height: 1.6;
}

ol, ul {
	list-style: none;
}

p, ol li, ul li, dl dt, dl dd {
	font-size: var(--Size_10);
}

span {
	font-size: var(--Size_08);
}

a {
	color: var(--Color_1D100);
	text-decoration: none;
	border: 0;
	transition: var(--Transition_04s);
	-o-transition: var(--Transition_04s);
	-moz-transition: var(--Transition_04s);
	-webkit-transition: var(--Transition_04s);
}

a:hover {
	
}

span.none {
	display: none;
}

figure {
	margin: 0;
}

img {
	max-width: 100%;
	vertical-align: bottom;
	object-fit: cover;
}

.ihub {
	font-family: "nasalization", sans-serif;
	font-weight: 400;
	font-style: normal;
}






/* ーーーーーーーーーーーーーーーーーーーー
   H
ーーーーーーーーーーーーーーーーーーーー */

h1,h2,h3,h4,h5 {
	color: var(--Color_1D100);
	line-height: 1;
	font-weight: 200;
}

h2 {
	display: flex;
	justify-content: center;
	margin: 0 0 var(--Size_24);
	font-size: var(--Size_10);
}

h3 {
	margin: 0 0 var(--Size_24);
	padding: var(--Size_10) 0;
	font-size: var(--Size_10);
	border-bottom:  1px var(--Color_A020) solid;
}

h4 {
	display: inline-block;
	margin: var(--Size_12) 0 var(--Size_12);
	padding: var(--Size_04) var(--Size_10);
	font-size: var(--Size_12);
	background: -webkit-linear-gradient(0deg, var(--Color_A100), var(--Color_FF100));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}

#cave h4 {
	background: -webkit-linear-gradient(0deg, var(--Color_CV100), var(--Color_FF100));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}

#cavex h4 {
	background: -webkit-linear-gradient(0deg, var(--Color_CX100), var(--Color_FF100));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}

h4:before, h4:after { 
	position: absolute;
	box-sizing: border-box;
	top: 0;
	content:'';
	width: var(--Size_06);
	height: 100%;
	display: inline-block;
	border-top: 1px var(--Color_A100) solid;
	border-bottom: 1px var(--Color_A100) solid;
}

#cave h4:before, #cave h4:after { 
	border-top: 1px var(--Color_CV100) solid;
	border-bottom: 1px var(--Color_CV100) solid;
}

#cavex h4:before, #cavex h4:after { 
	border-top: 1px var(--Color_CX100) solid;
	border-bottom: 1px var(--Color_CX100) solid;
}

h4:before {
	left: 0;
	border-left: 1px var(--Color_A100) solid;
}

#cave h4:before {
	left: 0;
	border-left: 1px var(--Color_CV100) solid;
}

#cavex h4:before {
	left: 0;
	border-left: 1px var(--Color_CX100) solid;
}

h4:after {
	right: 0;
	border-right: 1px var(--Color_A100) solid;
}

#cave h4:after {
	right: 0;
	border-right: 1px var(--Color_CV100) solid;
}

#cavex h4:after {
	right: 0;
	border-right: 1px var(--Color_CX100) solid;
}

h4 span {
	padding: 0 0 0 var(--Size_06);
	font-size: var(--Size_08);
	color: var(--Color_D060);
}

h4 strong {
	padding: 0 0 0 var(--Size_06);
	font-size: var(--Size_08);
	color: var(--Color_D060);
}

h5 {
	margin: 1em 0 .5em;
	padding: .5em .5em;
	color: rgba(255,255,255,1);
	font-size: 1em;
	font-weight: 600;
	line-height: 1.4;
	border-bottom: 1px #EC6C00 solid;
}








/* ーーーーーーーーーーーーーーーーーーーー
   アーティクル
ーーーーーーーーーーーーーーーーーーーー */

article {
	flex: 1;
	position: relative;
	display: flex;
	flex-direction: column;
	max-width: 100%;
}








/* ーーーーーーーーーーーーーーーーーーーー
   コンテンツ
ーーーーーーーーーーーーーーーーーーーー */

section#contents {
	flex: 1;
	position: relative;
	display: flex;
	flex-direction: column;
	margin: var(--SectionContents_margin);
	overflow: hidden;
	& .wrap {
		flex: 1;
		margin: 0;
		padding: var(--SectionContents_padding);
		border-bottom: 1px var(--Color_1D020) solid;
	}
}

section#contents > p {
	margin: 0;
	padding: 0 0 var(--Size_36);
	color: var(--Color_FF100);
	font-size: var(--Size_10);
	line-height: 1.6;
	font-weight: 400;
}

section#contents > p a {
	display: flex;
	align-items: center;
	gap: var(--Size_02);
}

section#contents > p a i {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: var(--Size_02);
	width: var(--Size_22);
	background: var(--Color_A100);
	border-radius: var(--Border-radius_L);
	transition: var(--Transition_04s);
	-o-transition: var(--Transition_04s);
	-moz-transition: var(--Transition_04s);
	-webkit-transition: var(--Transition_04s);
}

#cave section#contents > p a i {
	background: var(--Color_CV100);
}

#cavex section#contents > p a i {
	background: var(--Color_CX100);
}

section#contents > p a:hover {
	display: flex;
	align-items: center;
	gap: var(--Size_02);
}

.margin_S {
	margin: 0 0 var(--Size_12);
}

.margin_M {
	margin: 0 0 var(--Size_24);
}

.margin_L {
	margin: 0 0 var(--Size_36);
}








/* ーーーーーーーーーーーーーーーーーーーー
   テキスト装飾
ーーーーーーーーーーーーーーーーーーーー */

section#contents > p strong {
	margin: 0 var(--Size_02);
	padding: 0 var(--Size_03) var(--Size_01) var(--Size_03);
	color: var(--Color_A100);
	line-height: 1;
	font-weight: 600;
	border-radius: var(--Border-radius_S);
}











/* ーーーーーーーーーーーーーーーーーーーー
  ボタン 
ーーーーーーーーーーーーーーーーーーーー */

div.btn {
	display: flex;
	justify-content: center;
	margin: var(--Size_12) 0;
}

div.btn a {
	display: inline-flex;
	padding: 0;
	border-radius: var(--Border-radius_S);
}

div.btn a:hover {
	background: var(--Color_A100);
}

div.btn a strong {
	padding: var(--Size_08) var(--Size_12);
	background: var(--Color_A100);
	border: var(--Border_A060);
	border-radius: var(--Border-radius_S);
	transition: var(--Transition_04s);
	-o-transition: var(--Transition_04s);
	-moz-transition: var(--Transition_04s);
	-webkit-transition: var(--Transition_04s);
}

div.btn a:hover strong {
	background: var(--Color_1D100);
}



