@charset "UTF-8";
/*--------------- ▽ 変数設定 ▽ ---------------*/

/*--------------- △ 変数設定 △ ---------------*/
/*--------------- ▽ header ▽ ---------------*/
.header {
	background: url(../img/common/pat01.png);
	box-sizing: border-box;
	padding: 8px 20px;
	position: fixed;
	z-index: 70;
	width: 100%;
	top: 0;
	left: 0;
	right: 0;
	margin: auto;
}
.header h1 span {
	display: block;
}
.header-logo {
	display: block;
	width: fit-content;
}
.header-logo:hover {
	opacity: 0.7;
}
.header-btn-list {
	position: absolute;
	top: 0;
	right: 0;
	gap: 10px;
}
.header-btn-item .item-btn {
	width: 110px;
	height: 100px;
	border-radius: 0 0 55px 55px;
}
.header-btn-item .item-btn .icon {
	position: absolute;
	top: 12px;
}
.header-btn-item .item-btn .text {
	font-family: var(--font-ttl-ja);
	font-size: 1.5rem;
	position: relative;
	top: 5px;
}
.header-btn-item .item-btn:hover {
	opacity: 0.7;
}
/*-------------------
header-nav
--------------------*/
.header-nav-list {
	gap: 15px 50px;
	box-sizing: border-box;
	padding: 0 240px 0 0;
	z-index: 2;
}
.header-nav-link {
	position: relative;
	display: block;
	box-sizing: border-box;
	z-index: 2;
	font-weight: 500;
}
.header-nav-link:hover {
	color: var(--col-main);
}
.header-nav-item {
	position: relative;
}
.header-nav-item::before {
	position: absolute;
	content: '';
	background: url(../img/common/icon-nav.png) no-repeat;
	width: 15px;
	height: 16px;
	bottom: 0;
	margin: auto;
	right: -30px;
	top: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
.header-nav-item:last-child::before {
	content: none;
}

/*-------------------
現在の表示ページ
--------------------*/
.header-nav-link.current {
	color: var(--col-main);
}

.drawer-link.current {
	color: var(--col-main);
}

/*--------------- △ header △ ---------------*/
/*--------------- ▽ footer ▽ ---------------*/
#pagetop {
	position: fixed;
	right: 2.5%;
	bottom: 5%;
	z-index: 100;
}

.footer {
	position: relative;
	background: var(--col-main-bg);
	box-sizing: border-box;
	padding: 40px 0;
}
.footer::before {
	position: absolute;
	content: '';
	background: url(../img/common/footer-deco-top.png) no-repeat top center;
	width: 100%;
	height: 228px;
	left: 0;
	margin: auto;
	right: 0;
	top: clamp(-220px, -11vw, -150px);
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 2;
}
.footer-wrap {
	margin: 0 auto 40px;
}
.footer-info-box {
	box-sizing: border-box;
	padding: 30px;
	border-radius: 20px;
	width: 600px;
}
.footer-logo {
	display: block;
	width: fit-content;
	margin-bottom: 35px;
}
.footer-logo:hover {
	opacity: 0.7;
}

.footer-nav {
	width: 400px;
	gap: 40px;
}
.footer-nav-link {
	position: relative;
	display: block;
	line-height: 2;
	box-sizing: border-box;
	padding: 0 0 0 30px;
	font-size: 1.5rem;
}
.footer-nav-link:hover::before {
	left: 5px;
	background: var(--col-sub02);
}
.footer-nav-link::before {
	position: absolute;
	content: '';
	background: var(--col-wh);
	width: 15px;
	height: 1px;
	bottom: 0;
	left: 0;
	margin: auto;
	top: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
.footer #copyright {
	text-align: center;
	padding: 5px 0;
}
.footer #copyright small {
	color: var(--col-text);
	font-size: 12px;
}
.footer #copyright small a {
	color: var(--col-text);
}
.footer #copyright small a:hover {
	opacity: 0.7;
}

