@charset "utf-8";

/*===========================================================
ループスライダー
===========================================================*/

.loop-slider .swiper {
	overflow: visible;
}

.loop-slider .swiper-wrapper {
	-webkit-transition-timing-function: linear !important;
	transition-timing-function: linear !important;
}

.loop-slider .swiper-slide {
	width: -webkit-max-content;
	width: -moz-max-content;
	width: max-content;
}

.loop-slider .swiper-slide {
	width: 340px;
}

/*===========================================================
アコーディオン
===========================================================*/

.gjs-dashed .accordionContent {
	display: block;
}

.accordionBtn {
	position: relative;
	z-index: 1;
	transition: all ease .3s;
	cursor: pointer;
}

.accordionContent {
	display: none;
	position: relative;
	z-index: 1;
}

.accordionIcon {
	position: relative;
	width: 100%;
	height: 30px;
	margin-right: 5px;
	margin: 0 0 0 2%;
	max-width: 48px;
}

.accordionIconItem01 {
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	width: 50%;
	height: 2px;
	background-color: var(--primary);
	border-radius: 4px;
	top: 50%;
	transform: rotate(0deg);
}

.accordionIconItem02 {
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	width: 50%;
	height: 2px;
	background-color: var(--primary);
	border-radius: 4px;
	top: 50%;
	transform: rotate(90deg);
	transition: .5s;
}

.accordionIcon.active > .accordionIconItem01 {
	display: none;
}

.accordionIcon.active > .accordionIconItem02 {
	top: 50%;
	transform: rotate(180deg);
	-webkit-transform: rotate(180deg);
	-moz-transform: rotate(180deg);
	-ms-transform: rotate(180deg);
	-o-transform: rotate(180deg);
}

.repeater02-accordion-block {
	border-bottom: 1px solid var(--border-primary);
}

.repeater02-accordion-btn {
	display: flex;
    justify-content: space-between;
	padding: 20px 0;
	transition: all .3s;
}

.repeater02-accordion-btn:hover {
	opacity: .7;
}

.repeater02-accordion-block:first-child .repeater02-accordion-btn {
	padding: 0 0 20px;
}

.repeater02-q-area,
.repeater02-a-area {
	display: flex;
}

.repeater02-accordion-text {
	flex: 1;
}

.repeater02-q {
	margin: 0 10px 0 0;
    font-size: clamp(18px, calc(1.125rem + ((1vw - 3.75px) * 0.3883)), 24px);
    font-weight: 500;
    letter-spacing: 0;
    line-height: 1.3em;
	color: var(--primary);
}

.repeater02-a-area {
	padding: 0 0 20px;
}

.repeater02-a {
	margin: 0 10px 0 0;
    font-size: clamp(18px, calc(1.125rem + ((1vw - 3.75px) * 0.3883)), 24px);
    font-weight: 500;
    letter-spacing: 0;
    line-height: 1.3em;
}

/*===========================================================
REPEATER02
===========================================================*/

.repeater02-container {
	margin: 60px 0 0;
}

.repeater02-container:first-child {
	margin: 0;
}

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (min-width:414px) {


/*===========================================================

===========================================================*/



} /* min-width: 414px ここまで */


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (min-width:544px) {


/*===========================================================

===========================================================*/



} /* min-width: 544px ここまで */


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

/*===========================================================
アコーディオン
===========================================================*/


/*===========================================================
REPEATER02
===========================================================*/

.repeater02-container {
	margin: 80px 0 0;
}


} /* min-width: 768px ここまで */


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (min-width: 1024px) {


/*===========================================================
REPEATER02
===========================================================*/

.repeater02-container {
	margin: 100px 0 0;
}


} /* min-width: 1024px ここまで */


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (min-width:1200px) {


/*===========================================================

===========================================================*/



} /* min-width: 1200px ここまで */


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (min-width:1440px) {


/*===========================================================

===========================================================*/



} /* min-width: 1440px ここまで */


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
@media screen and (min-width:1620px) {




} /* min-width: 1520px ここまで */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */ 