html {
		font-size: 62.5%;
}
body {
		color: #292929;
		font-family: "Cinzel", serif;
		/*font-family: "Noto Sans JP", sans-serif;*/
		font-size: 1.6rem;
		font-weight: 400;
		line-height: 1.6;
}
figure, picture {
		max-width: 100%;
		width: 100%;
		line-height: 0;
		display: inline-block;
}
img {
		max-width: 100%;
		width: 100%;
		height: auto;
		vertical-align: middle;
}
p{
		font-size: 1.6rem;
		line-height: 2;
}
a {
		color: #000000;
		display: block;
		text-decoration: unset;
		transition: all 0.4s ease-in-out;
}
a:active, a:focus, a:focus-visible, a:focus-within, a:visited, a:target {
		color: #000000;
}
.screen-reader-text:focus {
		color: #000000;
}
.br_pc {
		display: block;
}
.br_sp {
		display: none;
}
.only_sp {
		display: none;
}
select {
		-webkit-appearance: none;
		appearance: none;
}
.inner {
		max-width: 1200px;
		width: 100%;
		margin: 0 auto;
}
.center {
		text-align: center;
}
.flex {
		display: flex;
}
/* fonts ---------------------------------------*/
.abril {
		font-family: "Abril Fatface", serif;
		font-style: normal;
}
.cinzel {
		font-family: "Cinzel", serif;
}
.zen-old-mincho {
		font-family: "Zen Old Mincho", serif;
}
.noto-sans-jp {
		font-family: "Noto Sans JP", sans-serif;
}

/* common --------------------------------------*/
#wrapper {
		display: flex;
		flex-direction: column;
		justify-content: space-between;
		min-height: 100vh;
}
#content {
		margin-top: 65px;
}
.section{
		padding: 15rem 0;
}
.entry-content{
		padding: 0;
}
h2.section-title{
		font-family: "Cinzel", serif;
		font-size: clamp(2.8rem, 3vw, 3.5rem);
		line-height: 1.4;
}
.section-title span {
		color: #716346;
		display: block;
		font-size: 0.5em;
}
.panel-layout {
		display: flex;
		flex-direction: column;
}
.section-title-sub{
		position: relative;
		z-index: 5;
}

/* main-visual --------------------------------*/
.fadeIn_Mv {
		animation-name: fadeIn;
		animation-duration: 4s;
		animation-fill-mode: forwards;
		opacity: 0;
}
.fadeIn_MvBg::after {
		animation-name: fadeIn;
		animation-duration: 3s;
		animation-fill-mode: forwards;
		opacity: 0;
}
@keyframes fadeIn {
		from {
				opacity: 0;
		}
		to {
				opacity: 1;
		}
}
.mv_txt figure{
		position: relative;
		width: 100%;
		height: 100%;
}
.mv_txt p {
		color: #fff;
		position: absolute;
		top: 35vw;
		left: 5vw;
		z-index: 1;
		animation-name: fadeIn_2;
		animation-duration: 8s;
		animation-fill-mode: forwards;
		opacity: 0;
}
@keyframes fadeIn_2 {
		from {
				opacity: 0;
		}
		to {
				opacity: 1;
		}
}
/* Sub main-visual ----------------------------*/
.subpage-head-content h1 {
		font-size: 3rem;
		font-weight: 600;
}
.breadcrumb {
		font-size: 0.75em;
		margin-top: 0.5rem;
}
.breadcrumb a{
		display: inline-block;
}
.subpage-head-content .breadcrumb, .breadcrumb .home {
		color: #a5a5a5;
}
.subpage-header {
		display: flex;
		align-items: center;
		position: relative;
		height: 215px;
		background-color: #fff;
		border-bottom: 1px solid #ddd;
		box-sizing: border-box;
}
/* Top ----------------------------------------*/
/* section1 ------------*/
#section1{
}
#section1-inner {
		position: relative;
}
#section1-inner .inner-content{
		max-width: 760px;
		margin: 0 auto;
		background-color: rgba(255,255,255,0.9);
		z-index: 5;
		position: relative;
		padding: 5rem;
}
#section1-inner .inner-content p {
		margin-top: 2rem;
}
/* 背景のスライド --*/
.scroll-banner {
		overflow: hidden;
		position: absolute;
		top: 50%;
		left: 0;
		width: 100%;
		transform: translateY(-50%);
		opacity: 0.2;
		-webkit-transform: translateY(-50%) translateZ(0);
		will-change: transform;
		backface-visibility: hidden;
}
.scroll-track {
		display: flex;
		width: max-content;
		animation: scroll 45s linear infinite;
		will-change: transform;
		transform: translate3d(0, 0, 0); /* GPU処理を強制 */
		backface-visibility: hidden;
}
.scroll-track img {
		flex-shrink: 0;
		height: 450px;
		width: auto;
		object-fit: cover;
		-webkit-transform: translateZ(0); /* Safariで滑らかに */
}
@keyframes scroll {
		from {
				transform: translateX(0);
		}
		to {
				transform: translateX(-50%);
		}
}
@media screen and (max-width: 480px) {
		.scroll-track {
				animation: scroll 30s linear infinite;
		}
		.scroll-track img {
				height: 500px;
		}
}



