@charset "UTF-8";

/* ------------------------------ */
/* ローダー対策 */
/* ------------------------------ */

.front-page p {
	margin-bottom: 1rem;
}
.front-page img {
	display: inline;
}
@media (min-width: 768px) {
	.front-page .sp-only {
		display: none;
	}
}
@media (max-width: 767px) {
	.front-page .pc-only {
		display: none;
	}
}

/* ------------------------------ */
/* .fv */
/* ------------------------------ */

.front-page .fv {
	position: relative;
	background-color: var(--yellow);
	background-image: url(../img/top/fv_bg.png);
	background-position: center top 80px;
	background-repeat: no-repeat;
	z-index: 1;
}
.front-page .fv .container {
	max-width: 1350px;
}
.front-page .fv__inner {
	position: relative;
	padding: 130px 0 140px 0;
}
.front-page .fv__main {
	position: relative;
	text-align: center;
}
.front-page .fv__btn01,
.front-page .fv__btn02,
.front-page .fv__cloud,
.front-page .fv__insect {
	position: absolute;
}
.front-page .fv__pickup {
	display: block;
	background: linear-gradient(to right, #e73828 0%, #ffd700 56%, #00be87 100%);
	box-shadow: 0 0 15px rgba(255, 200, 0, 0.7);
	border-radius: 100px;
	width: 330px;
	padding: 5px;
	z-index: 2;
}
.front-page .fv__pickup__inner {
	position: relative;
	display: block;
	background-color: #ffffff;
	border-radius: 100px;
	font-size: 16px;
	line-height: 1.2;
	padding: 10px 50px 15px 40px;
}
.front-page .fv__pickup__inner::after {
	position: absolute;
	right: 20px;
	top: 50%;
	transform: translateY(-50%);
	font-family: "Material Symbols Sharp";
	content: "\e941";
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background-color: var(--black);
	color: #ffffff;
	font-size: 16px;
	font-weight: 300;
}
.front-page .fv__pickup__inner .label {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 75px;
	height: 24px;
	background-color: var(--black);
	border-radius: 24px;
	color: #ffffff;
	font-size: 14px;
	font-weight: 500;
	line-height: 1;
	padding-bottom: 2px;
}
.front-page .fv__pickup__inner .title {
	font-weight: 500;
	margin: 10px 0;
}
.front-page .fv__pickup__inner .date {
	color: #666666;
}
.front-page .fv__cloud {
	z-index: 1;
}
.front-page .fv__insect {
	left: 50%;
	transform: translateX(-48%);
	bottom: -70px;
}

@media (min-width: 768px) {
	.front-page .fv__btn01 {
		top: 21vw;
		right: calc(50% + 13.33vw);
		width: 32vw;
	}
	.front-page .fv__btn02 {
		top: 21vw;
		left: calc(50% + 10vw);
		width: 32vw;
	}
	.front-page .fv__pickup {
		position: absolute;
		right: 0;
		bottom: -3vw;
	}
	.front-page .fv__cloud {
		right: 40px;
		bottom: -3vw;
	}
}

@media (min-width: 1350px) {
	.front-page .fv__btn01 {
		top: 290px;
		right: calc(50% + 180px);
		width: 441px;
	}
	.front-page .fv__btn02 {
		top: 290px;
		left: calc(50% + 135px);
		width: 444px;
	}
	.front-page .fv__pickup {
		bottom: 30px;
	}
	.front-page .fv__cloud {
		right: 40px;
		bottom: 30px;
	}
}

@media (max-width: 1349px) {
	.front-page .fv__pickup__inner {
		font-size: 14px;
	}
	.front-page .fv__pickup__inner .label {
		font-size: 12px;
	}
	.front-page .fv__insect {
		transform: translateX(-50%);
		bottom: -150px;
		width: 100px;
	}
}

@media (max-width: 767px) {
	.front-page .fv {
		background-image: url(../img/top/fv_bg_sp.png);
		background-position: center top 115px;
		background-size: 745px;
	}
	.front-page .fv .container {
		max-width: 100%;
		padding: 0 15px;
	}
	.front-page .fv__inner {
		padding: 70px 0 130px 0;
	}
	.front-page .fv__main {
		overflow: hidden;
		height: 540px;
		margin: 0 -15px;
	}
	.front-page .fv__main>img {
		position: absolute;
		left: 50%;
		transform: translateX(-50%);
		top: 0;
		width: 420px;
		min-width: 420px;
	}
	.front-page .fv__btn01 {
		top: 150px;
		right: calc(50% + 45px);
		width: 132px;
		max-width: 132px;
	}
	.front-page .fv__btn02 {
		top: 155px;
		left: calc(50% + 40px);
		width: 134px;
		max-width: 134px;
	}
	.front-page .fv__pickup {
		position: relative;
		width: 100%;
		max-width: 350px;
		padding: 3px;
		margin: 20px auto 0 auto;
	}
	.front-page .fv__insect {
		bottom: -60px;
		width: 60px;
	}
	.front-page .fv__cloud {
		left: 50%;
		transform: translateX(-50%);
		bottom: 110px;
		margin: 0 -15px;
		overflow: hidden;
	}
	.front-page .fv__cloud img {
		width: 328px;
		max-width: 328px;
		min-width: 328px;
	}
}
.front-page .fv__bottom {
	position: relative;
	overflow: hidden;
	height: 488px;
}
.front-page .fv__bottom img {
	position: absolute;
	left: 50%;
	transform: translateX(-51%);
	top: 0;
	width: 1920px;
	min-width: 1920px;
}

@media (max-width: 767px) {
	.front-page .fv__bottom {
		height: 230px;
	}
	.front-page .fv__bottom img {
		width: 900px;
		min-width: 900px;
	}
}

/* ------------------------------ */
/* .section */
/* ------------------------------ */

.front-page .section {
	font-size: 16px;
	line-height: 2;
}
.front-page .section__title {
	margin-bottom: 40px;
}
.front-page .section__title .en {
	font-size: 18px;
	font-weight: 500;
	line-height: 1.2;
}
.front-page .section__title .title {
	font-size: 50px;
	font-weight: 600;
	line-height: 1.2;
	color: #000000;
	margin: 15px 0 0 0;
}
@media (min-width: 768px) {
	.front-page .section .container {
		max-width: 1380px;
	}
}

@media (max-width: 767px) {
	.front-page .section {
		font-size: 14px;
	}
	.front-page .section .container {
		padding: 0 10px;
	}
	.front-page .section__title .en {
		font-size: 16px;
	}
	.front-page .section__title .title {
		font-size: 34px;
	}
}

/* ------------------------------ */
/* .about */
/* ------------------------------ */

.front-page .about {
	text-align: center;
	background-image: url("../img/top/about_bg.png");
	background-repeat: no-repeat;
	background-position: center top 150px;
	padding: 150px 0 120px 0;
}
.front-page .about p {
	font-size: 22px;
	line-height: 1.6;
}
.front-page .about .about__btn {
	text-align: center;
	margin-top: 50px;
}
.front-page .about .about__btn img {
	display: inline;
}
@media (max-width: 1199px) {
	.front-page .about {
		background-size: 1000px;
	}
}

@media (max-width: 767px) {
	.front-page .about {
		background-image: url("../img/top/about_bg_sp.png");
		background-position: center top 270px;
		background-size: auto;
		padding: 100px 0 50px 0;
	}
	.front-page .about p {
		font-size: 16px;
	}
}

/* ------------------------------ */
/* .section__cloud */
/* ------------------------------ */

.section__cloud {
	background-image: url("../img/top/cloud_bg.png");
	background-repeat: repeat-x;
	background-position: center top;
	height: 630px;
}
.section__cloud .cloud {
	background-image: url("../img/top/cloud.png");
	background-repeat: repeat-x;
	background-position: left top;
	height: 140px;
}

@media (max-width: 767px) {
	.section__cloud {
		background-size: auto 550px;
		height: 500px;
	}
	.section__cloud .cloud {
		background-size: auto 60px;
	}
}

/* ------------------------------ */
/* .rules */
/* ------------------------------ */

.front-page .rules {
	background-color: #f4f4f4;
	padding: 180px 0;
}
.front-page .rules .row {
	display: flex;
	flex-wrap: wrap;
}
.front-page .rules .row .col-txt {
	width: 35%;
}
.front-page .rules .row .col-slider {
	width: 65%;
	overflow: hidden;
}
.front-page .slider-wrap {
	overflow: hidden;
}
.swiper-rules .swiper-slide dl {
	background-color: #e5f8f3;
	border: 2px solid var(--green);
	border-radius: 40px;
	padding: 40px 20px;
}
.swiper-rules .swiper-slide dl dt {
	text-align: center;
	height: 250px;
}
.swiper-rules .swiper-slide dl dd .en {
	display: flex;
	align-items: flex-end;
	font-size: 18px;
	font-weight: 500;
	line-height: 1;
}
.swiper-rules .swiper-slide dl dd .en img {
	display: block;
	height: 18px;
	margin: 0 0 0.1em 0.5em;
}
.swiper-rules .swiper-slide dl dd .title {
	font-size: 23px;
	font-weight: 700;
	color: var(--black);
	margin: 15px 0;
}
.swiper-rules .swiper-slide dl dd p {
	line-height: 1.6;
	margin: 0;
}
.swiper-rules .swiper-slide.slide_2 dl {
	background-color: #fceee5;
	border-color: var(--orange);
}
.swiper-rules .swiper-slide.slide_3 dl {
	background-color: #fefbeb;
	border-color: var(--yellow);
}

@media (min-width: 768px) {
	.front-page .rules .slider-wrap {
		background-color: #ffffff;
		border-radius: 40px;
	}
}
@media (max-width: 991px) {
	.front-page .rules .row .col-txt,
	.front-page .rules .row .col-slider {
		width: 50%;
	}
}
@media (max-width: 767px) {
	.front-page .rules {
		padding: 90px 0 100px 0;
	}
	.front-page .rules .container {
		max-width: 100%;
	}
	.front-page .rules .row {
		position: relative;
		padding-bottom: 70px;
	}
	.front-page .rules .row .col-txt,
	.front-page .rules .row .col-slider {
		width: 100%;
	}
	.front-page .rules .col-txt {
		text-align: center;
		margin-bottom: 40px;
	}
	.front-page .rules .row .col-slider {
		position: relative;
		width: calc(100% + 20px);
		margin: 0 -10px;
	}
	.front-page .rules .row .col-slider::after {
		position: absolute;
		left: 50%;
		transform: translateX(-50%);
		top: 0;
		content: "";
		width: calc(100% - 20px);
		height: 100%;
		background-color: #ffffff;
		border-radius: 40px;
	}
	.swiper-rules .swiper-slide dl {
		padding-bottom: 30px;
	}
	.swiper-rules .swiper-slide dl dt img {
		max-width: 195px;
	}
	.swiper-rules .swiper-slide dl dd .en {
		font-size: 16px;
	}
	.swiper-rules .swiper-slide dl dd .title {
		font-size: 18px;
	}
}

/* .swiper */

.swiper-rules {
	width: 390px;
	overflow: visible;
}
.swiper-rules .swiper-wrapper {
	padding: 90px 0 50px 0;
}
.swiper-rules .swiper-wrapper>* {
	display: flex;
	height: auto;
}
.swiper-rules .swiper-slide {
	padding: 0 20px;
	transition: 0.3s;
}

@media (min-width: 768px) {
	.front-page .rules .swiper-slide-active {
		transform: translateY(-20px);
	}
}

@media (max-width: 991px) {
	.swiper-rules {
		width: 90%;
	}
	.swiper-rules .swiper-slide {
		padding: 0 7px
	}
}
@media (max-width: 767px) {
	.swiper-rules {
		width: 85%;
		max-width: 330px;
	}
	.swiper-rules .swiper-wrapper {
		padding: 60px 0 0 0;
	}
	.front-page .rules .swiper-slide-active {
		transform: translateY(-30px);
	}
}

/* ------------------------------ */
/* ページネーション */
/* ------------------------------ */

/* 1. ページネーション全体の配置リセット（必要に応じて） */
.front-page .rules .swiper-pagination {
	position: relative !important;
	/* スライダーの下に置く場合 */
	bottom: 0 !important;
	margin: 0;
}

/* 2. ドット（数字）自体のリセットとスタイル設定 */
.front-page .rules .swiper-pagination-bullet {
	all: unset;
	/* 標準の丸いスタイルをすべて解除 */
	cursor: pointer;
	display: inline-block;
	margin: 0 10px !important;
	/* 数字同士の間隔 */

	/* 数字の見た目 */
	font-size: 16px;
	font-family: sans-serif;
	color: #999;
	/* 通常時の色 */
	transition: color 0.3s;
}

/* Swiperが強制付与する不透明度をリセット */
.front-page .rules .swiper-pagination-bullet {
	opacity: 1 !important;
}

/* カスタマイズ */
.front-page .rules .swiper-pagination {
	position: relative;
	display: flex;
}
.front-page .rules .swiper-pagination::after {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	content: "";
	width: calc(100% - 30px);
	height: 1px;
	background-color: #707070;
	z-index: 0;
}
.front-page .rules .swiper-pagination-bullet {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #ffffff;
	border: 2px solid #ffffff;
	border-radius: 50%;
	width: 32px;
	height: 32px;
	font-family: var(--en);
	font-weight: 500;
	line-height: 1;
	margin: 0 8px !important;
	z-index: 1;
}
.front-page .rules .swiper-pagination-bullet-active:nth-child(1) {
	background-color: #e5f8f3;
	border-color: var(--green);
}
.front-page .rules .swiper-pagination-bullet-active:nth-child(2) {
	background-color: #fceee5;
	border-color: var(--orange);
}
.front-page .rules .swiper-pagination-bullet-active:nth-child(3) {
	background-color: #fefbeb;
	border-color: var(--yellow);
}

/* ------------------------------ */
/* Swiperの矢印ボタン リセットCSS */
/* ------------------------------ */

/* 1. 本体（枠、背景、配置など）のリセット */
.front-page .rules .swiper-button-prev,
.front-page .rules .swiper-button-next {
	all: unset;
	/* 標準のスタイル（ボタンの枠線など）を解除 */
	position: static;
	/* デフォルトの absolute を解除（自由に配置可能に） */
	margin: 0;
	/* デフォルトの margin-top を解除 */
	width: auto;
	/* デフォルトの width (27px等) を解除 */
	height: auto;
	/* デフォルトの height (44px等) を解除 */
	cursor: pointer;
	/* divタグに変更したため、クリックできるカーソルを明示 */
	display: inline-block;
	/* 横並びにするなど、扱いやすいdisplayに変更 */
}
.front-page .rules .swiper-button-prev svg,
.front-page .rules .swiper-button-next svg {
	display: none !important;
}

/* 2. Swiper標準の「青い矢印アイコン」を消去（最重要） */
.front-page .rules .swiper-button-prev::after,
.front-page .rules .swiper-button-next::after {
	content: none;
	/* アイコンを完全に非表示にする */
}

/* 3. 無効時（最初/最後のスライド到達時）のスタイルリセット */
.front-page .rules .swiper-button-disabled {
	opacity: 0.3;
	/* デフォルトで薄くなるのを好みに変更可能（不要なら 1 に） */
	cursor: default;
	/* クリックできないカーソルにする */
	pointer-events: none;
	/* クリックイベントを無効化 */
}

/* カスタマイズ */
.front-page .rules .swiper-nav {
	position: relative;
	width: fit-content;
	padding: 0 60px;
	margin-top: 100px;
}
.front-page .rules .swiper-button-prev,
.front-page .rules .swiper-button-next {
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	background-color: #000000;
	border-radius: 50%;
	width: 48px;
	height: 48px;
}
.front-page .rules .swiper-button-next {
	left: auto;
	right: 0;
}
.front-page .rules .swiper-button-prev::after,
.front-page .rules .swiper-button-next::after {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	font-family: "Material Symbols Sharp";
	content: "\ef7d";
	color: #ffffff;
	font-size: 24px;
}
.front-page .rules .swiper-button-next::after {
	content: "\e941";
}

@media (max-width: 767px) {
	.front-page .rules .row {
		position: relative;
		padding-bottom: 80px;
	}
	.front-page .rules .swiper-nav {
		position: absolute;
		left: 50%;
		transform: translateX(-50%);
		bottom: 0;
	}
}

/* ------------------------------ */
/* .service */
/* ------------------------------ */

.front-page .service {
	background-color: #f4f4f4;
	margin-bottom: -1px;
}
.front-page .service .row {
	display: flex;
	flex-wrap: wrap;
}
.front-page .service .section__title .row {
	align-items: flex-end;
}
.front-page .service .section__title .row>* {
	width: 50%;
}
.front-page .service .service_bg {
	border-radius: 40px 40px 0 0;
	padding: 80px 0 90px 0;
}
.front-page .service .service_1 {
	background-color: var(--green);
}
.front-page .service .service_2 {
	background-color: var(--orange);
	background-image: url("../img/top/service_cloud.png");
	background-repeat: repeat-x;
	background-position: center bottom;
	margin-top: -40px;
	padding-bottom: 190px;
}
.front-page .service .service_bg .col_right {
	color: #ffffff;
}
.front-page .service .service_bg .col_right .logo {
	margin: 0 0 30px 0;
}
.front-page .service .service_bg .col_right .title {
	font-size: 20px;
	font-weight: 500;
	margin: 0 0 0.2em 0;
}
.front-page .service .service_bg .col_right .btn_more {
	margin-top: 25px;
}

@media (min-width: 768px) {
	.front-page .service .service_bg .row {
		margin: 0 -20px;
	}
	.front-page .service .service_bg .col_left {
		width: 60%;
		padding: 0 20px;
	}
	.front-page .service .service_bg .col_right {
		width: 40%;
		padding: 0 20px;
	}
}

@media (max-width: 767px) {
	.front-page .service .section__title .row>* {
		width: 100%;
		text-align: center;
	}
	.front-page .service .section__title .col_right {
		line-height: 1.8;
		margin-top: 20px;
	}
	.front-page .service .service_bg {
		padding: 50px 0 80px 0;
	}
	.front-page .service .service_2 {
		background-position: left 40% bottom;
		background-size: 200%;
		padding-bottom: 80px;
	}
	.front-page .service .service_bg .col_right .logo {
		text-align: center;
		margin: 20px 0 30px 0;
	}
	.front-page .service .service_bg .col_right .title {
		text-align: center;
	}
	.front-page .service .service_bg .col_right .btn {
		margin: 20px auto 0 auto;
	}
}

/* .swiper */
.front-page .service .swiper {
	position: relative;
	width: fit-content;
	height: 376px;
	padding-left: 40px;
	margin: 0;
}
.swiper-pagination-vertical.swiper-pagination-bullets,
.swiper-vertical>.swiper-pagination-bullets {
	right: auto;
	left: 0;
	top: 40%;
}
.front-page .service .swiper-pagination::after {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	content: "";
	width: 1px;
	height: calc(100% - 40px);
	background-color: var(--basic);
	z-index: 0;
}
.front-page .service .swiper-pagination-bullet {
	position: relative;
	background-color: var(--basic);
	margin: 20px 0;
	opacity: 1;
	z-index: 1;
}
.front-page .service .swiper-pagination-bullet-active {
	background-color: var(--yellow);
}

@media (max-width: 767px) {
	.front-page .service .swiper {
		aspect-ratio: 16 / 9;
		width: 100%;
		height: auto;
		padding-left: 20px;
	}
}

/* ------------------------------ */
/* .access */
/* ------------------------------ */

.front-page .access {
	background-color: #ffffff;
	padding: 70px 0 150px 0;
}
.front-page .access .section__title {
	position: relative;
	margin-bottom: 180px;
}
.front-page .access .row {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.front-page .access .img_wrap {
	position: relative;
}
.front-page .access .img_wrap .flag {
	position: absolute;
	left: 0;
	top: -135px;
}
.front-page .access .col_right .title {
	background-image: url("../img/top/access_dot.png");
	background-repeat: no-repeat;
	background-position: left top 0.4em;
	color: var(--black);
	font-size: 24px;
	font-weight: 500;
	line-height: 1.2;
	padding-left: 20px;
	margin: 0 0 15px 0;
}
.front-page .access .col_right p {
	line-height: 1.8;
}
.front-page .access .google_map {
	height: 275px;
}
.front-page .access .google_map iframe {
	width: 100%;
	height: 100%;
}

@media (min-width: 768px) {
	.front-page .access .row {
		margin: 0 -20px;
	}
	.front-page .access .row>* {
		width: 50%;
		max-width: 640px;
		padding: 0 20px;
	}
}

@media (max-width: 767px) {
	.front-page .access {
		padding: 110px 0 40px 0;
	}
	.front-page .access .section__title {
		margin-bottom: 150px;
	}
	.front-page .access .section__title .insect {
		position: absolute;
		right: 0;
		top: 50%;
		transform: translateY(-50%);
		width: 50%;
		max-width: 180px;
	}
	.front-page .access .row>* {
		width: 100%;
	}
	.front-page .access .img_wrap {
		margin: 0 -10px;
	}
	.front-page .access .img_wrap .flag {
		left: 10px;
		top: -80px;
		width: 220px;
	}
	.front-page .access .col_right .title {
		font-size: 20px;
		margin: 15px 0;
	}
	.front-page .access .google_map {
		height: 180px;
	}
}

/* ------------------------------ */
/* .text_slider */
/* ------------------------------ */

.text_slider {
	display: flex;
	overflow: hidden;
	border-top: 2px solid #d8d9d9;
	border-bottom: 2px solid #d8d9d9;
	padding: 12px 0 8px 0;
}
.text_slider ul {
	margin: 0;
	padding: 0;
	list-style-type: none;
	display: flex;
	animation: infinity-left 95s infinite linear 0.5s both;
}
.text_slider ul li {
	width: 649px;
	margin-right: 50px;
}
.text_slider ul li img {
	width: 100%;
}

@keyframes infinity-left {
	from {
		transform: translateX(0);
	}

	to {
		transform: translateX(-100%);
	}
}

/* ------------------------------ */
/* .contact */
/* ------------------------------ */

.front-page .contact {
	position: relative;
	background-color: var(--yellow);
	overflow: hidden;
	line-height: 1.6;
	padding: 130px 0 270px 0;
}
.front-page .contact>* {
	position: relative;
	z-index: 1;
}
.front-page .contact::after {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: 0;
	content: "";
	width: 4000px;
	height: 4000px;
	background-color: #ffffff;
	border-radius: 50%;
	z-index: 0;
}
.front-page .contact .row {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.front-page .contact .section__title {
	margin-bottom: 20px;
}
.front-page .contact .lead {
	border-top: 1px solid #666666;
	border-bottom: 1px solid #666666;
	padding: 30px 0;
	margin-bottom: 30px;
}
.front-page .contact p {
	margin-bottom: 0.5rem;
}
.front-page .contact strong {
	font-weight: 500;
}
.front-page .contact dl.tel dt {
	font-size: 20px;
	font-weight: 500;
}
.front-page .contact dl.tel dd a {
	display: block;
	width: fit-content;
	font-size: 40px;
	font-weight: 500;
	line-height: 1;
	border-bottom: 2px solid var(--basic);
	padding-bottom: 5px;
	margin: 5px 0 10px 0;
}
.front-page .contact ul li+li {
	margin-top: 10px;
}

@media (min-width: 768px) {
	.front-page .contact .row {
		margin: 0 -20px;
	}
	.front-page .contact .col_left {
		width: 40%;
		max-width: 430px;
		padding: 0 20px;
	}
	.front-page .contact .col_right {
		width: 60%;
		max-width: 720px;
		padding: 30px 20px 0 20px;
	}
}
@media (max-width: 991px) {
	.front-page .contact .row > * {
		width: 50%;
	}
	.front-page .contact .col_right .pc-only {
		display: none;
	}
	.front-page .contact .col_right .sp-only {
		display: inline;
	}
}

@media (max-width: 767px) {
	.front-page .contact {
		padding: 60px 0 120px 0;
	}
	.front-page .contact::after {
		width: 1500px;
		height: 1500px;
	}
	.front-page .contact .row>* {
		width: 100%;
		text-align: center;
	}
	.front-page .contact .lead {
		padding: 20px 0;
		margin-bottom: 20px;
	}
	.front-page .contact dl.tel {
		margin-top: 30px;
	}
	.front-page .contact dl.tel dt {
		font-size: 18px;
	}
	.front-page .contact dl.tel dd a {
		padding-bottom: 5px;
		margin: 5px auto 10px auto;
	}
	.front-page .contact ul li+li {
		margin-top: 20px;
	}
	.front-page .contact .col_left p:last-child {
		font-size: 12px;
	}
	.front-page .contact .col_left .sp-only ul li a img {
		margin: 0 auto;
	}
}

/* ------------------------------ */
/* .yellow_insect */
/* ------------------------------ */

.yellow_insect {
	position: relative;
	background-color: var(--yellow);
	background-image: url("../img/top/insect_img.png");
	background-repeat: no-repeat;
	background-position: center center;
	height: 740px;
	margin-bottom: -1px;
}
.yellow_insect img {
	position: absolute;
	left: calc(50% + 80px);
	top: -50px;
}

@media (max-width: 767px) {
	.yellow_insect {
		background-position: center top 130px;
		background-size: 660px;
		height: 350px;
	}
	.yellow_insect img {
		width: 95px;
		left: 50%;
		transform: translateX(-30%);
		top: -40px;
	}
}

/* ------------------------------ */
/* .company */
/* ------------------------------ */

.front-page .section.company {
	position: relative;
	background-color: #f4f4f4;
	background-image: url("../img/top/yellow_cloude.png");
	background-repeat: repeat-x;
	background-position: center top -1px;
	padding: 300px 0 200px 0;
	z-index: 1;
}
.front-page .company .inner {
	max-width: 1080px;
	margin: 0 auto;
}
.front-page .company .section__title {
	text-align: center;
}
.front-page .company__list dl {
	display: flex;
	flex-wrap: wrap;
	line-height: 1.6;
	border-bottom: 1px solid #666666;
	padding: 30px 0;
}
.front-page .company__list dl:last-child {
	border: none;
}
.front-page .company__list dl dd .title {
	position: relative;
	font-size: 24px;
	font-weight: 500;
	line-height: 1.4;
	margin: 0 0 10px 0;
	padding-left: 20px;
}
.front-page .company__list dl dd .title::before {
	position: absolute;
	left: 0;
	top: 0.6em;
	content: "";
	width: 7.5px;
	height: 7.5px;
	background-color: var(--green);
	border-radius: 50%;
}
.front-page .company__list dl:nth-child(2) dd .title::before {
	background-color: var(--orange);
}
.front-page .company__list dl:nth-child(3) dd .title::before {
	background-color: var(--yellow);
}
.front-page .company__list dl dd p {
	margin-bottom: 0.5rem;
}
.front-page .company__list dl dd ul li {
	display: inline-block;
}
.front-page .company__list dl dd ul li:nth-child(2) {
	margin-left: 2em;
}
.front-page .company__list dl dd ul li a {
	text-decoration: underline;
}
.front-page .company__list dl dd ul li:nth-child(2) a {
	color: var(--orange);
}
.front-page .company .insect_1 {
	position: absolute;
	left: calc(50% + 390px);
	top: 140px;
}
.front-page .company .insect_2 {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom: -150px;
}

@media (min-width: 768px) {
	.front-page .company__list dl>* {
		width: 50%;
	}
	.front-page .company__list dl dt img {
		transform: translate(-2%, -11%);
		margin-bottom: -3%;
	}
	.front-page .company__list dl dd {
		padding-left: 20px;
	}
}

@media (max-width: 1199px) {
	.front-page .company .insect_1 {
		left: auto;
		right: 15px;
	}
}

@media (max-width: 767px) {
	.front-page .section.company {
		background-size: 75px;
		padding: 140px 0 70px 0;
	}
	.front-page .company .section__title {
		text-align: left;
	}
	.front-page .company__list dl {
		padding: 10px 0 20px 0;
	}
	.front-page .company__list dl>* {
		width: 100%;
	}
	.front-page .company__list dl dd .title {
		font-size: 20px;
		margin: 15px 0 5px 0;
	}
	.front-page .company__list dl dd ul {
		text-align: center;
	}
	.front-page .company__list dl dd ul li:nth-child(2) {
		margin-left: 1em;
	}
	.front-page .company .insect_1 {
		left: auto;
		right: 15px;
		top: 110px;
		width: 120px;
	}
	.front-page .company .insect_2 {
		bottom: -100px;
		width: 60px;
	}
}

/* ------------------------------ */
/* .news */
/* ------------------------------ */

.front-page .news {
	position: relative;
	overflow: hidden;
	background-color: #f4f4f4;
	color: #ffffff;
	line-height: 1.4;
	padding: 330px 0 150px 0;
}
.front-page .news>* {
	position: relative;
	z-index: 1;
}
.front-page .news::after {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	top: 0;
	content: "";
	width: 4000px;
	height: 4000px;
	background-color: #3b4043;
	border-radius: 50%;
	z-index: 0;
}
.front-page .news .row {
	display: flex;
	flex-wrap: wrap;
}
.front-page .news .section__title .en,
.front-page .news .section__title .title {
	color: #ffffff;
}
.front-page .news__tab {
	max-width: 310px;
	background-color: #333333;
	border-radius: 20px;
	padding: 35px 40px;
}
.front-page .news__tab ul li {
	position: relative;
	cursor: pointer;
	padding-left: 20px;
	opacity: 0.5;
}
.front-page .news__tab ul li.active {
	opacity: 1;
}
.front-page .news__tab ul li::before {
	position: absolute;
	left: 0;
	top: 0.4em;
	content: "";
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background-color: var(--yellow);
}
.front-page .news__tab ul li.type-b::before {
	background-color: var(--green);
}
.front-page .news__tab ul li.day-service::before {
	background-color: var(--orange);
}
.front-page .news__tab__content {
	display: none;
}
.front-page .news__tab__content.active {
	display: block;
}
.front-page .news .btn {
	background-color: var(--yellow);
	margin-top: 60px;
}
.front-page .news .btn::after {
	color: var(--yellow);
}
.front-page .news .col_right ul li a {
	display: block;
	color: #ffffff;
}
.front-page .news .col_right dl {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}
.front-page .news .col_right dl dt {
	width: 30%;
}
.front-page .news .col_right dl dt .img_wrap {
	aspect-ratio: 21 / 9.5;
	border-radius: 20px;
	overflow: hidden;
}
.front-page .news .col_right dl dd {
	width: 70%;
	padding-left: 7%;
}
.front-page .news .col_right dl dd .category {
	position: relative;
	background-color: #333333;
	border-radius: 50px;
	width: fit-content;
	min-width: 240px;
	line-height: 1.2;
	padding: 5px 25px 5px 40px;
}
.front-page .news .col_right dl dd .category::before {
	position: absolute;
	left: 20px;
	top: 50%;
	transform: translateY(-50%);
	content: "";
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background-color: var(--yellow);
}
.front-page .news .col_right dl dd .category.service01::before {
	background-color: var(--green);
}
.front-page .news .col_right dl dd .category.service02::before {
	background-color: var(--orange);
}
.front-page .news .col_right dl dd .title {
	font-size: 16px;
	font-weight: 400;
	margin: 10px 0 5px 0;
}

@media (min-width: 768px) {
	.front-page .news .col_left {
		width: 33.33%;
		padding-right: 30px;
	}
	.front-page .news .col_right {
		width: 66.66%;
		padding-left: 5%;
		border-left: 1px dashed #ffffff;
	}
	.front-page .news__tab ul li+li {
		margin-top: 20px;
	}
	.front-page .news .col_right ul li+li {
		margin-top: 30px;
	}
}

@media (max-width: 991px) {
	.front-page .news .row>* {
		width: 50%;
	}
	.front-page .news .col_right dl dt {
		width: 100%;
		margin-bottom: 10px;
	}
	.front-page .news .col_right dl dd {
		width: 100%;
		padding: 0;
	}
}

@media (max-width: 767px) {
	.front-page .news {
		padding: 140px 0 40px 0;
	}
	.front-page .news::after {
		width: 1500px;
		height: 1500px;
	}
	.front-page .news .row>* {
		width: 100%;
	}
	.front-page .news__tab {
		max-width: 100%;
		padding: 20px 30px;
		margin: -10px 0 20px 0;
	}
	.front-page .news__tab ul li {
		display: inline-block;
		margin: 6px 15px 6px 0;
	}
	.front-page .news .col_right ul {
		display: flex;
		flex-wrap: wrap;
		margin: 0 -10px;
	}
	.front-page .news .col_right ul li {
		width: 50%;
		padding: 0 10px;
		margin: 0 0 40px 0;
	}
	.front-page .news .col_right dl dt .img_wrap {
		aspect-ratio: 3 / 2;
	}
	.front-page .news .col_right dl dd .category {
		font-size: 13px;
		min-width: auto;
		padding: 3px 13px 3px 23px;
	}
	.front-page .news .col_right dl dd .category::before {
		left: 10px;
		width: 7px;
		height: 7px;
	}
	.front-page .news .col_right dl dd .title {
		font-size: 14px;
	}
	.front-page .news .col_right dl dd .date {
		font-size: 16px;
	}
	.front-page .news .btn {
		margin: 0 auto;
	}
}

/* ------------------------------ */
/* .recruit */
/* ------------------------------ */

.front-page .recruit {
	background-color: #3b4043;
	padding: 130px 0 0 0;
}
.front-page .recruit .section__title {
	margin-bottom: 10px;
}
.front-page .recruit .section__title .title {
	margin-top: 10px;
}
.front-page .recruit a {
	display: block;
	text-align: center;
	width: fit-content;
	margin: 0 auto;
	background-image: url("../img/top/recruit_arrow.png");
	background-repeat: no-repeat;
	background-position: center bottom 15px;
	font-size: 16px;
	line-height: 1.8;
	padding-bottom: 70px;
}

@media (min-width: 768px) {
	.front-page .recruit {
		background-image: url("../img/top/recruit_bg.png");
		background-repeat: no-repeat;
		background-position: center bottom;
	}
}

@media (max-width: 767px) {
	.front-page .recruit {
		background-image: url("../img/top/recruit_bg_sp_1.png");
		background-repeat: no-repeat;
		background-position: center top;
		background-size: 100%;
		padding-top: 35vw;
	}
	.front-page .recruit .inner {
		background-image: url("../img/top/recruit_bg_sp_2.png");
		background-repeat: no-repeat;
		background-position: center bottom;
		background-size: 100%;
	}
	.front-page .recruit a {
		background-position: center bottom 30px;
		padding-bottom: 100px;
	}
}

/* ------------------------------ */
/* .loader */
/* ------------------------------ */

.loader {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: var(--yellow);
	z-index: 9999;
	transition: opacity 0.6s ease, visibility 0.6s ease;
	overflow: hidden;
	font-family: 'Comic Sans MS', 'Chalkboard SE', 'Marker Felt', 'Arial Rounded MT Bold', sans-serif;
}

.loader.is-loaded {
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
}

.image-container {
	position: relative;
	width: 100%;
	max-width: 1600px;
	/* 実際の画像の比率に合わせて調整してください（例：横1920px、縦600pxなら 1920/600） */
	aspect-ratio: 1920 / 600; 
	overflow: hidden;
	container-type: inline-size;
}

/* absolute inset-0 w-full h-full object-cover の代わり */
.img-background {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* absolute z-0 の代わり */
.patch-base {
	position: absolute;
	z-index: 0;
}

/* rounded-full の代わり */
.rounded-full {
	border-radius: 9999px;
}

/* absolute top-[34%] w-full flex justify-center text-black font-black tracking-[0.1em] z-10 select-none の代わり */
.loading-text-container {
	position: absolute;
	top: 34%;
	width: 100%;
	display: flex;
	justify-content: center;
	color: black;
	font-weight: 900;
	letter-spacing: 0.1em;
	z-index: 10;
	user-select: none;
	-webkit-user-select: none;
}

/* absolute z-10 の代わり */
.svg-container {
	position: absolute;
	z-index: 10;
}

/* --- アニメーション関連（元のまま） --- */

/* 波打ちアニメーション */
@keyframes wave {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(-15%); }
}

.char-wave {
	display: inline-block;
	animation: wave 1.2s ease-in-out infinite;
}

/* まばたきアニメーション */
@keyframes blink {
	0%, 94%, 100% { transform: scaleY(1); }
	97% { transform: scaleY(0.05); }
}

.eye-blink {
	animation: blink 4s infinite;
}

/* 文字ごとの微調整 */
.char-wrapper:nth-child(1) { transform: translateY(2%) rotate(-4deg); font-size: 1.1em; }
.char-wrapper:nth-child(2) { transform: translateY(-2%) rotate(2deg); font-size: 0.9em; }
.char-wrapper:nth-child(3) { transform: translateY(1%) rotate(-1deg); }
.char-wrapper:nth-child(4) { transform: translateY(3%) rotate(4deg); font-size: 1.05em; }
.char-wrapper:nth-child(5) { transform: translateY(-1%) rotate(-3deg); }
.char-wrapper:nth-child(6) { transform: translateY(1%) rotate(1deg); font-size: 0.95em; }
.char-wrapper:nth-child(7) { transform: translateY(-2%) rotate(-5deg); font-size: 1.1em; }

@media (max-width: 767px) {
	.image-container {
		position: absolute;
		left: 50%;
		top: 50%;
		transform: translate(-46%, -50%);
		width: 170%;
	}
}