/*
Thame Name:eyely
Thame URL:
Description:eyely
Author:Katayama
Version:1.0
*/

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

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

#wpadminbar:hover {
	background: rgba(0, 0, 0, 0.8) !important;
}

/*------------------------------------
変数
------------------------------------*/
:root {
	--font-family_1: "Manrope", "Open Sans", "Noto Sans JP", "Hiragino Kaku Gothic ProN", -apple-system, BlinkMacSystemFont, sans-serif;
	--font-family_2: "Manrope", "Open Sans", "Hiragino Kaku Gothic ProN", -apple-system, BlinkMacSystemFont, sans-serif;
	--font-family_3: "PT Sans Narrow", sans-serif;
	--font-family_4: "Kosugi Maru", sans-serif;

	--font-size_ssss: 0.6rem !important;
	--font-size_sss: 0.8rem !important;
	--font-size_ss: 0.9rem !important;
	--font-size_s: 1rem !important;
	--font-size_mm: 1.1rem !important;
	--font-size_m: 1.3rem !important;
	--font-size_l: 1.6rem !important;
	--font-size_ll: 1.9rem !important;
	--font-size_lll: 2.5rem !important;
	--font-size_llll: 4.1rem !important;

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

	/* =========================
	Black
	========================= */
	--color_00: hsl(32 10% 10%);
	--color_01: hsl(32 10% 18%);
	--color_02: hsl(32 10% 37%);
	--color_03: hsl(32 10% 48%);
	--color_04: hsl(32 10% 57%);
	--color_05: hsl(32 10% 65%);
	--color_06: hsl(32 10% 73%);
	--color_07: hsl(32 10% 82%);
	--color_08: hsl(32 10% 91%);
	--color_09: hsl(32 10% 96%);

	/* =========================
	Brown
	========================= */
	--color_10: hsl(25 38% 28%);
	--color_11: hsl(25 38% 40%);
	--color_12: hsl(25 38% 62%);
	--color_13: hsl(25 38% 78%);
	--color_14: hsl(25 38% 96%);

	/* =========================
	Orange
	========================= */
	--color_20: hsl(18 72% 50%);
	--color_21: hsl(18 72% 62%);
	--color_22: hsl(18 72% 72%);
	--color_23: hsl(18 72% 86%);
	--color_24: hsl(18 72% 96%);

	/* =========================
	Yellow
	========================= */
	--color_30: hsl(45 82% 42%);
	--color_31: hsl(45 82% 54%);
	--color_32: hsl(45 82% 66%);
	--color_33: hsl(45 82% 82%);
	--color_34: hsl(45 82% 96%);

	/* =========================
	Green
	========================= */
	--color_40: hsl(175 34% 40%);
	--color_41: hsl(175 34% 52%);
	--color_42: hsl(175 34% 64%);
	--color_43: hsl(175 34% 82%);
	--color_44: hsl(175 34% 96%);

	/* =========================
	Blue
	========================= */
	--color_50: hsl(212 46% 36%);
	--color_51: hsl(212 46% 48%);
	--color_52: hsl(212 46% 60%);
	--color_53: hsl(212 46% 80%);
	--color_54: hsl(212 46% 96%);

	--color_bg_01: hsl(45 10% 96%);
	--color_bg_02: hsl(45 20% 100%);

	--color_sun: hsl(44, 100%, 65%);

	--color_f: hsl(0 0% 100%);

	--color_line: hsl(157 54% 44%);

	--color_bs_00: hsla(0 15% 5% / 0.20);

	--color_bs_1: hsla(30 11% 31% / 0.07);

	--color_bs_2: hsla(30 11% 31% / 0.13);

	--color_bs_3: hsla(30 11% 31% / 0.20);

	--color_g_1: linear-gradient(to right, #f78ca0 0%, #f9748f 19%, #fd868c 60%, #fe9a8b 100%);
	--color_g_2: linear-gradient(90deg, rgba(35, 152, 255, 1), rgba(209, 254, 224, 1));
	--color_g_3: linear-gradient(120deg, #cfa38c 0%, #dfc5b7 100%);
	--color_g_4: linear-gradient(90deg, rgba(255, 233, 186, 1), rgba(222, 254, 209, 1));


	--shadow_1: 3px 3px 7px #0000001A;
	--shadow_2: 2px 2px 5px #0000001A;
	--shadow_3: 1px 1px 2px #0000001A;
	--shadow_0: 2px 2px 0 #1a1a1a;

	--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_01: solid 2px var(--color_01);
	--border_02: solid 2px var(--color_02);
	--border_03: solid 2px var(--color_03);
	--border_04: solid 2px var(--color_04);
	--border_05: solid 2px var(--color_05);
	--border_1: solid 2px var(--color_20);
	--border_2: solid 2px var(--color_21);
	--border_3: solid 2px var(--color_22);
	--border_4: solid 2px var(--color_23);
	--border_5: solid 2px var(--color_24);
	--border_f: solid 2px var(--color_f);

	--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;
}

@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: 1rem !important;
		--font-size_m: 1.2rem !important;
		--font-size_l: 1.4rem !important;
		--font-size_ll: 1.7rem !important;
		--font-size_lll: 2rem !important;
		--font-size_llll: 3.5rem !important;
	}
}

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

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

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

body::after {
	content: '';
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--color_bg_01);
	z-index: 9999;
	pointer-events: none;
	opacity: 0;
	-webkit-transition: opacity .8s ease;
	transition: opacity .8s ease;
}

body.fade::after {
	opacity: 1;
}

body .no-scroll {
	overflow: hidden;
}

.container {
	overflow: hidden;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	color: var(--color_01);
	font-weight: var(--font-weight_ll);
	line-height: 1.5em;
}

h1,
h2,
h3 {}

h4,
h5,
h6 {}

h2 {
	font-size: 2rem;
}

h3 {
	font-size: 1.3rem;
}

p,
a,
li,
i {
	font-family: var(--font-family_1);
	font-size: var(--font-size_s);
	color: var(--color_01);
	font-weight: var(--font-weight_m);
	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;
}

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

.white {
	color: var(--color_f) !important;
}

.black {
	color: var(--color_00) !important;
}

/*------------------------------------ここからレイアウトパーツ------------------------------------*/

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

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

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

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

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

.wrapper__over-left {
	width: calc(50% + 500px);
	max-width: 100vw;
	margin-left: 0;
	margin-right: auto;
}

.wrapper__over-right {
	width: calc(50% + 500px);
	max-width: 100vw;
	margin-left: auto;
	margin-right: 0;
}

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

.wrapper-wide__over-left {
	width: calc(50% + 600px);
	max-width: 100vw;
	margin-left: 0;
	margin-right: auto;
}

.wrapper-wide__over-right {
	width: calc(50% + 600px);
	max-width: 100vw;
	margin-left: auto;
	margin-right: 0;
}

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

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

	.wrapper,
	.wrapper__over-left,
	.wrapper__over-right,
	.wrapper-wide,
	.wrapper-wide__over-left,
	.wrapper-wide__over-right {}
}

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

.block-item {
	margin: 100px auto;
}

.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: 75px 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;
}

/*------------------------------------
左：sticky / 右メインコンテンツ
------------------------------------*/
.layout_1 {
	display: flex;
	flex-wrap: nowrap;
	align-items: stretch;
	justify-content: center;
	gap: 100px;
}

.layout_1 .left-pack {
	width: calc(50% - 50px);
	height: auto;
}

.layout_1 .left-pack .inner {
	position: sticky !important;
	top: 25px;
}

.layout_1 .right-pack {
	width: calc(50% - 50px);
}

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

	.layout_1 .left-pack {
		width: 100%;
	}

	.layout_1 .left-pack .inner {
		position: relative;
	}

	.layout_1 .right-pack {
		width: 100%;
	}
}

/*------------------------------------
左：メインコンテンツ / 右sticky
------------------------------------*/
.layout_2 {
	display: flex;
	flex-wrap: nowrap;
	align-items: stretch;
	justify-content: center;
	gap: 100px;
}

.layout_2 .left-pack {
	width: calc(50% - 50px);
}

.layout_2 .right-pack {
	width: calc(50% - 50px);
	height: auto;
}

.layout_2 .right-pack .inner {
	position: sticky !important;
	top: 25px;
}

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

	.layout_2 .left-pack {
		width: 100%;
	}

	.layout_2 .right-pack {
		width: 100%;
	}

	.layout_2 .right-pack .inner {
		position: relative;
	}
}

/*------------------------------------
背景カラー
------------------------------------*/
.bg_01::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--color_bg_01);
	z-index: -3;
}

.bg_02::after {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--color_bg_02);
	z-index: -3;
}

/*------------------------------------
背景パターン
------------------------------------*/
/*斜めストライプ*/
.pattern_1 {
	background-image: repeating-linear-gradient(-45deg,
			var(--color_07) 0,
			var(--color_07) 1px,
			transparent 1px,
			transparent 50%);
	background-size: 15px 15px;
	background-repeat: repeat;
}

/*------------------------------------
境界線
------------------------------------*/
/*ギザギザ*/
.boundary {
	background: var(--color_24);
}

.boundary::before,
.boundary::after {
	content: "";
	position: absolute;
	width: 100%;
	height: 20px;
	background:
		linear-gradient(-45deg, var(--color_24) 10px, transparent 0),
		linear-gradient(45deg, var(--color_24) 10px, transparent 0);
	background-size: 20px 20px;
	background-position: left bottom;
	background-repeat: repeat-x;
}

.boundary::before {
	top: -20px;
}

.boundary::after {
	bottom: -20px;
	transform: scaleY(-1);
}

/*------------------------------------
枠パーツ
------------------------------------*/
.box_1 {
	position: relative;
	width: 100%;
	height: 100%;
	padding: 30px 30px 35px 30px;
	background: var(--color_f);
	border: var(--border_2);
}

.box_2 {
	position: relative;
	width: 100%;
	height: 100%;
	padding: 30px 30px 35px 30px;
	background: var(--color_f);
	border: var(--border_01);
}

.box_3 {
	position: relative;
	width: 100%;
	height: 100%;
	padding: 50px;
	background: var(--color_f);
}

.box_4 {
	position: relative;
	width: 100%;
	height: 100%;
	padding: 20px 20px 30px 20px;
	background: var(--color_f);
	border-radius: var(--radius_1);
	z-index: 0;
}

.box_5 {
	position: relative;
}

.box_5::after {
	content: '';
	position: absolute;
	top: 15px;
	left: 15px;
	width: 100%;
	height: 100%;
	background-image: repeating-linear-gradient(-45deg,
			var(--color_07) 0,
			var(--color_07) 1px,
			transparent 1px,
			transparent 50%);
	background-size: 15px 15px;
	background-repeat: repeat;
	z-index: -1;
}

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

	.box_2 {
		padding: 25px 25px 35px 25px;
	}

	.box_3 {}

	.box_4 {}
}

/*------------------------------------
テキストボックス
------------------------------------*/
/*テキストボックス1*/
.content_1 {
	position: relative;
	margin: 25px auto;
}

.content_1 .title {
	font-family: var(--font-family_3);
	font-size: var(--font-size_ss);
	color: var(--color_20);
	font-weight: var(--font-weight_s);
	letter-spacing: 0.1em;
	line-height: 1.5em;
}

.content_1 .sub-title {
	margin-top: 20px;
	font-family: var(--font-family_1);
	font-size: var(--font-size_l);
	font-weight: var(--font-weight_ll);
	letter-spacing: 0.1em;
	line-height: 1.85em;
}

.content_1 .caption {
	margin-top: 25px;
}

.content_1 .caption p {
	margin-top: 20px;
	font-size: var(--font-size_s);
}

.content_1 .caption p:nth-child(1) {
	margin-top: 0;
}

.content_1 .caption p:nth-child(1) {
	margin-top: 0;
}

.content_1 .btn_4 {
	margin-top: 75px;
}

.content_1 .btn_4 a {
	margin-left: 0;
	margin-right: auto;
}

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

/*テキストボックス2*/
.content_2 {}

.content_2 .title {
	font-size: var(--font-size_l);
	font-weight: var(--font-weight_l);
}

.content_2 .caption {
	margin-top: 25px;
}

.content_2 .caption p {
	margin-bottom: 25px;
}

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

	.content_2 .title {
		font-size: var(--font-size_m);
	}

	.content_2 .caption {
		margin-top: 15px;
	}

	.content_2 .caption p {}
}

/*注記*/
.note_1 {
	margin: 10px auto 5px auto;
}

.note_1 p {
	font-size: var(--font-size_ss);
	font-weight: var(--font-weight_s);
	color: var(--color_03);
}

.note_2 {
	margin: 0px auto 25px;
	padding: 10px;
	background: var(--color_10);
}

.note_2 p {
	font-size: var(--font-size_sss);
	font-weight: var(--font-weight_s);
	color: var(--color_06);
}

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

/*------------------------------------
見出し
------------------------------------*/
.title_l {
	font-family: var(--font-family_4);
	font-size: 75px;
	color: var(--color_01);
	font-weight: var(--font-weight_l);
	line-height: 1.5em;
}

.title_m {
	font-family: var(--font-family_4);
	font-size: 50px;
	color: var(--color_01);
	font-weight: var(--font-weight_l);
	line-height: 1.5em;
}

.title_s {
	font-family: var(--font-family_4);
	font-size: 30px;
	color: var(--color_01);
	font-weight: var(--font-weight_l);
	line-height: 1.5em;
}

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

	.title_m {
		font-size: 35px;
	}

	.title_s {
		font-size: 25px;
	}
}


/*------------------------------------
大見出し
------------------------------------*/
.section-title_1 {
	position: relative;
	width: 100%;
	margin: 0 auto 50px auto;
	padding-bottom: 25px;
}

.section-title_1 p {
	font-family: var(--font-family_1);
	font-size: var(--font-size_llll);
	color: var(--color_23);
	font-weight: var(--font-weight_s);
	letter-spacing: 0.1em;
	line-height: 1.2em;
}

.section-title_1 h2,
.section-title_1 h3 {
	position: relative;
	font-size: var(--font-size_m);
	color: var(--color_20);
	font-weight: var(--font-weight_ll);
	line-height: 2em;
}

.section-title_1 h2::before,
.section-title_1 h3::before {
	content: '';
	position: absolute;
	bottom: -25px;
	left: 0;
	width: 50px;
	height: 4px;
	background: var(--color_23);
	border-radius: var(--radius_5);
}

/*基本色*/
.st_1__normal p {
	color: hsl(25 80% 80%);
}

.st_1__normal h2,
.st_1__normal h3 {
	color: hsl(25 80% 50%);
}

