@charset "UTF-8";

body {
	font-family: "Hiragino Kaku Gothic ProN","Hiragino Sans","Helvetica Neue",Arial,Meiryo,sans-serif;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	color: #3e3a39;
	font-size: 17px;
	letter-spacing: .08em;
	line-height: 1.7;
	padding:0;
	margin:0;
	-webkit-text-size-adjust: 100%;
}

div,
dl,dt,dd,ul,ol,li,
h1,h2,h3,h4,h5,h6,
pre,form,fildset,p,blockquote{
	margin:0;
	padding:0;
	border:0;
	font-size:100%;
	font-style:normal;
	font-weight: normal;
}

img{
    max-width: 100%;
    height: auto;
    width: auto\9; /* ie8 */
	border-top-style: none;
	border-right-style: none;
	border-bottom-style: none;
	border-left-style: none;
	vertical-align: top;
}
table {
    font-size:inherit;
    font:100%;
	border-collapse: collapse;
}

address{
	font-style:normal;
}

ul{
	list-style:none;
}
ul img{
	vertical-align: top;
	margin:0;
}

a{
	color: inherit;
	text-decoration: none;
	outline:0;
	transition: color 0.7s, background-color 1.0s;
}
a:hover{
	transition: color 0.7s, background-color 1.0s;
}

.clearfix:after {
  content: ".";  /* 新しい要素を作る */
  display: block;  /* ブロックレベル要素に */
  clear: both;
  height: 0;
  visibility: hidden;
}

.clearfix {
  min-height: 1px;
}

* html .clearfix {
  height: 1px;
  /*\*//*/
  height: auto;
  overflow: hidden;
  /**/
}


/*<group=style>*/
.fw_normal{font-weight: normal;}
.fw_bold{font-weight: bold;}
/*</group>*/

/*<group=text_align>*/
.txt_al_l{text-align:left;}
.txt_al_r{text-align:right;}
.txt_al_c{text-align:center;}
.sp_txt_l{text-align:center;}	
/*</group>*/

/*<group=float>*/
.flt_l{float:left;}
.flt_r{float:right;}	
/*</group>*/

