/*
Theme Name:original
Author:SolabotSchool
Version:1.00
*/

/*全体設定*/
/*ヘッダー*/
/*フッター*/
/*トップページ*/

/*メディアクエリ・ブレイクポイント*/

/*-----------------------------------------------全体設定-----------------------------------------------*/
/* reset */
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td{margin:0;padding:0;}
address,caption,cite,code,dfn,em,strong,th,var{font-style:normal;}
ul{list-style:none;}
table{border-collapse:collapse;border-spacing:0;}
caption,th{text-align:left;}
q:before,q:after{content:'';}
object,embed{vertical-align:top;}
legend{display:none;}
h1,h2,h3,h4,h5,h6{font-size:100%;}
img,abbr,acronym,fieldset{border:0;}

img {
	display: block;
    width: 100%;
    height: auto;
}

/*全体幅*/
*, *:before, *:after { box-sizing: border-box;}

/*フォント*/
@font-face {
	font-family: "NotoSansJP-Regular";
	src: url("/wp-content/themes/original/fonts/NotoSansJP-Regular.woff") format("woff");
	font-display: swap;
}
@font-face {
	font-family: "NotoSansJP-Medium";
	src: url("/wp-content/themes/original/fonts/NotoSansJP-Medium.woff") format("woff");
	font-display: swap;
}
@font-face {
	font-family: "NotoSansJP-Bold";
	src: url("/wp-content/themes/original/fonts/NotoSansJP-Bold.woff") format("woff");
	font-display: swap;
}

div,a,p,span {
	font-family: "NotoSansJP-Regular";
}
h1,h2,h3,h4,h5 {
	font-family: "NotoSansJP-Bold";
}

/*-----------------------------------------------ヘッダー-----------------------------------------------*/
.main-header-content {
  display: flex;
  justify-content: space-between;
  padding-right: 1vw;
}
.site-branding {
  display: flex;
  align-items: center;
}
.site-logo {
  width: 6vw;
}
.site-title a {
  font-size: 1vw;
  color: #000;
  text-decoration: none;
}
.site-title {
  margin-left: 1vw;
}
.header_nav {
  margin-left: auto;
  margin-right: 1vw;
}
.header_nav_container {
  display: flex;
  height: 100%;
}
.nav_item {
  margin-right: 1vw;
}

/* Drawer Button */
.drawer-hamburger {
	background-color: transparent;
	box-sizing: content-box;
	display: block;
	margin-right: -5px;
	outline: 0;
	padding: 12px 5px;
	transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
	width: 21px;
	min-width: 21px;
	z-index: 102;
	border: 0;
}
.drawer-hamburger:hover,
.drawer-hamburger:focus {
	background-color: transparent;
}
.drawer-hamburger-icon {
	position: relative;
	display: block;
}
.drawer-hamburger-icon,
.drawer-hamburger-icon:before,
.drawer-hamburger-icon:after {
	background-color: #111;
	height: 2px;
	transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
	width: 100%;
}
.drawer-hamburger-icon:before,
.drawer-hamburger-icon:after {
	position: absolute;
	left: 0;
	content: ' ';
}
.drawer-hamburger-icon:before {
	top: -6px;
}
.drawer-hamburger-icon:after {
	top: 6px;
}
.drawer-opened .drawer-hamburger-icon {
	background-color: transparent;
}
.drawer-opened .drawer-hamburger-icon:before,
.drawer-opened .drawer-hamburger-icon:after {
	top: 0;
}
.drawer-opened .drawer-hamburger-icon:before {
	transform: rotate(45deg);
}
.drawer-opened .drawer-hamburger-icon:after {
	transform: rotate(-45deg);
}

