@charset "UTF-8";

	
	/*共通設定
	ーーーーーーーーーーーー*/

html, body {
height: 100%;
width: 100%;
min-height: 100%;
}

body { 
font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "serif";
background-color: #f2f2f2;
}

/*"Sawarabi Mincho", */

a { 
text-decoration:none;
}

										
/*共通設定 font-family 
--------------------*/

/*.wf-sawarabimincho { font-family: "Sawarabi Mincho"; }


h1,h2,h3,h4,{
font-family: "Sawarabi Mincho"; 
}
*/

/*共通設定 font-size 
--------------------*/

/* 1rem(16px) @ 30rem(760px) increasing to 2rem(32px) @ 120rem(1920px) */
@media (min-width: 47.5rem) {
  :root {
    font-size: calc(1rem + ((1vw - 0.3rem) * 1.1111));
    /* Where: * 1.1111 = 100 * font_Size_Difference / viewport_Width_Difference */
  }
}
/* Prevent font scaling beyond this breakpoint */
@media (min-width: 120rem) {
  :root {
    font-size: 2rem;
  }
}


/*共通ボタン設定
	ーーーーーーーーーーーー*/

.button {
 box-sizing: border-box;
	padding: 1rem;
	text-align: center;
	text-transform: uppercase;
	font-weight: bold;
	letter-spacing: 2px;
	border: 1px solid rgba(255,255,255,1);
	transition: all 0.3s linear;
}

.button:hover {
	background-color: rgba(255,255,255,0.62);
	color: #000;
	cursor: pointer;
}



/*共通ボタン設定_ギザギザ円
	ーーーーーーーーーーーー*/
	.giza_s{

	}
#gizagiza .giza_s , #gizagiza .giza_s:after , #gizagiza .giza_s:before , #gizagiza .giza_s span {
  content:"";
  width:200px;
  height:200px;
		background-color: rgba(186,0,3,1.00);
  position:absolute;
  top:0px;
}
#gizagiza , #gizagiza .giza_s , #gizagiza .giza_s:after , #gizagiza .giza_s:before {
  -webkit-transform: rotate(22.5deg);
  -moz-transform: rotate(22.5deg);
}
#gizagiza .giza_s span {
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  text-align: center;
		box-sizing: border-box;
display: table;
vertical-align: middle;
  z-index: 999;
  color: #fff;
			font-size: 1rem;
	line-height: 1.2rem;
	margin: auto;
}
#gizagiza {
  position:relative;
  width:200px;
  height:200px;
  background-color:rgba(186,0,3,1.00);
  margin:20px 0 0 20px ;
}

#burst-12 span {
z-index: 999;
}			
#burst-12 {
      background: red;
      width: 80px;
      height: 80px;
      position: relative;
      text-align: center;
    }
    #burst-12:before,
    #burst-12:after {
      content: "";
      position: absolute;
      top: 0;
      left: 0;
      height: 80px;
      width: 80px;
      background: red;
    }
    #burst-12:before {
      transform: rotate(30deg);
    }
    #burst-12:after {
      transform: rotate(60deg);
    }
	
				


.flex_0 {
display: flex;
justify-content: center;
margin: 2%;

}


/*共通ボタン設定_円
	ーーーーーーーーーーーー*/
.flex_0 div {
background:rgba(126,110,161,1.00);
border-radius: 50%;
padding: 2%;
margin: 1%;
text-align: center;
font-size: .7rem;
line-height: 1rem;
font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
color:rgba(255,255,255,1.00);
}

.flex_0 div:last-child{
background-color: rgba(170,134,50,1.00)
}


/*共通設定 header 
--------------------*/
body .wrapper {
	box-sizing: border-box;
	max-width: 1080px;
	width: 100%;
	min-height: 100%;
	height: 100%;
	margin: 0 auto;
	background-color: rgba(255,255,255,1.00);
/*	display:flex;
	flex-direction: column;
	justify-content: space-between;*/
	
}

header { 
max-width: 1080px;
width: 100%;
padding-bottom: .1rem;
background: rgba(255,255,255,1.00);
border-bottom: 5px solid rgba(163,98,177,1.00); 
position: fixed;
left:auto;
top:0;
z-index:24;
}