.st_1__normal h2::before,
.st_1__normal h3::before {
	background: hsl(25 80% 80%);
}

/*ブラウン*/
.st_1__brown p {
	color: hsl(45 80% 80%);
}

.st_1__brown h2,
.st_1__brown h3 {
	color: hsl(45 80% 50%);
}

.st_1__brown h2::before,
.st_1__brown h3::before {
	background: hsl(45 80% 80%);
}

/*グレー*/
.st_1__gray p {
	color: var(--color_06);
}

.st_1__gray h2,
.st_1__gray h3 {
	color: var(--color_03);
}

.st_1__gray h2::before,
.st_1__gray h3::before {
	background: var(--color_03);
}

/*イエロー*/
.st_1__yellow p {
	color: var(--color_33);
}

.st_1__yellow h2,
.st_1__yellow h3 {
	color: var(--color_30);
}

.st_1__yellow h2::before,
.st_1__yellow h3::before {
	background: var(--color_33);
}

/*ブルー*/
.st_1__blue p {
	color: var(--color_53);
}

.st_1__blue h2,
.st_1__blue h3 {
	color: var(--color_50);
}

.st_1__blue h2::before,
.st_1__blue h3::before {
	background: var(--color_53);
}

/*グリーン*/
.st_1__green p {
	color: var(--color_43);
}

.st_1__green h2,
.st_1__green h3 {
	color: var(--color_40);
}

.st_1__green h2::before,
.st_1__green h3::before {
	background: var(--color_43);
}

/*ホワイト*/
.st_1__white p {
	color: var(--color_f);
}

.st_1__white h2,
.st_1__white h3 {
	color: var(--color_f);
}

.st_1__white h2::before,
.st_1__white h3::before {
	background: var(--color_f);
}


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

	.section-title_1 h2,
	.section-title_1 h3 {
		font-size: var(--font-size_m);
	}

	.section-title_1 h2::before,
	.section-title_1 h3::before {
		top: auto;
		bottom: -20px;
		left: 0;
	}
}


.section-title_4 {
	margin: 0 auto 25px auto;
	padding: 25px 15px;
	border-top: solid 1px var(--color_01);
	border-bottom: solid 1px var(--color_01);
}

.section-title_4 h2,
.section-title_4 h3 {
	font-family: var(--font-family_2);
	font-size: var(--font-size_l);
	letter-spacing: 0.1em;
}

.section-title_4 h2 span,
.section-title_4 h3 span {
	font-size: var(--font-size_s);
}

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

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

.section-title_5 {
	display: flex;
	margin-bottom: 20px;
}

.section-title_5 h2,
.section-title_5 h3 {
	font-family: var(--font-family_2);
	font-size: var(--font-size_m);
}

.section-title_5 p {}

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

.section-title_6 {
	position: relative;
	width: 100%;
	text-align: left;
	margin-bottom: 10px;
}

.section-title_6 h2 {
	font-family: var(--font-family_4);
	font-size: 45px;
	color: var(--color_22);
}

.section-title_6 p {
	position: absolute;
	bottom: 0;
	left: 0;
	transform: translateY(-3px);
	font-family: var(--font-family_2);
	font-size: 15px;
}

@media screen and (max-width: 699px) {
	.section-title_6 {
		margin-bottom: 25px;
	}

	.section-title_6 h2 {
		font-size: 60px;
	}

	.section-title_6 p {
		transform: translateY(-5px);
		font-size: 20px;
	}
}

.section-title_7 {
	position: relative;
	display: flex;
	align-items: baseline;
	gap: 10px;
	text-align: left;
	margin-bottom: 25px;
}

.section-title_7 h2 {
	font-family: var(--font-family_4);
	font-size: 45px;
	font-weight: var(--font-weight_l);
	color: var(--color_20);
}

.section-title_7 p {
	font-family: var(--font-family_2);
	font-size: 17px;
}

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

	.section-title_7 h2 {
		font-size: 35px;
	}

	.section-title_7 p {}
}

/*------------------------------------
リストデザイン
------------------------------------*/
.list-pack {
	display: flex;
	flex-wrap: nowrap;
	align-items: stretch;
	gap: 25px;
	width: 100%;
}

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

/*リストデザイン1*/
.list_1 {
	width: fit-content;
	min-width: 300px;
	max-width: 100%;
	padding: 15px 20px 15px 35px;
	background: var(--color_f);
	border: var(--border_3);
	border-radius: var(--radius_1);
}

.list_1 .title {
	margin-bottom: 10px !important;
	font-size: var(--font-size_mm);
	color: var(--color_21);
	font-weight: var(--font-weight_ll);
}

.list_1 ul {
	list-style: decimal;
}

.list_1 li {
	font-size: var(--font-size_ss);
}

.list_1 .note {
	margin: 15px auto 0 !important;
	font-size: var(--font-size_sss);
	color: var(--color_22);
	line-height: 1em;
}

@media screen and (max-width: 699px) {
	.list_1 {
		width: 100%;
		min-width: 0;
	}

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

	.list_1 ul {}

	.list_1 li {}
}

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

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

.table_2 .row-header p,
.table_2 .row p,
.table_3 .row-header p,
.table_3 .row p {
	margin-top: 0;
	line-height: 1.5em;
}

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

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

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

.table_2 .cell:nth-child(1) {
	width: calc(40% - 15px);
}

.table_2 .cell:nth-child(2) {
	width: calc(60% - 15px);
}

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

.table_2 .cell p,
.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 .row-header p,
	.table_3 .row-header p {
		font-size: var(--font-size_ss);
	}

	.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,
	.table_2 .cell a,
	.table_3 .cell a {
		font-size: var(--font-size_ss);
	}

	.table_2 .note,
	.table_3 .note {}

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

/*------------------------------------
グリッドレイアウト
------------------------------------*/
.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;
	}
}

/*------------------------------------
ボタンデザイン
------------------------------------*/
.btn-pack {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 15px;
	margin-top: 25px;
}

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

/*共通*/
.btn_1,
.btn_2,
.btn_3,
.btn_line {
	position: relative;
	display: flex;
	justify-content: center;
	margin: 35px auto 0 auto;
	min-width: 250px;
	max-width: 300px;
}

.btn_1 a,
.btn_2 a,
.btn_3 a,
.btn_line a {
	width: 100%;
	padding: 20px 40px;
	text-align: center;
	font-family: var(--font-family_2);
	font-size: var(--font-size_s);
	line-height: 1em;
	letter-spacing: 0.1em;
	border: solid 1px var(--color_01);
	border-radius: var(--radius_5);
	transition: var(--ease_1);
}

.btn_1 a:hover,
.btn_2 a:hover,
.btn_3 a:hover,
.btn_line a:hover {}

.btn_1 a::after,
.btn_2 a::after,
.btn_3 a::after,
.btn_line a::after {
	position: absolute;
	top: 50%;
	right: 25px;
	transform: translate(0, -50%);
	font-family: "Font Awesome 6 Free";
	content: "\f105";
	font-weight: 900;
	transition: var(--ease_1);
}

.btn_1 a:hover,
.btn_2 a:hover,
.btn_3 a:hover,
.btn_line a:hover {}

.btn_1 a:hover::after,
.btn_2 a:hover::after,
.btn_3 a:hover::after,
.btn_line a:hover::after {
	transform: translate(5px, -50%);
}

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

	.btn_1,
	.btn_2,
	.btn_3,
	.btn_line {
		margin: 35px auto 0 auto;
	}
}

/*ベタ塗り*/
.btn_1 a {
	color: var(--color_f);
	background: var(--color_20);
	border-color: var(--color_20);
	transition: var(--ease_1);
}

.btn_1 a:hover {
	color: var(--color_20);
	background: none;
}

/*ボーダー*/
.btn_2 a {
	color: var(--color_40);
	background: none;
	border-color: var(--color_40);
}

.btn_2 a:hover {
	color: var(--color_f);
	background: var(--color_40);
}

/*白ボーダー*/
.btn_3 a {
	color: var(--color_f);
	background: none;
	border-color: var(--color_f);
}

.btn_3 a:hover {
	background: var(--color_bs_00);
}

/*LINE*/
.btn_line a {
	color: var(--color_f);
	background: var(--color_line);
	border-color: var(--color_f);
}

.btn_line a:hover {
	background: var(--color_bs_00);
}

/*矢印と下線の小ボタン*/
.btn_4 {
	width: 100%;
	margin-top: 25px;
}

.btn_4 a {
	position: relative;
	width: 90px;
	height: 90px;
	margin-left: auto;
	margin-right: 0;
	background: var(--color_22);
	border-radius: var(--radius_5);
	box-shadow: var(--shadow_1);
	transition: var(--ease_1);
}

.btn_4 a:hover {
	box-shadow: inset 2px 2px 3px var(--color_bs_1);
}

.btn_4 a p {
	font-family: var(--font-family_3);
	font-size: var(--font-size_mm);
	letter-spacing: 0.2em;
	color: var(--color_f);
	text-shadow: var(--shadow_3);
}

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

	.btn_4 a {
		font-size: var(--font-size_s);
	}

	.btn_4 a:hover {}

	.btn_4 a::after {}

	.btn_4 svg {
		width: 8px;
	}
}

/*街並みくるくるボタン*/
.btn_5 {
	position: relative;
	width: 115px;
	margin-top: 35px;
	margin-left: auto;
	margin-right: 0;
	transition: var(--ease_1);
}

.btn_5:hover {
	transform: scale(1.05);
}

.btn_5 img {
	animation: spin 20s linear infinite;
}

.btn_5 p {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-family: var(--font-family_3);
	font-size: var(--font-size_m);
	color: var(--color_02);
	letter-spacing: 0.1em;
}

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

/*リンクなしのダミーボタン(要素全体をホバー可した時用。今回は不使用)*/
.btn_dummy {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	background: var(--color_22);
	border-radius: var(--radius_5);
}

.btn_dummy svg {
	width: 10px;
	fill: var(--color_f);
	transition: var(--ease_1);
}

.btn_dummy_pack:hover .inner {}

.btn_dummy_pack:hover .inner svg {
	fill: var(--color_00);
}

/*------------------------------------
区切り線デザイン
------------------------------------*/
.separator_1 {
	all: unset;
	display: block;
	width: 100%;
	height: 10px;
	background-image: repeating-linear-gradient(-45deg,
			var(--color_05) 0,
			var(--color_05) 1px,
			transparent 1px,
			transparent 50%);
	background-size: 15px 15px;
}

/*------------------------------------
画像ホバーエフェクト
------------------------------------*/
.more-pack {
	position: relative;
	overflow: hidden;
}

.more-text {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	font-family: var(--font-family_2);
	font-size: var(--font-size_m);
	color: var(--color_f);
	opacity: 0;
	transition: var(--ease_1);
}

.more-pack img {
	height: 100%;
	transition: var(--ease_1);
}

.more-pack:hover img {
	filter: brightness(0.7) blur(3px);
	transform: scale(1.05);
}

.more-pack:hover .more-text {
	transform: translate(-50%, -50%);
	opacity: 1;
}

@media screen and (max-width: 699px) {
	.more-text {
		font-size: var(--font-size_mm);
	}
}

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

.accordion-area .accodion-item {
	margin: 25px auto;
	background: var(--color_f);
	border-radius: var(--radius_5);
	box-shadow: var(--shadow_1);
}

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

.accodion-title {
	position: relative;
	cursor: pointer;
	padding: 25px 40px 25px 25px;
	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: 30px;
	transform: rotate(-45deg);
}

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

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

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

.accodion-title h3 {
	font-size: var(--font-size_s);
	font-weight: var(--font-weight_l);
}

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

.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_42);
}

.close-btn {
	display: block;
	margin: 30px auto 0;
	padding: 8px 20px 8px 20px;
	color: var(--color_f);
	background: var(--color_00);
	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);
}

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

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

.tab-list>* {
	flex: 0 0 calc((100% - 6px) / 3);
}

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

.tab-item.active {
	background: var(--color_20);
}

.tab-content {
	display: block;
}

.tab-panel {
	display: none;
	width: 100%;
	padding: 25px;
	background: var(--color_f);
}

.tab-panel h4 {}

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

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

@media screen and (max-width: 799px) {
	.tab-item {
		font-size: var(--font-size_ss);
		padding: 10px 0;
	}
}

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

.parallax-1 {
	position: absolute;
	will-change: transform;
	transform: translate3d(0, 0, 0);
}

.parallax-1 {
	inset: -35% 0 -35% 0;
}

.parallax-1>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 {
	width: 100%;
	gap: 25px;
}

.icon-list a {
	display: flex;
	align-items: center;
}

.icon-list i {
	font-size: 30px;
}

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

/*------------------------------------
テキストアニメーション
------------------------------------*/
/*テキストアニメーション1*/
.textanimation1 {
	white-space: nowrap;
	/* 強制改行防止 */
}

.word {
	display: inline-flex;
}

.space {
	display: inline-block;
	width: 0.4em;
	/* スペース幅調整 */
}

/*テキストアニメーション2*/

/*------------------------------------
流れるテキスト
------------------------------------*/
.marquee-container {
	position: relative;
	width: 100%;
	height: 200px;
	margin: 0px auto;
	overflow: hidden;
	display: flex;
	align-items: center;
}

.marquee-text {
	position: absolute;
	white-space: nowrap;
	will-change: transform;
	font-family: var(--font-family_4);
	font-size: 200px;
	font-weight: light;
	letter-spacing: 0;
	color: var(--color_f);
}

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

	.marquee-text {
		position: absolute;
		font-size: 100px;
	}
}


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

/*------------------------------------
共通パーツ・ロゴ
------------------------------------*/
.logo {}

.logo svg {
	width: 100px;
	fill: var(--color_01);
}

.logo .caption {
	margin-top: 5px;
	font-family: var(--font-family_1);
	font-size: var(--font-size_sss);
}

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

/*------------------------------------
共通パーツ・bg
------------------------------------*/
.bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
}

.bg img {
	height: 100%;
}

.bg-left,
.bg-right {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -3;
}

.bg-left {
	background: var(--color_bg_01);
}

.bg-right {
	background: var(--color_bg_02);
	z-index: -3;
}

.bg-left::after,
.bg-right::after {
	content: '';
	position: absolute;
	top: 0;
	width: calc(50% + 750px);
	height: 100%;
	z-index: -2;
}

.bg-left::after {
	left: 0;
	background: var(--color_bg_02);
	border-radius: 0 100px 100px 0;
}

.bg-right::after {
	right: 0;
	background: var(--color_bg_01);
	border-radius: 100px 0 0 100px;
}

