﻿@charset "utf-8";
/* -- -- --
 * ROOM8 Template V3.7
 * Last Up Date: 2023.1
 * Author: mick
-- -- -- -- -- -- -- -- */
*,
*::before,
*::after {
	margin: 0;
	padding: 0;
	overflow-wrap: anywhere;
	word-break: normal;
	line-break: strict;
	box-sizing: border-box;
	background-repeat: no-repeat;
}

html {
	opacity: 0;
	font-size: 10px;
	font-size: 62.5%;
	-webkit-text-size-adjust: 100%;
	-webkit-tap-highlight-color: transparent;
}

html.wf-active, html.loading-delay {
	opacity: 1;
	-webkit-transition: .2s;
	transition: .2s;
}

body {
	color: #2a2223;
	-webkit-font-smoothing: antialiased;
	font-weight: 300;
	font-family: "fot-tsukuaoldmin-pr6n", sans-serif;
	/* font-feature-settings : 'palt'; */
}

/*

FOT-TsukuAOldMin Pr6N L
font-family: "fot-tsukuaoldmin-pr6n", sans-serif;
font-weight: 300;
font-style: normal;

Adobe Garamond Pro Regular
font-family: "adobe-garamond-pro", serif;
font-weight: 400;
font-style: normal;

DIN 2014 Regular
font-family: "din-2014", sans-serif;
font-weight: 400;
font-style: normal;

 */


html, body {
	height:100%;
}

body.lock {
	position: fixed;
	top:0;
	left:0;
	width: 100%;
}

header,
article,
nav,
main,
section,
footer {
	display: block;
}

p, h1, h2, h3, h4, h5, h6 {
	overflow-wrap: break-word;
}

p {
	line-height: 1.8;
}

h1, h2, h3, h4, h5, h6 {
	line-height: 1.6;
	font-size: inherit;
	font-weight: inherit;
	font-weight: 300;
}

a {
	color: #333;
	border: none;
	outline: 0;
	background-color: transparent;
	text-decoration: none;
	text-underline-offset: 0.6ex;
}

a:active,
a:hover {
	outline: 0;
}

b,
strong {
	font-weight: 300;
}

small {
	font-size: 0.8rem;
}

sub,
sup {
	font-size: 0.75rem;
	line-height: 1.0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

hr {
	border: none;
	border-block-start: 1px solid;
	color: inherit;
	block-size: 0;
	overflow: visible;
}

i {
	font-style: italic;
}

del {
	text-decoration: line-through;
}

img, picture, video, canvas, svg {
	display: block;
	max-width: 100%;
	vertical-align: bottom;
}

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

code,
pre {
	font-family: monospace, monospace;
	overflow: auto;
}

table {
	border-collapse: collapse;
	border-style: none;
	border-spacing: 0;
}

dt,
dd,
td,
th {
	line-height: 1.8;
	font-weight: 300;
}

td {
	word-break: break-all;
}

ul,
ol {
	list-style: none;
}

li {
	line-height: 1.8;
}

.pc,
.pcbox {
	display: none;
}

/* entry_body
========================================================================== */
.entry_body .aligncenter {
	display: block;
	margin: 0 auto;
}

.entry_body .alignright {
	margin:0 0 0 10px;
	float: right;
}

.entry_body .alignleft {
	margin:0 10px 0 0;
	float: left;
}

.entry_body ol {
	margin:0 0 0 20px;
	list-style-position: outside;
	list-style-type: decimal;
}

.entry_body ul {
	margin:0 0 0 20px;
	list-style-position: outside;
	list-style-type: disc;
}

.entry_body table {
	max-width:100%!important;
	border:1px solid #CCC;
}

.entry_body img {
	max-width:100%;
	height:auto;
}

.entry_body hr {
	height: 0;
	-moz-box-sizing: content-box;
	box-sizing: content-box;
}

.entry_body table th,
.entry_body table td {
	padding:5px;
}

.entry_body blockquote {
	margin:0 0 15px;
	padding: 25px 15px 15px 50px;
	min-height:80px;
	box-sizing: border-box;
	font-style: italic;
	background: #efefef;
	color: #555;
	position: relative;
}

.entry_body blockquote:before {
	display: inline-block;
	position: absolute;
	top: 10px;
	left: -3px;
	vertical-align: middle;
	content: "“";
	font-family: sans-serif;
	color: #cfcfcf;
	font-size: 90px;
	line-height: 1;
}

.entry_body blockquote p {
	 padding: 10px 0;
	padding: 0;
	line-height: 1.7;
}

.entry_body blockquote cite {
	display: block;
	text-align: right;
	color: #888888;
	font-size: 0.9em;
}

@media screen and (min-width: 768px) {

	.entry_body table th,
	.entry_body table td {
		padding:10px;
	}

	.entry_body blockquote {
		margin:0 0 40px;
	}
}

/* Forms
========================================================================== */
input {
	border-radius: 0;
}

[type='number']::-webkit-inner-spin-button,
[type='number']::-webkit-outer-spin-button {
	height: auto;
}

[type='search'] {
	-webkit-appearance: textfield;
	outline-offset: -2px;
}

[type='search']::-webkit-search-decoration {
	-webkit-appearance: none;
}

::placeholder {
 	color: #baaa85;
}

textarea {
	overflow: auto;
	resize: vertical;
}

button,
input,
optgroup,
select,
textarea {
	font: inherit;
}

optgroup {
	font-weight: 300;
}

button {
	overflow: visible;
}

button,
select {
	text-transform: none;
}
button,
[type='button'],
[type='reset'],
[type='submit'],
[role='button'] {
	cursor: pointer;
}

button::-moz-focus-inner,
[type='button']::-moz-focus-inner,
[type='reset']::-moz-focus-inner,
[type='submit']::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

button:-moz-focusring,
[type='button']::-moz-focus-inner,
[type='reset']::-moz-focus-inner,
[type='submit']::-moz-focus-inner {
	outline: 1px dotted ButtonText;
}

button,
html [type='button'],
[type='reset'],
[type='submit'] {
	-webkit-appearance: button;
}

button,
input,
select,
textarea {
	background-color: transparent;
	border-style: none;
}

a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
	outline-width: 0;
}

select {
	-moz-appearance: none;
	-webkit-appearance: none;
}

select::-ms-expand {
	display: none;
}

select::-ms-value {
	color: currentColor;
}

legend {
	border: 0;
	color: inherit;
	display: table;
	max-width: 100%;
	white-space: normal;
	max-width: 100%;
}

::-webkit-file-upload-button {
	-webkit-appearance: button;
	color: inherit;
	font: inherit;
}

[disabled] {
	cursor: default;
}

::-webkit-input-placeholder {
	color: #AAA;
}

::-placeholder {
	color: #AAA;
}

/* Extras
========================================================================== */
.clear:after {
	content: "";
	clear: both;
	display: block;
	visibility: hidden;
	overflow: hidden;
}

.moviebox {
	position: relative;
	padding-top: 56.25%;
}

.moviebox iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.screen {
	display: none;
	opacity: 0;
	position: fixed;
	top:0;
	left:0;
	width:100%;
	height:130%;
	background-color: #000;
	z-index: 80;
}

.screen_active .screen {
	animation-delay:0.2s;
	-webkit-animation-delay:0.2s;
	animation-name: screen_active;
	-webkit-animation-name: screen_active;
	animation-duration: 0.3s;
	-webkit-animation-duration: 0.3s;
	animation-iteration-count:1;
	-webkit-animation-iteration-count:1;
	animation-fill-mode:both;
	-webkit-animation-fill-mode:both;
}

@keyframes screen_active {
	0% {display: none; opacity: 0;}
	1% {display: block; opacity: 0;}
	100% {display: block; opacity: 0.8;}
}

@-webkit-keyframes screen_active {
	0% {display: none; opacity: 0;}
	1% {display: block; opacity: 0;}
	100% {display: block; opacity: 0.8;}
}

#dammy {
	display: block;
	overflow: hidden;
	background: url('../images/') no-repeat;
	padding: 40px 0 0;
	width: 216px;
	height: 0!important;
}

