@charset "utf-8";
/* CSS Document */

/*ヘッダー *****************************************************************/
.head-top .company-name h1 { font-size: inherit; }


/*メインビジュアル *****************************************************************/
#mv { align-items: center; height: 600px; }

/*テキストエリア --------------------*/
#mv .text-area { align-items: center; width: 55%; }
#mv .text-area .cont-wrap {
	flex-direction: column; gap: 48px 0; width: 80%; max-width: 568px; min-width: 328px; margin-left: 12%; padding: 72px 0 72px; color: #fff; }
/*キャッチコピーフレーズ、文章 -----*/
#mv .catch-phrase {
	margin-bottom: 20px; font-weight: bold; font-size: clamp(2.3rem, 1.6vw + 1.5rem, 3.1rem); white-space: nowrap; }
#mv .text-area .title .text {
	line-height: 2.8; white-space: nowrap; font-size: clamp(1.2rem, .5vw + 1rem, 1.8rem); }
/*王冠 -----*/
#mv .crown-box h3 {
	display: inline-block; margin-bottom: 24px; padding: 4px 3%; border-radius: var(--border-radius-s); background: #fff; font-size: var(--font-size-04); line-height: 1; white-space: nowrap; color: var(--color-toto); }
#mv .crown-list { gap: 0 2%; max-width: 504px; }
#mv .crown-item { aspect-ratio: 1; width: 28%; text-align: center; }
#mv .crown-item .bg-img {
	background-image: url("../images/crown.svg"); top: 12px; }
#mv .crown-item h4 {
	width: 100%; font-size: clamp(1rem, .3vw + 1rem, 1.4rem); position: absolute; top: 0; left: 50%; translate: -50% 0; }
#mv .crown-item.no1 h4 { line-height: 1.3; top: -8px; }
#mv .crown-item p {
	font-weight: bold; font-size: clamp(1.5rem, .6vw + 1rem, 1.8rem); white-space: nowrap; line-height: 1.3; position: absolute; top: 45%; left: 50%; translate: -50% -50%; }
#mv .crown-item p .strong {
	padding: 0 4px; font-size: var(--font-size-07); }

/*画像エリア --------------------*/
#mv .image-area { width: 45%; height: 100%; }

/*スライダー -----*/
#mv .slick-slider,
#mv .slick-list.draggable,
#mv .slick-slider .slick-track { height: 100%; }
#mv .slider img { display: block; height: 100%; object-fit: cover; }


@media (max-width: 960px) {
	#mv .text-area .crown-item p { top: 48%; }
	#mv .text-area { width: 52%; }
	#mv .image-area { width: 48%; }
}
@media (max-width: 767px) {
	#mv { flex-wrap: wrap; height: auto; }
	#mv .bg-img.wave { background-position: center 98%; }
	#mv .text-area,
	#mv .image-area { width: 100%; }
	#mv .text-area { order: 2; }
	#mv .text-area .cont-wrap {
		justify-content: center; gap: 40px 0; max-width: 400px; margin-left: auto; padding: 40px 0; }
	#mv .text-area .title { order: 2; }
	#mv .text-area .catch-phrase {
		margin-bottom: 4px; font-size: clamp(2.6rem, 2.3vw + 1.5rem, 3.1rem); }
	#mv .text-area .title .text { font-size: clamp(1.4rem, .8vw + 1.1rem, 1.6rem); }
	#mv .text-area .crown-box { order: 1; }
	#mv .crown-item { width: 32%; }
	#mv .crown-item h4 { background: #193289b3; }
	#mv .crown-item p { font-size: clamp(1.5rem, .6vw + 1rem, 2rem); }
	#mv .image-area { height: 280px; }
}
@media (max-width: 520px) {
	#mv .text-area .cont-wrap  { min-width: 312px; }
	#mv .text-area h3 { width: 100%; text-align: center; }
}





/*事業内容 *****************************************************************/
#service { overflow: hidden; }
#service .bg-img.wave { background-color: transparent; }
#service .bg-img01.wave { background-position: center 35%; }
#service .bg-img02.wave { background-position: bottom; }

