/*
Template: arkhe
Theme Name: Arkhe_child
Version: 1.0.0
*/

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200..900&display=swap');

/* font-family:"Noto Sans JP", sans-serif; */
/* font-family:"Noto Serif JP", serif; */


:root {
	--ark-font_family:"Noto Sans JP","Helvetica Neue","Arial","Hiragino Kaku Gothic ProN","Hiragino Sans","Meiryo",sans-serif;
}

/*
	--wp--preset--color--arkb-color-main-01
*/


/*******************************
/* Arkhe［ユーティリティクラス］
 * 詳しくは、src/scss/object/utility/**
*******************************/

/*

・「u-only-pc」というクラスをつけるとPCサイズでのみ表示されるようになったり
・「u-fz-l」を付けるとフォントサイズが大きくなったり
・「u-mt-0」を付けると上部マージンが 0 になったり

u-mt-0	(0,5,10,15,20,25,30,40,50,60,80)
u-mb-0	(0,5,10,15,20,25,30,40,50,60,80)


*/


/*******************************
/* 
*******************************/
h1, h2, h3, h4, h5, h6{
	line-height:inherit;
}

.l-content__body{
	margin-bottom:0;
}

/*******************************
/* header
*******************************/

#header .l-header__body.l-container{
	max-width:none;
}

/*
#header .c-gnav a{
	transition:opacity 0.3s;
}
#header .c-gnav a:hover{
	color:#fff;
	opacity:0.6;
}
html[data-scrolled=true] #header .c-gnav a:hover{
	color:#fff;
}
*/

.c-gnav__li.-current,
.c-gnav__li.focus,
.c-gnav__li:hover{
	color:#fff;
}
.c-gnav__li a.c-gnav__a[aria-current="page"]{
	text-decoration:underline;
}
#header .c-gnav a:hover,
html[data-scrolled=true] #header .c-gnav a:hover{
	color:#fff;
}


.l-header__logo.has-image{}
.l-header__logo.has-image a{
	display:flex;
	align-items:center;
}
.l-header__logo.has-image a::after{
	content:"アドミテッドジャパン株式会社";
	font-size:0.9rem;
	font-weight:500;
	margin-left:1.5rem;
}
@media screen and (max-width: 767px){
/* mobile -------------------------------------------------------------------------------------------- */
	.l-header__logo.has-image a::after{
		content:none;
	}
}


/*******************************
/* footer
*******************************/

.l-footer__nav a{
	padding:0.4em 0.5em;
}
.l-footer__foot{
	padding:2.5rem 0 1.5rem 0;
}
.l-footer__inner .l-footer__widgets ~ .l-footer__foot{
	padding-top:0;
}
.l-footer__foot p.c-copyright{
	margin-top:4em;
}


/*******************************
/* Arkhe［ブロック］：セクション見出し
 * ark-block-heading
*******************************/

.ark-block-heading{
	padding:1.0em 0 1.0em 0;
}
.ark-block-heading .ark-block-heading__main{
	font-family:"Noto Serif JP", serif;
	font-size:2.2rem;
	font-weight:600;
	line-height:1.8;
}
.ark-block-heading .ark-block-heading__sub{
	color:var(--wp--preset--color--arkb-color-main-02);
	font-family:"Noto Serif JP", serif;
	font-size:1.4rem;
	font-weight:600;
	line-height:inherit;
	margin-bottom:0.5em;
}
.ark-block-heading .ark-block-heading__line::before{
	background-color:var(--wp--preset--color--arkb-color-main-02);
	border-radius:0;
	opacity:0.65;
}
.ark-block-heading[data-sub=top] .ark-block-heading__line{
	margin-top:1.5em;
}
.ark-block-heading[data-sub=bottom] .ark-block-heading__line{
	margin:1.2em 0 1.2em 0;
}
@media screen and (max-width: 767px){
/* mobile -------------------------------------------------------------------------------------------- */
	.ark-block-heading .ark-block-heading__main{
		font-size:1.25rem;
	}
	.ark-block-heading .ark-block-heading__sub{
		font-size:1.15rem;
	}
	.ark-block-heading ~ p.has-text-align-center{
		text-align:left;
	}
	.ark-block-heading ~ p.has-text-align-center br{
		display:none;
	}
}


