@charset "utf-8";
/*
Theme Name: Genova Template
File: top.css
Theme Author: Genova Design
Author URI: https://genova.co.jp/
Description: Description: This file is reserved for the top-page css
Version: 1.0
*/

/*--------------------------------------
	mainimage
--------------------------------------*/

#mainimage img {
	width: 100%;
}

#mainimage h1 {
	display: none;
}


/*--------------------------------------
	news
--------------------------------------*/

.top-news .post-box__header h2 {
	width: 100%;
    font-size: 26px;
	line-height: 1;
	letter-spacing: .05em;
}

.top-news .post-box__content {
	max-height: 300px;
	overflow: auto;
}


.elementor-column-gap-default>.elementor-row>.elementor-column>.elementor-element-populated>.elementor-widget-wrap {
    padding: 0px !important;
}

.elementor-section.elementor-section-boxed>.elementor-container {
    max-width: 100% !important;
}


#mv{
	position: relative;
	max-width: 100%;
	height: 768px;
	background: #fff;
}

#mv #mv-bg{
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: calc(100% - 700px);
	background-image: url(../img/top/top-bg.png);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: bottom left;
}

#mv #mv-ln{
	position: absolute;
	top: 39px;
	right: 87px;
	bottom: 39px;
	width: calc(100% - 787px);
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	border-bottom: 1px solid #fff;
}

#mv h1{
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	color: #fff;
	text-shadow: 0 0 14px #DE8F90;
	position: absolute;
	top: 50%;
	left: 65%;
	transform: translateY(-50%);
	width: 346px;
	display: block;
	font-size: 3.4rem;
	line-height: 2;
	letter-spacing: .253em;
}

#mv #mv-slide .slide-wrap{
	position: relative;
	max-width: 62%;
	height: 768px;
	z-index: 1;
}

#mv #mv-slide .slide-wrap .prev-arrow,
#mv #mv-slide .slide-wrap .next-arrow{
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	display: block;
	width: 30px;
	z-index: 32;
}

#mv #mv-slide .slide-wrap .prev-arrow{
	left: 20px;
}

#mv #mv-slide .slide-wrap .next-arrow{
	right: 20px;
}

#mv #mv-slide .slide-wrap ul.slider-mv{
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	width: 100%;
	height: 570px;
	z-index: 3;
}

#mv #mv-slide .slide-wrap ul.slider-mv li .mv-img{
	width: 100%;
	height: 570px;
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
}

#mv #mv-slide .slide-wrap ul.slider-mv .slick-list{
	z-index: 5;
}

.home main h2{
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	text-align: center;
	font-size: 1.4rem;
	line-height: 2.1;
	letter-spacing: .03em;
	color: #746050;
	padding: 0;
	margin: 0;
}

.home main h2 span.en{
	display: block;
	font-family: 'Cormorant Garamond', serif;
	font-weight: 500;
	font-size: 4.4rem;
	line-height: .8;
	letter-spacing: 0;
	padding-bottom: 8px;
}

.page main h2::after{
	display: none;
}

.home main h3{
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	text-align: center;
	font-size: 2.0rem;
	line-height: 1.8;
	letter-spacing: .05em;
	color: #DE8F90;
	margin: 45px 0 0;
	padding: 0;
}

.home main h3 span.emp{
	font-size: 2.6rem;
}

.home main h3::after{
	display: none;
}

#announcement,
#preofinf,
#introduction,
#information{
	display: block;
	width: 100%;
}


#announcement .announcement-box{
	display: grid;
	grid-template-columns: 41% 1fr;
	min-height: 856px;
}

#announcement .img-container{
	width: 100%;
	height: 856px;
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
}

#announcement .txt-container{
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
}

#announcement .txt-container .contents-read{
	max-width: 620px;
	padding: 0 32px;
}

#announcement .txt-container .read-box{
	margin-top: 26px;
}

#announcement .txt-container .read-box p{
	font-size: 1.5rem;
	line-height: 2.46;
	letter-spacing: .05em;
}

#announcement .txt-container .dr-name{
	position: relative;
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	text-align: right;
	font-size: 1.8rem;
	letter-spacing: .05em;
	color: #746050;
	margin-top: 30px;
}

