@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
.pageTop {
	display: none;
}
.mainVisual {
	margin-bottom: 80px;
	position: relative;
}
.mainVisual .fooUl li {
	height: 100%;
}
.mainVisual .fooUl .slick-slide > div {
	height: 640px;
	overflow: hidden;
}
.mainVisual .fooUl .active {
	animation: imgzoom 18s linear forwards;
}
@keyframes imgzoom {
    0% {
        -webkit-transform: scale(1);
        transform: scale(1);
    }
    100% {
        -webkit-transform: scale(1.2);
        transform: scale(1.2);
    }
}
.mainVisual .fooUl li img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.mainVisual .scroll {
	position: absolute;
	bottom: 86px;
	right: 80px;
}
.mainVisual .scroll a {
	padding-right: 19px;
	position: relative;
	display: block;
	color: #FFF;
	font-size: 1.2rem;
	font-weight: 500;
	letter-spacing: 0.1em;
	font-family: 'Inter', sans-serif;
	-webkit-writing-mode : tb-rl;
	-webkit-writing-mode: vertical-rl;
	writing-mode: tb-rl;
	writing-mode: vertical-rl;
}
.mainVisual .scroll a::before {
	position: absolute;
	right: 0;
	bottom: -61px;
	width: 11px;
	height: 36px;
	background: url(../img/common/icon02.png) no-repeat left top / 100%;
	content: '';
}
.mainVisual .scroll a::after {
	position: absolute;
	right: 5px;
	top: 0;
	width: 1px;
	height: 120px;
	background-color: #FFF;
	content: '';
	animation: pathmove 3s ease-in-out infinite;
}
@keyframes pathmove{
	0% {
		clip-path: inset(0 0 100% 0);
		background-color: rgba(255, 255, 255, 1);
	}
	90%{
		background-color: rgba(255, 255, 255, 1);
	}
	100%{
		clip-path: inset(0 0 0 0);
		background-color: rgba(255, 255, 255, 0);
	}
}
.mainVisual .scroll a:hover {
	opacity: 0.7;
}
#main .sec01 {
	margin: 0 auto 110px;
	padding: 0 20px;
	box-sizing: border-box;
	max-width: 1102px;
}
#main .sec01 .content {
	width: 981px;
}
#main .sec01 .imgBox {
	margin: 0 0 80px;
}
#main .sec01 .imgBox:last-child {
	margin-bottom: 0;
}
#main .sec01 .imgBox .photoBox {
	width: 410px;
}
#main .sec01 .imgBox .textBox {
	margin: 44px 115px 0 0;
	order: 1;
	width: 362px;
}
#main .sec01 .imgBox .textBox h2 {
	margin-bottom: 44px;
	width: 304px;
}
#main .sec01 .imgBox .textBox p {
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.025em;
}
#main .sec01 .imgBox.imgBox01 .photoBox {
	margin-right: 0;
	width: 473px;
	order: 2;
}
#main .sec01 .imgBox.imgBox01 .textBox {
	margin: 13px 0 0 10px;
	width: 455px;
}
#main .sec01 .imgBox.imgBox01 .textBox h2 {
	margin-bottom: 50px;
}
#main .sec02 {
	margin: 0 auto;
	max-width: 1010px;
	box-sizing: border-box;
	padding: 62px 20px 60px;
}
#main .sec02 h2 {
	margin: 0 auto 58px;
	width: 147px;
}
#main .sec02 .linkUl {
	margin: -20px 0 60px;
}
#main .sec02 .linkUl li {
	margin-top: 20px;
	width: 390px;
}
#main .sec02 .linkUl li a {
	display: block;
	height: 100%;
	background-color: #FFF;
}
@media all and (min-width: 901px) {
	#main .sec02 .linkUl li a:hover .ttlBox::before {
		display: none;
	}
	#main .sec02 .linkUl li.li01 a:hover .ttlBox .btn {
		background-image: url(../img/index/btn02_on.png);
	}
}
#main .sec02 .linkUl li .ttlBox {
	padding: 109px 20px 20px;
	width: 390px;
	height: 295px;
	position: relative;
	box-sizing: border-box;
	background: url(../img/index/photo03.jpg) no-repeat center center / cover;
}
#main .sec02 .linkUl li .ttlBox::before {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	mix-blend-mode: multiply; 
	background-color: rgba(75, 37, 21, 0.5);
	content: '';
	transition: all 0.3s;
}
#main .sec02 .linkUl li.li01 .ttlBox {
	background-image: url(../img/index/photo04.jpg);
}
#main .sec02 .linkUl li .ttlBox .ttl {
	margin-bottom: 20px;
	text-align: center;
	position: relative;
}
#main .sec02 .linkUl li .ttlBox .ttl img {
	height: 22px;
}
#main .sec02 .linkUl li .ttlBox .btn {
	margin: 0 auto;
	width: 220px;
	height: 50px;
	position: relative;
	transition: all 0.3s;
	background: url(../img/index/btn02.png) no-repeat left top / 220px;
}
#main .sec02 .linkUl li.li02 .ttlBox .btn {
	background-image: url(../img/index/btn01.png);
}
#main .sec02 .linkUl li .txtBox {
	padding: 13px 13px 10px 15px;
	background-color: #FFF;
}
#main .sec02 .linkUl li .txtBox p {
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.025em;
}
#main .sec03 {
	margin: 0 auto;
	max-width: 1010px;
	box-sizing: border-box;
	padding: 82px 20px 80px;
}
#main .sec03 h2 {
	margin: 0 auto 70px;
	width: 117px;
}
#main .sec03 .inner {
	margin-bottom: 100px;
}
#main .sec03 .inner .lBox {
	margin-top: 7px;
	width: 420px;
}
#main .sec03 .inner .rBox {
	width: 366px;
}
#main .sec03 .map {
	margin-bottom: 85px;
}
#main .sec03 .map iframe {
	width: 100%;
	height: 289px;
}
#main .sec04 {
	margin: 0 auto;
	max-width: 978px;
	box-sizing: border-box;
	padding: 112px 20px 80px;
}
#main .sec04 h2 {
	margin: 0 auto 113px;
	width: 177px;
}
#main .sec04 .content {
	width: 784px;
}
#main .sec04 .tableBox table {
	width: 100%;
	border-collapse: collapse;
}
#main .sec04 .tableBox th,
#main .sec04 .tableBox td {
	display: block;
	width: 100%;
}
#main .sec04 .tableBox th {
	margin-bottom: 16px;
	color: #4B2515;
	font-weight: 700;
	letter-spacing: 0.1em;
}
#main .sec04 .tableBox th .mark {
	margin-right: 10px;
	padding: 3px 2px 2px;
	display: inline-block;
	width: 43px;
	color: #FFF;
	font-size: 1.5rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	line-height: 1.2;
	text-align: center;
	box-sizing: border-box;
	background-color: #CB3B39;
}
#main .sec04 .tableBox th .mark.any {
	background-color: #707070;
}
#main .sec04 .tableBox th .sml {
	color: #000;
	font-size: 1.2rem;
	font-weight: 500;
	letter-spacing: 0.05em;
}
#main .sec04 .tableBox td {
	margin-bottom: 38px;
}
#main .sec04 .tableBox textarea,
#main .sec04 .tableBox input[type="tel"],
#main .sec04 .tableBox input[type="text"],
#main .sec04 .tableBox input[type="email"] {
	appearance:none;
    -moz-appearance:none;
    -webkit-appearance:none;
    border-radius: 2px;
    height: 50px;
    border: 1px solid #BFBFBF;
    box-sizing: border-box;
	color: #000;
    font-size: 1.6rem;
	font-weight: 500;
    padding: 0 18px;
    width: 100%;
    background-color: #FFF;
}
#main .sec04 .tableBox textarea {
	padding: 18px;
	height: 183px;
	resize: vertical;
}
input::-webkit-input-placeholder,
textarea::-webkit-input-placeholder { /* WebKit browsers */
	color: #C6C6C6;
	opacity:1;
}
input:-moz-placeholder,
textarea:-moz-placeholder { /* Mozilla Firefox 4 to 18 */
	color: #C6C6C6;
	opacity:1;
}
input::-moz-placeholder,
textarea::-moz-placeholder {
	color: #C6C6C6;
	opacity:1;
}
input:-ms-input-placeholder,
textarea:-ms-input-placeholder { /* Internet Explorer 10+ */
	color: #C6C6C6;
	opacity:1;
}
#main .sec04 .tableBox .error {
	color: #000;
	background-color: #FFEFEF !important;
}
#main .sec04 .tableBox input:-webkit-autofill {
    -webkit-box-shadow: 0 0 0px 1000px #fff inset !important;
}
#main .sec04 .tableBox .errorTxt {
	margin: 17px 0 -4px;
	display: block;
	color: #E20D0D;
	font-size: 1.2rem;
	font-weight: 500;
}
#main .sec04 .tableBox .zip {
	width: 140px !important;
}
#main .sec04 .tableBox .sub .lTxt {
	margin-right: 24px;
}
#main .sec04 .tableBox input[type="button"] {
	appearance:none;
    -moz-appearance:none;
    -webkit-appearance:none;
	padding: 0 5px;
	color: #000;
	font-size: 1.2rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	width: 171px;
	height: 30px;
	cursor: pointer;
	border: none;
	box-sizing: border-box;
	background-color: #EDEDED;
}
@media all and (min-width: 901px) {
	#main .sec04 .tableBox input[type="button"]:hover {
		opacity: 0.7;
	}
}
#main .sec04 .tableBox .chooseUl li {
	margin-bottom: 15px;
}
#main .sec04 .tableBox .chooseUl li:last-child {
	margin-bottom: 0;
}
#main .sec04 .tableBox input[type="radio"] {
	display: none;
}
#main .sec04 .tableBox input[type="radio"] ~ span {
	padding: 8px 0 8px 39px;
	cursor: pointer;
	background: url(../img/common/icon03.png) no-repeat left center / 30px;
}
#main .sec04 .tableBox input[type="radio"]:checked ~ span {
	background-image: url(../img/common/icon03_on.png);
}
#main .sec04 .tableBox .scrollBox {
	margin-bottom: 43px;
	padding: 16px 37px;
	height: 240px;
	box-sizing: border-box;
	border: 1px solid #bfbfbf;
}
#main .sec04 .tableBox .scrollBox p {
	margin-bottom: 40px;
	color: #402F1D;
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.78;
	letter-spacing: 0.025em;
}
#main .sec04 .tableBox .scrollBox p:last-child {
	margin-bottom: 0;
}
#main .sec04 .tableBox .scrollBox p a {
	color: #402F1D;
}
#main .sec04 .tableBox .scrollBox .txt01 a {
	text-decoration: underline;
}
@media all and (min-width: 901px) {
	#main .sec04 .tableBox .scrollBox p a:hover {
		text-decoration: none;
	}
}
#main .sec04 .tableBox .simplebar-track.simplebar-vertical {
	width: 14px;
	background-color: #EAEAEA;
}
#main .sec04 .tableBox .simplebar-track.simplebar-vertical::before {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background-color: #C7C7C7;
	content: '';
}
#main .sec04 .tableBox .simplebar-scrollbar {
	left: 2px;
	right: 2px;
}
#main .sec04 .tableBox .simplebar-scrollbar:before {
	border-radius: 4px;
	background-color: #8E8E8E;
}
#main .sec04 .tableBox .simplebar-scrollbar.simplebar-visible:before {
	opacity: 1;
}
#main .sec04 .tableBox .simplebar-track.simplebar-vertical .simplebar-scrollbar:before {
	top: 7px;
	bottom: 3px;
}
#main .sec04 .tableBox .agree {
	margin-bottom: 83px;
	text-align: center;
}
#main .sec04 .tableBox input[type="checkbox"] {
	display: none;
}
#main .sec04 .tableBox input[type="checkbox"] ~ span {
	padding: 8px 0 8px 39px;
	color: #4B2515;
	font-weight: 700;
	letter-spacing: 0.05em;
	cursor: pointer;
	background: url(../img/common/icon04.png) no-repeat left center / 30px;
}
#main .sec04 .tableBox input[type="checkbox"]:checked ~ span {
	background-image: url(../img/common/icon04_on.png);
}
#main .sec04 .tableBox .submit li {
	margin: 0 auto 20px;
	padding: 0 20px;
	width: 604px;
	height: 80px;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	position: relative;
	border-radius: 10px;
	text-align: center;
	cursor: pointer;
	border: 1px solid #4B2515;
	background: #FFF;
	transition: all 0.3s;
	box-sizing: border-box;
}
#main .sec04 .tableBox .submit li:last-child {
	margin-bottom: 0;
}
#main .sec04 .tableBox .submit li input[type="submit"] {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 10;
	opacity: 0;
	cursor: pointer;
}
#main .sec04 .tableBox .submit li input[type="submit"]:disabled {
	cursor: not-allowed;
}
#main .sec04 .tableBox .submit li .txt {
	padding: 0 45px;
	position: relative;
	display: inline-block;
	color: #4B2515;
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: 0.1em;
}
#main .sec04 .tableBox .submit li .txt::before,
#main .sec04 .tableBox .submit li .txt::after {
	display: none;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	left: 0;
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background-color: #FFF;
	content: '';
	transition: all 0.3s;
}
#main .sec04 .tableBox .submit li .txt::after {
	left: inherit;
	right: 0;
}
@media all and (min-width: 901px) {
	#main .sec04 .tableBox .submit li:not(.notallow):hover {	
		background-color: #4B2515;
	}
	#main .sec04 .tableBox .submit li:not(.notallow):hover .txt {
		color: #FFF;
	}
	#main .sec04 .tableBox .submit li:not(.notallow):hover .txt::before,
	#main .sec04 .tableBox .submit li:not(.notallow):hover .txt::after {
		display: block;
	}
}
@media all and (max-width: 900px) {
	.mainVisual {
		margin-bottom: 41px;
		padding-left: 0;
	}
	.mainVisual .fooUl .slick-slide > div {
		height: 400px;
		overflow: hidden;
	}
	.mainVisual .fooUl .slick-slide > div img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	.mainVisual .scroll {
		bottom: 62px;
		right: inherit;
		left: 18px;
	}
	.mainVisual .scroll a {
		padding-right: 18px;
	}
	.mainVisual .scroll a::before {
		right: 0;
		bottom: -35px;
	}
	.mainVisual .scroll a::after {
		right: 5px;
		height: 100px;
	}
	#main .sec01 {
		margin: 0 0 49px;
		padding: 0;
	}
	#main .sec01 .imgBox {
		margin: 0 0 56px;
		display: block;
	}
	#main .sec01 .imgBox .photoBox {
		margin: 0 -31px;
		width: auto !important;
	}
	#main .sec01 .imgBox .photoBox img {
		width: 100% !important;
	}
	#main .sec01 .imgBox .textBox {
		margin: 0 0 35px;
		width: auto !important;
	}
	#main .sec01 .imgBox .textBox h2 {
		margin-bottom: 38px;
		width: auto;
		max-width: 261px;
	}
	#main .sec01 .imgBox .textBox p {
		line-height: 1.5;
		letter-spacing: 0.08em;
	}
	#main .sec01 .imgBox.imgBox01 .photoBox {
		margin: 0 38px;
	}
	#main .sec01 .imgBox.imgBox01 .textBox {
		margin: 0 0 58px;
	}
	#main .sec01 .imgBox.imgBox01 .textBox h2 {
		margin-bottom: 33px;
		max-width: 257px;
	}
	#main .sec02 {
		padding: 44px 0 45px;
	}
	#main .sec02 h2 {
		margin: 0 auto 49px;
		width: auto;
		max-width: 126px;
	}
	#main .sec02 .linkUl {
		margin: 0 0 39px;
		display: block;
	}
	#main .sec02 .linkUl li {
		margin: 0 0 40px;
		width: auto;
	}
	#main .sec02 .linkUl li:last-child {
		margin-bottom: 0;
	}
	#main .sec02 .linkUl li .ttlBox {
		padding: 29% 20px 20.8%;
		width: auto;
		height: inherit;
		position: relative;
		box-sizing: border-box;
		background: url(../img/index/photo03_sp.jpg) no-repeat center center / cover;
	}
	#main .sec02 .linkUl li .ttlBox::before {
		display: none;
	}
	#main .sec02 .linkUl li.li01 .ttlBox {
		background-image: url(../img/index/photo04_sp.jpg);
	}
	#main .sec02 .linkUl li .ttlBox .ttl {
		margin: 0 auto 2%;
		width: 43.9%;
	}
	#main .sec02 .linkUl li.li02 .ttlBox .ttl {
		width: 56.7%;
	}
	#main .sec02 .linkUl li .ttlBox .ttl img {
		width: 100%;
		height: inherit;
	}
	#main .sec02 .linkUl li .ttlBox .btn {
		width: 55%;
		background: none !important;
	}
	#main .sec02 .linkUl li.li02 .ttlBox .btn {
		width: 48%;
	}
	#main .sec02 .linkUl li .ttlBox .btn img {
		width: 100%;
	}
	#main .sec02 .linkUl li .txtBox {
		padding: 16px 25px;
	}
	#main .sec02 .linkUl li .txtBox p {
		line-height: 1.5;
		letter-spacing: 0.08em;
	}
	#main .sec03 {
		padding: 40px 0 68px;
	}
	#main .sec03 h2 {
		margin: 0 auto 46px;
		width: auto;
		max-width: 100px;
	}
	#main .sec03 .inner {
		margin-bottom: 60px;
		display: block;
	}
	#main .sec03 .inner .lBox {
		margin: 0 0 35px;
		width: auto;
	}
	#main .sec03 .inner .rBox {
		width: auto;
	}
	#main .sec03 .inner .rBox img {
		width: 100%;
	}
	#main .sec03 .map {
		margin-bottom: 42px;
		padding-bottom: 54.3%;
		position: relative;
	}
	#main .sec03 .map iframe {
		position: absolute;
		top: 0;
		left: 0;
		height: 100%;
	}
	#main .sec04 {
		padding: 44px 0 50px;
	}
	#main .sec04 h2 {
		margin: 0 auto 41px;
		width: auto;
		max-width: 152px;
	}
	#main .sec04 .tableBox th {
		margin-bottom: 6px;
	}
	#main .sec04 .tableBox th .mark {
		padding: 2px 2px 2px;
		width: 36px;
		font-size: 1.4rem;
	}
	#main .sec04 .tableBox th .mark.any {
		padding: 3px 2px 2px;
	}
	#main .sec04 .tableBox th .sml {
		margin-left: 3px;
	}
	#main .sec04 .tableBox td {
		margin-bottom: 28px;
	}
	#main .sec04 .tableBox textarea,
	#main .sec04 .tableBox input[type="tel"],
	#main .sec04 .tableBox input[type="text"],
	#main .sec04 .tableBox input[type="email"] {
		height: 44px;
		padding: 0 9px;
	}
	#main .sec04 .tableBox textarea {
		padding: 9px;
		height: 220px;
	}
	#main .sec04 .tableBox .zip {
		width: 82px !important;
	}
	#main .sec04 .tableBox input[type="button"] {
		padding: 0 2px;
		font-size: 1.4rem;
		width: calc(100% - 106px);
		max-width: 320px;
		height: 37px;
	}
	#main .sec04 .tableBox .chooseUl {
		margin: 12px 0 0;
	}
	#main .sec04 .tableBox .chooseUl li {
		margin-bottom: 22px;
	}
	#main .sec04 .tableBox input[type="radio"] ~ span {
		padding: 9px 0 9px 45px;
		font-weight: 500;
		background-size: 34px;
	}
	#main .sec04 .tableBox .scrollBox {
		margin-bottom: 30px;
		padding: 19px 12px;
		height: 203px;
	}
	#main .sec04 .tableBox .scrollBox p {
		margin-bottom: 40px;
		color: #402F1D;
		font-size: 1.6rem;
		line-height: 1.5;
	}
	#main .sec04 .tableBox .scrollBox p a {
		color: #402F1D;
	}
	#main .sec04 .tableBox .simplebar-track.simplebar-vertical {
		width: 11px;
	}
	#main .sec04 .tableBox .simplebar-track.simplebar-vertical::before {
		height: 3px;
	}
	#main .sec04 .tableBox .simplebar-scrollbar {
		left: 1px;
		right: 1px;
	}
	#main .sec04 .tableBox .simplebar-track.simplebar-vertical .simplebar-scrollbar:before {
		top: 6px;
	}
	#main .sec04 .tableBox .agree {
		margin-bottom: 42px;
	}
	#main .sec04 .tableBox input[type="checkbox"] ~ span {
		padding: 8px 0 8px 37px;
		font-size: 1.4rem;
		background-size: 27px;
	}
	#main .sec04 .tableBox input[type="checkbox"]:checked ~ span {
		background-image: url(../img/common/icon04_on_sp.png);
	}
	#main .sec04 .tableBox .submit li {
		margin: 0 auto 20px;
		padding: 0 18px;
		width: auto;
		max-width: 313px;
		height: 60px;
		background-color: #4B2515;
	}
	#main .sec04 .tableBox .submit li .txt {
		padding: 0 20px;
		color: #FFF;
		font-size: 1.6rem;
		display: block;
		width: 100%;
	}
	#main .sec04 .tableBox .submit li .txt::before,
	#main .sec04 .tableBox .submit li .txt::after {
		display: block;
	}
}
@media all and (max-width: 374px) {
	#main .sec04 .tableBox .submit li .txt {
		font-size: 3.8vw;
	}
}
@media all and (max-width: 359px) {
	#main .sec04 .tableBox th .sml {
		margin-left: 0;
		font-size: 2.8vw;
	}
	#main .sec04 .tableBox input[type="button"] {
		font-size: 1.1rem;
	}
	#main .sec04 .tableBox input[type="radio"] ~ span {
		font-size: 1.4rem;
	}
}