a {
	color: #796042;
}

body {
    color: #796042;
}

.home table.timetable th, .home table.timetable td {}
.home table.timetable tbody tr td span {}
@media screen and (min-width: 767px) {
.home table.timetable th, .home table.timetable td {}
.home table.timetable tbody tr td span {} 
}

.txt-vertical {
	cursor: vertical-text;
	writing-mode: vertical-rl;
	-o-writing-mode: vertical-rl;
	-ms-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	-moz-writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
	text-orientation: upright;
	word-wrap: break-word;
}
.txt-vertical .int {
	writing-mode: lr-tb;
	-o-writing-mode: horizontal-tb;
	-ms-writing-mode: horizontal-tb;
	-ms-writing-mode: lr-tb;
	-moz-writing-mode: horizontal-tb;
	-webkit-writing-mode: horizontal-tb;
	display: inline-block;
	text-align: center;
	line-height: 1;
}

img {
	width: 100%;
	height: auto;
}

#key {
	position: relative;
	margin-bottom: -10px;
}
#key::before {
	content: "";
	border: 1px solid #fff;
	position: absolute;
	top: 39px;
	bottom: 20px;
	right: 10px;
	left: 10px;
	z-index: 1;
}
#key img {
	width: 100%;
	height: auto;
}
#key .kv {
	height: 100vh;
}
#key .kv01 {
	background: url(/wp-content/uploads/kv012_sp.jpg) no-repeat 50% 50%;
	background-size: cover;
}
#key .kv02 {
	background: url(../img/kv02_sp.jpg) no-repeat 50% 50%;
	background-size: cover;
}
#key .kv03 {
	background: url(../img/kv03_sp.jpg) no-repeat 50% 50%;
	background-size: cover;
}
#key dl {
	position: absolute;
	top: 41vw;
	right: 9vw;
}
#key dl dt {
	margin-left: 20px;
	width: 78px;
}
#key dl dd {
	font-size: 18px;
	color: #fff;
	position: absolute;
	top: 9vw;
	right: 100px;
	height: 400px;
	letter-spacing: 1vw;
    font-weight: 600;
}
#key dl dd span {
	display: block;
}
#key .catch {
	color: #fff;
	font-size: 12px;
	width: 13px;
	position: absolute;
	left: 20px;
	bottom: 25vw;
}
#key .scroll {
	max-width: 64px;
	height: 76px;
	position: absolute;
	bottom: 20px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 2;
	width: 14vw;
}

@media screen and (min-width: 767px) {
#key::before {
	top: 50px;
	bottom: 34px;
	right: 20px;
	left: 20px;
}
#key .kv {
	height: 768px;
}
#key .kv01 {
	background: url(/wp-content/uploads/kv012-scaled.jpg) no-repeat 50% 50%;
	background-size: cover;
}
#key .kv02 {
	background: url(../img/kv02.jpg) no-repeat 50% 50%;
	background-size: cover;
}
#key .kv03 {
	background: url(../img/kv03.jpg) no-repeat 50% 50%;
	background-size: cover;
}
#key dl {
	top: 172px;
	right: 55px;
}
#key dl dt {
	margin-left: 20px;
	width: 101px;
}
#key dl dd {
	font-size: 20px;
	top: 41px;
	right: 138px;
	height: 468px;
	letter-spacing: 8px;
	line-height: 46px;
}
#key .catch {
	height: 690px;
	font-size: 12px;
	width: 17px;
	top: 235px;
	left: 47px;
	bottom: 0;
}
#key .scroll {
	width: 64px;
	height: 76px;
	bottom: 58px;
}
}
.title-c {
	text-align: center;
}
.title-c h2 {
	color: #F29801;
	font-size: 20px;
	display: inline-block;
	font-weight: bold;
}
.title-c h2 span {
	display: block;
	text-transform: uppercase;
	color: #796042;
	font-size: 40px;
	margin-bottom: 14px;
    font-weight: bold;
}

@media screen and (min-width: 767px) {
.title-c h2 {
	font-size: 20px;
	line-height: 1;
}
.title-c h2 span {
	font-size: 40px;
	letter-spacing: 3px;
	margin-bottom: 24px;
}
}
.btn-shared {
	width: 180px;
	margin-left: auto;
	margin-right: auto;
}
.btn-shared a {
	display: block;
	font-size: 18px;
	color: #fff;
	position: relative;
	background-color: #F29801;
	border-radius: 50px;
	text-align: center;
	padding: 12px 0px;
	line-height: 1;
	transition: all .4s ease;
        font-weight: 500;
}
.btn-shared a::after {
	content: "";
	background: url("../img/icon_arrow.png") no-repeat;
	background-size: 100% auto;
    width: 7px;
    height: 11px;
	position: absolute;
	top: 50%;
	right: 15px;
	transform: translateY(-50%);
}