.main-nav {
display: -webkit-flex;
display: -moz-flex;
display: -ms-flex;
display: -ms-flexbox;
display: -o-flex;
display: flex;
-webkit-box-align: end;
-webkit-align-items: flex-end;
-ms-flex-align: end;
align-items: flex-end;
}

header li {
list-style: none;
font-size: .5rem;
margin-right: 10px;
width: 10%;
text-align: center;
}

.main-nav a {
display: block;
margin: 0 0 10px;
border-radius: 5px;
border: rgba(0,0,0,0.3) 1px solid;
color: #000;
padding: 15px;
text-decoration: none;
}

.main-nav a:hover {
background: #60B99A;
}

.main-nav li:first-child {
width: 15%;
text-align: left;
margin-right: auto;
margin-top: 0;
padding: 0;
border: none;
}

.logo {
width: 200%;
background: #fff;
border: none;
}

.main-nav li:first-child a {
border:none;
}

.main-nav li:first-child a:hover {
background: #fff;
}

.logo img {
width: 100%;
}



.logo a:hover {
  background: #fff;
		border: none;
}

.text { display: inline-block; }



	/*共通maine
	ーーーーーーーーーーーー*/
main {
box-sizing: border-box;
max-width: 1080px;
width: 100%;
padding-top:10%;
background: rgba(255,255,255,1.00);
flex: 1;

}


/*共通footer
	ーーーーーーーーーーーー*/

footer {
box-sizing: border-box;

width: 100%;
margin-top: auto;

font-size: .5rem;
background: rgba(0,0,0,1.00);
text-align: center;
padding: 2%;


}

footer ul {
width: 100%;
display: -webkit-flex;
display: -moz-flex;
display: -ms-flex;
display: -ms-flexbox;
display: -o-flex;
display: flex;
justify-content: space-between;
color: rgba(255,255,255,1.00);
padding: 1% 5%;
}

footer li {
list-style: none;
}

footer .copyright, footer a {
display: block;
text-align: center;
color: rgba(255,255,255,1.00);
}

footer .copyright {
border-top: rgba(148,148,148,1.00) 1px solid;
padding-top: 2%;
}






/*共通 テーブル設定
	ーーーーーーーーーーーー*/

table {
  margin: 2rem;
		font-size: .4rem;

}
.tbl-r02 th {
  background:rgba(126,110,161,1.00) ;
  border: solid 1px #ccc;
  color: #fff;
		font-size: .6rem;
  padding: 3%;
}
.tbl-r02 td {
　border: solid 1px #ccc;
   padding: 3%;
			font-size: .6rem;
		text-align: left;
}

table li {
  margin-left:.8rem;
		font-size: .6rem;
		line-height: 1rem;
}


 



/*top
	ーーーーーーーーーーーー*/
	#top {

max-width: 1080px;
width: 100%;
	 }

video {
  width: 100%;
  max-width: 1080px;
  height: auto;
  aspect-ratio: 16 / 9; /* 動画のアスペクト比 */
  display: block;
  margin: auto;
}


#top .title_cover {
box-sizing: border-box;
position: relative;
padding: 10% 0 10%;
background: url("../../images/top01.jpg");
background-size:cover;
background-position: center;
background-repeat: no-repeat;
text-align: center;
}

#top .top_logo{
text-align: center;
background: rgba(255,255,255,0.3);
padding: 2% 0;
}

#top .title_top { 
padding: 0;
margin: 0;
}

#top .title_top h1 {
margin: 0;
background: rgba(79,76,177,0.5);
padding: 3% 0 0;
color: rgba(255,255,255,1.00);
font-size: calc(1rem*2);
letter-spacing: .4rem;

}

#top .title_top p {
margin: 0;
background: rgba(79,76,177,0.5);
padding:0 0 3%;
font-size: calc(1rem*1);
color: rgba(255,255,255,1.00)
}

#top .contents { 
box-sizing: border-box;
padding: 6.897% 0 20%;
text-align:center;
/*position: relative;*/
display: -webkit-flex;
display: -moz-flex;
display: -ms-flex;
display: -ms-flexbox;
display: -o-flex;
display: flex;
flex-direction: column;

}
#top .contents h2 {
font-size: 1.2rem;
padding-top: 0;
padding-right: 0;
padding-left: 0;
color: rgba(255,255,255,1.00);
}

