@charset "UTF-8";

/*メインイメージ、共通
---------------------------------------------------------*/
.m_img_area {
	width: 100%;
	height: 100vh;
	position: relative;
}
.m_img_area .m_img {
	position: absolute;
	z-index: 0;
}
.m_img_area .m_logo {
	position: absolute;
	z-index: 2;
}
.m_img_area .m_copy {
	position: absolute;
	z-index: 1;
}

.m_img_area .m_img {
	right: 0;
	top: 0;
	width: 80%;
	height: 95%;
	overflow: hidden;
}
.m_img_area .m_img img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: right top;
}

.m_img_area .m_logo,
.m_img_area .m_copy {
	left: 0;
	width: 100%;
	box-sizing: border-box;
	padding: 0 5.5%;
	text-align: left;
}

.m_img_area .m_logo {
	top: 4%;
	text-shadow: 0px 0px 20px rgba(255,255,255,1),
		0px 0px 20px rgba(255,255,255,1),
		0px 0px 20px rgba(255,255,255,1),
		0px 0px 20px rgba(255,255,255,1),
		0px 0px 20px rgba(255,255,255,1);
	font-size: min(100%,1.1vw);
}
.m_img_area .m_logo .ft_eng1 {
	color: var(--color_turquoise);
	font-size: 215%;
	letter-spacing: .1em;
}
.m_img_area .m_logo .ft_eng1 span {
	display: block;
	font-size: 65%;
	letter-spacing: .1em;
	line-height: 1.0em;
	margin-top: .5em;
}
.m_img_area .m_logo .ft_min {
	font-size: 400%;
	letter-spacing: .1em;
	margin-top: 1.5vh;
	margin-bottom: 2vh;
}

.m_img_area .m_copy {
	top: 62%;
	transform: translateY(-50%);
}
.m_img_area .m_copy .m_open {
	width: 85vh;
	max-width: 900px;
	transform: translateX(-7%);
}
.m_img_area .m_copy ul {
	margin-top: 2vh;
	display: flex;
	column-gap: .5em;
	text-align: center;
	color: var(--color_brown);
	font-size: min(95%,1.2vw);
	font-weight: bold;
	letter-spacing: .2em;
	line-height: 1.0em;
}
.m_img_area .m_copy li {
	width: 10.5em;
	background: #fff;
	padding: 1.5em 0;
	border-radius: 3.0em;
	box-shadow: 0px 0px 10px 0px rgba(0,0,0,0.15);
}

/*bnr_insta*/
.bnr_insta {
	width: 32vw;
	max-width: 370px;
	margin-top: 40px;
	margin-left: auto;
	margin-right: auto;
}

/*マーカー*/
.marker {
	background: #666;
	color: #fff;
	font-weight: bold;
	padding: .2em;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
.m_img_area .m_logo,
.m_img_area .m_copy {
	padding: 0 3%;
}
.m_img_area .m_logo {
	top: 3%;
	font-size: min(100%,1.2vw);
}
.m_img_area .m_copy {
	top: auto;
	bottom: 3%;
	transform: none;
}
.m_img_area .m_copy .m_open {
	width: 85%;
}
.m_img_area .m_copy ul {
	margin-top: 4%;
	font-size: min(95%,1.7vw);
	letter-spacing: .05em;
}
.m_img_area .m_copy li {
	width: auto;
	display: inline-block;
	padding: 1.5em 1.5em;
}

/*bnr_insta*/
.bnr_insta {
	width: 35vw;
	margin-top: 4%;
}
}

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



/*内覧会
---------------------------------------------------------*/
#event .w1200 {
	text-align: center;
}
#event .tit {
	width: 60%;
	margin-left: auto;
	margin-right: auto;
}
#event .sp_txt_l {
	margin: 1.3em 0;
}
#event .day {
	width: 90%;
	max-width: 810px;
	margin-left: auto;
	margin-right: auto;
	border-top: 1px solid var(--color_brown);
	border-bottom: 1px solid var(--color_brown);
	padding: 1.5em 0;
}
#event .day p {
	font-size: 110%;
	letter-spacing: .1em;
	line-height: 1.4em;
}

