/*
Theme Name: keig
Theme URl: https://sub-06.hokuto-web-development.com/wp-content/themes/keig/
Author: arakawahokuto
Description: arakawahokuto Original Theme
License: GNU General Public License v2 or later
License URl: http://www.gnu.org/licenses/gpl-2.0.html
Version: 1.0
*/

*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	font-size: 62.5%;
}

body {
	font-size: min(1.25vw, 1.8rem);
	font-family: "Noto Sans JP", sans-serif;
	line-height: 1.5;
	color: #333;
	font-weight: 400;
}

@media screen and (max-width: 767px) {
	body {
		font-size: min(4.27vw, 1.6rem);
	}
}

body.is-fixed {
	position: fixed;
	width: 100%;
}

img {
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}

a {
	text-decoration: none;
	transition: all 0.5s;
}

a:hover {
	opacity: 0.7;
}

@media screen and (max-width: 767px) {
	.u-pc {
		display: none !important;
	}
}

@media screen and (min-width: 768px) {
	.u-sp {
		display: none !important;
	}
}

.u-align-center {
	text-align: center !important;
}

.u-robot {
	font-family: 'Roboto', sans-serif;
}

/* content */
.l-main {
	width: 100%;
}

.l-content {
	width: 100%;
}

.l-content__inner {
	max-width: 1440px;
	margin: 0 auto;
}

.l-content__body {
	position: relative;
}

.l-content__bg {
	width: 100%;
	position: relative;
	overflow: hidden;
}

.l-content__bg--01 {
	background: #F4F5F7;
}

.l-content__bg--02 {
	background: #F4F5F7;
}

@media screen and (max-width: 767px) {
	.l-content__bg--02 {
		background: #FFF;
	}
}

.l-content__bg-item {
	margin-right: 20.83vw;
}

@media screen and (max-width: 767px) {
	.l-content__bg-item {
		margin-right: 0;
	}
}

.l-content__bg-inner {
	margin: 0 auto;
}

@media screen and (max-width: 767px) {
	.l-content__bg-inner {
		padding: 0 16px;
	}
}

.l-content__bg-inner--01 {
	max-width: 1120px;
	padding: min(9.72vw, 140px) 20px min(10.83vw, 156px);
}

@media screen and (max-width: 767px) {
	.l-content__bg-inner--01 {
		padding: min(10.67vw, 40px) 16px min(17.07vw, 64px);
	}
}

.l-content__bg-inner--02 {
	max-width: 830px;
	padding: min(9.72vw, 140px) 20px min(17.36vw, 250px);
}

@media screen and (max-width: 767px) {
	.l-content__bg-inner--02 {
		padding: min(10.67vw, 40px) 16px min(26.67vw, 100px);
	}
}

.l-content__bg-inner--03 {
	max-width: 1060px;
	padding: min(9.72vw, 140px) 20px;
}

@media screen and (max-width: 767px) {
	.l-content__bg-inner--03 {
		padding: min(17.07vw, 64px) 16px;
	}
}

.l-content__bg-inner--04 {
	max-width: 1140px;
	margin: 0 auto;
}

@media screen and (max-width: 767px) {
	.l-content__bg-inner--04 {
		padding: min(10.67vw, 40px) 16px;
	}
}

@media screen and (max-width: 767px) {
	.l-content__bg-inner--04-img {
		padding: 0;
	}
}

.l-content__parent {
	position: relative;
	overflow: hidden;
}

.l-content__parent--01::after {
	position: absolute;
	right: 0;
	bottom: 0;
	transform: rotate(-42deg);
	content: '';
	width: 100%;
	height: min(10.76vw, 155px);
	background: #F9EEE2;
	z-index: -1;
}

@media screen and (min-width: 1441px) {
	.l-content__parent--01::after {
		right: -470px;
	}
}

@media screen and (min-width: 1801px) {
	.l-content__parent--01::after {
		right: -420px;
	}
}

@media screen and (max-width: 1440px) {
	.l-content__parent--01::after {
		right: max(-34.03vw, -490px);
	}
}

@media screen and (max-width: 767px) {
	.l-content__parent--01::after {
		height: min(18.67vw, 70px);
		right: max(-40vw, -150px);
		transform: rotate(-38deg);
	}
}

.l-content__parent--02::after {
	position: absolute;
	top: 0;
	left: 0;
	left: max(-21.53vw, -310px);
	transform: rotate(-42deg);
	content: '';
	width: calc(100% + 150px);
	height: min(10.76vw, 155px);
	background: #EBEDF2;
}

@media screen and (max-width: 1440px) {
	.l-content__parent--02::after {
		left: max(-21.53vw, -310px);
	}
}

@media screen and (max-width: 767px) {
	.l-content__parent--02::after {
		height: min(18.67vw, 70px);
		right: max(-32vw, -120px);
		transform: rotate(-38deg);
	}
}

@media screen and (max-width: 767px) {
	.l-content__bg-access {
		background: #F4F5F7;
	}
}

.l-content__inquiry {
	max-width: 720px;
	padding: min(5.56vw, 80px) 20px min(12.5vw, 180px);
}

@media screen and (max-width: 767px) {
	.l-content__inquiry {
		padding: min(17.07vw, 64px) 16px min(32vw, 120px);
	}
}

.slider-wrap {
	position: absolute;
	bottom: min(13.19vw, 190px);
	left: 0;
	overflow: hidden;
	width: 100%;
	height: min(19.44vw, 280px);
}

@media screen and (max-width: 767px) {
	.slider-wrap {
		bottom: min(14.67vw, 55px);
		height: min(36.8vw, 138px);
	}
}

.slider {
	display: flex;
	align-items: center;
	justify-content: flex-start;
}

.slider li {
	padding: 0 0.25em;
	font-size: min(15.42vw, 222px);
	color: rgba(255, 255, 255, 0.7);
	font-family: 'Roboto', sans-serif;
	font-weight: 300;
	letter-spacing: min(0.28vw, 4px);
	white-space: nowrap;
}