/*
========================================================================== */
#wrapper {
	font-size:1.4rem;
	overflow: hidden;
	position: relative;
}

#wrapper::before {
	position: absolute;
	top:0;
	left:0;
	content: '';
	background: url('../images/bgbox1.webp') repeat center top;
	background-size: 500px 500px;
	width:100%;
	height:100%;
	z-index:-100;
}

.block1 {
	padding:30px 15px;
}

.fiu {
	opacity: 0;
	transform: translateY(30px);
	transition-duration: .6s;
}

.fiu.anim_action {
	opacity: 1;
	transform: translateY(0);
}

.pagetop {
	display: none;
	position: fixed;
	right:15px;
	bottom:15px;
	width: 35px;
	overflow: hidden;
	border-radius: 35px;
	-moz-border-radius: 35px;
	-webkit-border-radius: 35px;
}

.pagetop a {
	display: block;
	overflow: hidden;
	background: url('../images/pagetop.svg') no-repeat center center;
	background-size: 16px 8px;
	background-color:rgba(0, 0, 0, 0.2);
	padding: 35px 0 0;
	height: 0!important;
}

footer p {
	padding:0 0 0 0.08em;
	line-height:1.2;
	text-align: center;
	font-size:1.0rem;
	font-family: "din-2014", sans-serif;
	letter-spacing: 0.2em;
}

/* KV
=================================== */
.kv_area {
	position: relative;
}

.kv_area::after {
	position: absolute;
	top:0;
	left:0;
	content: '';
	background: url('../images/kv_cover.webp') repeat-x center top;
	background-size: 500px 410px;
	width:100%;
	height:100%;
	z-index:-5;
}

.kv_area .block1 {
	padding-top:10.67vw;
	padding-bottom:0;
	height:140vw;
	position: relative;
}

.kv_area h1 {
	overflow: hidden;
	background: url('../images/logo1.webp') no-repeat center center;
	background-size: auto 19.2vw;
	margin:0 0 9.2vw;
	padding: 19.2vw 0 0;
	height: 0!important;
}

.kv_area .en {
	margin:0 0 6.2vw;
	line-height:1.35;
	text-align: center;
	font-size:7.6vw;
	font-weight: 400;
	font-family: "adobe-garamond-pro", serif;
	letter-spacing: 0.08em;
}

.kv_area .kv_mlead {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	flex-direction: row-reverse;
	height:200px;
}

.kv_area .kv_mlead p {
	font-fauture-settings: initial;
	writing-mode:vertical-rl;
	-ms-writing-mode:tb-rl;
	margin:0 0 0 10px;
	color:#988455;
}

.kv_area .kv_mlead p:last-child {
	margin:0;
}

.kv_area .kv_mlead p b {
	display: block;
	line-height:0.9;
	font-size:4.53vw;
	letter-spacing: 0.06em;
}

.kv_area .kv_mlead p.hi b {
	letter-spacing: 0em;
}

.kv_area .lang {
	position: absolute;
	top:10px;
	right:10px;
}

.kv_area .lang a {
	font-size:1.3rem;
	text-decoration: underline;
}

.kv_area .kv_bgcover {
	position: absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
	z-index:-5;
	opacity: 0;
	transition-delay: .3s;
	transition-duration: .6s;
}

.kv_area .kv_bgcover.active {
	opacity: 1;
}

.kv_area .kv_bgcover .inblock {
	width:100%;
	height:128vw;
	position: relative;
}

.kv_area .kv_bgcover.bgcover1 {
	background: url('../images/sp_kv_item1.webp') no-repeat center top;
	background-size: 100% 128vw;
}

.kv_area .kv_bgcover.bgcover1 .kvitem {
	position: absolute;
	top:0;
	left:0;
	content: '';
	background-repeat: no-repeat;
	background-position: center top;
	background-size: 100% 128vw;
	width:100%;
	height:128vw;
	z-index:-10;
	opacity: 0;
}

.kv_area .kv_bgcover.bgcover1 .kvitem.kvitem1 {
	background-image: url('../images/sp_kv_item2.webp');
}

.kv_area .kv_bgcover.bgcover1.active .kvitem.kvitem1 {
	-webkit-animation: kvitemmove 6s ease-in-out infinite;
	animation: kvitemmove 6s ease-in-out infinite;
}

.kv_area .kv_bgcover.bgcover1 .kvitem.kvitem2 {
	background-image: url('../images/sp_kv_item3.webp');
}

.kv_area .kv_bgcover.bgcover1.active .kvitem.kvitem2 {
	-webkit-animation: kvitemmove 6s ease-in-out .3s infinite;
	animation: kvitemmove 6s ease-in-out .3s infinite;
}

@-webkit-keyframes kvitemmove {
	0% {opacity: 0; transform: translateX(100px) translateY(-100px);}
	30% {opacity: 1; transform: translateX(0) translateY(0);}
	70% {opacity: 1; transform: translateX(0) translateY(0);}
	100% {opacity: 0; transform: translateX(-100px) translateY(100px);}
}

@keyframes kvitemmove {
	0% {opacity: 0; transform: translateX(100px) translateY(-100px);}
	30% {opacity: 1; transform: translateX(0) translateY(0);}
	70% {opacity: 1; transform: translateX(0) translateY(0);}
	100% {opacity: 0; transform: translateX(-100px) translateY(100px);}
}

.kv_area .kv_bgcover.bgcover2 .kvitem {
	position: absolute;
	content: '';
	background-repeat: no-repeat;
	background-position: center top;
	z-index:-10;
	opacity: 0;
}

.kv_area .kv_bgcover.bgcover2.active .kvitem {
	-webkit-animation: kvitemmove2 6s ease-in-out infinite;
	animation: kvitemmove2 6s ease-in-out infinite;
}

.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem1 {
	top: 9.87vw;
	left: calc(50% + 22.67vw);
	background-image: url('../images/kv_icon1.webp');
	background-size: auto 19.2vw;
	width: 22.67vw;
	height: 19.2vw;
}

.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem2 {
	top: 17.6vw;
	left: calc(50% - 54.67vw);
	background-image: url('../images/kv_icon1.webp');
	background-size: auto 9.6vw;
	width: 13.34vw;
	height: 9.6vw;
	animation-delay: .5s;
}

.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem3 {
	top: 25.1vw;
	left: calc(50% - 45.3vw);
	background-image: url('../images/kv_icon1.webp');
	background-size: auto 11.7vw;
	width: 16vw;
	height: 11.7vw;
	animation-delay: .35s;
}

.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem4 {
	display: none;
}

.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem5 {
	display: none;
}

.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem6 {
	top: 55.47vw;
	left: calc(50% + 26.67vw);
	background-image: url('../images/kv_icon1.webp');
	background-size: auto 29.33vw;
	width: 33.33vw;
	height: 29.33vw;
}

.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem7 {
	top: 63.73vw;
	left: calc(50% - 38.67vw);
	background-image: url('../images/kv_icon2.webp');
	background-size: auto 14.67vw;
	width: 18.67vw;
	height: 14.67vw;
	animation-delay: .2s;
}

.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem8 {
	top: 75.47vw;
	left: calc(50% + 22.93vw);
	background-image: url('../images/kv_icon1.webp');
	background-size: auto 16vw;
	width: 18.67vw;
	height: 16vw;
	animation-delay: .4s;
}

.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem9 {
	display: none;
}

.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem10 {
	top: 86.67vw;
	left: calc(50% - 45.87vw);
	background-image: url('../images/kv_icon1.webp');
	background-size: auto 6.93vw;
	width: 10.67vw;
	height: 6.93vw;
	animation-delay: .3s;
}

.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem11 {
	top: 88.8vw;
	left: calc(50% - 69.33vw);
	background-image: url('../images/kv_icon2.webp');
	background-size: auto 29.33vw;
	width: 34.67vw;
	height: 29.33vw;
	animation-delay: .45s;
}

