@charset "UTF-8";
/* CSS Document */

@font-face {
  font-family: "YuGothic M";
  src: local("Yu Gothic Medium");
}

/* =================================
 reset
================================= */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, main {
	display: block;
}
body {
	line-height: 1;
	color:#333;
	position: relative;
}
ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
img {
	display: block;
}
p{
	line-height: 1.8em;
}
iframe {
	vertical-align: bottom;
	border: 0;
}
table th,
table td {
	vertical-align: top;
}
input,
/*select,*/
textarea,
button {
	/*-webkit-appearance: none;*/
	-moz-appearance: none;
}
/*select::-ms-expand {
	display: none;
}*/
*, :after, :before {
	box-sizing: border-box;
}

@media screen and (min-width: 769px) {
a[href^="tel:"] {
    pointer-events: none;
}
}
/* =================================
clearfix
================================= */

.clearfix:after{
	content:".";
	display:block;
	height:0;
	clear:both;
	visibility:hidden;
}
.clearfix{
	display:inline-table;
	min-height:1%;
}
/* \*/
html .clearfix{
	* height:1%;
}
.clearfix{
	display:block;
}
/* */
.clear {
	clear: both;
}

/* =================================
 画像サイズ（レスポンシブ仕様）
================================= */
img.img100{
	width:100%;
	max-width: 100%;
	line-height: 0;
	vertical-align: bottom;
	display: block;
}
img.imgInner {
	max-width: calc(100% - 30px);
	line-height: 0;
	vertical-align: bottom;
	display: block;
	margin-left: auto;
	margin-right: auto;
}
img.imgCenter{
	display: block;
	margin-left: auto;
	margin-right: auto;
	max-width:100%;
}
img.imgLeft{
	display: block;
	margin-right: auto;
	max-width:100%;
}
img.imgRight{
	display: block;
	margin-left: auto;
	max-width:100%;
}

/* =================================
 画像リンク（透過）
================================= */
a:hover img{
	filter:alpha(opacity=50);
    -moz-opacity: 0.5;
    opacity: 0.5;
}

/* =================================
 margin・padding
================================= */