@media screen and (max-width: 767px) {
	.slider li {
		padding: 0 0.25em;
		font-size: min(24.53vw, 92px);
		letter-spacing: min(0.49vw, 1.84px);
	}
}

.c-heading-02 {
	font-size: min(2.92vw, 4.2rem);
	font-weight: 500;
}

@media screen and (max-width: 767px) {
	.c-heading-02 {
		font-size: min(7.47vw, 2.8rem);
	}
}





/* header */
.l-header {
	position: fixed;
	top: 0;
	right: 0;
	width: 20.83vw;
	height: 66.15vw;
	z-index: 99999;
	box-shadow: max(-1.39vw, -20px) 0px min(2.08vw, 30px) 0px rgba(0, 0, 0, 0.1);
	transition: background-color .5s;
}

@media screen and (max-width: 767px) {
	.l-header {
		width: 100%;
		height: 70px;
		box-shadow: none;
	}
}

@media screen and (max-width: 767px) {
	.is-show-top.l-header {
		background-color: #FFF;
	}
}

.l-header__inner {
	height: 100vh;
	overflow-y: scroll;
}

@media screen and (max-width: 767px) {
	.l-header__inner {
		position: fixed;
		top: 0;
		right: -100%;
		width: 100%;
		height: 100%;
		transition: all .5s;
		background: rgba(0, 0, 0, 0.6);
		overflow-y: visible;
	}
}

@media screen and (max-width: 767px) {
	.is-open .l-header__inner {
		right: 0;
	}
}

@media screen and (max-width: 767px) {
	.l-header__container {
		position: fixed;
		top: 0;
		right: -100%;
		width: min(94.67vw, 355px);
		height: 100%;
		transition: all .5s;
		z-index: 1;
		overflow-y: scroll;
	}
}

@media screen and (max-width: 767px) {
	.is-open .l-header__container {
		right: 0;
	}
}

.l-header__logo-wrap {
	position: absolute;
	top: 2.36vw;
	left: 5.56vw;
	width: 5.21vw;
	z-index: 1;
}

@media screen and (max-width: 767px) {
	.l-header__logo-wrap {
		top: 15px;
		left: 20px;
		width: 40px;
		z-index: 0;
	}
}

.l-header__title-wrap {
	padding: 0.83vw 0.97vw 0.83vw 1.67vw;
	background: #C38C49;
}

@media screen and (max-width: 767px) {
	.l-header__title-wrap {
		padding: min(3.2vw, 12px) min(6.4vw, 24px);
	}
}

.l-header__title-inner {
	padding-left: 0.83vw;
	color: #FFF;
	border-left: 2px solid #FFF;
}

@media screen and (max-width: 767px) {
	.l-header__title-inner {
		padding-left: min(2.67vw, 10px);
	}
}

.l-header__title {
	font-size: 1.25vw;
	font-weight: bold;
	letter-spacing: 0.22vw;
}

@media screen and (max-width: 767px) {
	.l-header__title {
		font-size: min(4.27vw, 1.6rem);
		letter-spacing: min(0.85vw, 3.2px);
	}
}

.l-header__title-lead {
	margin-top: 0.28vw;
	font-size: 0.97vw;
	letter-spacing: 0.1vw;
}

@media screen and (max-width: 767px) {
	.l-header__title-lead {
		margin-top: min(1.07vw, 4px);
		font-size: min(3.73vw, 1.4rem);
	}
}

.l-header__body {
	padding: 1.6vw 0.83vw;
	background: #F4F5F7;
}

@media screen and (max-width: 767px) {
	.l-header__body {
		padding: 0 min(6.4vw, 24px) min(4.27vw, 16px);
	}
}

@media screen and (max-width: 767px) {
	.l-header__nav {
		display: flex;
		align-items: center;
		justify-content: center;
		flex-direction: column;
		margin-top: 0;
	}
}

@media screen and (max-width: 767px) {
	.l-header__nav-item {
		width: 100%;
	}
}

.l-header__nav-item a {
	display: block;
	padding: 1.67vw 0;
	font-size: 1.11vw;
	color: #4F4F4F;
	border-bottom: 1px solid #AFAFAF;
}

@media screen and (max-width: 767px) {
	.l-header__nav-item a {
		padding: min(6.4vw, 24px) 0;
		font-size: min(4.27vw, 1.6rem);
	}
}

.l-header__trigger {
	display: none;
	position: fixed;
	top: 22px;
	right: 20px;
	width: 30px;
	height: 26px;
	transition: .5s all;
	cursor: pointer;
	z-index: 20;
}

@media screen and (max-width: 767px) {
	.l-header__trigger {
		display: block;
	}
}

.l-header__trigger span {
	display: block;
	position: absolute;
	right: 0;
	width: 30px;
	height: 4px;
	border-radius: 10px;
	background-color: rgba(255, 255, 255, 0.6);
	transition: all .5s;
}

.is-show-top .l-header__trigger span {
	background-color: rgba(0, 0, 0, 0.6);
}

.is-open .l-header__trigger span {
	background-color: #504E4E;
}

.is-open .l-header__trigger span {
	right: auto;
	left: 0;
}

.l-header__trigger span:first-of-type {
	top: 0;
}

.is-open .l-header__trigger span:first-of-type {
	top: 2px;
	-webkit-transform: translateY(10px) rotate(-315deg);
	transform: translateY(10px) rotate(-315deg);
}

.l-header__trigger span:nth-of-type(2) {
	top: 11px;
}

.is-open .l-header__trigger span:nth-child(2) {
	opacity: 0;
}

.l-header__trigger span:last-of-type {
	bottom: 0;
}

.is-open .l-header__trigger span:nth-child(3) {
	bottom: 0;
	-webkit-transform: translateY(-10px) rotate(315deg);
	transform: translateY(-10px) rotate(315deg);
}

