@charset "UTF-8";


@import url('https://fonts.googleapis.com/css?family=Montserrat');
@import url('https://fonts.googleapis.com/css?family=Noto+Sans');

*{
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
body{
	font-family: 'Noto Sans', sans-serif;
	font-size:14px;
	letter-spacing:1.5px;
	color:#353E49;
	font-weight:500;
}
a{
	color:#000;
	text-decoration:none;
	border-bottom:1px dotted #000;
	-webkit-transition: all 0.3s;
	-moz-transition: all 0.3s;
	-ms-transition: all 0.3s;
	-o-transition: all 0.3s;
	transition: all 0.3s;
}
a:hover{
	border-bottom:1px solid #888888;
}
.noborder{
	border:0;
}
a.blank{
	background-image:url(../img/icon_blank.svg);
	background-repeat:no-repeat;
	background-position:right center;
	padding-right:18px;
}
img{
	-webkit-backface-visibility: hidden;
}


/* ======================================================================
   HEADER
====================================================================== */
/* header */
header{
	text-align:center;
	position:relative;
}
header ul{
}
header li img{
	width:100%;
}
header h1{
	position:absolute;
	top:0px;
	right:0px;
	bottom:0px;
	left:0px;
	margin:auto;
	z-index:30;
}

#viewer {
	margin: 0 auto;
	width: 100%;
	text-align: left;
	overflow: hidden;
	position: relative;
}

#viewer img {
	top: 0;
	left: 0;
	width: 100%;
	position: absolute;
}

/* nav */
nav{
	position:fixed;
	top:0;
	left:0;
	font-family:'Montserrat', sans-serif;
	line-height:1;
	width:100%;
	background-color: rgba(255,255,255,0.9);
	z-index:99999;
}
nav .logo{
	float:left;
}
nav .logo a{
	border:0;
	padding:0;
}
nav .logo img{
	width:180px;
	height:50px;
}
.fixed {
	display:block;
	top:0;
	left:0;
}




/* ======================================================================
   MAIN
====================================================================== */
main{
	line-height:1.8;
}
main h1{
	font-family:'Montserrat', sans-serif;
	font-weight:500;
	font-size:180%;
	text-align:center;
	margin-bottom:30px;
}
h2{
	font-size:180%;
}
h3{
	font-size:120%;
}
main p{
	line-height:2.2;
	margin-bottom:30px;
}
main ul{
	margin:0 0 30px 30px
}
main ul li{
	line-height:2.2;
}
.container{
	margin:auto 0;
}


h1.kv{
	margin:72px 0 0 0;
	width:100%;
	height:500px;
	background-size:cover;
	background-position:center center;
	color:#ffffff;
	font-size:60px;
	line-height:1;
	display: flex;
  justify-content: center;
  align-items: center;
	text-shadow: rgba(0,0,0,0.1) 0 0 3px;
}

.price{
	border:2px solid #353E49;
	padding:20px;
	text-align:center;
	font-size:120%;
	margin-bottom:30px;
	font-weight:600;
	background:#fff;
}
.price strong{
  font-size: 200%;
}

.tab{
	width:100%;
	display:table;
	table-layout:fixed;
	margin:0;
	text-align:center;
	font-size:16px;
}
.tab li{
	display:table-cell;
	width:25%;
	font-weight:600;
	list-style-type:none;
	margin-right:20px;
	border-right:1px solid #ebeff5;
}
tab li:last-child{
	border-right:none;
}
.tab li a{
	background:#353E49;
	color:#fff;
	width:100%;
	padding:10px;
	display:block;
	border-bottom:none;
}
.tab li.active a{
	background:#fff;
	color:#353E49;
}
.tab-contents{
	border-radius:5px;
	background:#ffffff;
	display:block;
}
.tab-contents > div{
	padding:30px;
}

/* table */
.table{
	line-height:2.4;
	margin-bottom:60px;
}
.table dd{
	font-size:110%;
}

/* HOME
------------------------------------------------------------------------ */


#home .about{
	background:#ebeff5;
  padding-top: 0;
}
#home .kv{
  width: 100%;
  height: 500px;
  margin-bottom: 30px;
}
#home .kv img{
  width: 100%;
  height: 500px;
  object-fit: cover;
}

