@charset "UTF-8";

/*--------------- ▽ header ▽ ---------------*/
.header {
	box-sizing: border-box;
	padding: 14px 5%;
	background: var(--col-wh);
	position: fixed;
	width: 100%;
	z-index: 50;
	top: 0;
}
.header h1 span {
	display: block;
}
.header-wrap {
	justify-content: center;
}
.header-logo {
	display: block;
	margin: 0 auto;
	width: 180px;
	text-align: center;
}
.header-logo:hover {
	opacity: 0.7;
}
.header-right {
	gap: 30px;
}
.header-btn-list {
	gap: 20px;
	width: 100%;
	justify-content: flex-end;
	margin-bottom: 20px;
}
.header-btn-item {
	flex: 0 0 max-content;
}
.header-nav-list {
	gap: 30px;
}
.header-nav-link {
	font-weight: 700;
}

/*-------------------
header-nav
--------------------*/
.header-nav-link:hover {
	color: var(--col-main);
}

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

.header-nav-link.current .nav-wrap::before {
	background: var(--col-main);
	border: 1px solid --col-main;
}

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

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

.footer-wrap {
	position: relative;
	overflow-x: clip;
}
.footer-wrap::before {
	content: '';
	position: absolute;
	top: -20px;
	width: 100%;
	height: 20px;
	left: 0;
	transform: none;

	background: url(../img/common/bg-wave.png) no-repeat center top;
	background-size: cover;
	z-index: 10;
}

.footer {
	position: relative;
	background: var(--col-main-middlelight);
	box-sizing: border-box;
	padding: 12% 0;
}
.footer-inner {
	display: block;
}
.footer-logo {
	display: block;
	width: 250px;
	margin: 0 auto 10%;
}
.footer-logo:hover {
	opacity: 0.7;
}
.footer-btn-list {
	flex-direction: column;
	gap: 20px;
	justify-content: center;
	margin: 0 auto 10%;
}
.footer-btn {
	width: 80%;
	margin: 0 auto;
	text-align: center;
}
.footer-nav-list {
	font-weight: 700;
	font-family: var(--font-ttl-ja);
	gap: 20px;
}

.footer-nav-item{
	width: calc(100% - 20px);
	font-size: 1.3rem;
}
.footer-nav{
	gap: 35px;
}

.footer-tel{
	margin: 0 auto 6%;
}

.footer-nav-link{
	display: block;
}

.footer #copyright {
	text-align: center;
	padding: 5px 0;
	margin-top: 80px;
}
.footer #copyright small {
	color: var(--col-text);
	font-size: 1rem;
}
.footer #copyright small a {
	color: var(--col-text);
}
.footer #copyright small a:hover {
	opacity: 0.7;
}