/*--------------- △ footer △ ---------------*/
/*--------------- ▽ entrance ▽ ---------------*/
.entrance {
	position: relative;
	background: url(../img/entrance/entrance-bg.jpg) no-repeat center center/cover;
	width: 100%;
	margin: 0 auto;
	max-width: 1920px;
	height: clamp(750px, 50vw, 960px);
}
.entrance-header {
	position: absolute;
}
.entrance-item {
	z-index: 10;
	width: 275px;
	height: 71px;
	display: block;
	z-index: 5;
}
.entrance-item .item-link {
	display: block;
	position: relative;
	bottom: 0;
}
.entrance-item .item-link:hover {
	bottom: 10px;
	opacity: 0.8;
}
.entrance-item .item-more {
	font-family: var(--font-ttl-en);
	color: var(--col-wh);
	display: block;
	text-align: center;
	position: relative;
	width: fit-content;
	margin: 0 auto;
}
.entrance-item .item-more::before {
	position: absolute;
	content: '';
	background: url(../img/common/icon-arw-wh.png) no-repeat;
	width: 23px;
	height: 10px;
	bottom: 0;
	margin: auto;
	right: -40px;
	top: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
.entrance-item .item-ttl .main-ttl {
	color: var(--col-wh);
	font-size: clamp(1.5rem, 1vw, 2rem);
	font-weight: 600;
	box-sizing: border-box;
	width: 100%;
	position: relative;
	display: block;
	text-align: center;
	margin-bottom: 35px;
}
.entrance-item .item-ttl .main-ttl::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco-ttl-frame04.png) no-repeat center center;
	width: 270px;
	height: clamp(55px, 3.6vw, 71px);
	left: 0;
	margin: auto;
	right: 0;
	top: 0;
	bottom: clamp(-15px, 0.7vw, -8px);
	background-size: contain;
	transition: all 0.3s ease;
	z-index: -1;
}
.entrance-item:nth-child(1) {
	position: absolute;
	bottom: clamp(80px, 6.7vw, 130px);
	margin: auto;
	left: clamp(50px, 5.2vw, 270px);
	width: clamp(400px, 26vw, 483px);
	height: fit-content;
}
.entrance-item:nth-child(1) .item-ttl {
	position: relative;
}
.entrance-item:nth-child(1) .item-ttl .main-ttl {
	color: var(--col-main);
	font-size: clamp(2.8rem, 1.8vw, 3.5rem);
	font-weight: 600;
	box-sizing: border-box;
	width: 100%;
	position: relative;
	display: block;
	text-align: center;
	margin-bottom: 35px;
}
.entrance-item:nth-child(1) .item-ttl .main-ttl::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco-ttl-frame02.png) no-repeat center center;
	width: clamp(400px, 26vw, 483px);
	height: clamp(100px, 6.7vw, 125px);
	left: 0;
	margin: auto;
	right: 0;
	top: 0;
	bottom: clamp(-15px, 0.7vw, -8px);
	background-size: contain;
	transition: all 0.3s ease;
	z-index: -1;
}
.entrance-item:nth-child(1) .item-ttl .sub-ttl {
	background: var(--col-main-bg);
	border-radius: 30px;
	display: block;
	width: fit-content;
	box-sizing: border-box;
	padding: 2px 10px;
	color: var(--col-wh);
	position: relative;
	top: clamp(-28px, -1.6vw, -10px);
	left: 0;
	right: 0;
	margin: auto;
	font-weight: 500;
}
.entrance-item:nth-child(2) {
	position: absolute;
	top: clamp(180px, 13vw, 250px);
	margin: auto;
	left: 0;
	right: -5vw;
	width: clamp(400px, 27vw, 420px);
	height: fit-content;
}
.entrance-item:nth-child(2) .item-ttl {
	position: relative;
}
.entrance-item:nth-child(2) .item-ttl .main-ttl {
	color: var(--col-wh);
	font-size: clamp(2.8rem, 1.8vw, 3.5rem);
	font-weight: 600;
	box-sizing: border-box;
	width: 100%;
	position: relative;
	display: block;
	text-align: center;
	margin-bottom: 35px;
}
.entrance-item:nth-child(2) .item-ttl .main-ttl::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco-ttl-frame03.png) no-repeat center center;
	width: clamp(400px, 27vw, 420px);
	height: clamp(100px, 6.7vw, 125px);
	left: 0;
	margin: auto;
	right: 0;
	top: 0;
	bottom: clamp(-15px, 0.7vw, -8px);
	background-size: contain;
	transition: all 0.3s ease;
	z-index: -1;
}
.entrance-item:nth-child(2) .item-ttl .sub-ttl {
	background: var(--col-wh);
	border-radius: 30px;
	display: block;
	width: fit-content;
	box-sizing: border-box;
	padding: 2px 10px;
	color: var(--col-main);
	position: relative;
	top: clamp(-20px, -1.8vw, -15px);
	left: 0;
	right: 0;
	margin: 0 auto;
	font-weight: 500;
	width: fit-content;
}
.entrance-item:nth-child(2) .item-ttl .sub-ttl::before {
	position: absolute;
	content: '';
	background: var(--col-wh);
	clip-path: polygon(50% 100%, 0 0, 100% 0);
	width: 12px;
	height: 10px;
	bottom: -9px;
	left: 0;
	margin: auto;
	right: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
.entrance-item:nth-child(3) {
	position: absolute;
	top: clamp(190px, 13vw, 250px);
	margin: auto;
	right: clamp(50px, 8.5vw, 270px);
}
.entrance-item:nth-child(4) {
	position: absolute;
	bottom: 0;
	top: clamp(40px, 5.5vw, 100px);
	margin: auto;
	right: clamp(350px, 21vw, 420px);
}
.entrance-item:nth-child(5) {
	position: absolute;
	bottom: clamp(80px, 5.25vw, 115px);
	margin: auto;
	left: clamp(100px, 15vw, 240px);
	right: 0;
}
.entrance-item:nth-child(6) {
	position: absolute;
	bottom: clamp(80px, 5.25vw, 115px);
	margin: auto;
	right: clamp(120px, 8.5vw, 270px);
}

@media screen and (max-width: 1600px) {
	.entrance .entrance-item .item-ttl .main-ttl {
		margin-bottom: 25px;
	}
	.entrance .entrance-item:nth-child(3) {
		top: clamp(190px, 13vw, 250px);
		right: clamp(50px, 6vw, 150px);
	}
	.entrance .entrance-item:nth-child(4) {
		bottom: 0;
		top: clamp(40px, 5.5vw, 100px);
		right: clamp(240px, 19vw, 350px);
	}
	.entrance .entrance-item:nth-child(5) {
		bottom: clamp(80px, 5.25vw, 115px);
		left: clamp(80px, 15vw, 220px);
		right: 0;
	}
	.entrance .entrance-item:nth-child(6) {
		bottom: clamp(80px, 5.5vw, 115px);
		right: clamp(40px, 5.8vw, 180px);
	}
}
@media screen and (max-width: 1300px) {
	.entrance .entrance-item .item-ttl .main-ttl {
		margin-bottom: 25px;
	}
	.entrance .entrance-item:nth-child(3) {
		right: 10px;
	}
	.entrance .entrance-item:nth-child(4) {
		right: 200px;
	}
	.entrance .entrance-item:nth-child(6) {
		right: 0;
	}
}

.entrance-news-right {
	width: 740px;
}
.entrance-news .news-item a {
	background: var(--col-wh);
}

.entrance-footer {
	position: relative;
}
.entrance-footer #copyright {
	position: absolute;
	text-align: center;
	margin: 0 auto;
	left: 0;
	right: 0;
	bottom: 30px;
	font-size: 1.2rem;
	z-index: 5;
}

/*--------------- △ entrance △ ---------------*/
/*--------------- ▽ top-page ▽ ---------------*/
.top-section {
	padding: 120px 0;
	box-sizing: border-box;
}

/*--------------- ▼ main-visual ▼ ---------------*/
.mv {
	position: relative;
	width: 100%;
	height: clamp(750px, 60vw, 920px);
	background: url(../img/mv/mv-bot.png) no-repeat bottom -2px center/100%, url(../img/mv/mv-bg.jpg) no-repeat center center/cover;
	margin-top: 70px;
}
.mv-wrap {
	width: 100%;
	height: 100%;
	margin: auto;
}
.mv-img {
	margin: 0 100px 0 auto;
	width: fit-content;
	height: fit-content;
	position: relative;
	top: 50px;
}
.mv-catch {
	position: absolute;
	left: 0;
	top: 40px;
	margin: auto;
	width: clamp(550px, 45vw, 800px);
	height: fit-content;
	z-index: 10;
}