.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem12 {
	top: 104.53vw;
	left: calc(50% + 12.8vw);
	background-image: url('../images/kv_icon2.webp');
	background-size: auto 9.1vw;
	width: 11.73vw;
	height: 9.1vw;
	animation-delay: .6s;
}

.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem13 {
	top: 132.53vw;
	left: calc(50% - 42.67vw);
	background-image: url('../images/kv_icon1.webp');
	background-size: auto 14.4vw;
	width: 17.6vw;
	height: 14.4vw;
	animation-delay: .55s;
}

@-webkit-keyframes kvitemmove2 {
	0% {opacity: 0; transform: translateY(-60px);}
	20% {opacity: 1; transform: translateY(0);}
	80% {opacity: 1; transform: translateY(0);}
	100% {opacity: 0; transform: translateY(60px);}
}

@keyframes kvitemmove2 {
	0% {opacity: 0; transform: translateY(-60px);}
	20% {opacity: 1; transform: translateY(0);}
	80% {opacity: 1; transform: translateY(0);}
	100% {opacity: 0; transform: translateY(60px);}
}

/* area
=================================== */
.area_mtitlebox {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	margin:0 0 16vw;
	width:100%;
}

.area_mtitlebox h2 {
	background: url('../images/logo2.webp') no-repeat center top;
	background-size: auto 40px;
	margin: 0 auto;
	padding: 63px 0 0 0.4em;
	font-size: 3.6vw;
	letter-spacing: 0.32em;
}

.area_mleadbox {
	margin:0 10px 10.4vw;
}

.area_mleadbox .labelbox {
	display: flex;
	align-items: center;
	margin: 0 0 4.5vw;
	opacity: 0;
	transition-duration: .3s;
}

.area_mleadbox.anim_action .labelbox {
	opacity: 1;
}

.area_mleadbox .labelbox .label {
	margin:0 8px 0 0;
	padding:0 25px 0 0;
	line-height:1.0;
	text-align: center;
	font-size:2.5rem;
	background-position: right center;
	background-repeat: no-repeat;
	font-feature-settings : 'palt';
}

.area_mleadbox .labelbox .name {
	color:#b4a582;
	font-size:0.8rem;
	font-weight: 400;
	font-family: "din-2014", sans-serif;
	letter-spacing: 0.12em;
}

.area_mleadbox .mlead {
}

.area_mleadbox .mlead p {
	line-height: 1.45;
	font-size: 5.1vw;
	font-family: YakuHanMP, "fot-tsukuaoldmin-pr6n", sans-serif;
	letter-spacing: 0;
	opacity: 0;
	transition-delay: .4s;
	transition-duration: 1.0s;
}

.area_mleadbox .mlead p:nth-child(2) {
	transition-delay: .6s;
}

.area_mleadbox .mlead p:nth-child(3) {
	transition-delay: .8s;
}

.area_mleadbox.anim_action .mlead p {
	opacity: 1;
}

.areaex_block {
	margin:0 10px;
	padding:0 0 0 40px;
}

.areaex_block p {
	margin:0 0 30px;
	line-height:1.65;
	font-size:4.0vw;
	letter-spacing: 0.04em;
	font-feature-settings : 'palt';
}

.areaex_block p:last-child {
	margin-bottom:0;
}

.area_label {
	display: none;
}

/* area1
=================================== */
.top_area1 {
	position: relative;
}

.top_area1::before {
	position: absolute;
	top:-70px;
	left:0;
	content: '';
	background: url('../images/area1top.webp') no-repeat center top;
	background-size: 700px 125px;
	width:100%;
	height:125px;
	z-index:-80;
}

.top_area1::after {
	position: absolute;
	top:55px;
	left:0;
	content: '';
	background: url('../images/area1body.webp') repeat center top;
	background-size: 700px 125px;
	width:100%;
	height:calc(100% + 0px);
	z-index:-80;
}

.top_area1 .block1 {
	padding-bottom:120px;
}

.top_area1 .mlead {
	margin:0 0 25px;
}

.top_area1 .mlead p {
	line-height:2.0;
	text-align: center;
	letter-spacing: 0.04em;
}

.top_area1 .gallery_block {
	margin:0 0 20px;
}

.top_area1 .gallery_block ul {
	display: flex;
	align-items: flex-start;
	flex-wrap: wrap;
}

.top_area1 .gallery_block li {
	margin:0 8px 8px 0;
	width:calc(50% - 4px);
}

.top_area1 .gallery_block li:nth-child(2n) {
	margin-right:0;
}

.top_area1 .btnbox {
	margin:0 auto;
	width:245px;
}

.top_area1 .btnbox a {
	display: block;
	padding:6px 0 6px;
	color:#988455;
	text-align: center;
	background-color: #FFF;
	border:1px solid #dcd1b9;
	border-radius: 5px;
}

.top_area1 .btnbox .bline1 {
	line-height:1.4;
	font-size:1.3rem;
	letter-spacing: 0.04em;
}

.top_area1 .btnbox .bline2 {
	line-height:1.4;
	font-size:2.0rem;
	letter-spacing: 0.08em;
}

/* area2
=================================== */
.top_area2 {
	position: relative;
}

.top_area2::before {
	position: absolute;
	top:-90px;
	left:0;
	content: '';
	background: url('../images/area2top.webp') no-repeat center top;
	background-size: 700px auto;
	width:100%;
	height:123px;
	z-index:-50;
}

.top_area2::after {
	position: absolute;
	bottom:-10px;
	left:0;
	content: '';
	background: url('../images/area2bottom.webp') no-repeat center top;
	background-size: 700px 125px;
	width:100%;
	height:125px;
	z-index:-50;
}

.top_area2 .inblock {
	position: relative;
}

.top_area2 .inblock::before {
	position: absolute;
	top:33px;
	left:0;
	content: '';
	background-color:#FFF;
	width:100%;
	height:calc(100% - 148px);
	z-index:-50;
}

.top_area2 .block1 {
	padding-right:5px;
	padding-bottom:100px;
}

.top_area2 .area_mtitlebox {
	margin-right:10px;
}

.top_area2 .area_mleadbox .label {
	background-image:url('../images/area2ticon.webp');
	background-size:auto 14px; /* 19 */
}

.top_area2 .areaex_block {
	margin-right:20px;
}

/* area3
=================================== */
.top_area3 .block1 {
	padding-bottom:60px;
}

.top_area3 .area_mtitlebox {
	display: none;
}

.top_area3 .area_mleadbox .label {
	background-image:url('../images/area3ticon.webp');
	background-size:auto 16px;
}

/* area4
=================================== */
.top_area4 {
	position: relative;
}

.top_area4::before {
	position: absolute;
	top:-45px;
	left:0;
	content: '';
	background: url('../images/area4top.webp') no-repeat center top;
	background-size: 700px auto;
	width:100%;
	height:123px;
	z-index:-50;
}

.top_area4::after {
	position: absolute;
	bottom:-10px;
	left:0;
	content: '';
	background: url('../images/area4bottom.webp') no-repeat center top;
	background-size: 700px 125px;
	width:100%;
	height:125px;
	z-index:-50;
}

.top_area4 .inblock {
	position: relative;
}

.top_area4 .inblock::before {
	position: absolute;
	top:48px;
	left:0;
	content: '';
	background-color:#FFF;
	width:100%;
	height:calc(100% - 163px);
	z-index:-50;
}

.top_area4 .block1 {
	padding-bottom:90px;
}

.top_area4 .area_mtitlebox {
	display: none;
}

.top_area4 .area_mleadbox .label {
	background-image:url('../images/area4ticon.webp');
	background-size:auto 16px;
}

/* area5
=================================== */
.top_area5 .block1 {
	padding-bottom:115px;
}

.top_area5 .area_mtitlebox {
	display: none;
}

.top_area5 .area_mleadbox .label {
	background-image:url('../images/area5ticon.webp');
	background-size:auto 14px;
}

/* area6
=================================== */
.top_area6 {
	position: relative;
}

.top_area6::before {
	position: absolute;
	top:-100px;
	left:0;
	content: '';
	background: url('../images/area6top.webp') no-repeat center top;
	background-size: 700px 123px;
	width:100%;
	height:123px;
	z-index:-50;
}