#announcement .txt-container .dr-name span.posi{
	font-size: 1.5rem;
	padding-right: 16px;
}

#announcement .txt-container .dr-name span.rubi{
	position: absolute;
	right: 0;
	bottom: -21px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	font-size: .9rem;
	letter-spacing: .05em;
	color: #DE8F90;
}

#announcement .txt-container .dpro-btn{
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	margin-top: 42px;
}

#announcement .txt-container .dpro-btn a{
	display: block;
	width: 310px;
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
	border-radius: 3.25rem;
	box-shadow: 0 2px 30px rgba(224,171,172,0.2);
}

#announcement .txt-container .dpro-btn a img{
	transition-duration: .3s;
}

#announcement .txt-container .dpro-btn a img:hover{
	opacity: 0;
}

#preofinf{
	background: #F6EFE7;
}

#preofinf .inner{
	padding: 108px 0 180px;
}

#preofinf .prevention{
	position: relative;
	margin-top: 46px;
}

#preofinf .prevention .slide-wrap{
	width: 48.5%;
	margin-left: auto;
}

#preofinf .prevention .slide-wrap .slick-dotted.slick-slider{
	margin-bottom: 0;
}

#preofinf .prevention .slide-wrap ul.slider-prevention{
	width: 100%;
	z-index: 3;
}

#preofinf .prevention .slide-wrap ul.slider-prevention li .preofinf-img{
	margin: 0 3.66%;
}

#preofinf .prevention .slide-wrap ul.slider-prevention .slick-list{
	z-index: 5;
}

#preofinf .prevention .slide-wrap ul.slider-prevention .slick-list .slick-track{
    margin-left: -34.4%;
}

#preofinf .prevention .slide-wrap .slick-dots{
	position: relative;
	top: 0 !important;
	bottom: 0 !important;
	width: auto;
	text-align: left !important;
	margin-top: 20px;
	display: inline-flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: center;
}

#preofinf .prevention .slide-wrap .slick-dots::before{
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	content: '';
	width: calc(100% - 56px);
	height: 1px;
	background: #A79A8F;
}

#preofinf .prevention .slide-wrap .slick-dots li{
	width: 32px;
	height: 32px;
	margin: 0 11px !important;
}

#preofinf .prevention .slide-wrap .slick-dots li button{
	position: relative;
	width: 32px;
	height: 32px;
}

#preofinf .prevention .slide-wrap .slick-dots li button:before{
	font-family: 'Libre Caslon Text', serif;
	font-weight: 400;
	font-size: 15px !important;
	line-height: 1;
	color: #A79A8F !important;
	position: absolute;
	top: 0;
	left: 0;
	width: 32px;
	height: 32px;
	background: #fff;
	border-radius: 16px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	opacity: 1 !important;
	transition-duration: .3s;
}

#preofinf .prevention .slide-wrap .slick-dots li button:hover:before{
	color: #fff !important;
	background: #746050;
}

#preofinf .prevention .slide-wrap .slick-dots li.slick-active button:before{
	color: #fff !important;
	background: #746050;
}

#preofinf .prevention .slide-wrap ul.slick-dots li:nth-child(1) button:before{
	content: '01';
}
#preofinf .prevention .slide-wrap ul.slick-dots li:nth-child(2) button:before{
	content: '02';
}
#preofinf .prevention .slide-wrap ul.slick-dots li:nth-child(3) button:before{
	content: '03';
}
#preofinf .prevention .slide-wrap ul.slick-dots li:nth-child(4) button:before{
	content: '04';
}
#preofinf .prevention .slide-wrap ul.slick-dots li:nth-child(5) button:before{
	content: '05';
}
#preofinf .prevention .slide-wrap ul.slick-dots li:nth-child(6) button:before{
	content: '06';
}
#preofinf .prevention .slide-wrap ul.slick-dots li:nth-child(7) button:before{
	content: '07';
}
#preofinf .prevention .slide-wrap ul.slick-dots li:nth-child(8) button:before{
	content: '08';
}