/*--------------- ▲ main-visual ▲ ---------------*/
/*--------------- ▼ top ▼ ---------------*/
/*--------------------
top-ameba
---------------------*/
.top-ameba {
	background: url(../img/top/ameba-bg-bot.png) no-repeat bottom -2px center/100%, var(--col-main-bg);
	padding: 130px 0 220px;
}
.top-ameba-bnr-wrap {
	position: relative;
	outline: 10px solid var(--col-wh);
	border-radius: 150px;
	transition: all 0.3s ease;
	bottom: 0;
}

.top-ameba-bnr {
	display: block;
	position: relative;
	background: url(../img/top/ameba-illust-l.png) no-repeat bottom left 30px, url(../img/top/ameba-illust-r.png) no-repeat bottom right 30px,
		url(../img/top/ameba-deco-bot.png) no-repeat center bottom/100%, var(--col-wh);
	border-radius: 150px;
	height: 300px;
	transition: all 0.3s ease;
	border: 3px dashed var(--col-main-light);
	box-sizing: border-box;
	padding: 30px;
	overflow: hidden;
}
.top-ameba-bnr-wrap:hover {
	opacity: 0.7;
	bottom: 10px;
}
.top-ameba-bnr::before {
	position: absolute;
	content: '';
	background: rgba(var(--col-main-rgb), 0.2);
	width: 400px;
	height: 400px;
	border-radius: 50%;
	bottom: 0;
	left: 0;
	margin: auto;
	right: 0;
	top: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
.top-ameba-bnr .bnr-ttl {
	text-align: center;
	margin: 0 auto 30px;
}
.top-ameba-bnr .bnr-more {
	position: relative;
	display: block;
	font-family: var(--font-ttl-en);
	font-size: 2.5rem;
	color: var(--col-main-dark);
	text-align: center;
	margin: 0 auto;
	width: fit-content;
	box-sizing: border-box;
	padding: 0 40px 0 0;
}
.top-ameba-bnr .bnr-more::before {
	position: absolute;
	content: '';
	background: url(../img/common/icon-arw.png) no-repeat;
	width: 31px;
	height: 14px;
	bottom: 0;
	margin: auto;
	right: 0;
	top: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
.top-ameba-bnr .bnr-text {
	background: var(--col-main);
	color: var(--col-wh);
	display: block;
	width: fit-content;
	text-align: center;
	margin: 0 auto;
	font-size: 2.5rem;
	font-weight: 500;
	border-radius: 30px;
	box-sizing: border-box;
	padding: 10px 20px;
	margin: 0 auto 20px;
	position: relative;
	z-index: 2;
}

/*--------------------
top-about
---------------------*/
.top-about {
	background: url(../img/common/deco-flag-l.png) no-repeat top left, url(../img/common/deco-flag-r.png) no-repeat top right, url(../img/top/about-bg-bot.png) no-repeat center bottom,
		url(../img/common/pat01.png);
	padding: 30px 0 200px;
}
.top-about-ttl {
	margin: 0 auto 30px;
	text-align: center;
}
.top-about .outbox {
	position: relative;
	background: url(../img/top/about-deco01.png) no-repeat right top;
}
.top-about-text {
	margin: 0 auto 60px;
	position: relative;
}
.top-about-movie {
	position: relative;
	box-sizing: border-box;
	padding: 10px 44px;
	background: url(../img/common/movie-frame.png) no-repeat center center/contain;
	width: fit-content;
	margin: 0 auto;
}
.top-about-movie::before {
	position: absolute;
	content: '';
	background: url(../img/top/about-deco02.png) no-repeat;
	width: 62px;
	height: 62px;
	left: -100px;
	margin: auto;
	top: -60px;
	background-size: contain;
	transition: all 0.3s ease;
}
.top-about-movie .movie {
	padding-top: 56.25%;
	width: 760px;
	position: relative;
}
.top-about-movie .movie video {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0px;
	left: 0px;
}

/*--------------------
top-service
---------------------*/
.top-service {
	background: url(../img/top/service-bg-tr.png) no-repeat top right, url(../img/top/service-bg-bot.png) no-repeat center bottom, url(../img/common/pat02.png) repeat;
	padding: 180px 0;
}
.top-service-contents {
	position: relative;
	z-index: 2;
	box-sizing: border-box;
	padding: 0 0 150px 0;
	margin-bottom: 40px;
}
.top-service-contents .contents-ttl {
	font-size: 3.5rem;
	font-weight: 700;
	color: var(--col-wh);
	box-sizing: border-box;
	padding: 70px 70px 50px 50px;
	margin-bottom: 40px;
	text-align: center;
}
.top-service-contents .contents-text-wrap {
	position: relative;
	box-sizing: border-box;
	top: -70px;
}
.top-service-contents .contents-text-wrap::before {
	position: absolute;
	content: '';
	background: var(--col-wh);
	width: 640px;
	height: 550px;
	left: 0;
	margin: auto;
	right: 0;
	top: 40px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: -1;
	border-radius: 50%;
	opacity: 0.7;
}
.top-service-contents .contents-text {
	margin: 0 auto 30px;
}
.top-service-contents .contents-btn {
	margin: 0 auto;
}
.top-service-contents .contents-img .img {
	aspect-ratio: 640/450;
	width: 640px;
	height: 450px;
	border-radius: 10px;
	position: relative;
}
.top-service-contents .contents-img .img::before {
	position: absolute;
	content: '';
	border: 2px dashed var(--col-wh);
	width: calc(100% - 12px);
	height: calc(100% - 12px);
	bottom: 0;
	left: 0;
	margin: auto;
	right: 0;
	top: 0;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 10;
}
.top-service-contents:nth-of-type(odd)::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco01.png) no-repeat;
	width: 273px;
	height: 192px;
	bottom: 0px;
	left: -200px;
	margin: auto;
	right: 0;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 2;
}
.top-service-contents:nth-of-type(odd) .contents-img {
	transform: rotate(8deg);
}
.top-service-contents:nth-of-type(odd) .contents-text-wrap {
	padding: 0 0 0 100px;
}
.top-service-contents:nth-of-type(even)::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco03.png) no-repeat;
	width: 192px;
	height: 141px;
	bottom: 20px;
	left: -260px;
	margin: auto;
	right: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