@media screen and (max-width: 699px) {
	.bg-left::after {
		width: 100%;
		border-radius: 0 50px 50px 0;
	}

	.bg-right::after {
		width: 100%;
		border-radius: 50px 0 0 50px;
	}
}


/*------------------------------------
共通パーツ・装飾
------------------------------------*/
.deco {
	position: absolute;
	z-index: -2;
}

.deco img {
	width: 500px;
	height: auto;
}

/*位置合わせ*/
.top-left {
	top: 0;
	left: 0;
	transform: translate(-50%, -50%);
}

.top-right {
	top: 0;
	right: 0;
	transform: translate(50%, -50%);
}

.bottom-left {
	bottom: 0;
	left: 0;
	transform: translate(-50%, 50%);
}

.bottom-right {
	bottom: 0;
	right: 0;
	transform: translate(50%, 50%);
}


@media screen and (max-width: 699px) {
	.deco img {
		width: 300px;
	}
}

/*------------------------------------
共通パーツ・ペットのイラスト
------------------------------------*/
.animal-illust {
	position: absolute;
}

.animal-illust img {
	width: 250px;
}

@media screen and (max-width: 699px) {
	.animal-illust img {
		width: 175px;
		padding: 10px;
	}
}

/*------------------------------------
共通パーツ・足跡のイラスト
------------------------------------*/
.foot-illust_1,
.foot-illust_2 {
	position: absolute;
	z-index: -1;
}

.foot-illust_1 img,
.foot-illust_2 img {
	width: 50px;
}

.foot-illust_1 {
	top: 50px;
	left: calc(50% + 550px);
	transform: rotate(45deg);
}

.foot-illust_2 {
	bottom: 50px;
	left: calc(50% - 600px);
	transform: rotate(45deg);
}

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

	.foot-illust_1,
	.foot-illust_2 {}

	.foot-illust_1 img,
	.foot-illust_2 img {
		width: 35px;
	}

	.foot-illust_1 {
		top: 0;
		left: calc(100% - 70px);
		transform: rotate(30deg);
	}

	.foot-illust_2 {
		bottom: 0;
		left: calc(0% + 20px);
		transform: rotate(30deg);
	}
}

/*------------------------------------
共通パーツ・パンくずリスト
------------------------------------*/
.bread_1 {
	position: absolute;
	top: 0;
	left: 0;
}

.bread_2 {
	position: relative;
}

.breadcrumbs {
	display: inline-block;
	width: auto;
	padding: 15px 0;
	font-family: var(--font-family_1);
	font-size: var(--font-size_ss);
	color: var(--color_06);
}

.breadcrumbs a {
	font-family: var(--font-family_1);
	font-size: var(--font-size_ss);
	color: var(--color_06);
	font-weight: var(--font-weight_s);
}

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

/*------------------------------------
共通パーツ・投稿リスト
------------------------------------*/
.post-card {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: flex-start;
	gap: 15px;
}

.post-card__image {
	position: relative;
	width: 100%;
	aspect-ratio: 3 / 2;
	overflow: hidden;
}

.post-card__image img {
	width: 100%;
	height: 100%;
}

.post-card__text {
	width: 100%;
	text-align: left;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: flex-start;
}

.post-card__header {
	width: 100%;
	justify-content: flex-start;
	align-items: baseline;
	gap: 10px;
}

.post-card__header .date,
.post-card__header .slug {
	font-family: var(--font-family_2);
	font-size: var(--font-size_ss);
	color: var(--color_02);
}

.post-card__text .category {}

.post-card__text .category a {
	position: relative;
	font-size: var(--font-size_ss);
	color: var(--color_02);
	text-decoration: none;
}

.post-card__text .title {
	width: 100%;
	margin-top: 5px;
	margin-bottom: 10px;
}

.post-card__text .title p,
.post-card__text .title a {
	font-family: var(--font-family_1);
	font-size: var(--font-size_mm);
	font-weight: var(--font-weight_l);
}

.post-card__text .tag {
	flex-wrap: wrap;
	justify-content: flex-start;
	gap: 3px;
	width: 100%;
}

.post-card__text .tag a {
	position: relative;
	padding: 5px 7px;
	font-size: var(--font-size_sss);
	color: var(--color_02);
	line-height: 1.1em;
}

.post-card__text .tag a::after {
	content: '';
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	width: 1px;
	height: 15px;
	background: var(--color_02);
}

.post-card__text .tag a:nth-last-child(1)::after {
	display: none;
}


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

	.post-card__text {}

	.post-card__text .category a,
	.post-card__text .category p {
		font-size: var(--font-size_sss);
	}

	.post-card__text .title {
		margin-top: 0;
		margin-bottom: 10px;
	}

	.post-card__text .title p,
	.post-card__text .title a {}
}

/*------------------------------------
共通パーツ・関連記事
------------------------------------*/
#related {}

#related .flex-pack {
	align-items: stretch;
	gap: 25px;
}

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

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

	#related .flex-pack {
		flex-wrap: wrap;
		align-items: flex-start;
		justify-content: flex-start;
	}

	#related .post-card {
		flex-wrap: nowrap;
		align-items: center;
		width: 100%;
		padding: 15px;
	}

	#related .post-card {}

	#related .post-card__image {
		width: calc(30% - 7.5px);
		aspect-ratio: 1 / 1;
	}

	#related .post-card__image img {
		height: 100%;
	}

	#related .post-card__image:hover img {}

	#related .post-card__text {
		width: calc(70% - 7.5px);
	}

	#related .post-card__text .title {
		margin-bottom: 0;
	}

	#related .post-card__text .title a {
		font-size: var(--font-size_s);
	}

	#related .post-card__text .tag {
		display: none;
	}

	#related .post-card__text .btn_4 {}
}



/*------------------------------------
問い合わせフォーム
------------------------------------*/
.form-pack {
	position: relative;
	padding: 50px;
	background: var(--color_f);
	border-radius: var(--radius_1);
	box-shadow: var(--shadow_1);
}

.form-item {
	margin: auto;
}

#contactForm {
	width: 100%;
}

#contactForm .table_2 {}

#contactForm .form-parts {
	border-bottom: none;
}

#contactForm .form-parts .cell:nth-child(1) p {
	font-weight: var(--font-weight_ll);
}

#contactForm .required-mark {
	color: var(--color_42);
	margin-left: 5px;
}

#contactForm .form-parts input,
#contactForm .form-parts textarea {
	width: 100%;
	margin-bottom: 5px;
	padding: 5px 15px;
	background: var(--color_24);
	border-radius: var(--radius_1);
}

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

#contactForm .form-parts select {
	width: auto;
	padding: 5px;
	background: var(--color_09);
	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 .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 .send {
	text-align: center;
}

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

#contactForm .send input:hover {
	color: var(--color_00);
	background: none;
}

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

.thanks-message h3 {}

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

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

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

	#contactForm .row {
		flex-wrap: wrap;
		border-bottom: none;
	}

	#contactForm .cell {
		width: 100%;
	}
}

/*------------------------------------
共通パーツ・投稿スライダー
------------------------------------*/
#postslider {
	padding-top: 75px;
}

#postslider .swiper3 {}

#postslider .swiper-wrapper {}

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

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

#postslider .swiper-slide img {
	height: 100%;
}

#postslider .swiper-slide .caption {
	margin-top: 5px;
	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 {
	margin-top: 10px;
	text-align: left;
	font-size: var(--font-size_s);
	font-weight: var(--font-weight_m);
}

#postslider .swiper-slide .caption p {
	margin-top: 0px;
	font-size: var(--font-size_ss);
}

@media screen and (max-width: 699px) {
	#postslider .swiper-slide .image-link {
		height: 200px;
	}

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

/*------------------------------------
pricetable
------------------------------------*/
#pricetable {}

#pricetable .flex-pack {
	flex-wrap: wrap;
	align-items: stretch;
	justify-content: space-between;
	gap: 70px;
}

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


#pricetable .flex-item:nth-child(1) {
	position: relative;
}

#pricetable .animal-illust {
	bottom: 0;
	right: 0;
}

#pricetable .flex-item:nth-child(1),
#pricetable .flex-item:nth-child(6) {
	width: 200px;
}

#pricetable .flex-item:nth-last-child(1) p {}

#pricetable .flex-item:nth-child(2),
#pricetable .flex-item:nth-child(3),
#pricetable .flex-item:nth-child(4),
#pricetable .flex-item:nth-child(5) {
	position: relative;
	padding: 50px;
	background: var(--color_f);
	border: var(--border_03);
	border-radius: var(--radius_1);
	box-shadow: var(--shadow_1);
}

#pricetable .flex-item:nth-child(2)::before,
#pricetable .flex-item:nth-child(3)::before,
#pricetable .flex-item:nth-child(4)::before,
#pricetable .flex-item:nth-child(5)::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 10px;
	height: 100%;
	border-radius: 7.5px 0 0 7.5px;
}

#pricetable .flex-item:nth-child(2)::before {
	background: var(--color_22);
}

#pricetable .flex-item:nth-child(3)::before {
	background: var(--color_33);
}

#pricetable .flex-item:nth-child(4)::before {
	background: var(--color_42);
}

#pricetable .flex-item:nth-child(5)::before {
	background: var(--color_03);
}

#pricetable .flex-item:nth-child(2)::after,
#pricetable .flex-item:nth-child(3)::after,
#pricetable .flex-item:nth-child(4)::after,
#pricetable .flex-item:nth-child(5)::after {
	border-radius: var(--radius_1);
}

#pricetable .flex-item:nth-child(6) {
	align-items: flex-end;
	justify-content: flex-end;
}

#pricetable .flex-item:nth-child(6) .inner {}

#pricetable .flex-item:nth-child(6) .text p {
	font-size: var(--font-size_mm);
}

#pricetable .flex-item:nth-child(6) .text p::after {
	font-family: "Font Awesome 5 Free";
	content: '\f063';
	font-weight: 900;
}

#pricetable .menu-header {
	align-items: baseline;
	justify-content: flex-start;
	gap: 10px;
}

#pricetable .menu-header svg {
	width: 50px;
	fill: var(--color_01);
}

#pricetable .menu-header p {
	font-size: var(--font-size_m);
	font-weight: var(--font-weight_l);
}

#pricetable .table_2,
#pricetable .table_3 {}

#pricetable .table_2 .row,
#pricetable .table_3 .row {
	padding: 0;
	border-bottom: none;
}

#pricetable .table_2 .row-header .cell p,
#pricetable .table_3 .row-header .cell p {
	font-size: var(--font-size_s) !important;
}

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

#pricetable .table_2 .cell:nth-child(1) p,
#pricetable .table_3 .cell:nth-child(1) p {
	font-size: var(--font-size_ss);
}

#pricetable .table_2 .cell:nth-child(2) p,
#pricetable .table_3 .cell:nth-child(2) p,
#pricetable .table_3 .cell:nth-child(3) p {
	font-size: var(--font-size_mm);
}

#pricetable .table_2 .cell:nth-child(2) span,
#pricetable .table_3 .cell:nth-child(2) span,
#pricetable .table_3 .cell:nth-child(3) span {
	font-size: var(--font-size_l);
	padding: 0 2px;
}

#pricetable .table_2 .cell:nth-child(1) {
	width: 72.5%;
}

#pricetable .table_2 .cell:nth-child(2) {
	width: 27.5%;
}

#pricetable .table_3 .cell:nth-child(1) {
	width: 45%;
}

#pricetable .table_3 .cell:nth-child(2) {
	width: 27.5%;
}

#pricetable .table_3 .cell:nth-child(3) {
	width: 27.5%;
}

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

	#pricetable .animal-illust {}

	#pricetable .flex-pack {
		gap: 0;
	}

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

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

	#pricetable .flex-item:nth-child(2),
	#pricetable .flex-item:nth-child(3),
	#pricetable .flex-item:nth-child(4),
	#pricetable .flex-item:nth-child(5) {
		padding: 25px;
	}

	#pricetable .flex-item:nth-child(3),
	#pricetable .flex-item:nth-child(4),
	#pricetable .flex-item:nth-child(5),
	#pricetable .flex-item:nth-child(6) {
		margin-top: 50px;
	}

	#pricetable .flex-item:nth-child(6) .inner {
		display: flex;
		align-items: center;
	}

	#pricetable .flex-item:nth-child(6) .text {
		display: flex;
		justify-content: center;
		width: 100%;
		margin-right: 25px;
	}

	#pricetable .flex-item:nth-child(6) .text p::after {
		content: '\f061';
	}

	#pricetable .flex-item:nth-child(6) .btn_4 {
		width: 100px;
		margin-top: 0;
	}

}



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


/*------------------------------------
header
------------------------------------*/
#header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 150px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	z-index: 10;
	pointer-events: none;
}

/* トップページだけ初期位置を40px下げる */
.home #header,
.front-page #header {
	transform: translateY(40px);
}

.home #header.is-fixed,
.front-page #header.is-fixed {
	top: 0;
}

/* fixedになったら0に戻す */
#header.is-fixed {
	position: fixed;
	top: 0;
	left: 0;
}

#header .nav {
	text-align: center;
}

@media screen and (max-width: 699px) {
	#header {
		top: 0;
	}

	body.header-front-only #header:not(.is-fixed) {
		top: 0px;
	}
}

/*------------------------------------
header
------------------------------------*/
/*メインロゴ*/
#header .header-logo {
	position: absolute;
	top: 20px;
	left: 20px;
	transition: var(--ease_1);
}

#header .header-logo a {
	align-items: center;
	gap: 15px;
	pointer-events: all;
}

#header .header-logo .logo_1 {
	width: 85px;
	transition: var(--ease_1);
}

#header .header-logo .logo_2 {
	width: 200px;
	transition: var(--ease_1);
}

#header.is-fixed .header-logo {
	top: 40px;
}

#header.is-fixed .header-logo .logo_1 {
	width: 70px;
}

#header.is-fixed .header-logo .logo_2 {
	width: 180px;
}

@media screen and (max-width: 699px) {
	#header .header-logo {
		top: 15px;
		left: 15px;
	}

	#header .header-logo a {
		gap: 10px;
	}

	#header .header-logo .logo_1 {
		width: 55px;
		transition: var(--ease_1);
	}

	#header .header-logo .logo_2 {
		width: 130px;
		transition: var(--ease_1);
	}

	#header.is-fixed .header-logo {
		top: 15px;
	}

	#header.is-fixed .header-logo .logo_1 {
		width: 55px;
	}

	#header.is-fixed .header-logo .logo_2 {
		width: 130px;
	}
}

/*------------------------------------
スマホナビ・コンテンツ
------------------------------------*/
.nav {
	text-align: center;
}

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