#preofinf .txt-prevention{
	position: absolute;
	top: 0;
	left: 0;
	width: 48%;
}

#preofinf .txt-prevention .txt-container .ttl-h4{
	height: 118px;
	padding-left: 24px;
	background: #fff;
	border-radius: 0 5.9rem 5.9rem 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	align-items: center;
}

#preofinf .txt-prevention .txt-container .ttl-h4-in{
	width: 524px;
	padding: 0 0 0 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: center;
}

#preofinf .txt-prevention .txt-container span.numb{
	width: 91px;
	height: 78px;
	background-size: 89px auto;
	background-repeat: no-repeat;
	background-position: center;
}

#preofinf .txt-prevention .txt-container h4{
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	font-size: 15px;
	letter-spacing: .03em;
	color: #746050;
	padding-left: 7px;
}

#preofinf .txt-prevention .txt-container h4 span.en{
	display: block;
	font-family: 'Cormorant Garamond', serif;
	font-weight: 500;
	font-size: 28px;
	line-height: 1;
	letter-spacing: 0;
	padding: 10px 0 3px;
}

#preofinf .txt-prevention .txt-container .read-box{
	padding-left: 24px;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
}

#preofinf .txt-prevention .txt-container .read-box-in{
	width: 524px;
	padding: 30px 0 0 0;
}

#preofinf .txt-prevention .txt-container .read-box p{
	font-size: 15px;
	line-height: 2.46;
	letter-spacing: .05em;
}

#introduction{
	background: #fff;
}

#introduction .intro-inner{
	padding: 108px 0 120px;
	background-image: url(../img/top/bg-deco-01.png);
	background-size: 100%;
	background-repeat: no-repeat;
	background-position: bottom center;
}

#introduction .intro-container{
	max-width: 866px;
	margin: 0 auto;
	padding: 0 32px;
}

#introduction .read-box{
	padding: 40px 0;
}

#introduction .read-box p{
	text-align: center;
	font-size: 1.5rem;
	line-height: 2.46;
	letter-spacing: .05em;
}

#introduction .movie-box{
	position: relative;
	width: 100%;
	padding-top: 56.25%;
}

#introduction .movie-box iframe {
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
}

#information .info-inner{
	max-width: 1148px;
	margin: 0 auto;
	padding: 108px 32px 48px;
}

#information .dc-info-container{
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-gap: 36px;
	margin-top: 45px;
}

#information ul.info-lists{
	font-size: 1.5rem;
	line-height: 1.8;
	letter-spacing: .05em;
}

#information ul.info-lists li{
	position: relative;
	display: grid;
	grid-template-columns: 131px calc(100% - 139px);
	grid-gap: 8px;
	padding: 0 0 13px;
}

#information ul.info-lists li + li{
	padding: 13px 0;
}

#information ul.info-lists li::before{
	content: "";
	width: 100%;
	height: 2px;
	background-image: url(../img/common/dotted.svg);
	background-size: 7px 2px;
	background-repeat: repeat-x;
	background-position: center left;
	position: absolute;
	bottom: -1px;
	left: 0;
}

#information .info-lists span.color-c{
	font-weight: 500;
	color: #746050;
}

#information .info-lists .emp{
	font-weight: 500;
	color: #A77475;
}

#information .info-lists .tel-c{
	color: #A77475;
}

#information .info-lists span.und-l{
	text-decoration: underline;
	text-decoration-color: #A77475;
}

.ttb-box{
	background: #fff;
}

.ttb-box .box-inner{
	padding: 0 30px 0 0;
}

.ttb-box .box-inner + .box-inner{
	border-top: 1px solid #F2EFED;
}

.ttb-box .ttb{
	width: 100%;
	table-layout: fixed;
	border-collapse: collapse;
}

.ttb-box .ttb th,
.ttb-box .ttb td {
	text-align: center;
	vertical-align: middle;
	line-height: 1;
	letter-spacing: 0;
	font-size: 1.5rem;
	padding: 21px 0;
}

.ttb-box .ttb td {
	color: #DE8F90;
}

.ttb-box .ttb td span.close{
	color: #312B26;
}

