@charset "utf-8";

/*
Theme Name: HOLOLINO
Description: HOLOLINO Original theme.
Theme URI: https://saitasaita.co.jp/
Author: Saita Corp.
Author URI: https://saitasaita.co.jp/
Description: Original Wordpress theme for HOLOLINO.
Version: 1.0.0
*/

@import url('https://fonts.googleapis.com/css2?family=Figtree:ital,wght@0,300..900;1,300..900&family=Oswald:wght@200..700&family=Sacramento&family=Zen+Kaku+Gothic+New:wght@400;500;700&family=Zen+Old+Mincho&display=swap');


/*

font-family: "Figtree", sans-serif;
  font-family: "Zen Old Mincho", serif;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-family: "Sacramento", serif;
  font-family: "Oswald", serif;

*/

@import url(style_contents.css);

li {
  list-style: none;
}
img {
  border: 0;
  -webkit-backface-visibility: hidden;
  width: 100%;
}
a {
color: #000;
  outline: none;
  text-decoration: none;
}
h1, h2, h3, h4, p,figure {
  margin: 0;
  padding: 0;
}
ul {
  margin: 0;
  padding: 0;
}
html {
 height:100%;
	overflow-y: scroll;
}

.orik {
  display: inline-block;
}
.clearfix:after {
  content: "";
  clear: both;
  display: block;
}
img {
  max-width: 100%;
  height: auto;
  image-rendering: -webkit-optimize-contrast;
}



body {
  margin: 0;
  padding: 0;
  color: #000;
  line-height: 160%;
  font-family: 'Zen Kaku Gothic New', "游ゴシック", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", MS UI Gothic, Osaka, sans-serif;
  font-size: 15px;
  overflow-x: hidden;
  font-smoothing: antialiased;
  -webkit-font-smoothing: antialiased;
  font-weight: 500;
	position: relative;
}

/*----------------loading------------------*/
/*--最初に出すカバー---*/


#white {
  width: 100vw;
  height: 100vh;
  background-color: #fff;
  z-index: 1000000;
  position: fixed;
  left: 0;
  top: 0;
}
#white figure{
height: 100vh;
min-height: 557px;
}

#white figure img{
height: 100%;
width: 100%;
object-fit: cover;
}
#cover {
  width: 100vw;
  height: 100vh;
/*  background-color: #fff;*/
  z-index: 100000;
  position: fixed;
  left: 0;
  top: 0;
  background-size: cover;
}
@media screen and (max-width: 870px) {
#white figure{
/*height: 80vw;*/
}
}

@media screen and (max-width: 400px) {

}
#cover.is-active {
  display: none;
}


/*----LUXYプリンタ対応----*/
#luxy {position: fixed !important;}	
@media print {
#luxy {position: static !important;}	
}


/*----Ios初期化-----*/
input, textarea {
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -webkit-appearance: none;
  max-width: 100%;
}
textarea {
height: 235px;
}
/*----tel イベント-------------*/
a.tel {
  cursor: default;
  pointer-events: none;
  text-decoration: none;
}
@media screen and (max-width: 855px) {
  a.tel {
    pointer-events: auto;
  }
}

/*-----------------------------------------------------

ヘッダー

--------------------------------------------------------*/

#header {
  width: 100%;
  box-sizing: border-box;
  margin: 0 auto;
  position: relative;
  padding: 56px 30px 0 56px;
	max-width: 1500px;
}

#header .left {
  float: left;
  padding: 0;
  letter-spacing: -0.4em;
  width: 150px;
}
#header .right {
  float: right;
  width: calc(100% - 150px - 60px);
}
/*---左側---*/
#header .left a {
  display: inline-block;
  text-decoration: none;
}
#header .left a img {
  display: inline-block;
  width: 150px;
  height: auto;
}


/*--右側---*/
#header .sns {
	text-align: right;
	padding: 15px 5px 0 0;
}

#header .sns a {
	width: 30px;
	height: auto;
	margin: 0 0 0 5px;
}

#header .sns a img {
	width: 30px;
	height: auto;
}

@media screen and (max-width: 880px) {
	
#header {
  padding: 30px 30px 0 30px;
}	
}

@media screen and (max-width: 780px) {
	
#header { border-top: 5px solid #6dc4bb;}	
#header .sns {
	position: absolute;
	right: 80px;
	top: 10px;
	}

#header .left {
 	float: none;
	text-align: center;
  	width: 100%;
}
}

@media screen and (max-width: 500px) {

#header .left {padding-top: 50px;}
	
#header .sns {
	right: inherit;
	top: 10px;
	left: 20px;
	}

}

/*---------------------------------------------
グローバルメニュー　
---------------------------------------------*/
#gmenu {
  width: auto;
  margin: 0;
  padding: 0 0 15px 0;
  clear: both;
  font-weight: 500;
border-bottom: 5px solid #6dc4bb;
}
#gmenu ul p {
  margin: 0;
  padding: 0;
}
#gmenu ul {
  width: auto;
  margin: 0 auto;
  text-align: right;
  letter-spacing: -0.4em;
  position: relative;
  float: right;
	
}
#gmenu li.mn {
  display: inline-block;
  letter-spacing: normal;
  margin: 0;
	text-align: center;
	font-size: 14px;
	transition: 0.5s;
	width: 160px;
}


#gmenu li.mn a {padding-bottom: 15px;}
#gmenu li.mn a span {
	font-family: "Oswald", serif;
	display: block;
	padding: 15px 0px;
	border-bottom: 1px solid #333;
	font-size: 26px;
	margin-bottom: 10px;
	transition: 0.5s;
}

#gmenu li.mn a:hover span {border-bottom: 1px solid #d6d6d6; }


#gmenu li.mn p a.slc span {
border-bottom: 2px solid #000;
}


#gmenu li ul li a {
  border: none;
}


