/*
Thame Name:ペットシッター熊谷・鴻巣
Thame URL:
Description:
Author:Katayama
Version:1.0
*/

/*------------------------------------
開発用・border表示
------------------------------------*/
/*--
* {
	border: solid 1px var(--color_03);
}
--*/


/*------------------------------------
開発用・管理バーを半透明にする
------------------------------------*/
#wpadminbar {
	background: rgba(0, 0, 0, 0.3) !important;
	backdrop-filter: blur(6px);
	/* ぼかし */
	transition: background 0.3s ease;
}

/* hover時に少し濃くする */
#wpadminbar:hover {
	background: rgba(0, 0, 0, 0.8) !important;
}

/*------------------------------------
変数
------------------------------------*/
:root {
	--font-family_1: "Asap", "Zen Maru Gothic", sans-serif;
	--font-family_2: "Josefin Sans", sans-serif;
	--font-family_3: "Instrument Serif", sans-serif;

	--font-size_sss: 0.85rem !important;
	--font-size_ss: 0.95rem !important;
	--font-size_s: 1.05rem !important;
	--font-size_mm: 1.2rem !important;
	--font-size_m: 1.4rem !important;
	--font-size_l: 1.7rem !important;
	--font-size_ll: 2rem !important;
	--font-size_lll: 3rem !important;
	--font-size_llll: 4.5rem !important;

	--font-weight_s: 500;
	--font-weight_m: 600;
	--font-weight_l: 600;
	--font-weight_ll: 700;

	--color_00: #2a2320;
	/* 深いチャコールブラウン */
	--color_01: #3a2f2a;
	--color_02: #6c5a52;
	--color_03: #967c70;
	--color_04: #b59b8d;
	--color_05: #bfa89b;
	--color_06: #c3b0a4;
	--color_07: #d2c2b7;
	--color_08: #e9ded6;
	--color_09: #f3ebe5;
	--color_10: #fff9f4;

	--color_1: #c67f78;
	--color_2: #d69c96;
	--color_3: #dba8a2;
	--color_4: #ffeade;
	--color_5: #fff7f2;
	--color_6: #26A6A6;
	--color_7: #d9ae59;
	--color_f: #fff;
	--color_line: #72BF4E;
	--color_instagram: #CF2E92;
	--color_bs: #00000033;

	--shadow_01: 3px 3px 7px #00000033;
	--shadow_02: 2px 2px 5px #00000033;
	--shadow_03: 1px 1px 2px #00000033;
	--shadow_1: 3px 3px 7px #0000001A;
	--shadow_2: 2px 2px 5px #0000001A;
	--shadow_3: 1px 1px 2px #0000001A;

	--circle_1: 57% 43% 56% 44% / 41% 42% 58% 59%;
	--circle_2: 40% 60% 41% 59% / 50% 37% 63% 50%;
	--circle_3: 64% 36% 41% 59% / 50% 54% 46% 50%;
	--circle_4: 38% 62% 35% 65% / 63% 42% 58% 37%;

	--border_1: solid 2px var(--color_01);
	--border_2: solid 2px var(--color_04);
	--border_3: solid 2px var(--color_08);

	--radius_05: 5px;
	--radius_1: 10px;
	--radius_2: 20px;
	--radius_3: 30px;
	--radius_4: 40px;
	--radius_5: 50px;
	--radius_10: 100px;
	--radius_50: 50%;

	--flex_1: 100%;
	--flex_2: 47%;
	--flex_3: 32%;
	--flex_4: 22%;

	--ease_1: 0.2s ease-out;
	--ease_2: 0.4s ease-out;
	--ease_3: 0.6s ease-out;

	--bg_1: repeating-linear-gradient(-45deg, var(--color_2), var(--color_2) 2px, transparent 2px, transparent 5px);

}

@media screen and (max-width: 699px) {
	:root {
		--font-size_sss: 0.7rem !important;
		--font-size_ss: 0.8rem !important;
		--font-size_s: 0.9rem !important;
		--font-size_mm: 1.1rem !important;
		--font-size_m: 1.2rem !important;
		--font-size_l: 1.5rem !important;
		--font-size_ll: 1.8rem !important;
		--font-size_lll: 2.8rem !important;
		--font-size_llll: 4.3rem !important;
	}
}

/*------------------------------------
基本CSS
------------------------------------*/
*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	scroll-behavior: smooth;
	font-size: 100%;
}

body {
	background: var(--color_5);
	top: 0px !important;
	color: var(--color_00);
	font-family: var(--font-family_1);
	font-weight: var(--font-weight_s);
	letter-spacing: 0.1em;
	line-height: 2em;
	text-align: left;
}

body .no-scroll {
	overflow: hidden;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: var(--font-family_1);
}

h1,
h2,
h3 {
	font-weight: var(--font-weight_ll);
}

h4,
h5,
h6 {
	font-weight: var(--font-weight_l);
}

h2 {
	font-size: 2rem;
}

h3 {
	font-size: 1.3rem;
}

p,
i {
	font-family: var(--font-family_1);
	font-size: var(--font-size_s);
	color: var(--color_02);
	font-weight: var(--font-weight_s);
	letter-spacing: 0.05em;
	line-height: 1.8em;
}

ul,
ol {
	list-style: none;
}

a {
	color: inherit;
	text-decoration: none;
}

p a {
	text-decoration: underline;
}

img,
video {
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
}

table {
	line-height: 1.4em;
}

button,
input,
select,
textarea {
	font: inherit;
	color: inherit;
	background: none;
	border: none;
	outline: none;
}

/*------------------------------------
セクション
------------------------------------*/
.section-container_1 {
	position: relative;
	padding: 150px 0;
}

.section-container_2 {
	position: relative;
	padding: 100px 0;
}

@media screen and (max-width: 699px) {
	.section-container_1 {
		padding: 75px 0;
	}

	.section-container_2 {
		padding: 50px 0;
	}
}

/*------------------------------------
コンテンツの幅を制限する
------------------------------------*/
.wrapper {
	max-width: 1200px;
	height: auto;
	padding-left: 20px;
	padding-right: 20px;
	margin-left: auto;
	margin-right: auto;
}

.wrapper-wide {
	max-width: 1400px;
	height: auto;
	margin-left: auto;
	margin-right: auto;
}

.wrapper-fullwide {
	margin: 0 calc(50% - 50vw);
	width: 100vw;
	height: auto;
}

@media screen and (max-width: 699px) {

	.wrapper,
	.wrapper-wide {
		padding-left: 15px;
		padding-right: 15px;
	}
}

/*------------------------------------
コンテンツを中央縦積みにする
------------------------------------*/
.block-pack {
	display: block;
	margin: auto;
	text-align: center;
}

.block-item {
	margin: 200px auto;
	text-align: left;
}

.block-item:nth-child(1) {
	margin-top: 0;
}

.block-item:nth-last-child(1) {
	margin-bottom: 0;
}

@media screen and (max-width: 699px) {
	.block-item {
		margin: 100px auto;
	}
}

/*------------------------------------
コンテンツを横並びで配置
------------------------------------*/
.flex-pack {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 50px;
}

.flex-item {}

@media screen and (max-width: 699px) {
	.flex-pack {
		flex-wrap: wrap;
	}
}

/*------------------------------------
内包コンテンツを横並びにする時はこのクラスを付与する
------------------------------------*/
.flex {
	display: flex;
	justify-content: center;
	align-items: center;
}

/*------------------------------------
背景パターン
------------------------------------*/
.pattern_1 {
	background: var(--color_5);
	background-image:
		radial-gradient(circle, var(--color_4) 1.5px, transparent 1.5px),
		radial-gradient(circle, var(--color_4) 1.5px, transparent 1.5px);
	background-position: 0 0, 3px 3px;
	background-size: 6px 6px;
	background-repeat: repeat;
}


/*------------------------------------
見出し・大
------------------------------------*/
.section-title_1 {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, -50%);
	margin-left: 15px;
	text-align: center;
}

.section-title_1 h2 {
	margin-left: 20px;
	font-size: 80px;
	color: var(--color_f);
	font-family: var(--font-family_2);
	font-weight: var(--font-weight_s);
	line-height: 1.5em;
	letter-spacing: 0.3em;
	text-shadow: var(--shadow_01);
}

.section-title_1 p {
	font-size: var(--font-size_mm);
}

.section-title_2 {
	justify-content: center;
	gap: 15px;
	margin: 0 auto 50px auto;
	padding-right: 50px;
}

.section-title_2 .icon i {
	font-size: 65px;
	color: var(--color_01);
}

.section-title_2 .icon img {
	width: 65px;
}

.section-title_2 p {
	text-align: center;
	font-family: var(--font-family_2);
	font-weight: var(--font-weight_l);
	color: var(--color_2);
}

.section-title_2 h2 {
	font-size: 35px;
	letter-spacing: 0.1em;
	line-height: 1.5em;
}

.section-title_3 {
	margin: 0 auto 25px auto;
	padding: 25px 15px 0px;
	text-align: center;
}

.section-title_3 span {
	color: var(--color_1);
	font-family: var(--font-family_2);
	font-weight: var(--font-weight_l);
}

.section-title_3 h3 {
	font-size: var(--font-size_l);
}

.section-title_3 p {
	margin-top: 10px !important;
	font-size: var(--font-size_sss);
	line-height: 1.5em !important;
}

.section-title_4 {
	position: relative;
	text-align: center;
	margin: 0 auto 25px auto;
}

.section-title_4 span {}

.section-title_4 h2 {
	font-size: var(--font-size_ll);
}

.section-title_4 p {
	margin-top: 15px;
	font-size: var(--font-size_ss);
}

.section-title_5 {
	position: relative;
	margin: 0 auto 25px auto;
}

.section-title_5 span {
	font-size: var(--font-size_mm);
	color: var(--color_1);
}

.section-title_5 h3 {
	font-size: var(--font-size_l);
}

/*見出しの補足テキスト*/
.title-note {
	margin-bottom: 15px;
	text-align: center;
}

.title-note p {
	font-size: var(--font-size_ss);
}

@media screen and (max-width: 699px) {
	.section-title_1 h2 {
		margin-left: 5px;
		font-size: 40px;
	}

	.section-title_2 {
		margin: 0 auto 25px auto;
	}

	.section-title_2 .icon i {
		font-size: 45px;
	}

	.section-title_2 .icon img {
		width: 45px;
	}

	.section-title_2 .text {}

	.section-title_2 span {}

	.section-title_2 h2 {
		font-size: 25px;
	}

	.section-title_3 h2 {
		font-size: 25px;
	}

	.section-title_4 h2 {
		font-size: var(--font-size_l);
	}

	.section-title_4 p {}
}

/*------------------------------------
見出し・小
------------------------------------*/
.title_l {
	font-size: 100px;
	line-height: 1.5em;
}

.title_m {
	font-size: 65px;
	line-height: 1.5em;
}

.title_s {
	font-size: 30px;
	line-height: 1.5em;
}

.box-title_1 {
	position: absolute;
	top: 0;
	left: 25px;
	transform: translateY(-50%);
	padding: 5px 25px;
	font-size: var(--font-size_mm);
	color: var(--color_f);
	background: var(--color_2);
	border-radius: var(--radius_5);
}

@media screen and (max-width: 699px) {
	.title_l {
		font-size: 45px;
	}

	.title_m {
		font-size: 35px;
	}

	.title_s {
		font-size: 20px;
	}

	.box-title {
		font-size: var(--font-size_s);
	}
}

/*------------------------------------
画像トリミング
------------------------------------*/
.frame_1 {
	border-radius: var(--radius_2);
	overflow: hidden;
}

/*------------------------------------
リストデザイン
------------------------------------*/
/*リストデザイン1*/
.list_1 {
	position: relative;
	margin: 10px auto;
	padding: 40px;
	font-size: var(--font-size_ss);
	line-height: 2em;
	background: var(--color_10);
	overflow: hidden;
}

.list_1 h4 {
	margin-bottom: 5px;
	font-size: var(--font-size_mm);
	color: var(--color_1);
}

/*フローチャート*/
.list-flow-pack {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 50px;
}

.list-flow-item {
	position: relative;
	width: 100%;
	padding: 35px 25px;
	border: solid 3px var(--color_1);
	border-radius: var(--radius_2);
}

.list-flow-item .number {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 45px;
	height: 45px;
	position: absolute;
	top: 0;
	left: 0;
	transform: translate(-50%, -50%);
	font-size: var(--font-size_mm);
	color: var(--color_f);
	background: var(--color_1);
	border-radius: var(--radius_5);
}

