@charset "UTF-8";

/*--------------- ▽ header ▽ ---------------*/
.header {
	box-sizing: border-box;
	padding: 17px clamp(40px, 4.5vw, 100px);
	background: var(--col-wh);
	position: fixed;
	width: 100%;
	z-index: 1000;
	top: 0;
}
.header-inner {
	min-width: 1180px;
}
.header h1 span {
	display: block;
}
.header-logo {
	display: block;
	width: clamp(250px, 20vw, 322px);
}
.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;
	font-family: var(--font-ttl-ja);
}

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

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

.header-nav-link.current .nav-wrap::before {
	background: var(--col-sub02);
}

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

/*--------------- △ 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: -55px;
	left: 50%;
	width: 1920px;
	height: 55px;
	transform: translateX(-50%);
	background: url(../img/common/bg-wave.png) no-repeat center top;
	background-size: 1920px 55px;
	pointer-events: none;
	z-index: 10;
}

.footer {
	position: relative;
	background: var(--col-main-middlelight);
	box-sizing: border-box;
	box-sizing: border-box;
	padding: 55px 0;
}
.footer-logo {
	display: block;
	width: fit-content;
	margin: 0 auto 50px;
}
.footer-logo:hover {
	opacity: 0.7;
}

.footer-tel{
  margin-bottom: 25px;
}
.footer-btn-list {
	flex-direction: column;
	gap: 20px;
}
.footer-btn {
	width: 270px;
}
.footer-nav {
	gap: 60px;
}
.footer-nav-list {
	flex-direction: column;
	gap: 30px 60px;
	font-weight: 700;
	height: 260px;
	font-family: var(--font-ttl-ja);
}
.footer-nav a:hover {
	opacity: 0.7;
}
.footer #copyright {
	text-align: center;
	padding: 5px 0;
	margin-top: 80px;
}
.footer #copyright small {
	color: var(--col-text);
	font-size: 1.4rem;
}
.footer #copyright small a {
	color: var(--col-text);
}
.footer #copyright small a:hover {
	opacity: 0.7;
}

/*--------------- △ footer △ ---------------*/
/*--------------- ▽ 共通 ▽ ---------------*/
/*--------------- △ 共通 △ ---------------*/
/*--------------- ▽ top-page ▽ ---------------*/
.top-section {
	padding: 100px 0;
	box-sizing: border-box;
}