.l-header__link-group {
	margin-top: min(2.22vw, 32px);
}

@media screen and (max-width: 767px) {
	.l-header__link-group {
		margin-top: min(6.4vw, 24px);
	}
}

.l-header__link-wrap {
	position: relative;
	box-shadow: 0px min(0.28vw, 4px) min(0.56vw, 8px) 0px rgba(0, 0, 0, 0.15);
	background: #C38C49;
	border-radius: 4px;
}

@media screen and (max-width: 767px) {
	.l-header__link-wrap {
		box-shadow: 0px min(1.07vw, 4px) min(2.13vw, 8px) 0px rgba(0, 0, 0, 0.15);
	}
}

.l-header__link-wrap::after {
	position: absolute;
	top: 50%;
	right: 1.39vw;
	transform: translateY(-50%);
	content: '';
	width: 0.35vw;
	height: 0.69vw;
	background: url(assets/img/icon_triangle.svg) no-repeat center center / contain;
}

@media screen and (max-width: 767px) {
	.l-header__link-wrap::after {
		right: min(5.33vw, 20px);
		width: min(1.33vw, 5px);
		height: min(2.13vw, 8px);
	}
}

.l-header__link-wrap:not(:first-of-type) {
	margin-top: 0.56vw;
}

@media screen and (max-width: 767px) {
	.l-header__link-wrap:not(:first-of-type) {
		margin-top: min(2.67vw, 10px);
	}
}

.l-header__link-wrap a {
	display: block;
	padding: 1.67vw 1.94vw 1.67vw 0.97vw;
	font-size: 1.11vw;
	color: #FFF;
}

@media screen and (max-width: 767px) {
	.l-header__link-wrap a {
		font-size: min(4.27vw, 1.6rem);
		padding: min(6.4vw, 24px) min(9.6vw, 36px) min(6.4vw, 24px) min(4.27vw, 16px);
	}
}

.l-header__link-img-group {
	margin-top: 1.11vw;
}

@media screen and (max-width: 767px) {
	.l-header__link-img-group {
		margin-top: min(5.33vw, 20px);
	}
}

.l-header__link-img-wrap {
	height: 4.44vw;
	background-repeat: no-repeat;
	background-size: cover;
}

@media screen and (max-width: 767px) {
	.l-header__link-img-wrap {
		height: min(17.07vw, 64px);
	}
}

.l-header__link-img {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	padding: 0.5em 1em;
}

.l-header__link-img--01 {
	background-image: url(assets/img/header_img_01.jpg);
}
.l-header__link-img--02 {
	background-image: url(assets/img/header_img_02.jpg);
}
.l-header__link-img--03 {
	background-image: url(assets/img/header_img_03.jpg);
}
.l-header__link-img--04 {
	background-image: url(assets/img/header_img_04.jpg);
}

.l-header__link-img-wrap:not(:first-of-type) {
	margin-top: 0.28vw;
}

@media screen and (max-width: 767px) {
	.l-header__link-img-wrap:not(:first-of-type) {
		margin-top: min(1.07vw, 4px);
	}
}

.l-header__link-text {
	position: relative;
	color: #FFF;
	font-size: 1.11vw;
}

@media screen and (max-width: 767px) {
	.l-header__link-text {
		font-size: min(4.27vw, 1.6rem);
	}
}

.l-header__link-text::after {
	display: inline-block;
	position: relative;
	top: 0;
	right: -0.28vw;
	content: '';
	width: 0.69vw;
	height: 0.69vw;
	background: url(assets/img/icon_blank.svg) no-repeat center center / contain;
}

@media screen and (max-width: 767px) {
	.l-header__link-text::after {
		right: max(-1.07vw, -4px);
		width: min(2.67vw, 10px);
		height: min(2.67vw, 10px);
	}
}




/* KV */
.p-kv-area {
	margin-right: min(20.83vw, 300px);
	margin-right: 20.83vw;
}

@media screen and (max-width: 767px) {
	.p-kv-area {
		margin-right: 0;
	}
}

.p-kv__img-wrap img {
	width: 100%;
}

#slide_wrap{
  position: relative;
  overflow: hidden;
}

.slide_item{
	opacity: 0;
	transform: scale(1);
	transition: opacity 2s linear, transform 7.5s linear;
	position: relative;
}

.slide_item:not(:first-child){
	position: absolute;
	top: 0;
	left : 0;
	width: 100%;
}

.slide_item.is-show{
	opacity: 1;
}

.slide_item.is-zoom{
	transform: scale(1.1);
}

.slide_item img{
	width: 100%;
	display: block;
}

.c-heading-01 {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-size: 4.44vw;
	color: rgba(255, 255, 255, 0.9);
	font-weight: 300;
	text-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
	text-align: center;
	letter-spacing: 3.2px;
}

@media screen and (max-width: 767px) {
	.c-heading-01 {
		width: 90%;
		font-size: min(10.13vw, 38px);
		letter-spacing: min(0.51vw, 1.9px);
	}
}

.c-heading-01 span {
	font-style: italic;
	letter-spacing: min(1.01vw, 3.8px);
}



/* NEWS */
.p-news__item-group {
	margin-top: min(2.22vw, 32px);
}

@media screen and (max-width: 767px) {
	.p-news__item-group {
		margin-top: min(6.4vw, 24px);
	}
}

.p-news__item {
	max-width: min(64.17vw, 924px);
}

@media screen and (max-width: 767px) {
	.p-news__item {
		max-width: none;
	}
}

.p-news__item:not(:first-of-type) {
	margin-top: min(1.67vw, 24px);
}

@media screen and (max-width: 767px) {
	.p-news__item:not(:first-of-type) {
		margin-top: min(6.4vw, 24px);
	}
}

.p-news__item a {
	position: relative;
	display: block;
	padding: min(0.56vw, 8px) 0;
	color: #231815;
	border-bottom: 1px solid #E8E8E8;
}