@media screen and (max-width: 1100px) {
#gmenu li.mn {width: 140px;}
}

@media screen and (max-width: 1000px) {
#gmenu li.mn {width: 100px;}
#gmenu li.mn a span {font-size: 20px;}
}



/*---サブメニュースタイル--*/
#gmenu ul.sub {
  position: absolute;
  z-index: 9999;
  top: 100px;
  margin: 0;
  padding: 0;
  width: 160px;
  box-sizing: border-box;
  white-space: nowrap;
  zoom: 100%;
  background-color: #47a399;
  height: auto;
  text-align: left;
  list-style: none;
  /*box-shadow: 1px 1px 8px rgba(0, 0, 0, 0.25);*/
  font-weight: 500;
	border-radius: 5px;
}

@media screen and (max-width: 1100px) {
#gmenu ul.sub {width: 140px;}
}

@media screen and (max-width: 1000px) {
#gmenu ul.sub {display: none;}
}

@media screen and (max-width: 780px) {
	#gmenu {display: none;}	
}

#gmenu ul > li > ul.sub > li {
  overflow: hidden;
  width: 100%;
  height: 0;
  transition: .5s;
  float: left;
  padding: 0 20px;
  box-sizing: border-box;
}
#gmenu ul li ul.sub li a {
  padding: 10px;
  font-size: 18px;
  box-sizing: border-box;
  display: block;
  color: #fff;
	text-align: center;
	font-family: "Oswald", serif;
	transition: 0.5s;
}

#gmenu ul li ul.sub li a:hover {
  color: #333;
}
#gmenu > li:hover > a {
  background: none
}
#gmenu > li:hover li:hover > a img {
  transform: scale(1.1);
}
#gmenu li:hover > ul.sub > li {
  overflow: hidden;
  height: 48px;
  display: inline-block;
  letter-spacing: normal;
}


/*---------------------------------------------------------------------------
ハンバーガーメニュー

---------------------------------------------------------------------------*/
#nav-drawer { display: none;}
@media screen and (max-width: 780px) {

#nav-drawer {
  display: block;
  position: fixed;
  top: 0px;
  right: 0;
  left: calc(100% - 70px);
  z-index: 9999;
}
}
/*----------ハンバーガー-----------*/
/*Media Queries*/

@media screen and (max-width: 420px) {
  #nav-drawer {
    top: 0px;
    left: calc(100% - 70px);
  }
}
/*チェックボックス等は非表示に*/
.nav-unshown {
  display: none;
}
/*アイコンのスペース*/
#nav-open {
  display: inline-block;
  width: 70px;
  height: 70px;
  vertical-align: middle;
  box-sizing: border-box;
  line-height: 40px;
  position: absolute;
  cursor: pointer;
  z-index: 9999;
  text-align: left;
  padding: 0 0 0 15px;
  font-size: 13px;
  color: #fff;
  font-weight: 300;
	background-color: #6dc4bb;
}
#nav-open span {
  display: block;
  transition: all .2s;
  box-sizing: border-box;
}
#nav-open span {
  position: absolute;
  right: 22px;
  width: 28px;
  height: 2px;
  background-color: #fff;
}
#nav-open span:nth-of-type(1) {
  top: 23px;
}
#nav-open span:nth-of-type(2) {
  top: 33px;
}
#nav-open span:nth-of-type(3) {
  top: 43px;
}

#nav-input:checked ~ #nav-open {
  background-color: transparent;
  color: #fff;
}
#nav-input:checked ~ #nav-open span {
  background-color: #000;
}
#nav-input:checked ~ #nav-open span:nth-of-type(1) {
  -webkit-transform: translateY(11px) rotate(-45deg);
  transform: translateY(11px) rotate(-45deg);
}
#nav-input:checked ~ #nav-open span:nth-of-type(2) {
  opacity: 0;
}
#nav-input:checked ~ #nav-open span:nth-of-type(3) {
  -webkit-transform: translateY(-8.3px) rotate(45deg);
  transform: translateY(-8.3px) rotate(45deg);
}
#nav-input:checked ~ #nav-open span {
  height: 2px;
}
/*閉じる用の薄黒カバー*/
#nav-close {
  display: none; /*はじめは隠しておく*/
  position: fixed;
  z-index: 998;
  top: 0; /*全体に広がるように*/
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
}

/*中身*/
#nav-content {
  overflow: auto;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999; /*最前面に*/
  width: 100%; /*右側に隙間を作る（閉じるカバーを表示）*/
  /*max-width: 400px;最大幅（調整してください）*/
  height: 100vh;
  transition: 0.3s ease-in-out; /*滑らかに表示*/
  -webkit-transform: translateY(-105%);
  transform: translateY(-105%); /*左に隠しておく*/
  padding: 30px 20px;
  box-sizing: border-box;
  background-size: auto 50px;
  background-position: 50% 30px;
  text-align: left;
  /*background-color: rgba(0,0,0,0.6);*/
}
/*チェックが入ったらもろもろ表示*/
#nav-input:checked ~ #nav-close {
  display: block; /*カバーを表示*/
}
#nav-input:checked ~ #nav-content {
  -webkit-transform: translateY(0%);
  transform: translateY(0%);
}
#nav-input:checked ~ #nav-content {
  -webkit-animation: ham 1s;
  -o-animation: ham 1s;
  -ms-animation: ham 1s;
  -moz-animation: ham 1s;
}
@-webkit-keyframes ham {
  0% {
    -webkit-transform: translateY(-105%);
    opacity: 0;
    filter: alpha(opacity=0);
  }
  10% {
    -webkit-transform: translateY(0);
    opacity: 0;
    filter: alpha(opacity=0);
  }
  100% {
    -webkit-transform: translateY(0);
    opacity: 1.0;
    filter: alpha(opacity=100);
  }
}
@-o-keyframes ham {
  0% {
    -o-transform: translateY(-105%);
    opacity: 0;
    filter: alpha(opacity=0);
  }
  10% {
    -o-transform: translateY(0);
    opacity: 0;
    filter: alpha(opacity=0);
  }
  100% {
    -o-transform: translateY(0);
    opacity: 1.0;
    filter: alpha(opacity=100);
  }
}
@-ms-keyframes ham {
  0% {
    -ms-transform: translateY(-105%);
    opacity: 0;
    filter: alpha(opacity=0);
  }
  10% {
    -ms-transform: translateY(0);
    opacity: 0;
    filter: alpha(opacity=0);
  }
  100% {
    -ms-transform: translateY(0);
    opacity: 1.0;
    filter: alpha(opacity=100);
  }
}
@-moz-keyframes ham {
  0% {
    -moz-transform: translateY(-105%);
    opacity: 0;
    filter: alpha(opacity=0);
  }
  10% {
    -moz-transform: translateY(0);
    opacity: 0;
    filter: alpha(opacity=0);
  }
  100% {
    -moz-transform: translateY(0);
    opacity: 1.0;
    filter: alpha(opacity=100);
  }
}