.list-flow-item::before {
	content: '';
	position: absolute;
	bottom: -15px;
	left: 50%;
	transform: translate(-50%, 0);
	width: 35px;
	height: 20px;
	background: var(--color_3);
	clip-path: polygon(0 0, 100% 0, 50% 100%);
}

.list-flow-item:nth-last-child(1)::before {
	display: none;
}

.list-flow-item:nth-last-child(1) {
	padding: 10px;
	background: var(--color_1);
	border-radius: var(--radius_5);
}

.list-flow-item:nth-last-child(1) p {
	font-size: var(--font-size_m);
	font-weight: var(--font-weight_l);
	color: var(--color_f);
}

@media screen and (max-width: 799px) {
	.list-flow-pack {
		gap: 25px;
	}
}


/*------------------------------------
表デザイン
------------------------------------*/
/*表2列・3列*/
.table_2,
.table_3 {
	flex-wrap: wrap;
	gap: 10px;
	margin: 15px auto;
}

.table_2 .row-header,
.table_2 .row,
.table_3 .row-header,
.table_3 .row {
	gap: 10px;
	width: 100%;
}

.table_2 .row-header,
.table_3 .row-header {
	padding-bottom: 5px;
	border-bottom: solid 2px var(--color_03);
}

.table_2 .row-header p,
.table_3 .row-header p {
	font-weight: var(--font-weight_m);
}

.table_2 .row,
.table_3 .row {
	padding: 5px 0;
	border-bottom: dotted 1px var(--color_03);
}

.table_2 .cell {
	width: calc((100% - 15px) / 2);
}

.table_3 .cell {
	width: calc((100% - 30px) / 3);
}

.table_2 .cell,
.table_3 .cell p {}

.table_2 .cell:nth-child(1) p,
.table_3 .cell:nth-child(1) p {}

.table_2 .cell:nth-child(2) p,
.table_3 .cell:nth-child(2) p {}

.table_2 .cell:nth-child(3) p,
.table_3 .cell:nth-child(3) p {}

.table_2 .note,
.table_3 .note {
	margin-top: 15px;
}

.table_2 .note p,
.table_3 .note p {
	font-size: var(--font-size_ss);
}

@media screen and (max-width: 799px) {

	.table_2,
	.table_3 {}

	.table_2 .row-header,
	.table_2 .row,
	.table_3 .row-header,
	.table_3 .row {}

	.table_2 .row-header,
	.table_3 .row-header {}

	.table_2 .row-header p,
	.table_3 .row-header p {
		font-size: var(--font-size_ss);
		font-weight: var(--font-weight_m);
	}

	.table_2 .row,
	.table_3 .row {}

	.table_2 .cell {
		width: calc((100% - 15px) / 2);
	}

	.table_3 .cell {
		width: calc((100% - 30px) / 3);
	}

	.table_2 .cell p,
	.table_3 .cell p {
		font-size: var(--font-size_s);
	}

	.table_2 .cell:nth-child(1) p,
	.table_3 .cell:nth-child(1) p {}

	.table_2 .cell:nth-child(2) p,
	.table_3 .cell:nth-child(2) p {}

	.table_2 .cell:nth-child(3) p,
	.table_3 .cell:nth-child(3) p {}

	.table_2 .note,
	.table_3 .note {
		margin-top: 15px;
	}

	.table_2 .note p,
	.table_3 .note p {
		font-size: var(--font-size_ss);
	}
}

/*------------------------------------
グリッドレイアウト
------------------------------------*/
.grid-pack {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	grid-auto-rows: 50px;
	gap: 100px;
}

.grid-item {
	flex-wrap: wrap;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.grid-item img {
	width: 100%;
	height: 100%;
}

.grid-item-inner {
	padding: 50px;
}

@media screen and (max-width: 699px) {
	.grid-pack {
		display: flex;
		flex-wrap: wrap;
		gap: 50px;
	}

	.grid-item img {
		height: 100%;
	}

	.grid-item-inner {
		padding: 0px;
	}
}

/*------------------------------------
切り替えタブ
------------------------------------*/
.tabs {
	max-width: 100%;
}

.tab-list {
	display: none;
}

.tab-item {}

.tab-content {
	display: flex;
	gap: 30px;
}

.tab-panel {
	display: block;
	width: calc(100% / 3 - 20px);
	min-height: 350px;
	padding: 10px;
	background-color: var(--color_f);
}

/* タブアクティブ状態の見た目をPCでも使う場合は残しておく */
.tab-item.active {
	background: var(--color_2);
	color: var(--color_f);
	font-weight: bolder;
}

.tab-panel h2 {
	font-size: var(--font-size_ll);
}

@media screen and (max-width: 799px) {
	.tabs {
		max-width: 100%;
	}

	.tab-list {
		display: flex;
		gap: 3px;
	}

	.tab-item {
		width: calc(100% / 3);
		text-align: center;
		font-size: var(--font-size_s);
		white-space: nowrap;
		color: var(--color_f);
		border-radius: 5px 5px 0 0;
		background: var(--color_07);
		padding: 10px 0;
		cursor: pointer;
	}

	.tab-content {
		display: block;
	}

	.tab-panel {
		display: none;
		width: 100%;
		padding: 25px 15px;
		border-top: solid 5px var(--color_5);
	}

	.tab-panel h4 {}

	.tab-panel.active {
		display: block;
	}

	.tab-panel h2 {
		font-size: 20px;
	}
}


/*------------------------------------
ボタンデザイン
------------------------------------*/
/*ベタ塗り丸ボタン*/
.btn-pack {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 25px;
}

.btn-pack .btn_1,
.btn-pack .btn_2,
.btn-pack .btn_3 {
	margin: 35px 0 0 0;
}

.btn_1,
.btn_2,
.btn_3 {
	position: relative;
	display: flex;
	justify-content: center;
	margin: 35px auto 0 auto;
	width: 250px;
}

.btn_1 i,
.btn_2 i,
.btn_3 i {
	position: absolute;
	top: 50%;
	left: 20px;
	transform: translateY(-50%);

}

.btn_1 a,
.btn_2 a,
.btn_3 a {
	width: 100%;
	text-align: center;
	font-size: var(--font-size_s);
	font-weight: var(--font-weight_l);
	color: var(--color_f);
	text-shadow: var(--text-shadow_1);
	background: var(--color_01);
	padding: 5px 40px;
	border: solid 1px var(--color_01);
	border-radius: var(--radius_5);
	transition: 0.3s ease-out;
}

.btn_1 a::before::after,
.btn_2 a::before::after,
.btn_3 a::before::after {
	content: '';
	position: absolute;
}

.btn_1 a::before,
.btn_1 a:after,
.btn_2 a::before,
.btn_2 a:after,
.btn_3 a::before,
.btn_3 a:after {
	position: absolute;
	content: '';
	width: 8px;
	height: 1px;
	background: var(--color_f);
	transition: var(--ease_2);
}

.btn_1 a::before,
.btn_2 a::before,
.btn_3 a::before {
	top: 45%;
	right: 20px;
	transform: rotate(45deg);
}

.btn_1 a::after,
.btn_2 a::after,
.btn_3 a::after {
	top: 54%;
	right: 20px;
	transform: rotate(-45deg);
}

.btn_1 a:hover,
.btn_2 a:hover,
.btn_3 a:hover {
	color: var(--color_01);
	text-shadow: none;
	background: rgba(0, 0, 0, 0);
}

.btn_1 a:hover::before,
.btn_2 a:hover::before,
.btn_3 a:hover::before {
	background: var(--color_01);
	transform: rotate(45deg) translate(5px, -5px);
}

.btn_1 a:hover::after,
.btn_2 a:hover::after,
.btn_3 a:hover::after {
	background: var(--color_01);
	transform: rotate(-45deg) translate(5px, 5px);
}

/*ベタ塗り丸ボタン(red)*/
.btn_2 {}

.btn_2 i {}

.btn_2 a::before::after {}

.btn_2 a::before,
.btn_2 a:after {}

.btn_2 a::before {}

.btn_2 a::after {}

.btn_2 a {
	background: var(--color_2);
	border: solid 1px var(--color_2);
}

.btn_2 a:hover {
	color: var(--color_2);
}

.btn_2 a:hover::before {
	background: var(--color_2);
}

.btn_2 a:hover::after {
	background: var(--color_2);
}

/*ベタ塗り丸ボタン(write)*/
.btn_3 {}

.btn_3 i {}

.btn_3 a::before::after {}

.btn_3 a::before,
.btn_3 a:after {
	background: var(--color_00);
}

.btn_3 a::before {}

.btn_3 a::after {}

.btn_3 a {
	color: var(--color_00);
	background: none;
	border: solid 1px var(--color_00);
}

.btn_3 a:hover {
	color: var(--color_f);
	background: var(--color_00);
}

.btn_3 a:hover::before,
.btn_3 a:hover::after {
	background: var(--color_f);
}

/*下線ボタン*/
.btn_4 {
	position: relative;
	display: flex;
	justify-content: center;
	margin: 15px auto 0px auto;
	width: 250px;
}

.btn_4 a::before::after {
	content: '';
	position: absolute;
}

.btn_4 a::before,
.btn_4 a:after {
	position: absolute;
	content: '';
	width: 8px;
	height: 1px;
	background: var(--color_05);
	border-radius: var(--radius_5);
	transition: var(--ease_2);
}

.btn_4 a::before {
	top: 46%;
	right: 20px;
	transform: rotate(45deg);
}

.btn_4 a::after {
	top: 54%;
	right: 20px;
	transform: rotate(-45deg);
}

.btn_4 a {
	width: 100%;
	text-align: center;
	color: var(--color_00);
	padding: 10px 20px;
	font-size: var(--font-size_s);
	letter-spacing: 0.3em;
	border-bottom: solid 1px var(--color_00);
	transition: var(--ease_2);
}

.btn_4 a:hover {
	color: var(--color_05);
	text-shadow: none;
}

.btn_4 a:hover::before {
	background: var(--color_05);
	transform: rotate(45deg) translate(5px, -5px);
}

.btn_4 a:hover::after {
	background: var(--color_05);
	transform: rotate(-45deg) translate(5px, 5px);
}

/*小さな枠ボタン*/
.btn_5 {
	position: relative;
	display: flex;
	justify-content: center;
	margin: 25px auto 0px auto;
}

.btn_5 a {
	position: relative;
	display: block;
	width: 250px;
	text-align: center;
	font-size: var(--font-size_ss);
	border: solid 1px var(--color_1);
	padding: 5px 10px;
	transition: var(--ease_2);
}

.btn_5 a:hover {
	color: var(--color_2);
	background: var(--color_09);
}

/*------------------------------------
アコーディオン
------------------------------------*/
.accordion-area {
	list-style: none;
	width: 100%;
	margin: 0 auto;
}

.accordion-area .accordion-list {
	margin: 25px auto;
	background: var(--color_f);
	border-radius: var(--radius_2);
	box-shadow: var(--shadow_2);
}

.accordion-area section {
	border: 1px solid var(--color_05);
}

.accodion-title {
	position: relative;
	cursor: pointer;
	padding: 20px 40px 20px 15px;
	border-radius: var(--radius_5);
	transition: var(--ease_1);
	_
}

.accodion-title::before,
.accodion-title::after {
	position: absolute;
	content: '';
	width: 10px;
	height: 2px;
	background: var(--color_02);
	transition: var(--ease_2);
}

.accodion-title::before {
	top: 48%;
	right: 20px;
	transform: rotate(-45deg);
}

.accodion-title::after {
	top: 48%;
	right: 26px;
	transform: rotate(45deg);
}

.accodion-title.close::before {
	transform: rotate(0deg);
}

.accodion-title.close::after {
	transform: rotate(-0deg);
}

.accodion-title h3 {
	line-height: 2em;
	font-size: var(--font-size_s);
}

.accodion-title h3 span {
	margin-right: 10px;
	font-size: var(--font-size_l);
	color: var(--color_2);
}

.box {
	max-height: 0;
	overflow: hidden;
	transition: var(--ease_2);
}

.box-content {
	padding: 10px 40px 30px 30px;
}

.box-content span {
	padding-right: 10px;
	font-size: var(--font-size_l);
	color: var(--color_6);
}

.box-content .list_1 li {
	list-style: '△';
	text-indent: 0.5cap;
}

.close-btn {
	display: block;
	margin: 30px auto 0;
	padding: 8px 20px 8px 25px;
	color: var(--color_f);
	background: var(--color_01);
	border: none;
	cursor: pointer;
	position: relative;
	font-size: var(--font-size_sss);
	letter-spacing: 0.1em;
	line-height: 1.5;
	text-align: center;
	width: 100px;
}

.close-btn::before,
.close-btn::after {
	content: '';
	position: absolute;
	top: 50%;
	left: 15px;
	width: 10px;
	height: 2px;
	background: var(--color_f);
	transform: translateY(-50%);
}

.close-btn::before {
	transform: translateY(-50%) rotate(45deg);
}

.close-btn::after {
	transform: translateY(-50%) rotate(-45deg);
}

/*------------------------------------
パララックス
------------------------------------*/
.parallax-container {
	position: relative;
	overflow: hidden;
	aspect-ratio: 16 / 9;
	width: 100%;
	height: 100%;
}

.parallax-inner {
	position: absolute;
	inset: -15% 0 -15% 0;
	will-change: transform;
	transform: translate3d(0, 0, 0);
}

.parallax-inner>img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	backface-visibility: hidden;
	-webkit-transform: translateZ(0);
}