.red {color: #BA3654;}
.fs15 {
	font-size: 88%;
	line-height: 1.8;
}

.img_max {
	width: 100% !important;
	max-width: initial !important;
}
.change_img img {margin-left: auto; margin-right: auto;}

.blocklink,
.blocklink_out,
.blocklink_ank {
	cursor:pointer;
}

a.txt_link {
	text-decoration: underline;
}
a.txt_link:hover {
	text-decoration: none;
}

/* スマホで電話をかけるボタン：画像対応 */
.sp_tel_btn {
	position: relative;
}
.sp_tel_btn img {
	position: relative;
	z-index: 0;
}
.sp_tel_btn span,
.sp_tel_btn a {
	display: block;
}
.sp_tel_btn a {
	content: "";
	position: absolute;
	z-index: 1;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
}

.pink {color: #ec6d7b}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {

body {
	font-size: 15px;
	line-height: 1.8;
}

	
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {	
/* スマホのときはビューポートを基準にサイズ調節する */
/* スマホ時：emまたは%で指定する */
/* スマホ以外でビューポート基準にするときは、その都度「vw」で指定する */
body {
	font-size: 4vw;
	letter-spacing: normal;
	line-height: 1.8;
}
.sp_txt_l{text-align:left;}

.btnlist{
	width: 90%;
	margin: 0 auto 1em;
}
	
}




/*共通
---------------------------------------------------------*/
#pagebody {
	overflow: hidden;
}

.max_1500{
	max-width: 1500px;
	margin: 0 auto;
}
.w1500{
	max-width: 1500px;
	margin: 0 auto;
	width: 94%;
}
.w1200 {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 3%;
	width: 94%;
}
.w1000 {
	max-width: 1000px;
	margin: 0 auto;
	padding: 0 3%;
	width: 94%;
}
.w720 {
	max-width: 720px;
	margin: 0 auto;
	padding: 0 3%;
	width: 94%;
}


/*フォント*/
.ft_min {
	font-family: "Hina Mincho", serif;
    font-weight: 400;
    font-style: normal;
}
.ft_min.fw_bold {
	-webkit-text-stroke-width: 0.6px;
}
.ft_sheila {
	font-family: sheila, sans-serif;
    font-weight: 400;
    font-style: normal;
	-webkit-text-stroke-width: 1px;
}


/*レイアウト*/
.flex_box {
	display: flex;
}

.com_txt_link {
	color: #ec6d7b;
}
.com_txt_link:hover {
	text-decoration: underline;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {


}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.w1500, .w1200, .w1000, .w720 {
	padding: 0 5%;
	width: 90%;
}
	
/*見出し*/

}


/*アニメーション
---------------------------------------------------------*/
/*フェード*/
.com_an_fade {
	opacity: 0;
	transition: all .8s ease;
}
.com_an_fade.anime_on {
	opacity: 1;
}
/*アップ*/
.com_an_up {
	opacity: 0;
	transition: all 1s ease;
	transform: translateY(20px);
}
.com_an_up.anime_on {
	opacity: 1;
	transform: translateY(0px);
}
/*ズーム*/
.com_an_zoom {
	opacity: 0;
	transition: all .5s ease;
	transform: scale(0.9);
}
.com_an_zoom.anime_on {
	opacity: 1;
	transform: scale(1.0);
}



/*header
---------------------------------------------------------*/
header {
	position: fixed;
	background-color: rgba(255,255,255,0.7);
	width: 100%;
	box-sizing: border-box;
	padding: 1em;
	z-index: 1000;
}
header .h_inbox {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	max-width: 1200px;
	margin: 0 auto;
}
header .h_left {
	width: 26%;
	max-width: 308px;
}
header .h_right {
	width: 73%;
}
header h1 {
	color: #f29c97;
	font-size: 82%;
	letter-spacing: .05em;
	line-height: 1.5;
	margin-bottom: .7em;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) { 

header h1 {
	font-size: 78%;
	letter-spacing: .02em;
}

	
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

header {
	padding: .5em 3%;
}
header .h_inbox {
	display: block;
}
header .h_left {
	width: 50%;
}
header .h_right {
	display: none;
}
header h1 {
	width: 90%;
	font-size: 70%;
	letter-spacing: normal;
}

}







/*メインナビ
---------------------------------------------------------*/
.m_nav {
	position: relative;
	display: flex;
}
.m_nav > li {
	position: relative;
	margin-right: 1.3em;
}
.m_nav > li > a {
	position: relative;
	display: block;
	font-size: min(1.3vw,100%);
	font-weight: bold;
	line-height: 1.3;
	letter-spacing: .06em;
	white-space: nowrap;
	box-sizing: border-box;
	transition: all .5s;
}
.m_nav > li > a:hover {
	color: #ec6d7b;
}

.bnr_reserve {
	position: fixed;
	width: 9%;
	max-width: 221px;
	right: calc(50% - 28vw);
	bottom: 0;
	z-index: 1001;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) { 

.m_nav > li {
	margin-right: .7em;
}
.m_nav > li > a {
	font-size: 1.45vw;
	letter-spacing: .02em;
}

.bnr_reserve {
	width: 12%;
	right: 12%;
}

}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

	
.bnr_reserve {
	width: 20%;
	right: 2%;
}
	
}





/*スマホメニュー
---------------------------------------------------------*/
.drawer_inbox {
	padding: 1em 5% 0;
}
.drawer_inbox .drw_logo {
	width: 30%;
	margin: 10% auto 7%;
}
.drawer_inbox .drw_menu li {
	border-bottom: 1px solid rgba(182,161,118,0.6);
}
.drawer_inbox .drw_menu li:first-of-type {
	border-top: 1px solid rgba(182,161,118,0.6);
}
.drawer_inbox .drw_menu li a  {
	position: relative;
	display: block;
	text-align: center;
	font-weight: bold;
	letter-spacing: .08em;
	box-sizing: border-box;
	padding: .8em;
}
.drawer_inbox .drw_menu li a:hover  {
	color: #ec6d7b;
}