/*margin right*/
.mr05 {
    margin-right: 5px;
  }
  .mr10 {
    margin-right: 10px;
  }
  .mr15 {
    margin-right: 15px;
  }
  .mr20 {
    margin-right: 20px;
  }
  .mr25 {
    margin-right: 25px;
  }
  .mr30 {
    margin-right: 30px;
  }
  .mr35 {
    margin-right: 35px;
  }
  .mr40 {
    margin-right: 40px;
  }
  .mr45 {
    margin-right: 45px;
  }
  .mr50 {
    margin-right: 50px;
  }
  /*margin left*/
  .ml05 {
    margin-left: 5px;
  }
  .ml10 {
    margin-left: 10px;
  }
  .ml15 {
    margin-left: 15px;
  }
  .ml20 {
    margin-left: 20px;
  }
  .ml25 {
    margin-left: 25px;
  }
  .ml30 {
    margin-left: 30px;
  }
  .ml35 {
    margin-left: 35px;
  }
  .ml40 {
    margin-left: 40px;
  }
  .ml45 {
    margin-left: 45px;
  }
  .ml50 {
    margin-left: 50px;
  }
  /*margin top*/
  .mt00 {
    margin-top: 0px !important;
  }
  .mt05 {
    margin-top: 5px;
  }
  .mt10 {
    margin-top: 10px;
  }
  .mt15 {
    margin-top: 15px;
  }
  .mt20 {
    margin-top: 20px;
  }
  .mt25 {
    margin-top: 25px;
  }
  .mt30 {
    margin-top: 30px;
  }
  .mt35 {
    margin-top: 35px;
  }
  .mt40 {
    margin-top: 40px;
  }
  .mt45 {
    margin-top: 45px;
  }
  .mt50 {
    margin-top: 50px;
  }
  .mt80 {
    margin-top: 80px;
  }
  .mt100 {
    margin-top: 100px;
  }
  /*margin bottom*/
  .mb00 {
    margin-bottom: 0px !important;
  }
  .mb05 {
    margin-bottom: 5px;
  }
  .mb10 {
    margin-bottom: 10px;
  }
  .mb15 {
    margin-bottom: 15px;
  }
  .mb20 {
    margin-bottom: 20px;
  }
  .mb25 {
    margin-bottom: 25px;
  }
  .mb30 {
    margin-bottom: 30px;
  }
  .mb35 {
    margin-bottom: 35px;
  }
  .mb40 {
    margin-bottom: 40px;
  }
  .mb45 {
    margin-bottom: 45px;
  }
  .mb50 {
    margin-bottom: 50px;
  }
  .mb80 {
    margin-bottom: 80px;
  }
  .mb100 {
    margin-bottom: 100px;
  }
  /*padding right*/
  .pr05 {
    padding-right: 5px;
  }
  .pr10 {
    padding-right: 10px;
  }
  .pr15 {
    padding-right: 15px;
  }
  .pr20 {
    padding-right: 20px;
  }
  .pr25 {
    padding-right: 25px;
  }
  .pr30 {
    padding-right: 30px;
  }
  .pr35 {
    padding-right: 35px;
  }
  .pr40 {
    padding-right: 40px;
  }
  .pr45 {
    padding-right: 45px;
  }
  .pr50 {
    padding-right: 50px;
  }
  /*padding left*/
  .pl05 {
    padding-left: 5px;
  }
  .pl10 {
    padding-left: 10px;
  }
  .pl15 {
    padding-left: 15px;
  }
  .pl20 {
    padding-left: 20px;
  }
  .pl25 {
    padding-left: 25px;
  }
  .pl30 {
    padding-left: 30px;
  }
  .pl35 {
    padding-left: 35px;
  }
  .pl40 {
    padding-left: 40px;
  }
  .pl45 {
    padding-left: 45px;
  }
  .pl50 {
    padding-left: 50px;
  }
  /*padding top*/
  .pt05 {
    padding-top: 5px;
  }
  .pt10 {
    padding-top: 10px;
  }
  .pt15 {
    padding-top: 15px;
  }
  .pt20 {
    padding-top: 20px;
  }
  .pt25 {
    padding-top: 25px;
  }
  .pt30 {
    padding-top: 30px;
  }
  .pt35 {
    padding-top: 35px;
  }
  .pt40 {
    padding-top: 40px;
  }
  .pt45 {
    padding-top: 45px;
  }
  .pt50 {
    padding-top: 50px;
  }
  .pt80 {
    padding-top: 80px;
  }
  .pt100 {
    padding-top: 100px;
  }
  /*padding bottom*/
  .pb05 {
    padding-bottom: 5px;
  }
  .pb10 {
    padding-bottom: 10px;
  }
  .pb15 {
    padding-bottom: 15px;
  }
  .pb20 {
    padding-bottom: 20px;
  }
  .pb25 {
    padding-bottom: 25px;
  }
  .pb30 {
    padding-bottom: 30px;
  }
  .pb35 {
    padding-bottom: 35px;
  }
  .pb40 {
    padding-bottom: 40px;
  }
  .pb45 {
    padding-bottom: 45px;
  }
  .pb50 {
    padding-bottom: 50px;
  }
  .pb80 {
    padding-bottom: 80px;
  }
  .pb100 {
    padding-bottom: 100px;
  }
  
  /*All padding*/
  .pd10{
      padding:10px;
  }
  .pd20{
      padding:20px;
  }
  .pd30{
      padding:30px;
  }
  .pd50{
      padding:50px;
  }
  
/* =================================
font（weight）
================================= */
.bold {
	font-weight: bold;
}
.normal {
	font-weight: normal !important;
}

/* =================================
font（size %）
================================= */
.font50 {
	font-size: 50% !important;
}
.font60 {
	font-size: 60% !important;
}
.font70 {
	font-size: 70% !important;
}
.font80 {
	font-size: 80% !important;
}
.font90 {
	font-size: 90% !important;
}
.font100 {
	font-size: 100% !important;
}
.font110 {
	font-size: 110% !important;
}
.font120 {
	font-size: 120% !important;
	line-height:1.8em;
}

/* =================================
font（size px）
================================= */
.font12px{
	font-size: 12px;
}
.font14px{
	font-size: 14px;
}
.font16px{
	font-size: 16px;
}
.font18px{
	font-size: 18px;
}
.font20px{
	font-size: 20px;
}
.font25px{
	font-size: 25px;
}
.font30px{
	font-size: 30px;
}
@media screen and (min-width: 769px) {
	.font12-14px{
		font-size: 14px;
	}
	.font14-16px{
		font-size: 16px;
	}
	.font16-18px{
		font-size: 18px;
	}
	.font16-20px{
		font-size: 20px;
	}
	.font18-20px{
		font-size: 20px;
	}
	.font18-25px{
		font-size: 25px;
	}
	.font20-25px{
		font-size: 25px;
	}
	.font20-30px{
		font-size: 30px;
	}
	.font22-30px{
		font-size: 30px;
	}
	.font25-30px{
		font-size: 30px;
	}
}
@media screen and (max-width: 768px) {
    .font12-14px{
		font-size: 12px;
	}
	.font14-16px{
		font-size: 14px;
	}
	.font16-18px{
		font-size: 16px;
	}
	.font16-20px{
		font-size: 16px;
	}
	.font18-20px{
		font-size: 18px;
	}
	.font18-25px{
		font-size: 18px;
	}
	.font20-25px{
		font-size: 20px;
	}
	.font20-30px{
		font-size: 20px;
	}
	.font22-30px{
		font-size: 22px;
	}
	.font25-30px{
		font-size: 25px;
	}
}