@media screen and (max-width: 767px) {
	.p-news__item a {
		padding: min(2.13vw, 8px) 0;
	}
}

.p-news__item-contents-wrap {
	display: flex;
	align-items: center;
}

.p-news__item-label {
	display: inline-block;
	padding: min(0.42vw, 6px) min(1.39vw, 20px);
	font-size: min(0.97vw, 1.4rem);
	color: #FFF;
	background: #C38C49;
}

@media screen and (max-width: 767px) {
	.p-news__item-label {
		padding: min(1.6vw, 6px) min(5.33vw, 20px);
		font-size: min(3.73vw, 1.4rem);
	}
}

.p-news__item-time {
	display: inline-block;
	margin-left: min(0.56vw, 8px);
	color: #C38C49;
	font-size: min(1.11vw, 1.6rem);
}

@media screen and (max-width: 767px) {
	.p-news__item-time {
		margin-left: min(2.13vw, 8px);
		font-size: min(3.72vw, 1.6rem);
	}
}

.p-news__item-text-wrap {
	margin-top: min(0.97vw, 14px);
}

@media screen and (max-width: 767px) {
	.p-news__item-text-wrap {
		margin-top: min(3.73vw, 14px);
	}
}

.p-news__item-text {
	font-weight: bold;
	font-size: min(1.11vw, 1.6rem);
}

@media screen and (max-width: 767px) {
	.p-news__item-text {
		font-size: min(3.72vw, 1.6rem);
	}
}

.p-news__button-area {
	display: flex;
	justify-content: end;
}

.p-news__button-wrap {
	position: relative;
	display: inline-block;
	margin-top: min(2.78vw, 40px);
	margin-right: min(2.78vw, 40px);
}

@media screen and (max-width: 767px) {
	.p-news__button-wrap {
		margin-top: min(7.47vw, 28px);
		margin-right: 0;
	}
}

.p-news__button-wrap a {
	padding-right: min(3.33vw, 48px);
	color: #333;
	font-size: min(1.25vw, 1.8rem);
}

@media screen and (max-width: 767px) {
	.p-news__button-wrap a {
		padding-right: min(12.8vw, 48px);
		font-size: min(4.8vw, 1.8rem);
	}
}

.p-news__button-wrap a::before,
.p-news__button-wrap a::after {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	content: '';
}

.p-news__button-wrap a::before {
	right: min(0.9vw, 13px);
	width: min(0.35vw, 5px);
	height: min(0.69vw, 10px);
	background: url(assets/img/icon_triangle_02.svg) no-repeat center center / cover;
	z-index: 1;
}

@media screen and (max-width: 767px) {
	.p-news__button-wrap a::before {
		right: min(3.47vw, 13px);
		width: min(1.33vw, 5px);
		height: min(2.67vw, 10px);
	}
}

.p-news__button-wrap a::after {
	right: 0;
	width: min(2.22vw, 32px);
	height: min(2.22vw, 32px);
	background: #FFF;
	border: 1px solid #C38C49;
	border-radius: 50%;
}

@media screen and (max-width: 767px) {
	.p-news__button-wrap a::after {
		width: min(8.53vw, 32px);
		height: min(8.53vw, 32px);
	}
}



/* about */
.p-about-area {
	position: relative;
	z-index: 1;
}

.p-about__text-wrap {
	margin-top: min(5.83vw, 84px);
}

@media screen and (max-width: 767px) {
	.p-about__text-wrap {
		margin-top: min(8.53vw, 32px);
	}
}

.p-about__text {
	text-align: center;
	line-height: 2;
	letter-spacing: min(0.13vw, 1.8px);
}

@media screen and (max-width: 767px) {
	.p-about__text {
		line-height: 1.75;
		letter-spacing: min(0.21vw, 0.8px);
	}
}

.p-about__text:not(:first-of-type) {
	margin-top: min(4.44vw, 64px);
}

@media screen and (max-width: 767px) {
	.p-about__text:not(:first-of-type) {
		margin-top: min(8.53vw, 32px);
	}
}

.p-about__text:nth-of-type(2),
.p-about__text:nth-of-type(3) {
	margin-top: 0;
}

@media screen and (max-width: 767px) {
	.p-about__text:nth-of-type(2),
	.p-about__text:nth-of-type(3) {
		margin-top: min(8.53vw, 32px);
	}
}



/* link */
.p-link__group {
	display: flex;
}

@media screen and (max-width: 767px) {
	.p-link__group {
		display: block;
	}
}

.p-link__item {
	position: relative;
	width: min(26.39vw, 380px);
	height: min(26.39vw, 380px);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

@media screen and (max-width: 767px) {
	.p-link__item {
		width: min(90.4vw, 339px);
		height: min(90.4vw, 339px);
		margin: 0 auto;
	}
}

.p-link__item::after {
  position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	content: '';
  background-color: rgba(0,0,0,.4);
}

.p-link__item--01 {
	background-image: url(assets/img/img_02.jpg);
}

.p-link__item--02 {
	background-image: url(assets/img/img_03.jpg);
}

.p-link__item--03 {
	background-image: url(assets/img/img_04.jpg);
}

.p-link__item-top-wrap {
	display: flex;
	height: calc(100% - min(3.33vw, 48px));
}

@media screen and (max-width: 767px) {
	.p-link__item-top-wrap {
		height: calc(100% - min(11.2vw, 42px));
	}
}

.p-link__item-top-left {
	border-right: 1px solid #FFF;
	width: min(3.33vw, 48px);
	height: 100%;
}

@media screen and (max-width: 767px) {
	.p-link__item-top-left {
		width: min(11.2vw, 42px);
	}
}

.p-link__item-top-right {
	width: 100%;
	position: relative;
}

.p-link__item-top-right::after {
  position: absolute;
	top: 0;
	left: 0;
	content: '';
	width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,.3);
	backdrop-filter: blur(3px);
	-webkit-backdrop-filter: blur(24px);
}