.ttb-box .ttb thead th{
	font-weight: 500;
	color: #746050;
}

.ttb-box .ttb thead th:first-child,
.ttb-box .ttb tbody th:first-child{
	width: 23%;
}

.ttb-box .ttb tbody th:first-child{
	text-align: right;
	padding-right: 3.2%;
}

.ttb-box .ttb thead th:not(:first-child) {
	width: 11%;
}

.dc-ttb .ttb-sup{
	margin-top: 13px;
}

.dc-ttb .ttb-sup p{
	font-size: 15px;
	letter-spacing: .05em;
}

.dc-ttb .ttb-sup p span.cch{
	color: #DE8F90;
	padding-right: .5em;
}

.dc-ttb .ttb-txt{
	margin-top: 3px;
}

.dc-ttb .ttb-txt ul.ttb-lists{
	font-size: 15px;
	letter-spacing: .05em;	
}

.dc-ttb .ttb-txt ul.ttb-lists li{
	display: grid;
	grid-template-columns: 100px calc(100% - 108px);
	grid-gap: 8px;
}

.dc-ttb .ttb-txt ul.ttb-lists span.txt-i{
	font-weight: 500;
	color: #746050;
}

#googlemap .map-inner{
	padding: 0 30px;
}

.g-map{
	max-width: 1080px;
	margin: 45px auto 0;
	height: 0;
	overflow: hidden;
	padding-bottom: 331px;
	position: relative;
}

.g-map iframe{
	position: absolute;
	left: 0;
	top: 0;
	height: 100%;
	width: 100%;
}

.goto-gmap{
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
}

.goto-gmap a{
	position: relative;
	display: inline-block;
	font-size: 14px;
	line-height: 1;
	letter-spacing: .03em;
	color: #746050;
	padding: 13px 0 13px 25px;
}

.goto-gmap a::before{
	content: "";
	width: 20px;
	height: 20px;
	background-image: url(../img/top/map-icon.svg);
	background-size: 14px auto;
	background-repeat: no-repeat;
	background-position: center;
	position: absolute;
	top: 52%;
	left: 0;
	transform: translateY(-50%);
}

@media screen and (max-width: 1130px) {

	#mv #mv-slide .slide-wrap{
		max-width: 50%;
	}

	#mv #mv-bg{
		width: 50%;
	}

	#mv #mv-ln{
		width: 50%;
	}

	#mv h1{
		left: 57%;
	}

}


@media screen and (max-width: 960px) {

	#mv{
		height: 667px;
	}

	#mv #mv-bg{
		width: 100%;
		background-image: url(../img/top/top-bg-s.png);
		background-position: bottom center;
	}

	#mv #mv-ln{
		position: absolute;
		top: 14px;
		left: 15px;
		bottom: 14px;
		width: calc(100% - 15px);
		border-right: none;
		border-left: 1px solid #fff;
	}

	#mv h1{
		position: relative;
		top: auto;
		left: auto;
		transform: translateY(0);
		width: 700px;
		display: block;
		text-align: right;
		font-size: 3.0rem;
		line-height: 1.76;
		letter-spacing: .253em;
		padding: 27px 0 0;
	}

	#mv #mv-slide{
		padding-top: 99px;
	}

	#mv #mv-slide .slide-wrap{
		max-width: 700px;
		height: 345px;
	}

	#mv #mv-slide .slide-wrap .prev-arrow,
	#mv #mv-slide .slide-wrap .next-arrow{
		position: absolute;
		top: auto;
		bottom: 10px;
		transform: translateY(0);
		display: block;
		width: 21px;
		z-index: 32;
	}

	#mv #mv-slide .slide-wrap .prev-arrow{
		left: auto;
		right: 60px;
	}

	#mv #mv-slide .slide-wrap .next-arrow{
		right: 10px;
	}

	#mv #mv-slide .slide-wrap ul.slider-mv{
		height: 345px;
	}

	#mv #mv-slide .slide-wrap ul.slider-mv li .mv-img{
		height: 345px;
	}

	#preofinf .txt-prevention .txt-container .ttl-h4{
		padding-left: 15px;
	}

	#preofinf .txt-prevention .txt-container span.numb{
		width: 52px;
		height: 43px;
		background-size: 50px auto;
	}

	#preofinf .txt-prevention .txt-container h4{
		font-size: 13px;
	}

	#preofinf .txt-prevention .txt-container h4 span.en{
		font-size: 20px;
	}

	#preofinf .prevention .slide-wrap .slick-dots li{
		width: 32px;
		height: 32px;
		margin: 0 6px !important;
	}

	.ttb-box .ttb thead th:not(:first-child) {
		width: 6%;
	}

	.ttb-box .ttb thead th:last-child {
		width: 13%;
	}

	.ttb-box .ttb td {
		width: 6%;
	}
	.ttb-box .ttb td:last-child {
		width: 13%;
	}

}