#top .contents .sub-nav{
display: -webkit-flex;
display: -moz-flex;
display: -ms-flex;
display: -ms-flexbox;
display: -o-flex;
display: flex;
justify-content:space-between;
}

#top a:link {
color: #fff;
}

#top a:hover {
	color: #000;
	cursor: pointer;
}

#top a:visited {
	color: #fff;
	cursor: pointer;
}

#top .cp_bgpattern21 {
	background:
	linear-gradient(27deg, #0e0f14 5px, transparent 5px) 0 5px,
	linear-gradient(207deg, #0e0f14 5px, transparent 5px) 10px 0px,
	linear-gradient(27deg, #14151f 5px, transparent 5px) 0px 10px,
	linear-gradient(207deg, #14151f 5px, transparent 5px) 10px 5px,
	linear-gradient(90deg, #14151c 10px, transparent 10px),
	linear-gradient(#15151c 25%, #12131a 25%, #12131a 50%,
		transparent 50%, transparent 75%, #191b24 75%, #191b24);
	background-color: #0c0d12;
	background-size: 20px 20px;
 }

#top .contents .monthly {
border: rgba(255,255,255,1.00) 1px solid;
border-radius: 10px; 
padding: 5%; 
margin:0 7% 5%;
background: rgba(255,255,255,1.00);
/* box-shadow */
box-shadow: 2px 2px 4px inset;
}

#top .monthly h1 {
border-bottom: groove rgba(0,0,0,1.00) 1px ;
padding-bottom: 2%;
margin-bottom: 5%;
font-size: 1rem;
}

#top .monthly p {
font-size: 1.2rem;
line-height: 2rem;
}
	
		/*message
	ーーーーーーーーーーーー*/
#message {
box-sizing: border-box;
background-image: url( "../../images/parallax.png");
background-repeat: no-repeat;
background-color: #fff;
background-position: bottom;
background-size:contain;
}

#message .title_cover {
box-sizing: border-box;
padding: 10% 0;
background: url("../../images/message_bg_01.jpg");
background-size: cover;
background-position:bottom;
background-repeat: no-repeat;
text-align: center;
	}
	
	#message .contents { 
box-sizing: border-box;
text-align:center;
padding: 6.897% 0 20%;


}
	#message h1 {
display: block;
text-align: center;
color: #fff;
font-size: 1.5rem;
margin-bottom: 0.3%;
text-shadow: 1px 2px 3px #808080;
background-color: rgba(0,0,0,0.30);
padding: 1rem;
}
				
.parallax_description {
color: #000;

padding-left: 5%;
width: 50%;
font-size: .7rem;
line-height: 1.8em;
font-weight: lighter;
border-bottom: #000000 solid 1px;
padding-bottom: 1rem;
text-align: left;
}

	#message h2 {
width: 50%;
font-size: 1rem;
line-height: 1.8rem;
letter-spacing: 2;
margin-bottom: 2%;
}

.parallax {
color: #000;
padding-top:1rem;
padding-left: 100px;
width: 50%;
line-height: 1.8em;
text-align: right;				
}



/*	outline
	ーーーーーーーーーーーー*/
#outline {	

}

#outline .title_cover {
padding: 5% 0;
background: url("../../images/top01.jpg");
background-size:cover;
background-position: center;
background-repeat: no-repeat;
}

#outline h1 {
text-align: center;
color: #fff;
font-size: 1rem;
margin-bottom: 0.3%;
text-shadow: 1px 2px 3px #808080;
background-color: rgba(31,31,71,0.70);
padding: .2rem;
}
				
#outline .outline_main {
display: -webkit-flex;
display: flex;
flex-basis: 40%;
margin: 0;
padding: 0;
background-image: url( "../../images/parallax.png");
background-color: #fff;
background-position: right 0 bottom 0;
background-repeat: no-repeat;
background-size: contain;
flex: 1 0 auto;
}

#outline table {
box-sizing: border-box;
width:  40%;
margin: 5% 0 0 5%;
}

#outline th {
width: 20%
}