/*------PC版ハンバーガーの中身----------*/
#nav-content {
 /*background: url("images/back.jpg") center top;*/
 background-color:#6dc4bb;
padding: 80px 60px 30px 60px;
}

#nav-content p {
	display: block;
	color: #fff;
	text-align: right;
	border-bottom: 1px solid #fff;
	padding: 0 0 10px 0;
	margin: 15px 0 20px 0;
}

#nav-content p a {
	display: block;
	color: #fff;
}
#nav-content p a span {
font-family: "Oswald", serif;
	float: left;
	font-size: 24px;
}

#nav-content .subm {
	padding: 0 20px 10px 20px;
}

#nav-content .subm a {
	display: block;
	color: #fff;
	font-family: "Figtree", sans-serif;
	margin: 0 0 5px 0;
	font-size: 18px;
}

@media screen and (max-width: 1200px) {
	
}


/*----------------------------------------------
トップページ
----------------------------------------------*/
#mainv {
  height: calc(100vh - 300px);
  position: relative;
	box-sizing: border-box;
	max-width: 1500px;
	margin: 20px auto;
	padding: 0;
}
#mainv .swiper-container1 {
  height: 100%;
  width: 100%;
  position: relative;
  z-index: -1;
  max-height: 100%;
}

#mainv .swiper-container1 .swiper-slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#mainv .swiper-container1 .swiper-slide img.sp {display: none;}

@media screen and (max-width: 800px) {

#mainv .swiper-container1 .swiper-slide img.pc {display: none;}
#mainv .swiper-container1 .swiper-slide img.sp {display: block;}
}

/*----------------------------------------------------
背景動画共通設定
-----------------------------------------------------*/

.video-container {
  height: 100vh;
  position: relative;
  overflow: hidden;
}
@media (max-width: 600px) {
  .video-container {
    height: 500px;
  }
}
 
video {
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  height: 100%;
  width: 100vw;
  top: 0;
  left: 0;
	z-index: -9999;
}


/*----------------------------------------------
content :　100％幅
----------------------------------------------*/
hr.grn {
	border: none;
	background-color: transparent;
	padding: 0;
	height: 0;
	border-bottom: 20px solid #6dc4bb;
	max-width: 1500px;
	margin: 0 auto;
}

.ttl {
	display: block;
	text-align: center;
	padding: 70px 0 50px 0;
}

.ttl p.sc {
	font-size: 65px;
	font-family: "Sacramento", serif;
	padding: 15px 0;
	border-bottom: 5px solid #6dc4bb;
	display: inline-block;
}

.ttl p.sc.usp {
	margin-bottom: 15px;
}

.ttl h2,
.ttl h1 {
	font-size: 18px;
	font-weight: 700;
	padding: 10px 20px;
}

.ttl h2::before,
.ttl h1::before {
	content: "- ";
}
.ttl h2::after,
.ttl h1::after {
	content: " -";
}


/*--------------------------------*/

.maincopy {
	text-align: center;
	font-family: "Zen Old Mincho", serif;
	margin-bottom: 50px;
}

.maincopy p {
	font-size: 60px;
	line-height: 140%;
	letter-spacing: 15px;
	font-weight: 600;
}	

.maincopy p b {
	color: #6dc4bb;
}


@media screen and (max-width: 1100px) {
	
.maincopy p {
	font-size: 5vw;
	line-height: 140%;
	letter-spacing: 15px;
	font-weight: 600;
}
}


@media screen and (max-width: 500px) {
	
.maincopy p {
	font-size: 7vw;
	letter-spacing: 5px;
}	

.maincopy {
	margin-bottom: 30px;
}

}





/*--------左右段組み------------------*/

.about_2dan {
	max-width: 1200px;
	margin: 0 auto 50px auto;
	display: flex;
	flex-wrap: wrap;
	flex-direction: row-reverse;
}
.about_2dan .box {
	width: 50%;
}

.about_2dan .box .txt {
	text-align: center;
	padding: 20px 30px;
	font-size: 18px;
	line-height: 200%;
}

.about_2dan .box .txt h3 {
	background-color:  #6dc4bb;
	padding: 5px;
	font-weight: normal;
	font-size: 18px;
	margin: 5px 0;
}

.about_2dan .box .txt span {display: inline-block;}

@media screen and (max-width: 800px) {
	
.about_2dan {}	
.about_2dan .box {
	width: 100%;
}
}

/*------------------------------------*/

.subcopy {
	text-align: center;
	margin-bottom: 50px;
	padding: 0 20px;
	box-sizing: border-box;
}

.subcopy p {
	font-size: 22px;
	line-height: 200%;
}

.subcopy p span {display: inline-block;}

@media screen and (max-width: 500px) {
	
.subcopy p {
	font-size: 17px;
	line-height: 200%;
}	
}