.top-service-contents:nth-of-type(even) .contents-img {
	transform: rotate(-8deg);
	order: 1;
}
.top-service-contents:nth-of-type(even) .contents-text-wrap {
	padding: 0 100px 0 0;
	order: 2;
}
.top-service-contents:nth-of-type(even) .contents-text-wrap::before {
	right: 70px;
	left: auto;
}
.top-service-contents:nth-child(1) .contents-ttl {
	background: url(../img/top/servicettl-deco01.png) no-repeat center center/contain;
}
.top-service-contents:nth-child(1) .contents-text-wrap::after {
	position: absolute;
	content: '';
	background: url(../img/common/illust01.png) no-repeat;
	width: 164px;
	height: 189px;
	bottom: -70px;
	left: 0;
	margin: auto;
	background-size: contain;
	transition: all 0.3s ease;
}
.top-service-contents:nth-child(1) .contents-img::before {
	position: absolute;
	content: '';
	background: url(../img/common/illust02.png);
	width: 154px;
	height: 174px;
	bottom: -70px;
	margin: auto;
	right: -60px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 5;
}
.top-service-contents:nth-child(2) {
	margin-bottom: 80px;
}
.top-service-contents:nth-child(2) .contents-ttl {
	background: url(../img/top/servicettl-deco02.png) no-repeat center center/contain;
	padding: 70px 160px 120px 70px;
	margin-bottom: 0;
	right: -60px;
}
.top-service-contents:nth-child(2) .contents-text-wrap::after {
	position: absolute;
	content: '';
	background: url(../img/common/illust03.png) no-repeat;
	width: 130px;
	height: 190px;
	bottom: -70px;
	right: 0;
	margin: auto;
	background-size: contain;
	transition: all 0.3s ease;
}
.top-service-contents:nth-child(2) .contents-img {
	order: 1;
}
.top-service-contents:nth-child(2) .contents-img::before {
	position: absolute;
	content: '';
	background: url(../img/common/illust04.png) no-repeat;
	width: 199px;
	height: 177px;
	bottom: -100px;
	margin: auto;
	left: -60px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 5;
}
.top-service-contents:nth-child(2) .contents-img::after {
	position: absolute;
	content: '';
	background: url(../img/common/deco-crowd01.png) no-repeat;
	width: 171px;
	height: 133px;
	left: -160px;
	margin: auto;
	top: -80px;
	background-size: contain;
	transition: all 0.3s ease;
}
.top-service-contents:nth-child(3) .contents-ttl {
	background: url(../img/top/servicettl-deco03.png) no-repeat center center/contain;
	padding: 50px 80px 60px 60px;
}
.top-service-contents:nth-child(3) .contents-text-wrap::after {
	position: absolute;
	content: '';
	background: url(../img/common/illust05.png) no-repeat;
	width: 235px;
	height: 204px;
	bottom: -120px;
	left: 20px;
	margin: auto;
	background-size: contain;
	transition: all 0.3s ease;
}
.top-service-contents:nth-child(3) .contents-img::before {
	position: absolute;
	content: '';
	background: url(../img/common/illust07.png) no-repeat;
	width: 146px;
	height: 107px;
	bottom: -70px;
	margin: auto;
	right: -60px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 5;
}
.top-service-contents:nth-child(4) .contents-ttl {
	background: url(../img/top/servicettl-deco04.png) no-repeat center center/contain;
	padding: 80px 110px 88px 50px;
	right: -20px;
	margin-bottom: 20px;
}
.top-service-contents:nth-child(4) .contents-text-wrap {
	margin: 0 0 0 auto;
	top: 0;
	right: -60px;
}
.top-service-contents:nth-child(4) .contents-text-wrap::after {
	position: absolute;
	content: '';
	background: url(../img/common/illust06.png) no-repeat;
	width: 235px;
	height: 204px;
	bottom: -120px;
	right: -80px;
	margin: auto;
	background-size: contain;
	transition: all 0.3s ease;
}
.top-service-contents:nth-child(4) .contents-img {
	position: absolute;
	left: -100px;
	top: -50px;
}

/*--------------------
top-message
---------------------*/
.top-message-container {
	background: var(--col-wh);
	border-radius: 10px;
	box-sizing: border-box;
	padding: 50px;
	border: 2px dashed var(--col-main);
	outline: 10px solid var(--col-wh);
	position: relative;
}
.top-message-container::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco-leaf03.png) no-repeat;
	width: 93px;
	height: 74px;
	bottom: -20px;
	left: -20px;
	margin: auto;
	background-size: contain;
	transition: all 0.3s ease;
}
.top-message-ttl {
	position: absolute;
	background: url(../img/common/deco-ttl-frame01.png) no-repeat center center/contain;
	box-sizing: border-box;
	padding: 10px 40px 30px 15px;
	width: 360px;
	font-size: 3rem;
	font-weight: 700;
	color: var(--col-wh);
	text-align: center;
	left: -15px;
	top: 40px;
}
.top-message-ttl .small {
	font-size: 2rem;
	display: block;
}
.top-message-text {
	width: 640px;
	margin: 0 0 0 auto;
}

/*--------------------
top-news
---------------------*/
.top-news {
	background: url(../img/common/wave-main-light-top.png) no-repeat center top, url(../img/top/news-bg.jpg) no-repeat center top/100%;
	padding: 150px 120px;
}
.top-news-box {
	background: var(--col-wh);
	box-sizing: border-box;
	padding: 50px;
	border-radius: 20px;
	position: relative;
}
.top-news-box::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco-flag-l02.png) no-repeat left top;
	width: 210px;
	height: 162px;
	left: -20px;
	margin: auto;
	top: -20px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 1;
}
.top-news-box::after {
	position: absolute;
	content: '';
	background: url(../img/common/deco-flag-l02.png) no-repeat left top;
	width: 210px;
	height: 162px;
	right: -20px;
	margin: auto;
	top: -20px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 1;
	transform: scale(-1, 1);
}
.top-news-btn {
	margin: 30px auto 0;
}

/*--------------------
top-gallery
---------------------*/
.top-gallery {
	background: url(../img/common/deco-line-top.png) repeat-x top center;
}
.top-gallery-list {
	gap: 40px;
	box-sizing: border-box;
	padding: 0 30px;
}
.top-gallery-btn {
	margin: 70px auto 0;
}
.top-gallery-item {
	width: calc((100% - 160px) / 5);
	position: relative;
}
.top-gallery-item:nth-child(odd) .item-link::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco-leaf01.png) no-repeat;
	width: 57px;
	height: 65px;
	bottom: -10px;
	margin: auto;
	right: -10px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 2;
}
.top-gallery-item:nth-child(even) {
	top: 40px;
}
.top-gallery-item:nth-child(even) .item-link::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco-leaf02.png) no-repeat;
	width: 30px;
	height: 30px;
	top: 20px;
	margin: auto;
	left: -10px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 2;
}
.top-gallery-item .item-link {
	position: relative;
	display: block;
	transition: all 0.3s ease;
	bottom: 0;
}
.top-gallery-item .item-link:hover {
	opacity: 0.7;
	bottom: 10px;
}
/*--------------- ▲ top ▲ ---------------*/
/*--------------- ▽ sub-page ▽ ---------------*/
.sub-section {
	position: relative;
	padding: 120px 0;
	box-sizing: border-box;
}