/*チラシを見るボタン*/
#event .btn_flyer {
	margin-top: 2.0em;
	text-align: center;
}
#event .btn_flyer a {
	display: inline-block;
	color: #fff;
	font-size: 110%;
	font-weight: bold;
	letter-spacing: .1em;
	line-height: 1.4em;
	background: var(--color_brown);
	padding: 1.0em 3em;
	border-radius: 3em;
}
#event .btn_flyer a:hover {
	background-color: var(--color_turquoise);
}
#event .btn_flyer a span {
	display: inline-block;
	padding-right: 1.6em;
	background: url(../images/icon_zoom.svg) no-repeat right center;
	background-size: auto 1em;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
#event .tit {
	width: 70%;
}
#event .sp_txt_l {
	margin: 1.0em 0;
}
}

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



/*オープニングスタッフ募集
---------------------------------------------------------*/
#recruit .rec_inbox {
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	padding: 50px 6%;
	padding-right: 0;
}
#recruit .rec_inbox::after {
	content: "";
	background: #f9f0f2;
	width: 96%;
	height: 100%;
	position: absolute;
	z-index: -2;
	left: 0;
	bottom: 0;
}
#recruit .rec_inbox .box_l {
	width: 56%;
	max-width: 730px;
}
#recruit .rec_inbox .box_r {
	width: 40%;
	max-width: 490px;
	box-sizing: border-box;
	position: relative;
	text-align: center;
}

#recruit .rec_inbox .copy {
	font-size: min(145%,1.6vw);
	letter-spacing: .1em;
	line-height: 1.6em;
}
#recruit .rec_inbox .tit {
	color: var(--color_pink);
	font-size: min(310%,3.7vw);
	letter-spacing: .1em;
	line-height: 1.4em;
	white-space: nowrap;
    margin-bottom: .3em;
}
#recruit .rec_inbox .syokusyu {
	text-align: center;
	color: #fff;
	font-size: min(125%,1.9vw);
	line-height: 2.0em;
	letter-spacing: .1em;
	display: flex;
	flex-wrap: wrap;
	column-gap: .5em;
	row-gap: .5em;
}
#recruit .rec_inbox .syokusyu > li {
	box-sizing: border-box;
	background: var(--color_pink);
	padding: 0 1.6em;
	border-radius: 3em;
}
/*#recruit .rec_inbox .syokusyu > li span {
	font-size: 110%;
	letter-spacing: .1em;
}*/
#recruit .rec_inbox .txt {
	margin-top: 1.0em;
	text-align: justify;
}

#recruit .rec_inbox .box_r .abs_img {
	position: absolute;
	width: 80%;
	max-width: 350px;
	left: 3%;
	bottom: 100%;
}
#recruit .rec_inbox .box_r dl {
	background-color: #fff;
	box-shadow: 7px 7px 10px 0px rgba(0,0,0,0.2);
	box-sizing: border-box;
	padding: 5% 4% 4%;
	text-align: center;
}
#recruit .rec_inbox .box_r dt {
	font-size: min(105%,1.3vw);
	line-height: 1.4em;
	letter-spacing: .1em;
	margin-bottom: .8em;
}
#recruit .rec_inbox .box_r .tel {
	font-size: min(294%,3.5vw);
	letter-spacing: .1em;
}
#recruit .rec_inbox .box_r .tel a {
	display: inline-block;
	position: relative;
	padding-left: .9em;
}
#recruit .rec_inbox .box_r .tel a::before {
	content: "";
	position: absolute;
	width: 1.0em;
	height: 1.0em;
	background: url("../images/frontpage/icon_tel@2x.png") no-repeat left center;
	background-size: auto 70%;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}
#recruit .rec_inbox .box_r .btn a {
	display: block;
	background: var(--color_pink);
	color: #fff;
	font-size: min(105%,1.5vw);
	font-weight: bold;
	line-height: 1.4em;
	letter-spacing: .19em;
	padding: 1.4em 0;
	margin-top: 1em;
}
#recruit .rec_inbox .box_r .btn a span {
	position: relative;
	padding-right: 2.5em;
}
#recruit .rec_inbox .box_r .btn a span::after {
	position: absolute;
	content: "";
	display: block;
	width: 2.0em;
	height: 2.0em;
	background: url(../images/frontpage/rec_arrow.svg) no-repeat right center;
	background-size: contain;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