/*--------------- △ footer △ ---------------*/
/*--------------- ▽ top-page ▽ ---------------*/
/*--------------- ▼ main-visual ▼ ---------------*/
.mv {
	position: relative;
	width: 100%;
	margin: 90px auto 0;
	width: 100%;
	box-sizing: border-box;
	padding: 0 0 50px;
}
.mv::before {
	position: absolute;
	content: '';
	background: var(--col-main-light);
	z-index: -1000;
	width: 100%;
	height: 485px;
	bottom: 0;
	left: 0;
	margin: auto;
	right: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
.mv::after {
	position: absolute;
	content: '';
	background: url(../img/common/bg-nami-wh02.png) repeat-x;
	width: 100%;
	height: 31px;
	bottom: 455px;
	left: 0;
	margin: auto;
	right: 0;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: -100;
}
.mv-box-inner {
	flex-direction: column;
	justify-content: center;
}
.mv-box {
	width: 94%;
	margin: 0 auto;
	background:
		url(../img/mv/mv-deco-l.png) no-repeat left top/60%,
		url(../img/mv/mv-deco-r.png) no-repeat right top/30%,
		var(--col-base);
	box-sizing: border-box;
	padding: 10% 5% 20%;
	border-radius: 20px;
	border: 4px solid var(--col-main-light);
}
.mv-catch {
	display: block;
	margin: 0 auto;
	text-align: center;
	position: relative;
	box-sizing: border-box;
	padding: 0 0 100px 0;
	order: 2;
}
.mv-catch::before {
	position: absolute;
	content: '';
	background: url(../img/common/illsut-staff01.png) no-repeat center bottom;
	width: 260px;
	height: 180px;
	bottom: -100px;
	left: 0;
	margin: auto;
	right: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
.mv-catch-main {
	margin: 0 auto 6%;
	display: block;
}
.mv-catch-sub {
	font-size: 1.6rem;
	letter-spacing: 0.05em;
	font-weight: 800;
	line-height: 1.8;
}
.mv-img {
	position: relative;
}
.mv-box-inner {
	gap: 20px;
}

/*--------------- ▲ main-visual ▲ ---------------*/
/*--------------- ▼ top ▼ ---------------*/
.top-section {
	padding: 17% 0;
	box-sizing: border-box;
}

/*--------------------
top-lead
---------------------*/
.top-lead {
	padding: 10% 0 22%;
	position: relative;
	background:
		url(../img/common/bg-wave-stripe.png) no-repeat center bottom/100%,
		url(../img/common/bg-deco01.png) no-repeat bottom -30px right/100%;
}
.top-lead-wrap {
	position: relative;
}
.top-lead-text-wrap {
	width: 100%;
	margin: 0 0 0 auto;
	order: 1;
	order: 1;
}
.top-lead-ttl {
	font-size: 2rem;
	line-height: 1.6;
	margin: 0 0 8%;
	width: fit-content;
	box-sizing: border-box;
	padding: 0 66px 0 0;
}
.top-lead-ttl .large {
	font-size: 2.4rem;
}
.top-lead-ttl::before {
	position: absolute;
	content: '';
	background: url(../img/common/illsut-staff02.png) no-repeat;
	width: 60px;
	height: 80px;
	margin: auto;
	right: 0;
	bottom: 0;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 2;
}
.top-lead-text {
	margin: 0 auto 12%;
}
.top-lead-imgs {
	position: relative;
	margin: 0 auto 8%;
}
.top-lead-img-main {
	aspect-ratio: 680/510;
	width: 100%;
	height: 280px;
	border-radius: 0 20px 20px 0;
	left: -5vw;
}
.top-lead-img-sub {
	position: relative;
	aspect-ratio: 465/360;
	width: 100%;
	height: 100%;
	width: 50%;
	border-radius: 20px;
	margin: -120px 0 0 auto;
}

/*--------------------
top-reason
---------------------*/
.top-reason {
	position: relative;
	padding: 17% 0 160px;
}
.top-reason .inbox {
	position: relative;
}
.top-reason-list {
	position: relative;
	gap: 30px;
	counter-reset: number 0;
}
.top-reason-item {
	position: relative;
	width: 100%;
	box-sizing: border-box;
	padding: 6% 4%;
	background: var(--col-wh);
	border-radius: 10px;
	gap: 6%;
}
.top-reason-item::before {
	content: '0' counter(number);
	counter-increment: number 1;
	position: absolute;
	z-index: 5;
	font-size: 4rem;
	color: var(--col-sub);
	letter-spacing: 0.02em;
	font-family: var(--font-ttl-ja);
	text-shadow:
		-4px 0 0 #fff,
		4px 0 0 #fff,
		0 -4px 0 #fff,
		0 4px 0 #fff,
		-3px -3px 0 #fff,
		3px -3px 0 #fff,
		-3px 3px 0 #fff,
		3px 3px 0 #fff;
	line-height: 1;
	font-weight: 700;
	top: -20px;
}
.top-reason-item-ttl {
	margin: 0 auto 5%;
}

.top-reason-item-img {
	aspect-ratio: 300/180;
	width:100%;
	height: fit-content;
	border-radius: 5px;
	margin: 0 auto 25px;
}
.top-reason-item-wrap {
	width: 100%;
}
.top-reason-img {
	position: absolute;
	z-index: 0;
	width: 110px;
	bottom: -165px;
	margin: 0 auto;
	left: 0;
	right: 0;
}
.top-reason-img::before {
	position: absolute;
	content: '';
	background: url(../img/top/reason-img-deco.png) no-repeat;
	width: 70px;
	height: 90px;
	margin: auto;
	right: -30px;
	bottom: 0;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: -2;
}

/*--------------------
top-comic
---------------------*/
.top-comic {
	padding: 17% 0 150px;
}
.top-comic .inbox {
	position: relative;
}
.top-comic-bnr-wrap {
	position: relative;
}
.top-comic-bnr-wrap::before {
	position: absolute;
	content: '';
	background: url(../img/top/comic-illust-l.png) no-repeat bottom left;
	width: 200px;
	height: 200px;
	bottom: -150px;
	margin: auto;
	left: -50px;
	background-size: contain;
	transition: all 0.3s ease;
}
.top-comic-bnr-wrap::after {
	position: absolute;
	content: '';
	background: url(../img/top/comic-illust-r.png) no-repeat bottom left;
	width: 200px;
	height: 200px;
	bottom: -150px;
	margin: auto;
	right: -50px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 0;
}
.top-comic-bnr {
	z-index: 2;
	position: relative;
	margin: 0 auto;
	background: url(../img/top/comic-box.jpg) no-repeat center center/cover;
	width: 100%;
	height: 290px;
	border: 3px solid var(--col-main-light);
	outline-offset: -11px;
	outline: 6px solid var(--col-wh);
	border-radius: 20px;
	overflow: hidden;
	bottom: 0;
	box-sizing: border-box;
}
.top-comic-bnr:hover {
	opacity: 0.7;
	bottom: 10px;
}
.top-comic-bnr-ttl {
	position: relative;
}
.top-comic-bnr-ttl::before {
	position: absolute;
	content: '';
	background: url(../img/top/comic-staff.png) no-repeat right bottom;
	width: 160px;
	height: 100px;
	bottom: -40px;
	margin: auto;
	right: -20px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 2;
}

/*--------------------
top-partner
---------------------*/
.top-partner {
	padding: 17% 0 150px;
}
.top-partner .inbox {
	position: relative;
}
.top-partner .inbox::before {
	position: absolute;
	content: '';
	background: url(../img/common/illust-staff05.png) no-repeat;
	width: 120px;
	height: 120px;
	bottom: -150px;
	margin: auto;
	right: -20px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 5;
}
.top-partner-list {
	gap: 40px 20px;
}
.top-partner-item {
	width: calc((100% - 20px) / 2);
}
.top-partner-btn {
	width: 100%;
	display: block;
}
.top-partner-btn figcaption {
	font-size: 1.2rem;
	display: block;
	text-align: center;
}
.top-partner-btn-logo {
	display: block;
	border: 1px solid var(--col-gry);
	width: 100%;
	height: 90px;
	margin: 0 auto 10px;
}
.top-partner-btn-logo.no-img {
	background: var(--col-gry);
	color: var(--col-wh);
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: -ms-flexbox;
	-js-display: flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
}
/*--------------------
top-news
---------------------*/
.top-news {
	padding: 17% 0 25%;
	background:
		url(../img/common/bg-deco02.png) no-repeat bottom right/100%,
		var(--col-base);
}

/*--------------------

---------------------*/
/*--------------- ▲ top ▲ ---------------*/
/*--------------- ▽ sub-page ▽ ---------------*/
.sub-section {
	padding: 20% 0;
	box-sizing: border-box;
	position: relative;
}

/*--------------- ▼ sub-visual ▼ ---------------*/
.sv {
	position: relative;
	width: 100%;
	margin: 90px auto 0;
	height: 190px;
}
.sv-wrap {
	width: 100%;
}
.sv-ttl {
	background: url(../img/common/pat01.png);
	box-sizing: border-box;
	padding: 4% 3%;
	border-radius: 70px;
	font-size: 2.4rem;
	font-family: 900;
	width: 80%;
	margin: 0 auto;
}

/*---------------------
各ページの画像設定
-----------------------*/
.sv-service {
	background: url(../img/sv/sv-service-bg.jpg) no-repeat center center/cover;
}

.sv-price {
	background: url(../img/sv/sv-price-bg.jpg) no-repeat center center/cover;
}

.sv-first {
	background: url(../img/sv/sv-first-bg.jpg) no-repeat center center/cover;
}

.sv-info {
	background: url(../img/sv/sv-info-bg.jpg) no-repeat center center/cover;
}

.sv-news {
	background: url(../img/sv/sv-news-bg.jpg) no-repeat center center/cover;
}

.sv-news {
	background: url(../img/sv/sv-news-bg.jpg) no-repeat center center/cover;
}

.sv-contact {
	background: url(../img/sv/sv-contact-bg.jpg) no-repeat center center/cover;
}

.sv-complete {
	background: url(../img/sv/sv-complete-bg.jpg) no-repeat center center/cover;
}

.sv-privacy {
	background: url(../img/sv/sv-privacy-bg.jpg) no-repeat center center/cover;
}

.sv-site {
	background: url(../img/sv/sv-site-bg.jpg) no-repeat center center/cover;
}

.sv-notfound {
	background: url(../img/sv/sv-notfound-bg.jpg) no-repeat center center/cover;
}

/*--------------- ▼ ぱんくず ▼ ---------------*/
#bread-clumb {
	width: 100%;
	position: relative;
	margin: 0 auto;
	padding: 2% 0;
	z-index: 100;
	line-height: 1;
}
#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_ ▼ ---------------*/
.service-wrap,
.price-wrap {
	position: relative;
	box-sizing: border-box;
	box-sizing: border-box;
	padding: 17% 0 22%;
	z-index: 10;
}

.service-section,
.price-section {
	background: var(--col-wh);
	margin: 0 auto 17%;
	width: 90%;
	border-radius: 20px;
}
.service-section:last-child,
.price-section:last-child {
	margin: 0 auto 0;
}

.service .price-sec {
	box-sizing: border-box;
	padding: 17% 0;
	position: relative;
}

/*-----------------------
service-sec-about
-------------------------*/
.service-sec-about {
	margin: 0 auto 17%;
}
.service-sec-about-wrap {
	margin: 0 auto 10%;
	flex-direction: column;
}
.service-sec-about-text {
	width: 100%;
	margin: 0 auto 10%;
}
.service-sec-about-ttl {
	font-size: 2.4rem;
	margin-bottom: 6%;
}
.service-sec-about-img {
	aspect-ratio: 455/360;
	width: 100%;
	height: fit-content;
	border-radius: 20px;
}
.service-sec-about-note {
	margin: 0 auto;
}

/*-----------------------
service-sec-worries
-------------------------*/
.service-sec-worries {
	position: relative;
	margin: 0 auto 18%;
}
.service-sec-worries-list {
	flex-direction: column;
	gap: 22px;
	margin: 0 auto 8%;
}
.service-sec-worries-item {
	position: relative;
	background: var(--col-main-highlight);
	width: fit-content;
	box-sizing: border-box;
	padding: 5%;
	border-radius: 10px;
	font-size: 1.6rem;
	font-weight: 700;
	font-family: var(--font-ttl-ja);
	max-width: 75%;
}
.service-sec-worries-item::before {
	position: absolute;
	content: '';
	background: var(--col-main-highlight);
	width: 26px;
	height: 13px;
	clip-path: polygon(0 100%, 0 0, 100% 0);
	bottom: -12px;
	margin: auto;
	left: 40px;
	background-size: contain;
	transition: all 0.3s ease;
}
.service-sec-worries-item:nth-child(odd) {
	margin: 0 0 0 auto;
}
.service-sec-worries-item:nth-child(odd)::before {
	clip-path: polygon(100% 100%, 0 0, 100% 0);
	right: 40px;
	left: auto;
}
.service-sec-worries-illust {
	position: relative;
	width: 65%;
	text-align: center;
	margin: auto;
}

/*-----------------------
service-sec-feature
-------------------------*/
.service-sec-feature-list {
	gap: 30px;
	margin: 0 auto 60px;
}
.service-sec-feature-item {
	position: relative;
	box-sizing: border-box;
	padding: 6%;
	width: 525px;
	background: var(--col-base);
	border-radius: 10px;
}

/*-----------------------

-------------------------*/
/*-----------------------

-------------------------*/
/*--------------- ▲ sub02_ ▲ ---------------*/
/*--------------- ▼ sub03_price ▼ ---------------*/
/*-----------------------
price-section
-------------------------*/

.price-section-img {
	width: 100%;
	height: 160px;
	border-radius: 20px;
	margin: 0 auto 8%;
}
.price-section-list {
	position: relative;
	margin: 0 auto 6%;
}
.price-section-item {
	position: relative;
	box-sizing: border-box;
	padding: 20px 0;
	border-bottom: 2px dashed var(--col-gry);
	font-size: 1.8rem;
	gap: 20px;
	flex-wrap: wrap;
	font-weight: 500;
}
.price-section-item .ttl {
	width: 100%;
}
.price-section-item .price {
	width: 100%;
	text-align: right;
}
.price-section-text {
	margin: 0 auto;
	text-align: left;
}
.price-section-note {
	width: 100%;
	padding: 15% 6% 10%;
	margin: 22% auto 0;
	font-size: 1.6rem;
}
.price-section-note-ttl {
	font-size: 2rem;
	background: var(--col-main);
	color: var(--col-wh);
	text-align: center;
	width: fit-content;
	height: fit-content;
	box-sizing: border-box;
	padding: 4px 50px;
	border-radius: 50px;
	margin: 0 auto;
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	top: 0;
	transform: translateY(-50%);
}

/*-----------------------

-------------------------*/
/*--------------- ▲ sub03_price ▲ ---------------*/
/*--------------- ▼ sub04_first ▼ ---------------*/
/*-----------------------
first-worries
-------------------------*/
.first-worries-wrap {
	position: relative;
	margin: 0 auto 35%;
}
.first-worries-list {
	gap: 20px;
	margin: 0 auto 10%;
}
.first-worries-item {
	background: var(--col-main-highlight);
	border-radius: 10px;
	width: fit-content;
	box-sizing: border-box;
	padding: 4%;
	font-size: 1.5rem;
	font-weight: 700;
	font-family: var(--font-ttl-ja);
	position: relative;
	max-width: 70%;
}
.first-worries-item::before {
	position: absolute;
	content: '';
	clip-path: polygon(0% 100%, 0 0, 100% 0);
	width: 26px;
	height: 18px;
	bottom: -17px;
	margin: auto;
	background-size: contain;
	transition: all 0.3s ease;
	background: var(--col-main-highlight);
	left: 40px;
}
.first-worries-item:nth-child(odd) {
	margin: 0 0 0 auto;
}
.first-worries-item:nth-child(odd)::before {
	clip-path: polygon(90% 100%, 0 0, 100% 0);
	left: auto;
	right: 40px;
}
.first-worries-illust {
	margin: -90px 0 18%;
	display: block;
	width: 150px;
	position: relative;
}
.first-worries-contact {
	position: relative;
}
.first-worries-contact-ttl {
	transform: translateY(-50%);
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	width: 90%;
	font-size: 1.8rem;
	padding: 4%;
}
.first-worries-contact-ttl::before {
	position: absolute;
	content: '';
	left: 0;
	right: 0;
	bottom: -17px;
	width: 25px;
	height: 19px;
	background: var(--col-main);
	z-index: 1;
	clip-path: polygon(50% 100%, 0 0, 100% 0);
	margin: 0 auto;
}

.first-worries-contact-btn {
	width: 80%;
	margin: 0 auto;
}
.first-worries-contact-box {
	box-sizing: border-box;
	padding: 100px 5% 15%;
	background: url(../img/common/pat01.png);
	border-radius: 20px;
}
.first-worries-contact-list {
	gap: 30px;
	flex-wrap: wrap;
	justify-content: center;
}
.first-worries-contact-item {
	width: 100%;
	margin: 0 auto;
}
.first-worries-contact-item .first-worries-contact-btn.btn-style02 {
	padding: 18px 50px 18px 15px;
	text-align: left;
}

/*-----------------------
first-flow
-------------------------*/
.first-flow {
	padding: 17% 0;
}
.first-flow-list {
	flex-direction: column;
	gap: 30px;
}
.first-flow-item {
	background: var(--col-wh);
	box-sizing: border-box;
	padding: 6%;
	border-radius: 20px;
	flex-direction: column;
	gap: 15px;
}
.first-flow-item .com-text {
	font-size: 1.5rem;
	line-height: 1.7;
}
.first-flow-item-text {
	width: 100%;
}
.first-flow-item-img {
	aspect-ratio: 260/170;
	width: 100%;
	height: fit-content;
	border-radius: 10px;
}
.first-flow-item-ttl {
	gap: 10px;
	margin-bottom: 1%;
}
.first-flow-item-ttl .ttl {
	font-size: 1.8rem;
	width: calc(100% - 52px);
}
.first-flow-item-ttl .icon {
	position: relative;
	background: var(--col-sub);
	color: var(--col-wh);
	border-radius: 50%;
	width: 42px;
	height: 42px;
	text-align: center;
	line-height: 1;
	box-sizing: border-box;
	padding: 6px 0;
	top: -6px;
}
.first-flow-item-ttl .icon .en {
	position: relative;
	font-size: 1rem;
	top: -5px;
}
.first-flow-item-ttl .icon .num {
	font-size: 1.8rem;
	position: relative;
	top: -5px;
}

/*-----------------------
first-faq
-------------------------*/
.first-faq-list {
	gap: 60px;
	flex-direction: column;
}
.first-faq-item-q {
	background: var(--col-wh);
	box-sizing: border-box;
	padding: 4% 5% 4% 12px;
	border-radius: 20px;
	font-size: 1.7rem;
	gap: 40px;
	position: relative;
	overflow: hidden;
	margin-bottom: 26px;
}
.first-faq-item-q::before {
	position: absolute;
	content: '';
	background: var(--col-sub);
	width: 45px;
	bottom: 0;
	left: 0;
	margin: auto;
	top: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
.first-faq-item-q .icon {
	position: relative;
	display: block;
	width: fit-content;
	font-size: 2.2rem;
	color: var(--col-wh);
	bottom: 4px;
	font-weight: 700;
}
.first-faq-item-q .text {
	line-height: 1.6;
	font-weight: 600;
}
.first-faq-item-a {
	gap: 20px;
}
.first-faq-item-a .icon {
	position: relative;
	display: block;
	width: 45px;
	height: 45px;
	font-size: 2.2rem;
	color: var(--col-wh);
	bottom: 4px;
	background: var(--col-sub02);
	border-radius: 50%;
	text-align: center;
	line-height: 2;
	font-weight: 700;
}
.first-faq-item-a .text {
	position: relative;
	box-sizing: border-box;
	padding:5px 0 0;
	line-height: 1.7;
	width: calc(100% - 65px);
}

/*--------------- ▲ sub04_first ▲ ---------------*/
/*--------------- ▼ sub05_info ▼ ---------------*/
/*-----------------------
info-company
-------------------------*/
.info-company-table {
	margin: 0 auto 15%;
}
.info-company-access-ttl {
	font-size: 2.2rem;
	color: var(--col-main);
  margin: 0 auto 7%;
}

/*-----------------------
info-message
-------------------------*/
.info-message {
	padding: 20% 0;
}
.info-message-wrap {
	flex-direction: column;
	justify-content: center;
}
.info-message-text {
	width: 100%;
	order: 2;
}
.info-message-img {
	position: relative;
	order: 1;
	margin: 0 auto 8%;
	width: 100%;
}
.info-message-img::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco-circle03.png) no-repeat;
	width: 150px;
	height: 150px;
	margin: auto;
	right: -12px;
	top: -40px;
	background-size: contain;
	transition: all 0.3s ease;
}
.info-message-img .img {
	aspect-ratio: 420/400;
	width: 75%;
	text-align: center;
	height: fit-content;
	border-radius: 20px;
	border: 5px solid var(--col-wh);
	margin: 0 auto 20px;
}
.info-message-img figcaption {
	text-align: center;
	width: 160px;
	margin: 0 auto;
}