#navi .navi-container {
	flex-wrap: wrap;
	gap: 50px;
	height: 100%;
	padding: 75px 20px 50px 20px;
}

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

#navi .menu .navi-pack {
	list-style: none;
	display: block;
	width: 100%;
}

#navi .menu .navi-item {
	cursor: pointer;
	position: relative;
	padding: 15px 0 15px 0;
	text-align: left;
	line-height: 1em;
	border-bottom: dotted 2px var(--color_04);
}

#navi .menu .navi-item:nth-last-child(1) {
	border-bottom: none;
}

#navi .menu .navi-item::after {
	display: flex;
	align-items: center;
	justify-content: center;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translate(0, -50%);
	width: 25px;
	height: 25px;
	font-family: "Font Awesome 6 Free";
	color: var(--color_f);
	background: var(--color_32);
	border-radius: var(--radius_5);
	content: "\f105";
	font-weight: 900;
	transition: var(--ease_1);
}

#navi .menu .navi-item p:nth-child(1) {
	font-size: var(--font-size_l);
	letter-spacing: 0.1em;
}

#navi .menu .navi-item p:nth-child(2) {
	margin-top: 5px;
	font-size: var(--font-size_ss);
	font-weight: var(--font-weight_l);
}

/*スマホナビ・展開メニュー*/
#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 .navi-item,
#navi .reserve {
	opacity: 0;
	transform: translateY(15px);
	transition: opacity 0.3s ease-out, transform 0.3s ease-out;
}

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

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

	#navi {}

	#navi .navi-container {}

	#navi .menu {}

	#navi .menu .navi-pack {
	}

	#navi .menu .navi-item {
	}

	#navi .menu .navi-item:nth-child(1) {
		margin-top: 0;
	}

	#navi .menu .navi-item p {
		font-size: var(--font-size_mm);
		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_s);
	}

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

#navi .reserve {
	position: relative;
	padding: 15px 20px 25px 20px;
	background: var(--color_24);
	border-radius: var(--radius_1);
}

/*------------------------------------
スマホナビ・アイコン
------------------------------------*/
.navi-icon {
	position: absolute;
	top: 45px;
	right: 30px;
	transition: var(--ease_2);
}

.navi-icon .navi-icon-pack {
	flex-direction: row-reverse;
	gap: 20px;
	height: 50px;
}

.navi-icon .navi-icon-item {
	position: relative;
}

.navi-icon .navi-icon-item:nth-child(1) {
	z-index: 101;
}

.navi-icon .navi-icon-item:nth-child(2),
.navi-icon .navi-icon-item:nth-child(3) {
	z-index: 99;
}

.navi-icon .navi-icon-item a {
	gap: 10px;
	padding: 10px 25px;
	transition: var(--ease_1);
	pointer-events: all;
	border-radius: var(--radius_5);
}

.navi-icon .navi-icon-item a:hover {
	opacity: 0.5;
}

.navi-icon .navi-icon-item img,
.navi-icon .navi-icon-item svg {
	width: 20px;
	height: 20px;
}

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

.navi-icon .navi-icon-item .line svg {
	fill: var(--color_f);
}

.navi-icon .navi-icon-item .line p {
	color: var(--color_f);
}

.navi-icon .navi-icon-item .mail {
	background: var(--color_32);
}

.navi-icon .navi-icon-item .mail p {
	color: var(--color_f);
}

.navi-icon .navi-icon-item .mail i {
	font-size: var(--font-size_mm);
	color: var(--color_f);
}

.navi-icon .navi-icon-item .phone {}

.navi-icon .navi-icon-item .phone .inner {}

.navi-icon .navi-icon-item .phone .inner p {
	position: relative;
	line-height: 1.3em;
}

.navi-icon .navi-icon-item .phone .inner i {
	position: absolute;
	top: 50%;
	left: -30px;
	transform: translateY(-50%);
	font-size: 20px;
}

.navi-icon .navi-icon-item .phone .inner p:nth-child(1) {
	display: flex;
	align-items: center;
	font-family: var(--font-family_3);
	font-size: var(--font-size_l);
}

.navi-icon .navi-icon-item .phone .inner p:nth-child(2) {
	font-size: var(--font-size_ss);
}

@media screen and (max-width: 999px) {
	.navi-icon {
		top: 15.5px;
		right: 10px;
	}

	.navi-icon .navi-icon-pack {
		flex-wrap: wrap;
		gap: 10px 0;
		width: 60px;
	}

	.navi-icon .navi-icon-item a {
		flex-wrap: wrap;
		gap: 0;
		width: 55px;
		height: 55px;
		padding: 7px;
		border-radius: var(--radius_5);
		box-shadow: 0 3px 5px var(--color_bs_3);
	}

	.navi-icon .navi-icon-item img,
	.navi-icon .navi-icon-item svg {
		width: 25px;
		height: 25px;
	}

	.navi-icon .navi-icon-item p {
		font-size: var(--font-size_sss);
		line-height: 1em;
		letter-spacing: 0.1em;
	}

	.navi-icon .navi-icon-item .phone {
		display: none;
	}

	.navi-icon .navi-icon-item .mail {}

	.navi-icon .navi-icon-item .mail i {
		font-size: var(--font-size_m);
	}

	.navi-icon .navi-icon-item .line svg {
		width: 23px;
		height: 23px;
	}
}

/*------------------------------------
スマホナビ・ハンバーガーボタン
------------------------------------*/
.hamburger {
	display: none;
	cursor: pointer;
	width: 55px;
	height: 55px;
	background: var(--color_21);
	border-radius: var(--radius_5);
	box-shadow: 0 3px 5px var(--color_bs_3);
	z-index: 101;
	pointer-events: painted;
}

.hamburger span {
	position: absolute;
	background: var(--color_f);
	width: 20px;
	height: 2px;
	left: 17.5px;
	border-radius: var(--radius_10);
	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: 15px;
}

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

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

.hamburger p {
	position: absolute;
	bottom: 10px;
	left: 50%;
	transform: translateX(-50%);
	font-size: var(--font-size_sss) !important;
	color: var(--color_f);
	letter-spacing: 0.1em;
}

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

.nav_open .hamburger span {
	top: 20px;
}

.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);
}

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

/*クローズボタン*/
.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: 999px) {
	.hamburger {
		display: block;
	}

	.hamburger p {}
}

/*スマホナビ展開時の背景*/
.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;
}

/*------------------------------------
PCナビ
------------------------------------*/
#navi-pc {
	position: absolute;
	top: 0;
	width: 100%;
	height: 150px;
	z-index: 11;
	pointer-events: none;
}

#navi-pc .navi-pc-pack {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 35px;
	height: 100%;
	margin-left: 550px;
	list-style-type: none;
}

#navi-pc .navi-pc-item {
	position: relative;
	pointer-events: all;
}

#navi-pc .navi-pc-item a {
	padding: 25px 20px;
	position: relative;
	transition: var(--ease_2);
}

#navi-pc .navi-pc-item a p {
	text-decoration: none;
	font-family: var(--font-family_1);
	font-weight: var(--font-weight_l);
	letter-spacing: 0em;
	line-height: 1.4em;
}

#navi-pc .navi-pc-item a p:nth-child(1) {
	font-size: var(--font-size_m);
}

#navi-pc .navi-pc-item a p:nth-child(2) {
	font-size: var(--font-size_sss);
}


#navi-pc .navi-pc-item a:hover {
	opacity: 0.5;
}

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

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

#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;
	overflow: hidden;
}

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

#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 .submenu li a::after {
	bottom: -5px !important;
}

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

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

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

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

#contact-btn a {
	flex-wrap: wrap;
	gap: 10px;
	position: relative;
	height: 50px;
	text-align: center;
	padding: 8px 0px;
	color: var(--color_f);
	background: var(--color_f);
	border-radius: var(--radius_5);
	box-shadow: var(--shadow_1);
	cursor: pointer;
}

#contact-btn .tel {
	width: calc(100% - 65px);
background: linear-gradient(90deg, var(--color_41) 0%, var(--color_42) 100%);}

#contact-btn .top {
	width: 50px;
	height: 50px;
	background: #ffffff66;
}

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

#contact-btn .top i {
	color: var(--color_04);
}

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

#contact-btn p {
	font-family: var(--font-family_3);
	font-size: var(--font-size_m);
	color: var(--color_f);
	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;
}

#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 {}

/*------------------------------------
フロートボタン(PC&SP)
------------------------------------*/
#float-btn {
	position: absolute;
	top: 0;
	right: 115px;
	height: 100px;
	z-index: 100;
	pointer-events: all;
}

#float-btn a {
	flex-wrap: wrap;
	gap: 10px;
	padding: 5px 25px;
	background: var(--color_01);
	border-radius: var(--radius_05);
	transition: var(--ease_1);
}

#float-btn a:hover {
	background: var(--color_03);
}

#float-btn a svg {
	width: 16px;
	fill: var(--color_f);
}

#float-btn a p {
	color: var(--color_f);
}


@media screen and (max-width: 999px) {
	#float-btn {
		right: 55px;
	}

	#float-btn a {
		padding: 5px 20px;
		background: none;
	}

	#float-btn a:hover {
		background: none;
	}

	#float-btn a svg {
		width: 30px;
		fill: var(--color_00);
	}

	#float-btn a p {
		display: none;
	}
}


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


/*------------------------------------
トップページ・オープニングアニメーション
------------------------------------*/
#opening {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--color_24);
}

#opening .opening-logo {
	text-align: center;
}

#opening .opening-logo .logo_1 {
	width: 80px;
	margin: auto;
}

#opening .opening-logo .logo_2 {
	width: 200px;
	margin: 15px auto 0;
}

#opening.is-hidden {
	display: none;
}

.site-main {
	opacity: 0;
}


/*------------------------------------
トップページ・top-bar
------------------------------------*/
.top-bar {
	gap: 10px;
	height: 40px;
	background-image: linear-gradient(135deg, #FD6E6A 10%, #FFC600 100%);
}

.top-bar p {
	font-size: var(--font-size_mm);
	color: var(--color_f);
	font-weight: var(--font-weight_l);
	text-shadow: var(--shadow_3);
}

/*------------------------------------
トップページ・mainvisual
------------------------------------*/
#mainvisual {
	position: relative;
	margin-bottom: 150px;
	padding: 150px 0 0 0;
	z-index: -1;
}

#mainvisual .mv {
	align-items: stretch;
	width: calc(50% + 800px);
}

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

	#mainvisual .mv {
		flex-wrap: wrap-reverse;
		gap: 10px;
	}
}

/*------------------------------------
トップページ・インフォメーションバー
------------------------------------*/
.information-bar {
	position: absolute;
	top: 120px;
	left: 20px;
	width: 300px;
	transition: var(--ease_1);
	background-image: linear-gradient(135deg, #FD6E6A 10%, #FFC600 100%);
	border-radius: var(--radius_5);
	z-index: 1;
}

.information-bar p {
	padding: 2px 0;
	font-size: var(--font-size_s);
	font-weight: var(--font-weight_l);
	color: var(--color_f);
}

#header.is-fixed .information-bar {
	opacity: 0;
}

@media screen and (max-width: 699px) {
	.information-bar {
		top: 84px;
		left: 0;
		width: 260px;
		border-radius: 0 50px 50px 0;
	}
}

/*------------------------------------
mainvisual 左
------------------------------------*/
#mainvisual .mv__left {
	position: relative;
	width: 550px;
}

#mainvisual .mv__left__intro {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -70%);
	text-align: center;
}

#mainvisual .mv__left__intro .main {
	font-family: var(--font-family_1);
	font-size: 2.2rem;
	color: var(--color_02);
	font-weight: bold;
	line-height: 1.5em;
	letter-spacing: 0.05em;
	white-space: nowrap;
}

#mainvisual .mv__left__intro .main .small {
	font-size: 0.8em;
}

#mainvisual .mv__left__intro .main .color {
	font-size: 1.3em;
	line-height: 1.7em;
	background: linear-gradient(90deg, var(--color_22), var(--color_31), var(--color_22));
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	color: transparent;
}

#mainvisual .mv__left__intro .sub {
	margin-top: 10px;
	font-size: var(--font-size_sss);
}

@media screen and (max-width: 699px) {
	#mainvisual .mv__left {
		width: 100%;
		height: 300px;
	}

	#mainvisual .mv__left__intro {
		top: 35px;
		left: 50%;
		transform: translate(-50%, 0);
	}

	#mainvisual .mv__left__intro .main {
		font-size: var(--font-size_l);
	}
}

/*------------------------------------
mainvisual 右
------------------------------------*/
#mainvisual .mv__right {
	position: relative;
	width: calc(100% - 550px);
	aspect-ratio: 16 / 9;
	min-height: 600px;
	z-index: -3;
}

#mainvisual .swiper1 {
	width: 100%;
	height: 100%;
	z-index: -1;
	border-radius: var(--radius_5);
	box-shadow: var(--shadow_1);
}

#mainvisual .swiper1 .swiper-wrapper {}

#mainvisual .swiper1 .swiper-slide {}

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

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

@media screen and (max-width: 699px) {
	#mainvisual .mv__right {
		margin: 0 calc(50% - 50vw);
		width: 100vw;
		aspect-ratio: 3 / 2;
		min-height: 0;
	}

	#mainvisual .swiper1 {
		border-radius: 0;
		z-index: -1;
	}

	#mainvisual .swiper1 .swiper-wrapper {}

	#mainvisual .swiper1 .swiper-slide {}

	#mainvisual .swiper1 .swiper-slide img {}

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

/* お知らせ */
#mainvisual .mv-pickup {
	position: absolute;
	bottom: 50px;
	left: 50%;
	transform: translate(-50%, 100%);
	width: 100%;
	padding: 25px 100px;
	background: var(--color_f);
	border: none;
	border-radius: var(--radius_10);
	box-shadow: var(--shadow_1);
}

#mainvisual .mv-pickup__item {
	padding: 5px;
}

#mainvisual .mv-pickup__item a {
	justify-content: flex-start;
	gap: 10px;
}

#mainvisual .mv-pickup__item .date,
#mainvisual .mv-pickup__item .slug {
	text-transform: uppercase;
	font-size: var(--font-size_ss);
	color: var(--color_20);
}

#mainvisual .mv-pickup__item .title {
	font-size: var(--font-size_ss);
}

@media screen and (max-width: 699px) {
	#mainvisual .mv-pickup {
		bottom: 0;
		margin: 0 auto 0 auto;
		padding: 25px 20px;
		border-top: solid 2px var(--color_22);
		border-bottom: solid 2px var(--color_22);
		border-radius: 0;
	}
}