#recruit .rec_inbox {
	padding: 4% 4.5%;
	padding-right: 0;
}
#recruit .rec_inbox .box_r {
	padding-bottom: 3%;
}
#recruit .rec_inbox .copy {
	font-size: 110%;
	letter-spacing: .1em;
}
#recruit .rec_inbox .tit {
	font-size: 4.0vw;
	letter-spacing: .05em;
}
#recruit .rec_inbox .syokusyu {
	font-size: 110%;
}
#recruit .rec_inbox .syokusyu > li {
	padding: 0 1.2em;
}
#recruit .rec_inbox .box_r .abs_img {
	width: 97%;
	left: 3%;
}
#recruit .rec_inbox .box_r dt {
	font-size: 100%;
	letter-spacing: .05em;
	margin-bottom: .5em;
}
#recruit .rec_inbox .box_r .tel {
	font-size: 3.8vw;
	letter-spacing: .05em;
}
#recruit .rec_inbox .box_r .btn a {
	font-size: 1.8vw;
	letter-spacing: .1em;
}
#recruit .rec_inbox .box_r .btn a span {
	padding-right: 2.0em;
}
#recruit .rec_inbox .box_r .btn a span::after {
	width: 1.5em;
	height: 1.5em;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
#recruit .rec_inbox {
	display: block;
	padding: 8% 6%;
}
#recruit .rec_inbox::after{
	width: 100%;
}
#recruit .rec_inbox .box_l {
	width: 100%;
	margin-bottom: 5%;
}
#recruit .rec_inbox .box_r {
	width: 100%;
	max-width: none;
	margin-bottom: 0;
}
#recruit .rec_inbox .rec_copy {
	font-size: 110%;
	letter-spacing: .05em;
	text-align: center;
}
#recruit .rec_inbox .rec_title {
	font-size: 160%;
	letter-spacing: .05em;
	margin: .1em 0 .6em;
	text-align: center;
}
#recruit .rec_inbox .syokusyu {
	margin-bottom: 0.5em;
	justify-content: space-between;
}
#recruit .rec_inbox .syokusyu > li {
	width: 49%;
	font-size: 90%;
	letter-spacing: normal;
	padding: .7em 0;
	margin: 0 0 2% !important;
}
#recruit .rec_inbox .syokusyu > li span {
	letter-spacing: normal;
}
#recruit .rec_inbox .box_r .abs_img {
	position: static;
	transform: translateX(0);
	margin: 0 auto;
	text-align: center;
	width: 70%;
}
#recruit .rec_inbox .box_r dl {
	padding: 6% 5% 5%;
	box-shadow: 5px 5px 8px 0px rgba(0,0,0,0.2);
}
#recruit .rec_inbox .box_r dt {
	font-size: 120%;
	letter-spacing: .05em;
}
#recruit .rec_inbox .box_r .rec_btn a {
	font-size: 105%;
	letter-spacing: .05em;
}
#recruit .rec_inbox .box_r .rec_btn a span {
	padding-right: 1.5em;
}
#recruit .rec_inbox .box_r .rec_btn a span::after {
	width: 1.2em;
	height: 1.2em;
}
}



/*concept
---------------------------------------------------------*/
#concept .bg {
	background: var(--color_bg1);
	position: relative;
}
#concept .bg::before {
	content: "";
	position: absolute;
	z-index: 0;
	width: 100%;
	height: 10vw;
	max-height: 100px;
	background: linear-gradient(0deg,rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 100%);
	left: 0;
	top: -1px;
}
#concept .bg > div {
	position: relative;
	z-index: 1;
}
#concept .marker {background: var(--color_violet);}
#concept .com_txt_link:hover {color: var(--color_violet);}

#concept .box1 {
	display: flex;
    justify-content: space-between;
    align-items: center;
}
#concept .box1 .img_l {
	width: 44%;
	max-width: 640px;
}
#concept .box1 .txt_r {
	width: 52%;
	max-width: 760px;
}
#concept .box1 .txt_r .in_box {
	width: 94%;
	max-width: 620px;
}
#concept .box1 .txt_r dt {
	color: var(--color_violet);
	font-weight: bold;
	letter-spacing: .1em;
	line-height: 1.6em;
	margin: .8em 0;
}