/*-----------------------
info-gallery 
-------------------------*/
.info-gallery-list {
	gap: 30px 20px;
}
.info-gallery-item {
	width: calc(50% - 20px);
}
.info-gallery-item-img {
	aspect-ratio: 340/280;
	width: 100%;
	border-radius: 20px;
	border: 5px solid var(--col-wh);
}

/*--------------- ▲ sub05_info ▲ ---------------*/
/*--------------- ▼ お知らせ ▼ ---------------*/
.post-wrp .tag-change {
	text-align: center;
	flex-wrap: nowrap;
	overflow-x: scroll;
	margin-bottom: 30px;
	-webkit-justify-content: start;
	justify-content: start;
}
.post-wrp .tag-change li {
	flex: 0 0 30%;
	margin: 2% 1% 0 0;
}
.post-wrp .tag-change li a {
	border: solid 1px var(--col-main);
	padding: 5px 0;
	display: block;
	color: var(--col-main);
	background: #fff;
	font-size: 3vw;
}
.post-wrp .tag-change .current a {
	background: var(--col-main);
}
.post-wrp .tag-change .current a span {
	color: #fff;
}

/*タグ一覧
-------------------------------*/
.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: 0;
	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 #333;
	cursor: pointer;
	border-radius: 0;
	background: none;
	color: #333;
	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: #fff;
	padding: 10px 15px;
	display: block;
}
.post-wrp .tag-change .current a {
	background: var(--col-main);
}
.post-wrp .tag-change .current a span {
	color: #fff;
}

/*詳細
-------------------------------*/
.s-time-tag {
	margin-bottom: 5%;
}

.sb-post-body {
	margin-bottom: 7%;
	line-height: 2;
}

.s-post-taglist {
	margin-bottom: 30px;
}

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