/* =================================
font（family）
================================= */
.yu_font{
	font-family:"游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif !important;
}
.yugo_font{
	font-family: "游ゴシック体", YuGothic, "YuGothic M", sans-serif;
}
.heisei_font{
	font-family: "heisei-kaku-gothic-std","Hiragino Kaku Gothic ProN","メイリオ", sans-serif;
}
.cent_font{
	font-family: Century Gothic, sans-serif;
}

/* =================================
font（color）
================================= */

.white{
	color:#fff;
}
.red{
	color:#ff0000;
}
.tiffany{
	color:#23b6b8;
}
.green{
  color:#b3ea3c;
}

/* =================================
テキスト揃え
================================= */
.txtJustify{
	text-align:justify;
}
.txtCenter{
	text-align:center;
}

/* =================================
テキスト行間
================================= */
.lh10{
	line-height:1em;
}
.lh15{
	line-height:1.5em;
}
.lh18{
	line-height:1.8em;
}
.lh20{
	line-height:2.0em;
}
.lh25{
	line-height:2.5em;
}

/* =================================
文字間
================================= */
.ls01{
	letter-spacing: 0.1em;
}
.ls02{
	letter-spacing: 0.2em;
}

/* =================================
２行目以降改行位置をずらす
================================= */
.textLine{
  padding-left:1em;
	text-indent:-1em;
}

/* =================================
改行
================================= */

/*スマホのみ改行*/
@media screen and (min-width: 769px) {
    .kaigyouSp {
     display: none;
    }
}
/*PCのみ改行*/
@media screen and (max-width: 768px) {
    .kaigyouPc {
        display: none;
    }
}

/* =================================
背景色
================================= */
.bgWhite{
	background: #fff;
}
.bgRed{
  background: rgba(226,0,0,0.8) !important;
}
.bgBlue{
  background: rgba(0,122,255,0.8) !important;
}
.bgGold{
  background: rgba(183,137,41,0.8) !important;
}

/* =================================
角丸
================================= */
.radius05{
	border-radius: 5px;		/* CSS3草案 */
	-webkit-border-radius: 5px;	/* Safari,Google Chrome用 */
	-moz-border-radius: 5px;	/* Firefox用 */
}
.radius10{
	border-radius: 10px;		/* CSS3草案 */
	-webkit-border-radius: 10px;	/* Safari,Google Chrome用 */
	-moz-border-radius: 10px;	/* Firefox用 */
}

/* =================================
 スマホ・PC それぞれの表示・非表示
================================= */

@media screen and (min-width: 769px) {
    .sp_only{
        display:none !important;
    }
}

@media screen and (max-width: 768px) {
    .pc_only{
        display:none !important;
    }
}

/* =================================
 inner
================================= */
.inner{
	width: 1000px;
	max-width: calc(100% - 30px);
	margin-left:auto;
	margin-right:auto;
}
.inner768{
	width: 768px;
	max-width: calc(100% - 30px);
	margin-left:auto;
	margin-right:auto;
}

/* =================================
 flexbox
================================= */

.flex{
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	align-items: stretch;    /*全ての要素の高さを揃える*/
}
.flex-wrap{
	flex-wrap:wrap; 	/*要素を折り返して繰り返す*/
}
.space-between{
	justify-content: space-between; /*均等に間隔をあける*/
}
.row-reverse{
	flex-flow: row-reverse; /*並び順を逆にする*/
}
.border-box{
	box-sizing:border-box;
}
@media(max-width:768px)  {
	.flex_block{
		display: block;
	}
}

@media(min-width:769px) {
	.flexBox2{
		width:48%;
    }
    .flexBox3{
        width:31%;
    }
    .flexBox4{
		width:24%;
    }
}
@media(max-width:768px) {
	.flexBox2{
      width:100%;
      margin-bottom: 30px;
    }
    .flexBox3{
      width:100%;
      margin-bottom: 30px;
    }
    .flexBox4{
      width:49%;
      margin-bottom: 30px;
    }
}

/* =================================
 float
================================= */
.left{
	float: left;
}
.right{
	float: right;
}