/*------------------------------------
犬と街並み
------------------------------------*/
.walking-animation__pack {
	position: relative;
	height: 100%;
}

/*歩く犬*/
.dog {
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 2;
}

.dog::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: 69px;
	width: 100%;
	height: 10px;
	background: var(--color_bg_01);
}

.dog dotlottie-player {
	width: 350px;
	height: 350px;
	filter: contrast(0.9) brightness(1.1) grayscale(0.2);
}

/*街並み*/
.town {
	position: absolute;
	bottom: 100px;
	left: 0;
	margin: 0 calc(50% - 50vw);
	width: 100vw;
	z-index: -4;
}

.town-outer {
	overflow: hidden;
	width: 100%;
}

.town-inner {
	display: flex;
	width: 200%;
	/* ← 2セット分 */
	animation: townLoop 30s linear infinite;
}

.town-inner img {
	width: 25%;
	/* 200% ÷ 4枚 */
	flex-shrink: 0;
}

/* 無限ループ */
@keyframes townLoop {
	0% {
		transform: translateX(0);
	}

	100% {
		transform: translateX(-50%);
		/* ← 1セット分だけ動かす */
	}
}

/*くるくる太陽*/
.sun-pack {
	display: flex;
	justify-content: flex-end;
}

.sun-btn {
	position: relative;
	top: 50px;
	right: 50px;
	width: 70px;
	height: 70px;
	border: 0;
	border-radius: 50%;
	background: var(--color_sun);
	padding: 0;
	isolation: isolate;
	transition: var(--ease_1);
}

.sun-rays {
	position: absolute;
	inset: -32px;
	width: calc(100% + 64px);
	height: calc(100% + 64px);
	z-index: 1;
	pointer-events: none;
	fill: var(--color_sun);
	transform-origin: 50% 50%;
	animation: sunSpin 20s linear infinite;
}

/* 回転 */
@keyframes sunSpin {
	to {
		transform: rotate(360deg);
	}
}

/* 減速設定の人には止める */
@media (prefers-reduced-motion: reduce) {
	.sun-rays {
		animation: none;
	}
}

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

	/*歩く犬*/
	.dog {
		bottom: -25px;
		left: -50px;
	}

	.dog::after {
		bottom: 47px;
	}

	.dog dotlottie-player {
		width: 250px;
		height: 250px;
	}

	/*街並み*/
	.town {
		bottom: 50px;
	}

	.town-outer {}

	.town-inner {
		animation: townLoop 25s linear infinite;
	}

	.town-inner img {
		width: 75%;
	}

	/*くるくる太陽*/
	.sun-btn {
		top: 0;
		right: 0;
		width: 50px;
		height: 50px;
	}

	.sun-rays {
		inset: -30px;
		width: calc(100% + 60px);
		height: calc(100% + 60px);
	}
}

/*雲*/
.cloud {
	position: absolute;
	top: 0;
	left: 0;
	transform: translate(-50%, -50%);
}

.cloud img {
	width: 450px;
}

@media screen and (max-width: 699px) {
	.cloud img {
		width: 250px;
	}
}

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

#scenes .text_1 {
	text-align: center;
}

#scenes .text_1 p,
#scenes .text_2 p {
	font-weight: var(--font-weight_ll);
	line-height: 2.2em;
	text-decoration: underline;
	text-decoration-style: dotted;
	text-decoration-color: var(--color_02);
	text-decoration-thickness: 2px;
	text-underline-offset: 8px;
}

#scenes .text_1 p {
	font-size: var(--font-size_ll);
}

#scenes .text_1 p span,
#scenes .text_2 p span {
	color: var(--color_21);
}

#scenes .text_2 {
	position: relative;
	text-align: center;
}

#scenes .text_2::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -20%);
	width: 600px;
	height: 600px;
	background: var(--color_f);
	border: solid 8px var(--color_34);
	border-radius: var(--radius_50);
	z-index: -4;
}

#scenes .text_2 p {
	font-size: var(--font-size_l);
}

#scenes .flex-pack {
	max-width: 1000px;
	margin: 150px auto 0px auto;
	gap: 100px;
}

#scenes .flex-item {
	position: relative;
	width: calc((100% - 200px) / 3);
	aspect-ratio: 1 / 1;
	background: var(--color_f);
	border: solid 8px var(--color_20);
	border-radius: var(--radius_50);
}

#scenes .flex-item p {
	position: absolute;
	bottom: 0;
	left: 0;
	padding: 6px 20px;
	font-size: var(--font-size_m);
	color: var(--color_f);
	text-shadow: var(--shadow_2);
	border-radius: var(--radius_5);
}

#scenes .flex-item:nth-child(1) {
	border-color: var(--color_22);
}

#scenes .flex-item:nth-child(1) p {
	background: var(--color_22);
}

#scenes .flex-item:nth-child(2) {
	transform: translateY(-100px);
	border-color: var(--color_32);
}

#scenes .flex-item:nth-child(2) p {
	background: var(--color_32);
}

#scenes .flex-item:nth-child(3) {
	border-color: var(--color_42);
}

#scenes .flex-item:nth-child(3) p {
	background: var(--color_42);
}

#scenes .flex-item img {
	height: 100%;
	padding: 25px;
	filter: grayscale(0.3);
}

#scenes .image {
	width: 300px;
	margin: 50px auto 0;
}

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

	#scenes .text_1 {}

	#scenes .text_1 p {
		font-size: var(--font-size_m);
	}

	#scenes .text_1 p span {}

	#scenes .text_2 {}

	#scenes .text_2::before {
		top: 50%;
		left: 50%;
		transform: translate(-50%, -35%);
		width: 250px;
		height: 250px;
		border: solid 3px var(--color_34);
	}

	#scenes .text_2 p {
		font-size: 1.15rem;
	}

	#scenes .flex-pack {
		margin: 100px auto 25px auto;
		gap: 10px;
	}

	#scenes .flex-item {
		width: calc((100% - 20px) / 3);
		border: solid 3px var(--color_20);
	}

	#scenes .flex-item p {
		bottom: 0;
		left: 0;
		padding: 3px 10px;
		font-size: var(--font-size_s);
	}

	#scenes .flex-item:nth-child(1) {}

	#scenes .flex-item:nth-child(1) p {}

	#scenes .flex-item:nth-child(2) {
		transform: translateY(-50px);
	}

	#scenes .flex-item:nth-child(2) p {}

	#scenes .flex-item:nth-child(3) {}

	#scenes .flex-item:nth-child(3) p {}

	#scenes .flex-item img {
		padding: 5px;
	}

	#scenes .image {
		width: 225px;
	}
}

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

#greeting .layout_2 {}

#greeting .left-pack {
	position: relative;
	width: calc(40% - 50px);
	margin-top: 100px;
}

#greeting .left-pack .animal-illust {
	top: 0;
	right: -100px;
	transform: translate(0, -50%);
}

#greeting .left-pack .content_1 .caption {
	margin-top: 0;
}

#greeting .right-pack {
	position: relative;
	width: calc(60% - 50px);
}

#greeting .right-pack .animal-illust {
	top: -300px;
	right: 0;
}

@keyframes spin {
	to {
		transform: rotate(360deg);
	}
}

#greeting .right-pack .inner {
	height: 800px;
}

#greeting .right-pack .inner img {
	position: absolute;
	border-radius: var(--radius_1);
	box-shadow: var(--shadow_1);
}

#greeting .right-pack .inner img:nth-child(1) {
	top: 0;
	right: 0;
	width: 550px;
	aspect-ratio: 3 / 2;
}

#greeting .right-pack .inner img:nth-child(2) {
	bottom: 100px;
	left: 0;
	width: 250px;
	aspect-ratio: 1 / 1;
	border-radius: var(--radius_50);
}

#greeting .right-pack .inner img:nth-child(3) {
	bottom: 0;
	right: 0;
	width: 300px;
	aspect-ratio: 1 / 1;
}

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

	#greeting .layout_2 {
		flex-wrap: wrap;
		gap: 50px;
	}

	#greeting .left-pack {
		width: 100%;
		margin-top: 0;
	}

	#greeting .left-pack .animal-illust {
		right: 0px;
		transform: translate(0, -50%);
	}

	#greeting .right-pack {
		width: 100%;
	}

	#greeting .right-pack .animal-illust {
		top: -175px;
		right: auto;
		left: 0;
	}

	#greeting .right-pack .inner {
		display: flex;
		flex-wrap: wrap;
		height: auto;
		border-radius: var(--radius_1);
		box-shadow: var(--shadow_1);
		overflow: hidden;
	}

	#greeting .right-pack .inner img {
		position: relative;
		border-radius: 0;
		box-shadow: none;
	}

	#greeting .right-pack .inner img:nth-child(1) {
		width: 100%;
		aspect-ratio: 2 / 1;
	}

	#greeting .right-pack .inner img:nth-child(2) {
		bottom: 0;
		left: 0;
		width: 50%;
		border-radius: 0;
	}

	#greeting .right-pack .inner img:nth-child(3) {
		width: 50%;

	}
}

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

#guide .animal-illust {
	top: 0;
	left: calc(50% - 350px);
	transform: translate(0, -50%);
}

#guide .flex-pack {}

#guide .flex-item {
	width: calc((100% - 150px) / 4);
	border-radius: var(--radius_1);
	box-shadow: var(--shadow_1);
	overflow: hidden;
}

#guide .flex-item .title {
	flex-wrap: wrap;
	justify-content: center;
	padding: 10px 0;
	text-align: center;
	background: var(--color_22);
}

#guide .flex-item .title .text_1 {
	width: 100%;
	font-size: var(--font-size_m);
	color: var(--color_f);
	line-height: 1.5em;
}

#guide .flex-item .title .text_2 {
	width: 100%;
	font-size: var(--font-size_sss);
	color: var(--color_f);
	line-height: 1.5em;
}

#guide .flex-item .image {
	position: relative;
	aspect-ratio: 3 / 2;
}

#guide .flex-item .image img {
	height: 100%;
}

#guide .flex-item .btn_dummy {
	position: absolute;
	bottom: 10px;
	right: 10px;
}

#guide .flex-item .caption {
	padding: 10px 0;
	font-size: var(--font-size_ss);
	background: var(--color_f);
}

@media screen and (max-width: 699px) {
	#guide .animal-illust {
		left: 50%;
		transform: translate(-50%, -50%);
	}

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

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

	#guide .flex-item .title .text_1 {
		font-size: var(--font-size_mm);
	}

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

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

#good-points .animal-illust {
	top: 0;
	left: calc(50% - 250px);
	transform: translate(0, -50%);
}

#good-points .swiper5 {
	height: auto;
}

#good-points .swiper5 .swiper-wrapper {
	align-items: stretch;
	height: auto;
	padding-bottom: 7px;
}

#good-points .swiper5 .swiper-slide {
	padding: 25px;
	background: var(--color_f);
	border: var(--border_3);
	border-radius: var(--radius_1);
	box-shadow: var(--shadow_1);
}

#good-points .swiper5 .swiper-slide .image {
	width: 150px;
	aspect-ratio: 1 / 1;
	margin: auto;
	background: var(--color_f);
	border: solid 3px var(--color_21);
	border-radius: var(--radius_50);
}

#good-points .swiper5 .swiper-slide .image svg {
	width: 100px;
	fill: var(--color_21);
}

#good-points .swiper5 .swiper-slide .text {
	margin-top: 15px;
}

#good-points .swiper5 .swiper-slide .text .title {
	text-align: center;
	font-size: var(--font-size_m);
}

#good-points .swiper5 .swiper-slide .text .caption {
	margin-top: 15px;
}

@media screen and (max-width: 699px) {
	#good-points .animal-illust {
		left: 0;
	}

	#good-points .swiper5 {
		margin: 0 calc(50% - 50vw);
		width: 100vw;
	}
}

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

#lisence .flex-pack {
	flex-wrap: wrap;
	align-items: stretch;
}

#lisence .flex-item {
	flex-wrap: wrap;
	gap: 25px;
	width: calc(50% - 25px);
	height: 100%;
	text-align: center;
	border-radius: var(--radius_2);
	box-shadow: var(--shadow_1);
}

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

#lisence .flex-item .image img,
#lisence .flex-item .image svg {
	width: 150px;
	margin: auto;
}

#lisence .flex-item .image svg {
	fill: var(--color_22);
}

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

#lisence .flex-item .text .title {
	width: fit-content;
	margin: auto;
	font-size: var(--font-size_m);
	color: var(--color_21);
	font-weight: var(--font-weight_ll);
}

#lisence .flex-item .text .caption {
	margin-top: 25px;
	text-align: left;
}

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

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

	#lisence .flex-item .image img {
		max-width: 200px;
	}

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

	#lisence .flex-item .text .title {
		font-size: var(--font-size_m);
		line-height: 1.3em;
	}

	#lisence .flex-item .text .caption {
		margin-top: 15px;
	}
}

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

#area .animal-illust {
	top: 0;
	left: calc(50% + 700px);
	transform: translate(-100%, 0);
}

#area .area__pack {
	gap: 100px;
}

#area .area__item {}

#area .area__item:nth-child(1) {
	width: calc(40% - 50px);
}

#area .content_1 .caption {
	margin-top: 0;
}

#area .area__item:nth-child(2) {
	width: calc(60% - 50px);
	flex-wrap: wrap;
	gap: 50px;
	text-align: center;
}

#area .area__item .content {
	width: calc(100% - 100px);
	padding: 25px 50px 50px;
	background: var(--color_f);
	border-radius: var(--radius_10);
	box-shadow: var(--shadow_1);
}

#area .area__item .left {}

#area .area__item .right {}

#area .area__item .content .title {
	font-size: var(--font-size_l);
	color: var(--color_21);
	font-weight: var(--font-weight_l);
}

#area .area__item .content .place {
	margin-top: 10px;
	font-size: var(--font-size_mm);
	letter-spacing: 0.05em;
}

#area .area__item .content:nth-child(2) {
	margin-left: auto;
	margin-right: 0;
}

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

	#area .animal-illust {
		top: 0;
		left: auto;
		right: 0;
		transform: translate(0, 0);
	}

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

	#area .flex-item {}

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

	#area .flex-item:nth-child(2) {
		width: 100%;
		gap: 35px;
	}

	#area .area__item .content {
	width: 100%;
	padding: 20px 15px 35px 15px;
	background: var(--color_f);
	border-radius: var(--radius_1);
	box-shadow: var(--shadow_1);
}

#area .area__item .left {}

#area .area__item .right {}

#area .area__item .content .title {
	font-size: var(--font-size_m);
}

