
@charset "UTF-8";

html{
	font-size: 10px;
	scroll-behavior: smooth;
}

html.pc .sp{ display: none !important; }
html.sp .pc{ display: none !important; }

body{
	padding: 0;
	margin: 0;
	font-size: 1.8rem;
	font-weight: 300;
	line-height: 1.6;
	/*letter-spacing: 1.5px;*/
	overflow-x: hidden;
	scroll-behavior: smooth;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "Hiragino Sans", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	-webkit-font-smoothing: antialiased;
	-webkit-text-size-adjust: 100%; /* iPhoneだけ文字が大きくなる現象を防ぐ */
	font-feature-settings: "palt"; /* 文字詰め（フォントにカーニング情報が含まれる場合） */

	 /* iPhoneで上下のバーを抜いた高さ */
	height: -webkit-fill-available;
	height: -moz-available;
}

::-webkit-input-placeholder{ color: #bbb; }
:-moz-placeholder          { color: #bbb; }
:-ms-input-placeholder     { color: #bbb; }

h1{
	margin: 50px 0;
}

h2{
	font-size: 1.8rem;
	margin: 0;
}

h3{
	font-size: 1.5rem;
	font-weight: normal;
	margin: 20px 0;
}

h4{
	font-size: 1.2rem;
	font-weight: normal;
	margin: 15px 0;
}

img{
	vertical-align: middle;
	max-width: 100%;
}
img.double{
	display: none;
}
img.double.show{
	display: inline-block;
}

iframe{
	vertical-align: bottom;
	max-width: 100%;
}

a,
a:link,
a:visited{
	color: inherit;
	text-decoration: underline;
}
a:hover{
	text-decoration: none;
}

/* IE6,7 対策 */
a img{
	border-style: none;
}

a.fade{
	display: inline-block;
	text-decoration: none;
	-webkit-transition: 0.2s ease-in-out;
	   -moz-transition: 0.2s ease-in-out;
	     -o-transition: 0.2s ease-in-out;
	        transition: 0.2s ease-in-out;
}

a.fade:hover{
	opacity: 0.6;
	filter: alpha(opacity=60);
	text-decoration:none;
}

#page{
	min-height: 100vh;
}

header{
	display: none;
}
#page.index header{
	display: flex;
	justify-content: space-between;
	padding: 30px 70px 0 80px;
	font-weight: bold;
}
html.sp header,
html.sp #page.index header{
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	position: fixed;
	left: 0;
	top: 70px;
	box-sizing: border-box;
	width: 100%;
	height: calc(100vh - 70px);
	padding: 80px 20px 50px;
	background-color: #9ba6a2;
	z-index: 1000;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.3s linear;
}
html.sp #open_nav:checked ~ header{
	opacity: 1;
	pointer-events: auto;
}

header a,
header a:link,
header a:visited{
	text-decoration: none;
	color: #fff;
}

#site-navigation{
	flex-grow: 1;
	display: flex;
	/*justify-content: space-between;*/
	align-items: center;
	margin: 0 0 0 70px;
}
html.sp #site-navigation{
	flex-grow: 0;
	flex-direction: column;
	margin: 0 0 100px 0;
}
header a{
	text-decoration: none;
	vertical-align: bottom;
	font-size: 1.6rem;
	line-height: 1;
	white-space: nowrap;
	transition: 0.2s ease-in-out;
}
#site-navigation a{
	font-weight: bold;
	padding: 5px 10px;
	margin: 0 10px;
}
html.sp #site-navigation a{
	font-size: 2.5rem;
	margin: 20px 0;
}
header a:hover{
	background-color: rgba(255,255,255, 0.3);
	box-shadow: 0 0px 0 10px rgba(255,255,255, 0.3);
}
html.sp #site-navigation .nav1 a:hover{
	box-shadow: 0 0 0 10px #eee;
}