/*--------------- ▼ sub-visual ▼ ---------------*/
.sv {
	position: relative;
	width: 100%;
	height: 500px;
	background: url(../img/sv/sv-bg.png) no-repeat center center/cover;
	margin-top: 70px;
}
.sv::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco-flag-r02.png) no-repeat;
	width: 140px;
	height: 140px;
	background-size: contain;
	right: 30px;
	top: 30px;
	z-index: 5;
	margin: auto;
}
.sv-ttl {
	position: absolute;
	z-index: 50;
	font-size: 3.5rem;
	left: 30px;
	top: 0;
	bottom: 0;
	margin: auto;
	font-weight: 700;
	color: var(--col-main);
	background: url(../img/sv/sv-catch-frame.png) no-repeat center center/contain;
	box-sizing: border-box;
	padding: 200px 150px 150px;
}
.sv-img {
	aspect-ratio: 970/390;
	width: 970px;
	height: 390px;
	position: absolute;
	right: 80px;
	top: 0;
	bottom: 0;
	margin: auto;
	border-radius: 20px;
}

/*--------------- ▼ 下層共通タイトル ▼ ---------------*/
/*--------------- ▲ 下層共通タイトル ▲ ---------------*/
/*--------------- ▼ ぱんくず ▼ ---------------*/
#bread-clumb {
	width: 100%;
	position: absolute;
	margin: 0 auto;
	padding: 10px 0;
	z-index: 1;
	min-width: 1280px;
}
#bread-clumb ul {
	display: flex;
	overflow: hidden;
	white-space: nowrap;
}
#bread-clumb li {
	position: relative;
	color: var(--col-text);
	font-size: 14px;
	float: left;
	margin-right: 20px;
}
#bread-clumb li:after {
	content: '>';
	position: absolute;
	display: block;
	right: -15px;
	top: 0;
}
#bread-clumb li:last-child {
	margin-right: 0;
}
#bread-clumb li:last-child:after {
	display: none;
}
#bread-clumb li a {
	color: var(--col-text);
	border-bottom: 1px solid;
	display: block;
}
#bread-clumb li a:hover {
	opacity: 0.7;
}

/*--------------- ▲ ぱんくず ▲ ---------------*/
/*--------------- ▼ sub02_about ▼ ---------------*/
/*-----------------------
about-message
-------------------------*/
.about-message {
	background: url(../img/common/deco-leafbot-bl.png) no-repeat bottom left, url(../img/common/deco-leafline-bot.png) repeat-x center bottom;
	padding: 50px 0 120px;
}
.about-message .inbox {
	position: relative;
}
.about-message .inbox::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco-crowd04.png) no-repeat;
	width: 289px;
	height: 159px;
	margin: auto;
	right: -200px;
	top: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
.about-message-ttl {
	margin: 0 auto 70px;
}
.about-message-text-wrap {
	width: 520px;
}
.about-message-img .img {
	aspect-ratio: 500/600;
	width: 500px;
	height: 600px;
}
.about-message-name {
	font-size: 2rem;
	gap: 12px;
	border-bottom: 1px dotted var(--col-sub);
	margin-bottom: 25px;
}
.about-message-name .name {
	position: relative;
	display: block;
	font-size: 3rem;
	font-family: var(--font-ttl-ja02);
	bottom: 10px;
}

/*-----------------------
about-philosophy
-------------------------*/
.about-philosophy {
	background: url(../img/common/deco-leafbot-br.png) no-repeat bottom right, url(../img/common/pat05.png) repeat;
}
.about-philosophy-box {
	position: relative;
	z-index: 5;
}
.about-philosophy-ttl {
	margin: 0 auto 60px;
}
.about-philosophy-container {
	background: url(../img/common/pat02.png);
	position: relative;
	display: block;
	z-index: 0;
	box-sizing: border-box;
	padding: 80px 50px 50px;
	border-radius: 20px;
	margin: 0 auto 60px;
}
.about-philosophy-container::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco-leaf04.png) no-repeat;
	width: 133px;
	height: 118px;
	bottom: -15px;
	left: -20px;
	margin: auto;
	background-size: contain;
	transition: all 0.3s ease;
}
.about-philosophy-container .container-ttl {
	margin: 0 auto 80px;
	transform: translateY(-50%);
	top: 0;
	left: 0;
	right: 0;
	position: absolute;
}
.about-philosophy-container .container-text {
	font-size: 1.8rem;
	line-height: 2.5;
}

/*-----------------------
about-staff
-------------------------*/
.about-staff-list {
	gap: 80px;
}
.about-staff-item {
	width: 500px;
}
.about-staff-item .item-img {
	margin: 0 auto 15px;
}

/*-----------------------
about-info
-------------------------*/
.about-info-table {
	width: 620px;
}
.about-info-wrap {
	margin: 0 auto 80px;
}
.about-info-img {
	width: 500px;
	position: relative;
	left: -100px;
}
.about-info-img::before {
	left: -20px;
	top: -20px;
	right: auto;
	bottom: auto;
}
.about-info-img .img {
	aspect-ratio: 500/360;
	width: 500px;
	height: 360px;
}
.about-info-access-ttl {
	width: fit-content;
	margin: 0 auto 30px;
	text-align: center;
	font-size: 3rem;
	color: var(--col-main);
	font-weight: 700;
}
.about-info-access-ttl::before {
	position: absolute;
	content: '';
	background: url(../img/common/icon-map.png) no-repeat;
	width: 22px;
	height: 30px;
	bottom: 0;
	left: -40px;
	margin: auto;
	top: 0;
	background-size: contain;
	transition: all 0.3s ease;
}

/*--------------- ▲ sub02_about ▲ ---------------*/
/*--------------- ▼ sub03_service ▼ ---------------*/
/*-----------------------
service
-------------------------*/
#service .service {
	padding: 100px 0 0;
}
#service .service-sec {
	position: relative;
	border-top: 4px double var(--col-sub);
	box-sizing: border-box;
	padding: 100px 0;
}