#area .area__item .content .place {
	font-size: var(--font-size_s);
}

#area .area__item .content:nth-child(2) {
	margin-left: auto;
	margin-right: 0;
}
}

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

#topic .flex-pack {
	align-items: flex-start;
}

#topic .flex-item {}

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

#topic .flex-item:nth-child(2) {
	width: calc(75% - 25px);
}

#topic .topic__pack {
	gap: 50px;
}

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

	#topic .flex-item {
		display: contents;
	}

	#topic .item_1 {
		display: contents;
		width: 100%;
		order: 1;
	}

	#topic .item_2 {
		margin-top: 35px;
		order: 3;
	}

	#topic .item_3 {
		width: 100%;
		order: 2;
	}

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

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

	#topic .topic__pack {
		flex-wrap: wrap;
	}
}

/*------------------------------------
トップページ・topic_2
------------------------------------*/
#topic_2 {
	background-image: repeating-linear-gradient(-45deg,
			var(--color_08) 0,
			var(--color_08) 1px,
			transparent 1px,
			transparent 50%);
	background-size: 15px 15px;
	background-repeat: repeat;
}

#topic_2 .swiper4 {
	position: relative;
	overflow: hidden;
	padding-bottom: 7px;
}

#topic_2 .swiper4 .swiper-wrapper {}

#topic_2 .swiper4 .swiper-slide {
	box-shadow: var(--shadow_1);
}

@media screen and (max-width: 699px) {
	#topic_2 {
		padding: 25px 0;
	}
}

/* ページネーション */
#topic_2 .swiper4 .swiper-button-next,
#topic_2 .swiper4 .swiper-button-prev {
	background: var(--color_11);
	border-radius: 50%;
	width: 35px;
	height: 35px;
	z-index: 1;
}

#topic_2 .swiper4 .swiper-button-next {}

#topic_2 .swiper4 .swiper-button-next::after,
#topic_2 .swiper4 .swiper-button-prev::after {
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	color: var(--color_02);
	font-size: var(--font-size_mm);
}

#topic_2 .swiper4 .swiper-button-next::after {
	content: '\f054';
}

#topic_2 .swiper4 .swiper-button-prev::after {
	content: '\f053';
	/* FontAwesomeの左矢印 */
}

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

#snap .flex-pack {
	gap: 100px;
	position: relative;
}

#snap .animal-illust {
	top: 0;
	left: calc(50% - 700px);
	transform: translate(50%, -50%);
}

#snap .flex-item {
	align-items: stretch;
}

#snap .flex-item:nth-child(1) {
	width: calc(30% - 50px);
}

#snap .flex-item:nth-child(2) {
	width: calc(70% - 50px);
}

#snap .snap__pack {
	flex-wrap: wrap;
	gap: 3px;
	border-radius: var(--radius_1);
	box-shadow: var(--shadow_1);
	overflow: hidden;
}

#snap .snap__item {
	width: calc((100% - 6px) / 3);
}

#snap .snap__item .post-card__image {
	aspect-ratio: 1 / 1;
}

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

	#snap .animal-illust {
		top: 0;
		left: auto;
		right: 0;
		transform: translate(0, -50%);
	}

	#snap .flex-pack {
		flex-wrap: wrap;
		gap: 0;
	}

	#snap .flex-item {
		display: contents;
	}

	#snap .item_1 {
		display: contents;
		width: 100%;
		order: 1;
	}

	#snap .item_2 {
		width: 100%;
		margin-top: 35px;
		order: 3;
	}

	#snap .item_3 {
		width: 100%;
		order: 2;
	}

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

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

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

	#snap .snap__pack {}

	#snap .snap__item {}

	#snap .snap__item .post-card__image {}
}

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

#update .animal-illust {
	top: 0;
	left: calc(50% - 700px);
	transform: translate(0, -50%);
}

#update .flex-pack {
	gap: 100px;
	align-items: flex-start;
}

#update .flex-item {}

#update .flex-item:nth-child(1) {
	width: calc(30% - 50px);
}

#update .flex-item:nth-child(2) {
	width: calc(70% - 50px);
}

#update .update__pack {
	flex-wrap: wrap;
	gap: 25px;
}

#update .update__item {
	width: 100%;
	padding-bottom: 25px;
	border-bottom: solid 1px var(--color_03);
}

#update .update__item .date {
	color: var(--color_20);
}

@media screen and (max-width: 699px) {
	#update .animal-illust {
		top: 0;
		left: 0;
	}

	#update .flex-pack {
		flex-wrap: wrap;
		gap: 0;
	}

	#update .flex-item {
		display: contents;
	}

	#update .item_1 {
		display: contents;
		width: 100%;
		order: 1;
	}

	#update .item_2 {
		margin-top: 35px;
		order: 3;
	}

	#update .item_3 {
		width: 100%;
		order: 2;
	}

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

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

	#update .update__pack {
		gap: 15px;
	}

	#update .update__item {
		padding-bottom: 10px;
	}

}

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

#access .flex-pack {}

#access .flex-item {
	width: calc(50% - 25px);
}

#access .flex-item:nth-child(1) {
	aspect-ratio: 16 / 9;
}

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

	#access .flex-pack {}

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

	#access .flex-item:nth-child(1) {
		aspect-ratio: 16 / 9;
	}
}


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


/*------------------------------------
下層ページ用メインビジュアル
------------------------------------*/
#subvisual_1 {
	max-width: 100vw;
	padding-top: 160px;
	padding-bottom: 75px;
}

#subvisual_1 .sv-pack {
	max-width: 1600px;
}

#subvisual_1 .sv-image {
	width: calc(100% - 550px);
	height: 600px;
	border-radius: var(--radius_5);
	overflow: hidden;
	z-index: -1;
}

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

#subvisual_1 .sv-caption {
	width: 550px;
	padding: 35px 50px;
	z-index: 1;
}

#subvisual_1 .sv-caption .inner {
	text-align: center;
}

#subvisual_1 .sv-caption .inner h1 {
	font-size: var(--font-size_llll);
	color: var(--color_03);
	font-weight: var(--font-weight_s);
	letter-spacing: 0.25em;
	white-space: nowrap;
}

#subvisual_1 .sv-caption .inner p {
	font-size: var(--font-size_mm);
	letter-spacing: 0.2em;
}

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

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

	#subvisual_1 .sv-image {
		width: 100%;
		height: 200px;
		border-radius: var(--radius_2);
	}

	#subvisual_1 .sv-caption {
		position: absolute;
		bottom: 0;
		left: 50%;
		transform: translate(-50%, 60%);
		width: 100%;
	}

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

	#subvisual_1 .sv-caption .inner p {}
}

/*------------------------------------下層ページ・コンテンツ------------------------------------*/


/*------------------------------------
sub_intro
------------------------------------*/
#sub_intro .sub_intro__pack {}

#sub_intro .sub_intro__item {
	width: calc((100% - 50px) / 2);
}

#sub_intro .sub_intro__item:nth-child(2) img {
	border-radius: var(--radius_1);
	box-shadow: var(--shadow_1);
}

@media screen and (max-width: 699px) {
	#sub_intro .sub_intro__item {
		width: 100%;
	}
}

/*------------------------------------
about
------------------------------------*/
#about-intro {}

#about-intro .left-pack {}

#about-intro .left-pack .inner {
	top: 150px;
	left: 0;
	max-width: 500px;
	margin-left: 0;
}

#about-intro .right-pack {
	flex-wrap: wrap;
	gap: 100px;
}

#about-intro .right-pack img {
	width: 100%;
	aspect-ratio: 3 / 2;
	border-radius: var(--radius_1);
	box-shadow: var(--shadow_1);
}

@media screen and (max-width: 699px) {
	#about-intro .right-pack {
		gap: 25px;
	}
}

#about-profile {}

#about-profile .flex-pack {
	align-items: stretch;
}

#about-profile .flex-item:nth-child(1) {
	width: calc(40% - 25px);
}

#about-profile .flex-item:nth-child(2) {
	width: calc(60% - 25px);
}

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

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

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

/*------------------------------------
flow
------------------------------------*/
#flow_1 {}

#flow_1 .flow_1__pack {
	align-items: stretch;
	flex-wrap: wrap;
	gap: 10px;
}

#flow_1 .flow_1__item {
	align-items: stretch;
	gap: 50px;
	width: 100%;
}

#flow_1 .flow_1__item .left {
	position: relative;
	width: 50px;
	height: 100%;
}

#flow_1 .flow_1__item .left::before {
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	width: 1px;
	height: 100%;
	border-left: dotted 3px var(--color_06);
	z-index: -1;
}

#flow_1 .flow_1__item:nth-last-child(1) .left::before {
	display: none;
}

#flow_1 .flow_1__item .left .number {
	position: relative;
	width: 50px;
	height: 50px;
	text-align: center;
	background: var(--color_22);
	border-radius: var(--radius_5);
}

#flow_1 .flow_1__item .left .number .inner {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
	height: 100%;
}

#flow_1 .flow_1__item .left .number .inner span {
	font-size: var(--font-size_ssss);
	color: var(--color_f);
	line-height: 0.5em;
}

#flow_1 .flow_1__item .left .number .inner p {
	font-family: var(--font-family_3);
	font-size: var(--font-size_l);
	color: var(--color_f);
	line-height: 0.5em;
}

#flow_1 .flow_1__item .right {
	width: calc(100% - 100px);
	margin-bottom: 50px;
	padding: 50px;
	background: var(--color_f);
	border-radius: var(--radius_3);
	box-shadow: var(--shadow_1);
}

#flow_1 .flow_1__item .right .btn_1 {
	margin-top: 25px;
}

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

	#flow_1 .wrapper {
		padding: 0;
	}

	#flow_1 .flow_1__pack {
		gap: 10px;
	}

	#flow_1 .flow_1__item {
		gap: 15px;
	}

	#flow_1 .flow_1__item .left {
		width: 40px;
	}

	#flow_1 .flow_1__item .left::before {}

	#flow_1 .flow_1__item:nth-last-child(1) .left::before {}

	#flow_1 .flow_1__item .left .number {
		width: 40px;
		height: 40px;
	}

	#flow_1 .flow_1__item .left .number .inner p {
		font-size: var(--font-size_s);
	}

	#flow_1 .flow_1__item .right {
		width: calc(100% - 55px);
		margin-bottom: 35px;
		padding: 30px 20px;
	}

	#flow_1 .flow_1__item .right .btn_1 {
		margin-top: 25px;
	}
}

/*------------------------------------
price
------------------------------------*/
#price_1 {}

#price_1 .system__pack {
	align-items: stretch;
	gap: 20px;
	padding: 50px;
}

#price_1 .system__item {
	text-align: center;
	border-radius: var(--radius_3);
}

#price_1 .system__item .title {
	font-size: var(--font-size_mm);
	font-weight: var(--font-weight_l);
}

#price_1 .system__item .note {
	font-size: var(--font-size_sss);
	color: var(--color_02);
}

#price_1 .system__1 {
	flex-wrap: wrap;
	gap: 10px;
	width: calc(40% - 20px);
	padding: 20px;
	background: var(--color_23);
}

#price_1 .system__1 .inner {
	width: 100%;
	padding: 10px;
	background: var(--color_f);
	border: solid 3px var(--color_22);
	border-radius: var(--radius_5);
}

#price_1 .system__1 i {
	font-size: var(--font-size_m);
}

#price_1 .system__2 {
	width: calc(20% - 20px);
	height: 150px;
	margin: auto;
	background: var(--color_08);
}

#price_1 .system__3 {
	width: calc(40% - 20px);
	background: var(--color_42);
}

#price_1 .system__3 .title {
	font-size: var(--font-size_l);
}

#price_1 .system__3 p {
	color: var(--color_f) !important;
}

#price_1 .system__mark {
	width: 50px;
}

#price_1 .system__mark i {
	font-size: var(--font-size_m);
}

@media screen and (max-width: 699px) {
	#price_1 .system__pack {
		flex-wrap: wrap;
		padding: 0px 20px;
	}

	#price_1 .system__item {
		width: 100%;
		min-height: 50px;
		padding: 25px 20px;
	}

	#price_1 .system__2 {
		height: auto;
	}

	#price_1 .system__mark i {
		transform: rotate(90deg);
	}
}

#price_2 {}

#price_2 .flex-pack {
	flex-wrap: wrap;
	align-items: stretch;
	justify-content: space-between;
	gap: 70px;
}

#price_2 .flex-item {
	width: calc((100% - 70px) / 2);
	position: relative;
	padding: 50px;
	background: var(--color_f);
	border: var(--border_03);
	border-radius: var(--radius_1);
	box-shadow: var(--shadow_1);
}


#price_2 .flex-item::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 10px;
	height: 100%;
	border-radius: 7.5px 0 0 7.5px;
}

#price_2 .flex-item:nth-child(1)::before {
	background: var(--color_22);
}

#price_2 .flex-item:nth-child(2)::before {
	background: var(--color_32);
}

#price_2 .flex-item:nth-child(3)::before {
	background: var(--color_42);
}

#price_2 .flex-item:nth-child(4)::before {
	background: var(--color_03);
}

#price_2 .flex-item:nth-child(5)::before {
	background: var(--color_01);
}

#price_2 .flex-item::after {
	border-radius: var(--radius_1);
}

#price_2 .flex-item:nth-child(6) {
	align-items: flex-end;
	justify-content: flex-end;
}

#price_2 .menu-header {
	align-items: baseline;
	justify-content: flex-start;
	gap: 10px;
}

#price_2 .menu-header svg {
	width: 50px;
	fill: var(--color_01);
}

#price_2 .menu-header p {
	font-size: var(--font-size_m);
	font-weight: var(--font-weight_l);
}

#price_2 .table_2 .row,
#price_2 .table_3 .row {
	padding: 0;
	border-bottom: none;
}

#price_2 .table_2 .row-header .cell p,
#price_2 .table_3 .row-header .cell p {
	font-size: var(--font-size_s) !important;
}

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

#price_2 .table_2 .cell:nth-child(1) p,
#price_2 .table_3 .cell:nth-child(1) p {
	font-size: var(--font-size_ss);
}

#price_2 .table_2 .cell:nth-child(2) p,
#price_2 .table_3 .cell:nth-child(2) p,
#price_2 .table_3 .cell:nth-child(3) p {
	font-size: var(--font-size_mm);
}

#price_2 .table_2 .cell:nth-child(2) span,
#price_2 .table_3 .cell:nth-child(2) span,
#price_2 .table_3 .cell:nth-child(3) span {
	font-size: var(--font-size_l);
	padding: 0 2px;
}