@media screen and (min-width: 767px) {
.btn-shared {
	margin-left: 0;
	margin-right: 0;
}
	.btn-shared a {
    padding: 14px 0 12px;
}
	.btn-shared a:hover {
		opacity: .7;
	}
	.btn-shared a::after {}
}
#news {
	padding: 20vw 4vw;
	position: relative;
}
#news::before {
	content: "";
	background: #F7F6F0;
	position: absolute;
	top: 0;
	bottom: 0;
	left: calc(50% + 55px);
	right: 0;
}
#news .elementor-container {
	display: flex;
	justify-content: space-between;
	max-width: 1114px !important;
	margin: 0 auto;
}
#news .elementor-container .elementor-row {
	display: block;
	justify-content: space-between;
	width: 100%;
	position: relative;
}
#news .left {text-align: center;margin-bottom: 6vw;}
#news .left .ttl h2 {
	font-size: 40px;
	color: #796042;
	margin-bottom: 15px;
    font-weight: 500;
}
#news .left .ttl span {
	color: #F29801;
	font-size: 20px;
	display: block;
    font-weight: bold;
}
#news .right {

}

#news .right .newsfeed {
	background: #FFFFFF;
	padding: 4vw;
	box-sizing: border-box;
	box-shadow: 0 12px 24px rgba(0, 0, 0, 0.04);
	margin-bottom: 10vw;
}

#news .right dl {
	font-size: 16px;
	position: relative;
	padding: 10px 0;
    font-weight: bold;
}
#news .right dl dt {
	color: #F29801;
	letter-spacing: 1.8px;
}
#news .right dl dt span.new-label {
    display: none;
}
#news .right dl dd {
}
#news .right dl dd a {
	display: block;
	position: relative;
	color: #796042;
}
#news .right dl dd a::after {
	content: "";
	background: url("../img/icon_ellip.png") no-repeat center;
	background-size: 100% auto;
	width: 44px;
	height: 12px;
	position: absolute;
	top: 50%;
	right: 0;
	opacity: 0;
	margin-top: -8px;
}
#news .right dl + dl {
	border-top: 1px solid #D1BEA6;
}
#news .btn-shared {
	position: relative;
}

@media screen and (min-width: 767px) {
#news {
	padding: 95px 0 97px;
}
#news::before {
	left: calc(50% + 200px);
}
#news .elementor-container {
}
#news .elementor-container .elementor-row {
	display: flex;
	justify-content: space-between;
	width: 100%;
	position: relative;
}
#news .left {
	width: 19%;
	margin-bottom: 0;
	padding-top: 27px;
}
#news .left .ttl h2 {line-height: 1;margin-bottom: 19px;}
#news .left .ttl span {
	color: #F29801;
	font-size: 20px;
	display: block;
}

#news .right {
	width: 72%;
}
	
	#news .right .newsfeed {
        padding: 23px 53px 20px 43px;
        margin-bottom: 0;
        min-height: 244px;
	}	
#news .right dl {
	font-size: 16px;
	display: flex;
	justify-content: space-between;
	padding: 17px 0;
}
#news .right dl dt {
	width: 21%;
}
#news .right dl dd {
	width: 78%;
}
#news .right dl dd a::after {opacity: 1;}
#news .right dl dd a:hover {
	text-decoration: underline;
}
#news .right dl + dl {
	border-top: 1px solid #D1BEA6;
}
#news .btn-shared {
	position: absolute;
        top: 151px;
        left: 8px;
}
}
#clinic {
	padding: 20vw 4vw 10vw;
	position: relative;
}
#clinic::before {
	content: "";
	background: #F7F6F0;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: calc(50% - 55px);
}
#clinic .wrap {
	position: relative;
}
#clinic .wrap::before {
content: "";
    border: 2px solid #fff;
    position: absolute;
    top: 20px;
    right: -45px;
    bottom: -45px;
    left: -45px;
	display: none;
	    z-index: -1;
}
#clinic .title-c {
	margin-bottom: 8vw;
}
#clinic .row {
	justify-content: space-between;
}
#clinic .row .col {margin-bottom: 8vw;}
#clinic .row .col .table_txt {
	margin-bottom: 5vw;
	color: #454545;
}
#clinic table.timetable th {
    font-weight: bold;
}
#clinic table.timetable th, 
#clinic table.timetable td {
    padding: 15px 0;
}
#clinic table.timetable td {
    font-weight: 500;
}
#clinic table.timetable thead th,
#clinic table.timetable thead td{
    font-size: 16px;
	font-weight: 600;
}