.tel_sns{
	display: flex;
	align-items: center;
}
html.sp .tel_sns{
	flex-direction: column;
	justify-content: center;
}
.tel_sns a{
	display: inline-flex;
	justify-content: center;
	align-items: center;
	font-family: refrigerator-deluxe, sans-serif;
	font-weight: 800;
	font-size: 2.3rem;
	color: #fff;
	margin: 0 6px 0 0;
	border-radius: 100px;
}
html.sp .tel_sns a{
	font-size: 2.9rem;
}
.tel_sns a.tel{
	display: inline-block;
	padding: 0 7px;
	margin: 0 10px 0 0;
}
.tel_sns .sns{
	display: flex;
	align-items: center;
}
html.sp .tel_sns .sns{
	margin: 30px 0 0;
}
html.sp .tel_sns .sns img{
	height: 30px;
}
html.sp .tel_sns .sns a{
	margin: 0 15px;
}

.left_bar{
	display: flex;
	flex-direction: column;
	position: fixed;
	z-index: 1000;
	width: 80px;
	height: 100vh;
	background-color: #fff;
}
html.sp .left_bar{
	/*display: none;*/
	flex-direction: row;
	width: 100%;
	height: 70px;
}
.left_bar.opacity{
	/*background-color: rgba(255,255,255, 0.5);*/
	/*opacity: 0.5;*/
	transition: background-color 0.2s linear;
}
.left_bar.opacity:hover{
	/*background-color: rgba(255,255,255, 1);*/
	/*opacity: 1;*/
}
.left_bar .title{
	flex-grow: 1;
	text-align: center;
	padding: 10px 0 0 0;
}
html.sp .left_bar .title{
	display: flex;
	/*justify-content: center;*/
	align-items: center;
	text-align: left;
	padding: 0 0 0 10px;
}
html.sp .left_bar .title img{
	width: 200px;
}
.left_bar a{
	transition: 0.15s linear;
}
.left_bar a:hover{
	opacity: 0.7;
}
.left_bar .omitumori{
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	text-decoration: none;
	font-size: 1rem;
	height: 80px;
	color: #4b5e59;
	background-color: #d7dbdb;
}
html.sp .left_bar .omitumori{
	height: auto;
	width: 70px;
}
.left_bar .contact{
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	text-decoration: none;
	font-size: 1rem;
	height: 80px;
	color: #fff;
	background-color: #4b5e59;
}
html.sp .left_bar .contact{
	height: auto;
	width: 70px;
}
.left_bar .omitumori img,
.left_bar .contact img{
	margin: 0 0 5px 0;
}
.left_bar .contact img{
	padding: 3px 0 2px 0;
}

#open_nav{
	display: none;
}

label[for="open_nav"] {
    /*position: fixed;*/
    top: 10px;
    right: 10px;
    display: flex;
    /*height: 70px;*/
    width: 70px;
    border-radius: 5px;
    justify-content: center;
    align-items: center;
    z-index: 1100;
    background-color: #fff;
}
html.pc label[for="open_nav"] {
    display: none;
}
label[for="open_nav"] span,
label[for="open_nav"] span:before,
label[for="open_nav"] span:after {
    content: '';
    display: block;
    height: 1px;
    width: 35px;
    border-radius: 5px;
    background-color: #000;
    position: absolute;
}
label[for="open_nav"] span:before {
    bottom: 13px;
}
label[for="open_nav"] span:after {
    top: 13px;
}
label[for="open_nav"] img{
	width: 70px;
}
#open_nav:checked ~ label[for="open_nav"] {
    background-color: transparent;
}
#open_nav:checked ~ label[for="open_nav"] span {
    background-color: rgba(255, 255, 255, 0);/*メニューオープン時は真ん中の線を透明にする*/
}
#open_nav:checked ~ label[for="open_nav"] span::before {
    bottom: 0;
    transform: rotate(45deg);
}
#open_nav:checked ~ label[for="open_nav"] span::after {
    top: 0;
    transform: rotate(-45deg);
}
.site-header .sp_gnav{
	display: none;
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100vh;
	background-color: #bdad77;
	z-index: 1100;
}
label[for="open_nav"] .nav_close{
	/*display: none;*/
}
#open_nav:checked ~ label[for="open_nav"] .nav_open{
	/*display: none;*/
}
#open_nav:checked ~ label[for="open_nav"] .nav_close{
	/*display: block;*/
}

