@charset "utf-8";
/*
Theme Name: 台由
Description: 台由テーマファイル
Version: 1.0
Author: Future
Tags: 
*/

/*===============
var(--)
=================*/
:root {
	--inner-width: 1100px;
	--section-bg-gray: #f2f2f2;
}

/*===============
base
=================*/

* { box-sizing: border-box; }
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,
form,input,p,th,td {
margin:0;
padding:0;
}  
img {
	border-top-style: none;
	border-right-style: none;
	border-bottom-style: none;
	border-left-style: none;
	font-size: 0%;
	line-height: 0%;
	vertical-align: bottom;
    width: 100%;
    height: auto;	
}



html {
	overflow-y: scroll;
	font-size: 62.5%;
	scroll-padding-top:120px;	
}
body{
	font-size:1.6rem; /* =16px */

	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 400;
	font-style: normal;

	line-height: 1.8;
	color: #333333;
	margin: 0; padding: 0;
	overflow-x:hidden;
	position: relative;
}
@media screen and (max-width: 768px) {
	body {
		font-size:1.4rem;/* 14px*/
		background-image:none;
	}
}
@media screen and (max-width: 640px) {
	html,
	body { overflow-x: hidden; max-width: 100%; }
	}

a:link,
a:visited,
a:active{
	color: #333;
	text-decoration: underline;
}

a:hover{
	text-decoration: underline;
}

/* 横幅が768px以上で、電話番号リンクは無効 */
@media (min-width: 768px) {
	a[href*="tel:"] {
	pointer-events: none;
	cursor: default;
	text-decoration: none;
	}
}


ul,ol{
list-style: none;
}

/*clearfix*/
.clearfix:after,
.recruit_p:after
{  
visibility:hidden;/*見えなくする*/ 
height:0;/*見えなくする*/
display: block;/*block要素にする*/
font-size: 0;  
content: " ";  
clear: both;  

}  
* html .clearfix             { zoom: 1; } /* IE6 */  
*:first-child+html .clearfix { zoom: 1; } /* IE7 */


.mb0 { margin-bottom: 0 !important; }
.mb10 { margin-bottom: 10px !important; }
.mb15 { margin-bottom: 15px !important; }
.mb20 { margin-bottom: 20px !important; }

.mt50 { margin-top: 50px !important; }
.mt60 { margin-top: 60px !important; }

.al_left { text-align: left; }
.al_right { text-align: right; }
.al_center { text-align: center; }

.t_red { color: #ff0000; }

.no_border_btm { border-bottom: none !important; } 


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




@media screen and (max-width: 640px) {
	.pc { display: none !important; }
	.sp { display: block !important; }
	.scroll_x {
	  overflow-y: hidden;
	  overflow-x: scroll;
	-webkit-overflow-scrolling: touch;	
	}
	.scroll_x::-webkit-scrollbar {
	  height: 10px;
	}	
}


/*ページネーション*/
div.pagination {
	clear:both;
	padding:20px 0;
	position:relative;
	font-size:11px;
	line-height:13px ;
	background:none;
	margin:10px 0 20px;
	vertical-align: middle;
}

div.pagination span, .pagination a {
	display:block;
	float:left ;
	margin: 2px 2px 2px 0 ;
	padding:6px 9px 5px 9px ;
	text-decoration:none;
	width:auto ;
	color:#fff ;
	background: #666 ;
}

div.pagination a:hover{
	color:#fff ;
	background: #fdcd1a;
}

div.pagination .current{
	padding:6px 9px 5px 9px ;
	background: #fdcd1a;
	color:#fff ;
}

/* reCAPTCHAマーク　非表示 */
.grecaptcha-badge { visibility: hidden; }



/*---------------------------------------------------------------------------
　header .inner
---------------------------------------------------------------------------*/
/*==============================
.inner
================================*/
/* header {
  top: 0;
  left: 0;
  z-index: 9999;
  width: 100%;
  height: 220px;
	background: #fff;
  transition: .3s;
} */
/* header */
header {
	background-color: #fff;
    width: 100%;
	height: 160px;
	margin: 0 auto;
    padding: 0;
    line-height: 1;
    position: absolute; z-index: 999;
}
header * {  }

header .inner {
	/* position: relative; */
	width: 100%;
	max-width: 1400px;
	height: 120px;
	margin: 0 auto;
	padding: 20px 1%;
}

header .inner .logo {
	display: inline-block;
	font-size: 30px; color: #000;
	margin: 0 2em 0 0;
}
header .inner .logo img {
    max-width: 300px; height: auto;
}

header #mobile-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
}