#clinic table.timetable tbody tr td span {
	font-size: 15px;
}

#clinic .row .col .table-info {
	background-color: #fff;
	padding: 5vw 4vw;
}
#clinic .row .col .table-info dl {
	display: flex;
	justify-content: space-between;
	line-height: 24px;
	padding: 10px 0;
}
#clinic .row .col .table-info dl dt {
	max-width: 100px;
	width: 32%;
    font-weight: bold;
}
#clinic .row .col .table-info dl dt span {
	display: block;
	border-radius: 20px;
	background: #F29801;
	font-size: 16px;
	padding: 2px 10px;
	color: #fff;
	text-align: center;
}
#clinic .row .col .table-info dl dd {
	width: 65%;
}
#clinic .row .col .table-info h1 {
	font-weight: 600;
}
#clinic .row .col .photo {
	height: 70vw;
	margin-bottom: 30px;
}
#clinic .row .col .mmap iframe {
	height: 360px;
	width: 100%;
/* 	-webkit-filter: grayscale(100%);
	-moz-filter: grayscale(100%);
	-ms-filter: grayscale(100%);
	-o-filter: grayscale(100%);
	filter: grayscale(100%);
	filter: gray; */
}

@media screen and (min-width: 767px) {
#clinic {
	padding: 101px 0 101px;
}
#clinic::before {
	top: 0;
	bottom: 0;
	left: 0;
	right: calc(50% - 200px);
}
#clinic .wrap {
}
#clinic .wrap::before {
	display: block;
}
#clinic .title-c {
	margin-bottom: 57px;
	position: relative;
	z-index: 2;
}
#clinic .title-c h2 {
	background: #F7F6F0;
	padding: 0 40px;
}
#clinic .row {
	display: flex;
	justify-content: space-between;
}
#clinic .row .col {
	width: 48.5%;
	margin-bottom: 0;
}
#clinic .row .col .table_txt {
	margin-bottom: 20px;
	padding-top: 0;
}
#clinic .row .col .table-info {
	padding:14px 23px 12px;
}
#clinic .row .col .table-info dl {
	line-height: 24px;
	padding: 9px 0;
}
#clinic .row .col .table-info dl dt {
        max-width: 100px;
        width: 18%;
        min-width: 86px;
}
#clinic .row .col .table-info dl dt span {
	padding: 4px 0px;
	line-height: 1;
}
#clinic .row .col .table-info dl dd {
	width: 78%;
}
#clinic .row .col .photo {
	height: 167px;
	margin-bottom: 30px;
}
#clinic .row .col .mmap iframe {
	height: 360px;
	width: 100%;
}

#clinic table.timetable thead th, #clinic table.timetable thead td {
	font-size: 18px;
}

}
#greeting {
	background-color: #F9F9F9;
	padding: 20vw 4vw 0;
	position: relative;
}
#greeting::before {
	content: "";
	background: url(../img/img_greeting04.jpg) no-repeat center;
	-webkit-background-size: cover;
	background-size: cover;
	position: absolute;
	bottom: 0;
	right: 0;
	left: 0;
	height: 71vw;
}
#greeting .wrap {
	max-width: 100%;
	padding-top: 0;
	padding-bottom: 0;
}
#greeting .photo-group {
	position: relative;
	top: 0;
	left: 0;
	display: flex;
	justify-content: space-between;
}
#greeting .photo-group .img-object {
	height: 30vw;
	width: 50%;
}
#greeting .photo-group .img-object + .img-object {
	margin-top: 0;
}
#greeting .title-c {
	margin-bottom: 10vw;
    position: relative;
    z-index: 2;
}
#greeting .box {
	position: relative;
	z-index: 2;
}
#greeting .box .text {
	padding: 5vw;
	background-color: #fff;
	margin-bottom: 10vw;
    font-weight: bold;
}
#greeting .box .btn-shared {
	max-width: 198px;
	margin-left: auto;
	width: 198px;
}
#greeting .greeting-thumb {
	position: relative;
	padding-top: 15vw;
}
#greeting .greeting-thumb .photo {
	width: 72%;
	max-width: 550px;
	margin-left: auto;
}
#greeting .greeting-thumb .photo img {
	width: 100%;
	height: auto;
}
#greeting .greeting-thumb .name {
	position: absolute;
	top: 24vw;
	left: 14vw;
	width: 80px;
}
#greeting .greeting-thumb .name .txt-vertical {
	font-size: 16px;
	width: 30px;
	height: 210px;
	color: #fff;
	background-color: #F29801;
	float: right;
	text-align: center;
	line-height: 24px;
	padding: 0vw 1vw 0vw 0vw;
        font-weight: bold;
}
#greeting .greeting-thumb .name .txt-vertical span {
	margin-bottom: 10px;
}
#greeting .greeting-thumb .name .txt-vertical + .txt-vertical {
	margin-top: 5vw;
	margin-right: 3vw;
}