@media screen and (max-width: 699px) {}

/*------------------------------------
SNSアイコン横並び
------------------------------------*/
.icon-list {
	gap: 20px;
	margin: 25px auto;
}

.icon-list a {
	display: flex;
	align-items: center;
	padding: 15px;
	background: var(--color_03);
	border-radius: var(--radius_5);
}

.icon-list .line {
	background: var(--color_line);
}

.icon-list .instagram {
	background: var(--color_instagram);
}

.icon-list .mail {
	background: var(--color_02);
}

.icon-list i {
	font-size: 20px;
	color: var(--color_f);
}

.icon-list img {
	width: 30px;
}

/*------------------------------------
枠パーツ
------------------------------------*/
/*ボックス1*/
.box_1 {
	position: relative;
	width: 100%;
	height: 100%;
	padding: 50px;
	background: var(--color_f);
	border-radius: var(--radius_2);
	outline: dotted 2px var(--color_08);
	outline-offset: -7px;
	box-shadow: var(--shadow_2);
}

/*ボックス2*/
.box_2 {
	position: relative;
	width: 100%;
	height: 100%;
	padding: 25px 15px;
	background: var(--color_f);
	border: solid 3px var(--color_2);
	border-radius: var(--radius_2);
}

/*ボックス3*/
.box_3 {
	position: relative;
	width: 100%;
	height: 100%;
	padding: 25px 15px;
}

/*ボックス4*/
.box_4 {
	position: relative;
	width: 100%;
	height: auto;
	padding: 25px 15px;
}

/*ボックス5(枠なし・見出しとテキストのみ中央に配置)*/
.box_5 {
	margin: 50px auto;
}

.box_5 h3 {
	font-size: var(--font-size_mm);
}

.box_5 p {
	margin-top: 30px;
}

/*補足テキスト*/
.note {
	margin-top: 25px;
	padding: 15px;
	background: var(--color_5);
}

.note p {
	font-size: var(--font-size_sss);
}

@media screen and (max-width: 699px) {
	.box_1 {
		padding: 50px 20px;
	}

	.box_5 {
		margin: 25px auto;
	}

	.box_5 h3 {}

	.box_5 p {
		margin-top: 20px;
	}

	.sticky {
		position: fixed;
		top: 0px;
	}
}

/*------------------------------------
stycky
------------------------------------*/
.sticky {
	position: sticky;
	top: 0px;
	z-index: 103;
	pointer-events: none;
}

@media screen and (max-width: 699px) {
	.sticky {
		position: fixed;
		top: 0px;
	}
}

/*------------------------------------
テキストアニメーションの改行を防止
------------------------------------*/
.word {
	display: flex;
	margin-right: 1rem;
}


/*------------------------------------ここからヘッダーコンテンツ------------------------------------*/


/*------------------------------------
header
------------------------------------*/
#header {
	margin: 0 auto;
}

/*メインロゴ*/
#header .header-logo {
	position: fixed;
	top: 15px;
	left: 25px;
	z-index: 10;
	opacity: 0;
	visibility: hidden;
	transition: none;
}

#header .header-logo a {
	display: flex;
	align-items: center;
	justify-content: center;
}

#header .header-logo img {
	width: 200px;
	height: auto;
	transition: var(--ease_2);
}

@media screen and (max-width: 699px) {
	#header .header-logo {
		position: absolute;
		top: 0px;
		left: 0px;
		padding: 10px 25px 15px 10px;
		background: var(--color_10);
		border-radius: 0 0 15px 0;
	}

	#header .header-logo::after {
		content: '';
		position: absolute;
		top: -3px;
		left: -3px;
		width: 100%;
		height: 100%;
		border: dotted 2px var(--color_07);
		border-radius: 0 0 15px 0;
	}

	#header .header-logo a {}

	#header .header-logo img {
		width: 175px;
		z-index: 11;
	}
}

/*------------------------------------
スマホナビ・コンテンツ
------------------------------------*/
.nav {}

#navi {
	position: fixed;
	top: 0;
	right: -10%;
	width: 100%;
	height: 100vh;
	opacity: 0;
	padding: 75px;
	background: var(--color_5);
	transition: var(--ease_2);
	pointer-events: none;
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	z-index: 100;
}

/*メニューオープン時*/
.nav_open #navi {
	right: 0;
	opacity: 1;
	pointer-events: all;
}

/*スマホナビ展開時の背景*/
.overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	opacity: 0;
	background: var(--color_00);
	cursor: pointer;
	transition: var(--ease_1);
	visibility: hidden;
	z-index: 10;
}

.nav_open .overlay {
	opacity: 0.8;
	visibility: visible;
	z-index: 99;
}

/*ここからスマホナビ・コンテンツ*/
#navi .navi-container {
	align-items: start;
	gap: 50px;
	height: 100%;
}


#navi .navi-left,
#navi .navi-right {}

/*スマホナビ・左半分*/
#navi .navi-left {
	width: calc(40% - 25px);
	height: 100%;
}

#navi .navi-left img {
	width: 200px;
}

/*スマホナビ・右半分*/
#navi .navi-right {
	width: calc(60% - 25px);
}

/*スマホナビ・メインメニュー*/
#navi .menu {}

#navi .menu .navi-pack {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
}

#navi .menu .navi-item {
	display: block;
	cursor: pointer;
	position: relative;
	text-align: left;
	width: 100%;
	padding-bottom: 25px;
	line-height: 1.5em;
}

#navi .menu .navi-item::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 1px;
	background: var(--color_01);
}

#navi .menu .navi-item p {
	position: relative;
	font-family: var(--font-family_1);
	font-size: var(--font-size_ll);
	font-weight: var(--font-weight_l);
}

#navi .menu .navi-item span {
	color: var(--color_1);
}

/*スマホナビ・展開メニュー*/
#navi .menu .submenu {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	max-height: 0;
	padding: 0 30px;
	overflow: hidden;
	transition: all 0.5s ease-out;
}

#navi .menu .submenu.open {
	max-height: 500px;
	padding: 30px;
}

#navi .menu .submenu li {
	width: 100%;
	padding-bottom: 15px;
	border-bottom: none;
}

#navi .menu .submenu a {
	width: 100%;
}

#navi .menu .submenu img {
	width: 30%;
}

#navi .menu .submenu .sub-caption {
	width: 70%;
}

#navi .menu .submenu p {
	position: relative;
	font-family: var(--font-family_1);
	font-size: var(--font-size_l);
	font-weight: var(--font-weight_l);
}

#navi .menu .submenu span {
	font-size: var(--font-size_ss);
}

#navi .menu .sub-toggle {
	position: absolute;
	top: 30px;
	right: 40px;
}

#navi .menu .sub-toggle span {
	background-color: var(--color_00);
	height: 2px;
	position: absolute;
	transition: 0.6s ease-out;
	width: 15px;
}

#navi .menu .sub-toggle span:nth-child(1) {}

#navi .menu .sub-toggle span:nth-child(2) {
	transform: rotate(90deg);
}

#navi .menu-bottom {
	margin-top: 50px;
}

#navi .menu-bottom ul {
	gap: 15px;
}

#navi .menu-bottom .menu-bottom-item {
	width: calc((100% - 15px) / 2);
	text-align: center;
	padding: 0;
}

#navi .menu-bottom a {
	display: block;
	width: 100%;
	height: 100%;
	padding: 35px 5px;
}

#navi .menu-bottom p {
	font-size: var(--font-size_ll);
	font-weight: var(--font-weight_l);
	line-height: 1.2em;
}

#navi .menu-bottom span {
	color: var(--color_1);
}

/* フェードアニメーション初期状態 */
#navi .navi-item,
#navi .menu-bottom-item {
	opacity: 0;
	transform: translateX(25px);
	transition: opacity 0.3s ease-out, transform 0.3s ease-out;
}

/* フェードアニメーション表示状態 */
#navi .navi-item.animate,
#navi .menu-bottom-item.animate {
	opacity: 1;
	transform: translateX(0);
}

@media screen and (max-width: 699px) {
	.nav {
		display: block;
	}

	#navi {
		padding: 0px 25px 50px 25px;
	}

	#navi .navi-container {
		display: block;
	}

	#navi .navi-left,
	#navi .navi-right {
		width: 100%;
	}

	#navi .navi-left {
		height: 100px;
	}

	#navi .navi-left img {
		width: 65px;
	}

	#navi .navi-right {}

	#navi .navi-right img {}

	#navi .contents-list {
		width: calc((100% - 25px) / 2);
	}

	#navi .menu {}

	#navi .menu .navi-pack {
		gap: 5px;
		margin: 0;
	}

	#navi .menu .navi-item {
		width: 100%;
		padding-top: 15px;
		padding-bottom: 15px;
	}

	#navi .menu .navi-item p {
		font-size: var(--font-size_l);
		line-height: 1.2em;
	}

	#navi .menu .navi-item span {
		font-size: var(--font-size_ss);
	}

	#navi .menu .submenu p {
		font-size: var(--font-size_m);
	}

	#navi .menu .submenu span {
		font-size: var(--font-size_ss);
	}

	#navi .menu .sub-toggle {
		top: 33px;
	}

	#navi .menu-bottom {
		margin-top: 25px;
	}

	#navi .menu-bottom ul {}

	#navi .menu-bottom .menu-bottom-item {}

	#navi .menu-bottom a {
		padding: 25px 5px 5px 5px;
	}

	#navi .menu-bottom p {
		font-size: var(--font-size_m);
		line-height: 0.2em
	}

	#navi .menu-bottom span {
		font-size: var(--font-size_ss);
	}

}

/*------------------------------------
スマホナビ・ハンバーガーボタン
------------------------------------*/
.hamburger {
	cursor: pointer;
	width: 60px;
	height: 60px;
	position: fixed;
	top: 23px;
	right: 30px;
	z-index: 101;
	pointer-events: painted;
}

.hamburger span {
	background: var(--color_01);
	height: 2px;
	left: 17px;
	border-radius: var(--radius_10);
	position: absolute;
	width: 26px;
	transition: top 0.3s ease-in-out, transform 0.3s ease-in-out 0.25s, opacity 0.3s ease-in-out 0.25s, width 0.3s ease-in-out 0.25s;
}

.hamburger span:nth-child(1) {
	top: 18px;
}

.hamburger span:nth-child(2) {
	top: 26px;
}

.hamburger span:nth-child(3) {
	top: 34px;
}

.nav_open .hamburger span {
	top: 26px;
	/* 全部中央集合 */
}

.nav_open .hamburger span:nth-child(1) {
	transform: rotate(45deg);
}

.nav_open .hamburger span:nth-child(2) {
	opacity: 0;
	width: 0;
}

.nav_open .hamburger span:nth-child(3) {
	transform: rotate(-45deg);
}

/*クローズボタン*/
.navi-close {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--color_00);
}

.navi-close i {
	padding-right: 10px;
}

@media screen and (max-width: 699px) {
	.hamburger {
		position: fixed;
		top: 0;
		right: 0;
		background: var(--color_1);
		border-radius: 0 0 0 15px;
	}

	.hamburger span {
		background: var(--color_f);
	}

	.hamburger p {
		font-size: var(--font-size_ss);
	}
}

/*------------------------------------
PCナビ
------------------------------------*/
#navi-pc {
	position: fixed;
	top: 0;
	right: 40px;
	width: 100%;
	z-index: 5;
	pointer-events: none;
}

/*白背景*/
#navi-pc .bg {
	position: fixed;
	top: -100px;
	right: 0;
	width: 1225px;
	height: 100px;
	background: var(--color_f);
	border-radius: 0 0 0 20px;
	box-shadow: var(--shadow_2);
	opacity: 0;
	z-index: 0;
}