#service .flex { justify-content: space-between; }
#service h3 {
	padding: 2px 8px; border-radius: var(--border-radius-s); background: var(--color-lbl-01); }
#service .cont-wrap { padding-top: 124px; padding-bottom: 176px; }
#service .inner { flex-wrap: wrap; gap: 80px 4%; }
#service .inner .list-item { width: 49%; }


/*タイトル --------------------*/
#service .title { width: 100%; }
#service .title { text-align: center; }
#service .title h2 .en { left: 50%; translate: -50% 0; }

/*サービス内容 --------------------*/
#service .service-list { width: 100%; position: relative; }
#service .service-list01 { margin-bottom: 60px; }
#service .service-list::before,
#service .service-list::after {
	content: ""; width: 80%; height: 12px; background: var(--color-lbl-01); position: absolute; z-index: -9; }
#service .service-list::before { top: 18%; left: -30%; }
#service .service-list::after { bottom: 10%; right: -50%; }
#service .service-list02::before { right: -30%; left: unset; }
#service .service-list02::after { right: unset; left: -50%; }
#service .service-list h3 {
	padding-left: 5.5rem; background: none; font-size: 1.3em; color: var(--color-toto); line-height: 1.3; position: relative; }
#service .service-list02 h3 { padding-left: 0; padding-right: 5.5rem; text-align: right; }
#service .service-list h3 .number {
	font-size: 6rem; color: #fff; position: absolute; left: 0; top: 50%; translate: 0 -50%; text-shadow: 2px 2px 0 #20b743, -2px -2px 0 #20b743, -2px 2px 0 #20b743, 2px -2px 0 #20b743, 0px 2px 0 #20b743,  0 -2px 0 #20b743, -2px 0 0 #20b743, 2px 0 0 #20b743; }
#service .service-list02 h3 .number { left: unset; right: 0; }

#service .navi-area { flex-direction: column; justify-content: space-around; width: 30%; }
#service .image-switch-nav { flex-wrap: wrap; gap: 8px 3%; }
#service .image-switch-nav .image {
	width: 48.5%; aspect-ratio: 1; overflow: hidden; position: relative; }
#service .image-switch-nav .image:not(.active) { cursor: pointer; }
#service .image-switch-nav .image:before,
#service .image-switch-nav .image:after {
	display: block; width: 100%; position: absolute; left: 0; transition: .5s; }
#service .image-switch-nav .image:before { content: ""; height: 100%; top: 0; z-index: 5; }
#service .image-switch-nav .image.active:before { background: #00000088; }
#service .image-switch-nav .image:after {
	content: ""; text-align: center; font-size: .8em; color: #fff; top: 50%; translate: 0 -50%; z-index: 9; }
#service .image-switch-nav .image.active:after { content: "表示中"; }
#service .image-switch-nav .image img { height: 100%; object-fit: cover; transition: .5s; }
#service .image-switch-nav .image:not(.active):hover img { height: 110%; }
#service .image-switch-area { width: 67%; height: 480px; position: relative; }
#service .image-switch-area .switch-image {
	width: 100%; height: 100%; opacity: 0; position: absolute; top: 0; left: 0; transition: .3s; } 
#service .image-switch-area .switch-image.active { opacity: 1; } 
#service .image-switch-area .switch-image img { height: 100%; object-fit: cover; }


/*対応エリア、製品 --------------------*/
#service .area { width: 25%; }
#service .products-list { width: 71%; }
#service .area h3,
#service .products-list h3 { margin-bottom: 16px; }
#service .area .item,
#service .products-list .list-item { align-items: center; padding: 12px 3%; }
#service .area .image,
#service .products-list .image { width: 56px; height: 56px; }
#service .area .bg-img,
#service .products-list .bg-img { z-index: 1; }
#service .area .text,
#service .products-list .text { width: calc(94% - 56px); }
/*対応エリア -----*/
#service .area .bg-img {
	background-image: url("../images/service-icon-map.svg"); }