/* section2 ------------*/
#section2{
}
#section2-inner{
		max-width: 1200px;
		width: 100%;
		margin: 0 auto;
		padding: 0 2rem;
}
#section2-inner .lineup.flex {
		margin-top: 5rem;
		flex-wrap: wrap;
		gap: 10rem;
}
#section2-inner .lineup-box.flex {
		width: 100%;		
		/*		width: calc((100% - 1rem) / 2);*/
		align-items: flex-start;
		justify-content: space-between;
		padding: 5rem 2rem 5rem 0;
		position: relative;
}
#section2-inner .lineup-box.flex > div {
		width: calc(100% - 350px);
}
#section2-inner h3 {
		font-size: 1.8rem;
		font-weight: 600;
		z-index: 5;
		margin-bottom: 1rem;
		position: relative;
}
#section2-inner .section-title-sub span {
		font-family: "Abril Fatface", serif;
		font-size: 4.5vw;
		line-height: 1;
		color: #f7f7f7;
		position: absolute;
		bottom: 0;
		left: 0;
		z-index: -1;
}
#section2-inner .lineup-box p {
		line-height: 1.6;
}
#section2-inner .lineup-box.flex figure {
		position: absolute;
		width: 350px;
		right: 0;
		top: 50%;
		transform: translateY(-50%);
		height: 100%;
		overflow: hidden;
}
#section2-inner .lineup-box.flex figure img {
		height: 100%;
		object-fit: cover;
}


/* section3 ------------*/
#section3{
}
#section3-inner{
		max-width: 1200px;
		width: 100%;
		margin: 0 auto;
		padding: 0 2rem;
}
#section3-inner h2{
		text-align: center;
}

/* 会社概要 テーブル --*/
.company-table {
		margin: 5rem auto;
		max-width: 640px;
		table-layout: fixed;
}
.company-table .column-1 {
		width: 30%;
}
.company-table .column-2 {
		width: 70%;
}
.company-table td {
		padding: 2rem 0.5rem;
}
/* section4 ------------*/
#section4{
}
#section4-inner{
		max-width: 1200px;
		width: 100%;
		margin: 0 auto;
		padding: 0 2rem;
}
#section4-inner h2{
		text-align: center;
}

/* フォーム --*/
.form-area {
		margin: 5rem auto;
		max-width: 640px;
}