#navi-pc .navi-pc-pack {
	position: relative;
	display: flex;
	justify-content: flex-end;
	gap: 10px;
	list-style-type: none;
	padding-right: 80px;
}

#navi-pc .navi-pc-item {
	padding: 30px 0px;
	position: relative;
	pointer-events: all;
}

#navi-pc .navi-pc-item a {
	padding: 25px 20px;
	text-decoration: none;
	font-size: var(--font-size_sss);
	font-weight: var(--font-weight_l);
	color: var(--color_01);
	position: relative;
	transition: var(--ease_2);
}

#navi-pc .navi-pc-item a:hover {
	color: var(--color_07);
}

#navi-pc .navi-pc-item i {
	margin-left: 10px;
	color: var(--color_01);
	transition: var(--ease_2);
}

#navi-pc .line a,
#navi-pc .contact a {
	padding: 10px 25px;
	font-size: var(--font-size_s);
	color: var(--color_f);
	border-radius: var(--radius_5);
}

#navi-pc .line a {
	background: var(--color_line);
	border: solid 1px var(--color_line);
}

#navi-pc .contact a {
	background: var(--color_2);
	border: solid 1px var(--color_2);
}

#navi-pc .line a:hover,
#navi-pc .contact a:hover {
	background: none;
}

#navi-pc .line a:hover {
	color: var(--color_line);
}

#navi-pc .contact a:hover {
	color: var(--color_2);
}

#navi-pc .has-submenu>a::after {
	display: none;
}

#navi-pc .navi-pc-submenu {
	display: none;
	position: absolute;
	top: 80%;
	left: 50%;
	transform: translateX(-50%);
	text-align: center;
	list-style-type: none;
	padding: 5px 0 25px 0;
	margin: 0;
	background: var(--color_f);
	border-radius: var(--radius_2);
	box-shadow: var(--shadow_3);
	overflow: hidden;
}

#navi-pc .navi-pc-submenu li {
	margin: 0;
	padding: 5px 10px;
}

#navi-pc .navi-pc-submenu li a {
	padding: 10px;
	margin: auto 20px;
	font-size: var(--font-size_sss);
	white-space: nowrap;
	text-decoration: none;
	color: var(--color_01);
}

#navi-pc .navi-pc-submenu li a::after {
	bottom: -5px !important;
}

#navi-pc .navi-pc-submenu li a:hover {
	color: var(--color_07);
}

#navi-pc .nav-pc-item:hover .submenu {
	display: block;
	max-height: 500px;
	transition: var(--ease_1);
}

@media screen and (max-width: 1149px) {
	#navi-pc .bg {
		display: none;
	}

	#navi-pc .navi-pc-pack {
		display: none;
	}
}

/*------------------------------------
フロート問い合わせボタン(SP)
------------------------------------*/
#contact-btn {
	display: none;
	justify-content: center;
	width: 100%;
	position: fixed;
	bottom: -100px;
	right: 0;
	opacity: 0;
	z-index: 50;
}

#contact-btn a {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	position: relative;
	height: 60px;
	text-align: center;
	padding: 14px 0 14px 0;
	background: var(--color_f);
	outline: dotted 1px var(--color_03);
	outline-offset: -5px;
	cursor: pointer;
}

#contact-btn .tel {
	flex-wrap: nowrap;
	width: 50%;
}

#contact-btn .tel p {
	margin-left: 5px;
}

#contact-btn .tel i {
	color: var(--color_1);
}

#contact-btn .line {
	flex-wrap: nowrap;
	width: 50%;
}

#contact-btn .line p {
	margin-left: 5px;
}

#contact-btn .line i {
	color: var(--color_line);
}


#contact-btn .top {
	position: absolute;
	top: -35px;
	right: 5px;
	width: 50px;
	height: 50px;
	background: var(--color_3);
	border-radius: var(--radius_5);
	box-shadow: var(--shadow_2);
	outline: none;
}

#contact-btn i {
	font-size: 20px;
	color: var(--color_f);
}

#contact-btn img {
	width: 20px;
}

#contact-btn p {
	margin-top: 3px;
	font-family: var(--font-family_2);
	font-size: var(--font-size_ss);
	font-weight: var(--font-weight_m);
	letter-spacing: 0.05em;
	line-height: 1em;
}

@media screen and (max-width: 699px) {
	#contact-btn {
		display: flex;
	}
}

/*------------------------------------
フロート問い合わせボタン(PC)
------------------------------------*/
#contact-pc {
	position: fixed;
	bottom: 0;
	right: 0;
	z-index: 100;
}

#contact-pc a {
	display: flex;
	align-items: center;
	width: 200px;
	padding: 10px 15px;
	color: var(--color_01);
}

#contact-pc a:nth-child(1) {
	background: var(--color_09);
}

#contact-pc a:nth-child(2) {
	background: var(--color_08);
}

#contact-pc i,
#contact-pc img {
	width: 25px;
	height: 25px;
	margin-right: 10px;
	font-size: 25px;
}

#contact-pc img {
	width: 25px;
	height: 25px;
	margin-right: 10px;
}

#contact-pc p {}

/*------------------------------------
トップページ・オープニングアニメーション
------------------------------------*/
#opening {
	position: fixed;
	inset: 0;
	background: var(--color_4);
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: 9999;
	pointer-events: auto;
	/* 初期状態は有効 */
}

#opening.is-hidden {
	opacity: 0;
	pointer-events: none;
	/* 消えたらクリックを透過 */
	transition: opacity 1s ease;
}

.logo {
	width: 150px;
	opacity: 0;
}

@media screen and (max-width: 699px) {
	.logo {
		width: 100px;
	}
}


/*------------------------------------ここからトップページコンテンツ------------------------------------*/


/*------------------------------------
トップページ・mainvisual
------------------------------------*/
#mainvisual {
	position: relative;
	text-align: center;
}

#mainvisual .mv-pack {
	position: relative;
	width: 100%;
	margin: auto;
}

#mainvisual .mv-pack .flex-pack {
	flex-wrap: wrap-reverse;
	justify-content: space-between;
	gap: 0;
	margin-right: 0px;
}

#mainvisual .mv-pack .flex-item:nth-child(1) {
	width: 30%;
}

#mainvisual .mv-pack .mv-left {
	margin: auto;
}

#mainvisual .mv-pack .mv-inner {
	flex-wrap: wrap;
}

#mainvisual .mv-pack .mv-inner .mv-logo {
	width: 100%;
	z-index: 2;
}

#mainvisual .mv-pack .mv-inner .mv-logo img {
	width: 200px;
	margin: auto;
}

#mainvisual .mv-pack .mv-inner .mv-logo p {
	margin-top: 15px;
	font-size: var(--font-size_mm);
	font-weight: var(--font-weight_m);
}

#mainvisual .mv-pack .flex-item:nth-child(2) {
	width: 70%;
}

#mainvisual .mv-pack .swiper1 {
	width: 100%;
	height: calc(100vh - 120px);
}

#mainvisual .mv-pack .swiper1 .swiper-wrapper {
	border-radius: 0 0 0 50px;
	overflow: hidden;
}

#mainvisual .mv-pack .swiper1 .swiper-slide {}

#mainvisual .mv-pack .swiper1 .swiper-slide img {
	width: 100%;
	height: 100%;
	transform: scale(1.2);
	transition: transform 8s linear;
}

#mainvisual .mv-pack .swiper1 .swiper-slide-active img {
	transform: scale(1);
}

#mainvisual .mv-info {
	width: 100%;
}

#mainvisual .mv-info-item {
	width: 50%;
	height: 120px;
}

#mainvisual .mv-info-item:nth-child(1) {
	flex-wrap: nowrap;
	background-image: linear-gradient(0deg, var(--color_1), var(--color_2));
}

#mainvisual .mv-info-item:nth-child(1) p {
	font-size: var(--font-size_mm);
	color: var(--color_f);
	line-height: 1;
}

#mainvisual .mv-info-item:nth-child(1) img {
	width: 150px;
	margin-left: 10px;
}

#mainvisual .mv-info-item:nth-child(2) {
	gap: 25px;
}

#mainvisual .mv-info-item:nth-child(2) a {}

#mainvisual .mv-info-item:nth-child(2) i {
	font-size: 35px;
}

#mainvisual .mv-info-item:nth-child(2) img {
	width: 35px;
	;
}

@media screen and (max-width: 699px) {
	#mainvisual {}

	#mainvisual .mv-pack {
		position: relative;
		width: 100%;
		margin: auto;
	}

	#mainvisual .mv-pack .flex-pack {}

	#mainvisual .mv-pack .flex-item:nth-child(1) {
		width: 100%;
	}

	#mainvisual .mv-pack .mv-left {}

	#mainvisual .mv-pack .mv-inner {}

	#mainvisual .mv-pack .mv-inner .mv-logo {
		position: absolute;
		top: 250px;
		left: 0;
		transform: translateY(-50%);
	}

	#mainvisual .mv-pack .mv-inner .mv-logo img {
		display: none;
	}

	#mainvisual .mv-pack .mv-inner .mv-logo p {
		writing-mode: vertical-rl;
		text-align: left;
		display: inline-block;
		margin-left: 60%;
		font-size: 1.4em;
		font-weight: bold;
		color: var(--color_f);
		text-shadow: var(--shadow_02);
	}

	#mainvisual .mv-pack .mv-inner .mv-menu {
		width: 100%;
	}

	#mainvisual .mv-pack .mv-inner .mv-menu-item {}

	#mainvisual .mv-pack .mv-inner .mv-menu-item a {}

	#mainvisual .mv-pack .flex-item:nth-child(2) {
		width: 100%;
	}

	#mainvisual .mv-pack .swiper1 {
		height: 500px;
	}

	#mainvisual .mv-pack .swiper1 .swiper-slide {}

	#mainvisual .mv-pack .swiper1 .swiper-slide img {}

	#mainvisual .mv-pack .swiper1 .swiper-slide-active img {}

	#mainvisual .mv-info {
		flex-wrap: wrap-reverse;
	}

	#mainvisual .mv-info-item {
		width: 100%;
	}

	#mainvisual .mv-info-item:nth-child(1) {
		height: 75px;
	}

	#mainvisual .mv-info-item:nth-child(1) p {
		font-size: var(--font-size_ss);
	}

	#mainvisual .mv-info-item:nth-child(1) img {
		width: 120px;
	}

	#mainvisual .mv-info-item:nth-child(2) {
		gap: 25px;
	}

	#mainvisual .mv-info-item:nth-child(2) a {}

	#mainvisual .mv-info-item:nth-child(2) i {}

	#mainvisual .mv-info-item:nth-child(2) img {}
}


/*------------------------------------
トップページ・greeting
------------------------------------*/
#greeting {
	overflow-x: hidden;
}

#greeting .grid-pack {
	grid-auto-rows: 100px;
	gap: 150px 100px;
}

#greeting .grid-item {}

#greeting .grid-item img {}

#greeting .grid-item:nth-child(1) {
	grid-column: 1 / span 3;
	grid-row: 1 / span 3;
	position: relative;
}

#greeting .grid-item:nth-child(1) .grid-item-inner h2 {
	line-height: 1.8em;
}

#greeting .grid-item:nth-child(1) .grid-item-inner span {
	position: absolute;
	top: 0;
	left: 0;
	transform: translate(-50%, -50%) rotate(-10deg);
	display: flex;
	align-items: center;
	justify-content: center;
	width: 125px;
	aspect-ratio: 1 / 1;
	font-size: var(--font-size_mm);
	font-weight: var(--font-weight_l);
	color: var(--color_f);
	background: var(--color_2);
	border-radius: var(--radius_50);
	outline: dotted 2px var(--color_08);
	outline-offset: -5px;
}

#greeting .grid-item:nth-child(2) {
	grid-column: 4 / span 5;
	grid-row: 1 / span 3;
}

#greeting .grid-item:nth-child(3) {
	grid-column: 1 / span 3;
	grid-row: 4 / span 2;
}

#greeting .grid-item:nth-child(4) {
	grid-column: 4 / span 5;
	grid-row: 3 / span 4;
}

#greeting .grid-item:nth-child(5) {
	grid-column: 3 / span 6;
	grid-row: 6 / span 2;
}

#greeting .grid-item-inner h2 {
	position: relative;
	display: inline-block;
	font-size: var(--font-size_ll);
	z-index: 1;
}

#greeting .grid-item-inner p {
	margin-top: 25px;
}

#greeting .grid-item-inner .btn_4 {
	margin-top: 50px;
}

#greeting .swiper2 {
	height: 100%;
}

#greeting .swiper2 .swiper-wrapper {
	transition-timing-function: linear;
}