#service .service-sec .sec-main {
	margin: 0 auto 70px;
}
#service .service-sec .sec-main .sec-main-text {
	width: 540px;
	position: relative;
	display: block;
	margin-top: 30px;
}
#service .service-sec .sec-main .sec-main-img {
	position: relative;
	width: 500px;
}
#service .service-sec .sec-main .sec-main-img::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco-leaf04.png) no-repeat;
	width: 110px;
	height: 100px;
	bottom: -20px;
	margin: auto;
	right: -20px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 5;
}
#service .service-sec .sec-main .sec-main-img .img {
	aspect-ratio: 500/350;
	width: 500px;
	height: 350px;
	border-radius: 10px;
}
#service .service-sec .sec-environment {
	margin: 0 auto 70px;
}
#service .service-sec .sec-environment-ttl {
	top: 55px;
}
#service .service-sec .sec-environment-list {
	gap: 30px;
	width: 840px;
}
#service .service-sec .sec-environment-item {
	width: 260px;
}
#service .service-sec .sec-environment-item .item-img {
	aspect-ratio: 260/180;
	width: 260px;
	height: 180px;
	margin-bottom: 15px;
	border-radius: 10px;
}
#service .service-sec .sec-products {
	box-sizing: border-box;
	padding: 50px 40px 60px;
	position: relative;
	margin: 0 auto 100px;
}
#service .service-sec .sec-products-ttl {
	width: 95%;
	margin: 0 auto 30px;
}
#service .service-sec .sec-products-list {
	gap: 20px;
}
#service .service-sec .sec-products-item {
	width: 230px;
}
#service .service-sec .sec-products-item .item-img {
	aspect-ratio: 1/1;
	width: 230px;
	height: 230px;
	border-radius: 10px;
	margin-bottom: 15px;
}
#service .service-sec .sec-partner-ttl {
	width: 95%;
}
#service .service-sec .sec-partner-list {
	gap: 30px;
}
#service .service-sec .sec-partner-item {
	width: 520px;
}
#service .service-sec .sec-partner-item .item-link {
	display: block;
	position: relative;
	border-bottom: 1px dashed var(--col-main);
	box-sizing: border-box;
	padding: 15px 30px 15px 0;
}
#service .service-sec .sec-partner-item .item-link:hover {
	opacity: 0.7;
}
#service .service-sec .sec-partner-item .item-link::before {
	position: absolute;
	content: '';
	background: url(../img/common/icon-link.png) no-repeat;
	width: 20px;
	height: 20px;
	bottom: 0;
	margin: auto;
	right: 0;
	top: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
#service .service-sec:nth-of-type(even) .sec-ttl {
	background: var(--col-main-dark) !important;
}
#service .service-sec:nth-of-type(even) .sec-ttl::before {
	background: var(--col-main-dark);
}
#service .service-sec:nth-of-type(odd) .sec-main-img {
	order: 2;
}
#service .service-sec:nth-of-type(1) .sec-products::after {
	position: absolute;
	content: '';
	background: url(../img/common/illust01-ver02.png) no-repeat;
	width: 147px;
	height: 170px;
	bottom: -80px;
	left: -60px;
	margin: auto;
	background-size: contain;
	transition: all 0.3s ease;
}
#service .service-sec:nth-of-type(3) .sec-products::after {
	position: absolute;
	content: '';
	background: url(../img/common/illust05.png) no-repeat;
	width: 235px;
	height: 204px;
	bottom: -80px;
	left: -90px;
	margin: auto;
	background-size: contain;
	transition: all 0.3s ease;
}
#service .service-sec:nth-of-type(2) .sec-products::after {
	position: absolute;
	content: '';
	background: url(../img/common/illust03.png) no-repeat;
	width: 130px;
	height: 190px;
	bottom: -80px;
	right: -60px;
	margin: auto;
	background-size: contain;
	transition: all 0.3s ease;
}

.service-sec .sec-bnr {
	margin-top: 90px;
	display: block;
	position: relative;
	background: url(../img/top/ameba-deco-bot.png) no-repeat center bottom/100%, url(../img/common/pat02.png);
	border-radius: 150px;
	height: 300px;
	box-sizing: border-box;
	padding: 30px;
	overflow: hidden;
	transition: all 0.3s ease;
	bottom: 0;
}
.service-sec .sec-bnr:hover {
	opacity: 0.7;
	bottom: 10px;
}
.service-sec .sec-bnr::before {
	position: absolute;
	content: '';
	border: 3px dashed var(--col-main-light);
	width: calc(100% - 20px);
	height: calc(100% - 20px);
	border-radius: 150px;
	bottom: 0;
	left: 0;
	margin: auto;
	right: 0;
	top: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
.service-sec .sec-bnr-ttl {
	margin: 0 auto 30px;
	width: fit-content;
	text-align: center;
}
.service-sec .sec-bnr-text {
	background: var(--col-main);
	color: var(--col-wh);
	display: block;
	width: fit-content;
	text-align: center;
	margin: 0 auto;
	font-size: 2.5rem;
	font-weight: 500;
	border-radius: 30px;
	box-sizing: border-box;
	padding: 6px 20px;
	margin: 0 auto 20px;
	position: relative;
	z-index: 2;
}
.service-sec .sec-bnr-more {
	position: relative;
	display: block;
	font-family: var(--font-ttl-en);
	font-size: 2.5rem;
	color: var(--col-main-dark);
	text-align: center;
	margin: 0 auto;
	width: fit-content;
	box-sizing: border-box;
	padding: 0 40px 0 0;
}
.service-sec .sec-bnr-more::before {
	position: absolute;
	content: '';
	background: url(../img/common/icon-arw.png) no-repeat;
	width: 31px;
	height: 14px;
	bottom: 0;
	margin: auto;
	right: 0;
	top: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
#service .sec-works-item {
	position: relative;
	margin: 0 auto 100px;
}
#service .sec-works-item:last-of-type {
	margin: 0 auto;
}
#service .sec-works-text {
	margin: 0 auto 50px;
}
#service .sec-works-imgs {
	position: relative;
	margin: 0 auto 60px;
}
#service .sec-works-imgs::after {
	position: absolute;
	content: '';
	background: url(../img/common/icon-arw02.png) no-repeat;
	width: 69px;
	height: 42px;
	bottom: 0;
	left: -160px;
	margin: auto;
	right: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