.top_area6::after {
	position: absolute;
	bottom:50px;
	left:0;
	content: '';
	background: url('../images/area6bottom.webp') no-repeat center top;
	background-size: 700px 125px;
	width:100%;
	height:125px;
	z-index:-50;
}

.top_area6 .inblock {
	position: relative;
}

.top_area6 .inblock::before {
	position: absolute;
	top:23px;
	left:0;
	content: '';
	background-color:#FFF;
	width:100%;
	height:calc(100% - 158px);
	z-index:-50;
}

.top_area6 .block1 {
	padding-bottom:170px;
}

.top_area6 .area_mtitlebox {
	display: none;
}

.top_area6 .area_mleadbox .label {
	background-image:url('../images/area6ticon.webp');
	background-size:auto 12px;
}

/* area7
=================================== */
.top_area7 .block1 {
	padding-bottom:70px;
}

.top_area7 .area_mtitlebox {
	display: none;
}

.top_area7 .message_block {
	background-color: rgba(255, 255, 255, 0.7);
	padding: 11.5vw 4vw 10.5vw 10.8vw;
	border-radius: 17px;
	position: relative;
}

.top_area7 .message_block h3 {
	position: absolute;
	top:-50px;
	right:10px;
	line-height:1.25;
	text-align: right;
	color:#988455;
	font-size:6.5vw;
	letter-spacing: 0.02em;
	opacity: 0;
	transition-delay: .6s;
	transition-duration: .6s;
}

.top_area7 .message_block.anim_action h3 {
	opacity: 1;
}

.top_area7 .message_block .exbox {
	opacity: 0;
	transform: translateY(30px);
	transition-delay: 1.2s;
	transition-duration: .8s;
}

.top_area7 .message_block.anim_action .exbox {
	opacity: 1;
	transform: translateY(0);
}

.top_area7 .message_block .exbox p {
	margin:0 0 2.6vw;
	line-height:1.55;
	font-size:4.3vw;
	letter-spacing: 0.01em;
	font-feature-settings : 'palt';
}

.top_area7 .message_block .exbox p:last-child {
	margin-bottom:0;
}

.top_area7 .message_block .picon {
	position: absolute;
	content: '';
	background-repeat: no-repeat;
	background-position: center top;
}

.top_area7 .message_block .picon.picon1 {
	top:-130px;
	right:-50px;
	background-image: url('../images/area7picon1.webp');
	background-size: 220px auto;
	width:220px;
	height:215px;
	z-index:-10;
	opacity: 0;
	transform: scale(0.6);
	transition-duration: .6s;
}

.top_area7 .message_block.anim_action .picon.picon1 {
	opacity: 1;
	transform: scale(1);
}

.top_area7 .message_block .picon.picon2,
.top_area7 .message_block .picon.picon4,
.top_area7 .message_block .picon.picon5,
.top_area7 .message_block .picon.picon7,
.top_area7 .message_block .picon.picon9 {
	background-image: url('../images/area7picon2.webp');
	background-size: auto 45px;
	width:43px;
	height:45px;
}

.top_area7 .message_block .picon.picon2 {
	display: none;
}

.top_area7 .message_block .picon.picon4 {
	top:135px;
	right:-15px;
}

.top_area7 .message_block .picon.picon5 {
	top:160px;
	left:-18px;
}

.top_area7 .message_block .picon.picon7 {
	display: none;
}

.top_area7 .message_block .picon.picon9 {
	display: none;
}

.top_area7 .message_block .picon.picon3 {
	top:5px;
	left:-65px;
	background-image: url('../images/area7picon3.webp');
	background-size: auto 115px;
	width:120px;
	height:115px;
}

.top_area7 .message_block .picon.picon6 {
	top:360px;
	right:-20px;
	background-image: url('../images/area7picon4.webp');
	background-size: auto 56px;
	width:60px;
	height:56px;
}

.top_area7 .message_block .picon.picon8 {
	display: none;
}

.top_area7 .message_block .picon.picon2,
.top_area7 .message_block .picon.picon3,
.top_area7 .message_block .picon.picon4,
.top_area7 .message_block .picon.picon5,
.top_area7 .message_block .picon.picon6,
.top_area7 .message_block .picon.picon7,
.top_area7 .message_block .picon.picon8,
.top_area7 .message_block .picon.picon9 {
	opacity: 0;
	transform: scale(0.6);
	transition-delay: 2.0s;
	transition-duration: .6s;
}

.top_area7 .message_block.anim_action .picon.picon3 {
	transition-delay: 2.1s;
}

.top_area7 .message_block.anim_action .picon.picon4 {
	transition-delay: 2.3s;
}

.top_area7 .message_block.anim_action .picon.picon5 {
	transition-delay: 2.6s;
}

.top_area7 .message_block.anim_action .picon.picon6 {
	transition-delay: 2.7s;
}

.top_area7 .message_block.anim_action .picon.picon7 {
	transition-delay: 2.5s;
}

.top_area7 .message_block.anim_action .picon.picon8 {
	transition-delay: 2.4s;
}

.top_area7 .message_block.anim_action .picon.picon9 {
	transition-delay: 2.2s;
}

.top_area7 .message_block.anim_action .picon.picon2,
.top_area7 .message_block.anim_action .picon.picon3,
.top_area7 .message_block.anim_action .picon.picon4,
.top_area7 .message_block.anim_action .picon.picon5,
.top_area7 .message_block.anim_action .picon.picon6,
.top_area7 .message_block.anim_action .picon.picon7,
.top_area7 .message_block.anim_action .picon.picon8,
.top_area7 .message_block.anim_action .picon.picon9 {
	opacity: 1;
	transform: scale(1);
}

/* area8
=================================== */
.top_area8 {
	position: relative;
}

.top_area8::before {
	position: absolute;
	top:-50px;
	left:0;
	content: '';
	background: url('../images/area8top.webp') no-repeat center top;
	background-size: 700px auto;
	width:100%;
	height:53px;
	z-index:-50;
}

.top_area8::after {
	position: absolute;
	bottom:-30px;
	left:0;
	content: '';
	background: url('../images/area8bottom.webp') no-repeat center top;
	background-size: 700px 100px;
	width:100%;
	height:100px;
	z-index:-50;
}

.top_area8 .inblock {
	position: relative;
}

.top_area8 .inblock::before {
	position: absolute;
	top:2px;
	left:0;
	content: '';
	background: url('../images/area8body.webp') repeat center top;
	background-size: 700px 100px;
	width:100%;
	height:calc(100% - 71px);
	z-index:-50;
}

.top_area8 .block1 {
	padding-bottom:55px;
}

.top_area8 .area_mtitlebox {
	margin-bottom:7.4vw;
}

.top_area8 .data_block .titlebox {
	display: none;
}

.top_area8 .shopinfo_block {
	margin:0 10px 20px;
}

.top_area8 .shopinfo_block .imagebox {
	display: none;
}

.top_area8 .shopinfo_block .parlor .shoptitlebox {
	margin:0 0 6vw;
	text-align: center;
}

.top_area8 .shopinfo_block .parlor .shoptitlebox h4 {
	color:#988455;
	font-size:3.1rem;
	letter-spacing: 0.04em;
}

.top_area8 .shopinfo_block .parlor .shoptitlebox p {
	display: none;
}

.top_area8 .shopinfo_block .sp_imagebox {
	margin:0 auto 4vw;
	padding:7px 14vw;
	max-width:420px;
	background-color: #f0f0f0;
}

.top_area8 .shopinfo_block .sp_gallery_block {
	margin:0 0 35px;
}

.top_area8 .shopinfo_block .sp_gallery_block li {
	margin:0 0 15px;
}

.top_area8 .shopinfo_block .sp_gallery_block li:last-child {
	margin-bottom:0;
}

.top_area8 .shopinfo_block .parlor .ex {
}

.top_area8 .shopinfo_block .parlor .ex p {
	margin: 0 0 7vw;
	line-height: 1.58;
	font-size: clamp(1.5rem, 4.2vw, 2.9rem);
	letter-spacing: 0.015em;
	font-feature-settings: 'palt';
}