#greeting .swiper2 .swiper-slide {}

#greeting .swiper2 .swiper-slide img {
	height: 100%;
	border-radius: var(--radius_2);
}

@media screen and (max-width: 699px) {
	#greeting {
		padding-top: 100px;
	}

	#greeting .grid-pack {
		gap: 50px;
	}

	#greeting .grid-item {}

	#greeting .grid-item:nth-child(1) {}

	#greeting .grid-item:nth-child(1) .grid-item-inner span {
		transform: translate(-35%, -100%) rotate(-10deg);
		width: 80px;
		font-size: var(--font-size_sss);
	}

	#greeting .grid-item:nth-child(2),
	#greeting .grid-item:nth-child(3),
	#greeting .grid-item:nth-child(5) {
		height: 250px;
		padding: 0;
	}

	#greeting .grid-item:nth-child(3) {}

	#greeting .grid-item:nth-child(4) {}

	#greeting .grid-item:nth-child(5) {}

	#greeting .grid-item img {
		width: 100%;
		height: 100%;
	}

	#greeting .grid-item-inner h2 {
		font-size: var(--font-size_l);
	}

	#greeting .grid-item-inner h2::after {
		top: 50%;
		right: -325px;
		width: 300px;
	}

	#greeting .grid-item-inner p {
		margin-top: 25px;
	}

	#greeting .swiper2 {
		margin: 0 calc(50% - 50vw);
		width: 100vw;
	}

	#greeting .swiper2 .swiper-wrapper {}

	#greeting .swiper2 .swiper-slide {}

	#greeting .swiper2 .swiper-slide img {}
}

/*------------------------------------
トップページ・update
------------------------------------*/
#update {
	padding-top: 50px;
	padding-bottom: 200px;
}

#update .update-bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

#update .update-bg img {
	height: 100%;
	filter: opacity(0.35);
}

#update .flex-pack {
	justify-content: flex-start;
	gap: 0;
	padding-top: 100px;
}

#update .flex-item {}

#update .flex-item:nth-child(1) {
	width: 40%;
}

#update .flex-item:nth-child(2) {
	width: 60%;
}

#update .flex-item:nth-child(2) .post-pack {
	flex-wrap: wrap;
	gap: 80px;
}

#update .flex-item:nth-child(2) .post-item {
	position: relative;
	justify-content: flex-start;
	gap: 50px;
	width: 100%;
}

#update .flex-item:nth-child(2) .post-item::before,
#update .flex-item:nth-child(2) .post-item:nth-last-child(1)::after {
	content: '';
	position: absolute;
	left: 0;
	width: 100%;
	height: 1px;
	background: var(--color_01);
}

#update .flex-item:nth-child(2) .post-item::before {
	top: -40px;
}

#update .flex-item:nth-child(2) .post-item:nth-last-child(1)::after {
	bottom: -40px;
}

#update .flex-item:nth-child(2) .btn_1 {
	margin-top: 75px;
}

@media screen and (max-width: 699px) {
	#update {
		padding-bottom: 100px;
	}

	#update .flex-pack {
		flex-wrap: wrap;
		gap: 50px;
		padding-top: 50px;
	}

	#update .flex-item {}

	#update .flex-item:nth-child(1) {
		width: 100%;
	}

	#update .flex-item:nth-child(2) {
		width: 100%;
	}

	#update .flex-item:nth-child(2) .post-pack {
		flex-wrap: wrap;
		gap: 50px;
	}

	#update .flex-item:nth-child(2) .post-item {
		gap: 35px;
	}

	#update .flex-item:nth-child(2) .post-item::before,
	#update .flex-item:nth-child(2) .post-item:nth-last-child(1)::after {}

	#update .flex-item:nth-child(2) .post-item::before {
		top: -25px;
	}

	#update .flex-item:nth-child(2) .post-item:nth-last-child(1)::after {
		bottom: -25px;
	}

	#update .flex-item:nth-child(2) .btn_1 {}
}

/*------------------------------------
トップページ・profile
------------------------------------*/
/*profileレイアウト*/
#profile {
	background: var(--color_4);
}

#profile .grid-item:nth-child(1) {
	grid-column: 4 / span 4;
	grid-row: 1 / span 3;
}

#profile .grid-item:nth-child(2) {
	grid-column: 1 / span 3;
	grid-row: 1 / span 5;
}

#profile .grid-item:nth-child(3) {
	grid-column: 1 / span 3;
	grid-row: 4 / span 4;

}

#profile .grid-item:nth-child(4) {
	grid-column: 4 / span 4;
	grid-row: 4 / span 5;
}

#profile .grid-item-inner p {}

@media screen and (max-width: 699px) {
	#profile {
		padding-bottom: 100px;
	}

	#profile .grid-pack {}

	#profile .grid-item {}

	#profile .grid-item:nth-child(1),
	#profile .grid-item:nth-child(3) {
		height: 250px;
	}

	#profile .grid-item-inner {}

	#profile .grid-item-inner p {}
}

/* profile本体 */
#profile {
	position: relative;
}

#profile .order-pack {}

#profile .grid-item {}

#profile .grid-item img {}


/* 流れ続けるテキスト */
#profile .marquee-pack {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
}

#profile .marquee-container {
	position: relative;
	width: 100%;
	height: 140px;
	margin: 0px auto;
	overflow: hidden;
	display: flex;
	align-items: center;
}

#profile .marquee-text {
	position: absolute;
	white-space: nowrap;
	will-change: transform;
	font-size: 7rem;
	font-weight: bolder;
	color: var(--color_4);
}

@media screen and (max-width: 699px) {
	#profile .marquee-text {
		font-size: 3.5rem;
	}
}

/* profile・エリア */
#profile .profile-area {}

#profile .profile-area .flex-pack {
	flex-wrap: wrap;
	gap: 25px;
}

#profile .profile-area .flex-item {
	width: calc((100% - 100px) / 4);
	text-align: center;
	font-size: var(--font-size_mm);
	color: var(--color_f);
	background: var(--color_2);
	border-radius: var(--radius_2);
	aspect-ratio: 1 / 1;
}

@media screen and (max-width: 699px) {
	#profile .profile-area {}

	#profile .profile-area .flex-pack {
		gap: 15px;
	}

	#profile .profile-area .flex-item {
		width: calc((100% - 45px) / 4);
		font-size: var(--font-size_m);
		border-radius: var(--radius_1);
	}
}

/*------------------------------------
トップページ・step/price共通
------------------------------------*/
#step .btn-pack,
#price .btn-pack {
	margin-top: 50px;
}

@media screen and (max-width: 699px) {

	#step .btn-pack,
	#price .btn-pack {
		margin-top: 0px;
	}
}

/*------------------------------------
トップページ・flow
------------------------------------*/
/*step本体*/
#step {}

#step .flex-pack {}

#step .flex-item {
	width: calc((100% - 50px) / 2);
}

#step .step-pack {
	position: relative;
	gap: 25px;
	width: 100%;
}

#step .step-pack .step-item {
	position: relative;
	width: calc((100% - 50px) / 3);
	aspect-ratio: 1 / 1;
	padding: 30px 0;
	text-align: center;
	border-radius: var(--radius_50);
}

#step .step-pack .step-item::before {
	content: '';
	position: absolute;
	top: 50%;
	right: 0;
	transform: translate(125%, -50%);
	width: 20px;
	height: 35px;
	background: var(--color_1);
	clip-path: polygon(0 0, 100% 50%, 0% 100%);
}

#step .step-pack .step-item:nth-last-child(1)::before {
	display: none;
}

#step .step-pack .step-item img {
	width: 55px;
	height: 55px;
	margin: auto;
}

#step .section-title_4 span {
	margin: 0 5px;
	font-size: var(--font-size_l);
}

#step .step-pack .number {
	margin-top: 10px;
	font-size: var(--font-size_sss);
	color: var(--color_1);
	font-family: var(--font-family_2);
	font-weight: var(--font-weight_l);
}

#step .step-pack .number span {
	margin-left: 5px;
	font-size: var(--font-size_mm);
}

#step .step-pack .name {
	font-size: var(--font-size_mm);
	font-weight: var(--font-weight_l);
}

@media screen and (max-width: 699px) {
	#step .flex-pack {
		gap: 0;
	}

	#step .flex-item {
		width: 100%;
	}

	#step .flex-item:nth-child(2) {
		display: contents;
	}

	#step .box_4 {}

	#step .flex-item:nth-child(1) {
		order: 2;
	}

	#step .section-title_2 {
		order: 1;
	}

	#step .step-pack {

		order: 3;
		flex-wrap: wrap;
		margin-top: 50px;
	}

	#step .step-pack .step-item {
		display: flex;
		justify-content: flex-start;
		align-items: center;
		gap: 25px;
		width: 100%;
		height: auto;
		aspect-ratio: auto;
		padding: 10px 0 10px 25px;
		border-radius: var(--radius_1);
	}

	#step .step-pack .step-item::before {
		top: auto;
		bottom: -15px;
		left: 50%;
		transform: translate(-50%, 0);
		width: 35px;
		height: 20px;
		background: var(--color_3);
		clip-path: polygon(0 0, 100% 0, 50% 100%);
	}

	#step .step-pack .step-item:nth-last-child(1)::before {
		display: none;
	}

	#step .step-pack .step-item img {
		width: 55px;
		height: 55px;
		margin: 0;
	}

	#step .step-pack .number {
		margin-top: 0px;
		font-size: var(--font-size_s);
	}

	#step .step-pack .step-item p {
		font-size: var(--font-size_mm);
	}
}

/*------------------------------------
トップページ・price
------------------------------------*/
/*price本体*/
#price {
	background: var(--color_4);
}

#price .flex-pack {}


#price .flex-item {
	width: calc((100% - 0px) / 2);
}

#price .flex-item .a {
	margin: 0 5px;
	font-size: var(--font-size_m);
	font-weight: var(--font-weight_m);
}

@media screen and (max-width: 699px) {
	#price .flex-pack {
		flex-wrap: wrap;
	}

	#price .flex-item {
		width: 100%;
	}

	#price .flex-item .a {
		font-size: var(--font-size_m);
		font-weight: var(--font-weight_l);
	}
}

/*------------------------------------
トップページ・insta-grid
------------------------------------*/
#insta-grid {

}

#insta-grid .flex-pack {
	
}

#insta-grid .flex-item:nth-child(1) {
	width: calc(35% - 25px);
}

#insta-grid .flex-item:nth-child(2) {
	width: calc(65% - 25px);
}

#sb_instagram {
	width: 100%;
	max-width: 800px;
}

.sbi_item {
	width: 100%!important;
}

.sbi_type_image {
	width: 100%!important;
}

#sbi_images .sbi_photo_wrap {
width: 100%!important;
}

#sbi_images .sbi_photo {
width: 100%!important;

}

#sbi_images .sbi_photo img {
	width: 100%!important;
	border-radius: var(--radius_1)!important;
}

@media screen and (max-width: 699px) {

	#insta-grid .flex-pack {
		gap: 0;
	
}

	#insta-grid .flex-item:nth-child(1) {
	width: 100%;
}

#insta-grid .flex-item:nth-child(2) {
	width: 100%;
}
}

/*------------------------------------
トップページ・instagram
------------------------------------*/
#instagram {
	background: var(--color_5);
}

#instagram .flex-pack {}

#instagram .flex-item {}

#instagram .flex-item:nth-child(1) {
	width: 35%;
}

#instagram .flex-item:nth-child(1) .section-title_2 {
	flex-wrap: wrap;
}

#instagram .flex-item:nth-child(2) {
	width: 100%;
	margin-right: calc(50% - 50vw);
}

#instagram .swiper4 {
	width: 100%;
}

#instagram .swiper-slide {
	position: relative;
	width: 100%;
	height: auto;
	margin-bottom: 30px;
	border-radius: var(--radius_2);
	overflow: hidden;
}

#instagram .swiper-slide:hover img,
#instagram .swiper-slide:hover video {
	filter: brightness(0.5);
}

#instagram .swiper-slide img,
#instagram .swiper-slide video {
	width: 100%;
	height: 350px;
	object-fit: cover;
	transition: all 0.3s ease-in-out;
}

#instagram .swiper-slide .instagram-icon {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-size: 2rem;
	color: rgba(255, 255, 255, 0);
	transition: color 0.3s ease-in-out;
	pointer-events: none;
}

#instagram .swiper-slide:hover .instagram-icon {
	color: var(--color_f);
}

.instagram-posts {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
}