#service .sec-works-imgs .img {
	aspect-ratio: 460/300;
	border-radius: 10px;
	outline: 7px solid var(--col-wh);
	position: relative;
}
#service .sec-works-imgs .img.before {
	border: 2px solid var(--col-main-dark);
	width: 460px;
	height: 300px;
}
#service .sec-works-imgs .img.before::before {
	position: absolute;
	content: 'BEFORE';
	background: var(--col-main-dark);
	z-index: 5;
	width: 120px;
	height: 30px;
	left: 0;
	margin: auto;
	top: 20px;
	background-size: contain;
	transition: all 0.3s ease;
	clip-path: polygon(100% 0, 90% 50%, 100% 100%, 0 100%, 0 0);
	color: var(--col-wh);
	font-size: 1.5rem;
	font-family: var(--font-ttl-en);
	line-height: 2.2;
	box-sizing: border-box;
	padding: 0 12px;
}
#service .sec-works-imgs .img.after {
	border: 2px solid var(--col-sub);
	width: 560px;
	height: 370px;
}
#service .sec-works-imgs .img.after::before {
	position: absolute;
	content: 'AFTER';
	background: var(--col-sub);
	z-index: 5;
	width: 120px;
	height: 30px;
	left: 0;
	margin: auto;
	top: 20px;
	background-size: contain;
	transition: all 0.3s ease;
	clip-path: polygon(100% 0, 90% 50%, 100% 100%, 0 100%, 0 0);
	color: var(--col-wh);
	font-size: 1.5rem;
	font-family: var(--font-ttl-en);
	line-height: 2.2;
	box-sizing: border-box;
	padding: 0 12px;
}
#service .sec-works-info {
	position: relative;
	box-sizing: border-box;
	padding: 40px 60px;
	background: url(../img/common/pat02.png);
	border-radius: 10px;
}
#service .sec-works-info-table td {
	background: none;
}
#service .sec-works-info-table th {
	border-radius: 5px;
}

/*-----------------------
service-contact
-------------------------*/
.service-contact {
	background: url(../img/service/service-bg-bot.png) no-repeat center bottom;
}
/*--------------- ▲ sub03_service ▲ ---------------*/
/*--------------- ▼ sub04_merit ▼ ---------------*/
/*-----------------------
merit-links
-------------------------*/
.merit-links .com-page-links-list {
	gap: 50px;
}
.merit-links .com-page-links-item {
	width: 400px;
}
.merit-links .inbox {
	position: relative;
}
.merit-links .inbox::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco-crowd04.png) no-repeat bottom right;
	width: 289px;
	height: 159px;
	bottom: -100px;
	margin: auto;
	right: -200px;
	background-size: contain;
	transition: all 0.3s ease;
}
.merit-links .inbox::after {
	position: absolute;
	content: '';
	background: url(../img/common/deco-crowd05.png) no-repeat bottom right;
	width: 171px;
	height: 133px;
	bottom: -130px;
	left: -50px;
	margin: auto;
	background-size: contain;
	transition: all 0.3s ease;
}

/*-----------------------
merit-reason
-------------------------*/
.merit-reason {
	padding: 0;
}
.merit-reason .inbox {
	position: relative;
}
.merit-reason .inbox::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco-flag-l.png) no-repeat;
	width: 266px;
	height: 170px;
	left: -100px;
	margin: auto;
	top: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
.merit-reason .inbox::after {
	position: absolute;
	content: '';
	background: url(../img/common/deco-flag-r.png) no-repeat;
	width: 266px;
	height: 170px;
	right: -100px;
	margin: auto;
	top: 0px;
	background-size: contain;
	transition: all 0.3s ease;
}
.merit-reason-list {
	gap: 30px;
}
.merit-reason-item {
	position: relative;
	width: 340px;
	height: 340px;
	border-radius: 50%;
	background: var(--col-main);
}
.merit-reason-item .item-text {
	color: var(--col-wh);
	font-family: var(--font-ttl-ja);
	text-align: center;
	font-size: 2.2rem;
	line-height: 2;
	font-weight: 600;
	transform: rotate(0.05deg);
}
.merit-reason-item .item-num {
	text-align: center;
	position: absolute;
	top: -5px;
	left: 0;
	right: 0;
	margin: 0 auto;
	width: 70px;
	height: 95px;
	clip-path: polygon(100% 0, 100% 100%, 50% 78%, 0 100%, 0 0);
	background: var(--col-sub02);
	box-sizing: border-box;
	padding: 15px 2px 10px;
	color: var(--col-sub-dark);
	font-family: var(--font-ttl-en);
	font-size: 1.5rem;
}
.merit-reason-item .item-num .num {
	font-size: 2.5rem;
}
.merit-reason-item:nth-child(even) {
	background: var(--col-main-dark);
}

/*-----------------------
merit-case
-------------------------*/
.merit-case {
	padding: 120px 0 260px;
	background: url(../img/common/deco-leafline-bot02.png) no-repeat center bottom;
}
.merit-case .inbox {
	position: relative;
}
.merit-case-item {
	position: relative;
	margin: 0 auto 150px;
}
.merit-case-item:last-of-type {
	margin: 0 auto;
}
.merit-case-item .item-text-wrap {
	width: 470px;
}
.merit-case-item .item-text {
	box-sizing: border-box;
	padding: 0 15px;
}
.merit-case-item .item-ttl {
	color: var(--col-wh);
	background: url(../img/common/deco-ttl-frame07.png) no-repeat center center/contain;
	font-size: 3.5rem;
	box-sizing: border-box;
	padding: 50px;
	text-align: center;
	margin-bottom: 20px;
	font-weight: 700;
}
.merit-case-item .item-img {
	position: absolute;
}
.merit-case-item .item-img .img {
	aspect-ratio: 600/420;
	width: 600px;
	height: 420px;
	border-radius: 10px;
	position: relative;
}
.merit-case-item .item-img .img::before {
	position: absolute;
	content: '';
	border: 2px dashed var(--col-wh);
	width: calc(100% - 15px);
	height: calc(100% - 15px);
	bottom: 0;
	left: 0;
	margin: auto;
	right: 0;
	top: 0;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 5;
}
.merit-case-item:nth-child(odd) .item-img {
	right: -100px;
	top: 20px;
	transform: rotate(8deg);
}
.merit-case-item:nth-child(even) .item-img {
	left: -100px;
	top: 20px;
	transform: rotate(-8deg);
}
.merit-case-item:nth-child(even) .item-text-wrap {
	margin: 0 0 0 auto;
}
.merit-case-item:nth-child(even) .item-ttl {
	background: url(../img/common/deco-ttl-frame08.png) no-repeat center center/contain;
}
.merit-case-item:nth-child(1) .item-img::before {
	position: absolute;
	content: '';
	background: url(../img/common/illust08.png) no-repeat;
	width: 156px;
	height: 211px;
	bottom: -60px;
	margin: auto;
	right: -100px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 2;
}
.merit-case-item:nth-child(3)::before {
	position: absolute;
	content: '';
	background: url(../img/common/illust09.png) no-repeat;
	width: 167px;
	height: 203px;
	bottom: -160px;
	margin: auto;
	right: -100px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 2;
}

