/*base
------------------*/
/*html, body, div, span, object, iframe,*/
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
/*small, strong, sub, sup, var,b, i,*/
/*dl, dt, dd, ol, ul, li,*/
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
	margin:0;
	padding:0;
	border:0;
	outline:0;
	font-size:100%;
	background:transparent;
}
article,nav,section,header,footer,aside,main,address{
	display:block;
}
* {
	box-sizing: border-box;
}
nav ul,
nav li{
	list-style:none;
	margin:0;
	padding:0;
}
img {
	line-height:0;
	border:none;
	max-width:100%;
	height:auto;
	-moz-box-sizing: border-box;
 	-webkit-box-sizing: border-box;
	box-sizing:border-box;
}

:root {
  --color-rgb:84,190,180;/*メイン　みどり*/
  --color-sub:187,229,225;/*サブ　薄いみどり*/
  --color-back:255,255,255;/*背景　白*/
  --color-link:231,78,106;/*ピンク*/
  --color-text:51,51,51;/*くろ*/
  --color-hover:51,51,51;/*くろ*/
  --grd: linear-gradient(90deg,rgba(var(--color-rgb),0) 0%, rgba(var(--color-rgb),1) 100%);
  --header: 100px;
  scroll-padding: var(--header);
}

/*body
------------------*/
body{
	margin:0px;
	padding:0px;
	background-color:#FFF;
	color:rgb(var(--color-text));
	-webkit-text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;
	font-family:"Noto Sans JP", "Noto Sans","ヒラギノ角ゴ Pro W3", Hiragino Kaku Gothic Pro, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", MS PGothic, sans-serif;
	line-height:1.5;
	font-size:16px;
}

/*wrapper
------------------*/
#WRAPPER{
	margin:0px;
	padding:0px;
	height:100%;
	overflow-x: hidden;
	position: relative;
}
.wrapper_fixed{
	padding-top:var(--header) !important;
}

.overlay {
	content: "";
	display: block;
	width: 0;
	height: 0;
	background-color: rgba(50,50,50,0.8);
	position: fixed;
	top: 0;
	left: 0;
	z-index: 10;
	opacity: 0;
	transition: opacity .5s;
}
.overlay.open {
	width: 100%;
	height:100vh;
	opacity: 1;
}
/*inner
------------------*/
.inner{
	margin:0 auto;
	overflow:hidden;
	box-sizing:border-box;
	width:94%;
}

@media screen and (min-width: 1024px){
	.inner{
		max-width: 1200px;
	}
}

/*header
---------------------------------------------------------------------*/
#header{
	top:-100px;
	position: sticky;
	z-index:20;
	width:100%;
	height:var(--header);
	padding:10px 2%;
	background-color: rgba(var(--color-back), 1);
}
#header.fixed{
	top: 0;
	position: fixed;
	margin: 0;
	background-color:rgba(var(--color-back), .8);
    transition: top 0.65s ease-in;
    -webkit-transition: top 0.65s ease-in;
    -moz-transition: top 0.65s ease-in;
	box-shadow:0 0 5px rgba(0,0,0,0.1);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
}
#header .inner{
	display:flex;
    align-items: center;
    justify-content:space-between;
}

#headerlogo{
	flex-shrink:0;
}
#headerlogo img{
	width:240px;
}
ul#header_menu{
	list-style:none;
	margin:5px 0;
	padding:0;
	display:flex;
    align-items: center;
    justify-content: flex-end;
}
ul#header_menu li{
	margin:0 0 0 5px;
	padding:0;
	flex-shrink:0;
}
ul#header_menu li img{
}
ul#header_menu li a{
	display:block;
 /*   width: 40px;
    height:40px;
	padding:10px;
	border-radius:50%;
	border:solid 1px rgba(255,255,255,1) ;*/
}
#navi_spmenu{
	position: relative;
	cursor: pointer;
    width: 50px;
    height:50px;
	z-index:100;
	border:solid 1px rgba(var(--color-rgb),1) ;
	border-radius:50%;
}
#navi_spmenu span{
    display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 14px;
    height: 2px;
    border-radius: 5px;
	background: rgba(var(--color-rgb),1) ;
  	width: 45%;
  }