@media screen and (min-width: 767px) {
#greeting {
	padding: 45px;
}
#greeting::before {
	bottom: 45px;
        height: auto;
        top: 45px;
        left: 40.5%;
        right: 0;
}
	
#greeting .wrap {
	padding-top: 51px;
	padding-bottom: 134px;
} 
    
#greeting .photo-group {
	width: 37.9%;
	position: absolute;
	top: 0;
	left: 0;
	display: block;
}
#greeting .photo-group .img-object {
	height: 273px;
	width: 100%;
}
#greeting .photo-group .img-object + .img-object {
	margin-top: 50px;
}
#greeting .title-c {
	margin-bottom: 59px;
}
#greeting .box {
	width: 550px;
	max-width: 55%;
	margin-left: auto;
	margin-right: calc(50% - 10px);
}
#greeting .box .text {
	padding: 17px 33px;
	line-height: 32px;
	margin-bottom: 19px;
	letter-spacing: 0.7px;
}
#greeting .box .btn-shared {
	max-width: 198px;
	margin-left: auto;
	margin-right: 26px;
}
#greeting .greeting-thumb {
	position: absolute;
	bottom: -1px;
	left: calc(50% + 0px);
	width: 50%;
	padding-top: 0;
}
#greeting .greeting-thumb .photo {
	width: 100%;
	max-width: 550px;
	margin-left: 0;
}
#greeting .greeting-thumb .photo img {
	width: 100%;
	height: auto;
}
#greeting .greeting-thumb .name {
        top: 184px;
        left: 93px;
        width: 99px;
}
#greeting .greeting-thumb .name .txt-vertical {
        font-size: 16px;
        width: 32px;
        height: 239px;
        margin-right: 0;
        padding: 2px 8px 2px 5px;
        letter-spacing: 3px;
        line-height: 1;
}
#greeting .greeting-thumb .name .txt-vertical span {
	margin-bottom: 10px;
}
#greeting .greeting-thumb .name .txt-vertical + .txt-vertical {
        margin-top: 20px;
        margin-right: 8px;
}
}
#feature {
	padding: 20vw 4vw;
	position: relative;
	background: rgb(247,246,240);
	background: linear-gradient(180deg, rgba(247,246,240,1) 0%, rgba(255,255,255,1) 100%);
}
#feature::before {
	content: "";
	background: url(../img/feature_bg.png);
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
}
#feature .title-c {
	margin-bottom: 10vw;
}
#feature .row {
	justify-content: space-between;
}
#feature .row .photo {
	height: 60vw;
}
#feature .row dl {padding-top: 7vw;}
#feature .row dl dt {
	position: relative;
	margin-bottom: 11vw;
	font-size: 20px;
}
#feature .row dl dt::before {
	content: "";
	background: url("../img/feature_dotted.png") repeat-x bottom center;
	background-size: contain;
	position: absolute;
	bottom: -30px;
	left: 0;
	height: 22px;
	width: 102px;
}
#feature .row:nth-child(2n) {
	flex-direction: row-reverse;
}
#feature .row + .row {
	margin-top: 40px;
}