#outline td {
width: 40%;
}




/*map
ーーーーーーーーーーーー*/
#map { 
flex: 1;}




/*employment
ーーーーーーーーーーーー*/
#employment {	

}

#employment .title_cover {
padding: 5% 0;
background: url("../../images/employment_02.jpg");
background-size:cover;
background-position: center;
background-repeat: no-repeat;
}


#employment h1 {
text-align: center;
color: #fff;
font-size: 1rem;
margin-bottom: 0.3%;
text-shadow: 1px 2px 3px #808080;
background-color: rgba(31,31,71,0.70);
padding: .2rem;
}

#employment .employment_main {
padding: 5%;
background-image: url( "../../images/parallax02.png");
background-color: #fff;
background-position: right 0 bottom 0;
background-repeat: no-repeat;
}

#employment h2 {
border: 1px rgba(115,115,115,1.00) solid;
border-radius: 10px;
padding: 3%;
font-size: 1rem;
line-height: 1.5em;
text-align: center;


}


#employment table {
  margin: 0;
		font-size: .8rem;
		line-height: 1.2rem;
		width: 100%;
		padding: 3%;
}


#employment th {
  background:rgba(126,110,161,1.00) ;
  border: solid 1px #ccc;
  color: #fff;
  padding: 2%;
		width: 30%;}
		
		#employment td {
  border: solid 1px #ccc;
  padding: 2%;
}
		


/*contact
ーーーーーーーーーーーー*/
	
#contact	{
background-image: url( "../../images/parallax02.png");
background-color: #fff;
background-position: bottom;
background-size: 90%;
background-repeat: repeat-x;
padding-bottom: 16%;
}


#contact h1 {
font-size: 1rem;
color: rgba(0,0,0,1.00);
border-bottom: rgba(144,79,199,1.00) 3px solid;
margin-bottom: 5%;
}

#contact .contact_main {
height: 100%;
padding: 10%;
}

#contact p {
font-size: 1rem;
padding-bottom:4%;

}

.w50 {
height: 1rem;
width: 50%;
}

textarea,
input[type="number"],
input[type="text"],
input[type="submit"]{
    width: 100%;
    padding: 10px 15px;
    font-size: 1rem;
    border: 1px solid #ccc;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    -ms-border-radius: 4px;
    border-radius: 4px;
				margin-top: 1%
}

textarea {
    min-width: 100%;
    min-height: 30%;
    max-width:  300px;
    max-height: 200px;
				font-size: .5rem;
}

textarea:focus,
input[type="tel"]:focus,
input[type="email"]:focus,
input[type="text"]:focus {
    border: 1px solid #333;
}


input[type="submit"],
input[type="reset"]{
box-sizing: border-box;
    width: 100%;
    padding: 10px 15px;
    font-size: 14px;
    font-size: 1rem;
    border: 1px solid #ccc;
    -webkit-border-radius: 4px;
    -moz-border-radius: 4px;
    -ms-border-radius: 4px;
    border-radius: 4px;
				margin-top: 1%;
				margin-right: 3%;
}
	

	/*privacy
	ーーーーーーーーーーーー*/
#privacy {
padding: 17% 8%;
background: rgba(255,255,255,1.00);
}
	
#privacy h1 {
font-size: 1rem;
color: rgba(0,0,0,1.00);
border-bottom: rgba(144,79,199,1.00) 3px solid;
margin-bottom: 1%;
	}
	
#privacy p, #privacy li {
	padding-top: 1rem;
	font-size: .6rem;
	line-height: 1.2rem;
	}
	
#privacy p:first-child {
padding-top:0;
}
	
#privacy strong{
		display: block;
		font-size: .8rem;
		padding-bottom: .1rem;
		border-bottom: rgba(56,56,56,1.00) 1px solid;
		margin-bottom: 1rem;
		}
		
#privacy ul {
		margin-left: 2rem;
		margin-top: 2rem
		}
		

	
	