@media screen and (max-width: 640px) {
	header { min-width:auto; }
	header .inner { 
		height: 60px;
		margin: 0 auto 0;
	}
	header .inner .logo img {
		width: auto;
		height: 50px;
	}	
}


/*==============================
#global-nav
================================*/
#global-nav > ul {
	margin: 0 270px 0 0;
    list-style: none;

	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
}

#global-nav > ul > li {
    display: inline-block;
	/* width: calc(100% / 8); */
	text-align: center;
	box-sizing: border-box;
	font-size: 1.0em;
	white-space: nowrap;
	position: relative;
	height: 120px;
	width: 40px;
	margin: 0 5px;
	
}
#global-nav > ul > li.li_yoyaku {
    display: none;
	
}
#global-nav ul li a::before {
	content: '';
	display: block;
	width: 2px;
	height: 10px;
	background: #999;
	position: absolute; left: calc(50% - 1px); top: 0; 
}
#global-nav ul li a {
	width: 100%; height: 100%; display: block;
	transition:all .3s;
	padding: 15px 0 0;
	position: relative;
	font-family: "Noto Serif JP", serif;
	font-weight: 300;
	text-decoration: none;
	-webkit-writing-mode: vertical-rl;
	writing-mode: vertical-rl;	
	line-height: 40px;
	text-align: left;
	transition: .3s;
}
#global-nav ul li a:hover {
	padding-top: 10px;
}


#global-nav ul li a > img {
	width: 100%; height: auto; display: block;
	transition: 0.2s ;
}

#top-head a.reservations {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
	line-height: 1.2;
	vertical-align: middle;
	text-decoration: none;
	text-align: left;
	width: auto;
	margin: 0 10px 0 20px;
	padding: 2.0rem 3rem;
	color: #fff;
	background-color: #467359;
	border: 1px solid #fff;
	box-sizing: border-box;
	transition: .3s;
	-webkit-writing-mode: horizontal-tb;
	writing-mode: horizontal-tb;
	width: 240px;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
}
#top-head.fixed a.reservations {
	display: none;
}

footer a.reservations {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-family: "Noto Serif JP", serif;
	font-weight: 500;
	line-height: 1.2;
	vertical-align: middle;
	text-decoration: none;
	text-align: left;
	width: auto;
	margin: 0 auto;
	padding: 2.0rem 3rem;
	color: #fff;
	background-color: #467359;
	border: 1px solid #fff;
	box-sizing: border-box;
	transition: .3s;
	-webkit-writing-mode: horizontal-tb;
	writing-mode: horizontal-tb;
	width: 240px;
}
#top-head a.reservations:hover,
footer a.reservations:hover {
	color: #467359;
	border: 1px solid #467359;
	background-color: #fff;	
	font-weight: normal;
	/* background-image: linear-gradient(to left, #C9DDF0 0%, #5F9AD2 100%); */
}
#top-head a.reservations img,
footer a.reservations img {
	margin: 0 10px 0 0;
	width: 30px;
}



#global-nav ul ul{
	display: block;
}


/*== 2・3階層目の共通設定 */

/*下の階層を持っているulの指定*/
#global-nav li.has-child ul{
    /*絶対配置で位置を指定*/
	position: absolute;
	left:0;
	top:30px;
	z-index: 4;
    /*形状を指定*/
	background:rgba(0,98,163,0.95);
    /*はじめは非表示*/
  visibility: hidden;
  opacity: 0;
    /*アニメーション設定*/
	transition: all .3s;
}
#global-nav li.has-child li a {
	display: block;
	text-decoration: none;
	color: #fff;
	padding:20px 35px;
	transition:all .3s;	
	/* border-bottom:solid 1px rgba(255,255,255,0.6); */
}
#global-nav li.has-child li a:hover {
	background:rgba(0,0,0,0.2);
}

#global-nav li.has-child li:last-child a {
	border-bottom:none;
}