#home .concept h3{
	margin-bottom:30px;
}
#home .facility dd{
  text-align: center;
}

#home .facility dt{
  position: relative;
  width: 250px;
  height: 250px;
  border-radius: 50%;
  line-height: 250px;
  background: #ddd;
  overflow: hidden;
  margin-bottom: 20px;
}
#home .facility dt img{
  object-fit: cover;
  height: 100%;
}

#home #viewer{
	width:100%;
	position:relative;
}
#home #viewer img{
	position: absolute; 
	top:0;
	bottom:0;
	right:0;
	left:0;
}

/* access */
#home .access {
	text-align:center;
	margin:0;
	padding:0;
}

/**/
#home .lead .info{
	border:2px solid #353E49;
	padding:20px;
	text-align:center;
	font-size:120%;
	margin-bottom:30px;
	font-weight:600;
	background:#fff;
}
#home .lead .info p{
  margin: 0;
}


/* ABOUT
------------------------------------------------------------------------ */
#about .kv.omoya{
	background-image:url(../../about/img/omoya_kv.jpg);
}
#about .kv.hanare{
	background-image:url(../../about/img/hanare-kv.jpg);
}
#about .kv.koya{
	background-image:url(../../about/img/koya_kv.jpg);
}
#about h1.koya-guideline{
  padding-top: 120px;
}

/* room / booking */
#about .room,
#about .rental,
#about .aboutNavi{
	background: #ebeff5;
}

#about .gallery dd{
  margin-bottom: 10px;
}

/*aboutNavi*/
#about .aboutNavi{
}
#about .aboutNavi dd{
  text-align: center;
}
#about .aboutNavi dt{
  position: relative;
  width: 250px;
  height: 250px;
  border-radius: 50%;
  line-height: 250px;
  background: #ddd;
  overflow: hidden;
  margin-bottom: 20px;
}
#about .aboutNavi dt img{
  object-fit: cover;
  height: 100%;
}
/*
#about .aboutNavi dt span{
  position: absolute;
  left: 0;
  top:0;
  width: 250px;
  height: 250px;
  line-height: 250px;
  text-align: center;
  font-size: 180%;
  font-weight: bold;
  color: #fff;
  text-shadow: 1px 0px 5px #000;
}*/


/* working
------------------------------------------------------------------------ */
#working .kv{
	background-image:url(../../working/img/kv.jpg);
}
#working .kv.oyako{
	background-image:url(../../working/img/oyako-kv.jpg);
}
#working .tag{
  border-radius: 10px;
  background: #ebeff5;
  font-size: 12px;
  padding: 2px 6px;
  white-space: nowrap;
}

/*  */
#working .plan1,
#working .josei{
	background: #ebeff5;
}
#working .plan2{
}


/* plan */
#working .price{
  margin-bottom: 30px;
}
#working .price dl{
  margin-bottom: 30px;
}
#working .price dt{
  border-bottom: 3px solid #353E49;
  padding-bottom: 10px;
  margin-bottom: 10px;
  text-align: center;
  font-weight: bold;
  font-size: 18px;
}
#working .price dd{
  text-align: center;
}
#working .price dd strong{
  font-size: 32px;
}


/* josei */
#working .josei{
	/*background: #ebeff5;*/
}
#working .josei.oyako{
	background: #fff;
}
#working .josei table{
  border-collapse: collapse;
  margin: auto;
  margin-bottom: 60px;
}
#working .josei th,
#working .josei td{
  padding: 30px;
  border-bottom: 1px solid #dddddd;
}
#working .josei th{
  text-align: right;
}

/* activity
------------------------------------------------------------------------ */
#activity .kv{
	background-image:url(../../working/img/kv.jpg);
}
#activity #aroma .kv{
	background-image:url("../../activity/img/aroma_kv.jpg");
}

#activity .sup{
	background: #ebeff5;
}

#activity .plan{
  display: flex;
}
#activity .plan h2{
  text-align: left;
  margin-bottom: 30px;
}
#activity .plan dl{
  margin-bottom: 30px;
}
#activity .plan dt{
  font-weight: bold;
}
#activity .plan .pic{
  widows: 300px;
  margin-right: 30px;
}