@media screen and (max-width: 767px) {

	#mv{
		height: 667px;
	}

	#mv #mv-bg{
		width: 100%;
		background-image: url(../img/top/top-bg-s.png);
		background-position: bottom center;
	}

	#mv #mv-ln{
		position: absolute;
		top: 14px;
		left: 15px;
		bottom: 14px;
		width: calc(100% - 15px);
		border-right: none;
		border-left: 1px solid #fff;
	}

	#mv h1{
		position: relative;
		top: auto;
		left: auto;
		transform: translateY(0);
		width: 100%;
		display: block;
		text-align: right;
		font-size: 3.0rem;
		line-height: 1.76;
		letter-spacing: .253em;
		padding: 27px 6% 0;
	}

	#mv #mv-slide{
		padding-top: 91px;
	}

	#mv #mv-slide .slide-wrap{
		max-width: 92%;
		height: 345px;
	}

	#mv #mv-slide .slide-wrap .prev-arrow,
	#mv #mv-slide .slide-wrap .next-arrow{
		position: absolute;
		top: auto;
		bottom: 10px;
		transform: translateY(0);
		display: block;
		width: 21px;
		z-index: 32;
	}

	#mv #mv-slide .slide-wrap .prev-arrow{
		left: auto;
		right: 60px;
	}

	#mv #mv-slide .slide-wrap .next-arrow{
		right: 10px;
	}

	#mv #mv-slide .slide-wrap ul.slider-mv{
		height: 345px;
	}

	#mv #mv-slide .slide-wrap ul.slider-mv li .mv-img{
		height: 345px;
	}

	.home main h2 span.en{
		font-size: 3.6rem;
	}

	.home main h3{
		font-size: 1.8rem;
		margin-top: 45px;
	}

	.home main h3 span.emp{
		font-size: 2.4rem;
	}

	#announcement .announcement-box{
		display: grid;
		grid-template-columns: 1fr;
		min-height: auto;
		padding-bottom: 70px;
	}

	#announcement .img-container{
		order: 2;
		width: 80%;
		height: 102.2vw;
	}

	#announcement .txt-container{
		order: 1;
		display: block;
		padding: 80px 0 70px;
	}

	#announcement .txt-container .contents-read{
		max-width: 100%;
		padding: 0 4%;
	}

	#announcement .txt-container .read-box{
		margin-top: 25px;
	}

	#announcement .txt-container .dr-name{
		margin-top: 25px;
	}

	#announcement .txt-container .dpro-btn{
		margin-top: 41px;
	}

	#announcement .txt-container .dpro-btn a img:hover{
		opacity: 1;
	}

	#preofinf .inner{
		padding: 90px 0 68px;
	}

	#preofinf .prevention{
		margin-top: 41px;
	}

	#preofinf .prevention .slide-wrap{
		width: 100%;
		margin-left: 0;
	}

	#preofinf .prevention .slide-wrap ul.slider-prevention li .preofinf-img{
		margin: 0 3.7%;
	}

	#preofinf .prevention .slide-wrap ul.slider-prevention .slick-list .slick-track{
    	margin-left: 0;
	}

	#preofinf .prevention .slide-wrap .slick-dots{
		margin-top: 15px;
		left: 50%;
	    transform: translateX(-50%);
	}

	#preofinf .prevention .slide-wrap .slick-dots::before{
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		content: '';
		width: calc(100% - 56px);
		height: 1px;
		background: #A79A8F;
	}

	#preofinf .prevention .slide-wrap .slick-dots li{
		width: 26px;
		height: 26px;
		margin: 0 6px !important;
	}

	#preofinf .prevention .slide-wrap .slick-dots li button{
		position: relative;
		width: 26px;
		height: 26px;
	}

	#preofinf .prevention .slide-wrap .slick-dots li button:before{
		font-size: 11px !important;
		line-height: 1;
		width: 26px;
		height: 26px;
		border-radius: 13px;
	}

	#preofinf .txt-prevention{
		position: relative;
		width: 100%;
	}

	#preofinf .txt-prevention .txt-container .ttl-h4{
		width: 96%;
		height: 118px;
		padding-left: 11px;
		border-radius: 0 5.9rem 5.9rem 0;
		margin-top: 25px;
	}

	#preofinf .txt-prevention .txt-container .ttl-h4-in{
		width: 100%;
		padding: 0;
	}

	#preofinf .txt-prevention .txt-container span.numb{
		width: 66px;
		height: 54px;
		background-size: 64px auto;
	}

	#preofinf .txt-prevention .txt-container h4{
		font-size: 1.4rem;
		line-height: 1.5;
	}

	#preofinf .txt-prevention .txt-container h4 span.en{
		font-size: 2.0rem;
		line-height: 1.1;
		padding: 0 0 5px;
	}

	#preofinf .txt-prevention .txt-container .read-box{
		padding: 0 8.3%;
		display: block;
	}

	#preofinf .txt-prevention .txt-container .read-box-in{
		width: 100%;
		padding: 30px 0 0 0;
	}

	#preofinf .txt-prevention .txt-container .read-box p{
		line-height: 2.2;
	}

	#introduction .intro-inner{
		padding: 77px 0 100px;
		background-image: url(../img/top/bg-deco-s01.png);
		background-size: cover;
		background-position: top center;
	}

	#introduction .intro-container{
		max-width: 92%;
		padding: 0;
	}

	#introduction .read-box{
		padding: 25px 0;
	}

	#introduction .read-box p{
		text-align: left;
		line-height: 2.2;
	}

	#introduction .movie-box{
		padding-top: 56.25%;
	}

	#information .info-inner{
		max-width: 100%;
		padding: 77px 20px 48px;
	}

	#information .dc-info-container{
		display: grid;
		grid-template-columns: 1fr;
		grid-gap: 48px;
		margin-top: 56px;
	}

	#information ul.info-lists{
		font-size: 1.4rem;
		line-height: 1.57;
	}

	#information ul.info-lists li{
		grid-template-columns: 80px calc(100% - 88px);
		grid-gap: 8px;
		padding: 0 0 13px;
	}

	#information ul.info-lists li + li{
		padding: 13px 0;
	}

	.ttb-box .box-inner{
		padding: 0 17px 0 0;
	}

	.ttb-box .ttb th,
	.ttb-box .ttb td {
		font-size: 1.4rem;
	}

	.ttb-box .ttb thead th:first-child,
	.ttb-box .ttb tbody th:first-child{
		width: 30%;
	}

	.ttb-box .ttb tbody th:first-child{
		text-align: right;
		padding-right: 2.3%;
	}

	.ttb-box .ttb thead th:not(:first-child) {
		width: 9.5%;
	}

	.ttb-box .ttb thead th:last-child,
	.ttb-box .ttb tbody th:last-child,
	.ttb-box .ttb tbody td:last-child{
		width: 15%;
	}

	.ttb-box .ttb td {
		width: auto;
	}

	.dc-ttb .ttb-sup p{
		font-size: 1.4rem;
	}

	.dc-ttb .ttb-txt ul.ttb-lists{
		font-size: 1.4rem;
		line-height: 1.57;
	}

	.dc-ttb .ttb-txt ul.ttb-lists li{
		display: grid;
		grid-template-columns: 80px calc(100% - 88px);
		grid-gap: 8px;
		padding-top: 7px;
	}

	.dc-ttb .ttb-txt ul.ttb-lists li + li{
		padding-top: 13px;
	}

	#googlemap .map-inner{
		padding: 0 20px;
		margin-bottom: 72px;
	}
	.g-map{
		max-width: 100%;
		margin: 50px auto 0;
		height: 0;
		overflow: hidden;
		padding-bottom: 60vw;
		position: relative;
	}

}