.swiper4 .swiper-button-prev,
.swiper4 .swiper-button-next {
	width: 30px;
	height: 30px;
	background-color: rgba(0, 0, 0, 0.3);
	border-radius: 50%;
	position: absolute;
	top: 50%;
	justify-content: center;
	align-items: center;
}

.swiper4 .swiper-button-prev::after,
.swiper4 .swiper-button-next::after {
	content: "";
	width: 6px;
	height: 6px;
	border: solid var(--color_f);
	border-width: 0 2px 2px 0;
	display: inline-block;
	padding: 3px;
}

.swiper4 .swiper-button-prev::after {
	transform: rotate(135deg) translate(-0.5px, -0.5px);
}

.swiper4 .swiper-button-next::after {
	transform: rotate(-45deg) translate(-0.5px, -0.5px);
}

.swiper4 .swiper-pagination {}

.swiper4 .swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,
.swiper4 .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: 0 2px;
}

.swiper4 .swiper-pagination-bullet {
	background: var(--color_01);
	height: 5px;
	width: 5px;
	border-radius: var(--radius_10);
	gap: 5px;
}

.swiper4 .swiper-pagination-bullet.active {
	background: var(--color_f);
}

@media screen and (max-width: 699px) {
	#instagram .flex-pack {
		gap: 0;
	}

	#instagram .flex-item {}

	#instagram .flex-item:nth-child(1) {
		width: 100%;
	}

	#instagram .flex-item:nth-child(1) .section-title_2 {}

	#instagram .flex-item:nth-child(2) {
		width: 100%;
		margin-right: auto;
	}
}

/*------------------------------------
トップページ・features
------------------------------------*/
#features {}

#features .sectiontitle {
	position: relative;
}

#features .swiper-wrapper {
	padding-bottom: 75px;
}

#features .swiper5 .swiper-slide {
	display: block;
	width: 100%;
	height: auto;
	border-radius: var(--radius_2);
	text-align: center;
}

#features .swiper5 .swiper-slide .image-pack {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: auto;
	width: 230px;
	height: 230px;
	background: var(--color_4);
	border-radius: var(--radius_50);
}

#features .swiper5 .swiper-slide img {
	width: 100px;
	height: auto;
}

#features .swiper5 .swiper-slide .caption {
	display: block;
}

#features .swiper5 .swiper-slide h3 {
	width: 100%;
	margin-top: 25px;
	line-height: 1.5em;
	font-size: var(--font-size_m);
	color: var(--color_2);
}

#features .swiper5 .swiper-slide h3 i {
	font-size: var(--font-size_m);
	color: var(--color_2);
}

#features .swiper5 .swiper-slide p {
	width: 100%;
	margin-top: 25px;
	text-align: left;
	font-size: var(--font-size_s);
}

/*ページネーション*/
#features .swiper5 .swiper-pagination {
	position: absolute;
	bottom: 0px;
	left: 50%;
	font-family: var(--font-family_2);
	color: var(--color_2);
	letter-spacing: 0em;
	background: none;
	pointer-events: none;
}

/*現在のスライド番号*/
#features .swiper5 .swiper-pagination-current {
	font-size: var(--font-size_lll);
}

/*スライド総数*/
#features .swiper5 .swiper-pagination-total {
	font-size: var(--font-size_s);
}

/*矢印*/
#features .swiper5 .swiper-button-next,
#features .swiper5 .swiper-button-prev {
	content: none !important;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 30px;
	height: 30px;
	background: none;
	border: none;
	cursor: pointer;
	z-index: 10;
}

.swiper5 .swiper-button-prev::after,
.swiper5 .swiper-button-next::after {
	content: none !important;
}

#features .swiper5 .swiper-button-prev::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) rotate(180deg);
	width: 20px;
	height: 20px;
	border-left: 20px solid var(--color_4);
	border-top: 20px solid transparent;
	border-bottom: 20px solid transparent;
}

#features .swiper5 .swiper-button-next::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) rotate(180deg);
	width: 20px;
	height: 20px;
	border-right: 20px solid var(--color_4);
	border-top: 20px solid transparent;
	border-bottom: 20px solid transparent;
}

@media screen and (max-width: 699px) {
	#features {}
}

/*------------------------------------
トップページ・reserve
------------------------------------*/
#reserve {}

/*------------------------------------
トップページ・sns
------------------------------------*/
#sns {
	position: relative;
	padding-top: 50px;
	padding-bottom: 0;
}

#sns .sns-bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
	z-index: -1;
}

#sns .sns-bg img {
	width: 100%;
	height: 100%;
	transform: scale(1.1);
	filter: blur(5px);
}

#sns .sns-caption {
	max-width: 800px;
	margin: auto;
}

#sns .sns-caption p {}

#sns .flex-pack {
	flex-wrap: nowrap;
	align-items: end;
	max-width: 800px;
	margin-top: 25px;
}

#sns .flex-item {}

#sns .flex-item:nth-child(1) {
	display: block;
	text-align: center;
	width: 35%;
}

#sns .flex-item:nth-child(1) img {
	width: 200px;
}

#sns .flex-item:nth-child(2) {
	width: 65%;
	text-align: center;
	padding-bottom: 35px;
}

#sns .flex-item:nth-child(2) a {
	display: flex;
	align-items: center;
	justify-content: center;
}

#sns .flex-item:nth-child(2) i {
	font-size: var(--font-size_l);
}

#sns .flex-item:nth-child(2) img {
	transition: var(--ease_2);
}

#sns .facebook img {
	width: auto;
	height: 18px;
}

#sns .tiktok img {
	width: auto;
	height: 21px;
}


/*------------------------------------ここから下層ページコンテンツ------------------------------------*/


/*------------------------------------
下層ページ・メインビジュアル
------------------------------------*/
#subvisual_1 {
	position: relative;
	height: 100vh;
	max-height: 800px;
	overflow: hidden;
	z-index: -10;
}

#subvisual_1 .wrapper-wide {
	position: relative;
	width: 35%;
	height: 100%;
}

#subvisual_1 .sv-caption {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

#subvisual_1 .sv-caption .inner h1 {
	font-size: 50px;
	color: var(--color_01);
	line-height: 1em;
}

#subvisual_1 .sv-caption .inner p {
	margin-top: 30px;
	font-size: var(--font-size_s);
	color: var(--color_01);
}

#subvisual_1 .sv-image {
	width: 65%;
	height: 100%;
	margin: auto 0 auto auto;
	overflow: hidden;
}

#subvisual_1 .sv-image img {
	height: calc(100% - 90px);
	margin-top: 90px;
	border-radius: 50px 0 0 0;
}

@media screen and (max-width: 699px) {
	#subvisual_1 {
		flex-wrap: wrap-reverse;
		margin-top: 0px;
		height: 450px;
	}

	#subvisual_1 .wrapper-wide {
		position: relative;
		width: 100%;
		height: 150px;
	}

	#subvisual_1 .sv-caption {
		position: relative;
	}

	#subvisual_1 .sv-caption .inner h1 {
		font-size: 35px;
	}

	#subvisual_1 .sv-caption .inner p {
		margin-top: 15px;
		font-size: var(--font-size_ss);
	}

	#subvisual_1 .sv-image {
		width: 100%;
		height: 350px;
	}

	#subvisual_1 .sv-image img {
		height: 100%;
		margin-top: 0;
	}
}

/*------------------------------------
下層ページ・about
------------------------------------*/
#about {
	background: var(--color_5);
}

/*aboutレイアウト*/
#about .grid-item:nth-child(1) {
	grid-column: 4 / span 3;
	grid-row: 1 / span 3;
}

#about .grid-item:nth-child(2) {
	grid-column: 1 / span 3;
	grid-row: 1 / span 5;
}

#about .grid-item:nth-child(3) {
	grid-column: 1 / span 3;
	grid-row: 5 / span 4;
}

#about .grid-item:nth-child(4) {
	grid-column: 4 / span 3;
	grid-row: 4 / span 6;
}

#about .grid-item:nth-child(5) {
	grid-column: 2 / span 5;
	grid-row: 9 / span 5;
}

#about .swiper6 {

}

#about .swiper6 .frame_1 {
	margin: 20px;
	border-radius: var(--radius_50);
	aspect-ratio: 1 / 1;
}

#about .swiper6 .frame_1 img {
	
}

/*矢印*/
#about .swiper6 .swiper-button-next,
#about .swiper6 .swiper-button-prev {
	content: none !important;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 30px;
	height: 30px;
	background: none;
	border: none;
	cursor: pointer;
	z-index: 10;
}

#about .swiper-button-prev::after,
#about .swiper-button-next::after {
	content: none !important;
}

#about .swiper6 .swiper-button-prev::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) rotate(180deg);
	width: 20px;
	height: 20px;
	border-left: 20px solid var(--color_3);
	border-top: 20px solid transparent;
	border-bottom: 20px solid transparent;
}

#about .swiper6 .swiper-button-next::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) rotate(180deg);
	width: 20px;
	height: 20px;
	border-right: 20px solid var(--color_3);
	border-top: 20px solid transparent;
	border-bottom: 20px solid transparent;
}

@media screen and (max-width: 699px) {
	#about .grid-item:nth-child(1),
	#about .grid-item:nth-child(3) {
		height: 250px;
	}

	#about .swiper6 .frame_1 {
}
}

/*------------------------------------
下層ページ・ご利用の流れ
------------------------------------*/
#flow {}

#flow .flex-pack {
	flex-wrap: wrap;
}

#flow .flex-item {
	position: relative;
	gap: 50px;
	width: 100%;
	padding: 50px;
}

#flow .flex-item .left {
	width: calc(40% - 25px);
}

#flow .flex-item .left img {}

#flow .flex-item .right {
	width: calc(60% - 25px);
}

#flow .flex-item .right .section-title_5 span {
	font-size: var(--font-size_ll);
	font-weight: var(--font-weight_m);
}

#flow .flex-item i {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translate(-50%, -200%)rotate(90deg);
	font-size: var(--font-size_ll);
	color: var(--color_1);
}

@media screen and (max-width: 699px) {
	#flow .flex-pack {
		gap: 75px;
	}

	#flow .flex-item {
		flex-wrap: wrap-reverse;
		gap: 25px;
		width: 100%;
		padding: 45px 25px;
	}

	#flow .flex-item i {
		position: absolute;
		top: 0;
		left: 50%;
		transform: translate(-50%, -200%)rotate(90deg);
		font-size: var(--font-size_ll);
	}

	#flow .flex-item .left,
	#flow .flex-item .right {
		width: 100%;
	}

	#flow .flex-item .left img {}
}

/*------------------------------------
下層ページ・料金・サービス
------------------------------------*/
/*一回あたりの料金*/
#pricing {}

#pricing .system {}

#pricing .system-pack {
	gap: 25px;
}

#pricing .system-item {
	aspect-ratio: 1 / 1;
	border-radius: var(--radius_50);
}

#pricing .system-item:nth-child(odd) {
	width: 150px;
	height: 150px;
	background: var(--color_4);
}

#pricing .system-item:nth-child(odd) p {
	font-size: var(--font-size_m);
}

#pricing .system-item:nth-child(even) {
	width: 50px;
	height: 50px;
	background: var(--color_3);
}

#pricing .system-item:nth-child(even) i {
	color: var(--color_f);
}

#pricing .system-item:nth-last-child(1) {
	background: var(--color_1);
}

#pricing .system-item:nth-last-child(1) p {
	color: var(--color_f);
}


@media screen and (max-width: 699px) {
	#pricing {
		padding-top: 75px;
	}

	#pricing .system {}

	#pricing .system-pack {
		gap: 5px;
	}

	#pricing .system-item {}

	#pricing .system-item:nth-child(odd) {
		width: 90px;
		height: 90px;
	}

	#pricing .system-item:nth-child(odd) p {
		font-size: var(--font-size_s);
	}

	#pricing .system-item:nth-child(even) {
		width: 25px;
		height: 25px;
	}

	#pricing .system-item:nth-child(even) i {
		color: var(--color_f);
	}
}

/*料金・サービス共通CSS*/
#plan {
	background: var(--color_4);
}

#pricing .box_1,
#plan-fee .box_1,
#service .box_1 {
	margin-top: 50px;
	padding-top: 60px;
}

#plan-fee {
	padding-bottom: 25px;
}

#plan-cost {
	padding-top: 25px;
}

#plan-fee h4,
#plan-cost h4 {
	font-size: var(--font-size_m);
	text-align: center;
}

#plan-fee .wrapper,
#plan-cost .wrapper {
	position: relative;
	padding-top: 25px;
	padding-bottom: 25px;
}

#plan-fee .wrapper .section-title_4,
#plan-cost .wrapper .section-title_4 {}