/* FOOD
------------------------------------------------------------------------ */

#food .kv{
	background-image:url(../../food/img/kv.jpg);
}
#food .gallery ul{
  margin-bottom: 0;
}

#food .filer,
#food .rental,
#food .catering{
	background: #ebeff5;
}
#food .restaurant{
  text-align: center;
}

/* DELIVERY
------------------------------------------------------------------------ */
#delivery .kv{
	background-image:url(../../delivery/img/kv.jpg);
  background-position: left bottom;
}
#delivery .sagawa{
	background: #ebeff5;
  
}
#delivery .onomichibase{
  
}
#delivery .col{
  border:1px solid #ddd;
  padding: 20px 20px 1px 20px;
  margin-bottom: 20px;
}


/* ACCESS
------------------------------------------------------------------------ */
#access .kv{
	width:100%;
	line-height:1;
	position:relative;
}
#access .kv .map{
	width:100%;
}
#access .kv h1{
	position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%); /* Safari用 */
  transform: translate(-50%, -50%);
	font-size:60px;
}

#access .col{
  border:1px solid #ddd;
  padding: 20px 20px 1px 20px;
  margin-bottom: 20px;
}

#access .root{
	background: #ebeff5;
}
#access .localroot{
}
#access p + ul{
	margin-top:-30px;
}


/* BOOKING
------------------------------------------------------------------------ */
#booking{
	margin-top:90px;
}

/**/
#booking .price{
  font-size: 120%;
  font-weight: bold;
  border: none;
  margin-bottom: 20px;
}
#booking .price dl{
  border: 5px solid #353E49;
  background: #ffffff;
}
#booking .price dt{
  background:#353E49;
  color: #ffffff;
  height: 100%;
  padding: 10px 20px;
  text-align: center;
}
#booking .price dd{
  padding: 10px 20px;
  text-align: center;
}
#booking .price .plus{
  text-align: center;
  font-size: 60px;
  font-weight: lighter;
  margin: 0 20px;
}
#booking .message{
	padding:20px;
	text-align:center;
	font-size:120%;
	margin-bottom:30px;
	font-weight:600;
	background:#fff;
}

#booking .price-table{
  width: 100%;
  max-width: auto;
  border-collapse: collapse;
  margin-bottom: 30px;
}
#booking .price-table td,
#booking .price-table th{
  border-bottom:1px solid #dddd;
  padding: 10px;
  text-align: center;
}
#booking .price-table .note{
  font-size: 10px;
}

/* booking */
#booking .form h3{
	margin-bottom:20px;
}
#booking .usage{
	background: #ebeff5;
}

/* yadokari */
#booking .yadokari{
	background: #ebeff5;
}
#booking .yadokari h2 img{
	width:60px;
}

/* CONTACT
------------------------------------------------------------------------ */
#contact {
	margin-top:90px;
}

/* form
----------------------------------------------------------------------------- */
input[type="text"], 
input[type="email"], 
input[type="tel"], 
input[type="date"], 
input[type="time"],
input[type="number"], 
textarea{
	margin: 4px;
	padding:14px 8px;
	height: auto;
	line-height: 1;
	vertical-align:middle;
	outline: none;
	-webkit-transition: all .5s;
	-moz-transition: all .5s;
	transition: all .5s;
	border: 1px solid #ebeff5;
	background:#ebeff5;
	font-size:100%;
	width:100%;
	border-radius:2px;
}
input[type="date"]{
	width:200px;
}
input[type="time"]{
	width:100px;
}
input[type="number"]{
	width:80px;
}
textarea{
	line-height:1.6;
}
input[type="text"]:focus,
textarea:focus{
	box-shadow: 0 0 5px #9fcdfb;
	border: 1px solid #9fcdfb;
	background:#fff;
}

/* input type="radio" のみ */
/* input type="checkbox" のみ */
input[type="radio"],
input[type="checkbox"]{
	position: relative;
	width:16px;
	height:16px;
	border:1px solid #cccccc;
	background:#ffffff;
	vertical-align:-0.2em;
	margin:auto 4px;
}
input[type="radio"]{
	border-radius:30px;
}
input[type="checkbox"]{
	border-radius:2px;
}