/*--------------------------------------
	2022-11-18 追加
--------------------------------------*/

.post-box{
	min-height: 350px;
	display: grid;
	grid-template-columns: 246px 1fr;
	grid-gap: 32px;
	margin: 0 0 45px;
	padding: 59px 32px 59px 0;
	background-color: #fff;
	background-image: url(../img/top/news-bg.png);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: bottom left;
}

.post-box__header {
	position: relative;
	padding: 0;
	border-bottom: none;
}

.news-head-inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.post-box__summary-link {
	display: inline-block;
	position: static;
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	text-align: center;
	font-size: 15px;
	text-decoration: none;
	color: #746050;
	margin: 60px 0 0;
	padding: 3px 24px 3px 0;
	background-image: url(../img/top/arrow-r.png);
	background-size: 7px;
	background-repeat: no-repeat;
	background-position: 99% center;
	transition-duration: .3s;
}

.post-box__summary-link:hover{
	opacity: .7;
}

.post-box dl {
	position: relative;
	padding: 0 0 20px;
	margin-right: 49px;
	background-size: 0;
}

.post-box dl + dl{
	padding: 20px 0;
}

.post-box dl:after {
	content: "";
	width: 100%;
	height: 2px;
	background-image: url(../img/common/dotted.svg);
	background-size: 7px 2px;
	background-repeat: repeat-x;
	background-position: center left;
	position: absolute;
	bottom: -1px;
	left: 0;
}