/*hoverしたら表示*/
#global-nav li.has-child:hover > ul,
#global-nav li.has-child ul li:hover > ul,
#global-nav li.has-child:active > ul,
#global-nav li.has-child ul li:active > ul{
  visibility: visible;
  opacity: 1;
}

@media screen and (max-width: 1080px) {
	#top-head a.reservations {
		display: none;
	}
}

/*==============================
Fixed
================================*/

/* Fixed */
#top-head.fixed {
    margin-top: 0;
    top: 0;
    position: fixed;
    height: 100px;
    /* background: #fff;
    background: rgba(255,255,255,.95); */
    transition: top 0.65s ease-in;
    -webkit-transition: top 0.65s ease-in;
    -moz-transition: top 0.65s ease-in;
	 box-shadow: 0 10px 15px -10px;
}

#top-head.fixed #global-nav {
	position: absolute;
	/* 開いてないときは画面外に配置 */
	right: -100vw; top: 0px;
	/* background: rgba(147,189,81,0.98); */
	background: rgba(70,115,89,0.99);
	width: 100vw; height: 100vh;
	text-align: center;
	padding: 0 0;
	-webkit-transition: .5s ease-in-out;
	-moz-transition: .5s ease-in-out;
	transition: .5s ease-in-out;
	display: block;
	opacity: 0;
}
/* #global-nav スライドアニメーション */
#top-head.fixed.open #global-nav {
	/* #global-nav top + #mobile-head height */
	-moz-transform: translateX(-100vw);
	-webkit-transform: translateX(-100vw);
	transform: translateX(-100vw);
	opacity: 1;
}
#top-head.fixed.open #global-nav ul {
	list-style: none;
	position: static;
	right: 0;
	bottom: 0;
	font-size: 1.125em;
	margin: 0;
	padding: 100px 0 0;
}

#top-head.fixed.open #global-nav > ul > li {
	float: none;
	position: static;
	display: inline-block;
	width: 90%; max-width:none;
	height: auto;
	text-align: center;
	box-sizing: border-box;
	border-left: none; border-right: none !important;
	border-bottom: dotted 1px #fff;
	margin: 0 auto;
	padding: 5px 0;
	text-align: center;
}
#top-head.fixed.open #global-nav > ul > li.li_yoyaku {
	float: none;
	position: static;
	display: inline-block;
	width: 90%; max-width:none;
	height: auto;
	text-align: center;
	box-sizing: border-box;
	border-left: none;
	border-bottom: none;
	margin: 0 auto;
	padding: 5px 0;
	border: none;
}
#top-head.fixed.open #global-nav > ul > li.li_yoyaku a.reservations {
  display: block;
	position: relative;
	transform: translateY(0);
	display: flex;
	justify-content: center;
	padding: 1em;
	margin: 1em auto 0;	
	border: solid 1px #fff !important;
}

#top-head.fixed.open #global-nav > ul > li a:before {
	display: none;
}
#top-head.fixed.open #global-nav > ul > li a {
	height: auto;
	-webkit-writing-mode: horizontal-tb;
	writing-mode: horizontal-tb;
	color: #fff;
	padding: 15px 0 0 0;
	text-align: center;
}
#top-head.fixed.open #global-nav > ul > li a:hover {
	padding: 15px 0 0 0;
}

#top-head.fixed .inner { height: 100px; }

#top-head.fixed .header_right {
	display: none;
}
#top-head.fixed .inner .logo {
}
#top-head.fixed .inner .logo img {
	width: auto;
	height: 50px;
}	

/* Toggle Button */
#nav-toggle {
    display: none;
    position: absolute;
    right: 12px;
    /* top: 10px; */
    width: 40px;
    height: 40px;
    cursor: pointer;
    z-index: 101;
    padding: 5px 5px 0;
    background: #467359;
    border: solid 1px #fff;
}
#nav-toggle div {
    position: relative;
}
#nav-toggle span {
    display: block;
    position: absolute;
    height: 3px;
    width: 100%;
    background: #fff;
	border-radius: 50vh;
    left: 0;
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
}
#nav-toggle span:nth-child(1) {
    top: 2px;
}
#nav-toggle span:nth-child(2) {
    top: 11px;
}
#nav-toggle span:nth-child(3) {
    top: 20px;
}
#nav-toggle span:nth-child(4) {
    top: 22px;
	font-size: 6.0px;
	text-align: center;
}