@media screen and (min-width: 767px) {
#feature {
	padding: 103px 0 94px;
}
#feature .title-c {
	margin-bottom: 59px;
}
#feature .row {
	display: flex;
	justify-content: space-between;
}
#feature .row .photo {
	width: 46%;
	height: 310px;
}
#feature .row dl {
	width: 50%;
	padding-top: 8px;
	line-height: 32px;
	letter-spacing: 1.3px;
}
#feature .row dl dt {
	margin-bottom: 42px;
	font-size: 20px;
}
#feature .row dl dt::before {
	position: absolute;
	bottom: -28px;
	left: -4px;
	height: 22px;
	width: 102px;
}
#feature .row:nth-child(2n) {
	flex-direction: row-reverse;
}
#feature .row + .row {
	margin-top: 57px;
}
	
	#feature .row:nth-child(3) dl {
		padding-top: 38px;
	}	
	#feature .row:nth-child(4) dl {
		padding-top: 51px;
	}	
	
}
#menu {
	background: url("../img/menu_bg_sp.jpg") no-repeat center;
	padding: 20vw 4vw 10vw;
    -webkit-background-size: cover;
    background-size: cover;
}
#menu .title-c {
	margin-bottom: 8vw;
}
#menu .list-image {
	justify-content: center;
	flex-wrap: wrap;
	gap: 14px;
}
#menu .list-image .item {
	margin-bottom: 15vw;
	position: relative;
}
#menu .list-image .item::before {
	content: "";
	background: url(../img/icon_corner2.png) no-repeat;
	width: 16px;
	height: 16px;
	position: absolute;
	top: 5px;
	right: 5px;
	z-index: 2;
}
#menu .list-image .item .img-object {
	height: 262px;
	transition: all .4s ease;
}
#menu .list-image .item a {
	position: absolute;
	top: 0;
	right: 0;
	bottom: -30px;
	left: 0;
	z-index: 2;
	font-size: 0;
}
#menu .list-image .item .ttl {
	position: absolute;
	bottom: -20px;
	left: 20px;
	right: 20px;
	z-index: 2;
	display: table;
	width: 80%;
	text-align: center;
	margin: 0 auto;
}
#menu .list-image .item .ttl span {
	display: table-cell;
	width: 100%;
	background: #F29801;
	border-radius: 50px;
	color: #fff;
	line-height: 24px;
	height: 56px;
	vertical-align: middle;
	padding: 5px 0;
    font-weight: bold;
}

@media screen and (min-width: 767px) {
#menu {
	background: url("../img/menu_bg.jpg") no-repeat center;
	padding: 102px 0 80px;
    -webkit-background-size: cover;
    background-size: cover;
}
#menu .title-c {
	margin-bottom: 58px;
}
#menu .list-image {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 14px;
}
#menu .list-image .item {
	margin-bottom: 44px;
	width: 24%;
}
#menu .list-image .item .img-object {
	height: 262px;
	transition: all .4s ease;
}
#menu .list-image .item .ttl {
	position: absolute;
	bottom: -27px;
	left: 20px;
	right: 20px;
	z-index: 2;
	display: table;
	width: 80%;
	text-align: center;
	height: 56px;
    max-width: 240px;
}
#menu .list-image .item .ttl span {
	display: table-cell;
	color: #fff;
	line-height: 24px;
	height: 44px;
	vertical-align: middle;
}
#menu .list-image .item:hover .img-object {
	opacity: .6;
}
}
#scroll-photo .img-object {
	height: 129px;
}

@media screen and (min-width: 767px) {
#scroll-photo .img-object {
	height: 227px;
}
}


@media screen and (min-width: 767px) and (max-width: 1199px) {
	
	#feature,
	#clinic,
	#news {
		padding-left: 20px;
		padding-right: 20px;
	}
	#news .left {
		width: 28%;
	}
	#clinic .row .col .table-info dl dd {
		width: 65%;
	}
	#greeting {
		padding-left: 0;
		padding-right: 0;
	}
	#greeting .photo-group {
		bottom: 0px;
		height: 100%;
	}
	#greeting .photo-group .img-object {
		height: 50%;
	}
	#greeting .photo-group .img-object + .img-object {
		margin-top: 0;
	}
	
	#menu .list-image .item {
		width: 23%;
	}
	#menu .list-image .item .ttl span {
		border-radius: 25px;
		font-size: 14px;
		line-height: 20px;
	}
	
    #menu .list-image .item .ttl {
        bottom: -27px;
        left: 3%;
        right: 3%;
        width: 94%;
    }
	
	
}

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

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