.p-link__item-top-right a {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	width: 100%;
	height: 100%;
	color: #FFF;
	z-index: 1;
}

.p-link__item-top-right a span {
	position: relative;
	line-height: 1.8;
	padding-bottom: min(2.36vw, 34px);
}

@media screen and (max-width: 767px) {
	.p-link__item-top-right a span {
		line-height: 1.7;
		padding-bottom: min(11.2vw, 42px);
	}
}

.p-link__item-top-right a span::before,
.p-link__item-top-right a span::after {
	position: absolute;
	content: '';
}

.p-link__item-top-right a span::before {
	left: min(0.76vw, 11px);
	bottom: min(0.63vw, 9px);
	width: min(0.28vw, 4px);
	height: min(0.56vw, 8px);
	background: url(assets/img/icon_triangle_03.svg) no-repeat center center / cover;
	z-index: 1;
	transition: all .3s;
}

@media screen and (max-width: 767px) {
	.p-link__item-top-right a span::before {
		left: min(2.67vw, 10px);
		bottom: min(1.87vw, 7px);
		width: min(1.07vw, 4px);
		height: min(2.13vw, 8px);
	}
}

.p-link__item-top-right a:hover span::before {
	left: min(0.97vw, 14px);
}

@media screen and (max-width: 767px) {
	.p-link__item-top-right a:hover span::before {
		left: min(4.27vw, 16px);
	}
}

.p-link__item-top-right a span::after {
	left: 0;
	bottom: max(-2.99vw, -43px);
	bottom: 0;
	width: min(1.74vw, 25px);
	height: min(1.74vw, 25px);
	border: 1px solid #FFF;
	border-radius: 50%;
}

@media screen and (max-width: 767px) {
	.p-link__item-top-right a span::after {
		width: min(5.87vw, 22px);
		height: min(5.87vw, 22px);
	}
}

.p-link__item-bottom-wrap {
	border-top: 1px solid #FFF;
	height: min(3.33vw, 48px);
}



/* access */
.p-access__group {
	display: flex;
	margin-top: min(5.56vw, 80px);
}

@media screen and (max-width: 767px) {
	.p-access__group {
		display: block;
		margin-top: min(10.67vw, 40px);
	}
}

.p-access__img-wrap {
	width: min(36.53vw, 526px);
}

@media screen and (max-width: 767px) {
	.p-access__img-wrap {
		width: 100%;
		text-align: center;
	}
}

.p-access__text-wrap {
	margin-left: min(2.36vw, 34px);
}

@media screen and (max-width: 767px) {
	.p-access__text-wrap {
		max-width: 526px;
		margin: min(6.4vw, 24px) auto 0;
	}
}

.p-access__text {
	padding-bottom: min(1.11vw, 16px);
	font-size: min(1.53vw, 2.2rem);
	letter-spacing: min(0.15vw, 2.2px);
	border-bottom: 1px solid #E8E8E8;
}

@media screen and (max-width: 767px) {
	.p-access__text {
		padding-bottom: min(3.73vw, 14px);
		font-size: min(4.27vw, 1.6rem);
		letter-spacing: min(0.43vw, 1.6px);
	}
}

.p-access__text:not(:first-of-type) {
	margin-top: min(2.78vw, 40px);
}

@media screen and (max-width: 767px) {
	.p-access__text:not(:first-of-type) {
		margin-top: min(6.4vw, 24px);
	}
}

.p-access__text a {
	color: #333;
}





/* map */
.p-map__wrap iframe {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 1440 / 240;
}

@media screen and (max-width: 767px) {
	.p-map__wrap iframe {
		aspect-ratio: 375 / 180;
	}
}





/* footer */
.l-footer {
	background: #373633;
}

.l-footer__inner {
	margin-right: 20.83vw;
}

@media screen and (max-width: 1000px) {
	.l-footer__inner {
		margin-right: 0;
	}
}

.l-footer__inner-body {
	max-width: 1140px;
	margin: 0 auto;
}

.l-footer__top {
	padding: min(2.78vw, 40px) 20px;
}

@media screen and (max-width: 1000px) {
	.l-footer__top {
		padding: min(10.67vw, 40px) 16px;
	}
}

.l-footer__bottom {
	padding: min(2.78vw, 40px) 20px min(1.67vw, 24px);
	border-top: 1px solid #FFF;
}

@media screen and (max-width: 1000px) {
	.l-footer__bottom {
		padding: min(6.4vw, 24px) 16px min(3.2vw, 12px);
	}
}

.l-footer__inner-top-list,
.l-footer__inner-bottom-list,
.l-footer__inner-bottom-list ul {
	display: flex;
	align-items: center;
	justify-content: center;
}

@media screen and (max-width: 767px) {
	.l-footer__inner-top-list,
	.l-footer__inner-bottom-list {
		flex-direction: column;
	}
}

.l-footer__inner-top-list li:not(:first-of-type) {
	margin-left: min(2.78vw, 40px);
}

@media screen and (max-width: 767px) {
	.l-footer__inner-top-list li:not(:first-of-type) {
		margin: min(3.2vw, 12px) 0 0 0;
	}
}

.l-footer__inner-top-list li a,
.l-footer__inner-bottom-list li a {
	color: #FFF;
}

.l-footer__inner-bottom-list li:not(:first-of-type) {
	margin-left: min(6.4vw, 24px);
}

@media screen and (max-width: 767px) {
	.l-footer__inner-bottom-list li:not(:first-of-type) {
		margin: min(1.07vw, 4px) 0 0 0;
	}
}

.l-footer__inner-bottom-list li a {
	font-size: min(1.11vw, 1.6rem);
}

@media screen and (max-width: 767px) {
	.l-footer__inner-bottom-list li a {
		font-size: min(3.47vw, 1.3rem);
	}
}