#service .area .text { font-weight: bold; }
/*製品 -----*/
#service .products-list { flex-wrap: wrap; }
#service .products-list .list-item {
	background: #fff; border: 3px solid var(--color-lbl-01); border-radius: var(--border-radius-reg); }
#service .products-title { width: 100%; }
#service .products-list .item01 .bg-img {
	background-image: url("../images/service-icon-product01.svg"); }
#service .products-list .item02 .bg-img {
	background-image: url("../images/service-icon-product02.svg"); }

/*所属団体について --------------------*/
#service .affiliation { margin-top: 80px; }
#service .affiliation h3 {
	margin-bottom: 4px; padding: 0 0 0 56px; background: none; font-size: var(--font-size-05); color: var(--color-gr-01); position: relative; }
#service .affiliation h3::before {
	content: ""; display: block; width: 56px; height: 56px; background: url("../images/service-icon-right.svg") center / contain no-repeat; position: absolute; left: 0; top: 50%; translate: 0 -50%; }
#service .aff-list {
	padding: 32px 5% 48px; border-radius: var(--border-radius-reg); background: #fff; border: 2px solid var(--color-gy-01); }
#service .aff-list dl:first-child { margin-bottom: 24px; }
#service .aff-list dt {
	margin-bottom: 4px; padding-left: 1.5em; font-weight: bold; font-size: var(--font-size-04); color: var(--color-toto); position: relative; }
#service .aff-list dt::before {
	content: "■"; display: inline-block; position: absolute; left: 0; top: 0;  }
#service .aff-list dd {
	padding-left: 1.8em; text-align: justify; font-size: var(--font-size-03); }


@media (max-width: 1200px) {
	#service .image-switch-area { height: 400px; }
}
@media (max-width: 1100px) {
	#service .image-switch-area { height: 384px; }
}
@media (max-width: 960px) {
	#service .image-switch-area { height: 360px; }
}

@media (max-width: 767px) {
	#service .inner { justify-content: center; gap: 56px 0; }
	#service .title { width: 100%; }
	#service .area,
	#service .inner .list-item,
	#service .products-list { width: 100%; max-width: 480px; }

	#service .service-list { flex-wrap: wrap; gap: 16px 0; }
	#service .navi-area,
	#service .image-switch-area { width: 100%; }
	#service .navi-area { flex-direction: row; justify-content: space-between; align-items: center; }
	#service .service-list::before { top: 25%; }
	#service .service-list02 .navi-area { order: 1; }
	#service .service-list h3 { width: 176px; padding-left: 4.8rem; font-size: 1.2em; }
	#service .service-list h3 .number { font-size: 5.5rem; }
	#service .service-list02 h3 { order: 2; padding-left: 0; padding-right: 4.8rem; }
	#service .image-switch-nav { gap: 0 1%; width: calc(98% - 176px); }
	#service .service-list02 .navi-area .image-switch-nav { order: 1; }
	#service .image-switch-nav .image { width: 24%; }
	#service .image-switch-area { height: auto; aspect-ratio: 4 / 3; }
	#service .service-list02 .image-switch-area { order: 2; }

	#service .area h3,
	#service .products-list h3 { margin-bottom: 8px; }
	#service .products-list .list-item:last-child { margin-top: 12px; }
	#service .aff-list { padding: 24px 6% 32px; }
	#service .aff-list dl:first-child { margin-bottom: 40px; }
}

@media (max-width: 520px) {
	#service .bg-img01.wave { background-position: center 30%; }
	#service .navi-area { flex-wrap: wrap; gap: 16px; }
	#service .navi-area h3,
	#service .image-switch-nav { width: 100%; }
	#service .service-list01 { margin-bottom: 20px; }
	#service .service-list h3 { padding-left: 3.8rem; }
	#service .service-list02 h3 { order: 1; text-align: left; padding-right: 0; }
	#service .service-list h3 .number { font-size: 4rem; }
	#service .service-list02 h3 .number { left: 0; right: unset; }
	#service .service-list h3 br { display: none; }
	#service .service-list02 .navi-area .image-switch-nav { order: 2; }

}