.top_area8 .shopinfo_block .parlor .ex p:last-child {
	margin-bottom:0;
}

.top_area8 .gallery_block {
	display: none;
}

.top_area8 .shopdata_block {
	margin:0 20px;
}

.top_area8 .shopdata_block .mapbox {
	margin:0 0 20px;
}

.top_area8 .shopdata_block .mapbox iframe {
	width:100%;
	height:145px;
	vertical-align: bottom;
}

.top_area8 .shopdata_block .databox {
	margin:0 0 10px;
}

.top_area8 .shopdata_block .databox table {
	width:100%;
	font-size:1.3rem;
}

.top_area8 .shopdata_block .databox th {
	padding:3px 0;
	width:95px;
	line-height:1.45;
	color:#988455;
	text-align: left;
	vertical-align: top;
}

.top_area8 .shopdata_block .databox td {
	padding:3px 0;
	line-height:1.45;
	vertical-align: middle;
}

.top_area8 .shopdata_block .spinsta {
	padding:0 0 0 95px;
}

.top_area8 .shopdata_block .spinsta a {
	display: block;
	overflow: hidden;
	background: url('../images/icon_insta.webp') no-repeat center center;
	background-size: 26px 26px;
	padding: 26px 0 0;
	width: 26px;
	height: 0!important;
}

/* area9
=================================== */
.top_area9::before {
	position: absolute;
	bottom:0;
	left:0;
	content: '';
	background: url('../images/area9cover.webp') repeat-x center bottom;
	background-size: 500px 410px;
	width:100%;
	height:410px;
	z-index:-50;
}

.top_area9 .block1 {
	padding-bottom:45px;
}

.top_area9 .area_mtitlebox {
	margin-bottom:12vw;
}

.top_area9 .data_block {
	margin:0 10px 45px 15px;
}

.top_area9 .data_block .titlebox {
	display: none;
}

.top_area9 .data_block .databox {
	font-feature-settings : 'palt';
}

.top_area9 .data_block .databox table {
	width:100%;
	font-size:4.2vw
}

.top_area9 .data_block .databox th {
	padding:5px 0;
	width: 155px;
	line-height:1.5;
	text-align: left;
	vertical-align: top;
	color:#988455;
	border-bottom:1px solid #e3e2e2
}

.top_area9 .data_block .databox td {
	padding:5px 0;
	line-height:1.75;
	vertical-align: middle;
	border-bottom:1px solid #e3e2e2
}

.top_area9 .about_block {
	background: url('../images/logo1.webp') no-repeat center top 70px;
	background-size: 110px auto;
	background-color: rgba(255, 255, 255, 0.7);
	padding: 61vw 5px 30px 15px;
	border-radius: 17px;
	font-feature-settings : 'palt';
}

.top_area9 .about_block h3 {
	margin: 0 0 4.8vw;
	color:#988455;
	line-height:1.1;
	font-size:4.6vw;
}

.top_area9 .about_block .exbox {
	margin:0 20px 0 10px;
}

.top_area9 .about_block .exbox p {
	margin: 0 0 6.8vw;
	line-height: 1.85;
	font-size: 3.6vw;
	letter-spacing: 0.04em;
}

.top_area9 .about_block .exbox p:last-child {
	margin-bottom:0;
}


/* area10
=================================== */
.top_area10 .block1 {
	padding-bottom:50px;
}

.top_area10 .area_mtitlebox {
	height:60px;
}

.top_area10 .leadbox {
	margin:0 10px 50px;
	font-feature-settings : 'palt';
}

.top_area10 .leadbox .lead1 {
	margin:0 0 10px;
	line-height:1.4;
	color:#988455;
	font-size:1.8rem;
	letter-spacing: 0.04em;
}

.top_area10 .leadbox .lead2 {
	line-height:1.8;
	font-size:1.6rem;
	letter-spacing: 0.04em;
}

.top_area10 .form_block {
	margin:0 10px 70px;
	font-feature-settings : 'palt';
}

.top_area10 .form_block table {
	width:100%;
}

.top_area10 .form_block th {
	display: block;
	padding:0 0 5px;
	color:#988455;
	text-align: left;
	vertical-align: top;
}

.top_area10 .form_block td {
	display: block;
	padding:0 0 15px;
	letter-spacing: 0.04em;
}

.top_area10 .form_block tr:last-child td {
	padding-bottom:0;
}

.top_area10 .form_block .select100 {
	margin:0 0 10px;
	color: #baaa85;
	font-size:1.6rem;
}

.top_area10 .form_block .select100:last-child {
	margin:0;
}