/*---------SERVICE FLOATボタン部分------------*/

.subcopy.fl {
	position: relative;
	width: calc(100% - 300px);
	margin: 0 auto;
	max-width: 1100px;
}

.subcopy.fl .float {
	position: absolute;
	width: 130px;
	height: 130px;
	border-radius: 50%;
	border: 5px solid #6dc4bb;
	right: 0;
	top: -130px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.subcopy.fl .float p {
	font-size: 17px;
	line-height: 150%;
}

@media screen and (max-width: 960px) {
	
.subcopy.fl {
	position: relative;
	width: 100%;
}
	
.subcopy.fl .float {
	position: relative;
	top: -20px;
	margin: 0 auto 15px auto;
	width: 130px;
	height: 130px;
	border-radius: 50%;
	border: 5px solid #6dc4bb;
}	
}

/*--TOP SERVICE のイメージ画像イラスト---------*/

img.tsv {
	display: block;
	width: calc(100% - 30px);
	max-width: 1000px;
	height: auto;
	margin: 0 auto 30px auto;
}


/*----Service スクロール部分--------------*/

.swiper-container2 {
    width: 100%;
    height: 100%;
}

.swiper-container2 .swiper-wrapper {
  transition-timing-function: linear;
}

.swiper-container2 .swiper-slide {
   text-align: center;
   font-size: 18px;
   background: #fff;
   width: calc(100% / 4);

        /* Center slide text vertically */
        display: -webkit-box;
        display: -ms-flexbox;
        display: -webkit-flex;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        -webkit-justify-content: center;
        justify-content: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        -webkit-align-items: center;
        align-items: center;
    }
    /*.swiper-container2 .swiper-slide:nth-child(2n) {
        width: 60%;
    }
    .swiper-container2 .swiper-slide:nth-child(3n) {
        width: 40%;
    }*/

.swiper-container2 .swiper-slide:first-child {margin-left: 30px;}

.swiper-container2 .swiper-slide img {
	width: 100%;
	height: calc(100vw / 3.5);
	object-fit: cover;
	border-radius: 15px;
}

@media screen and (max-width: 800px) {
	
.swiper-container2 .swiper-slide {
   width: calc(100% / 3);	
	}
	
.swiper-container2 .swiper-slide img {
	height: calc(100vw / 2.5);
}
}

@media screen and (max-width: 500px) {
	
.swiper-container2 .swiper-slide {
   width: calc(100% / 2);	
	}
	
.swiper-container2 .swiper-slide img {
	height: calc(100vw / 1.5);
}
}



/*----------実績3段 →　２段へ---------------*/

.jisseki_3dan {
	max-width: 1000px;
	margin: 50px auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	padding: 110px 50px 0 50px;
	box-sizing: border-box;
	border-top: 2px solid #6dc4bb;
}

.jisseki_3dan .box {
	width: 40%;
	padding: 0 20px;
	margin-bottom: 50px;
	box-sizing: border-box;
	text-align: center;
}

.jisseki_3dan .box p {
	font-size: 26px;
	font-family: "Figtree", sans-serif;
	letter-spacing: 1px;
	color: #389ba4;
	font-weight: 700;
}


.jisseki_3dan .box h3 {
	font-size: 18px;
	font-weight: 500;
	color: #333;
	padding: 30px 0;
	margin-top: 30px;
	border-top: 2px solid #6dc4bb;
}

@media screen and (max-width: 1000px) {
	
.jisseki_3dan .box {
	width: 45%;
}
}
@media screen and (max-width: 800px) {
	
.jisseki_3dan {
	max-width: 500px;
	margin: 50px auto;
	padding: 110px 50px 0 50px;
}
	

.jisseki_3dan .box {
	width: 100%;
	padding: 0;
	margin-bottom: 50px;
}
	
}

@media screen and (max-width: 500px) {
	
.jisseki_3dan {
	border-top:none;
	padding: 0px 30px 0 30px;
}
	
.jisseki_3dan .box {
	margin-bottom: 40px;
}

.jisseki_3dan .box p {
	font-size: 24px;
}


.jisseki_3dan .box h3 {
	font-size: 16px;
	padding: 10px 0;
	margin-top: 10px;
}	
	
}




/*---coming soon---------*/

.cs {
	text-align: center;
	padding: 100px 30px;
}

.cs h3 {
	font-family: "Sacramento", serif;
	font-weight: normal;
	font-size: 40px;
}

.cs p {
	font-size: 16px;
	margin: 30px 0 0 0;
}

@media screen and (max-width: 800px) {
.cs {
	padding: 80px 10px 50px 10px;
}	
}

/*--------------------------------------------
TOP entry
----------------------------------------------*/

.newstop {margin: 30px 0 50px 0;}

.news_entry {
	max-width: 1200px;
	display: flex;
	flex-wrap: wrap;
	padding: 0 20px;
	box-sizing: border-box;
	margin: 0 auto;
	justify-content: center;
}


.news_entry .box {
	width: calc(25% - 40px);
	margin: 0 20px;
}

/*--アーカイブ用設定------*/
.news_entry.acv {
	margin-bottom: 100px;
	justify-content: flex-start;
}
.news_entry.acv .box {margin-bottom: 50px;}





.news_entry .box a {display: block;}
.news_entry .box a .img {
	width: 100%;
	height: 16vw;
	max-height: 200px;
	overflow: hidden;
	position: relative;
	margin-bottom: 5px;
	border-radius: 15px;
}

.news_entry .box a .img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: 0.5s;
	position: absolute;
	left: 0;
	top: 0;
}

.news_entry .box a:hover .img img {
	transform: scale(1.1);
}

.news_entry .box a p {
	font-size: 14px;
	font-family: "Figtree", sans-serif;
	color: #47a399;
}

.news_entry .box a h4 {
	font-weight: normal;
}