footer{
	position: sticky;
	top: 100vh;
	font-weight: bold;
	padding: 50px 0 0;
}
html.sp footer{
}
footer .row1{
	display: flex;
	justify-content: space-between;
	align-items: center;
}
html.sp footer .row1{/* flex-direction: column; */flex-wrap: wrap;justify-content: center;}
footer .address{
	font-size: 1.3rem;
	line-height: 1.5;
}
html.sp footer .address{text-align: center;margin: 15px 0 30px;}
footer .button_area{
	display: flex;
}
html.sp footer .button_area{margin: 0 20px 0 0;}
footer .button_area a{
	margin: 0 8px;
}
html.sp footer .button_area a{
}
a.button2{
	display: inline-flex;
	align-items: center;
	text-decoration: none;
	font-weight: bold;
	font-size: 1.6rem;
	line-height: 1;
	letter-spacing: 0.1em;
	transition: 0.3s ease-in-out;
	box-shadow: 0 0 0 7px #fff inset;
}
html.sp a.button2{
}
a.button2:hover{
	color: #fff;
	background-color: #000;
	box-shadow: 0 0 0 0px #fff inset;
}
html.sp a.button2:hover{
}
a.button2:before{
	content: url(/img/common/footer/button2_b.svg);
	margin: 0 20px 0 0;
}
html.sp a.button2:before{
}
a.button2:after{
	content: url(/img/common/footer/button2_a.svg);
	margin: 0 0 0 20px;
}
html.sp a.button2:after{
}
footer .sns a{
	text-decoration: none;
	margin-left: 10px;
	filter: brightness(0);
	transition: 0.15s linear;
}
html.sp footer .sns a{
}
footer .sns a:hover{
	filter: brightness(1);
}
html.sp footer .sns a:hover{
}

footer .row2{
	color: #fff;
	background-color: #9ba6a2;
	padding: 25px 0 100px;
	margin: 30px 0 0;
}
html.sp footer .row2{padding: 25px 0 30px;}
footer .row2 .inner{
	display: flex;
	justify-content: space-between;
	align-items: center;
}
html.sp footer .row2 .inner{flex-direction: column;}
footer .row2 nav{
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 1.2rem;
}
html.sp footer .row2 nav{flex-direction: row-reverse;align-items: normal;justify-content: center;margin: 0 0 40px;width: 100%;}
footer .row2 nav a{
	text-decoration: none;
	color: #fff;
	margin: 0 15px;
}
html.sp footer .row2 nav a{writing-mode: vertical-rl;font-feature-settings: initial;}
footer .row2 nav a:hover{
	text-decoration: underline;
}
html.sp footer .row2 nav a:hover{
}
footer .row2 nav .block{
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin: 0 10px;
}
html.sp footer .row2 nav .block{flex-direction: row-reverse;align-items: normal;}
footer .row2 nav .block a{
	margin: 0 5px;
}
html.sp footer .row2 nav .block a{
}
html.sp footer .row2 nav .block a.sub{
	position: relative;
	margin: 0em 5px 0;
}
html.sp footer .row2 nav .block a.sub:before{
	/* content: ""; */
	display: inline-block;
	height: 0.5em;
	width: 150%;
	border-top: 1px solid #fff;
	border-left: 1px solid #fff;
	position: absolute;
	left: 9px;
	top: -10px;
}
html.sp footer .row2 nav .block a.sub:nth-of-type(2):before{
	width: 100%;
	left: 9px;
}

.copyright{
	text-align: right;
	font-weight: normal;
	font-size: 1rem;
	/*margin: 70px 0 0;*/
}
html.sp .copyright{
}

.gototop{
	position: fixed;
	right: 15px;
	bottom: 15px;
	opacity: 0;
	pointer-events: none;
}
.gototop.show{
	opacity: 1;
	pointer-events: auto;
}

.page_width1{
	max-width: 90%;
	width: 1060px;
	margin: 0 auto;
}
.page_width2{
	max-width: 90%;
	width: 870px;
	margin: 0 auto;
}
.page_width1 .page_width2{
	max-width: 100%;
}
@media (max-width: 1235px) {
	.page_width1{
		max-width: 90%;
		width: 1060px;
		margin: 0 25px 0 auto;
	}
}


.contents{
}

.anchor_point{
	position: relative;
}
html.sp .anchor_point{
	top: -80px;
}