input[type="radio"]:checked:after,
input[type="checkbox"]:checked:after{
	content: "";
	position: absolute;
	top: 50%;
	left: 2px;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	display: block;
}

input[type="radio"]:checked:after{
	width: 10px;
	height: 10px;
	margin-top: -5px;
	background: #419bf9;
	border-radius: 30px;
}
input[type="checkbox"]:checked:after{
	width: 16px;
	height: 8px;
	margin-top: -8px;
	border-left: 3px solid #419bf9;
	border-bottom: 3px solid #419bf9;
	-webkit-transform: rotate(-45deg);
	-ms-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

.err {
	position: relative;
	display: inline-block;
	padding: 4px 20px;
	width: auto;
	min-width: 115px;
	color: #ffffff;
	background:#ed0e2d;
	z-index: 0;
	border-radius: 3px;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	font-size:12px;
}
.err:after {
	content: "";
	position: absolute;
	top: -10px; left: 30px;
	margin-left: -10px;
	display: block;
	width: 0px;
	height: 0px;
	border-style: solid;
	border-width: 0 10px 10px 10px;
	border-color: transparent transparent #ed0e2d transparent;
}


/* ======================================================================
   FOOTER
====================================================================== */
footer {
	background:#353E49;
	color:#ebeff5;
}

footer .info{
	line-height:1.8;
	font-size:12px;
}
footer .info img{
	width:180px;
	margin-bottom:10px;
}

footer .f-nav a{
  color: #ebeff5;
  border-color: #353E49
}
footer .f-nav a:hover{
  border-color: #ebeff5;
}
footer .f-nav ul{
  list-style: none;
  margin: 0 0 20px 0;
  display: flex;
}

footer .f-nav .blank{
	background-image:url(../img/icon_blank-white.svg) ;
	background-repeat:no-repeat;
	background-position:right center;
	padding-right:20px;
}

footer .sns li{
	display:inline-block;
}
footer .sns a{
	border:0;
	padding:0;
}
footer .sns a:hover img{
	filter:alpha(opacity=80);
	-moz-opacity: 0.8;
	opacity: 0.8;
}

footer .copyright{
	font-size:60%;
	font-family:'Montserrat', sans-serif;
	letter-spacing:1.5px;
	font-weight:bold;
}

/* pagetop */
footer .pagetop a {
	display:block;
	border:1px solid #ddd;
	text-decoration: none;
	text-align: center;
	vertical-align:middle;
	display: block;
	width:40px;
	height:40px;
	line-height:42px;
	border-radius: 50%;
	margin-bottom:30px;
}
footer .pagetop a:hover {
	border-color:#000;
	background-color:#000!important;
}
footer .pagetop a img{
	width:24px;
}

		

/* ======================================================================
   汎用
====================================================================== */
/**/
.center{
	text-align:center;
}
.right{
	text-align:right;
}
.left{
  text-align: left!important;
}


/**/
.note{
	font-size:12px;
	line-height:1.8;
}


/**/

.btn{
	padding:14px 50px;
	background-color:#353E49;
	border:0;
	color:#fff;
	text-decoration:none;
	display:inline-block;
	font-family:'Montserrat', sans-serif;
	line-height:1;
	border-radius:3px;
	font-size:16px;
	white-space:nowrap;
	cursor:pointer;
  text-align: center;
}
.btn:hover{
	background-color:#000;
	border:0;
	cursor:pointer;
}
.btn.blank{
	background-image:url(../img/icon_blank-white.svg) ;
	background-repeat:no-repeat;
	background-position:right 30px center;
	padding-right:50px;
}
.btn.send{
	background-color:#dd6f03;
}
.btn.send:hover{
	background-color:#be6e05;
}

.btn +.btn{
	margin-left:20px;
}
nav .btn,
.btn.small{
  font-size: 14px;
	padding:10px 25px;
  margin-top: -7px;
}

/* cleafix */
.cf:before,
.cf:after {
    content: " ";
    display: table;
}

.cf:after {
    clear: both;
}

.cf {
    *zoom: 1;
}

/**/
.red{
	color:#d72e45;}

.bxslider{
  margin: 0;
}