/*共通
---------------------------------------------------------*/
/*インデックス*/
.com_index1 {
	position: relative;
	background: linear-gradient(to top, #ffa6ab 75%, transparent 75%);
	font-size: 247%;
	box-sizing: border-box;
	padding: 50px 5% 0;
	z-index: 1;
}
.com_index1::before {
	position: absolute;
	content: "";
	background: url("../images/first/com_index1_bg@2x.jpg") no-repeat center top;
	background-size: auto 100%;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	mix-blend-mode: multiply;
}
.com_index1 + * {
	position: relative;
	padding-top: 50px;
}
.com_index1 + * > * {
	position: relative;
	z-index: 1;
}
.com_index1 > div {
	position: relative;
	color: #FFF;
	max-width: 720px;
	padding: 1.6em 0 1.4em;
	margin: 0 auto;
}
.com_index1 > div::before {
	position: absolute;
	content: "";
	background: url("../images/com_index1_illust@2x.png") no-repeat left top;
	background-size: contain;
	width: 40%;
	height: 190%;
	left: 1%;
	top: -16%;
	mix-blend-mode: multiply;
}
.com_index1 > div > * {
	z-index: 2;
}
.com_index1 .fw_bold {
	position: relative;
}
.com_index1 .fw_bold span {
	font-size: 72%;
	vertical-align: .1em;
}
.com_index1 .ft_sheila {
	position: absolute;
	display: block;
	color: #f29c97;
	font-size: 157%;
	letter-spacing: 0;
	line-height: 1;
	white-space: nowrap;
	mix-blend-mode: multiply;
	transform: rotate(-5deg);
	left: 50%;
	bottom: -15%;
	
/*safariで右側が見切れてしまうため*/
	padding-right: .3em;
}

/*リード*/
.com_lead_txt {
	text-align: center;
	font-size: 176%;
	letter-spacing: .08em;
	line-height: 1.3;
	padding-bottom: .6em;
	border-bottom: 2px solid rgba(62,58,57,0.8);
}
.com_lead_txt + dd {
	margin-top: 1.5em;
}
/*テキスト*/
.com_asterisk {
	position: relative;
	padding-left: 1em;
}
.com_asterisk::before {
	position: absolute;
	content: "※";
	left: 0;
	top: 0;
}
/*リスト*/
.com_list li {
	position: relative;
	line-height: 1.4;
	padding-left: 1.1em;
	margin-top: .5em;
}
.com_list li::before {
	position: absolute;
	content: "●";
	left: 0;
	top: 0;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {

/*インデックス*/
.com_index1 {
	font-size: 200%;
	padding: 30px 5% 0;
}
.com_index1 > div {
	padding: 1.4em 0 1.2em;
}
.com_index1 > div::before {
	width: 40%;
	height: 150%;
}

}



/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

/*インデックス*/
.com_index1 {
	font-size: 140%;
	padding: 8% 5% 0;
}
.com_index1::before {
	
}
.com_index1 + * {
	padding-top: 8%;
}
.com_index1 > div {
	padding: 1.6em 0 1.4em;
}
.com_index1 > div::before {
	height: 140%;
}

/*リード*/
.com_lead_txt {
	font-size: 130%;
	letter-spacing: .04em;
}
/*リスト*/
.com_list li {
	margin-top: .3em;
}

}


/*開閉アイコン
---------------------------------------------------------*/
.icon_open {
	letter-spacing: normal;
	line-height: 1.0em;
	display: inline-block;
	vertical-align: middle;
	width: 1em;
	height: 1em;
	background: rgba(236,109,123,0.7);
	border-radius: 50%;
	margin-left: .5em;
	transform: translateY(-.1em);
	position: relative;
	transition: all .4s;
}
.icon_open::before,
.icon_open::after {
	content: "";
	position: absolute;
	width: .5em;
	height: 2px;
	background: #fff;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
}
.icon_open::after {
	transform: rotate(90deg);
	transition: all 0.4s;
}
.active .icon_open::after {
	transform: rotate(0deg);
}


/*カレンダー
---------------------------------------------------------*/
.cal_box {
	background: #ffffff;
	border-radius: 5px;
	padding:20px 20px 20px 20px;}
.cal_box .xo-months {	
	font-family: 'Tajawal', sans-serif;
	font-weight: 400;
	font-style: normal;
	position: relative;
}
.xo-event-calendar table, .xo-event-calendar table.xo-month > caption {
	background-color: transparent !important;
}
/*年月*/
/*
.calendar-caption{
	font-size: 1.3em !important;
}
*/
.xo-event-calendar table.xo-month button span.nav-prev,
.xo-event-calendar table.xo-month button span.nav-next{
    height: 9px !important;
    width: 9px !important;
}
/* 曜日 */
.xo-event-calendar table.xo-month {
	margin: 0;	/* 下のキャプションとの隙間 */
}
.xo-event-calendar table.xo-month, .xo-event-calendar table.xo-month th, .xo-event-calendar table.xo-month td {
	border: none !important;
}
.xo-event-calendar table.xo-month {
	border: none !important;
}
.xo-event-calendar table.xo-month thead th {
	font-weight: bold;
	line-height: 1.2em;
	padding: 0.7em 0 0.3em 0 !important;
	color: #ffffff !important;
	background: #ccc !important;
	border: none !important;
	font-size: 85% !important;
}
.xo-event-calendar thead .sunday {
	color: #fffffff !important;
}
.xo-event-calendar thead .saturday {
	color: #ffffff !important;
}
/*日付の高さ*/
.xo-event-calendar table.xo-month .month-dayname-space{
	height:1.7em !important;
}
/* 今日 */
.xo-event-calendar .today {
	color: #473933 !important;
	background-color: #ffffff;
background-image: url("data:image/svg+xml,%3Csvg width='6' height='6' viewBox='0 0 6 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23aaaaaa' fill-opacity='0.38' fill-rule='evenodd'%3E%3Cpath d='M5 0h1L0 6V5zM6 5v1H5z'/%3E%3C/g%3E%3C/svg%3E") !important;
	font-weight: normal !important;
}
/* 日付 */
.xo-event-calendar table.xo-month .month-week table .dayname {
	font-size: 90%;
}
.xo-event-calendar table.xo-month div[class^="holiday-"] { /* セレクタ名の前方一致 */
	color: #473933 !important;
}
/* イベント日 */
.xo-event-calendar table.xo-month .month-event td {
	padding: 0;
}
.xo-event-calendar span.month-event-title {
	font-weight: normal !important;
	color: #fff !important;
	font-size: 80% !important;
	letter-spacing: 0 !important;
	border-radius: 0 !important;
	line-height: 1.2em;
	padding-top: 0.4em !important;
}
/* イベントデフォルト背景色はプラグイン/inc/main.phpの259行目を変更する */

/* キャプション */
.cal_box .holiday-titles {
	padding-top: .5em;
	text-align: left;
	line-height: 1.6em;
	font-size:110%;
	color:#473933;
	overflow: hidden;
}
.cal_box .holiday-titles p {
	float: left;
	margin-right: 1.0em !important;
}
.cal_box .holiday-titles p span {
	border: none !important; display: inline-block;
   padding: 0 !important;
   width: 0.8em;
   height: 0.8em;
}
/* リンクテキスト */
.cal_box .calendar_wrapp {
	position: relative;
}
.cal_box .sub_link {
	position: absolute;
	right: 0;
	bottom: 0;
	text-align: right;
	font-weight: bold;
	line-height: 1em;
}
.cal_box .sub_link a {
	text-decoration: underline;
	font-size:80%;
}
.cal_box .sub_link a:hover {
	text-decoration: none;
}
.cal_box .txt_sat {
	padding-top: .5em;
	color: #8dc21f;
	font-weight: bold;
	letter-spacing: .1em;
	line-height: 1.2em;
	text-align: center;
}
.cal_box .event_titles{
	text-align: left;
	line-height: 1.6em;
	font-size:110%;
	color:#473933;
	overflow: hidden;
}
.cal_box .event_title{
	padding: 2px 0;
	font-size: 90%;
}
.cal_box .event_titles p span{
	display: inline-block;
	width: 0.8em;
	height: 0.8em;
	margin: 0 6px 0 0;
	background: #84378e;
	padding: 0;
}
.cal_box .event_titles p:nth-child(2) span{
	background-color: #2c4298;
}


/*詳しくはお知らせへ*/
.btn_more{
	line-height: 1em;
	margin: 0 0 0 auto;
	text-align: right;}
footer .f_bg .btn_more a{
	color:#333;
	font-size:90%;
	letter-spacing: 0;
}
footer .f_bg .btn_more a i{
	opacity: 0.7;
}
/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
/*年月*/
.calendar-caption{
	font-size: 1.2em !important;
}
/* キャプション */
.cal_box .holiday-titles {
	font-size:95%;
}
.cal_box .event_titles{
	font-size:95%;
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.cal_box {
	padding:5%;}
/*年月*/
.calendar-caption{
	font-size: 1em !important;
}
/* キャプション */
.cal_box .holiday-titles {
	font-size:90%;
}
.cal_box .event_titles{
	font-size:90%;
}
/*日付の高さ*/
.xo-event-calendar table.xo-month .month-dayname-space{
	height:1.2em !important;}
}


/*footer
---------------------------------------------------------*/
footer {
	background: url("../images/f_bg@2x.png") no-repeat center center;
	background-size: cover;
	padding-top: 60px;
}
footer .f_logo {
	text-align: center;
	margin-bottom: 60px;
}
footer .f_logo img {
	width: 55%;
}
footer .f_logo p {
	color: #f29c97;
	font-size: 80%;
	line-height: 1.4;
	letter-spacing: .03em;
	margin-top: .4em;
}
/*f_info*/
footer .f_info {
	display: flex;
	justify-content: space-between;
	margin-bottom: 70px;
}
footer .f_info .box_l {
	width: 42%;
}
footer .f_info .box_r {
	width: 55%;
}
footer address {
	line-height: 1.4;
	margin-bottom: 2em;
}
footer .f_tel dt {
	line-height: 1.4;
	margin-bottom: .6em;
}
footer .f_tel dd {
	width: 72%;
	max-width: 337px;
}
footer .f_tel dt:last-of-type{
	margin-top: 1.5em;
}
/*f_info*/
footer .f_access {
	display: flex;
	justify-content: space-between;
	margin-bottom: 70px;
}
footer .f_access .box_l {
	width: 58%;
}
footer .f_access .box_r {
	width: 39%;
}
footer .f_access .box_l dt {
	font-weight: bold;
	margin-bottom: .2em;
}
footer .f_access .box_l dd {
	font-size: 90%;
}
footer .f_access .box_l dd:first-of-type {
	margin-bottom: 1.5em;
}
footer .f_access .map_img {
	box-shadow: 10px 10px 20px rgba(0,0,0,0.3);
}
footer .f_access .map_img + p {
	font-size: 90%;
	font-weight: bold;
	margin-top: 1em;
}

footer .copyright {
	text-align: center;
	line-height: 1.2;
	padding: 1.8em 0 2em;
}

/*f_timetable*/
footer .f_timetable {
	width: 100%;
	font-feature-settings: "halt";
	margin-bottom: .5em;
}
footer .f_timetable th:first-of-type {
	width: 32%;
	text-align: center;
	font-weight: normal;
	border-left: 1px solid rgba(35,24,21,0.5);
	border-right: 1px solid rgba(35,24,21,0.5);
}
footer .f_timetable td {
	text-align: center;
	padding: .2em;
}
footer .f_timetable td:first-of-type {
	padding-left: .6em;
}
footer .f_timetable td:last-of-type {
	padding-left: 0;
}
footer .f_timetable thead th {
	letter-spacing: .2em;
}
footer .f_timetable tbody th {
	letter-spacing: normal;
}

/*pagetop*/
#page_top {
	position: fixed;
	width: 6%;
	right: calc(50% - 36vw);
	bottom: 20px;
	z-index: 10;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {

footer {
	padding-top: 7%;
}
footer iframe {
	height: 400px;
}
/*pagetop*/
#page_top {
	width: 8%;
	right: 2%;
}

}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