.l-footer__inner-bottom-list li ul li:not(:first-of-type) {
	margin: 0 0 0 min(6.4vw, 24px);
}

@media screen and (max-width: 767px) {
	.l-footer__inner-bottom-list li ul li:not(:first-of-type) {
		margin: 0 0 0 min(3.2vw, 12px);
	}
}

.l-footer__img-wrap {
	margin-top: min(2.78vw, 40px);
	text-align: center;
}

@media screen and (max-width: 767px) {
	.l-footer__img-wrap {
		margin-top: min(1.67vw, 24px);
	}
}

.l-footer__copy-wrap {
	margin-top: min(0.97vw, 14px);
}

@media screen and (max-width: 767px) {
	.l-footer__copy-wrap {
		margin-top: min(2.13vw, 8px);
	}
}

.l-footer__copy-text {
	color: #FFF;
	font-size: min(0.9vw, 1.3rem);
	text-align: center;
}

@media screen and (max-width: 767px) {
	.l-footer__copy-text {
		font-size: min(3.2vw, 1.2rem);
	}
}





/* inquiry */
.inquiry .p-kv-area {
	position: relative;
}

.inquiry .p-kv-area img {
	width: 100%;
}

.l-header__nav-item.is-current {
	background: #e5e5e5;
}

.l-header__nav-item.is-current a
.l-footer__inner-top-list .is-current a {
	pointer-events: none;
	cursor: auto;
}


/* news archive */
.archive .p-news__button-area {
	justify-content: center;
}

.archive .p-news__button-wrap {
	margin-right: 0;
}





/* singleページ */
.p-news__single-contents-wrap {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.p-news__single-title {
	font-size: min(2.78vw, 4rem);
	margin-top: min(2.08vw, 30px);
}

@media screen and (max-width: 767px) {
	.p-news__single-title {
		font-size: min(9.3vw, 6rem);
		margin-top: min(6.98vw, 45px);
	}
}

.p-news__single-text-wrap {
	margin-top: min(5.83vw, 84px);
}

@media screen and (max-width: 767px) {
	.p-news__single-text-wrap {
		margin-top: min(4.65vw, 30px);
	}
}

.p-news__single-button-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: min(3.19vw, 46px);
}

@media screen and (max-width: 767px) {
	.p-news__single-button-wrap {
		margin-top: min(10.7vw, 69px);
	}
}

.p-news__single-button-wrap a {
	display: flex;
	align-items: center;
	justify-content: center;
	color: #FFF;
	background: #C38C49;
	width: min(23.82vw, 343px);
  height: min(4.58vw, 66px);
	font-size: min(1.25vw, 1.8rem);
	border-radius: 4px;
}

@media screen and (max-width: 767px) {
	.p-news__single-button-wrap a {
		width: min(91.47vw, 343px);
		height: min(17.6vw, 66px);
		margin-top: min(6.4vw, 24px);
		font-size: min(4.8vw, 1.8rem);
	}
}


/* シングルページ「投稿」で生成されるタグ */
/* 段落 */
.p-news__single-wrap p {
	word-break: break-all;
}

.p-news__single-wrap p:not(:first-of-type) {
	margin-top: min(2.08vw, 30px);
}

@media screen and (max-width: 767px) {
	.p-news__single-wrap p:not(:first-of-type) {
		margin-top: min(5.33vw, 20px);
	}
}

/* 見出し */
.p-news__single-wrap h1, .p-news__single-wrap h2, .p-news__single-wrap h3, .p-news__single-wrap h4, .p-news__single-wrap h5, .p-news__single-wrap h6 {
	margin-top: 30px;
	margin-bottom: 20px;
	font-weight: bold;
	line-height: 1.5;
}

/* リスト */
.p-news__single-wrap ul, .p-news__single-wrap ol {
	margin-left: 20px;
	padding-left: 20px;
	margin-bottom: 20px;
}

.p-news__single-wrap li {
	margin-bottom: 10px;
}

/* 画像 */
.p-news__single-wrap img {
	display: block;
	max-width: 100%;
	height: auto;
}

.p-news__single-wrap div {
	margin-top: 40px;
}

@media screen and (max-width: 767px) {
	.p-news__single-wrap div {
		margin-top: 20px;
	}
}

.p-news__single-wrap .p-news__single-button-wrap {
	margin-top: 64px;
}

@media screen and (max-width: 767px) {
	.p-news__single-wrap .p-news__single-button-wrap {
		margin-top: 48px;
	}
}

.p-news__single-wrap div img {
	margin: 0 auto;
}

/* リンク */
/* .p-news__single-wrap a {
	color: #0073e6;
	text-decoration: underline;
} */

.p-news__single-wrap a:hover {
	text-decoration: none;
}

/* 引用 */
.p-news__single-wrap blockquote {
	margin: 20px 0;
	padding: 10px 20px;
	border-left: 5px solid #ccc;
	background-color: #f9f9f9;
	font-style: italic;
}

/* テーブル */
.p-news__single-wrap table {
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 20px;
}

.p-news__single-wrap th, .p-news__single-wrap td {
	border: 1px solid #ccc;
	padding: 10px;
	text-align: left;
}

/* 強調 */
.p-news__single-wrap strong {
	font-weight: bold;
}

.p-news__single-wrap em {
	font-style: italic;
}

/* コードブロック */
.p-news__single-wrap pre, .p-news__single-wrap code {
	font-family: monospace;
	background-color: #f4f4f4;
	padding: 5px;
	border-radius: 3px;
	display: block;
	margin-bottom: 20px;
}

/* 動画・埋め込みコンテンツ */
.p-news__single-wrap iframe, .p-news__single-wrap video {
	max-width: 100%;
	height: auto;
	margin: 20px 0;
	display: block;
}








/* お問い合わせ */
.p-contact__cf7-item-information span {
	font-size: min(0.97vw, 1.4rem);
}

@media screen and (max-width: 767px) {
	.p-contact__cf7-item-information span {
		font-size: min(3.73vw, 1.4rem);
	}
}