/*サービスの流れ *****************************************************************/
#flow .cont-wrap { padding-top: 16px; }
#flow .flow-item { justify-content: space-between; }
#flow .flow-item .step-item.mark { padding: 0 3%; }
#flow .flow-item .step-item.text { padding-top: 0; padding-bottom: 96px; }
#flow .flow-item.step1 .step-item.text { padding-top: 24px; }
#flow .flow-item.step1 .step-item.mark { padding-top: 24px; }
#flow .flow-item.step4 .step-item.text { padding-bottom: 40px; }

/*ステップ --------------------*/
#flow .flow-item .mark {
	flex-direction: column; align-items: center; gap: 16px 0; width: 200px; color: #fff; position: relative; }
#flow .flow-item .mark .deco {
	padding-left: 7px; font-weight: bold; letter-spacing: .3em; }
#flow .flow-item .mark h3 { text-align: center; font-size: var(--font-size-reg); }
/*背景色 -----*/
#flow .flow-item .mark::before {
	content: ""; display: block; width: 100%; height: 101%; position: absolute; left: 0; top: 0; z-index: -5; }
#flow .flow-item.step1 .mark::before {
	background: linear-gradient(180deg, var(--color-gr-01) 0, #2dc676 100%); }
#flow .flow-item.step2 .mark::before {
	background: linear-gradient(180deg, #2dc676 0, #1bb69c 100%); }
#flow .flow-item.step3 .mark::before {
	background: linear-gradient(180deg, #1bb69c 0, #2498ae 100%); }
#flow .flow-item.step4 .mark::before {
	background: linear-gradient(180deg, #2498ae 0, var(--color-logo) 100%); }
/*背景矢印型の切り抜き -----*/
#flow .flow-item .mark::after {
	content: ""; display: inline-block; width: 100%; height: 48px; background: var(--color-lbl-02); clip-path: polygon(-1% 0, 50% 28px, 101% 0, 101% 16px, 50% 44px, -1% 16px); position: absolute; top: calc(100% - 88px); left: 0; z-index: 5; }
#flow .flow-item.step4 .mark::after { content: none; }
/*アイコン画像 -----*/
#flow .flow-item .mark .image { width: 40%; min-width: 40px; aspect-ratio: 1; }
#flow .flow-item .mark .bg-img { z-index: 1; }
#flow .flow-item.step1 .mark .bg-img { background-image: url("../images/icon-phone.svg"); }
#flow .flow-item.step2 .mark .bg-img { background-image: url("../images/icon-headset.svg"); }
#flow .flow-item.step3 .mark .bg-img { background-image: url("../images/icon-build.svg"); }
#flow .flow-item.step4 .mark .bg-img { background-image: url("../images/icon-wallet.svg"); }

/*本文 --------------------*/
#flow .flow-item .text { width: calc(96% - 200px); }
#flow .flow-item .text p { text-align: justify; }
#flow .flow-item .text .kakko::before { content: "（"; }
#flow .flow-item .text .kakko::after { content: "）"; display: inline-block; }
#flow .flow-item .text .caution { font-size: var(--font-size-02); }
#flow .flow-item.step1 .btn {
	align-items: center; flex-wrap: wrap; margin-top: 24px; gap: 8px 24px; }
#flow .flow-item.step1 .btn .telno a {
	font-weight: bold; font-size: var(--font-size-07); color: var(--color-gr-01); }
#flow .flow-item.step1 .btn .button { width: 248px; }
#flow .flow-item.step1 .btn .button a { padding: .9em 32px .9em 24px; text-align: left; }

@media (max-width: 767px) {
	#flow .flow-item .mark { width: 27%; }
	#flow .flow-item .text { width: 69%; }
}
@media (max-width: 520px) {
	#flow .flow-item .mark h3 { font-size: var(--font-size-02); }
	#flow .flow-item .mark h3 br { display: none; }
}
@media (max-width: 600px) {
	#flow .flow-item .mark::after { top: calc(100% - 88px); }
}
@media (max-width: 520px) {
	#flow .flow-item .step-item.mark { padding-top: 0; }
	#flow .flow-item .step-item.text { padding-bottom: 88px; }
	#flow .flow-item.step1 .step-item.mark { padding-top: 24px; }
}
@media (max-width: 428px) {
	#flow .flow-item.step1 .btn .telno a { font-size: var(--font-size-06); }
}






/*修正料金の仕組み ***********************************************************/
#fee .cont-wrap {
	min-width: 720px; margin-top: 64px; padding: 16px 0 40px; position: relative; }