@media screen and (max-width: 800px) {
	
.news_entry .box {
	width: calc(50% - 40px);
	margin: 0 20px 50px 20px;
}	
	
.news_entry .box a .img {
	width: 100%;
	height: 30vw;
	max-height: inherit;
}
}

@media screen and (max-width: 500px) {
	
.news_entry .box,
.news_entry.acv .box {
	width: 100%;
	margin: 0;
	padding: 15px 0 15px 5px;
	border-top: 1px solid #999;
}

.news_entry .box a .img {
	width: 40%;
	height: 25vw;
	max-height: inherit;
	margin: 0 0 0 20px;
	float: right;
}	
}

/*-----------------------------------------------
お知らせ記事ページ
------------------------------------------------*/

.ns_entry {
	max-width: 800px;
	margin: 0 auto;
	padding: 80px 50px;
	background-color: #fff;
	box-shadow: 0 0 10px rgba(0,0,0,0.1);
}

.ns_entry h1 {
	font-size: 30px;
	/*font-family: "Zen Old Mincho", serif;*/
	font-weight: normal;
	margin: 0 0 30px 0;
	text-align: center;
	line-height: 140%;
}

.ns_entry p.hd {
	font-family: "Figtree", sans-serif;
	font-size: 15px;
	color: #666;
	text-align: center;
	margin: 0 0 50px 0;
}

@media screen and (max-width: 990px) {
	
.ns_entry {
	padding: 50px 50px 0 50px;
	box-shadow: none;
}
}
@media screen and (max-width: 990px) {
	
.ns_entry {
	padding: 50px 30px 0 30px;
}
}



/*----エディタ----*/

.edi p {
	font-size: 16px;
	line-height: 200%;
	margin: 0;
	font-weight: 400;
	padding: 0;
}

.edi figure {margin: 15px 0;}

.edi h2 {
	font-weight: 600;
	margin: 30px 0;
	font-size: 22px;
	color: #47a399;
	line-height: 160%;
}

.edi h3 {
	font-weight: 400;
	margin: 30px 0 20px 0;
	font-size: 18px;
	background-color:  #f6f6f6;
	border-left: 5px solid #47a399;
	color: #000;
	padding: 5px 10px;
	border-radius: 3px;
	line-height: 160%;
}

.edi h4 {
	font-weight: 400;
	margin: 30px 0 20px 0;
	font-size: 16px;
	background-color:  #f6f6f6;
	border-bottom: 1px solid #47a399;
	border-top: 1px solid #47a399;
	color: #000;
	padding: 5px 10px;
	border-radius: 3px;
	line-height: 160%;
}

.edi iframe {
	margin: 20px 0;
	width: 100%;
	height: 60vw;
	max-height: 400px;
}

/*--------------------------------------------
会社案内
---------------------------------------------*/
.ctable {
	max-width: 800px;
	margin: 0 auto 80px auto;
	padding: 0 30px;
}

.ctable p {
	letter-spacing: -0.4em;
	font-size: 18px;
	border-bottom: 1px solid #6dc4bb;
	padding: 30px;
}

.ctable p span {
	vertical-align: top;
	display: inline-block;
	letter-spacing: normal;
	line-height: 180%;
}

.ctable p span:nth-child(1) {width: 30%;}
.ctable p span:nth-child(2) {width: 70%;}

@media screen and (max-width: 500px) {
.ctable p {
	padding: 15px;
}
.ctable p span:nth-child(1) {width: 100%; margin-bottom: 10px;}
.ctable p span:nth-child(2) {width: 100%;}	
}




/*---プロフィール---*/


.prof {
	text-align: center;
	padding: 0 30px;
}

.prof img.pf {
	width: 80%;
	max-width: 400px;
	height: auto;
}

.prof p {
	font-size: 18px;
	line-height: 180%;
	margin-bottom: 50px;
}

/*---スキル----------*/
.skill {
	max-width: 760px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	padding:  0 30px;
	box-sizing: border-box;
} 

.skill .box {
	text-align: center;
	width: 45%;
}

.skill .box p {
	font-family: "Oswald", serif;
	font-size: 40px;
	border-bottom: 5px solid #6dc4bb;
	padding: 20px 0;
}

@media screen and (max-width: 700px) {
	
.skill {
	max-width: 760px;
	flex-wrap: wrap;
} 

.skill .box {
	width: 100%;
}
	
}


/*----ごあいさつ------------------*/

.greeting {
	max-width: 1000px;
	margin: 100px auto 0 auto;
	text-align: center;
	padding: 50px 30px;
	border-top: 2px solid #666;
} 

.greeting p {
	font-size: 18px;
	line-height: 200%;
	letter-spacing: 1px;
}
.greeting p b {
	color: #6dc4bb;
	font-weight: normal;
}

.greeting p.name {
	text-align: right;
	padding: 50px 0 0 0;
}

/*---アクセス----------------*/
.acs {
	display: flex;
	max-width: 1000px;
	margin: 0 auto 100px auto;
	justify-content: space-between;
	padding: 0 30px;
}

.acs .box:nth-child(1) {
	width: 55%;
}

.acs .box:nth-child(2) {
	width: 35%;
}

.acs .box iframe {
	width: 100%;
	height: 60vw;
	max-height: 400px;
}

.acs .box p {
	margin: 0 0 10px 0;
}

.acs .box .telbox {
	background-color: #6dc4bb;
	padding: 10px;
	text-align: center;
	margin: 20px 0 0 0;
}

.acs .box .telbox a {
	color: #fff;
}

.acs .box .telbox a p:nth-child(1) {
	font-family: "Oswald", serif;
	font-size: 22px;
}

.acs .box .telbox p img {
	width: 30px;
	position: relative;
	top: 5px;
	height: auto;
}

@media screen and (max-width: 800px) {
	
.acs {
	display: block;
}

.acs .box:nth-child(1),
.acs .box:nth-child(2) {
	width: 100%;
}

.acs .box:nth-child(2) {
	padding: 20px;
	box-sizing: border-box;
}	
}