.p-contact__cf7-item-information {
	font-weight: 500;
}

.p-contact__cf7-item:not(:first-of-type) {
	margin-top: min(1.67vw, 24px);
}

@media screen and (max-width: 767px) {
	.p-contact__cf7-item:not(:first-of-type) {
		margin-top: min(6.4vw, 24px);
	}
}


/* input・textarea */
.p-contact__cf7-item input[type="text"],
.p-contact__cf7-item input[type="email"],
.p-contact__cf7-item textarea {
  width: 100%;
	margin-top: min(0.56vw, 8px);
  padding: min(0.69vw, 10px) min(1.11vw, 16px);
	border: 1px solid #D9D9D9;
	font-size: min(1.11vw, 1.6rem);
	border-radius: 4px;
}

@media screen and (max-width: 767px) {
	.p-contact__cf7-item input[type="text"],
	.p-contact__cf7-item input[type="email"],
	.p-contact__cf7-item textarea {
		margin-top: min(1.4vw, 6px);
		padding: min(1.86vw, 8px) min(2.79vw, 12px);
		font-size: min(4.27vw, 1.6rem);
	}
}

.p-contact__cf7-item input[type="text"]::placeholder,
.p-contact__cf7-item input[type="email"]::placeholder,
.p-contact__cf7-item textarea::placeholder {
	font-size: min(1.11vw, 1.6rem);
}

@media screen and (max-width: 767px) {
	.p-contact__cf7-item input[type="text"]::placeholder,
	.p-contact__cf7-item input[type="email"]::placeholder,
	.p-contact__cf7-item textarea::placeholder {
		font-size: min(4.27vw, 1.6rem);
	}
}

.p-contact__cf7-item--flex {
	display: flex;
	align-items: center;
}

.p-contact__cf7-item input[type="text"]:focus,
.p-contact__cf7-item input[type="email"]:focus,
.p-contact__cf7-item textarea:focus {
  outline: none;
	border: 2px solid #C38C49;
}

.p-contact__cf7-item input[type="text"],
.p-contact__cf7-item input[type="email"] {
	height: min(3.47vw, 50px);
}

@media screen and (max-width: 767px) {
	.p-contact__cf7-item input[type="text"],
	.p-contact__cf7-item input[type="email"] {
		height: min(13.33vw, 50px);
	}
}

.p-contact__cf7-item textarea {
	height: min(6.94vw, 100px);
}

@media screen and (max-width: 767px) {
	.p-contact__cf7-item textarea {
		height: min(26.67vw, 100px);
	}
}