/*--------------- ▼ main-visual ▼ ---------------*/
.mv {
	position: relative;
	width: 100%;
	margin: 150px 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 {
	width: 94%;
	margin: 0 auto;
	background:
		url(../img/mv/mv-deco-l.png) no-repeat left top,
		url(../img/mv/mv-deco-r.png) no-repeat right top,
		var(--col-base);
	box-sizing: border-box;
	padding: 80px 120px;
	border-radius: 20px;
	border: 4px solid var(--col-main-light);
	max-width: 1720px;
}
.mv-catch {
	display: block;
	margin: 0 auto;
	text-align: center;
	position: relative;
	box-sizing: border-box;
	padding: 0 0 clamp(160px, 30vw, 220px);
}
.mv-catch::before {
	position: absolute;
	content: '';
	background: url(../img/common/illsut-staff01.png) no-repeat center bottom;
	width: clamp(380px, 30vw, 525px);
	height: 361px;
	bottom: -70px;
	left: 0;
	margin: auto;
	right: 0;
	background-size: contain;
	transition: all 0.3s ease;
}
.mv-catch-main {
	margin: 0 auto 35px;
	display: block;
}
.mv-catch-sub {
	font-size: clamp(2rem, 1.5vw, 2.5rem);
	letter-spacing: 0.1em;
	font-weight: 800;
	white-space: nowrap;
	line-height: 1.8;
}
.mv-img {
	position: relative;
	right: -50px;
}
.mv-box-inner {
	gap: 20px;
}

/*--------------- ▲ main-visual ▲ ---------------*/
/*--------------- ▼ top ▼ ---------------*/
/*--------------------
top-lead
---------------------*/
.top-lead {
	padding: 140px 0 165px;
	position: relative;
	background:
		url(../img/common/bg-wave-stripe.png) no-repeat center bottom,
		url(../img/common/bg-deco01.png) no-repeat bottom -30px right;
}
.top-lead-wrap {
	position: relative;
}
.top-lead-text-wrap {
	width: 650px;
	margin: 0 0 0 auto;
}
.top-lead-ttl {
	font-size: 3.8rem;
	line-height: 1.6;
	margin: 0 auto 40px;
}
.top-lead-ttl .large {
	font-size: 4.2rem;
}
.top-lead-ttl::before {
	position: absolute;
	content: '';
	background: url(../img/common/illsut-staff02.png) no-repeat;
	width: 237px;
	height: 352px;
	margin: auto;
	right: -100px;
	top: -150px;
	background-size: contain;
	transition: all 0.3s ease;
}
.top-lead-text {
	margin: 0 auto 70px;
}
.top-lead-imgs {
	position: relative;
}
.top-lead-img-main {
	aspect-ratio: 680/510;
	width: 100%;
	height: 100%;
	width: 680px;
	height: 510px;
	border-radius: 0 20px 20px 0;
	position: absolute;
	left: -420px;
}
.top-lead-img-sub {
	aspect-ratio: 465/360;
	width: 100%;
	height: 100%;
	width: 465px;
	height: 360px;
	border-radius: 20px;
	position: absolute;
	left: -100px;
	top: 350px;
}

/*--------------------
top-reason
---------------------*/
.top-reason {
	position: relative;
	padding: 100px 0 110px;
}
.top-reason .inbox {
	position: relative;
}
.top-reason-list {
	position: relative;
	gap: 70px 30px;
	counter-reset: number 0;
}
.top-reason-item {
	position: relative;
	width: 340px;
	box-sizing: border-box;
	padding: 20px 20px 30px 20px;
	background: var(--col-wh);
	border-radius: 10px;
}
.top-reason-item::before {
	content: '0' counter(number);
	counter-increment: number 1;
	position: absolute;
	z-index: 5;
	font-size: 6rem;
	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: -30px;
}
.top-reason-item-ttl {
	text-align: center;
	margin: 0 auto 12px;
	margin: 0 auto 15px;
}
.top-reason-item-img {
	aspect-ratio: 300/190;
	width: 300px;
	height: 190px;
	border-radius: 5px;
	margin: 0 auto 25px;
}
.top-reason-img {
	position: absolute;
	bottom: -115px;
	right: 0;
	z-index: 0;
}
.top-reason-img::before {
	position: absolute;
	content: '';
	background: url(../img/top/reason-img-deco.png) no-repeat;
	width: 317px;
	height: 395px;
	margin: auto;
	right: -150px;
	top: 0;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: -1;
}

/*--------------------
top-comic
---------------------*/
.top-comic {
	padding: 100px 0 130px;
}
.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: 411px;
	height: 426px;
	bottom: -40px;
	margin: auto;
	left: -230px;
	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: 457px;
	height: 453px;
	bottom: -40px;
	margin: auto;
	right: -270px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 0;
}
.top-comic-bnr {
	position: relative;
	margin: 0 auto;
	background: url(../img/top/comic-box.jpg) no-repeat center center/cover;
	width: 790px;
	height: 430px;
	border: 3px solid var(--col-main-light);
	outline-offset: -11px;
	outline: 6px solid var(--col-wh);
	border-radius: 20px;
	overflow: hidden;
	bottom: 0;
  z-index: 2;
}
.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: 299px;
	height: 261px;
	bottom: -50px;
	margin: auto;
	right: -150px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 2;
}

/*--------------------
top-partner
---------------------*/
.top-partner .inbox {
	position: relative;
}
.top-partner .inbox::before {
	position: absolute;
	content: '';
	background: url(../img/common/illust-staff05.png) no-repeat;
	width: 268px;
	height: 357px;
	bottom: -250px;
	margin: auto;
	right: -160px;
	background-size: contain;
	transition: all 0.3s ease;
	z-index: 5;
}
.top-partner-list {
	gap: 24px;
}
.top-partner-item {
	width: 252px;
}
.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 {
	background:
		url(../img/common/bg-deco02.png) no-repeat bottom right,
		var(--col-base);
}

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

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

/*--------------- ▼ sub-visual ▼ ---------------*/
.sv {
	position: relative;
	width: 100%;
	margin: 132px auto 0;
	height: 580px;
}
.sv-ttl {
	background: url(../img/common/pat01.png);
	box-sizing: border-box;
	padding: 15px 50px;
	min-width: 680px;
	border-radius: 70px;
	font-size: 5.4rem;
	font-weight: 900;
}

/*---------------------
各ページの画像設定
-----------------------*/
.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: absolute;
	margin: 0 auto;
	padding: 0;
	z-index: 1;
	min-width: 1280px;
	font-family: var(--font-ttl-ja);
}
#bread-clumb ul {
	position: relative;
	display: flex;
	overflow: hidden;
	white-space: nowrap;
	padding: 15px;
	box-sizing: border-box;
}
#bread-clumb li {
	position: relative;
	color: var(--col-sub02);
	font-size: 14px;
	float: left;
	margin-right: 20px;
}
#bread-clumb li:after {
	content: '>';
	position: absolute;
	display: block;
	right: -15px;
	top: 0;
	color: var(--col-text);
}
#bread-clumb li:last-child {
	margin-right: 0;
}
#bread-clumb li:last-child:after {
	display: none;
}
#bread-clumb li a {
	color: var(--col-text);
	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: 100px 0 170px;
	z-index: 10;
}