#fee .bg-img { background-image: url("../images/bg-white-wave.webp"); }
#fee .inner { width: 90%; margin: 0 auto; }
#fee h2 { margin-bottom: 8px; font-size: var(--font-size-05); }
#fee .text-box {
	padding: 32px 5%; border-radius: var(--border-radius-reg); background: #fff; }
#fee .calc-box {
	justify-content: center; align-items: center; gap: 0 8px; margin-bottom: 24px; padding: 16px 3%; background: var(--color-lbl-01); font-weight: bold; }
#fee .answer { text-align: center; }
#fee .parts-list { align-items: center; }
#fee .calc-parts .item {
	padding: 8px 16px; border-radius: var(--border-radius-s); background: #fff; }
#fee .calc-parts .plus { padding: 6px; }
#fee .caution-list li { margin-bottom: 16px; text-align: justify; }
#fee .caution-list li:last-child { margin-bottom: 0; }
#fee .caution-list .kakko::before { content: "（"; }
#fee .caution-list .kakko::after { content: "）"; display: inline-block; }

@media (max-width: 767px) {
	#fee .cont-wrap { width: 100%; min-width: auto; max-width: none; }
	#fee .inner { width: 85%; }
	#fee .calc-parts .item { padding-right: 8px; padding-left: 8px; }
}
@media (max-width: 600px) {
	#fee h2 { text-align: center; }
	#fee .text-box { padding: 0; background: none; }
	#fee .calc-box { align-items: flex-start; background: none; }
	#fee .answer {
		padding: 8px 16px; border-radius: var(--border-radius-s); background: #fff; }
	#fee .equal { padding-top: 16px; font-size: var(--font-size-06); }
	#fee .calc-parts {
		padding: 16px; border-radius: var(--border-radius-s); background: var(--color-lbl-01); border: 4px solid #fff; }
	#fee .parts-list { flex-direction: column; }
	#fee .calc-parts .item { min-width: 112px; text-align: center; }
	#fee .caution-list { padding: 16px; background: #ffffff88; }
}






/*リンクボタンとフッター上の画像 **********************************************/
#end-cont { padding-top: 56px; }
#end-cont .link-area { justify-content: center; gap: 0 1%; margin-bottom: 120px; }
#end-cont .button { width: 40%; max-width: 256px; }
#end-cont .button a {
	padding-left: 24px; background: var(--color-logo); text-align: left; }
#end-cont .image-area {
	justify-content: space-between; gap: 0 8px; margin-bottom: 8px; }
#end-cont .image-area .bg-box { width: 25%; }
#end-cont .image-area .image02 { width: calc(50% - 16px); aspect-ratio: 1.2 / 1; }
#end-cont .image-area .image01 .bg-img {
	background-image: url("../images/end-cont-img01.webp"); }
#end-cont .image-area .image02 .bg-img {
	background-image: url("../images/end-cont-img02.webp"); }
#end-cont .image-area .image03 .bg-img {
	background-image: url("../images/end-cont-img03.webp"); }

@media (max-width: 428px) {
	#end-cont .link-area { flex-wrap: wrap; gap: 16px 0; }
	#end-cont .button { width: 84%; max-width: unset; }
	#end-cont .image-area { gap: 0 4px; }
	#end-cont .image-area .image01 { width: 35%; }
	#end-cont .image-area .image02 { width: calc(65% - 4px); }
	#end-cont .image-area .image03 { display: none; }
}