#navi_spmenu span:nth-of-type(1) {
	top:15px;	
}

#navi_spmenu span:nth-of-type(2) {
	top:23px;
}

#navi_spmenu span:nth-of-type(3) {
	top:31px;
}


#navi_spmenu.active span:nth-of-type(1) {
    top: 17px;
    left: 13px;
    transform: translateY(6px) rotate(-45deg);
  	width: 45%;
}

#navi_spmenu.active span:nth-of-type(2) {
	opacity: 0;
}

#navi_spmenu.active span:nth-of-type(3){
    top: 29px;
    left: 13px;
    transform: translateY(-6px) rotate(45deg);
  	width: 45%;
}


#headernavi{
	flex-grow:2;
}
@media screen and (min-width: 1024px){

	.pcmenu{
		position:relative;
		overflow:hidden;
		display:flex !important;
		justify-content:flex-end;
		align-items:center;
		gap:1em;
	}
}
#header .pcmenu li{
	margin:0 5px;
	text-align:center;
	font-weight:bold;
}
#header .pcmenu li:not(.linkbutton) a{
	padding:5px 5px;
	display:block;
	display:flex;
	flex-wrap:wrap;
	justify-content:center;
	align-items:center;
	position:relative;
	height:3.5em;
	color:rgb(var(--color-text));
}

#header .pcmenu li:not(.linkbutton) a:after{
	display:block;
	position:absolute;
	bottom:0;
	content:"";
	height:3px;
	width:0;
	background:rgba(var(--color-rgb),1);
	border-radius:5px;
    transition: all .4s;
    width:100%;
    left: 0px;
    transition: 0.3s ease-in-out;
    bottom: 0;
	transform:scale(0);
}
#header .pcmenu li a:hover,
#header .pcmenu li a.current{
	color:rgba(var(--color-link), 1);
}
#header .pcmenu li a:hover:after,
#header .pcmenu li a.current:after{
	transform:scale(1);
}
#mainnavi {
	width: 320px;
	height:100vh;
	background-color: rgba(var(--color-sub), 1);
	position: fixed;
	top: 0px;
	right: 0;
	z-index:11;
	padding-top:90px;
	transform: translate(320px,0px);
	transition: all .5s;
}
#mainnavi.open {
	transform: translateZ(0);
	transition: all .5s;
}
.slidemenu{
	margin:0 auto;
	padding-bottom:2em;
	transition: all .5s;
}
.slidemenu ul{
	margin-left:2em;
}
#mainnavi.open .slidemenu{
	margin:0px auto 0;
}
.slidemenu > li{
	transition: all .5s;
}
#mainnavi.open .slidemenu li{
	height:auto;
}
.slidemenu > li{
	border-top:dotted 1px rgba(var(--color-rgb),1);
}
.slidemenu li a{
	display:block;
	padding:0.75em;
	position:relative;
	flex-grow: 2;
	color:rgba(var(--color-text),1);
}

.slidemenu a:after{
	display:block;
	content:"";
	border-top: solid 2px rgba(var(--color-rgb),1);
	border-right: solid 2px rgba(var(--color-rgb),1);
	width: 12px;
	height: 12px;
	position:absolute;
	right:15px;
	top: 50%;
	transform: translate(0, -50%) rotate(45deg);
}


/*totop
------------------*/

/*footer
------------------*/
#footer{
	padding:60px 0 30px;
	background-color:rgba(200,200,200, 1);
	text-align:center;
}
#footer .inner{
}
#footer h2{
	font-size: clamp(1.4rem, 0.5rem + 1.5vw, 1.6rem);
	font-weight:bold;
	margin:0 0 1em;
}
#footernavi ul li{
	margin:10px ;
}
#footernavi ul li img{
	border-radius:10px;
	width:90%;
}
.footer_address{
}
.footer_address dt{
	font-weight:bold;
}
.footer_address dd{
	margin:0 0 1em;
}
#footer #copyright{
	text-align:center;
	font-size:small;
	clear:both;
	margin:0px 0;
	padding:10px 0;
}