.service-section,
.price-section {
	background: var(--col-wh);
	min-width: 1280px;
	margin: 0 auto 110px;
	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: 100px 0;
	position: relative;
}

/*-----------------------
service-sec-about
-------------------------*/
.service-sec-about {
	margin: 0 auto 70px;
}
.service-sec-about-wrap {
	margin: 0 auto 50px;
}
.service-sec-about-text {
	width: 565px;
}
.service-sec-about-ttl {
	font-size: 3.2rem;
	margin-bottom: 30px;
}
.service-sec-about-img {
	aspect-ratio: 455/360;
	width: 455px;
	height: 360px;
	border-radius: 20px;
}
.service-sec-about-note {
	max-width: 912px;
	margin: 0 auto;
}

/*-----------------------
service-sec-worries
-------------------------*/
.service-sec-worries {
	position: relative;
	margin: 0 auto 80px;
}
.service-sec-worries-list {
	flex-direction: column;
	gap: 22px;
}
.service-sec-worries-item {
	position: relative;
	background: var(--col-main-highlight);
	width: fit-content;
	box-sizing: border-box;
	padding: 17px 45px;
	border-radius: 50px;
	font-size: 2rem;
	font-weight: 700;
	font-family: var(--font-ttl-ja);
}
.service-sec-worries-item::before {
	position: absolute;
	content: '';
	background: var(--col-main-highlight);
	width: 26px;
	height: 13px;
	clip-path: polygon(100% 100%, 0 0, 100% 0);
	bottom: -12px;
	margin: auto;
	right: 60px;
	background-size: contain;
	transition: all 0.3s ease;
}
.service-sec-worries-illust {
	position: absolute;
	right: -30px;
	bottom: -20px;
}

/*-----------------------
service-inheritance
-------------------------*/
#service-inheritance .service-sec-worries-item:nth-child(2) {
	left: 170px;
}
#service-inheritance .service-sec-worries-item:nth-child(4) {
	left: 110px;
}

/*-----------------------
service-tax-return
-------------------------*/
#service-tax-return .service-sec-worries-item:nth-child(2) {
	left: 190px;
}
#service-tax-return .service-sec-worries-item:nth-child(4) {
	left: 190px;
}
#service-tax-return .service-sec-worries-item:nth-child(6) {
	position: absolute;
	top: 30px;
	right: 150px;
}

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

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

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

-------------------------*/
/*--------------- ▲ sub02_ ▲ ---------------*/
/*--------------- ▼ sub03_price ▼ ---------------*/
/*-----------------------
price-section
-------------------------*/
.price-section-img {
	width: 100%;
	height: 460px;
	border-radius: 20px;
	margin: 0 auto 40px;
}
.price-section-list {
	position: relative;
	margin: 0 auto 30px;
}
.price-section-item {
	position: relative;
	box-sizing: border-box;
	padding: 20px 0;
	border-bottom: 2px dashed var(--col-gry);
	font-size: 2rem;
	gap: 50px;
}
.price-section-item .ttl {
	width: 50%;
}
.price-section-item .price {
	width: 50%;
	text-align: right;
}
.price-section-text {
	margin: 0 auto 80px;
}
.price-section-note {
	width: fit-content;
	padding: 32px 40px;
	margin: 0 auto;
}
.price-section-note-ttl {
	font-size: 2.6rem;
	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;
	height: 490px;
	margin: 0 auto 100px;
}
.first-worries-item {
	background: var(--col-main-highlight);
	border-radius: 10px;
	width: fit-content;
	box-sizing: border-box;
	padding: 22px 28px;
	font-size: 2rem;
	font-weight: 700;
	font-family: var(--font-ttl-ja);
	text-align: center;
	position: absolute;
	line-height: 1.6;
}
.first-worries-item::before {
	position: absolute;
	content: '';
	clip-path: polygon(50% 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);
}
.first-worries-item:nth-child(1) {
	margin: 0 auto;
	left: 0;
	right: 0;
	left: 0;
	top: 0;
}
.first-worries-item:nth-child(2) {
	left: 0;
	top: 130px;
}
.first-worries-item:nth-child(2)::before {
	clip-path: polygon(90% 100%, 0 0, 100% 0);
	left: auto;
	right: 40px;
}
.first-worries-item:nth-child(3) {
	left: 50px;
	top: 270px;
}
.first-worries-item:nth-child(3)::before {
	clip-path: polygon(90% 100%, 0 0, 100% 0);
	left: auto;
	right: 40px;
}
.first-worries-item:nth-child(4) {
	right: 0;
	top: 130px;
}
.first-worries-item:nth-child(4)::before {
	clip-path: polygon(10% 100%, 0 0, 100% 0);
	right: auto;
	left: 40px;
}
.first-worries-item:nth-child(5) {
	right: 0;
	top: 270px;
}
.first-worries-item:nth-child(5)::before {
	clip-path: polygon(10% 100%, 0 0, 100% 0);
	right: auto;
	left: 40px;
}
.first-worries-illust {
	margin: 0 auto;
	display: block;
	width: fit-content;
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
}
.first-worries-contact {
	position: relative;
}
.first-worries-contact-ttl {
	max-width: 908px;
	transform: translateY(-50%);
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
}
.first-worries-contact-btn {
	min-width: 270px;
}
.first-worries-contact-box {
	box-sizing: border-box;
	padding: 60px 80px;
	background: url(../img/common/pat01.png);
	border-radius: 20px;
}
.first-worries-contact-list {
	gap: 30px;
}
.first-worries-contact-item .first-worries-contact-btn.btn-style02 {
	padding: 18px 50px 18px 15px;
	text-align: left;
}