footer {
	padding-top: 10%;
}
footer .f_logo {
	margin-bottom: 5%;
}
footer .f_logo img {
	width: 80%;
}
/*f_info*/
footer .f_info {
	display: block;
	margin-bottom: 8%;
}
footer .f_info .box_l {
	width: 100%;
	margin-bottom: 6%;
}
footer .f_info .box_r {
	width: 100%;
}
footer address {
	margin-bottom: 1em;
}
/*f_info*/
footer .f_access {
	display: block;
	margin-bottom: 9%;
}
footer .f_access .box_l {
	width: 100%;
	margin-bottom: 5%;
}
footer .f_access .box_r {
	width: 100%;
}
footer .f_access .box_l dt {
	margin-bottom: .2em;
}
footer .f_access .box_l dd {
	font-size: 90%;
}
footer .f_access .box_l dd:first-of-type {
	margin-bottom: 1.2em;
}

footer .copyright {
	text-align: center;
	line-height: 1.2;
	padding: 1em 0 5em;
}

footer iframe {
	height: 80vw;
}
/*pagetop*/
#page_top {
	width: 15%;
	right: 4%;
	bottom: 35vw;
}

}



/*sp_footer
---------------------------------------------------------*/
@media only screen and (min-width: 768px) {
#sp_footer {display: none !important;}

}