#price_2 .table_2 .cell:nth-child(1) {
	width: 72.5%;
}

#price_2 .table_2 .cell:nth-child(2) {
	width: 27.5%;
}

#price_2 .table_3 .cell:nth-child(1) {
	width: 45%;
}

#price_2 .table_3 .cell:nth-child(2) {
	width: 27.5%;
}

#price_2 .table_3 .cell:nth-child(3) {
	width: 27.5%;
}

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

	#price_2 .flex-pack {
		gap: 25px;
	}

	#price_2 .flex-item {
		width: 100%;
		padding: 25px;
	}

}

#price_3 {}

#price_3 .service__pack {
	flex-wrap: wrap;
	gap: 100px;
}

#price_3 .service__item {
	width: 100%;
	gap: 100px;
	padding-bottom: 100px;
	border-bottom: dotted 2px var(--color_03);
}

#price_3 .service__item:nth-last-child(1) {
	border: none;
}

#price_3 .service__left {
	width: calc(60% - 50px);
}

#price_3 .service__left .header {
	margin-bottom: 25px;
	font-size: var(--font-size_l);
	font-weight: var(--font-weight_ll);
}

#price_3 .service__left .header span {
	margin-right: 10px;
	color: var(--color_21);
}

#price_3 .service__left .inner {
	margin: 15px auto;
	padding: 20px;
	background: var(--color_f);
	border: var(--border_3);
	border-radius: var(--radius_1);
}

#price_3 .service__left .inner .title {
	font-size: var(--font-size_mm);
	color: var(--color_21);
	font-weight: var(--font-weight_l);
}

#price_3 .service__left .inner .caption {
	padding: 15px 10px;
}

#price_3 .service__left .note {
	font-size: var(--font-size_sss);
}

#price_3 .service__right {
	width: calc(40% - 50px);
}

#price_3 .service__right img {
	aspect-ratio: 3 / 2;
	border-radius: var(--radius_1);
	box-shadow: var(--shadow_1);
}

@media screen and (max-width: 699px) {
	#price_3 .service__item {
		flex-wrap: wrap;
		gap: 25px;
	}

	#price_3 .service__left {
		width: 100%;
	}

	#price_3 .service__right {
		width: 100%;
	}

	#price_3 .service__right img {
		width: 50%;
		aspect-ratio: 1 / 1;
		margin-left: auto;
		margin-right: 0;
		border-radius: var(--radius_50);
	}
}

/*------------------------------------
下層ページ・LINE
------------------------------------*/
#line_1 {}

#line_1 .line_1__pack {
	align-items: stretch;
	flex-wrap: wrap;
	gap: 10px;
}

#line_1 .line_1__item {
	align-items: stretch;
	gap: 50px;
	width: 100%;
}

#line_1 .line_1__item .left {
	position: relative;
	width: 50px;
	height: 100%;
}

#line_1 .line_1__item .left::before {
	content: '';
	position: absolute;
	top: 0;
	left: 50%;
	width: 1px;
	height: 100%;
	border-left: dotted 3px var(--color_06);
	z-index: -1;
}

#line_1 .line_1__item:nth-last-child(1) .left::before {
	display: none;
}

#line_1 .line_1__item .left .number {
	width: 50px;
	height: 50px;
	background: var(--color_22);
	border-radius: var(--radius_5);
}

#line_1 .line_1__item .left .number p {
	font-family: var(--font-family_3);
	font-size: var(--font-size_l);
	color: var(--color_f);
}

#line_1 .line_1__item .right {
	width: calc(100% - 100px);
	margin-bottom: 50px;
	padding: 50px;
	background: var(--color_f);
	border-radius: var(--radius_3);
	box-shadow: var(--shadow_1);
}

#line_1 .line_1__item .right .btn_1 {
	margin-top: 25px;
}

#line_1 .line_1__item:nth-child(1) .right {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 50px;
}

#line_1 .line_1__item:nth-child(1) .right .content_2,
#line_1 .line_1__item:nth-child(1) .right .qr {
	width: calc((100% - 50px) / 2);
}

#line_1 .line_1__item:nth-child(1) .right .qr {
	text-align: center;
}

#line_1 .line_1__item:nth-child(1) .right .qr img {
	width: 150px;
	margin: auto;
}

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

	#line_1 .wrapper {
		padding: 0;
	}

	#line_1 .line_1__pack {
		gap: 10px;
	}

	#line_1 .line_1__item {
		gap: 15px;
	}

	#line_1 .line_1__item .left {
		width: 40px;
	}

	#line_1 .line_1__item .left::before {}

	#line_1 .line_1__item:nth-last-child(1) .left::before {}

	#line_1 .line_1__item .left .number {
		width: 40px;
		height: 40px;
	}

	#line_1 .line_1__item .left .number p {
		font-size: var(--font-size_mm);
	}

	#line_1 .line_1__item .right {
		width: calc(100% - 55px);
		margin-bottom: 35px;
		padding: 30px 20px;
	}

	#line_1 .line_1__item .right .btn_1 {
		margin-top: 25px;
	}

	#line_1 .line_1__item:nth-child(1) .right .content_2,
	#line_1 .line_1__item:nth-child(1) .right .qr {
		width: 100%;
	}
}

/*------------------------------------
下層ページ・求人検索
------------------------------------*/
#job-search {}

#job-search .job-search-container {
	align-items: flex-start;
	gap: 50px;
}

#job-search .job-search-pack {
	width: 100%;
}

#job-search .products-list {
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: flex-start;
	gap: 75px 35px;
}

#job-search .products-list .products-list-item {
	flex-wrap: wrap;
	width: calc((100% - 35px) / 2);
	height: auto;
}

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

	#job-search .job-search-container {
		align-items: flex-start;
		gap: 50px;
	}

	#job-search .job-search-pack {
		width: 100%;
	}

	#job-search .products-list {
		flex-wrap: wrap;
		justify-content: flex-start;
		gap: 50px;
	}

	#job-search .products-list .products-list-item {
		flex-wrap: wrap;
		width: 100%;
		height: auto;
	}
}

/*フィルター機能*/
.cat-filter {
	width: 100%;
	padding: 3px 7px;
	text-align: left;
	font-size: var(--font-size_ss);
	border: none;
	background: transparent;
	cursor: pointer;
}

.cat-filter.active {
	background-color: var(--color_00);
	color: var(--color_f);
}

.filter-title {
	font-size: var(--font-size_mm);
}

.filter-group {
	flex-wrap: wrap;
	justify-content: flex-start;
	gap: 10px;
	margin: 15px auto 35px;
}

.tax-filter {
	padding: 0 10px;
	font-size: var(--font-size_ss);
	border: var(--border_02);
	border-radius: var(--radius_5);
}

.tax-filter.active {
	background: var(--color_00);
	color: var(--color_f);
	border-color: var(--color_00);
}

/*~の検索結果*/
.search-header {
	margin-bottom: 25px;
	font-size: var(--font-size_m);
}

/*PC表示（stickyサイドバー）*/
@media (min-width: 769px) {
	.category-filter {
		display: block;
		position: sticky;
		top: 0;
		width: 35%;
		padding: 50px;
		background: var(--color_f);
		height: auto;
	}

	.filter-toggle,
	.filter-close,
	.filter-overlay {
		display: none;
	}
}

/* スマホ表示（スライドイン） */
@media (max-width: 768px) {
	.filter-toggle {
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		gap: 6px;
		position: fixed;
		bottom: 10px;
		left: 15px;
		z-index: 98;
		background: var(--color_00);
		color: var(--color_f);
		border: none;
		padding: 10px 15px;
		border-radius: 25px;
		font-size: var(--font-size_s);
		font-weight: 600;
		cursor: pointer;
		box-shadow: var(--shadow_1);
	}

	.filter-toggle .filter-icon {
		font-size: 1.1em;
		color: var(--color_f);
	}

	.filter-toggle .filter-text {}

	.category-filter {
		display: block;
		position: fixed;
		top: 0;
		left: -100%;
		width: 75%;
		height: 100%;
		background: var(--color_f);
		transition: left 0.4s ease-out;
		z-index: 98;
		padding: 50px 20px;
		overflow-y: auto;
	}

	.category-filter::before {
		display: none;
	}

	.category-filter.open {
		left: 0;
	}

	.filter-close {
		position: absolute;
		top: 15px;
		right: 15px;
		background: none;
		border: none;
		font-size: 1.5rem;
		cursor: pointer;
	}

	.filter-overlay {
		display: none;
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: rgba(0, 0, 0, 0.5);
		z-index: 97;
	}

	.filter-overlay.show {
		display: block;
	}
}

/*------------------------------------
下層ページ・お問い合わせ
------------------------------------*/
#sub-contact {}

/*------------------------------------
下層ページ・利用規約/プライバシーポリシー共通
------------------------------------*/
#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;
}


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


/*------------------------------------
投稿一覧ページ
------------------------------------*/
#post-archive {}

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

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

/*------------------------------------
投稿一覧ページ・共通
------------------------------------*/
.post-list__pack {
	gap: 0px;
}

.post-list__item {
	gap: 50px;
	width: 100%;
	padding: 50px 0;
	border-bottom: var(--border_03);
}

.post-list__item:nth-last-child(1) {
	border: none;
}

.post-list__image {
	width: calc(40% - 25px);
}

.post-list__image img {
	aspect-ratio: 16 / 9;
}

.post-list__text {
	width: calc(60% - 25px);
}

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

.post-list__text .flex .date {}

.post-list__text .flex .category {
	font-size: var(--font-size_ss);
}

.post-list__text .title {
	margin-top: 10px;
	padding-bottom: 5px;
}

.post-list__text .text {
	margin-top: 10px;
	font-size: var(--font-size_ss);
}

@media screen and (max-width: 699px) {
	.post-list__item {
		flex-wrap: wrap;
		gap: 25px;
	}

	.post-list__image {
		width: 100%;
	}

	.post-list__image img {}

	.post-list__text {
		width: 100%;
	}

	.post-list__text .flex {}

	.post-list__text .flex .date {}

	.post-list__text .flex .category {}

	.post-list__text .title {}

	.post-list__text .text {}
}


/*------------------------------------
サイドバー
------------------------------------*/
.post-sideber {
	flex-wrap: wrap;
	gap: 25px;
	z-index: 0;
}

.post-sideber .post-card {
	align-items: center;
	gap: 15px;
	width: 100%;
	padding-bottom: 25px;
	border-bottom: var(--border_02);
}

.post-sideber .post-card__image {
	width: calc(30% - 7.5px);
	aspect-ratio: 1 / 1;
}

.post-sideber .post-card__image .more-text {
	font-size: var(--font-size_s);
}

.post-sideber .post-card__text {
	width: calc(70% - 7.5px);
}

.post-sideber .post-card__text .category a {
	font-size: var(--font-size_sss);
}

.post-sideber .post-card__text .title {
	margin-top: 0;
}

.post-sideber .post-card__text .title a {
	font-size: var(--font-size_ss);
}

@media screen and (max-width: 699px) {
	.post-sideber .post-card__text .title a {
		font-size: var(--font-size_s);
	}
}

/*------------------------------------
投稿リスト・ソート用タグ
------------------------------------*/
#post-archive .tag-list-pack {
	padding-bottom: 75px;
}

#post-archive .tag-list {
	flex-wrap: wrap;
	justify-content: flex-start;
	gap: 10px;
}

#post-archive .post-filter {
	padding: 5px 20px;
	font-size: var(--font-size_ss);
	font-weight: var(--font-weight_m);
	background: var(--color_23);
	border-radius: var(--radius_5);
}

#post-archive .post-filter.active {
	color: var(--color_f);
	background: var(--color_20);
}

@media screen and (max-width: 699px) {
	#post-archive .tag-list-pack {
		width: 100%;
		overflow-x: auto;
		overflow-y: hidden;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
	}

	#post-archive .tag-list {
		width: 500px;
	}
}

/*------------------------------------
投稿一覧・次のページ/前のページ
------------------------------------*/
.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;
	background: var(--color_23);
	border-radius: var(--radius_5);
}

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

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

}

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

}

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


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


/*------------------------------------
投稿ページ・レイアウト
------------------------------------*/
#post-container {}

#post-container .post-content {}

#post-container .post-content p {}

@media screen and (max-width: 699px) {
	#post-container {
		padding-top: 35px;
	}
}

.post-main-pack {
	align-items: stretch;
	gap: 75px;
}

.post-main-pack .flex-item:nth-child(1) {
	width: calc(100% - 375px);
}

.post-main-pack .flex-item:nth-child(2) {
	width: 300px;
}

.post-main-content {
	width: 100%;
	margin-bottom: 50px;
}

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

	.post-main-pack .flex-item:nth-child(1) {
		width: 100%;
	}

	.post-main-content {
		margin-bottom: 25px;
	}

	.post-main-pack .flex-item:nth-child(2) {
		width: 100%;
	}
}


/*------------------------------------
投稿ページ用ヘッダー
------------------------------------*/
#post-header {
	padding-top: 100px;
	padding-bottom: 50px;
}

#post-header .wrapper-wide {
	padding-top: 125px;
}

#post-header .post-header-pack {}

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

#post-header .post-meta .date p {
	font-size: var(--font-size_ss);
	color: var(--color_03);
}

#post-header .post-meta .category p {
	font-size: var(--font-size_ss);
}

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

#post-header .post-title h2 {
	font-family: var(--font-family_2);
	font-size: 35px;
	line-height: 1.3em;
}

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

#post-header .post-tag a {
	padding: 0 10px;
	font-size: var(--font-size_sss);
	background: var(--color_08);
}

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

#post-header .post-image img {
	width: 100%;
	aspect-ratio: 16 / 9;
}

@media screen and (max-width: 699px) {
	#post-header .wrapper-wide {
		padding-top: 100px;
	}

	#post-header .post-title h2 {
		font-size: 25px;
	}
}

/*------------------------------------
投稿ページ・次のページ/前のページ
------------------------------------*/
#post-navigation {
	padding: 35px 0;
}

#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;
}

#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);
	}
}

/*------------------------------------
通常コンテンツ記事にcssをあてて見た目を整える
------------------------------------*/
.post-main-content h2,
.post-main-content h3 {
	position: relative;
	text-align: left;
	padding-bottom: 30px;
	margin: 0 auto 50px auto;
	font-family: var(--font-family_2);
	font-weight: var(--font-weight_l);
	letter-spacing: 0em;
	line-height: 1.5em;
}

.post-main-content h2::after,
.post-main-content h3::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 50px;
	height: 3px;
	border-radius: var(--radius_5);
	background: var(--color_20);
}

