/*Common*/
body.index #main {
	padding-top: 30px;
}

header.special {
	margin-bottom: 30px;
	padding-top: 80px;
	position: relative;
	text-align: center;
}

.flex {
	display: flex;
}

.Mt10 { 
	margin-top: 10px;
}

.Mt20 { 
	margin-top: 20px;
}

.Mt30 { 
	margin-top: 30px;
}

.MB0 {
	margin-bottom: 0;
}

h3 span {
	font-size: 25px;
	font-weight: bold;
}

.lh28 {
	line-height: 28px;
}

.ML03 {
	margin-left: 0.3rem;
}

.MR03 {
	margin-right: 0.3rem;
}


/*introduction*/
.intro_greet {
	font-size: large;
    line-height: 1.6em;
}


/*infomation*/
.text_target {
	letter-spacing: -1px;
	color: #333;
	font-size: large;
}

.info_wrap { 
	letter-spacing: -1px;
	padding: 20px;
	border: 4px solid #ddd;
}

.info_wrap ul {
	margin:0;
	padding-left: 0;
}

.info_wrap ul li {
	list-style: none;
	font-size: large;
	line-height: 1.8em;
}

.info_wrap_tb {
	letter-spacing: -1px;
	border: 4px solid #ddd;
}

.info_wrap_tb ul  {
	margin:0;
	padding: 0 20px 20px 20px;
}

.info_wrap_tb ul li {
	list-style: none;
	font-size: large;
	line-height: 1.8em;
}

@media screen and (max-width: 840px) {
	h3 {
		text-align: left;
	}
	h3 span {
		font-size: 20px;
	}
}

/*Photo*/
.photo-wrap .row {
	padding: 0;
	margin: 0 !important;
}
.photo-wrap .row .col-3 {
	padding: 1em;
}
.portfolio-list {
	display: flex;
	width: 100%;
	padding: 10px 0 10px 0;
	margin-bottom: 30px;
}
.portfolio-list ul {
	gap: 15px;
	display: flex;
	flex-wrap: wrap;
	/* justify-content: center; */
}
ol, ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
.portfolio-list li {
	border: 1px solid #EFEFEF;
	padding: 6px 6px 6px 6px;
	text-align: center;
	width: 24%;
	transition: .3s all;
}
.img-fluid {
	max-width: 100%;
	width: 100%;
	max-height: 90% !important;
	/* height: auto !important; */
}
.photo-height {
	height: 200px !important;
	margin-bottom: 20px;
}
.po-item-title {
	display: block;
	width: 100%;
	line-height: 31px;
}
.smartphoto-dismiss {
	min-width:30px;
}

.js-img-viwer {
	/* border: 1px solid #EFEFEF; */
	/* padding: 6px 6px 6px 6px; */
	text-align: center;
	width: 24%;
	transition: .3s all;
}
.portfolio-list a {
	box-shadow: 0px 7px 20px #ebebeb;
	border-color: #c9c9c9;
}
.po-item-title {
	color: #232323;
	font-size: 18px;
}

@media screen and (max-width: 840px) {
	.img-fluid {
		max-width: 100%;
		width: 100%;
		height: auto !important;
	}
	.photo-height {
		width: 50% !important;
		height: auto !important;
		margin-bottom: 20px;
	}
}

/*Video*/
.map_box {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
}
.youtube-iframe {
	position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.video_youtube header {
	font-size: large;
	margin-bottom: 10px;
}

@media screen and (max-width: 840px) {
	.video_youtube header {
		text-align: left !important;		
	}
	.video_youtube h3 span {
		font-size: 20px;
	}
}

/*Information*/
.col2 {
	display: flex;
	width: 100%;
	justify-content: space-around;
}

.col2_info {
	width: 49%;
}

.col3 {
	display: flex;
	width: 100%;
	justify-content: space-around;
}

.col3_info {
	width: 32%;
}

.info_wrap {
	min-height: 113px;
}

.info_wrap_tb .short {
	width: 60%;
	border-right:1px solid #ccc
}

.info_wrap_tb .long {
	width: 40%;
}

.info_wrap_tb p  {
	border-bottom: 1px solid #ccc;
	margin-bottom: 20px;
	text-align: center;
	background: #f5f5f5;
	font-weight: 600;
}

.point_highlight {
	float:right;
	font-size: large;
	color: #dc3545;
}

.reservation_sms {
    line-height: 2.5em;
    letter-spacing: -1px;
    color: #fff;
    padding: 20px;
    text-align: center;
    background: url(../../images/info02_08.png);
	background-size: cover;
}

.reservation_tit {
	border-bottom: 1px dotted #ddd;
	padding: 20px 0;
	margin-bottom: 10px;
}

.reservation_tit span {
	font-size: 25px;
	font-weight: bold;
}

.reservation_txt {
	line-height: 1.5em;
	font-weight: 300;
	padding: 20px 0;
}

@media screen and (max-width: 840px) {
    .col3 {
        display: inline-block;
    }
	.col3_info {
		width: 100%;
		margin-top: 4em;
	}
	.col3_info:first-child {
		width: 100%;
		margin-top: 0;
	}
	.stit_left section h3 {
		text-align: left;
	}
	.stit_left section h3 span {
		font-size: 20px;
	}
	.info_wrap {
		min-height: auto;
	}
	.point_highlight {
		float: none;
	}
}

/*Reservation*/


/*Refund*/
section.wrapper section {
	margin-top: 50px;
}

section.wrapper section:first-child {
	margin-top: 0;
}

.refund_stit {
	line-height: 1.5em;
}

.tb_wrap {
	margin-top: 10px;
}

.table {
	display: flex;
}

.table:last-child {
	display: flex;
	border-top: 0;
	border-bottom: 1px solid #ccc;
}

.table div {
	width: 100% !important;
	font-size: large;	
	border-right: 1px solid #ccc;
}

.table div:last-child {
	border-right: 0;
}

.table div p {
	margin: 0 !important;
	line-height: 1.4em;
	padding: 8px;
	text-align: center;
	border-top: 1px solid #ccc;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 65px;			
}

.table div p:first-child {
	border-top: 1px solid #ccc;
	height: 50px;
	background: #f5f5f5;
	font-weight: 600;
}


@media screen and (max-width: 840px) {
	.table {
		flex-wrap: wrap;
	}
	.table div {
		border-right:0 !important;
	}
}

/*map*/
.sub_address {
	font-size: 18px;
	line-height: 28px;
}
.sub_address .adress_tit {
	text-align: center;
}
.sub_address .adress_route {
	text-align: left;
	display: flex;
	justify-content: center;
}
.sub_address span {
	font-weight: 800;
}

@media screen and (max-width: 736px) {
    .sub_address {
        padding: 0 1.5em;
    }
	.row.gtr-150 > * {
        padding: 45px 0 0 45px;
	}
}

/*construction_plan*/
.site_wrap {
	display: flex;
    flex-wrap: wrap;
    box-sizing: border-box;
    align-items: stretch;
}

.site_align {
	display: flex;
}