/* Contact ------------------------------------*/
.form-area label {
		font-size: 1.8rem;
		font-weight: 500;
		align-items: center;
}
.form-area .contact-note {
		font-size: 0.9em;
		line-height: 1.4;
		color: #777;
		display: block;
}
.required, .arbitrary {
		display: inline-block;
		padding: 0.5rem 2rem;
		border-radius: 30px;
		font-size: 0.7em;
		line-height: 1.6;
		color: #fff;
		margin-left: 1rem;
}
.required {
		background-color: #806738;
}
.arbitrary {
		background-color: #A5A5A5;
}
.form-item {
		margin: 4rem 0;
}
.form-item br {
		display: none;
}
.wpcf7-list-item {
		margin: 0 2.2em 0 0;
}
.wpcf7-list-item label {
		font-weight: 400;
		font-size: 2rem;
}
.wpcf7-checkbox span{
		font-size: 1.7rem;
}
.text-in input, .form-item.text-in textarea, .wpcf7-form-control.wpcf7-select {
		font-family: "Cinzel", serif;
		font-size: 1.6rem;
		width: 100%;
		box-sizing: border-box;
		padding: 1.5rem 1rem;
		margin-top: 1rem;
		border: 1px solid #A5A5A5;
		background-color: #F5F5F5;
}
.wpcf7-form-control.wpcf7-select {
		max-width: 60%;
		font-size: 1.6rem;
}
.form-item.text-in input::placeholder, .form-item.text-in textarea::placeholder {
		font-family: "Cinzel", serif;
		color: #acacac;
		font-size: 0.95em;
		font-weight: 600;
		opacity: unset;
}
.form-submit-area {
		max-width: 80%;
		margin: 0 auto;
}
.form-submit-area .submit-btn {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
}
.form-submit-area .submit-btn span {
		margin: 2rem auto;
}
.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output, .wpcf7 form.payment-required .wpcf7-response-output {
		text-align: center;
		max-width: 80%;
		margin: 0 auto;
		padding: 1.5rem;
}
.wpcf7-form-control.wpcf7-submit.has-spinner {
		color: #fff;
		font-family: "Cinzel", serif;
		font-size: 1.8rem;
		font-weight: 600;
		text-align: center;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		background-color: #cc7581;
		box-shadow: unset;
		border: unset;
		border-radius: 100px;
		width: 350px;
		box-sizing: border-box;
		padding: 1.5rem 0;
		margin: 3rem auto 0;
}
.type-selects {
		color: #292929 !important;
}
.form-area .select_wrapper {
		max-width: 60%;
		position: relative;
		margin: 0;
}
.form-area .select_wrapper::after {
		content: "";
		position: absolute;
		top: 50%;
		right: 5%;
		width: 0.8rem;
		height: 0.8rem;
		border-right: 2px solid #292929;
		border-bottom: 2px solid #292929;
		box-sizing: border-box;
		transform: rotate(45deg) translate(-50%, 0);
}
.select_wrapper .wpcf7-form-control.wpcf7-select{
		max-width: 100%;
}
/* footer -------------------------------------*/
#footer {
		background-color: #292929;
		color: #fff;
}
#copyright {
		text-align: center;
		border-top: 1px solid #fff;
		padding: 0.5rem 0;
}
#copyright p {
		font-size: 1.2rem;
}
/*Media Query ---------------------------------*/
@media screen and (max-width: 1240px) {
		.inner {
				max-width: 92%;
		}
}
@media screen and (max-width: 768px) {
		.only_sp {
				display: block;
		}
		#content {
				margin-top: 55px;
		}
		.section {
				padding: 3.5rem 0;
				margin: 0 auto;
		}
		/* Contact -------------*/
		.form-area {
				max-width: 100%;
				padding: 1rem 0;
		}
}
@media screen and (max-width: 640px) {
		#section2-inner .lineup-box.flex {
				flex-direction: column-reverse;
				gap: 2rem;
				padding: 0;
		}
		#section2-inner .lineup-box.flex > div {
				width: 100%;
		}
		#section2-inner .lineup-box.flex figure {
				position: unset;
				transform: unset;
				width: 100%;
		}
		.form-area label {
				font-size: 1.6rem;
		}
}
@media screen and (max-width: 480px) {
		.br_pc {
				display: none;
		}
		.br_sp {
				display: block !important;
		}
		/* Contact -------------*/
		.wpcf7-checkbox span {
				font-size: 1.6rem;
		}
		.form-area .select_wrapper{
				max-width: 90%;
		}
		.wpcf7-form-control.wpcf7-submit.has-spinner{
				width: 85%;
		}
		.form-submit-area {
				max-width: 100%;
		}
		.form-submit-area p {
				font-size: 1.5rem;
				text-align: left !important;
		}
}