.post-main-content h2 {
	font-size: 30px;
}

.post-main-content h3 {
	font-size: 25px;
}

.post-main-content h4 {
	font-family: var(--font-family_1);
	font-size: var(--font-size_mm);
	font-weight: var(--font-weight_l);
}

.post-main-content p {
	margin-top: 15px;
	line-height: 2em;
}

@media screen and (max-width: 699px) {
	.post-main-content h2 {
		font-size: 20px;
	}

	.post-main-content h3 {
		font-size: 20px;
	}
}

/*------------------------------------
インタビュー記事にcssをあてて見た目を整える
------------------------------------*/
.post-interview {
	flex-wrap: wrap;
	gap: 50px;
}

.post-interview .profile {
	width: 100%;
	gap: 50px
}

.post-interview .profile .image {
	width: calc(30% - 25px);
	aspect-ratio: 1 / 1;
}

.post-interview .profile .image img {
	height: 100%;
}

.post-interview .profile .text {
	width: calc(70% - 25px);
}

.post-interview .intro {
	width: 100%;
}

.post-interview .content {
	flex-wrap: wrap;
	gap: 25px;
	width: 100%;
}

.post-interview .content .inner {
	flex-wrap: wrap;
	gap: 15px;
}

.post-interview .content .inner .question {
	width: 100%;
	font-size: var(--font-size_mm);
}

.post-interview .content .inner .answer {
	width: 100%;
}


/*------------------------------------店舗ページ用CSS------------------------------------*/


/*------------------------------------
header
------------------------------------*/
#salon-header {
	padding-top: 100px;
	padding-bottom: 50px;
}

#salon-header .wrapper-wide {
	padding-top: 125px;
}

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

#salon-header .category p {
	font-size: var(--font-size_s);
}

#salon-header h2 {
	margin-top: 10px;
	margin-bottom: 35px;
	padding-bottom: 35px;
	font-family: var(--font-family_2);
	font-size: 50px;
	line-height: 1em;
	border-bottom: var(--border_01);
}

#salon-header p {
	font-size: var(--font-size_s);
	color: var(--color_03);
}

#salon-header .tag {
	justify-content: flex-start;
	gap: 10px;
	margin-top: 15px;
}

#salon-header .tag p {
	padding: 0px 10px;
	font-size: var(--font-size_sss);
	color: var(--color_02);
	background: var(--color_08);
}

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

	#salon-header .wrapper-wide {
		padding-top: 100px;
	}

	#salon-header .category p {
		font-size: var(--font-size_s);
	}

	#salon-header h2 {
		margin-top: 10px;
		margin-bottom: 25px;
		padding-bottom: 25px;
		font-size: 35px;
	}

	#salon-header p {
		font-size: var(--font-size_ss);
	}
}

/*------------------------------------
info
------------------------------------*/
#salon-info {
	padding-top: 0;
}

#salon-info .flex-pack {
	align-items: flex-start;
}

#salon-info .flex-item {}

#salon-info .flex-item:nth-child(1) {
	width: calc(40% - 25px);
}

#salon-info .flex-item:nth-child(2) {
	width: calc(60% - 25px);
}

#salon-info .flex-item:nth-child(2) img {
	aspect-ratio: 3 / 2;
}

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

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

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

/*------------------------------------
intro
------------------------------------*/
#salon-intro {}

#salon-intro .wrapper-wide {
	position: relative;
}

#salon-intro .salon-intro-pack {}

#salon-intro .salon-intro-item:nth-child(odd) {
	flex-wrap: wrap-reverse;
}

#salon-intro .salon-intro-item:nth-child(odd) .flex-item:nth-child(1) {
	width: calc(60% - 25px);
}

#salon-intro .salon-intro-item:nth-child(odd) .flex-item:nth-child(2) {
	width: calc(40% - 25px);
}

#salon-intro .salon-intro-item:nth-child(even) {}

#salon-intro .salon-intro-item:nth-child(even) .flex-item:nth-child(1) {
	width: calc(40% - 25px);
}

#salon-intro .salon-intro-item:nth-child(even) .flex-item:nth-child(2) {
	width: calc(60% - 25px);
}

@media screen and (max-width: 699px) {
	#salon-intro .salon-intro-item {
		gap: 0;
	}

	#salon-intro .salon-intro-item:nth-child(odd) .flex-item:nth-child(1),
	#salon-intro .salon-intro-item:nth-child(odd) .flex-item:nth-child(2),
	#salon-intro .salon-intro-item:nth-child(even) .flex-item:nth-child(1),
	#salon-intro .salon-intro-item:nth-child(even) .flex-item:nth-child(2) {
		width: 100%;
	}
}

/*------------------------------------
data
------------------------------------*/
#salon-data {}

#salon-data .wrapper-wide {}

#salon-data .flex-pack {
	flex-wrap: wrap;
}

#salon-data .flex-item {
	width: calc((100% - 100px) / 3);
	aspect-ratio: 1 / 1;
}

#salon-data .flex-item .inner {
	text-align: center;
}

#salon-data .flex-item .inner h3 {}

#salon-data .flex-item .inner p {
	margin-top: 25px;
	font-size: var(--font-size_l);
	color: var(--color_03);
}

#salon-data .flex-item .inner p span {
	font-size: 75px;
	font-weight: var(--font-weight_ll);
}

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

	#salon-data .wrapper-wide {}

	#salon-data .flex-pack {
		gap: 25px;
	}

	#salon-data .flex-item {
		width: calc((100% - 25px) / 2);
	}

	#salon-data .flex-item .inner {}

	#salon-data .flex-item .inner h3 {
		font-size: var(--font-size_s);
	}

	#salon-data .flex-item .inner p {
		margin-top: 25px;
		font-size: var(--font-size_mm);
	}

	#salon-data .flex-item .inner p span {
		font-size: 45px;
		font-weight: var(--font-weight_l);
	}
}

/*------------------------------------
tab
------------------------------------*/
#salon-tab {}

#salon-tab .tab-panel {
	gap: 100px;
	padding: 25px 75px;
}

#salon-tab .block-pack {
	width: 100%;
	max-width: 800px;
	margin: 50px auto 100px;
}

#salon-tab .flex-pack {
	flex-wrap: wrap;
}

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

#salon-tab .flex-item .image {
	width: 100%;
}

#salon-tab .flex-item .text {
	width: 100%;
	margin-top: 20px;
}

#salon-tab .tab-panel .table_2 {}

#salon-tab .tab-panel .data {}

#salon-tab .tab-panel .data .image {}

#salon-tab .tab-panel .data .text {}

#salon-tab .tab-panel .data .text h3 {
	font-size: var(--font-size_mm);
}

#salon-tab .tab-panel .data .text p {
	margin-top: 5px;
	font-size: var(--font-size_ss);
}

@media screen and (max-width: 699px) {
	#salon-tab .block-pack {
		margin: 25px auto 50px;
	}

	#salon-tab .tab-panel {
		padding: 20px;
	}

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

/*------------------------------------
recruit
------------------------------------*/
#salon-recruit {}

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


/*------------------------------------ここから共通フッターコンテンツ------------------------------------*/


/*------------------------------------
CTA
------------------------------------*/
.cta {
	position: relative;
	height: 100%;
}

#cta_1 {
	z-index: 1;
}

#cta_1 .wrapper {
	position: relative;
	padding: 0;
	border-radius: var(--radius_5);
	box-shadow: var(--shadow_1);
}

#cta_1 .flex-pack {
	position: relative;
	gap: 100px;
	padding: 75px 50px;
}

#cta_1 .flex-pack .cta-bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
	border-radius: var(--radius_5);
	z-index: -1;
}

#cta_1 .flex-pack .cta-bg img {
	width: 100%;
	height: 100%;
	filter: opacity(0.4) grayscale(0.7);
}

#cta_1 .flex-item {}

#cta_1 .flex-item:nth-child(1) {
	width: calc(50% - 50px);
}

#cta_1 .flex-item:nth-child(1) img {
	aspect-ratio: 3 / 2;
	border-radius: 300px;
}

#cta_1 .flex-item:nth-child(2) {
	width: calc(50% - 50px);
	text-align: center;
}

#cta_1 .flex-item:nth-child(2) .content_1 {
	margin: 0 auto 25px;
}

#cta_1 .flex-item:nth-child(2) .content_1 .title {
	gap: 5px;
	font-family: var(--font-family_3);
	font-size: var(--font-size_m);
	font-weight: var(--font-weight_l);
	color: var(--color_21);
}

#cta_1 .flex-item:nth-child(2) .content_1 .title svg {
	width: 35px;
	fill: var(--color_21);
}

#cta_1 .flex-item:nth-child(2) .content_1 .sub-title {
	margin-top: 10px;
	font-size: var(--font-size_ll);
	color: var(--color_02);
	font-weight: var(--font-weight_ll);
}

#cta_1 .flex-item:nth-child(2) .content_1 .child-title {
	display: inline-block;
	margin-top: 10px;
	padding: 3px 20px;
	color: var(--color_f);
	background: var(--color_03);
	border-radius: var(--radius_5);
}

#cta_1 .flex-item .reserve__pack {
	margin-top: 0;
}

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

	#cta_1 .wrapper {
		margin: auto 20px;
	}

	#cta_1 .flex-pack {
		gap: 25px;
		padding: 50px 20px;
	}

	#cta_1 .flex-item {}

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

	#cta_1 .flex-item:nth-child(1) img {}

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

	#cta_1 .flex-item:nth-child(2) .content_1 {
		margin: 0 auto 10px;
	}

	#cta_1 .flex-item:nth-child(2) .content_1 .title {}

	#cta_1 .flex-item:nth-child(2) .content_1 .title svg {}

	#cta_1 .flex-item:nth-child(2) .content_1 .sub-title {
		font-size: var(--font-size_l);
		letter-spacing: 0em;
		white-space: nowrap;
	}

	#cta_1 .flex-item .reserve__pack {
		margin-top: 10px;
	}
}

/*------------------------------------
共通パーツ・reserve
------------------------------------*/
.reserve__pack {
	flex-wrap: wrap;
	gap: 20px;
}

.reserve__item {}

.reserve__item a {
	width: 100%;
	padding: 10px;
	text-align: center;
}

.reserve__item .inner {}

.reserve__item .inner p {
	color: var(--color_f);
	line-height: 1.5em;
}

.reserve__item .inner p:nth-child(1) {
	gap: 5px;
	font-size: var(--font-size_mm);
}

.reserve__item .inner p:nth-child(2) {
	font-size: var(--font-size_sss);
}

.reserve__item .inner i {
	font-size: var(--font-size_mm);
	color: var(--color_f);
}

.reserve__item .inner svg {
	width: 15px;
	fill: var(--color_f);
}

.reserve__item:nth-child(1) {
	width: 100%;
}

.reserve__item:nth-child(2) {
	width: calc(50% - 10px);
}

.reserve__item:nth-child(3) {
	width: calc(50% - 10px);
}

.reserve__item .phone {}

.reserve__item .phone p {
	color: var(--color_02);
}

.reserve__item .phone p:nth-child(1) {
	font-family: var(--font-family_3);
	font-size: var(--font-size_ll);
	font-weight: var(--font-weight_l);
	line-height: 1.2em;
	border-bottom: solid 1px var(--color_02);
}

.reserve__item .phone p:nth-child(2) {
	margin-top: 5px;
	font-size: var(--font-size_s);
}

.reserve__item .phone i {
	font-size: var(--font-size_l);
	color: var(--color_02);
}

.reserve__item .line {
	background: var(--color_line);
	border-radius: var(--radius_05);
}

.reserve__item .mail {
	background: var(--color_32);
	border-radius: var(--radius_05);
}

@media screen and (max-width: 699px) {
	.reserve__pack {
		gap: 10px;
	}
}

/*------------------------------------
footer
------------------------------------*/
#footer {
	position: relative;
	z-index: 1;
	padding-top: 100px;
}

.page-about #footer,
.page-contact #footer,
.page-flow #footer,
.page-policy #footer,
.page-price #footer,
.page-poricy #footer,
.page-terms #footer {
	background: var(--color_bg_02);
}


#footer .animal-illust {
	top: 0;
	left: calc(50% + 700px);
	transform: translate(-100%, -50%);
}

#footer .footer__pack {
	flex-wrap: wrap;
	align-items: stretch;
	padding: 50px 0 100px 0;
}

#footer .footer__item {}

#footer .footer__item:nth-child(1) {
	width: 100%;
}

#footer .footer__item:nth-child(1) ul {
	width: fit-content;
	margin: 25px auto 35px auto;
}

#footer .footer__item:nth-child(1) li {
	font-size: var(--font-size_ss);
}

#footer .footer__item:nth-child(2) {
	width: 100%;
}

#footer .footer__item:nth-child(2) ul {
	gap: 35px;
}

#footer .footer__item:nth-child(2) a {
	font-weight: var(--font-weight_ll);
}

#footer .footer-logo {}

#footer .footer-logo a {}

#footer .footer-logo img {
	width: 275px;
	margin: auto;
}

/*コピーライト*/
#footer .copyright {
	background: var(--color_10);
}

#footer .copyright__pack {
	justify-content: space-between;
	gap: 50px;
	padding: 25px 0;
}

#footer .copyright__item {}

#footer .copyright__item:nth-child(1) {
	gap: 25px;
}

#footer .copyright__item:nth-child(1) a {
	font-size: var(--font-size_sss);
	color: var(--color_f);
}

#footer .copyright__item:nth-child(2) {}

#footer .copyright__item:nth-child(2) p {
	font-size: var(--font-size_sss);
	color: var(--color_f);
}

@media screen and (max-width: 699px) {
	#footer {
		position: relative;
		z-index: 1;
	}

	#footer .animal-illust {
		top: 0;
		left: auto;
		right: 0;
		transform: translate(0, -50%);
	}

	#footer .footer__pack {
		flex-wrap: wrap-reverse;
		padding: 0 25px 75px 25px;
		gap: 50px;
	}

	#footer .footer__item {
		width: 100%;
	}

	#footer .footer__item:nth-child(1) {}

	#footer .footer__item:nth-child(2) {}

	#footer .footer__item:nth-child(2) ul {
		flex-wrap: wrap;
		gap: 10px;
	}

	#footer .footer__item:nth-child(2) li {
		width: 100%;
		text-align: center;
	}

	#footer .footer-logo a {
		gap: 10px;
	}

	#footer .footer-logo img {
		width: 250px;
	}

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

	#footer .copyright__pack {
		flex-wrap: wrap;
		justify-content: center;
		padding: 25px 0;
	}

	#footer .copyright__item {}
}