/* モバイル版
------------------------------- */
@media (max-width: 767px) {
 body,
	.wrapper {
	max-width:767px;
}


/* headerモバイル版
------------------------------- */

header {
box-sizing: border-box;
width: 100%;
padding: 0;
margin: 0;
}
				
header li {
	list-style: none;
	font-size: 1rem;

}

.main-nav {
display: -webkit-flex;
display: flex;
-webkit-flex-wrap: wrap;
flex-wrap: wrap;
justify-content: center;
}

.main-nav li {
width: calc(90%/3);
text-align: center;
}

.logo {
	max-width:767px;
	width: 100%;
}

.logo img {
width:50%;
padding: 0;
}

.main-nav li:first-child {
width: 100%;
text-align: center;
}

.main-nav li:first-child a {
margin: 1% auto;
padding: 0;
}


	/*mainモバイル版
	ーーーーーーーーーーーー*/
main {
	margin: 43% 0 0;

}


	/*top_maineモバイル版
	ーーーーーーーーーーーー*/


#top .title_cover {
background: url("../../images/top01.jpg");
background-size:cover;
background-position: center;
background-repeat: no-repeat;
text-align: center;
}


#top .title_top {

}


#top .title_cover img, #top .top_logo  {
display: none;
}

#top h1 {
font-size:1.2rem;
}

#top .contents { 
text-align: center;
flex: 1;

}

#top .contents h2 { 
font-size: 1.5rem;
margin-bottom: 0;
}

#top .contents ul {
display: none;
}

#top .cp_bgpattern21 {
	background:
	linear-gradient(27deg, #0e0f14 5px, transparent 5px) 0 5px,
	linear-gradient(207deg, #0e0f14 5px, transparent 5px) 10px 0px,
	linear-gradient(27deg, #14151f 5px, transparent 5px) 0px 10px,
	linear-gradient(207deg, #14151f 5px, transparent 5px) 10px 5px,
	linear-gradient(90deg, #14151c 10px, transparent 10px),
	linear-gradient(#15151c 25%, #12131a 25%, #12131a 50%,
		transparent 50%, transparent 75%, #191b24 75%, #191b24);
	background-color: #0c0d12;
	background-size: 20px 20px;
 }

	/*message_maineモバイル版
	ーーーーーーーーーーーー*/
	
	#message {

}
	
	#message .title_cover {
box-sizing: border-box;
background: url("../../images/message_bg_01.jpg");
background-size:cover;
background-position: center;
background-repeat: no-repeat;
text-align: center;
padding: 20% 0;
	}
	
#message .title {
padding: 2rem;
background-color: rgba(0,0,0,0.70);

}
	
	#message h1 {
	margin: 0;
font-size: 1.2rem;
margin-bottom: 0.3%;
padding: 1rem;
}
				
	#message .message_main {
background-size: contain;
background-position: bottom;
flex: 1;
}

	#message .message_main h2 {
width: 100%;
font-size: 2rem;
line-height: 1.8em;
letter-spacing: 2;
padding-bottom: 1rem;
}

	#message .message_main h3 {
	padding: 10% 10% 30%;
font-size: 1.2rem;
font-weight: normal;
padding-bottom: 50%;
}


.parallax_description {
color: #000;
padding: 10%;
width: 100%;
font-size: 1rem;
line-height: 1.8em;
font-weight: normal;
border-bottom: #000000 solid 1px;
text-align: left;
}

.parallax {
color: #000;
padding-top:1rem;
padding-left: 100px;
width: 100%;
line-height: 1.8em;
text-align: right;				
}


	/*outlineモバイル版
	ーーーーーーーーーーーー*/
#outline {

}

#outline .title_cover {
padding: 5% 0;
}

#outline .outline_main {
padding: 5%;
display: flex;
flex-direction: column;
padding-bottom: 50%;

}

#outline .map {

}


	/*Tableモバイル版
	ーーーーーーーーーーーー*/
#outline table  {
table-layout:fixed;
width: 100%;
margin: 0;
}
#outline td, #outline th, #outline li {
font-size: 1rem;
line-height: 1.5rem;
}
	
#outline tbl-r02 th,
#outline .tbl-r02 td {
 border-bottom: none;
 width: 50%;
 padding-left: 5%;			
  }

#map {
flex: 1;
}

	/*contactモバイル版
	ーーーーーーーーーーーー*/
#contact .contact_main {
height: 100%;
padding: 15% 10% 10%;
}




}