/*Common
------------------*/
/*main
------------------*/
#main{
	margin:0px auto;
	position:relative;
}
#mainimg{
}
h1#mainimg {
	margin:0 auto 00px;
	padding:0px 0 0;
	line-height:0;
	text-align:center;
	background-size:contain;
	position:relative;
}
h1#mainimg img{
	width:100%;
	position:relative;
	z-index:10;
}
/*maincol
------------------*/
#maincol{
	overflow:hidden;
	margin:0px auto;
	position:relative;
	padding:0px 0 0 0;
}
#maincol article{
	margin:0px 0;
	padding:0;
	position: relative;
}
#maincol article#about{
	background:rgba(var(--color-rgb), 1);
}
#maincol article#plan{
	background:#efefef;
}
#maincol article.back{
	background:rgba(var(--color-sub), 1);
}
#maincol article .inner{
	padding:40px 4%;
	position:relative;
	z-index:10;
}

p{
	margin:0 0 1em 0;
	padding:0;
}
h1,h2,h3{
	float:none;
	clear:both;
}
#main h2{
	font-size: clamp(1.4rem, 0.5rem + 1.5vw, 1.6rem);
	font-weight:bold;
	margin:0em 0 1rem;
	padding:0.25em 0;
}

#TOP{
	position:relative;
}
#TOP:after{
	content:'';
	height:40%;
	width:100%;
	top:25%;
	left:0;
	position:absolute;
	display:block;
	background:var(--grd);
}

.small{
	font-size:80%;
}
.large{
	font-size:120%;
}

.center{
	text-align:center !important;
}
.txtright{
	text-align:right !important;
}
.txtleft{
	text-align:left !important;
}


.clear{
	clear:both;
	float:none;
}
strong{
	font-weight:bold;
	font-size:1.1em;
}
em,
.red{
	font-style:normal;
	color:#ff3f30 !important;
}
.blue{
	color: #39a6ff !important;
}
.linkbutton a{
	background-color:rgba(var(--color-link), 1);
	color:#FFF !important;
	display:inline-block;
	padding:0.5em 2em;
	position:relative;
	border-radius:50px;
	box-shadow:5px 5px 10px rgba(0,0,0,0.1);
}
.linkbutton a:hover{
	text-decoration:none !important;
	background-color:rgba(var(--color-rgb), 1);
}
#main .linkbutton a{
	min-width:300px;
}

a{
	text-decoration: none;
}
a:hover{
	color:rgba(var(--color-link), 1);
	transition-duration: 0.2s;
}
#main a,
#footer a{
	color: rgba(var(--color-hover), 1);
	text-decoration: none;
	transition-duration: 0.2s;
}

#main a:hover,
#footer a:hover{
	text-decoration:underline;
}
#maincol a img{
	filter: Alpha(opacity=100); 
    -moz-opacity:1.0;
    opacity:1.0; 
	transition-duration: 0.2s;
}
#maincol a:hover img{
	filter: Alpha(opacity=85); 
    -moz-opacity:0.85;
    opacity:0.85; 
	transition-duration: 0.2s;
}
a.blank:not(a:has(img)):after{
	content:'';
	display:inline-block;
	vertical-align:middle;
	margin-left: 5px;
	height:1em;
	width:1em;
	background:url(../img/blank.svg) no-repeat center center;
	background-size:0.8em;
}
@media screen and (min-width: 1024px){
	.flex_box{
		display:flex;
		justify-content:space-around;
	}
}


@media screen and (min-width: 1024px){
	.pc{
		display:block;
	}
	.sp{
		display:none;
	}
}

@media screen and (max-width: 1023px){
	.pc{
		display:none;
	}
	.sp{
		display:block;
	}
}


@media print{

	body{
		width:960px !important;
	}
	#header,
	#header.fixed{
		position:relative !important;
	}
	#totop{
		display:none;
	}
	#footer #footernavi{
		/*display:none;*/
	}
	.flexslider{
		width:960px !important;
	}
	#topimage{
		position:relative !important;
	}
	#main{
		margin-top:0px;
	}
	.print{
		display:none;
	}
}





