@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#main .mainVisual {
	margin-bottom: 9.1rem;
}
#main .mainVisual .photo {
	margin-top: max(-58.5vw,-22.4rem);
	margin-bottom: 0.5rem;
	position: relative;
	z-index: 1;
}
#main .mainVisual .photo img {
	width: 100%;
}
#main .mainVisual .subBox {
	padding: 12rem 0 min(70vw,26.7rem);
	z-index: 1;
	position: relative;
	background: url(../img/index/bg05.png) no-repeat center bottom;
	background-size: 100% 100%;
}
#main .mainVisual .subBox .enTxt {
	position: absolute;
	top: 13.2rem;
	/* left: 50%;
	transform: translateX(-50%); */
	z-index: -1;
	right: -1px;
	left: -1px;
}
#main .mainVisual .subBox h2 {
	width: 18rem;
	margin: 0 auto;
	font-size: 2.8rem;
	letter-spacing: 0.14em;
	font-weight: 500;
	line-height: 2.14;
}
#main .mainVisual .subBox h2 .subSpan {
	display: block;
	-webkit-writing-mode : tb-rl;
	-webkit-writing-mode: vertical-rl;
	writing-mode: tb-rl;
	writing-mode: vertical-rl;
	white-space: nowrap;
}
#main .mainVisual .subBox h2 .ico {
	margin-top: -0.5rem;
	display: inline-block;
}
#main .mainVisual .subBox h2 .ico2 {
	margin: -0.7rem 0 0.5rem;
	display: inline-block;
}
#main .mainVisual p {
	padding: 0 2rem;
	text-align: center;
	letter-spacing: 0.1em;
	line-height: 2;
	font-weight: 300;
}
#main .philosophy {
	padding: 7.0rem 0 8.9rem;
	color: #fff;
	position: relative;
	background: url(../img/index/bg01.jpg) no-repeat center;
	background-size: cover;
}
#main .philosophy::before {
	height: 0.65rem;
	background: url(../img/index/bg06.png) repeat-x;
	background-size: 100% 0.65rem;
	position: absolute;  
	top: -0.3rem;
	right: 0;  
	left: 0;
	content: ""; 
}
#main .philosophy::after {
	height: 0.65rem;
	background: url(../img/index/bg06.png) repeat-x;
	background-size: 100% 0.65rem;
	position: absolute;  
	bottom: -0.3rem;
	right: 0;  
	left: 0;
	content: ""; 
}
#main .philosophy .photo {
	margin-bottom: 3.7rem;
}
#main .philosophy .photo img {
	width: 100%;
}
#main .philosophy .txt {
	width: fit-content;
	margin-left: auto;
	line-height: 2;
	padding-right: 1rem;
}
#main .service {
	padding: 6.8rem 0 9.6rem;
}
#main .service .comTxt {
	margin-bottom: 2.8rem;
}
#main .serviceDl {
	align-items: flex-start;
}
#main .serviceDl dt {
	width: 8.5rem;
	padding: 0.8rem 1rem 0 3.5rem;
	position: relative;
}
#main .serviceDl dt:after {
	width: 8888px;  
	height: 1px;
	background-color: #8C7669;
	position: absolute;  
	top: 50%;
	transform: translateY(-50%);
	right: calc(100% - 2.3rem);  
	content: ""; 
}
#main .serviceDl dt img {
	width: auto;
	max-height: 1.5rem;
}
#main .serviceDl dd {
	margin-bottom: 3.3rem;
	width: calc(100% - 8.5rem);
}
#main .serviceDl dd:last-child {
	margin-bottom: 0;
}
#main .serviceDl dd p {
	font-size: 1.3rem;
	letter-spacing: 0.1em;
	line-height: 1.615;
	font-weight: 300;
}
#main .serviceDl dd .ttl {
	margin-bottom: 1rem;
	font-size: 1.8rem;
	font-weight: 400;
	letter-spacing: 0.14em;
	line-height: 1.44;
}
#main .craft {
	padding: 6.8rem 0 8.0rem;
	color: #fff;
	position: relative;
	background: url(../img/index/bg02.jpg) no-repeat center;
	background-size: cover;
}
#main .craft::before {
	height: 0.65rem;
	background: url(../img/index/bg06.png) repeat-x;
	background-size: 100% 0.65rem;
	position: absolute;  
	top: -0.3rem;
	right: 0;  
	left: 0;
	content: ""; 
}
#main .craft::after {
	height: 0.65rem;
	background: url(../img/index/bg06.png) repeat-x;
	background-size: 100% 0.65rem;
	position: absolute;  
	bottom: -0.3rem;
	right: 0;  
	left: 0;
	content: ""; 
}
#main .craft .comTxt {
	margin-bottom: 2.5rem;
}
#main .craft .comTxt2 {
	margin-bottom: 5.7rem;
}
#main .comJsList {
	position: relative;
	margin-bottom: 3.4rem;
}
#main .comJsListBox:last-child .comJsList {
	margin-bottom: 0;
}
#main .comJsList .slick-slide {
	line-height: 1;
}
#main .comJsList img {
	width: 100%;
}
#main .slick-dots {
	position: absolute;
	bottom: 1.5rem;
	left: 0;
	width: 100%;
	text-align: center;
	z-index: 1;
}
#main .slick-dots li {
	margin: 0 1rem;
	display: inline-block;
	cursor: pointer;
	width: 1.2rem;
	aspect-ratio: 1;
	border: 1px solid #fff;
	border-radius: 10rem;
}
#main .slick-dots li button {
	display: none;
}
#main .slick-dots li.slick-active {
	background-color: #fff;
}
#main .craft h3 {
	width: 8.2rem;
	margin-bottom: 1rem;
}
#main .craft .list {
	padding-left: 3.5rem;
}
#main .craft .list li {
	font-size: 1.4rem;
	line-height: 1.43;
	letter-spacing: 0.1em;
	padding: 0.1rem 0 1.6rem 3.5rem;
	background: url(../img/common/icon01.png) no-repeat left top;
	background-size: 1.5rem auto;
}
#main .gallery {
	padding: 6.7rem 0 9.6rem;
}
#main .gallery .comTxt {
	margin-bottom: 2.8rem;
}
#main .gallery .comTxt2 {
	margin-bottom: 5.6rem;
}
#main .gallery .inner {
	margin-bottom: 6rem;
}
#main .gallery .inner:last-child {
	margin-bottom: 0;
}
#main .gallery .inner h3 {
	margin-bottom: 1.9rem;
	font-size: 1.4rem;
	font-weight: 400;
	color: #8C7669;
	letter-spacing: 0.14em;
	font-family: "Noto Sans JP", sans-serif;
}
#main .gallery .inner h3 .en {
	margin-bottom: 0.2rem;
	display: block;
}
#main .gallery .inner h3 .en img {
	max-height: 4rem;
}
#main .gallery .fooList {
	margin-bottom: 1rem;
}
#main .gallery .fooList img {
	width: 100%;
	display: block;
}
#main .gallery .fooList li:nth-child(n + 2) {
	display: none;
}
#main .gallery .fooList {
	margin-bottom: 0.6rem;
}
#main .gallery .iconBox {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0 1rem;
}
#main .gallery .iconBox img {
	display: block;
}
#main .gallery .iconBox > div {
	width: 2.4rem;
	cursor: pointer;
}
#main .gallery .iconBox .subSpan {
	margin: 0 0.5rem;
	display: flex;
	align-items: center;
	gap: 0 4.5rem;
	font-size: 1.4rem;
	color: #8C7669;
	letter-spacing: 0.14em;
	position: relative;
}
#main .gallery .iconBox .subSpan::before {
	width: 1px;  
	background-color: #8C7669;
	position: absolute;  
	top: 0;
	bottom: 0;
	left: 50%;
	transform: rotate(44deg);
	content: ""; 
}
#main .gallery .iconBox .subSpan .num {
	width: 4rem;
	text-align: center;
}
#main .menuSec {
	padding: 6.9rem 0 9.7rem;
	position: relative;
	background: url(../img/index/bg03.jpg) no-repeat center;
	background-size: cover;
}
#main .menuSec::before {
	height: 0.65rem;
	background: url(../img/index/bg06.png) repeat-x;
	background-size: 100% 0.65rem;
	position: absolute;  
	top: -0.3rem;
	right: 0;  
	left: 0;
	content: ""; 
}
#main .menuSec::after {
	height: 0.65rem;
	background: url(../img/index/bg06.png) repeat-x;
	background-size: 100% 0.65rem;
	position: absolute;  
	bottom: -0.3rem;
	right: 0;  
	left: 0;
	content: ""; 
}
#main .menuSec .comTxt {
	margin-bottom: 2.8rem;
}
#main .menuSec .inner {
	margin: 0 -2.4rem 0 3.5rem;
}
#main .menuSec .priceDl {
	margin-bottom: 3.1rem;
	align-items: stretch;
}
#main .menuSec .priceDl dt {
	margin-bottom: 0.5rem;
	padding: 1.5rem 1rem 0.7rem 0;
	width: 14rem;
	font-size: 1.4rem;
	font-weight: 300;
	color: #8C7669;
	letter-spacing: 0.14em;
	display: flex;
	align-items: center;
	border-bottom: 1px solid #8C7669;
}
#main .menuSec .priceDl dd {
	margin-bottom: 0.5rem;
	padding: 1.5rem 0 0.7rem;
	font-size: 1.8rem;
	font-weight: 400;
	color: #322317;
	letter-spacing: 0.14em;
	width: calc(100% - 14rem);
	border-bottom: 1px solid #8C7669;
}
#main .menuSec .priceDl dd img {
	width: 11rem;
}
#main .menuSec .list li {
	font-size: 1.2rem;
	letter-spacing: 0.1em;
	font-weight: 300;
	color: #8C7669;
	text-indent: -1em;
	padding-left: 1em;
	line-height: 1.67;
}
#main .flow {
	padding: 6.8rem 0 9.6rem;
}
#main .flow .comTxt {
	margin-bottom: 2.5rem;
}
#main .flow .inner {
	margin: -0.3rem -2.4rem 5.6rem 0;
}
#main .flow .inner:last-child {
	margin-bottom: 0;
}
#main .flow .inner .stepTtl {
	cursor: pointer;
	padding-bottom: 0.8rem;
	background: url(../img/common/icon02.png) no-repeat right 2.4rem bottom 0.8rem;
	background-size: 1.7rem auto;
	border-bottom: 1px solid #8C7669;
}
#main .flow .inner .stepTtl.on {
	background-image: url(../img/common/icon03.png);
}
#main .flow .inner .stepTtl img {
	max-height: 3.2rem;
}
#main .flow .inner .subBox {
	display: none;
	position: relative;
	padding: 3.8rem 0 0 7rem;
}
#main .flow .inner .subBox::before {
	width: 1px;  
	background-color: #8C7669;
	position: absolute;  
	top: 0;
	bottom: 0;
	left: 3.4rem;
	content: ""; 
}
#main .flow .inner .subBox::after {
	width: 1px;  
	background-color: #8C7669;
	position: absolute;  
	bottom: 0;
	left: 3.6rem;
	content: ""; 
	height: 0.5rem;
	transform: rotate(38deg);
}
#main .flow .inner .subBox p {
	margin-bottom: 3.8rem;
	font-size: 1.3rem;
	font-weight: 300;
	letter-spacing: 0.1em;
	line-height: 1.615;
}
#main .flow .inner .subBox p:last-child {
	margin-bottom: 0;
}
#main .flow .inner .subBox .ttl {
	margin-bottom: 0.8rem;
	font-size: 1.6rem;
	font-weight: 400;
	letter-spacing: 0.14em;
	position: relative;
}
#main .flow .inner .subBox .ttl:after {
	width: 0.7rem;  
	aspect-ratio: 1;
	background-color: #fff;
	border: 1px solid #8C7669;
	border-radius: 100%;
	position: absolute;  
	top: 0.7rem;
	left: -4rem;
	content: ""; 
}
#main .flow .inner .subBox .photo {
	padding-top: 0.5rem;
}
#main .flow .inner .subBox .photo img {
	width: 100%;
}
#main .craftsman{
	padding: 7rem 0 9.6rem;
	position: relative;
	background: url(../img/index/bg04.jpg) no-repeat center bottom;
	background-size: cover;
}
#main .craftsman::before {
	height: 0.65rem;
	background: url(../img/index/bg06.png) repeat-x;
	background-size: 100% 0.65rem;
	position: absolute;  
	top: -0.3rem;
	right: 0;  
	left: 0;
	content: ""; 
}
#main .craftsman::after {
	height: 0.65rem;
	background: url(../img/index/bg06.png) repeat-x;
	background-size: 100% 0.65rem;
	position: absolute;  
	bottom: -0.2rem;
	right: 0;  
	left: 0;
	content: ""; 
}
#main .craftsman .comTxt {
	margin-bottom: 2.8rem;
}
#main .craftsman .comTxt2 {
	margin-bottom: 5.8rem;
}
#main .craftsman .photo {
	margin-bottom: 3rem;
	border-top: 1px solid #8C7669;
	border-bottom: 1px solid #8C7669;
	padding: 0.4rem 0;
}
#main .craftsman .photo img {
	width: 100%;
}
#main .craftsman .name {
	margin-bottom: 1.6rem;
	font-size: 1.6rem;
	font-weight: 400;
	letter-spacing: 0.14em;
	color: #322317;
}
#main .craftsman .name .en {
	margin-bottom: 0.5rem;
	display: block;
	width: 27.9rem;
}
#main .craftsman .txt {
	font-weight: 300;
	margin: 0 auto;
	padding-left: 3.4rem;
}
#main .access {
	padding: 7rem 0 7.6rem;
}
#main .access .headLine01 {
	margin-bottom: 3.7rem;
}
#main .access .map {
	margin-bottom: 3.9rem;
	padding: 0.5rem;
	border: 1px solid #8C7669;
	aspect-ratio: 327 / 242;
}
#main .access .map iframe {
	display: block;
	width: 100%;
	height: 100%;
}
#main .accessDl > dt {
	margin-bottom: 0.5rem;
	font-size: 1.2rem;
	letter-spacing: 0.1em;
	color: #8C7669;
}
#main .accessDl > dd {
	margin-bottom: 1.6rem;
	font-size: 1.4rem;
	font-weight: 300;
	letter-spacing: 0.1em;
	line-height: 1.43;
}
#main .accessDl .subDl dt {
	width: 11.5rem;
	padding-right: 1rem;
}
#main .accessDl .subDl dd {
	width: calc(100% - 11.5rem);
}
#main .voice {
	padding: 7.3rem 0 10.3rem;
	background: url(../img/index/bg06.png) no-repeat left top;
	background-size: 100% 0.65rem;
}
#main .voice .comTxt {
	margin-bottom: 2rem;
}
#main .voice .comTxt2 {
	margin-bottom: 5.7rem;
}
#main .voice .inner {
	margin-left: 0rem;
	padding: 2.4rem 2rem 3.8rem;
	position: relative;
	background-color: #EBEBE5;
	clip-path: polygon(
		0 0,
		calc(100% - 2rem) 0,
		100% 2rem,
		100% 100%,
		0 100%
	);
}
#main .voice .innerBox {
	margin-bottom: 4.3rem;
	position: relative;
}
#main .voice .innerBox:last-child {
	margin-bottom: 0;
}
#main .voice .innerBox::before {
	width: 1px;  
	background-color: #8C7669;
	position: absolute;  
	top: 0;
	bottom: 0;
	left: -0.6rem;
	content: ""; 
}
#main .voice .inner .voiceImg {
	width: 5rem;
	position: absolute;
	top: 1.5rem;
	right: 1.7rem;
}
#main .voice .inner p {
	margin-bottom: 2.4rem;
	font-size: 1.4rem;
	font-weight: 300;
	letter-spacing: 0.1em;
	line-height: 1.714;
	text-align: justify;
}
#main .voice .inner p:last-child {
	margin-bottom: 0;
}
#main .voice .inner .num {
	width: 5.4rem;
	margin-bottom: 1rem;
}
#main .voice .inner .ttl {
	margin-bottom: 0.2rem;
	font-size: 1.8rem;
	font-weight: 400;
	letter-spacing: 0.14em;
}
#main .voice .inner .ttl .txtSpan {
	display: block;
	font-size: 1.4rem;
	letter-spacing: 0.1em;
}
#main .voice .inner .txt {
	margin-bottom: 2.7rem;
	font-size: 1.2rem;
	font-weight: 400;
	letter-spacing: 0.1em;
}
#main .voice .inner .photo {
	margin: 0 -2rem -3.8rem;
	padding-top: 1.3rem;
}
#main .voice .inner .photo img {
	width: 100%;
}
#main .voice .jsTtl {
	cursor: pointer;
	margin-top: 6.2rem;
	padding: 0 2rem 0.6rem 0;
	font-size: 1.4rem;
	font-weight: 400;
	color: #8C7669;
	letter-spacing: 0.1em;
	background: url(../img/common/icon02.png) no-repeat right center;
	background-size: 1.7rem auto;
	border-bottom: 1px solid currentColor;
}
#main .voice .jsTtl.on {
	background-image: url(../img/common/icon03.png);
}
#main .voice .innerJs {
	padding-left: 0.6rem;
	margin-left: -0.6rem;
	display: none;
	padding-top: 4.2rem;
}
#main .contact {
	padding: 7.3rem 0 9.8rem;
	position: relative;
	background: url(../img/index/bg07.jpg) no-repeat center;
	background-size: cover;
}
#main .contact::before {
	height: 0.65rem;
	background: url(../img/index/bg06.png) repeat-x;
	background-size: 100% 0.65rem;
	position: absolute;  
	top: -0.2rem;
	right: 0;  
	left: 0;
	content: ""; 
}
#main .contact::after {
	height: 0.65rem;
	background: url(../img/index/bg06.png) repeat-x;
	background-size: 100% 0.65rem;
	position: absolute;  
	bottom: -0.3rem;
	right: 0;  
	left: 0;
	content: ""; 
}
#main .contact .comTxt2 {
	margin-bottom: 5.7rem;
}
#main .snsBox {
	position: relative;
	margin: 0 -2.4rem 4rem 0;
}
#main .snsBox::before {
	width: 1px;  
	background-color: #8C7669;
	position: absolute;  
	top: 0;
	bottom: 0;
	left: -0.6rem;
	content: ""; 
}
#main .snsBox p {
	padding: 0.7rem 2.3rem;
	font-size: 1.4rem;
	color: #fff;
	letter-spacing: 0.1em;
	background-color: #322317;
}
#main .snsList {
	display:flex;
	flex-wrap: wrap;
	gap: 0 5rem;
	padding: 1.5rem 0 1.7rem 2.5rem;
	background-color: #EBEBE5;
}
#main .snsList a {
	display: flex;
	align-items: center;
	font-size: 1.2rem;
	letter-spacing: 0.1em;
}
#main .snsList a:hover {
	opacity: 0.7;
}
#main .snsList a img {
	width: 3.5rem;
	margin: 0 0 -0.2rem;
	flex-shrink: 0;
}
#main .snsList .subSpan {
	min-width: 9.6rem;
}
#main .snsList .item .subSpan {
	min-width: 8.5rem;
}
#main .mailForm {
	margin-right: -2.4rem;
	position: relative;
}
#main .mailForm::before {
	width: 1px;  
	background-color: #8C7669;
	position: absolute;  
	top: 0;
	bottom: 0;
	left: -0.6rem;
	content: ""; 
}
#main .mailForm h3 {
	padding: 0.7rem 2.3rem 0.8rem;
	font-size: 1.4rem;
	font-weight: 400;
	letter-spacing: 0.1em;
	color: #fff;
	background-color: #322317;
}
#main .mailForm .inner {
	padding: 2.1rem 2.3rem 4.2rem;
	background-color: #EBEBE5;
}
#main .contactDl {
	margin-bottom: 1.7rem;
}
#main .contactDl dt {
	font-size: 1.2rem;
	letter-spacing: 0.1em;
	margin-bottom: 0.3rem;
}
textarea,
input[type="email"],
input[type="tel"],
input[type="text"] {
    appearance:none;
    -moz-appearance:none;
    -webkit-appearance:none;
    border-radius: 0.5rem;
    height: 4.4rem;
	color: #322317;
    border: 1px solid #CCCCCC;
    box-sizing: border-box;
    font-size: 1.4rem;
    padding: 0 1.8rem;
    width: 100%;
    letter-spacing: 0.1em;
    background-color: #fff;
}
textarea {
	height: 17.5rem;
	padding-block: 1rem;
	resize: vertical;
}
input::-webkit-input-placeholder { /* WebKit browsers */
	color: #ccc;
	opacity:1;
}
input:-moz-placeholder { /* Mozilla Firefox 4 to 18 */
	color: #ccc;
	opacity:1;
}
input::-moz-placeholder {
	color: #ccc;
	opacity:1;
}
input:-ms-input-placeholder { /* Internet Explorer 10+ */
	color: #ccc;
	opacity:1;
}
textarea::-webkit-input-placeholder { /* WebKit browsers */
	color: #ccc;
	opacity:1;
}
textarea:-moz-placeholder { /* Mozilla Firefox 4 to 18 */
	color: #ccc;
	opacity:1;
}
textarea::-moz-placeholder {
	color: #ccc;
	opacity:1;
}
textarea:-ms-input-placeholder { /* Internet Explorer 10+ */
	color: #ccc;
	opacity:1;
}
#main .contactDl dd {
	margin-bottom: 2.3rem;
}
#main .contactDl dd:last-child {
	margin-bottom: 0;
}
.submit li {
	margin-bottom: 2rem;
}
.submit li:last-child {
	margin-bottom: 0;
}
.submit li input {
    appearance:none;
    -moz-appearance:none;
    -webkit-appearance:none;
    width: 100%;
	height: auto;
    border-radius: 0;
    text-align: center;
    cursor: pointer;
    font-size: 1.4rem;
    font-weight: 400;
    color: #322317;
	transition: 0.3s;
	border: none;
	letter-spacing: 0.1em;
	background: none;
	padding: 0.5rem 0.5rem 0.6rem;
	border-bottom: 1px solid #322317;
}
#main .errorMsg {
	margin-bottom: 3rem;
	color: #ff0000;
}
#main .contact .text {
	margin-bottom: 2rem;
}
#thanks p {
	margin-bottom: 2rem;
	text-align: center;
}
#thanks p:last-child {
	margin-bottom: 0;
}

@media all and (min-width: 897px) {
	#main .gallery .iconBox > div:hover,
	.submit li input:hover {
		opacity: 0.7;
	}
	#thanks p a:hover {
		text-decoration: underline;
	}
}

@media all and (max-width: 896px) {
}