.top_area10 .form_block .select100:invalid { color: #baaa85; }
.top_area10 .form_block .select100 option { color: #2a2223; }
.top_area10 .form_block .select100 option:first-child { color: #baaa85; }

.top_area10 .form_block .tdline {
	margin:0 0 10px;
	font-size:1.6rem;
}

.top_area10 .form_block .tdline:last-child {
	margin:0;
}

.top_area10 .form_block .select100 {
	margin:0 0 10px;
	padding:0 10px;
	width:100%;
	height:46px;
	line-height:44px;
	letter-spacing: 0.04em;
	background-color: #FFF;
	border:1px solid #dcd1b9;
	vertical-align: bottom;
	border-radius: 46px;
}

.top_area10 .form_block .select100:last-child {
	margin:0;
}

.top_area10 .form_block .tdline input {
	padding:0 10px;
	width:100%;
	height:46px;
	line-height:44px;
	letter-spacing: 0.04em;
	background-color: #FFF;
	border:1px solid #dcd1b9;
	vertical-align: bottom;
}

.top_area10 .form_block .tdline .tarea100 {
	padding:10px;
	width:100%;
	height:150px;
	line-height:1.6;
	letter-spacing: 0.04em;
	background-color: #FFF;
	border:1px solid #dcd1b9;
	vertical-align: bottom;
}

.top_area10 .form_block .error {
	color:#C00;
	letter-spacing: 0.04em;
}

.top_area10 .thanks_block {
	display: none;
	padding:30px 0 0;
}

.top_area10 .thanks_block .thanks_ex {
	margin:0 0 70px;
	text-align: center;
	color:#78612b;
	font-feature-settings : 'palt';
}

.top_area10 .thanks_block .thanks_ex .lead {
	margin:0 0 20px;
	line-height:2.0;
	letter-spacing: 0.04em;
}

.top_area10 .thanks_block .thanks_ex .ex {
	line-height:1.7;
	font-size:1.2rem;
	letter-spacing: 0.04em;
}

.cmessage {
	text-align: center;
	letter-spacing: 0.08em;
}

.cmessage p {
	padding:0 0 30px;
}

.top_area10 .btn_block p {
	margin:0 auto;
	width:170px;
}

.top_area10 .btn_block .btn2 {
	width:220px;
}

.top_area10 .btn_block p a {
	display: block;
	line-height:38px;
	text-align: center;
	color:#78612b;
	letter-spacing: 0.12em;
	background-color: #dcd1b9;
	border-radius: 50px;
}

@media screen and (min-width: 768px) {

	/*
	=================================== */
	.sp,
	.spbox {
		display: none;
	}

	.pc {
		display: initial;
	}

	.pcbox {
		display: block;
	}

	.wrap_block {
		display: flex;
		justify-content: space-between;
		align-items: flex-start;
	}

	/*
	=================================== */
	#wrapper {
		min-width:1100px;
		font-size:1.6rem;
	}

	.block1 {
		margin:0 auto;
		padding:75px 50px 70px;
		width:1100px;
	}

	.pagetop {
		right:50px;
		bottom:50px;
		width:50px;
	}

	.pagetop a {
		padding: 50px 0 0;
		background-size: 22px 11px;
	}

	footer .block1 {
		padding-top:20px;
		padding-bottom:20px;
		position: relative;
	}

	footer .block1::after {
		position: absolute;
		top:0;
		left:150px;
		content: '';
		background-color:#e5e1d3;
		width:1px;
		height:100%;
		z-index:-30;
	}

	/* KV
	=================================== */
	.kv_area::after {
		background-size: 1000px 820px;
	}

	.kv_area .block1 {
		padding-top:80px;
		padding-bottom:0;
		height:865px;
	}

	.kv_area h1 {
		background-size: auto 108px;
		margin:0 0 160px;
		padding: 108px 0 0;
	}

	.kv_area .en {
		margin:0 0 40px;
		line-height:1.45;
		font-size:5.0rem;
	}

	.kv_area .kv_mlead {
		height:210px;
	}

	.kv_area .kv_mlead p {
		margin:0 0 0 20px;
	}

	.kv_area .kv_mlead p b {
		font-size:2.0rem;
	}

	.kv_area .lang {
		top:25px;
		right:50px;
	}

	.kv_area .lang a {
		font-size:1.6rem;
	}

	.kv_bgcover .inblock {
		height:907px;
	}

	.kv_area .kv_bgcover.bgcover1 {
		background-image: url('../images/kv_item1.webp');
		background-size: 1391px 907px;
	}

	.kv_area .kv_bgcover.bgcover1 .kvitem {
		background-size: 1391px 907px;
		height:907px;
	}

	.kv_area .kv_bgcover.bgcover1 .kvitem.kvitem1 {
		background-image: url('../images/kv_item2.webp');
	}

	.kv_area .kv_bgcover.bgcover1 .kvitem.kvitem2 {
		background-image: url('../images/kv_item3.webp');
	}

	.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem1 {
		top:13px;
		left:calc(50% + 150px);
		background-size: auto 150px;
		width:165px;
		height:150px;
	}

	.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem2 {
		top:65px;
		left:calc(50% - 445px);
		background-size: auto 80px;
		width:95px;
		height:80px;
	}

	.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem3 {
		top: 130px;
		left: calc(50% - 366px);
		background-size: auto 87px;
		width:102px;
		height:87px;
	}

	.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem4 {
		display: block;
		top: 140px;
		left: calc(50% + 430px);
		background-image: url('../images/kv_icon1.webp');
		background-size: auto 57px;
		width: 72px;
		height: 57px;
		animation-delay: .1s;
	}

	.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem5 {
		display: block;
		top:245px;
		left:calc(50% - 652px);
		background-image: url('../images/kv_icon1.webp');
		background-size: auto 110px;
		width:135px;
		height:110px;
		animation-delay: .7s;
	}

	.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem6 {
		top: 365px;
		left: calc(50% + 180px);
		background-size: auto 225px;
		width: 255px;
		height: 225px;
	}

	.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem7 {
		top:425px;
		left:calc(50% - 325px);
		background-size: auto 125px;
		width:150px;
		height:125px;
	}

	.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem8 {
		top: 515px;
		left: calc(50% + 145px);
		background-size: auto 122px;
		width: 150px;
		height: 122px;
	}

	.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem9 {
		display: block;
		top:500px;
		left:calc(50% + 495px);
		background-image: url('../images/kv_icon1.webp');
		background-size: auto 150px;
		width:175px;
		height:150px;
		animation-delay: .15s;
	}

	.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem10 {
		top: 603px;
		left: calc(50% - 380px);
		background-size: auto 55px;
		width: 80px;
		height: 55px;
	}

	.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem11 {
		top:620px;
		left:calc(50% - 555px);
		background-size: auto 226px;
		width:250px;
		height:226px;
	}

	.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem12 {
		top: 740px;
		left: calc(50% + 75px);
		background-size: auto 72px;
		width: 90px;
		height: 72px;
	}

	.kv_area .kv_bgcover.bgcover2 .kvitem.kvitem13 {
		top:800px;
		left:calc(50% + 500px);
		background-size: auto 86px;
		width:100px;
		height:86px;
	}

	/* area
	=================================== */
	.area_mtitlebox {
		position: absolute;
		top:70px;
		left:50px;
		justify-content: flex-start;
		writing-mode:vertical-rl;
		-ms-writing-mode:tb-rl;
		margin:0;
		width:100px;
		height:340px;
	}

	.area_mtitlebox h2 {
		background-size: 33px 71px;
		padding:110px 2px 0 0;
		width:34px;
		font-size:1.7rem;
		letter-spacing: 0.08em;
	}

	.area_mleadbox {
		margin:0;
	}

	.area_mleadinbox {
		padding:105px 0 0;
		position: relative;
	}

	.area_mleadbox .labelbox {
		display: block;
		margin:0;
	}

	.area_mleadbox .labelbox .label {
		position: absolute;
		top:0;
		left:0;
		margin:0;
		padding:0 0 40px;
		width:56px;
		font-size:4.4rem;
		background-position: center bottom;
	}

	.area_mleadbox .labelbox .name {
		display: none;
	}

	.area_mleadbox .mlead {
		margin:0 0 50px;
		padding:0;
	}

	.area_mleadbox .mlead p {
		line-height:1.75;
		font-size:2.8rem;
		letter-spacing: 0.08em;
	}

	.areaex_block {
		margin:0;
		padding:0;
	}

	.areaex_block p {
		margin:0 0 40px;
		line-height:2.0;
		font-size:1.7rem;
	}

	.area_label {
		position: absolute;
		bottom:0;
		left:50px;
		display: flex;
		justify-content: center;
		align-items: flex-start;
		width:100px;
		writing-mode:vertical-rl;
		-ms-writing-mode:tb-rl;
	}

	.area_label p {
		margin:0 auto;
		color:#b4a582;
		font-size:1.0rem;
		font-weight: 400;
		font-family: "din-2014", sans-serif;
		letter-spacing: 0.12em;
	}

	/* area1
	=================================== */
	.top_area1::before {
		top:-105px;
		background-size: 1400px 250px;
		height:250px;
	}

	.top_area1::after {
		top:145px;
		background-size: 1400px 250px;
		height:calc(100% + 40px);
	}

	.top_area1 .block1 {
		padding-bottom:90px;
		position: relative;
	}

	.top_area1 .block1::after {
		position: absolute;
		top:38px;
		left:150px;
		content: '';
		background-color:#e5e1d3;
		width:1px;
		height:100%;
		z-index:-30;
	}

	.top_area1 .mlead {
		margin:0 0 40px;
	}

	.top_area1 .mlead p {
		line-height:2.0;
		text-align: center;
		font-size:2.0rem;
		letter-spacing: 0.08em;
	}

	.top_area1 .gallery_block {
		margin:0 auto 50px;
		width:870px;
	}

	.top_area1 .gallery_block li {
		margin:0 10px 10px 0;
		width:210px;
	}

	.top_area1 .gallery_block li:nth-child(2n) {
		margin-right:10px;
	}

	.top_area1 .gallery_block li:nth-child(4n) {
		margin-right:0;
	}

	.top_area1 .btnbox {
		width:480px;
	}

	.top_area1 .btnbox a {
		display: flex;
		justify-content: center;
		align-items: baseline;
		padding:6px 0 6px;
	}

	.top_area1 .btnbox .bline1 {
		margin:0 15px 0 0;
		font-size:1.6rem;
	}

	.top_area1 .btnbox .bline2 {
		font-size:2.4rem;
	}

	.top_area1 .btnbox a:hover {
		box-shadow: 0 0 10px #dcd1b9;
	}

	/* area2
	=================================== */
	.top_area2::before {
		top:-90px;
		background-size: 1400px 245px;
		height:245px;
	}

	.top_area2::after {
		bottom:-105px;
		background-size: 1400px 250px;
		height:250px;
	}

	.top_area2 .inblock::before {
		top:155px;
		height:calc(100% - 275px);
	}

	.top_area2 .block1 {
		padding:70px 125px 90px 290px;
		position: relative;
	}

	.top_area2 .block1::after {
		position: absolute;
		top:0;
		left:150px;
		content: '';
		background-color:#e5e1d3;
		width:1px;
		height:100%;
		z-index:-30;
	}

.top_area2 .area_mtitlebox {
	margin-right:10px;
}

	.top_area2 .area_mleadbox .label {
		background-size:auto 19px;
	}

.top_area2 .areaex_block {
	margin-right:20px;
}

	.top_area2 .areaex_block {
		padding:0;
	}

	.top_area2 .area_label {
		bottom:-25px;
	}

	/* area3
	=================================== */
	.top_area3 .block1 {
		padding:70px 125px 130px 290px;
		position: relative;
	}

	.top_area3 .block1::after {
		position: absolute;
		top:0;
		left:150px;
		content: '';
		background-color:#e5e1d3;
		width:1px;
		height:100%;
		z-index:-30;
	}

	.top_area3 .area_mtitlebox {
		display: flex;
	}

	.top_area3 .area_mleadbox .label {
		left:auto;
		right:0;
		background-size:auto 21px;
	}

	.top_area3 .area_mleadbox .mlead {
		text-align: right;
	}

	.top_area3 .area_mtitlebox {
		top:95px;
	}

	.top_area3 .area_mleadbox {
		left:auto;
		right:235px;
	}

	.top_area3 .areaex_block {
		padding:0;
	}

	.top_area3 .area_label {
		bottom:30px;
	}

	/* area4
	=================================== */
	.top_area4::before {
		top:-65px;
		background-size: 1400px 245px;
		height:245px;
	}

	.top_area4::after {
		bottom:-90px;
		background-size: 1400px 250px;
		height:250px;
	}

	.top_area4 .inblock::before {
		top:180px;
		height:calc(100% - 280px);
	}

	.top_area4 .block1 {
		padding:70px 135px 90px 290px;
		position: relative;
	}

	.top_area4 .block1::after {
		position: absolute;
		top:0;
		left:150px;
		content: '';
		background-color:#e5e1d3;
		width:1px;
		height:100%;
		z-index:-30;
	}

	.top_area4 .area_mtitlebox {
		display: flex;
	}

	.top_area4 .area_mleadbox {
		top:145px;
		left:260px;
	}

	.top_area4 .area_mleadbox .label {
		background-size:auto 22px;
	}

	.top_area4 .areaex_block {
		padding:0;
	}

	/* area5
	=================================== */
	.top_area5 .block1 {
		padding:70px 135px 160px 290px;
		position: relative;
	}

	.top_area5 .block1::after {
		position: absolute;
		top:0;
		left:150px;
		content: '';
		background-color:#e5e1d3;
		width:1px;
		height:100%;
		z-index:-30;
	}

	.top_area5 .area_mtitlebox {
		display: flex;
	}

	.top_area5 .area_mleadbox {
		top:90px;
		left:auto;
		right:245px;
	}

	.top_area5 .area_mleadbox .label {
		left:auto;
		right:0;
		background-size:auto 19px;
	}

	.top_area5 .area_mleadbox .mlead {
		text-align: right;
	}

	.top_area5 .areaex_block {
		padding:0;
	}

	.top_area5 .area_label {
		bottom:20px;
	}

	/* area6
	=================================== */
	.top_area6::before {
		top:-160px;
		background-size: 1400px 245px;
		height:245px;
	}

	.top_area6::after {
		bottom:-50px;
		background-size: 1400px 250px;
		height:250px;
	}

	.top_area6 .inblock::before {
		top:85px;
		height:calc(100% - 270px);
	}

	.top_area6 .block1 {
		padding:70px 135px 175px 290px;
		position: relative;
	}

	.top_area6 .block1::after {
		position: absolute;
		top:0;
		left:150px;
		content: '';
		background-color:#e5e1d3;
		width:1px;
		height:100%;
		z-index:-30;
	}

	.top_area6 .area_mtitlebox {
		display: flex;
	}

	.top_area6 .area_mleadbox {
		top:85px;
		left:270px;
	}

	.top_area6 .area_mleadbox .label {
		background-size:auto 21px;
	}

	.top_area6 .areaex_block {
		padding:0;
	}

	.top_area6 .area_label {
		bottom:50px;
	}

	/* area7
	=================================== */
	.top_area7 .block1 {
		padding:135px 70px 150px 200px;
		position: relative;
	}

	.top_area7 .block1::after {
		position: absolute;
		top:0;
		left:150px;
		content: '';
		background-color:#e5e1d3;
		width:1px;
		height:100%;
		z-index:-30;
	}

	.top_area7 .area_mtitlebox {
		display: flex;
	}

	.top_area7 .message_block {
		padding:75px 65px 70px 85px;
		border-radius: 35px;
	}

	.top_area7 .message_block h3 {
		top:-70px;
		right:65px;
		line-height:1.0;
		font-size:3.0rem;
	}

	.top_area7 .message_block .exbox p {
		margin:0 0 25px;
		line-height:2.2;
		font-size:1.8rem;
	}

	.top_area7 .message_block .picon.picon1 {
		top:-190px;
		right:-85px;
		background-size: 348px 335px;
		width:348px;
		height:335px;
	}

	.top_area7 .message_block .picon.picon2,
	.top_area7 .message_block .picon.picon4,
	.top_area7 .message_block .picon.picon5,
	.top_area7 .message_block .picon.picon7,
	.top_area7 .message_block .picon.picon9 {
		background-size: 54px 57px;
		width:54px;
		height:57px;
	}

	.top_area7 .message_block .picon.picon2 {
		display: block;
		top:5px;
		right:-145px;
	}

	.top_area7 .message_block .picon.picon4 {
		top:205px;
		right:-5px;
	}

	.top_area7 .message_block .picon.picon5 {
		top:250px;
		left:-25px;
	}

	.top_area7 .message_block .picon.picon7 {
		display: block;
		top:500px;
		left:385px;
	}

	.top_area7 .message_block .picon.picon9 {
		display: block;
		top:555px;
		left:-165px;
	}

	.top_area7 .message_block .picon.picon3 {
		top:45px;
		left:-230px;
		background-size: 97px 93px;
		width:97px;
		height:93px;
	}

	.top_area7 .message_block .picon.picon6 {
		top:400px;
		right:-90px;
		background-size: 111px 106px;
		width:111px;
		height:106px;
	}

	.top_area7 .message_block .picon.picon8 {
		display: block;
		top:460px;
		left:-90px;
		background-image: url('../images/area7picon5.webp');
		background-size: 141px 132px;
		width:141px;
		height:132px;
	}

	.top_area7 .area_label {
		bottom:35px;
	}

	/* area8
	=================================== */
	.top_area8::before {
		top:-60px;
		background-size: 1400px 105px;
		height:105px;
	}

	.top_area8::after {
		bottom:-30px;
		background-size: 1400px 200px;
		height:200px;
	}

	.top_area8 .inblock::before {
		top:45px;
		background-size: 1400px 200px;
		height:calc(100% - 214px);
	}

	.top_area8 .block1 {
		padding:70px 50px 190px 180px;
		position: relative;
	}

	.top_area8 .block1::after {
		position: absolute;
		top:0;
		left:150px;
		content: '';
		background-color:#e5e1d3;
		width:1px;
		height:100%;
		z-index:-30;
	}

	.top_area8 .area_mtitlebox {
		margin-bottom:0;
	}

	.top_area8 .data_block {
		display: block;
		padding:70px 0 0 120px;
		position: relative;
	}

	.top_area8 .data_block .titlebox {
		position: absolute;
		top:0;
		left:0;
		display: block;
	}

	.top_area8 .data_block .titlebox .inbox {
		width:60px;
		color:#988455;
	}

	.top_area8 .data_block .titlebox h3 {
		height:140px;
		line-height:1.0;
		font-size:2.4rem;
		letter-spacing: 0.2em;
		writing-mode:vertical-rl;
		-ms-writing-mode:tb-rl;
	}

	.top_area8 .shopinfo_block {
		display: flex;
		justify-content: space-between;
		align-items: flex-start;
		margin:0 0 40px;
	}

	.top_area8 .shopinfo_block .imagebox {
		display: block;
		padding:7px;
		width:219px;
		background-color: #f0f0f0;
	}

	.top_area8 .shopinfo_block .parlor {
		width:490px;
	}

	.top_area8 .shopinfo_block .parlor .shoptitlebox {
		display: flex;
		justify-content: space-between;
		align-items: center;
		margin:0 0 25px;
		text-align: left;
	}

	.top_area8 .shopinfo_block .parlor .shoptitlebox h4 {
		font-size:3.0rem;
	}

	.top_area8 .shopinfo_block .parlor .shoptitlebox p {
		display: block;
		width: 26px;
	}

	.top_area8 .shopinfo_block .parlor .shoptitlebox p a {
		display: block;
		overflow: hidden;
		background: url('../images/icon_insta.webp') no-repeat center center;
		background-size: 26px 26px;
		padding: 26px 0 0;
		height: 0!important;
	}

	.top_area8 .shopinfo_block .sp_imagebox {
		display: none;
	}

	.top_area8 .shopinfo_block .sp_gallery_block {
		display: none;
	}

	.top_area8 .shopinfo_block .parlor .ex p {
		margin:0 0 25px;
		line-height:1.9;
		font-size:1.7rem;
	}

	.top_area8 .gallery_block {
		display: block;
		margin:0 auto 40px;
		width:750px;
	}

	.top_area8 .gallery_block ul {
		display: flex;
		align-items: flex-start;
		flex-wrap: wrap;
	}

	.top_area8 .gallery_block li {
		margin:0 10px 0 0;
		width:180px;
	}

	.top_area8 .gallery_block li:nth-child(4n) {
		margin-right:0;
	}

	.top_area8 .shopdata_block {
		display: flex;
		justify-content: space-between;
		align-items: flex-start;
		flex-direction: row-reverse;
		margin:0;
	}

	.top_area8 .shopdata_block .mapbox {
		margin:0;
		wodth:300px;
	}

	.top_area8 .shopdata_block .mapbox iframe {
		height:150px;
	}

	.top_area8 .shopdata_block .databox {
		margin:0;
		wodth:420px;
		font-feature-settings : 'palt';
	}

	.top_area8 .shopdata_block .databox table {
		font-size:1.5rem;
	}

	.top_area8 .shopdata_block .databox th {
		width:120px;
		letter-spacing: 0.04em;
	}

	.top_area8 .shopdata_block .databox td {
		letter-spacing: 0.04em;
	}

	.top_area8 .shopdata_block .spinsta {
		display: none;
	}

	.top_area8 .area_label {
		bottom:70px;
	}

	/* area9
	=================================== */
	.top_area9::before {
		background-size: 1000px 820px;
		height:820px;
	}

	.top_area9 .block1 {
		padding:70px 70px 80px 180px;
		position: relative;
	}

	.top_area9 .block1::after {
		position: absolute;
		top:0;
		left:150px;
		content: '';
		background-color:#e5e1d3;
		width:1px;
		height:100%;
		z-index:-30;
	}

	.top_area9 .area_mtitlebox {
		margin-bottom:0;
	}

	.top_area9 .data_block {
		margin:0 0 60px;
		padding:60px 0 0 200px;
		position: relative;
	}

	.top_area9 .data_block .titlebox {
		position: absolute;
		top:0;
		left:0;
		display: block;
	}

	.top_area9 .data_block .titlebox .inbox {
		width:60px;
		color:#988455;
	}

	.top_area9 .data_block .titlebox h3 {
		height:240px;
		line-height:1.0;
		font-size:2.4rem;
		letter-spacing: 0.2em;
		writing-mode:vertical-rl;
		-ms-writing-mode:tb-rl;
	}

	.top_area9 .data_block .databox table {
		font-size:1.6rem;
	}

	.top_area9 .data_block .databox th {
		padding:15px 0;
		width:190px;
		letter-spacing: 0.04em;
	}

	.top_area9 .data_block .databox td {
		padding:15px 0;
		letter-spacing: 0.04em;
	}

	.top_area9 .about_block {
		background-position: left 85px center;
		background-size: 142px auto;
		padding:90px 25px 90px 335px;
		border-radius: 35px;
	}

	.top_area9 .about_block h3 {
		margin:0 0 35px;
		line-height:1.8;
		font-size:2.2rem;
	}

	.top_area9 .about_block .exbox p {
		margin:0 0 30px;
		line-height:2.1;
		font-size:1.6rem;
	}

	.top_area9 .area_label {
		bottom:35px;
	}

	/* area10
	=================================== */
	.top_area10 .block1 {
		padding: 70px 200px 50px 220px;
		position: relative;
	}

	.top_area10 .block1::after {
		position: absolute;
		top:0;
		left:150px;
		content: '';
		background-color:#e5e1d3;
		width:1px;
		height:100%;
		z-index:-30;
	}

	.top_area10 .area_mtitlebox {
		height:300px;
	}

	.top_area10 .leadbox {
		margin:0 0 75px;
		padding:45px 0 0;
		text-align: center;
	}

	.top_area10 .leadbox .lead1 {
		font-size:2.2rem;
	}

	.top_area10 .leadbox .lead2 {
		line-height:1.4;
		font-size:1.6rem;
	}

	.top_area10 .form_block {
		margin:0 0 65px;
	}

	.top_area10 .form_block th {
		display: table-cell;
		padding:10px 0 25px;
		width:210px;
		font-size:1.7rem;
		letter-spacing: 0.04em;
	}

	.top_area10 .form_block td {
		display: table-cell;
		padding:10px 0 25px;
		letter-spacing: 0.08em;
	}

	.top_area10 .form_block tr:last-child th,
	.top_area10 .form_block tr:last-child td {
		padding-bottom:0;
	}

	.top_area10 .form_block .input {
		padding-top:0;
	}

	.top_area10 .form_block .select100 {
		margin:0 0 10px;
		padding:0 20px;
		height:40px;
		line-height:40px;
	}

	.top_area10 .form_block .tdline input {
		padding:0 20px;
		height:40px;
		line-height:40px;
		letter-spacing: 0.08em;
	}

	.top_area10 .form_block .tdline .tarea100 {
		padding:10px 20px;
		letter-spacing: 0.08em;
	}

	.top_area10 .thanks_block {
		padding:55px 0 0;
	}

	.top_area10 .thanks_block .thanks_ex {
		margin:0 0 50px;
		text-align: center;
		color:#78612b;
		font-feature-settings : 'palt';
	}

	.top_area10 .thanks_block .thanks_ex .lead {
		margin:0 0 30px;
		line-height:2.125;
		letter-spacing: 0.04em;
	}

	.top_area10 .thanks_block .thanks_ex .ex {
		line-height:1.7;
		font-size:1.4rem;
		letter-spacing: 0.04em;
	}

	.top_area10 .btn_block p {
		width:225px;
	}

	.top_area10 .btn_block .btn2 {
		width:300px;
	}

	.top_area10 .btn_block p a  {
		line-height:50px;
		letter-spacing: 0.16em;
	}
}

@media screen and (min-width: 769px) {

	/*
	=================================== */
	.op a:hover {
		opacity: 0.7;
		filter: alpha(opacity=70);
		zoom: 1;
	}

	.fade a {
		-webkit-transition: opacity 0.3s ease-in-out;
		transition: opacity 0.3s ease-in-out;
	}

	.fade2 a {
		-webkit-transition: 0.3s;
		transition: 0.3s;
	}
}

@media screen and (min-width: 1400px) {

	/* area1
	=================================== */
	.top_area1::before {
		background-size: 100% 250px;
	}

	/* area2
	=================================== */
	.top_area2::before {
		background-size: 100% 245px;
	}

	.top_area2::after {
		background-size: 100% 250px;
	}

	/* area4
	=================================== */
	.top_area4::before {
		background-size: 100% 245px;
	}

	.top_area4::after {
		background-size: 100% 250px;
	}

	/* area6
	=================================== */
	.top_area6::before {
		background-size: 100% 245px;
	}

	.top_area6::after {
		background-size: 100% 250px;
	}

	/* area8
	=================================== */
	.top_area8::before {
		background-size: 100% 105px;
	}

	.top_area8::after {
		background-size: 100% 200px;
	}
}