#concept .box2 .box_list {
	display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
#concept .box2 .box_list > li {
	width: 50%;
	position: relative;
	padding: 60px 3% 40px;
}
#concept .box2 .box_list > li:nth-child(-n+2) {
	padding-top: 110px;
}
#concept .box2 .box_list > li:nth-child(odd)::before {
	content: "";
	position: absolute;
	width: 200%;
	height: 1px;
	left: 0;
	top: 0;
	background: #cccccc;
}
#concept .box2 .box_list .in_box {
	width: 100%;
	max-width: 520px;
	margin-left: auto;
	margin-right: auto;
}
#concept .box2 .box_list h3 {
	font-size: min(219%,2.8vw);
	line-height: 1.4em;
	padding-left: 4.0em;
	position: relative;
	margin-bottom: 1.0em;
}
#concept .box2 .box_list h3::before {
	content: "";
	position: absolute;
	width: 3.4em;
	height: 3.4em;
	background: url("../images/frontpage/point01@2x.png") no-repeat center top;
	background-size: contain;
	left: 0;
	top: -.1em;
}
#concept .box2 .box_list > li:nth-child(2) h3::before {background-image: url("../images/frontpage/point02@2x.png");}
#concept .box2 .box_list > li:nth-child(3) h3::before {background-image: url("../images/frontpage/point03@2x.png");}
#concept .box2 .box_list > li:nth-child(4) h3::before {background-image: url("../images/frontpage/point04@2x.png");}
#concept .box2 .box_list .txt {
	margin-top: 1.8em;
}

#concept .box3 {
	margin-top: var(--gap_40);
	background: #D1D6E6;
	background: linear-gradient(90deg,rgba(209, 214, 230, 1) 0%, rgba(164, 173, 206, 1) 50%, rgba(209, 214, 230, 1) 100%);
	text-align: center;
	color: #fff;
	font-size: min(125%,1.9vw);
	font-weight: bold;
	letter-spacing: .1em;
	line-height: 1.8em;
	padding: 1.1em 0;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
#concept .box2 .box_list > li {
	padding: 5% 3% 5%;
}
#concept .box2 .box_list > li:nth-child(-n+2) {
	padding-top: 10%;
}
#concept .box2 .box_list h3 {
	font-size: 3.0vw;
	padding-left: 3.7em;
}
#concept .box2 .box_list .txt {
	margin-top: 1.5em;
}
#concept .box3 {
	font-size: 120%;
}
}

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



/*clinic
---------------------------------------------------------*/
#clinic .w1220 {
	text-align: center;
}
#clinic .tit_en80 {
	color: var(--color_green);
}
#clinic .lead {
	color: var(--color_green);
	font-weight: bold;
	letter-spacing: .1em;
	line-height: 1.6em;
	margin: .8em 0 .2em;
}
#clinic .item_list {
	margin-top: var(--gap_60);
	display: flex;
    justify-content: center;
    flex-wrap: wrap;
	column-gap: 3.3333%;
	row-gap: 40px;
	font-size: min(95%,1.4vw);
	letter-spacing: .1em;
	line-height: 1.8em;
}
#clinic .item_list > li {
	width: 22.5%;
	background: var(--color_bg1);
	padding: 2% 0 2.5%;
	border-radius: 20px;
}
#clinic .item_list .icon {
	width: 35%;
	margin: 0 auto;
}
#clinic .item_list dt {
	color: var(--color_green);
	font-size: 135%;
	font-weight: bold;
	letter-spacing: .1em;
	line-height: 1.4em;
	margin: 1.0em 0 .6em;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
#clinic .item_list {
	column-gap: 1.3333%;
	row-gap: 1.4vw;
	font-size: 90%;
	letter-spacing: normal;
}
#clinic .item_list > li {
	width: 24%;
}
#clinic .item_list dt {
	font-size: 130%;
	letter-spacing: .05em;
}
}

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