#pricing .caption,
#plan-fee .caption,
#plan-cost .caption {
	margin-bottom: 25px;
	font-size: var(--font-size_ss);
}

/*ペットごとの料金表*/
#plan-fee .caption {
	margin-bottom: 40px;
}

#plan-fee .tab-panel {
	padding: 30px;
}

#plan-fee .tab-item {
	color: var(--color_f);
}

#plan-fee .tab-item.active {}

#plan-fee .tab-panel h2 {}

#plan-fee ul {}

#plan-fee .menu {
	list-style: none;
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
	gap: 5px;
	margin: 20px auto 0;
}

#plan-fee .menu li {
	padding: 0 10px;
	text-align: center;
	font-size: var(--font-size_ss);
	color: var(--color_f);
	letter-spacing: 0;
	background: var(--color_1);
	border-radius: var(--radius_05);
}

@media screen and (max-width: 799px) {
	#plan-fee .caption {
		margin-bottom: 25px;
	}

	#plan-fee .tab-panel {
		border-radius: 0 0 20px 20px;
	}

	#plan-fee .tab-panel h4 {
		display: none;
	}
}

/*別途諸費用*/
#plan-cost {}

#plan-cost .flex-pack {
	align-items: flex-start;
	gap: 30px;
}

#plan-cost .flex-item {
	width: calc((100% - 30px) / 3);
}

#plan-cost .flex-item .table_2 {
	padding: 45px 25px;
}

#plan-cost .flex-item .table_2 h3 {}

@media screen and (max-width: 699px) {
	#plan-cost .flex-item {
		width: 100%;
	}
}

#plan .table_2,
#plan .table_3 {}

#plan .table_2 .row-header,
#plan .table_2 .row,
#plan .table_3 .row-header,
#plan .table_3 .row {}

#plan .table_2 .row-header,
#plan .table_3 .row-header {}

#plan .table_2 .row-header p,
#plan .table_3 .row-header p {}

#plan .table_2 .row,
#plan .table_3 .row {}

#plan .table_2 .cell {}

#plan .table_3 .cell {}

#plan .table_2 .cell p,
#plan .table_3 .cell p {
	font-size: var(--font-size_ss);
}

#plan-fee .table_2 .cell:nth-child(2) p,
#plan-fee .table_3 .cell:nth-child(2) p {
	white-space: nowrap;
}

#plan .table_2 .cell:nth-child(2) p span,
#plan .table_3 .cell:nth-child(2) p span {
	padding-right: 2px;
	font-size: var(--font-size_m);
	font-weight: var(--font-weight_m);
	color: var(--color_1);
}

#plan .table_2 .cell:nth-child(3) p span,
#plan .table_3 .cell:nth-child(3) p span {
	padding-right: 2px;
	font-size: var(--font-size_s);
	color: var(--color_03);
}

#plan .table_2 .cell:nth-child(1) p,
#plan .table_3 .cell:nth-child(1) p {}

#plan .table_2 .cell:nth-child(2) p,
#plan .table_3 .cell:nth-child(2) p {}

#plan .table_2 .cell:nth-child(3) p,
#plan .table_3 .cell:nth-child(3) p {}

#plan .table_2 .note,
#plan .table_3 .note {}

#plan .table_2 .note p,
#plan .table_3 .note p {}

@media screen and (max-width: 799px) {

	#plan .table_2,
	#plan .table_3 {}

	#plan .table_2 .row-header,
	#plan .table_2 .row,
	#plan .table_3 .row-header,
	#plan .table_3 .row {}

	#plan .table_2 .row-header,
	#plan .table_3 .row-header {}

	#plan .table_2 .row-header p,
	#plan .table_3 .row-header p {}

	#plan .table_2 .row,
	#plan .table_3 .row {}

	#plan .table_2 .cell {}

	#plan .table_3 .cell {}

	#plan .table_2 .cell p,
	#plan .table_3 .cell p {}

	#plan .table_2 .cell:nth-child(1) p,
	#plan .table_3 .cell:nth-child(1) p {}

	#plan .table_2 .cell:nth-child(2) p,
	#plan .table_3 .cell:nth-child(2) p {}

	#plan .table_2 .cell:nth-child(3) p,
	#plan .table_3 .cell:nth-child(3) p {}

	#plan .table_2 .note,
	#plan .table_3 .note {}

	#plan .table_2 .note p,
	#plan .table_3 .note p {}
}

/*お世話の内容*/
#service {}

#service .flex-pack {
	flex-wrap: wrap;
}

#service .flex-item .flex {
	position: relative;
	gap: 50px;
	width: 100%;
}

#service .flex-item .flex {}

#service .flex-item .left {
	width: calc(60% - 25px);
}

#service .flex-item .right {
	width: calc(40% - 25px);
}

#service .flex-item .left ul {}

#service .flex-item .left li {
	padding: 10px 0;
}

#service .flex-item .left h4 {
	margin-bottom: 10px;
	padding: 3px 10px;
	font-size: var(--font-size_mm);
	border-bottom: 2px solid var(--color_2);
}

#service .flex-item .left p {}

#service .flex-item .list_1 h4 {
	color: var(--color_01);
	background: none;
}

#service .flex-item .left .note {
	padding: 10px;
	font-size: var(--font-size_ss);
	background: var(--color_5);
}

#service .box_1 h4::before {
	display: none;
}

#service .box_1 .list_1 ul {
	list-style: disc;
}

#service .box_1 .list_1 li {
	padding: 2.5px 0;
}

@media screen and (max-width: 699px) {
	#service .flex-item .flex {
		flex-wrap: wrap-reverse;
		gap: 10px;
		width: 100%;
	}

	#service .flex-item .left {
		width: 100%;
	}

	#service .flex-item .right {
		width: 100%;
	}
}

/*------------------------------------
下層ページ・LINEで問い合わせ
------------------------------------*/
#line {}

#line .content_1 p,
#line .content_1 li {
	margin-top: 0;
}

/*レイアウト*/
#line .grid-item:nth-child(1) {
	grid-column: 4 / span 3;
	grid-row: 1 / span 4;
}

#line .grid-item:nth-child(2) {
	grid-column: 1 / span 3;
	grid-row: 2 / span 5;
}

#line .grid-item:nth-child(2) .line a {
	background: var(--color_line);
	border: solid 1px var(--color_line);
}

#line .grid-item:nth-child(2) .line a:hover::before,
#line .grid-item:nth-child(2) .line a:hover::after {
	background: var(--color_line);
}

#line .grid-item:nth-child(2) .line a:hover {
	background: none;
	color: var(--color_line);
}

#line .grid-item:nth-child(2) p {
	margin-top: 35px;
}

#line .grid-item:nth-child(2) .qr {
	margin-top: 25px;
	display: flex;
	justify-content: center;
}

#line .grid-item:nth-child(2) img {
	width: 150px;
	aspect-ratio: 1 / 1;
}

#line .grid-item:nth-child(3) {
	grid-column: 1 / span 2;
	grid-row: 8 / span 5;
}

#line .grid-item:nth-child(4) {
	grid-column: 3 / span 4;
	grid-row: 6 / span 8;
}

@media screen and (max-width: 699px) {

	#line .grid-item:nth-child(1),
	#line .grid-item:nth-child(3),
	#line .grid-item:nth-child(5) {
		height: 250px;
	}
}

/*------------------------------------
下層ページ・Q&A
------------------------------------*/
#faq {}

#faq .wrapper {
	margin-bottom: 100px;
}

/*------------------------------------
下層ページ・問い合わせ
------------------------------------*/
#sub-contact {
	background: var(--color_5);
}

/*------------------------------------
下層ページ・利用規約/プライバシーポリシー共通
------------------------------------*/
#sub-legals {}

#sub-legals .legals-pack {}

#sub-legals .legals-header {}

#sub-legals .legals-header h2 {}

#sub-legals .legals-item {}

#sub-legals .legals-item h3 {}

#sub-legals .legals-header p,
#sub-legals .legals-item p {
	margin: 15px auto 50px auto;
}

/*------------------------------------
下層ページ・投稿一覧・news/archive共通
------------------------------------*/
#post-archive {}

#post-archive .flex-pack {
	flex-wrap: wrap;
	align-items: flex-start;
}

#post-archive .flex-item {
	gap: 50px;
	width: 100%;
	padding-bottom: 50px;
	border-bottom: var(--border_3);
}

#post-archive .flex-item:nth-last-child(1) {
	border-bottom: none;
}

#post-archive .flex-item .image {
	width: calc((100% - 50px) / 2);
	height: 300px;
	border-radius: var(--radius_2);
	overflow: hidden;
}

#post-archive .flex-item .image img {
	width: 100%;
	height: 100%;
	transition: var(--ease_1);
}

#post-archive .flex-item .caption {
	width: calc((100% - 50px) / 2);
}

#post-archive .flex-item .caption .flex {
	justify-content: flex-start;
	gap: 10px;
}

#post-archive .flex-item .caption .date {
	font-size: var(--font-size_sss);
}

#post-archive .flex-item .caption .category {
	padding: 3px 10px;
	font-size: var(--font-size_sss);
	line-height: 1.2em;
	background: var(--color_4);
	border-radius: var(--radius_5);
}

#post-archive .flex-item .title {
	font-size: var(--font-size_s);
}

#post-archive .flex-item .text {
	font-size: var(--font-size_ss);
}

@media screen and (max-width: 699px) {
	#post-archive .flex-item {
		flex-wrap: wrap;
		gap: 10px;
	}

	#post-archive .flex-item .image {
		width: 100%;
		height: 200px;
	}

	#post-archive .flex-item .caption {
		width: 100%;
	}
}

/*------------------------------------
投稿一覧・次のページ/前のページ
------------------------------------*/
.pagination {
	text-align: center;
	margin-top: 40px;
}

.pagination ul {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	list-style: none;
}

.pagination li {
	width: 45px;
	height: 45px;
	color: var(--color_01);
	background: var(--color_4);
}

.pagination li a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	line-height: 1.25em;
	transition: var(--ease_1);
}

.pagination .current {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	color: var(--color_f);
	background: var(--color_01);
}

.pagination li a:hover {
	color: var(--color_f);
	background: var(--color_01);
}

@media screen and (max-width: 699px) {
	#page .page-date {
		font-size: var(--font-size_ss);
	}

	#page .page-category {
		font-size: var(--font-size_ss);
	}

	#page .page-container h1 {
		font-size: var(--font-size_l);
	}
}


/*------------------------------------ここから投稿ページコンテンツ------------------------------------*/


/*------------------------------------
投稿ページ・メインビジュアル
------------------------------------*/
#post-visual {}

#post-visual .flex-pack {
	position: relative;
	flex-wrap: wrap;
	gap: 0;
	padding-top: 90px;
}

#post-visual .flex-item {}

#post-visual .flex-item {
	margin: 0 calc(50% - 50vw);
	width: 100vw;
	height: 500px;
}

#post-visual .flex-item img {
	width: 100%;
	height: 100%;
}

@media screen and (max-width: 699px) {
	#post-visual {}

	#post-visual .flex-pack {
		flex-wrap: wrap-reverse;
		gap: 50px;
		padding-top: 45px;
	}

	#post-visual .flex-item {}

	#post-visual .flex-item {
		height: 250px;
	}

	#post-visual .flex-item img {}
}

/*------------------------------------
投稿ページ・コンテンツ
------------------------------------*/
#post {}

#post .post-header {
	margin-bottom: 50px;
}

#post .post-header .flex {
	justify-content: flex-start;
	gap: 10px;
}

#post .post-header .flex .date {}

#post .post-header .flex .category {
	padding: 3px 10px;
	font-size: var(--font-size_sss);
	background: var(--color_09);
}

#post .post-header .title {
	margin-top: 25px;
}

#post .post-container {
	margin-bottom: 25px;
}

#post .post-content {}

@media screen and (max-width: 699px) {
	#post {}

	#post .post-header {
		margin-bottom: 25px;
	}

	#post .post-header .flex {}

	#post .post-header .flex .date {}

	#post .post-header .flex .category {}

	#post .post-header .title {
		margin-top: 25px;
		font-size: var(--font-size_l);
	}

	#post .post-container {}

	#post .post-content {}
}

/*------------------------------------
投稿ページ・次のページ/前のページ
------------------------------------*/
#post-navigation {
	padding: 50px 0;
	background: var(--color_4);
}

#post-navigation .flex-pack {
	justify-content: center;
	gap: 40px;
}

#post-navigation .flex-item {
	text-align: center;
	width: calc((100% - 80px) / 3);
}

#post-navigation .flex-item a {
	font-size: var(--font-size_ss);
	text-decoration: underline;
	line-height: 1.25em!important;
}