/*----------------------------------------------
フロー
-----------------------------------------------*/

#flow_nml .inner {margin: 0 0 50px 0;}
.flow {
	max-width: 1000px;
	width: calc(100% - 40px);
	margin: 0 auto 80px auto;
	position: relative;
	margin-bottom: 10px;
	align-items: center;
	display: flex;
	box-sizing: border-box;
	border-top: 2px solid #6bbcb3;
	flex-wrap: wrap;
	padding: 30px 0;
}

.flow:before {
  content: "";
  position: absolute;
  bottom: -52px;
  left: 50%;
  margin-left: -15px;
  border: 22px solid transparent;
  border-top: 22px solid #FFF;
  z-index: 2;
}

.flow:after {
  content: "";
  position: absolute;
  bottom: -58px;
  left: 50%;
  margin-left: -17px;
  border: 24px solid transparent;
  border-top: 24px solid #6bbcb3;
  z-index: 1;
}

.flow:last-child:after,
.flow:last-child:before {border: none;}

.flow img {
	width: 180px;
	display: block;
	height: auto;
	margin: 0 40px 0 0;
	box-sizing: border-box;
}

.flow .num {width: 220px;}
.flow .txt {width: calc(100% - 220px - 220px);}

.flow .num p {
	color: #6bbcb3;
	text-align: center;
	line-height: 80px;
	font-family: "Figtree", sans-serif;
	font-weight: 600;
	font-size: 70px;
}

.flow .num h5 {
	font-size: 18px;
	margin: 10px 0 0 0;
	font-weight: 500;
	letter-spacing: 2px;
	text-align: center;
}



.flow .txt p {
	line-height: 200%;
	padding-right: 40px;
}

.flow .txt p span {
	font-size:1.2em;
}

@media screen and (max-width: 786px) {
	
.flow img {
	width: 120px;
	margin: 0 30px 0 0;
}

.flow .num {width: 220px;}
.flow .txt {width: calc(100% - 150px - 220px);}

.flow .txt p br {display: none;}
.flow .txt p span,
.flow .txt p span br {display: block;}
}

@media screen and (max-width: 680px) {
	
.flow img {
	width: 90px;
	margin: 0 30px 0 0;
}

.flow .num {width: 100%;}
.flow .txt {width: calc(100% - 120px);}
	
.flow .txt p {padding: 20px 20px 0 0;}
}

@media screen and (max-width: 500px) {
	
.flow img {
	width: 80px;
	margin: 0 15px 0 0;
}
.flow .txt {width: calc(100% - 95px);}
}


@media screen and (max-width: 400px) {
	
.flow .num p {
	line-height: 100%;
	font-size: 30px;
}

.flow img {
	width: 80px;
	margin: 15px auto 0 auto;
}
.flow .txt {width: 100%;}
	
.flow .txt p {padding: 20px 10px 0 10px;}
}







/*---------------------------------------------

フッタ- 

------------------------------------------------*/
#footer {
	max-width: 1500px;
	padding: 30px;
	text-align: right;
	font-weight: 500;
	font-size: 14px;
	color: #333;
}

@media screen and (max-width: 500px) {
#footer {text-align: center;}
}





/*---------------------------------------------------------------------------
ページングのスタイル
---------------------------------------------------------------------------*/
.newer-older {
	margin: 30px auto 30px auto;
	letter-spacing: -0.4em;
	display:flex;
	-js-display: flex;
	flex-direction:row;
	flex-wrap:wrap;
	width: 100%;
	max-width: 1200px;
	font-size: 14px;
	font-weight: 500;
	border-top: 1px solid #d6d6d6;
}
.newer-older p {margin: 0; padding: 0;}

.newer-older p.newer {text-align: right;}
.newer-older p.older {text-align: left; }
.newer-older p.blog {
	text-align: center; 
	background-color: #f6f6f6;
}

.newer-older p.older,
.newer-older p.newer {
	letter-spacing: normal;
	box-sizing: border-box;
	vertical-align: middle;
}

.newer-older p.older{width: calc(50%)}
.newer-older p.newer{width: calc(50%)}


.newer-older p.older a,
.newer-older p.newer a {
	height: 100%;
	display: block;
	text-decoration: none;
	transition: 0.5s;
	box-sizing: border-box;
}

.newer-older p.older a {padding: 20px;}
.newer-older p.newer a {padding: 20px;}


@media screen and (max-width: 550px) {

.newer-older p.older a {padding: 20px 0;}
.newer-older p.newer a {padding: 20px 0;}

	
.newer-older p.older{width: 50%}
.newer-older p.newer{width: 50%; }
.newer-older p.blog { display: none;}
.newer-older {
	margin: 0px auto ;
}
}

.bgred{
    background-color: #e60012;
    color: white;
    text-align: center;
    margin: 0 0% 10px 0%;
    padding: 2px 15px;
    display: inline-block;
}

/*------------------------------------**/




/*----------------------------------------------------------------------------
ページングカスタマイズ
-----------------------------------------------------------------------------*/

nav.pagination {
	letter-spacing: normal; 
	text-align: center;
	font-size: 16px;
	color:#000;
	margin: 60px 0 ;
	position: relative;
	z-index: 999;
}

nav.pagination h2 {display: none;}
nav.pagination a{
	display: inline-block;
	color:#000;
	margin: 0 2px;
	text-decoration: none;
	width: 30px;
	height: 30px;
	border-radius: 30px;
	transition: 0.5s;
}