/*doctor
---------------------------------------------------------*/
#doctor .bg {
	background: #e8f8f7;
}
#doctor .w1100 {
	position: relative;
}
#doctor .tit_en80 {
	text-align: center;
	color: var(--color_turquoise);
	position: absolute;
	margin: auto;
	left: 0;
	right: 0;
	top: 0;
	transform: translateY(-50%);
}
#doctor h2 {
	text-align: center;
}
#doctor .marker {background: var(--color_turquoise);}

#doctor .box1 .flt_box .box_l {
	float: left;
	width: 25%;
	max-width: 270px;
}
#doctor .box1 .flt_box .box_r {
	float: right;
	width: 71%;
	max-width: 750px;
}
#doctor .box1 .flt_box .box_l dl {
	text-align: center;
	font-size: min(125%,1.9vw);
	letter-spacing: .2em;
	line-height: 1.0em;
	margin-top: 1.0em;
}
#doctor .box1 .flt_box .box_l dd.ft_min {
	font-size: 165%;
	letter-spacing: .2em;
}
#doctor .box1 .flt_box .box_l dd.ft_eng1 {
	color: var(--color_brown);
	font-size: 75%;
	letter-spacing: .1em;
	margin-top: .5em;
}

#doctor .box2 h3 {
	border-top: solid 1px var(--color_brown);
	border-bottom: solid 1px var(--color_brown);
	text-align: center;
	color: var(--color_brown);
	font-weight: bold;
	letter-spacing: .15em;
	line-height: 1.6em;
	padding: 1.0em 3%;
	margin-bottom: 50px;
}

#doctor .profile_box {
	background: #fff;
	border-radius: 20px;
	padding: 40px 4%;
}
#doctor .profile_box .flex_box {
	width: 100%;
	max-width: 940px;
	margin-left: auto;
	margin-right: auto;
	display: flex;
    justify-content: space-between;
    align-items: flex-start;
}
#doctor .profile_box .flex_box .box_l {
	width: 50%;
}
#doctor .profile_box .flex_box .box_r {
	width: 45%;
}
#doctor .profile_box .prof_style > dt {
	color: var(--color_brown);
	font-size: 130%;
	letter-spacing: .2em;
	line-height: 1.4em;
	margin-bottom: .5em;
}
#doctor .profile_box .prof_style > dd li {
	margin-top: .3em;
}
#doctor .profile_box .prof_list1 li span {
	margin-right: 1.0em;
}
#doctor .profile_box .prof_list2 li {
	box-sizing: border-box;
	padding-left: 1.2em;
	position: relative;
}
#doctor .profile_box .prof_list2 li::before {
	content: "";
	position: absolute;
	width: .6em;
	height: .6em;
	border-radius: 50%;
	background: var(--color_turquoise);
	left: 0;
	top: .6em;
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
#doctor .box1 .flt_box .box_l dl {
	font-size: 120%;
}
#doctor .box1 .flt_box .box_l dd.ft_min {
	letter-spacing: .15em;
}
#doctor .box2 h3 {
	margin-bottom: 4%;
}
#doctor .profile_box {
	padding: 4% 4%;
}
#doctor .profile_box .prof_list2 li::before {
	top: .5em;
}
}

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



/* footer
---------------------------------------------------------*/
footer #info .f_tit {
	text-align: center;
}
footer #info .f_tit .f_lead {
	font-size: 110%;
	font-weight: bold;
	letter-spacing: .15em;
	line-height: 1.6em;
}
footer #info .f_tit .f_logo {
	font-size: min(250%,3.4vw);
	letter-spacing: .1em;
	line-height: 1.4em;
	margin: .2em 0 .4em;
}
footer #info .f_tit address {
	letter-spacing: .15em;
	line-height: 1.6em;
}

footer #info .f_flex {
	display: flex;
	justify-content: space-between;
}
footer #info .f_flex .f_box_l {
	width: 50%;
}
footer #info .f_flex .f_box_r {
	width: 47%;
	max-width: 500px;
}

footer #info .f_tel dt {
	font-size: min(145%,2.0vw);
	letter-spacing: .1em;
	line-height: 1.4em;
	margin-bottom: .5em;
}
footer #info .f_tel img {
	margin-left: 0;
}