/*-----------------------
first-flow
-------------------------*/
.first-flow {
	padding: 150px 0;
}
.first-flow-list {
	flex-direction: column;
	gap: 30px;
}
.first-flow-item {
	background: var(--col-wh);
	box-sizing: border-box;
	padding: 40px;
	border-radius: 20px;
}
.first-flow-item-text {
	width: 680px;
}
.first-flow-item-img {
	aspect-ratio: 260/200;
	width: 260px;
	height: 200px;
	border-radius: 20px;
}
.first-flow-item-ttl {
	gap: 15px;
	margin-bottom: 15px;
}
.first-flow-item-ttl .ttl {
	font-size: 3.2rem;
}
.first-flow-item-ttl .icon {
	position: relative;
	background: var(--col-sub);
	color: var(--col-wh);
	border-radius: 50%;
	width: 54px;
	height: 54px;
	text-align: center;
	line-height: 1;
	box-sizing: border-box;
	padding: 6px 0;
	top: -4px;
}
.first-flow-item-ttl .icon .en {
	font-size: 1.2rem;
}
.first-flow-item-ttl .icon .num {
	font-size: 2.6rem;
	position: relative;
	top: -2px;
}

/*-----------------------
first-faq
-------------------------*/
.first-faq {
	padding: 100px 0 150px;
}
.first-faq-list {
	gap: 55px;
	flex-direction: column;
}
.first-faq-item-q {
	background: var(--col-wh);
	box-sizing: border-box;
	padding: 12px 15px;
	border-radius: 20px;
	font-size: 2rem;
	gap: 40px;
	position: relative;
	overflow: hidden;
	margin-bottom: 26px;
}
.first-faq-item-q::before {
	position: absolute;
	content: '';
	background: var(--col-sub);
	width: 60px;
	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: 3rem;
	color: var(--col-wh);
	bottom: 4px;
}
.first-faq-item-q .text {
	max-width: 960px;
	line-height: 1.6;
}
.first-faq-item-a {
	gap: 20px;
}
.first-faq-item-a .icon {
	position: relative;
	display: block;
	width: 60px;
	height: 60px;
	font-size: 3rem;
	color: var(--col-wh);
	bottom: 4px;
	background: var(--col-sub02);
	border-radius: 50%;
	text-align: center;
	line-height: 2;
}
.first-faq-item-a .text {
	max-width: 900px;
	position: relative;
	box-sizing: border-box;
	padding: 20px 0 0;
	line-height: 1.7;
}

/*--------------- ▲ sub04_first ▲ ---------------*/
/*--------------- ▼ sub05_info ▼ ---------------*/
/*-----------------------
info-company
-------------------------*/
.info-company-table {
	margin: 0 auto 70px;
}
.info-company-access-ttl {
	font-size: 3.2rem;
	color: var(--col-main);
	margin: 0 auto 50px;
}

/*-----------------------
info-message
-------------------------*/
.info-message {
	padding: 150px 0;
}
.info-message-text {
	width: 612px;
}
.info-message-img {
	position: relative;
}
.info-message-img::before {
	position: absolute;
	content: '';
	background: url(../img/common/deco-circle03.png) no-repeat;
	width: 386px;
	height: 383px;
	margin: auto;
	right: -150px;
	top: -100px;
	background-size: contain;
	transition: all 0.3s ease;
}
.info-message-img .img {
	aspect-ratio: 420/400;
	width: 420px;
	height: 400px;
	border-radius: 20px;
	border: 5px solid var(--col-wh);
	margin: 0 auto 20px;
}
.info-message-img figcaption {
	text-align: center;
}

/*-----------------------
info-gallery 
-------------------------*/
.info-gallery {
	padding: 100px 0 150px;
}
.info-gallery-list {
	gap: 30px;
}
.info-gallery-item {
	width: 340px;
}
.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 {
	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;
}

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