#top-head.fixed #nav-toggle {
	display: block;
}
/* #nav-toggle 切り替えアニメーション */
#top-head.fixed.open #nav-toggle span:nth-child(1) {
	top: 12px;
	-webkit-transform: rotate(315deg);
	-moz-transform: rotate(315deg);
	transform: rotate(315deg);
}
#top-head.fixed.open #nav-toggle span:nth-child(2) {
	width: 0;
	left: 50%;
}
#top-head.fixed.open #nav-toggle span:nth-child(3) {
	top: 12px;
	-webkit-transform: rotate(-315deg);
	-moz-transform: rotate(-315deg);
	transform: rotate(-315deg);
}

@media screen and (max-width: 1080px) {
    header,
    header .inner {
        width: 100%;
        padding: 0;
		height: 60px;
    }
    #top-head {
        top: 0;
        position: fixed;
        margin-top: 0;
    }
    /* Fixed reset */
    #top-head.fixed {
        padding-top: 0;
		height: 65px;
    }
    #mobile-head {
        width: 100%;
        height: 60px;
        z-index: 999;
        position: relative;
    }
    #top-head.fixed .logo,
    #top-head .logo {
        position: absolute;
        left: 13px;
        top: 5px;
        width: 50%;
    }
	#top-head.fixed .inner { height: 60px; }
	#top-head.fixed .inner .logo {
	display: block;
	}
	#top-head .inner .logo img {
    width: auto; height: 50px;
	}
	#top-head .htel {
		display: none;
	}

    #global-nav {
        position: absolute;
        /* 開いてないときは画面外に配置 */
        right: -100vw; top: 0px;
        /* background: rgba(147,189,81,0.98); */
		background: rgba(70,115,89,0.95);
        width: 100vw; height: 100vh;
        text-align: center;
        padding: 0 0;
        -webkit-transition: .5s ease-in-out;
        -moz-transition: .5s ease-in-out;
        transition: .5s ease-in-out;
		display: block;
    }
    #global-nav ul {
        list-style: none;
        position: static;
        right: 0;
        bottom: 0;
        font-size: 14px;
		padding: 100px 0 0;
    }
	
    #global-nav > ul > li {
        float: none;
        position: static;
		display: inline-block;
		width: 90%; max-width:none;
		height: auto;
		text-align: center;
		box-sizing: border-box;
		border-left: none; border-right: none !important;
		border-bottom: dotted 1px #fff;
		margin: 0 auto;
		padding: 5px 0;
		text-align: center;
}



	
    #top-head #global-nav ul li a,
    #top-head.fixed #global-nav ul li a {
		width: 100%;
		display: block;
		color: #fff;
		padding: 1em 20px;
		font-size: 14px;
		text-align: center;
		text-decoration: none;
		-webkit-writing-mode: horizontal-tb;
		writing-mode: horizontal-tb;		
    }
	
	#global-nav > ul > li.li_yoyaku {
		float: none;
		position: static;
		display: inline-block;
		width: 90%; max-width:none;
		height: auto;
		text-align: center;
		box-sizing: border-box;
		border-left: none;
		border-bottom: none;
		margin: 0 auto;
		padding: 5px 0;
		border: none;
	}
	#global-nav > ul > li.li_yoyaku a.reservations {
		position: relative;
		transform: translateY(0);
		display: flex !important;
		justify-content: center;
		padding: 1em;
		margin: 1em auto 0;	
		border: solid 1px #fff !important;
	}	

	
	#top-head #global-nav ul li a::before {
		display: none;
	}

    #nav-toggle {
        display: block;
    }
    /* #nav-toggle 切り替えアニメーション */
    .open #nav-toggle span:nth-child(1) {
        top: 12px;
        -webkit-transform: rotate(315deg);
        -moz-transform: rotate(315deg);
        transform: rotate(315deg);
    }
    .open #nav-toggle span:nth-child(2) {
        width: 0;
        left: 50%;
    }
    .open #nav-toggle span:nth-child(3) {
        top: 12px;
        -webkit-transform: rotate(-315deg);
        -moz-transform: rotate(-315deg);
        transform: rotate(-315deg);
    }
    /* #global-nav スライドアニメーション */
    .open #global-nav {
        /* #global-nav top + #mobile-head height */
        -moz-transform: translateX(-100vw);
        -webkit-transform: translateX(-100vw);
        transform: translateX(-100vw);
	}

}