footer #info .f_kamoku {
	margin-top: 1.5em;
}
footer #info .f_kamoku ul {
	display: flex;
    flex-wrap: wrap;
}
footer #info .f_kamoku ul li::before {
	content: "／";
}
footer #info .f_kamoku ul li:first-child::before {
	display: none;
}
footer #info .f_timetable dd {
	letter-spacing: .15em;
	line-height: 1.4em;
	margin-top: .5em;
	display: flex;
    flex-wrap: wrap;
	column-gap: 1.0em;
}
footer #info .f_timetable .icon-sat {
	color: var(--color_pink);
}

footer #info .f_access {
	font-size: min(130%,1.8vw);
	letter-spacing: .1em;
	line-height: 1.6em;
	display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
	column-gap: 3%;
}
footer #info .f_access li {
	display: flex;
    justify-content: center;
    align-items: center;
	column-gap: .8em;
}
footer #info .f_access li div {
	width: 4.5em;
	max-width: 80px;
}

footer #info .bnr_insta {
	margin-top: var(--gap_80);
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
footer #info .f_tit .f_lead {
	letter-spacing: .1em;
}
footer #info .f_tit .f_logo {
	font-size: 3.8vw;
}
footer #info .f_tit address {
	letter-spacing: .1em;
}
footer #info .f_flex .f_box_l {
	width: 47%;
}
footer #info .f_flex .f_box_r {
	width: 50%;
}
footer #info .f_tel dt {
	font-size: 2.2vw;
}
footer #info .f_kamoku {
	margin-top: 1.5em;
}
footer #info .f_timetable dd {
	font-size: 90%;
	letter-spacing: .1em;
}
footer #info .f_access {
	font-size: 2.0vw;
	letter-spacing: .05em;
}
}

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



/* f_map
---------------------------------------------------------*/
footer #f_map {
	position: relative;
}
footer #f_map iframe {
	position: absolute;
	display: block;
	width: calc(100% - 200px);
	left: 0;
	top: 0;
}
footer #f_map .map_btn {
	width: 100%;
	max-width: 200px;
	margin-left: auto;
	margin-right: 0;
    box-sizing: border-box;
}
footer #f_map .map_btn li {
	box-sizing: border-box;
	border-bottom: #fff 2px solid;
}
footer #f_map .map_btn li:last-of-type {
	border-bottom: none;
}
footer #f_map .map_btn li a {
	display: block;
}

/* copyright */
footer .copyright {
	background: var(--color_brown);
	padding: 60px 0;
}
footer .copyright .w1500 {
	text-align: center;
	color: #fff;
	font-size: 75%;
	letter-spacing: .2em;
	line-height: 1.8em;
}

/* page_top */
#page_top {
	position: fixed;
	width: 10%;
	max-width: 100px;
	bottom: 18px;
	right: 18px;
	z-index: 990;
}
#page_top a {
	display: block;
	transition: all 0.8s;
}
#page_top a:hover {
	transition: all 0.4s;
	transform: translateY(-20px);
}

/* Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) and (max-width: 959px) {
footer #f_map iframe {
	width: 80%;
}
footer #f_map .map_btn {
	width: 20%;
}	
/* copyright */
footer .copyright {
	padding: 4% 0;
}
footer .copyright .w1500 {
	font-size: 85%;
	letter-spacing: .15em;
}
/* page_top */
#page_top {
	width: 8vw;
	bottom:1.5vw;
	right: 2vw;
}
}

/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
footer #f_map iframe {
	position: static;
	width: 100%;
    height: 350px;
}
footer #f_map .map_btn {
	display: none; 
}
footer #f_map .sp_map_btn a {
	display: block;
	background: #805b37;
	color: #fff;
	letter-spacing: .1em;
	line-height: 1.2em;
	padding: 1em 0;
	text-align: center;
}

/* page_top */
#page_top {
	width: 14vw;
	bottom: calc(2vw + 22vw);
	right: 2%;
}

/* copyright */
.copyright {
	width: 90%;
	text-align: left;
	font-size: 80%;
	letter-spacing: .1em;
	line-height: 1.4em;
	padding-top: 6vw;
	padding-bottom: 28vw;
}
}