.post-box dl dt {
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	line-height: 1;
	margin-bottom: 15px;
	font-size: 10px;
	color: #312B26;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: center;
}

.post-box dl dt .new-label {
	width: 48px;
	height: 22px;
	padding: 0;
	margin: 0 0 0 10px;
	font-family: 'Cormorant Garamond', serif;
	font-weight: 500;
	line-height: 1;
	font-size: 12px;
	letter-spacing: 0;
	text-indent: 0;
	text-align: center;
	color: #fff;
	background: #DE8F90;
	border-radius: 11px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
}

.post-box dl dd {
	position: relative;
	min-height: 49px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
}

.post-box dl dd:after {
	content: '';
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	width: 40px;
	height: 40px;
	border-radius: 50%;
	box-shadow: 0 2px 30px rgba(224,171,172,0.2);
	background-image: url(../img/top/news-arrow.png);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
}

.post-box dl dd a {
	font-size: 1.5rem;
	line-height: 1.8;
	letter-spacing: .05em;
	margin-right: 58px;
}


@media screen and (max-width: 767px) {

	.post-box{
		min-height: 350px;
		display: grid;
		grid-template-columns: 1fr;
		grid-gap: 0;
		margin-bottom: 48px;
		padding: 35px 14px 29px 27px;
		background-image: url(../img/top/news-bg-sp.png);
	}

	.post-box__header {
		position: relative;
		padding: 0;
		border-bottom: none;
		margin-bottom: 32px;
	}

	.news-head-inner {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		align-items: center;
	}

	.top-news .post-box__header h2 {
		width: auto;
	    font-size: 20px;
		line-height: 1;
		letter-spacing: .05em;
	}

	.post-box__summary-link {
		margin: 0;
	}

	.top-news .post-box__content {
		max-height: 280px;
	}

	.post-box dl {
		position: relative;
		padding: 0 0 24px;
		margin-right: 19px;
		background-size: 0;
	}

	.post-box dl + dl{
		padding: 24px 0;
	}

	.post-box dl dt {
		margin-bottom: 13px;
	}

	.post-box dl dd {
		min-height: 39px;
	}

	.post-box dl dd:after {
		width: 30px;
		height: 30px;
	}

	.post-box dl dd a {
		font-size: 1.4rem;
		line-height: 1.6;
		margin-right: 50px;
	}

}