/* =================================
 ヘッダー
================================= */
header{
  background:rgba(35,182,184,0.7);
  position: fixed;
  width:100%;
  z-index: 10;
}
@media(min-width:769px) {
  
}
@media(min-width:769px) {
  header div h1 img{
    width:300px;
  }
  header .inner{
    padding: 17.5px 0;
  }
  .telPc{
    display: block;
  }
  .telSp{
    display: none;
  }
}
@media(max-width:768px) {
  header div h1 img{
    width: 185px;
  }
  header .inner{
    padding: 10px 10px;
  }
  .telPc{
    display: none;
  }
  .telSp{
    display: block;
  }
}


/* =================================
 メインビジュアル
================================= */
.mv{
  position: relative;
}
img.mvImg{
  width:100%;
  object-fit: cover;
}
.mvTxt{
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  max-width:1150px;
  width:calc(100% - 30px);
  z-index:2;
}
.mvTxt h2{
  text-align: right;
  width:100%;
}

@media(min-width:769px) {
  .filter{
    display: none;
  }
  img.mvImg{
    height:700px;
  }
  .mvTxt h2{
    margin-top: 120px;
    font-size:30px;
    line-height: 1.5em;
  }
}
@media(max-width:768px) and (min-width:421px) {
  .filter{
    height:400px;
    width:100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    background: rgba(0,0,0,0.2);
    z-index:1;
  }
  img.mvImg{
    height:400px;
  }
  .mvTxt h2{
    margin-top: 80px;
    font-size:20px;
    line-height: 1.5em;
  }
}
@media(max-width:420px) {
  .filter{
    height:300px;
    width:100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    background: rgba(0,0,0,0.3);
    z-index:1;
  }
  img.mvImg{
    height:300px;
  }
  .mvTxt h2{
    margin-top: 80px;
    font-size:16px;
    line-height: 1.5em;
  }
}

/* =================================
 フッター
================================= */
.copyright{
	background: #23b6b8;
}
.copyright p{
	text-align: center;
	color: #fff;
	font-size:80%;
	font-weight:bold;
	padding-top:20px;
	padding-bottom:20px;
	line-height: 1.5em;
	width:90%;
	margin-left: auto;
	margin-right: auto;
}
.copyright a{
	text-decoration: none;
	color:#fff;
}

/* =================================
 トップへ戻るボタン
================================= */
#pageTop {
	position: fixed;
	bottom: 15px;
	right: 20px;
	z-index: 9999;
}
#pageTop i {
}
#pageTop a {
	display: block;
	color: #fff;
	font-weight: bold;
	font-size:35px;
	text-decoration: none;
	text-align: center;
	background:#23b6b8;
	width:40px;
	height:40px;
	line-height: 1.1em;
}
#pageTop a:hover {
	text-decoration: none;
	opacity: 0.7;
}


/* =================================
 コンテンツ
================================= */
.point_sub_tit{
  background:#23b6b8;
  border-radius: 100px;		/* CSS3草案 */
	-webkit-border-radius: 100px;	/* Safari,Google Chrome用 */
  -moz-border-radius: 100px;	/* Firefox用 */
}
.point_sub_tit p{
  color:#fff;
  text-align: center;
  padding:2px 0;
}
.priceList{
  background: url(../images/bg_price.jpg) repeat;
}
.price_tit{
  background: #fff;
  padding: 5px 0;
  box-sizing: border-box;
}
table.priceTb{
  display: block;
  overflow-x: scroll;
  white-space: nowrap;
  -webkit-overflow-scrolling: touch;
  color:#fff;
  line-height: 1.5em;
  text-align: center;
  border-bottom: 2px #fff solid;
}
table.priceTb tbody {
  width: 100%;
  display:table;
}
.priceTb th,.priceTb td{
  padding: 10px;
  border-bottom:1px #fff dashed;
  border-right:1px #fff solid;
}
.priceTb th{
  background:rgba(35,182,184,0.7);
  width:25%;
  vertical-align: middle;
}
.priceTb th.priceTbKind{
  border-bottom: 2px #fff solid;
}
.priceTb td{
  background:rgba(51,51,51,0.7);
  width:25%;
}
.priceTb th.bb0,
.priceTb td.bb0{
  border-bottom:none;
}
.priceTb th.br0,
.priceTb td.br0{
  border-right:none;
}
p.caution::before{
  content: "※";
  font-size:14px;
}
p.caution {
  padding-left:1em;
  text-indent:-1em;
}
@media(min-width:768px) {
  .priceTb td br{
    display: none;
  }
  .priceTb td br.kaigyouBlock{
    display: block;
  }
}
@media(max-width:767px) {
  .priceTb th,.priceTb td{
    font-size:14px;
  }
  table.rentalTb,table.rentalTb tbody,table.rentalTb tr,
  table.rentalTb th,table.rentalTb td{
    display: block;
  }
  table.rentalTb td{
    width: 100%;
    border-right: none;
    border-bottom: 1px #fff solid !important;
  }
}