#post-navigation .flex-item a:hover {
	text-decoration: underline;
	color: var(--color_03);
}

@media screen and (max-width: 699px) {
	#post-navigation .flex-pack {
		flex-wrap: nowrap;
		gap: 20px;
	}

	#post-navigation .flex-item {
		width: calc((100% - 40px) / 3);
	}

	#post-navigation .flex-item a {
		font-size: var(--font-size_sss);
	}
}


/*------------------------------------ここから共通パーツ------------------------------------*/


/*------------------------------------
共通パーツ・パンくずリスト
------------------------------------*/
.bread-pack {
	background: var(--color_4);
}

.breadcrumbs {
	padding: 10px 0;
	font-size: var(--font-size_sss);
	color: var(--color_03);
}

.breadcrumbs a {
	font-size: var(--font-size_sss);
	color: var(--color_03);
}

.breadcrumbs a:hover {
	text-decoration: underline;
}

/*------------------------------------
共通パーツ・問い合わせフォーム
------------------------------------*/
.form-pack {
	padding: 100px 10px;
	background: var(--color_f);
	border: solid 2px var(--color_08);
}

.form-item {
	max-width: 800px;
	margin: auto;
}

#contactForm {
	width: 100%;
}

#contactForm .form-parts {
	margin-top: 25px;
}

#contactForm .form-parts input,
#contactForm .form-parts textarea {
	width: 100%;
	margin-bottom: 5px;
	padding: 5px 15px;
	background: var(--color_f);
	border-radius: var(--radius_1);
	box-shadow: inset 0px 0px 4px var(--color_bs);
}

#contactForm input::placeholder,
#contactForm textarea::placeholder {
	color: var(--color_05);
}

#contactForm .form-parts select {
	width: auto;
	padding: 5px;
	background: var(--color_f);
	box-shadow: inset 0px 0px 4px var(--color_bs);
}

#contactForm .value-radio {
	display: flex;
	flex-wrap: nowrap;
	gap: 25px;
}

#contactForm .value-radio label {
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	font-size: var(--font-size_ss);
	white-space: nowrap;
}

#contactForm .value-radio input {
	margin-right: 5px;
	background: none;
	box-shadow: none;
}

#contactForm .attached-item {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	width: 100%;
	border: solid 1px var(--color_03);
}

#contactForm .custom-file-label {
	display: inline-block;
	padding: 7px 15px;
	background-image: linear-gradient(0deg, var(--color_03), var(--color_06));
	font-size: var(--font-size_ss);
	color: var(--color_f);
	cursor: pointer;
	position: relative;
	overflow: hidden;
}

#contactForm .custom-file-label input[type="file"] {
	display: block;
	position: absolute;
	inset: 0;
	left: 0;
	top: 0;
	opacity: 1;
	cursor: pointer;
	width: 100%;
	height: 100%;
	z-index: -1;
}

#contactForm .file-type {
	width: 100%;
}

#contactForm .file-name {
	margin-left: 10px;
	font-size: var(--font-size_ss);
	color: var(--color_03);
}

#contactForm .checkbox-area {
	margin-top: 10px;
}

#contactForm .checkbox-area a {
	text-decoration: underline;
	text-underline-offset: 5px;
}

#contactForm .checkbox-area input {
	box-shadow: none;
	width: auto;
	margin-right: 5px;
}

#contactForm .required-mark {
	color: var(--color_1);
	margin-left: 0.3em;
	font-size: 90%;
}

#contactForm .send {
	text-align: center;
}

#contactForm .send input {
	width: 250px;
	margin-top: 25px;
	padding: 10px 15px;
	background: var(--color_01);
	box-shadow: none;
	color: var(--color_f);
	border: solid 1px var(--color_01);
	transition: var(--ease_1);
}

#contactForm .send input:hover {
	color: var(--color_01);
	background: var(--color_f);
	box-shadow: none;
}

/*送信完了後*/
.thanks-message {}

.thanks-message h3 {}

.thanks-message p:nth-child(2) {
	margin-top: 25px;
}

.thanks-message p:nth-child(3) {
	color: var(--color_1);
}

/*------------------------------------
共通パーツ・問い合わせ３連ボタン
------------------------------------*/
.inquiry {
	display: block;
}

.inquiry .flex-pack {
	flex-wrap: wrap;
	gap: 20px;
}

.inquiry .flex-item {
	width: 100%;
}

.inquiry .flex-item a {
	flex-wrap: wrap;
	width: 100%;
	height: 100%;
	padding: 15px 0;
	font-weight: var(--font-weight_l);
	font-size: var(--font-size_mm);
	color: var(--color_f);
	line-height: 1.2em;
	border-radius: var(--radius_10);
	outline: dotted 1px var(--color_f);
	outline-offset: -3px;
}

.inquiry .flex-item a i {
	margin-right: 10px;
	font-size: 20px;
	color: var(--color_f);
}

.inquiry .flex-item a img {
	margin-right: 10px;
	width: 20px !important;
}

.inquiry .flex-item a span {
	width: 100%;
	text-align: center;
	font-size: var(--font-size_ss);
	font-weight: var(--font-weight_s);
}

.inquiry .flex-item:nth-child(1) a {
	font-size: var(--font-size_ll);
	color: var(--color_02);
	border-top: 2px solid var(--color_03);
	border-bottom: 2px solid var(--color_03);
	outline: none;
	border-radius: 0;
}

.inquiry .flex-item:nth-child(1) i {
	font-size: var(--font-size_ll);
	color: var(--color_02);
}

.inquiry .flex-item:nth-child(2) a {
	background: var(--color_line);
}

.inquiry .flex-item:nth-child(3) a {
	background: var(--color_1);
}

/*------------------------------------
共通パーツ・投稿スライダー
------------------------------------*/
#postslider {
	background: var(--color_4);
}

#postslider .swiper3 {
	margin: 0 calc(50% - 50vw);
	width: 100vw;
}

#postslider .swiper-wrapper {}

#postslider .swiper-slide {
	width: 100%;
	margin-top: 10px;
}

#postslider .swiper-slide .image-link {
	width: 100%;
	height: 350px;
}

#postslider .swiper-slide img {
	height: 100%;
	border-radius: var(--radius_2);
}

#postslider .swiper-slide .caption {
	margin-top: 15px;
	width: 100%;
}

#postslider .swiper-slide .caption .header {
	justify-content: flex-start;
	gap: 10px;
}

#postslider .swiper-slide .caption .header .date {
	font-size: var(--font-size_sss);
}

#postslider .swiper-slide .caption h3 {
	text-align: left;
	font-size: var(--font-size_s);
	font-weight: var(--font-weight_s);
	line-height: 1.8em;
}

#postslider .swiper-slide .caption .cat {
	flex-wrap: nowrap;
	justify-content: flex-start;
	gap: 5px;
	margin-top: 10px;
}

#postslider .swiper-slide .cat a {
	padding: 3px 10px 0px 10px;
	font-family: var(--font-family_2);
	font-size: var(--font-size_sss);
	color: var(--color_f);
	letter-spacing: 0.05em;
	background: var(--color_2);
	border-radius: var(--radius_5);
}

@media screen and (max-width: 699px) {
	#postslider {}

	#postslider .swiper3 {}

	#postslider .swiper-wrapper {}

	#postslider .swiper-slide {}

	#postslider .swiper-slide .image-link {
		height: 200px;
	}

	#postslider .swiper-slide img {
		height: 200px;
	}

	#postslider .swiper-slide .caption {}

	#postslider .swiper-slide .caption .header {}

	#postslider .swiper-slide .caption .header .date {}

	#postslider .swiper-slide .caption h3 {}

	#postslider .swiper-slide .caption .cat {
		flex-wrap: wrap;
	}

	#postslider .swiper-slide .cat a {
	}
}

/*------------------------------------
共通パーツ・メニューの小リスト
------------------------------------*/
.contents-pack {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	justify-content: space-between;
}

.contents-pack a {}

.contents-list {
	width: calc((100% - 75px) / 4);
}

.contents-list h3 {
	font-size: var(--font-size_s);
	color: var(--color_1);
}

.contents-list ul {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 25px;
}

.contents-list li {
	width: 100%;
	font-size: var(--font-size_ss);
	color: var(--color_01);
	line-height: 2.2em;
}

.contents-list a {
	text-decoration: underline var(--color_06);
	text-underline-offset: 5px;
}

@media screen and (max-width: 699px) {
	.contents-pack {
		gap: 10px;
	}

	.contents-pack a {}

	.contents-list {
		width: 100%;
	}

	.contents-list h3 {}

	.contents-list ul {}

	.contents-list li {}

	.contents-list a {}
}

/*------------------------------------
共通パーツ・フッターのCTAバナーエリア
------------------------------------*/
#banner-area {}

#banner-area .background {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	filter: opacity(0.5);
}

#banner-area .background img {
	width: 100%;
	height: 100%;
}

#banner-area .flex-pack {
	padding-left: 300px;
}

#banner-area .flex-item {
	width: calc((100% - 100px) / 3);
	height: 225px;
}

#banner-area .flex-item a {
	position: relative;
	flex-wrap: wrap;
	width: 100%;
	height: 100%;
	text-align: center;
	transition: var(--ease_1);
	overflow: hidden;
}

#banner-area .flex-item a:hover {
	filter: brightness(1.3);
}

#banner-area .flex-item img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	filter: brightness(0.7);
	transition: var(--ease_1);
}

#banner-area .flex-item a:hover img {
	transform: scale(1.1);
}

#banner-area .flex-item .inner {
	z-index: 1;
}

#banner-area .flex-item h3 {
	font-size: var(--font-size_l);
	color: var(--color_f);
}

#banner-area .flex-item p {
	font-size: var(--font-size_ss);
	color: var(--color_f);
}

@media screen and (max-width: 699px) {
	#banner-area {}

	#banner-area .flex-pack {
		gap: 15px;
		padding-left: 15px;
	}

	#banner-area .flex-item {
		width: 100%;
		height: 100px;
	}

	#banner-area .flex-item a {}

	#banner-area .flex-item img {}

	#banner-area .flex-item h3 {
		font-size: var(--font-size_m);
	}

	#banner-area .flex-item p {
		font-size: var(--font-size_sss);
	}
}


/*------------------------------------ここからフッターコンテンツ------------------------------------*/


/*------------------------------------
footer
------------------------------------*/
#footer {
	position: relative;
	background: var(--color_4);
	z-index: 1;
	padding-top: 100px;
}

#footer .flex-pack {
	padding: 50px 0 100px 0;
}

#footer .flex-item {}

#footer .flex-item:nth-child(1) {
	width: calc(25% - 25px);
}

#footer .flex-item:nth-child(1) .footer-logo {
	justify-content: flex-start;
}

#footer .flex-item:nth-child(1) .footer-logo img {
	width: 150px;
}

#footer .flex-item:nth-child(1) .icon-list {
	justify-content: flex-start;
	margin-top: 50px;
}

#footer .flex-item:nth-child(1) .icon-list i {}

#footer .flex-item:nth-child(1) .icon-list img {
	width: 30px;
}

#footer .flex-item:nth-child(2) {
	width: calc(75% - 25px);
}

#footer .contents-list h3 {}

#footer .contents-list li {}

#footer .copyright {
	padding: 25px 0;
	font-size: var(--font-size_ss);
}

@media screen and (max-width: 699px) {
	#footer {
		position: relative;
		z-index: 1;
		padding-top: 0;
	}

	#footer .flex-pack {
		padding: 75px 25px;
		gap: 50px;
	}

	#footer .flex-item {
		gap: 25px;
		width: 100%;
		color: var(--color_f);
	}

	#footer {
		padding-top: 0;
	}

	#footer .flex-pack {
		flex-wrap: wrap-reverse;
		padding: 75px 25px;
		gap: 50px;
	}

	#footer .flex-item {
		gap: 25px;
		width: 100%;
	}

	#footer .flex-item:nth-child(1) {
		width: 100%;
	}

	#footer .flex-item:nth-child(1) .footer-logo {}

	#footer .flex-item:nth-child(1) .footer-logo img {
		width: 125px;
	}

	#footer .flex-item:nth-child(1) .icon-list {}

	#footer .flex-item:nth-child(1) .icon-list i {}

	#footer .flex-item:nth-child(1) .icon-list img {}

	#footer .flex-item:nth-child(2) {
		width: 100%;
	}

	#footer .contents-list h3 {}

	#footer .contents-list li {}

	#footer .copyright {
		padding: 25px 0;
		font-size: var(--font-size_ss);
	}
}