/* Drawer Navigation */
.drawer-overlay {
	display: none;
	height: 100vh;
	left: 0;
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 100;
}
.drawer-navigation {
	background: #fff;
	height: 100vh;
	overflow-y: auto;
	position: fixed;
	right: 0;
	top: 0;
	transform: translateX(100%);
	transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
	width: 90%;
	z-index: 101;
	-webkit-overflow-scrolling: touch;
}
.drawer-navigation-content {
	box-sizing: border-box;
	height: 100%;
	overflow-y: auto;
	padding: 60px 75px 60px 40px;
	width: 100%;
}
.drawer-opened .drawer-overlay {
	display: block;
}
.drawer-opened .drawer-navigation {
	box-shadow: 0 0 90px rgba(0, 0, 0, 0.2);
	transform: translateX(0);
}

/*ドロワーオープン時スクロール禁止*/
html.overflow_hidden {
  overflow: hidden;
}

/*-----------------------------------------------フッター-----------------------------------------------*/
.footer_contents {
  background: #333;
  color: #fff;
  padding: 2vw 0;
  text-align: center;
}

/*下部問い合わせ*/
.bottom_contact {
  margin: 3vw auto;
  width: 60%;
  background: #3f3f3f;
  text-align: center;
  border-radius: 0.3vw;
  padding: 6vw 0;
  color: #fff;
}
.bottom_contact_title {
  font-size: 2.8vw;
  margin-bottom: 2vw;
}
.bottom_contact_caption {
  font-size: 1vw;
  margin-bottom: 3vw;
}
.bottom_contact_button a {
  color: #fff;
  text-decoration: none;
  font-size: 1.2vw;
  background: #518fdf;
  border-radius: 2vw;
  display: inline-block;
  padding: 0.4vw 2vw;
}

/*-----------------------------------------------トップページ-----------------------------------------------*/
.slide_fv .slide_image_wrap {
  position: relative;
}
.slide_fv .slide_image_wrap:before {
  content: "";
  display: block;
  padding-top: 36%;
}
.slide_fv .slide_image_wrap img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/*ABOUT*/
.about_container {
  padding: 3vw;
}
.home_h2 {
  text-align: center;
  font-size: 3vw;
  margin-bottom: 3vw;
}
.about_contents {
  display: flex;
}
.about_text {
  width: 50%;
  font-size: 2.4vw;
  display: flex;
  justify-content: center;
  align-items: center;
  line-height: 1.8;
}
.about_image {
  width: 50%;
}


/*-------------------------------------メディアクエリ750以下【SPのみ】-------------------------------------*/
@media only screen and (max-width: 750px) {
	.pc_only {
		display: none !important;
	}
	/*ヘッダー*/
	.header_nav {
		display: none;
	}
	.site-logo {
		width: 16vw;
	}
	.site-title {
		margin-left: 3vw;
	}
	.site-title a {
		font-size: 4vw;
	}
	.main-header-content {
		padding-right: 3vw;
	}
	/*トップページ*/
	.slide_fv .slide_image_wrap::before {
		padding-top: 100%;
	}
	.about_container {
		padding: 12vw 6vw;
	}
	.home_h2 {
		font-size: 6vw;
	}
	.about_contents {
		flex-direction: column-reverse;
	}
	.about_text {
		width: 100%;
		font-size: 4vw;
	}
	.about_image {
		width: 100%;
		margin-bottom: 3vw;
	}
	/*下部問い合わせ*/
	.bottom_contact {
		width: 88vw;
		margin: 6vw auto;
	}
	.bottom_contact_title {
		font-size: 5vw;
		margin-bottom: 3vw;
	}
	.bottom_contact_caption {
		font-size: 2.8vw;
		width: 64%;
		margin: 0 auto 6vw;
	}
	.bottom_contact_button a {
		font-size: 3.8vw;
		padding: 3vw 6vw;
		border-radius: 6vw;
	}
	/*フッター*/
	.footer_contents {
		font-size: 3vw;
	}
}
/*--------------------------------メディアクエリ750以上【タブレット以上】---------------------------------*/
@media only screen and (min-width: 751px) {
	.sp_only {
		display: none !important;
	}
	/*ドロワーメニュー非表示*/
	.drawer-hamburger, .drawer-overlay, .drawer-navigation {
		display: none;
	}
}