/* select */
.p-contact__cf7-item-address-wrap {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.p-contact__cf7-item select {
	width: 100%;
	height: min(3.47vw, 50px);
	padding: min(0.69vw, 10px) min(1.11vw, 16px);
	font-size: min(1.11vw, 1.6rem);
	border: 1px solid #DDDDDD;
	border-radius: 4px;
	-webkit-appearance: none;
  appearance: none;
}

@media screen and (max-width: 767px) {
	.p-contact__cf7-item select {
		height: min(13.33vw, 50px);
		padding: min(1.86vw, 8px) min(2.79vw, 12px);
		font-size: min(4.27vw, 1.6rem);
	}
}

.p-contact__cf7-item-select {
	position: relative;
	margin-top: min(0.56vw, 8px);
}

@media screen and (max-width: 767px) {
	.p-contact__cf7-item-select {
		margin-top: min(1.4vw, 6px);
	}
}

.p-contact__cf7-item-select::after {
	position: absolute;
	top: 50%;
	right: min(1.67vw, 24px);
	transform: translateY(-50%);
	content: '';
	width: min(0.69vw, 10px);
	height: min(0.35vw, 5px);
	background: url(assets/img/icon_triangle_04.svg) no-repeat center center / contain;
}

@media screen and (max-width: 767px) {
	.p-contact__cf7-item-select::after {
		right: min(2.13vw, 8px);
		width: min(2.67vw, 10px);
		height: min(1.33vw, 5px);
	}
}

/* フォーカス時（クリックして選択時）のスタイル */
.p-contact__cf7-item-select select:focus {
	outline: none;
	border: 2px solid #C38C49 !important;
}

.p-contact__cf7-item-address-select {
	width: min(11.81vw, 170px);
	margin-right: min(1.67vw, 24px);
}

@media screen and (max-width: 767px) {
	.p-contact__cf7-item-address-select {
		width: 22.4vw;
		margin-right: min(3.2vw, 12px);
	}
}

.p-contact__cf7-item .p-contact__cf7-item-address-text {
	width: calc(100% - min(13.47vw, 194px));
}

@media screen and (max-width: 767px) {
	.p-contact__cf7-item .p-contact__cf7-item-address-text {
		width: calc(100% - (22.4vw + min(3.2vw, 12px)));
	}
}

.p-contact__cf7-item-num-wrap {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.p-contact__cf7-item-num--01 {
	position: relative;
	width: min(11.81vw, 170px);
	margin-right: min(1.67vw, 24px);
}

@media screen and (max-width: 767px) {
	.p-contact__cf7-item-num--01 {
		width: 22.4vw;
		margin-right: min(3.2vw, 12px);
	}
}

.p-contact__cf7-item-num--01::after {
	position: absolute;
	top: calc(50% + min(0.28vw, 4px));
	right: max(-1.11vw, -16px);
	transform: translateY(-50%);
	content: '';
	width: min(0.56vw, 8px);
	height: min(0.07vw, 1px);
	background: #000;
}

@media screen and (max-width: 767px) {
	.p-contact__cf7-item-num--01::after {
		top: calc(50% + min(0.28vw, 4px));
		right: max(-2.13vw, -8px);
		width: min(1.07vw, 4px);
	}
}

.p-contact__cf7-item-num--02 {
	width: calc(100% - min(13.47vw, 194px));
}

@media screen and (max-width: 767px) {
	.p-contact__cf7-item-num--02 {
		width: calc(100% - (22.4vw + min(3.2vw, 12px)));
	}
}

.p-contact__checkbox {
	margin-top: min(6.94vw, 100px);
	text-align: center;
}

@media screen and (max-width: 767px) {
	.p-contact__checkbox {
		margin-top: min(17.07vw, 64px);
	}
}

.p-contact__checkbox .wpcf7-list-item {
	margin: 0;
}

.p-contact__checkbox .wpcf7-list-item label {
	display: flex;
	align-items: center;
	justify-content: center;
}

/* 元のチェックボックスを非表示にする */
.p-contact__checkbox input[type="checkbox"] {
	display: none !important;
}

/* カスタムチェックボックス用のスタイル */
.p-contact__checkbox .wpcf7-list-item-label {
	position: relative;
	padding-left: min(2.43vw, 35px); /* チェックボックスとテキストの間隔 */
	cursor: pointer;
	display: inline-block;
}

@media screen and (max-width: 767px) {
	.p-contact__checkbox .wpcf7-list-item-label {
		padding-left: min(9.33vw, 35px); /* チェックボックスとテキストの間隔 */
	}
}


/* カスタムチェックボックスの枠 */
.p-contact__checkbox .wpcf7-list-item-label::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: min(1.46vw, 21px);
	height: min(1.46vw, 21px);
	border: 1px solid #ccc;
	border-radius: 4px;
	background: #fff;
}

@media screen and (max-width: 767px) {
	.p-contact__checkbox .wpcf7-list-item-label::before {
		width: min(5.6vw, 21px);
		height: min(5.6vw, 21px);
	}
}

/* チェック時のスタイル */
.p-contact__checkbox input[type="checkbox"]:checked + .wpcf7-list-item-label::before {
	border: 1px solid #C38C49;
	background: #C38C49;
}

.p-contact__checkbox input[type="checkbox"]:checked + .wpcf7-list-item-label::after {
	content: '\2714'; /* チェックマーク */
	position: absolute;
	top: 50%;
	left: min(0.28vw, 4px);
	transform: translateY(-50%);
	color: #FFF;
	font-size: min(1.11vw, 1.6rem);
}

@media screen and (max-width: 767px) {
	.p-contact__checkbox input[type="checkbox"]:checked + .wpcf7-list-item-label::after {
		left: min(1.07vw, 4px);
		font-size: min(4.27vw, 1.6rem);
	}
}

/* Contact Form 7のデフォルトスタイルの調整 */
.p-contact__checkbox .wpcf7-list-item {
	margin: 0;
}



/* 送信ボタン */
.p-contact__cf7-button {
  text-align: center;
}

.p-contact__cf7-button input[type="submit"] {
  width: min(23.82vw, 343px);
  height: min(4.58vw, 66px);
	margin-top: min(1.67vw, 24px);
	font-weight: 500;
  background: #C38C49;
  color: #fff;
  transition: opacity .5s;
	border: none;
	cursor: pointer;
	font-size: min(1.25vw, 1.8rem);
	border-radius: 4px;
}

@media screen and (max-width: 767px) {
	.p-contact__cf7-button input[type="submit"] {
		max-width: 343px;
		width: 100%;
		height: min(17.6vw, 66px);
		margin-top: min(6.4vw, 24px);
		font-size: min(4.8vw, 1.8rem);
	}
}

.p-contact__cf7-button input[type="submit"]:hover {
  opacity: .7;
}

/* ajax-loader */
.wpcf7-spinner {
  display: none !important;
}

/* 未入力時文言 */
.wpcf7-response-output {
	font-size: min(1.67vw, 2.4rem) !important;
	padding: 0 !important;
	border: none !important;
	color: #dc3232 !important;
	text-align: center !important;
}

@media screen and (max-width: 767px) {
	.wpcf7-response-output {
		font-size: min(5.33vw, 2rem) !important;
	}
}

/* 入力してください */
.p-contact__cf7-item .wpcf7-not-valid-tip,
.p-contact__checkbox .wpcf7-not-valid-tip {
	font-size: min(0.97vw, 1.4rem);
}

@media screen and (max-width: 767px) {
	.p-contact__cf7-item .wpcf7-not-valid-tip,
	.p-contact__checkbox .wpcf7-not-valid-tip {
		font-size: min(2.4vw, 9px) !important;
	}
}

/* reCAPTCHA */
.grecaptcha-badge {
	visibility: hidden;
}

.p-contact__cf7-recaptcha {
	margin-top: min(1.39vw, 20px) !important;
	font-size: min(0.83vw, 1.2rem) !important;
  text-align: center !important;
}

@media screen and (max-width: 767px) {
	.p-contact__cf7-recaptcha {
		margin-top: min(5.33vw, 20px) !important;
		font-size: min(3.2vw, 1.2rem) !important;
		text-align: center !important;
	}
}



/* お問い合わせ完了ページ */
.page-contact-thanks__button-wrap {
  width: min(14.31vw, 206px);
  height: min(3.19vw, 46px);
	margin: min(5.56vw, 80px) auto 0;
	font-weight: 500;
  background: #B30124;
  color: #fff;
  transition: opacity .5s;
	border: none;
	cursor: pointer;
	font-size: min(1.11vw, 1.6rem);
}

@media screen and (max-width: 767px) {
	.page-contact-thanks__button-wrap{
		width: min(44.42vw, 191px);
		height: min(10.23vw, 44px);
		margin: min(9.3vw, 40px) auto 0;
		font-size: min(3.72vw, 1.6rem);
	}
}




.page-contact-thanks__button-wrap a {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	color: #fff;
	font-size: min(1.11vw, 1.6rem);
}

@media screen and (max-width: 767px) {
	.page-contact-thanks__button-wrap a {
		font-size: min(3.72vw, 1.6rem);
	}
}