/* .has-child ul　ドロップダウンメニュー */
@media screen and (max-width: 1080px) {

	#global-nav li.has-child ul {
		position: relative;
		left:0;
		top:0;
		width:100%;
		visibility:visible;/*JSで制御するため一旦表示*/
		opacity:1;/*JSで制御するため一旦表示*/
		display:block;/*JSで表示させるため非表示に*/
		transition:none;/*JSで制御するためCSSのアニメーションを切る*/
		background: rgba(0,0,0,0.5);
		display: flex;
		justify-content: flex-start;
		flex-wrap: wrap;		
	}		
	#global-nav ul {
		display: block;
		margin: 0;
	}
	#global-nav li.has-child ul li { 
		width: 50% !important;
		position: relative;
	}
		#global-nav li.has-child ul li::before { 
			content: "";
			width: 10px; height: 10px;
			display: inline-block;
			border-left: solid 2px #fff;
			border-bottom: solid 2px #fff; 
			position: absolute; left: 20px; top: 10px;
	}
	#global-nav li.has-child ul li a {
		padding: 1em 20px 1em 40px !important;
	}
	
}



/*---------------------------------------------------------------------------
　footer
---------------------------------------------------------------------------*/
/*==============================
footer .inner
================================*/
footer {
	background: #467359;
	font-family: "Noto Serif JP", serif;
	font-weight: 400;	
	color: #fff;
}

footer .inner {
	width: 100%;
	max-width: 1100px;
	margin: 0 auto;
	padding: 3em 0;	
}

footer .tel,
footer .time {
	text-align: center;
}
footer .company_name {
	font-weight: bold;
}
footer .address-info {
	text-align: center;
	margin: 3em auto;
}
footer .address-info img {
	width: 30%; height: auto;
	max-width: 180px;
	margin: 0 auto 20px;
}
footer .address-info a {
	text-decoration: none;
	color: #fff;
}


footer .footer_content {
	background-color: #0071bb;
}
footer .footer_content .inner {
	width: 100%;
	max-width: 1400px;
	margin: 0 auto;
	padding: 3em 0;	
}
.wrap_fnav {
	display: flex;
}
.fnav {
	display: flex;
	justify-content: space-between;
	border-bottom: solid 1px #fff;
	width: 100%;
}
.fnav li { 
	list-style: none;
	line-height: 1;
	padding: 0 1em;
	margin: 0 0 2em;
}

.fnav li a {
	color: #fff; text-decoration: none;
	font-size: 	1.0em;
	transition: .3s;
	padding: 1em 0;
}
.fnav li a:hover {
	text-decoration: underline;
}

.fnav li ul {
	border-left:solid 1px #000;
	margin: 10px auto 15px;
	padding: 5px 0;
}
.fnav a.links_hp {
	position: relative;
	padding: 0 30px 0 0;
}
.fnav a.links_hp::after {
	content: "";
	background: url("images/icon_link.png");
	background-size: cover;
	width: 20px; height: 16px;
	position: absolute; right: 0; top: 50%; transform: translateY(-50%)}

@media screen and (max-width: 640px) {
	footer .inner { 
		width: 100%; margin: 0 auto; padding: 1.5em 2.5%;
		text-align: center;
	}
	footer .inner .logo {
		width: 50%;
	}	
}






.copyright {
	color: #fff;
	font-size: 80%;
	padding: 1em;
	text-align: center; }



@media screen and (max-width: 640px) {
	footer .wrap_info {
		justify-content: center;
		margin-top: 0;
	}	
	.wrap_fnav {
		justify-content:center;
	}	
	footer .fnav {
		display: none;
	}	
}


.fnav_sp {
    width: 100%;
    position: fixed;
    bottom: 0%;
    left: 0%;
    z-index: 9998;
	display: none;
	background: #59b0c0;
}
.fnav_sp ul {
	display: flex;
	justify-content: center;
}
.fnav_sp li {
    width: calc(100% / 1);
	max-width: 300px;
    margin: 0 auto;
}
@media screen and (max-width: 640px) {
	.fnav_sp {
		display: block;
	}
}