/*-----------------------
merit-voice
-------------------------*/
.merit-voice-item {
	position: relative;
	margin: 0 auto 50px;
}
.merit-voice-item:last-child {
	margin: 0 auto;
}
.merit-voice-item .item-voice {
	box-sizing: border-box;
	padding: 30px;
	background: url(../img/common/pat02.png);
	border-radius: 20px;
}
.merit-voice-item .item-info {
	margin: 0 auto 20px;
}
.merit-voice-item .item-info-icon {
	aspect-ratio: 1/1;
	width: 110px;
	height: 110px;
	border: 1px solid var(--col-main);
	border-radius: 50%;
}
.merit-voice-item .item-info-about {
	width: 770px;
}
.merit-voice-item .item-info-about-wrap {
	gap: 15px;
}
.merit-voice-item .item-info-about-wrap .ttl {
	background: var(--col-main);
	color: var(--col-wh);
	border-radius: 30px;
	box-sizing: border-box;
	padding: 6px 15px;
	height: fit-content;
	display: inline-block;
}
.merit-voice-item .item-info-about-wrap .text {
	flex: 1;
	position: relative;
	top: 5px;
}

/*--------------- ▲ sub04_merit ▲ ---------------*/
/*--------------- ▼ sub05_gallery- ▼ ---------------*/
/*-----------------------
gallery
-------------------------*/
#gallery .gallery {
	padding: 0 0 120px;
}
#gallery .gallery-list {
	gap: 30px;
}
#gallery .gallery-item {
	width: 340px;
}
#gallery .gallery-item .tag {
	color: var(--col-sub);
	font-weight: 600;
	position: relative;
}
#gallery .gallery-item .tag::before {
	position: absolute;
	content: '';
	background: var(--col-sub);
	width: 5px;
	height: 5px;
	border-radius: 50%;
	bottom: 0;
	margin: auto;
	right: -12px;
	top: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
#gallery .gallery-item .tag:last-of-type::before {
	content: none;
}
#gallery .gallery-item .tag-list {
	gap: 25px;
	margin-bottom: 12px;
}
#gallery .gallery-item .item-img::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco-leaf01.png) no-repeat;
	width: 57px;
	height: 65px;
	bottom: -10px;
	margin: auto;
	right: -10px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 5;
}
#gallery .gallery-item .item-img .img {
	aspect-ratio: 1/1;
	width: 340px;
	height: 340px;
	display: block;
	margin-bottom: 20px;
}

#gallery .gallery-item .item-link {
	position: relative;
	display: block;
	transition: all 0.3s ease;
	bottom: 0;
}
#gallery .gallery-item .item-link:hover {
	opacity: 0.7;
	bottom: 10px;
}
#gallery .gallery-item figcaption {
	padding: 0 50px 0 0;
	box-sizing: border-box;
}

.com-page-links-item.current a {
	background: var(--col-sub);
}
/*-----------------------
gallery-post
-------------------------*/
#gallery-post .item-img {
	width: 900px;
	height: 600px;
	margin: 0 auto;
}

#gallery-post .img {
	aspect-ratio: auto;
}
/*--------------- ▲ sub05_gallery- ▲ ---------------*/
/*--------------- ▼ お知らせ ▼ ---------------*/
.post-wrp .tag-change {
	margin-bottom: 50px;
}
.post-wrp .tag-change li {
	text-align: center;
	width: 19%;
	margin: 2% 1% 0 0;
}
.post-wrp .tag-change li a {
	border: solid 1px --col-main;
	padding: 10px 0;
	display: block;
	color: var(--col-main);
	background: var(--col-base);
}
.post-wrp .tag-change .current a {
	background: var(--col-main);
}
.post-wrp .tag-change .current a span {
	color: var(--col-base);
}

/*タグ一覧
-------------------------------*/
.tag-select-box {
	position: relative;
	width: 40%;
	margin: 0 0 20px auto;
	max-width: 230px;
}
.tag-select-box:before {
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	z-index: 2;
	right: 0.8em;
	width: 0;
	height: 0;
	padding: 0;
	content: '';
	border-left: 5px solid transparent;
	border-right: 5px solid transparent;
	border-top: 6px solid var(--col-text);
	pointer-events: none;
}
.tag-select-box #tag-select {
	width: 100%;
	padding: 5% 20% 5% 5%;
	box-sizing: border-box;
	font-size: 1.2rem;
	margin-left: auto;
	display: block;
	font-family: 'Noto Sans JP', sans-serif;
	border: none;
	border-bottom: 2px solid var(--col-text);
	cursor: pointer;
	border-radius: 0;
	background: none;
	color: var(--col-text);
	font-weight: 700;
	-webkit-appearance: none;
	appearance: none;
}
.tag-select-box #tag-select option {
	padding: 10px;
	box-sizing: border-box;
	cursor: pointer;
	box-sizing: border-box;
}

.post-wrp .tag-change {
	margin-bottom: 50px;
}
.post-wrp .tag-change li {
	text-align: center;
	margin: 10px 10px 0 0;
	min-width: 190px;
	display: inline-block;
	vertical-align: middle;
}
.post-wrp .tag-change li a {
	border: solid 1px var(--col-main);
	color: var(--col-main);
	background: var(--col-base);
	padding: 10px 15px;
	display: block;
}
.post-wrp .tag-change .current a {
	background: var(--col-main);
}
.post-wrp .tag-change .current a span {
	color: var(--col-base);
}

/*詳細
-------------------------------*/
.s-post .news-tag {
	margin-bottom: 20px;
}

.s-post time {
	margin-bottom: 10px;
}

.s-time-tag {
	margin-bottom: 20px;
}

.sb-post-body {
	margin-bottom: 50px;
	padding-bottom: 50px;
	border-bottom: 1px solid;
	line-height: 2;
}

/*--------------- ▲ お知らせ ▲ ---------------*/