nav.pagination a:hover {background-color: #d6d6d6;}

nav.pagination span.page-numbers {
	background-color: #6dc4bb;
	display: inline-block;
	padding: 0;
	width: 30px;
	height: 30px;
	border-radius: 30px;
	color: #fff;
	text-decoration: none;
}

nav.pagination span.dots{
	background: none;
	color:#000;
}
/*--nav.pagination span.page-numbers {background-color: #d6d6d6;}--*/

/*----------------------------------------------------------------------------
フォーム用のボタン・入力
-----------------------------------------------------------------------------*/
	.a1 {
		height: 50px;
		padding:10px 20px;
		border:1px solid #acacaa;
		font-size:15px;
		font-family: 'Roboto', 'Zen Kaku Gothic New', "游ゴシック", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", MS UI Gothic, Osaka, sans-serif;
		background:#fff;
		width:100%;
		box-sizing:border-box;
		outline: none;
	}
	.a2 {
		padding:10px 20px;
		border:1px solid #acacaa;
		font-size:15px;
		font-family: 'Roboto', 'Zen Kaku Gothic New', "游ゴシック", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", MS UI Gothic, Osaka, sans-serif;
		background:#fff;
		width:100%;
		box-sizing:border-box;
		outline: none;
	}

	
.a1:focus,
.a2:focus{
	border-color:#D45557;
	outline: none;
}

/*送信ボタン*/
	.sendb,
	.sendb:focus {
		width: 251px;
		height: 57px;
		margin: 40px auto 0 auto;
		background-color: #343434;
		color:#fff;
		border: none;
		border-radius: 7px;
		font-size: 16px;
		font-weight: 400;
		cursor:pointer;
		display: grid;
		place-items:center;
		position: relative;
		transition: 0.3s;
		font-family: "Zen Kaku Gothic New", sans-serif;
}
	
	.sendb:hover {
		top: 2px;
		left: 2px;
		background-color:#000;
		cursor:pointer;
		transition: 0.3s;
	}


.entry_form label input:before {
	position: absolute;
	z-index: 1;
	top: 13px;
	left: 0.1875rem;
	width: 0.75rem;
	height: 0.375rem;
	content: '';
	-webkit-transition: -webkit-transform 0.4s cubic-bezier(0.45, 1.8, 0.5, 0.75);
	        transition:         transform 0.4s cubic-bezier(0.45, 1.8, 0.5, 0.75);
	-webkit-transform: rotate(-45deg) scale(0, 0);
	        transform: rotate(-45deg) scale(0, 0);
	border: 2px solid #da3c41;
	border-top-style: none;
	border-right-style: none;
	
}
.entry_form label input:checked:before {
	-webkit-transform: rotate(-45deg) scale(1, 1);
	        transform: rotate(-45deg) scale(1, 1);
}
.entry_form label input:after {
	position: absolute;
	top: 10px;
	left: 0;
	width: 1rem;
	height: 1rem;
	content: '';
	cursor: pointer;
	border: 1px solid #ccc;
	background:#f6f6f6;
}

.entry_form input[type="checkbox"]:focus {
  outline: none;
}
/* チェックボックス */
input[type=checkbox] {
    -webkit-appearance: none;
    -moz-appearance: none;
    -ms-appearance: none;
    appearance: none;
    position: relative;
    top: 3px;
    margin: 3px 0 0 -16px;
    width: 18px;
    height: 18px;
    cursor: pointer;
    background-color: #fff;
    border: 1px solid #acacaa;
    outline: none;
    transition: background-color 0.2s, border-color 0.2s;
}

input[type=checkbox]:checked {
    background-color: #2d6ab3;
    border-color: #2d6ab3;
}

/* チェックマーク */
input[type=checkbox]:checked::before {
    content: '';
    position: absolute;
    top: 1px;
    left: 6px;
    width: 3px;
    height: 10px;
    border: solid #fff;
    border-width: 0 2px 2px 0;
    transform: rotate(45deg);
}

input[type=checkbox]:hover {
    border-color: #2d6ab3;
}




/*----------------------------------------------------------------------------
お問合せ
-----------------------------------------------------------------------------*/

#contact p.ctr {
	text-align: center;
	max-width: 900px;
	font-size: 18px;
	line-height: 180%;
	margin: 0 auto 50px auto;
	padding: 0 30px;
}

@media screen and (max-width: 900px) {
	
#contact p.ctr {
	text-align: left;
	max-width: 900px;
	font-size: 16px;
}
}


#formw{
	
}

#formw .innerf{
	clear: both;
    margin: 30px auto;
    padding: 0px 30px 40px 30px;
    width: 100%;
    box-sizing: border-box;
    max-width: 1020px;
}

#formw .left{
	display: inline-block;
	margin-right: 30px;
	width: calc(50% - 30px);
}

#formw .right{
	padding: 0px 0 0 0;
	display: inline-block;
	vertical-align: top;
	width: calc(50% - 30px);
}

#formw .send{
	padding: 20px 0 0 0;
	display: inline-block;
	vertical-align: top;
	width: 100%;
}

#formw .personal{
	display: inline-block;
	margin-right: 0px;
	width: 100%;
	text-align: center;
}


/*#formw h3 {
	font-size: 18px;
    letter-spacing: 0.1em;
    font-weight: 400;
    margin-bottom: 20px;
    text-align: center;
    background-color: #4993a5;
    border-radius: 0 0 5px 5px;
    width: 270px;
    color: white;
    line-height: 45px;
}*/

#formw .tb {
	width: 100%;
	margin-bottom: 10px;
}


#formw .personal .tb{
	display: flex;
}

#formw .tb p {
    margin: 0 0 5px 0;
    padding: 0;
}


#formw .th {
	vertical-align: top;
}

#formw .td {
	vertical-align: top;
}
	
#formw span.red {
	background-color: #c7878e;
	padding: 2px 6px;
	color: #ffffff;
	display: inline-block;
	font-size: 14px;
	line-height: 110%;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	border-radius:  5px;
	margin-right: 5px;
	margin: 0 5px 0 0;
	}