/*******************************
/* Arkhe［ブロック］：アコーディオン
 * ark-block-accordion
*******************************/

.ark-block-accordion.is-style-box .ark-block-accordion__body{
	border-top-style:solid;
}


/*******************************
/* hero
*******************************/

#hero,
#hero > div.hero_visual .swiper-slide img{
	width:100%;
	height:100vh;
	min-height:690px;
}
#hero{
	position:relative;
	width:100%;
	overflow:hidden;
}
#hero > div.hero_caption{
	position:absolute;
	top:0;
	bottom:0;
	left:0;
	right:0;
	z-index:10;
	display:flex;
	align-items:center;
	width:100%;
}
#hero > div.hero_caption > div{
	text-align:left;
	padding-left:clamp(100px, 15%, 20%);
}
#hero > div.hero_caption div.primary{
	margin-bottom:1.5em;
}
#hero > div.hero_caption div.primary h2{
	color:#fff;
	font-size:65px;
	font-size:clamp(55px, 5vw, 75px);
	font-weight:600;
	line-height:1.55;
}
#hero > div.hero_caption div.primary h2 > span{
	display:block;
}
#hero > div.hero_caption div.secondary{
	padding-bottom:3.5em;
}
#hero > div.hero_caption div.secondary p{
	color:#fff;
	font-size:20px;
	font-size:clamp(16px, 1.5vw, 22px);
	font-weight:400;
	line-height:2;
}
#hero > div.hero_caption div.mark{
	width:25em;
	width:clamp(250px, 22vw, 350px);
}
#hero > div.hero_caption div.mark img{}
#hero > div.hero_visual{
	position:relative;
}
#hero > div.hero_visual::before{
	position:absolute;
	top:0;
	bottom:0;
	left:0;
	right:0;
	z-index:5;
	width:100%;
	height:100%;
	content:'';
	background:rgba(0,0,0,0.30);
}
#hero > div.hero_visual::after{
	position:absolute;
	bottom:-5%;
	right:0;
	z-index:6;
	content:"";
	background-image:url('images/logo_mark_02.png');
	background-repeat:no-repeat;
	background-size:contain;
	background-position:bottom right;
	width:50%;
	max-width:860px;
	height:100%;
	mix-blend-mode:overlay;
	opacity:0.35;
}
#hero > div.hero_visual .swiper{}
#hero > div.hero_visual .swiper-wrapper{}
#hero > div.hero_visual .swiper-slide{}
#hero > div.hero_visual .swiper-slide img{
	object-fit:cover;
	transform:scale(1);
}
#hero > div.hero_visual .swiper-slide[class*=-active] img,
#hero > div.hero_visual .swiper-slide[class*=-prev] img,
#hero > div.hero_visual .swiper-slide[class*=-next] img{
	animation:HeroAnimation 15s linear 0s normal both;
}
@keyframes HeroAnimation{
	0%{
		transform:scale(1);
	}
	100%{
		transform:scale(1.35);
	}
}

@media screen and (max-width: 767px){
/* mobile -------------------------------------------------------------------------------------------- */
	#hero,
	#hero > div.hero_visual .swiper-slide img{
		height:50vh;
		min-height:500px;
	}
	#hero > div.hero_caption > div{
		padding:0 1.5em;
	}
	#hero > div.hero_caption div.primary{
		margin-bottom:1.5em;
	}
	#hero > div.hero_caption div.primary h2{
		font-size:clamp(30px, 8vw, 35px);
	}
	#hero > div.hero_caption div.secondary{
		padding-bottom:3.5em;
	}
	#hero > div.hero_caption div.secondary p{
		font-size:clamp(12px, 3.8vw, 15px);
		font-weight:400;
	}
	#hero > div.hero_visual::after{
		position:absolute;
		bottom:-5%;
		width:80%;
		max-width:80%;
	}
}