#sp_footer {
    position: fixed;
    width: 100%;
    left: 0;
    bottom: 0;
    z-index: 1000;
	color: #FFF;
    background: #ec6d7b;
	padding: 2.25% 2%;
}
#sp_footer dl {
    display: flex;
	align-items: center;
	white-space: nowrap;
	font-feature-settings: "palt";
	line-height: 1.3;
	
}
#sp_footer dl dt {
    font-size: 65%;
	letter-spacing: normal;
	font-weight: bold;
	line-height: 1.6em;
	margin-right: 0.8em;
	text-align: center;
}
#sp_footer dl dd img {
    display: block;
	width: 75%;
}
#sp_footer dl dd p {
	font-weight: bold;
    font-size: 58%;
	letter-spacing: normal;
	margin-top: .5em;
}
/*margin
---------------------------------------------------------*/
.com_btm_160 {
	margin-bottom: 160px;
}
.com_btm_150 {
	margin-bottom: 150px;
}
.com_btm_120 {
	margin-bottom: 120px;
}
.com_btm_110 {
	margin-bottom: 110px;
}
.com_btm_100 {
	margin-bottom: 100px;
}
.com_btm_90 {
	margin-bottom: 90px;
}
.com_btm_80 {
	margin-bottom: 80px;
}
.com_btm_70 {
	margin-bottom: 70px;
}
.com_btm_60 {
	margin-bottom: 60px;
}
.com_btm_50 {
	margin-bottom: 50px;
}
.com_btm_40 {
	margin-bottom: 40px;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {

.com_btm_160 {
	margin-bottom: 12%;
}
.com_btm_150 {
	margin-bottom: 12%;
}
.com_btm_120 {
	margin-bottom: 10%;
}
.com_btm_110 {
	margin-bottom: 9%;
}
.com_btm_100 {
	margin-bottom: 8%;
}
.com_btm_90 {
	margin-bottom: 9%;
}
.com_btm_80 {
	margin-bottom: 7%;
}
.com_btm_70 {
	margin-bottom: 6%;
}
.com_btm_60 {
	margin-bottom: 5%;
}
.com_btm_50 {
	margin-bottom: 5%;
}
.com_btm_40 {
	margin-bottom: 4%;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {

.com_btm_160 {
	margin-bottom: 17%;
}
.com_btm_150 {
	margin-bottom: 14%;
}
.com_btm_120 {
	margin-bottom: 13%;
}
.com_btm_110 {
	margin-bottom: 12%;
}
.com_btm_100 {
	margin-bottom: 12%;
}
.com_btm_90 {
	margin-bottom: 11%;
}
.com_btm_80 {
	margin-bottom: 10%;
}
.com_btm_70 {
	margin-bottom: 9%;
}
.com_btm_60 {
	margin-bottom: 8%;
}
.com_btm_50 {
	margin-bottom: 7%;
}
.com_btm_40 {
	margin-bottom: 6%;
}
}



/* PC
------------------------------------------*/
@media only screen and (min-width: 768px)  {
.tb_only{display:none !important;}
.sp_only{display:none !important;}
.sp_tb{display:none !important;}
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.pc_only{display:none !important;}
.tb_only{display:inherit !important;}
.sp_only{display:none !important;}
.tb_pc{display:inherit !important;}
.sp_tb{display:inherit !important;}
.pc_w_only {display: none;}

/*body{background:#ccc;}*/
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.pc_only{display:none;}
.tb_only{display:none;}
.sp_only{display:inherit;}
.tb_pc{display:none;}
.sp_tb{display:inherit;}
.pc_w_only {display: none;}

}
/* Mobile (Landscape)
------------------------------------------*/
@media only screen and (min-width: 480px) and (max-width: 767px) {
	
}