#formw span.nin {
	background-color: #666;
	padding: 2px 6px;
	color: #ffffff;
	display: inline-block;
	font-size: 14px;
	line-height: 110%;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
	border-radius:  5px;
	margin-right: 5px;
	margin: 0 5px 0 0;
	}
	
	#formw .ctr {text-align:left;}

@media screen and (max-width: 800px) {
#formw .left, #formw .personal {
    display: block;
    margin: 0 auto;
    width: 80%;
}
#formw .right, #formw .send {
    padding: 20px 0 0 0;
    display: block;
    vertical-align: top;
    margin: 0 auto;
    width: 80%;
}
#formw .ctr {text-align:center;}
}

@media screen and (max-width: 500px){
#formw .left, #formw .personal {
    width: 100%;
}
#formw .right, #formw .send {
    width: 100%;
}

#formw h3 {
    width: 100%;

}
}
.personal .wpcf7-not-valid-tip{
	margin-top: 40px;
    margin-left: -277px;
}

.wpcf7-mail-sent-ok {border-color: #861214;}

/*----------------------------------------------------------------------------
フォーム用のボタン・入力
-----------------------------------------------------------------------------*/
	.a1 {
		padding:10px 20px;
		border:1px solid #ccc;
		font-size:15px;
		font-family:'Roboto','Noto Sans JP',"游ゴシック","メイリオ",Meiryo,"ＭＳ Ｐゴシック",MS UI Gothic,Osaka,sans-serif;
		background:white;
		width:100%;
		box-sizing:border-box;
		margin-bottom: 2px;
		-moz-border-radius: 20px;
		-webkit-border-radius: 20px;
		border-radius: 5px;
	}
	
	.a2 {
		padding:10px 20px;
		border:1px solid #ccc;
		font-size:15px;
		font-family:'Roboto','Noto Sans JP',"游ゴシック","メイリオ",Meiryo,"ＭＳ Ｐゴシック",MS UI Gothic,Osaka,sans-serif;
		background:white;
		width:100%;
		height: 260px;
		box-sizing:border-box;
		margin-bottom: 2px;
		-moz-border-radius: 20px;
		-webkit-border-radius: 20px;
		border-radius: 5px;
	}
	
	.a3 {
		padding:10px 20px;
		border:1px solid #ccc;
		font-size:15px;
		font-family:'Roboto','Noto Sans JP',"游ゴシック","メイリオ",Meiryo,"ＭＳ Ｐゴシック",MS UI Gothic,Osaka,sans-serif;
		background:white;
		width:30%;
		box-sizing:border-box;
		margin-bottom: 2px;
		-moz-border-radius: 20px;
		-webkit-border-radius: 20px;
		border-radius: 5px;
	}
	
.a1:focus,
.a2:focus,
.a3:focus {
	border-color: #666;
	background-color: #ffffff;
	outline: none;
}
	.sendb,
	.sendb:focus {
		padding:8px 20px;
		background-color:#6dc4bb;
		color:#FFFFFF;
		font-size: 18px;
		border:none;
		-webkit-box-shadow: 0px 0px 3px #ccc;
		-moz-box-shadow: 0px 0px 3px #ccc;
		cursor:pointer;
		box-shadow: 0px 0px 3px #ccc;
		-webkit-border-radius: 5px;
		-moz-border-radius: 5px; 
		border-radius: 5px;
		font-family: 'Zen Kaku Gothic New', "游ゴシック", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", MS UI Gothic, Osaka, sans-serif;
		width: 270px;
		line-height: 20px;
	}
	
	.sendb:hover {
		background-color:#333;
		cursor:pointer;
	}
	
 input[type=checkbox]
 {

  -webkit-appearance: none;
  -moz-appearance: none;
  -ms-appearance: none;
  appearance: none;

}
input[type=checkbox] {
	margin: 0;
	margin-left: 0;
	line-height: 0;
	width:0px;
	height: 0px;
	border: 0;
}

#formw label input {
	position: relative;
	margin: 0 1rem 0 0;
	cursor: pointer;
	
}
#formw label input:before {
	position: absolute;
	z-index: 1;
    top: 6px;
    left: 0.15rem;
    width: 0.75rem;
	height: 0.375rem;
	content: '';
	-webkit-transition: -webkit-transform 0.4s cubic-bezier(0.45, 1.8, 0.5, 0.75);
	        transition:         transform 0.4s cubic-bezier(0.45, 1.8, 0.5, 0.75);
	-webkit-transform: rotate(-45deg) scale(0, 0);
	        transform: rotate(-45deg) scale(0, 0);
	border: 2px solid #da3c41;
	border-top-style: none;
	border-right-style: none;
	
}
#formw label input:checked:before {
	-webkit-transform: rotate(-45deg) scale(1, 1);
	        transform: rotate(-45deg) scale(1, 1);
}
#formw label input:after {
	position: absolute;
	top: 3px;
	left: 0;
	width: 1rem;
	height: 1rem;
	content: '';
	cursor: pointer;
	border: 1px solid #ccc;
	background:#f6f6f6;

}

#formw input[type="checkbox"]:focus {
  outline: none;
  border: 0;
}


#formw .wpcf7-list-item{
	display: block;
}

#formw .wpcf7-list-item-label{
	margin-left: 25px;
}

.wpcf7-response-output {border-color: #333 !important;}
#formw label{
	display: flex;
}

@media screen and (max-width: 500px) {

	.a2 {
		padding:10px 20px;
		border:1px solid #ccc;
		font-size:15px;
		font-family:'Roboto','Noto Sans JP',"游ゴシック","メイリオ",Meiryo,"ＭＳ Ｐゴシック",MS UI Gothic,Osaka,sans-serif;
		background:white;
		width:100%;
		height: 260px;
		box-sizing:border-box;
		margin-bottom: 2px;
		-moz-border-radius: 20px;
		-webkit-border-radius: 20px;
		border-radius: 5px;
	}
}


