@charset "utf-8";

section.company {
	width: 100%;height: 800px;padding: 0;position: relative;
	background: #d9d9d9 url(../../img/mv01@2x.jpg) no-repeat center / cover;
}
section.company .wrap {
	position: relative;width: 1300px;height: 800px;
}
section.company .wrap::after {
	content: "";width: 265px;height: 277px;position: absolute;bottom: -57px;left: 22px;
	background: url(../../img/icon/humhumkun2.svg) no-repeat center / 100%;
}
section.company .text {
	position: absolute;top: 163px;left: 50px;
}
section.company .text p {
	display: inline-flex;flex-direction: column;align-items: flex-start;gap: 13px;
}
section.company .text p span {
	display: inline;padding: 0 .6em;
	color: #000;font-size: 2rem;line-height: 1.7;
	background: var(--color-background-white);
}
section.company .text p span:nth-of-type(1) ,
section.company .text p span:nth-of-type(4) {padding: 0 .1em 0 .6em}
section.company .text p span:nth-of-type(4) {padding: 0 .1em 0 .6em}

section.company-child ul {gap: 60px;width: 1160px}
section.company-child ul li {width: 550px}
section.company-child ul li a {
	display: block;background: var(--color-background-white);padding: 105px 0;
	text-align: center;border-radius: 20px;
}
section.company-child.mini ul li a {padding: 20px 0}
section.company-child ul li span {font-size: 2rem}

section.overview .img {
	width: 100%;height: 520px;
	position: relative;
}
section.overview .img::after {
	content: "";width: 385px;height: 318px;border: solid 10px var(--color-background-white);
	background: url(../../img/company/overview02@2x.jpg) no-repeat center / 100%;
	position: absolute;bottom: -200px;right: 33px;
}
section.overview .text {
	gap: 3.2em;flex-direction: column;
	margin: 70px 0 0;
}
section.overview .text dl {
	padding: 120px;border-radius: 20px;gap: 2em 0;
	font-size: 1.8rem;margin: 50px 0 0;
}
section.overview .text dl dt {width: 120px}
section.overview .text dl dd {width: 840px}
section.access {padding: 0 0 100px;}
section.access ul {gap: 60px;flex-direction: column;margin: 0 0 70px;}
section.access ul li {display: flex;flex-wrap: wrap;gap: 50px;}
section.access ul li .img {
	width: 300px;min-height: 150px;background: var(--color-gray-200);
	border-radius: 15px;overflow: hidden;
}
section.access ul li .text {display: flex;flex-wrap: wrap;align-items: center}
section.access ul li .text p {
	position: relative;
}
section.access ul li .text p::before {
	content: "";width: 37px;height: 1px;border-top: dotted 1px var(--color-text-black);
	position: absolute;right: -50px;top: 1em;
}
section.access ul li .text p::after {
	content: "";width: 67px;height: 50px;
	position: absolute;right: -129px;top: -10px;
	background: url(../../img/icon/car.svg) no-repeat center / 100%;
}
section.access .map {
	aspect-ratio: 12 / 6.64;
	max-width: 1200px;width: 100%;
	overflow: hidden;
}
section.access iframe {width: 100%;height: 100%;border-radius: 20px}
section.vision .text {margin: 90px 0 0 435px}
section.history dl {
	padding: 0 0 0 100px;margin: 0 0 0 450px;width: 500px;
	border-left: solid 1px var(--color-gray-200);
}
section.history dl dt {
	font-size: 3em;line-height: 1;
	margin: 0 0 20px;
}
section.history dl dd {
	display: flex;flex-direction: column;gap: 80px;
	margin: 0 0 120px;
}
section.history dl dd p {font-size: 1.8rem;line-height: 1.4}
section.history dl dd .box {position: relative;min-height: 50px}
section.history dl dd .box picture {position: absolute;top: 0;left: -400px}
section.history dl dd .box:first-of-type picture {top: -45px}

section.lead2 {min-width: auto;position: relative;padding: 100px 0;gap: 90px;}
section.lead2 .text {width: 450px}
section.lead2 .img::before ,
body.page-template-area section.lead + section.contentbox .img::before {
	content: "";width: 636px;height: 468px;position: absolute;top: 100px;right: 0;
	background: url(../../img/icon/service-area.svg) no-repeat center / cover;
}
body.page-template-area section.lead + section.contentbox {position: relative}
body.page-template-area section.lead + section.contentbox .img {background: none}
body.page-template-area section.lead + section.contentbox .text {width: 450px;}
body.page-template-area section.lead + section.contentbox .img::before {
	content: "";width: 636px;height: 468px;position: absolute;top: 100px;right: 110px;
	background: url(../../img/icon/service-area.svg) no-repeat center / cover;
}

section.serviceList ul {
	gap: 60px;margin: 0 90px;align-items: stretch;
}
section.serviceList ul li {width: 300px;display: flex;align-items: center;}
section.serviceList ul a {
	display: block;background: #fff;overflow: hidden;
	border-radius: 30px;box-shadow: 0 0 15px 0 rgba(0, 0, 0, .25);
}
section.serviceList ul .img {
	position: relative;display: block;height: 200px;
	background-color: #f5f5f5;
	background-image: url(../../img/icon/service-new.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: 120px;
}
section.serviceList ul li:nth-of-type(2) .img {background-size: 224px;background-image: url(../../img/icon/service-renewal.svg)}
section.serviceList ul li:nth-of-type(3) .img {background-size: 203px;background-image: url(../../img/icon/service-seo.svg)}
section.serviceList ul li:nth-of-type(4) .img {background-size: 186px;background-image: url(../../img/icon/service-cms.svg)}
section.serviceList ul li:nth-of-type(5) .img {background-size: 177px;background-image: url(../../img/icon/service-operation.svg)}
section.serviceList ul li:nth-of-type(6) .img {background-size: 135px;background-image: url(../../img/icon/service-server.svg)}
section.serviceList ul li:nth-of-type(7) .img {background-size: 161px;background-image: url(../../img/icon/service-security.svg)}
section.serviceList ul li:nth-of-type(8) .img {background-size: 210px;background-image: url(../../img/icon/service-flow.svg)}
section.serviceList ul li:nth-of-type(9) .img {background-size: 356px;background-image: url(../../img/icon/service-area.svg)}
section.serviceList ul .img::after {
	content: "";width: 100%;height: 50px;position: absolute;bottom: -50px;left: 0;z-index: 1;
	background: url(../../img/icon/wave2.svg) no-repeat center / 110%;
	filter: brightness(0) invert(1);transition: bottom .3s;
}

section.serviceList ul a:hover .img::after {bottom: -10px}
section.serviceList ul .text {padding: 20px 40px 50px;background: #fff;position: relative;z-index: 2;}
section.serviceList ul h2 {font-size: 2rem;margin: 0 -2px 20px}
section.serviceList ul p {line-height: 1.4}
section.reason {padding: 120px 0;color: var(--color-background-white)}
section.reason h2 span {color: rgba(0, 0, 0, 0);position: relative;}
section.reason h2 span::before {
	content: "";width: 4.5em;height: 1em;position: absolute;top: 0;left: 0;
	background: url(../../img/logo.svg) no-repeat center / 100%;filter: invert(1);
}
section.reason .slider-container {
  position: relative;
}

/* Swiperのカスタマイズ */
section.reason .swiper {
  width: 100%;
  padding: 40px 0 60px;
}

/* スライド基本スタイル */
section.reason .swiper-slide {
	overflow: hidden;
	transition: all 0.3s ease;
	opacity: 0.9;transform: scale(0.95);
}
section.reason .swiper-slide-active {
	opacity: 1;transform: scale(1);
	z-index: 2;
}

/* スライドコンテンツ */
section.reason .slide-image {
	width: 100%;
	display: flex;align-items: center;justify-content: center;
}
section.reason .slide-title {
	font-size: 3.6rem;text-align: center;
	margin: 35px 0 20px;
}

section.reason .slide-text {
	max-width: 500px;margin: 0 auto;
	font-size: 2rem;
}
/* ナビゲーションボタン */
section.reason .swiper-button-prev,
section.reason .swiper-button-next {
	width: 70px;height: 70px;background: #fff;
	border-radius: 50%;box-shadow: 0 2px 8px rgba(0, 0, 0, .15);
	color: #333;
}
section.reason .swiper-button-prev {left: calc(25% - 35px)}
section.reason .swiper-button-next {right: calc(25% - 35px)}
section.reason .swiper-button-prev:after,
section.reason .swiper-button-next:after {
	content: "";width: 30px;height: 30px;box-sizing: border-box;
	border: solid 3px var(--color-primary);border-radius: 50%;
	background: url(../../img/icon/arrow03.svg) no-repeat 60% 50% / 10px 16px;
}
section.reason .swiper-button-prev:after {
	transform: rotate(180deg);
}
section.reason .swiper-button-prev:hover,
section.reason .swiper-button-next:hover {background: var(--color-gray-200)}

/* ドットナビゲーション */
section.reason .swiper-pagination {bottom: 0}
section.reason .swiper-pagination-bullet {
	width: 20px;height: 20px;
	background: var(--color-background-white);opacity: 1;
	transition: all 0.3s ease;
}
section.reason .swiper-pagination-bullet-active {
	background: var(--color-text-black);opacity: 1;
	width: 40px;border-radius: 10px;
}
/* 複製されたスライドのドットを非表示（実質3つのコンテンツのみ表示） */
section.reason .swiper-pagination-bullet:nth-child(n+4) {display: none;}
/* アクセシビリティ向上 */
section.reason .swiper-button-prev:focus,
section.reason .swiper-button-next:focus,
section.reason .swiper-pagination-bullet:focus {outline: 2px solid #4A90E2;outline-offset: 2px}
/* スライドにフォーカスがある時の表示 */
section.reason .swiper-slide:focus-within {
	outline: 2px solid #4A90E2;
	outline-offset: 4px;
}

section.mediabox {}
section.mediabox .wrap {
	flex-direction: column;gap: 90px;
}
section.mediabox .content {
	padding: 65px 50px 40px;display: flex;gap: 100px;
	border-radius: 30px;background: #F3F3F3;
}
section.mediabox .content .text {
	width: 600px;
}
section.mediabox .content .img {
	width: 300px;display: flex;flex-direction: column;gap: 10px;
}
section.mediabox .content .img img {display: block}
section.mediabox .content h2 {
	margin: 0 0 30px;
}
section.mediabox .content h3 {
	font-size: 2.4em;
	border-bottom: solid 1px #111;
	padding: 0 0 27px;
}
section.mediabox .content span.title {
	font-size: 2.4em;font-weight: 600;line-height: 1.4;
}
section.mediabox .content ul {
	margin: 25px 0;
	font-size: 1.6em;line-height: 1.6;
}
section.mediabox .content ul li::before {content: "・"}
section.mediabox .content p {
	margin: 0 0 30px;line-height: 1.6;
}
section.mediabox .content p:last-of-type {margin: 0}

section.outline {
	padding: 90px 0 150px;
}
section.outline ul {
	border-radius: 50px;border: 30px solid var(--color-gray-100);
	box-shadow: 0 0 20px 0 rgba(0, 0, 0, 0.15);padding: 45px 70px;
	flex-direction: column;gap: 17px;position: relative;
}
section.outline ul span {
	font-size: 1.4rem;line-height: 1.2;text-decoration: underline;
	display: inline-block;position: relative;padding: 0 0 0 17px;
}
section.outline ul span::before {
	content: "";width: 10px;height: 10px;background: var(--color-gray-200);
	position: absolute;top: calc(50% - 5px);left: 0;border-radius: 50%;
}
section.outline ul span::after {
	content: "";width: 5px;height: 8px;box-sizing: border-box;
	border-top: solid 1px var(--color-text-black);border-left: solid 1px var(--color-text-black);
	position: absolute;top: calc(50% - 5px);left: 3px;transform: rotate(-135deg);
}

body.parent-pageid-1184 section.outline ul::before {
	content: "";width: 440px;height: 440px;box-sizing: border-box;
	position: absolute;top: calc(50% - 220px);right: 60px;
	background: url(../../img/icon/service-new.svg) no-repeat center right / 270px 336px;
}
body.parent-pageid-1184.page-id-5548 section.outline ul::before {
	background: url(../../img/icon/service-renewal.svg) no-repeat center right / 373px 181px;
}
body.parent-pageid-1184.page-id-5550 section.outline ul::before {
	background: url(../../img/icon/service-seo.svg) no-repeat center right / 394px 289px;
}
body.parent-pageid-1184.page-id-5552 section.outline ul::before {
	background: url(../../img/icon/service-cms.svg) no-repeat center right / 361px 312px;
}
body.parent-pageid-1184.page-id-5554 section.outline ul::before {
	background: url(../../img/icon/service-operation.svg) no-repeat center right / 354px 245px;
}
body.parent-pageid-1184.page-id-5557 section.outline ul::before {
	background: url(../../img/icon/service-server.svg) no-repeat center right / 287px 290px;
}
body.parent-pageid-1184.page-id-5559 section.outline ul::before {
	background: url(../../img/icon/service-security.svg) no-repeat center right / 309px 323px;
}
body.parent-pageid-1184.page-id-3295 section.outline ul::before {
	background: url(../../img/icon/service-flow.svg) no-repeat center 0 / 437px 275px;
}

section.contentbox .text {
	display: flex;flex-direction: column;gap: 30px;
}
section.contentbox .flex {gap: 90px}
section.contentbox .flex .img {
	width: 510px;height: 340px;background: var(--color-gray-200);
}
section.contentbox .flex .text {width: 600px;}
section.contentbox.right .flex .img {order: 1}
section.contentbox.right .flex .text {order: 2}
section.contentbox h1 {
	margin: 0;
}
section.contentbox h2 {font-size: 2.4rem;margin: 0;}
section.contentbox ul.list-check {
	display: flex;flex-direction: column;gap: 18px;
}
section.contentbox ul.list-check li {
	padding: 0 0 0 25px;position: relative;
	font-size: 1.8rem;line-height: 1;
}
section.contentbox ul.list-check li::before {
	content: "";width: 12px;height: 12px;box-sizing: border-box;
	background: var(--color-primary);border-radius: 50%;
	position: absolute;top: 4px;left: 0;
}
section.contentbox .more {margin: 0;}

.areaentry {}
.areaentry .flexbox {
	display: flex;flex-wrap: wrap;gap: 90px;
	margin: 0 0 150px;
}
.areaentry .flexbox .img {
	width: 510px;height: 340px;
	background: url(../../img/back/area01@2x.png) no-repeat center / 100%;
}
.areaentry .flexbox .text {width: 600px;}
.areaentry h2 {font-size: 2.4em;margin: 0 0 30px;}
.areaentry .flexbox p {margin: 0 0 30px;}
.areaentry .flexbox.right .img {order: 1}
.areaentry .flexbox.right .text {order: 2}

section.flow h2 {
	font-size: 2.4em;
}
section.flow ol {
	gap: 50px;
	counter-reset: stepnum;
}
section.flow ol li {flex: 1;position: relative}
section.flow ol li::before{
	color: var(--color-background-white);font-size: 2.4rem;text-align: center;
	font-family: "MFW-PA1GothicStd-Bold",'A P-OTF A1ゴシック Std B';line-height: 1;
	counter-increment: stepnum;display: block;background: var(--color-text-black);
	content: "STEP " counter(stepnum, decimal-leading-zero);
	padding: 25px 15px 25px 0;height: 74px;box-sizing: border-box;
}
section.flow ol h3 {font-size: 2rem;margin: 17px 0}
section.flow ol h3::before ,
section.flow ol h3::after {content: "";width: 0;height: 0;position: absolute;top: 0;border-style: solid}
section.flow ol h3::before {
	right: 0;
	border-color: transparent var(--color-background-white) transparent transparent;
	border-width: 0px 25px 74px 0px;;
}
section.flow ol h3::after {
	left: -25px;
	border-color: transparent var(--color-text-black) transparent transparent;
	border-width: 0px 25px 74px 0px;
}
section.flow ol li:first-child h3::after ,
section.flow ol li:last-child h3::before {display: none}
section.flow ol p {line-height: 1.6}
section.flowbox ol {
	border: solid 1px var(--color-gray-200);border-radius: 10px;
	counter-reset: stepnum2;overflow: hidden;
}
section.flowbox ol li {
	padding: 60px 100px 60px 360px;overflow: hidden;
	position: relative;border-bottom: solid 1px var(--color-gray-200);
}
section.flowbox ol li:last-child {border-bottom: none}
section.flowbox ol li::before {
	background: var(--color-gray-100);content: "";
	width: 300px;height: 100%;position: absolute;top: 0;left: 0;
}
section.flowbox ol li h2::before {
	content: "STEP";width: 300px;display: block;
	position: absolute;top: 35%;left: 0;font-size: 2rem;text-align: center;
	font-family: "MFW-PA1GothicStd-Regular",'A P-OTF A1ゴシック Std R'
}
section.flowbox ol li h2::after {
	counter-increment: stepnum2;content: counter(stepnum2, decimal-leading-zero);width: 300px;display: block;
	position: absolute;top: 42%;left: 0;font-size: 4.8rem;text-align: center;
	font-family: "MFW-PA1GothicStd-Medium",'A P-OTF A1ゴシック Std M';
}
section.flowbox ol li h2 {
	font-size: 2.4em;margin: 0 0 20px;
}

ul.arealist {
	display: flex;flex-wrap: wrap;font-size: 1.6em;line-height: 3;
	margin: 0 0 200px;
}
ul.arealist:last-of-type {margin: 0}
ul.arealist li {
	padding: 0 1.5em 0 0;position: relative;
}
ul.arealist li::after {content: "｜";position: absolute;right: .3em;top: 0}
ul.arealist li:last-of-type::after {display: none}
ul.arealist li a {transition: color .3s, text-decoration .3s}
ul.arealist li a:hover {color: var(--color-primary);text-decoration: underline}

section.catelist {padding: 50px 0 1px}
section.catelist .category {
	margin: 0 0 50px;
}
section.catelist .category h2 {
	font-size: 1.6rem;line-height: 1.4;
	width: 200px;margin: 0;
}
section.catelist .category ul {
	width: 1000px;
	font-size: 1.4rem;line-height: 1.4;
	gap: 1em;
}
section.catelist .category ul li {position: relative}
section.catelist .category ul li::before {content: "｜";position: absolute;top: 0;left: -1em}
section.catelist .category ul li:first-child:before {display: none}
section.catelist .category ul a {opacity: 1;transition: opacity .3s}
section.catelist .category ul a:hover {
	text-decoration: underline;opacity: .5;
}

section.team ul.author-list {
	display: flex;flex-wrap: wrap;flex-direction: column;
	gap: 100px;margin: 0 130px;
}
section.team ul.author-list a {
	flex-direction: row;gap: 50px;
}
section.team ul.author-list .author-avatar {width: 200px}
section.team ul.author-list .author-info {width: 190px;margin: 30px 0 0}
section.team ul.author-list .author-bio {width: 420px;margin: 30px 0 0}
section.team ul.author-list h2 {
	font-size: 3em;line-height: 1;
}
section.team ul.author-list h2::after {
	content: attr(data-en);font-size: 2rem;
	display: block;position: relative;margin: 10px 0 0;
}
section.team ul.author-list p.author-title {font-size: 1.4em;color: var(--color-gray-400)}
section.author-header {
	min-width: auto;
	padding: 0;overflow: hidden;gap: 140px;align-items: center;
	border-radius: 30px;background: #F6FAFD;
}
section.author-header img {
	width: 500px;display: block;
}
section.author-header .author-text {
	width: 500px;display: block;
}
section.author-header h1 {
	font-size: 3em;line-height: 1;
}
section.author-header h1::after {
	content: attr(data-en);font-size: 2rem;
	display: block;position: relative;margin: 10px 0 0;
}
section.author-header p.head + h1 {font-size: 2.4rem;margin: 8px 0 30px}
section.author-header p.author-title {
	font-size: 1.4em;color: var(--color-gray);
	margin: 0 0 45px;
}
section.author-header ul li a {
	display: inline-block;background: var(--color-background-white);
	font-size: 1.6em;line-height: 1;
	margin: 0 0 0 60px;
	padding: 14px 60px;border-radius: 5px;position: relative;
}
section.author-header ul li a::before {
	content: "";width: 60px;height: 60px;border-radius: 50%;
	background: var(--color-gray-200) url(../../img/namika/namika@2x.png) no-repeat center / 100%;position: absolute;top: calc(50% - 32px);left: -58px;
	border: solid 5px var(--color-background-white);
}
section.author-header ul li a:hover {
	background: var(--color-gray-200);
}
section.plan-list {background: #E5EFF1}
section.plan-list .flex {gap: 40px}
section.plan-list .box {
	width: 580px;padding: 50px 50px 25px;box-sizing: border-box;
	background: var(--color-background-white);border-radius: 10px;
}
section.plan-list .box.big {
	width: 100%;padding: 50px 50px 25px;
	background: none;
}
section.plan-list p.price {
	font-size: 2em;text-align: center;line-height: 1;
	padding: 25px 0;
}
section.plan-list p.price span {font-size: 4.8em}
section.plan-list h2 {font-size: 2.4em;margin: 0 0 12px}
section.plan-list h3 {font-size: 1.8em;margin: 0 0 5px}
section.plan-list p ,
section.plan-list ul {
	margin: 0 0 2em;
	font-size: 1.6em;line-height: 1.6;
}
section.plan-list ul li {padding: 0 0 0 20px;position: relative}
section.plan-list ul li::before {content: "・";position: absolute;top: 0;left: 0}
section.plan-list .box.big h2 {text-align: center;padding: 10px 0 0;}
section.plan-list .box.big p {width: 480px;margin: 40px auto;}
section.plan-list .box.big ul {
	display: flex;gap: 120px;flex-wrap: wrap;
}
section.plan-list .box.big ul li {flex: 1}
section.plan-list .box.big ul li::before {display: none;}
section.plan-list .box.big ul li a {
	display: block;font-size: 2rem;border-radius: 30px;
	background: var(--color-background-white);padding: 20px 40px;
}
section.plan-list .box.big ul li::after {
	content: "";width: 30px;height: 32px;box-sizing: border-box;
	background: url(../../img/icon/arrow04.svg) no-repeat center / 100%;
	filter: invert(1);position: absolute;	top: calc(50% - 15px);right: 30px;
	transform: rotate(-90deg);
}
section.plan-list .box.big ul li a:hover {
	background: var(--color-gray-200);
}
section.author-content {gap: 130px}
section.author-content .box {
	width: 500px;order: 2;
}
section.author-content .box:nth-of-type(1) {width: 570px;order: 1;}
section.author-content.left .box:nth-of-type(1) {order: 3;}
section.author-content p {
	margin: 0 0 2em;
}
section.author-content dl {
	font-size: 1.4em;line-height: 1.3;
}
section.author-content dl dt ,
section.author-content dl dd ul li {
	margin: 0 0 16px;
}
section.author-content dl dd {
	margin: 0 0 30px;
}
section.author-content.left span.date {
	display: inline-block;background: var(--color-gray-200);
	font-size: 1.4em;line-height: 1;color: var(--color-gray-400);
	border-radius: 23px;padding: 6px 18px;
}
section.author-content.left dl {
	margin: 45px 0 0;width: 324px;
	font-size: 1.6em;line-height: 1.3;
}
section.author-content.left dl div {
	background: var(--color-gray-200);padding: 13px 20px;border-radius: 5px;
	display: flex;flex-wrap: wrap;justify-content: space-between;
	margin: 0 0 10px;
}
section.author-content.left dl div:nth-of-type(1) ,
section.author-content.left dl div:nth-of-type(3) ,
section.author-content.left dl div:nth-of-type(5) {margin: 0 0 45px}
section.author-content.left dl dt {width: 180px;margin: 0}
section.author-content.left dl dd {margin: 0}

/**
 * カテゴリタブメニュー - スタイル
 * 
 * ミニマルなデザインで実装。
 * デザインの変更は各セクションごとに容易に調整可能。
 */

/* メインコンテナ */
.category-tabs ,
.works-category-tabs {
	width: 100%;
	margin: 2rem 0;
}
/* タブナビゲーション */
.tab-navigation {
	display: inline-flex;gap: 2em;align-items: flex-start;
	border-top: 1px solid var(--color-gray-200);
}

/* タブボタン */
.tab-button {
	display: block;
	padding: 16px 2px;
	font-size: 1.4em;line-height: 1;
	transition: all 0.3s ease;
	border-top: 5px solid transparent;
	position: relative;
	top: -3px;
}
.tab-link {
	padding: 16px 2px 16px 13px;
}
.tab-link::before {
	content: "";width: 10px;height: 10px;box-sizing: border-box;
	background: url(../../img/icon/menu2.svg) no-repeat center / 100%;
	position: absolute;top: 18px;left: 0;
}

.tab-button:hover {
	border-top-color: var(--color-gray-200);
}

.tab-button:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}

/* アクティブなタブ */
body.post-type-archive-works .tab-item:nth-of-type(1) .tab-button ,
body.page-template-list li.tab-item:nth-of-type(1) .tab-button ,
.tab-button.active ,
.tab-button.current {
	font-family: "MFW-PA1GothicStd-Bold",'A P-OTF A1ゴシック Std B';
	border-top-color: var(--color-primary);
}

/* タブコンテンツエリア */
.tab-contents {
	position: relative;
	min-height: 30px;
	margin-top: 1.5rem;
}

.tab-content {
	/* フェードアニメーション用 */
	opacity: 0;
	transition: opacity 0.3s ease;
}

.tab-content.active {
	opacity: 1;
}

/* 子カテゴリリスト */
.child-category-list {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.child-category-item {margin: 0}

/* 子カテゴリリンク */
.child-category-link {
	display: inline-block;padding: .75rem 1rem .75em 0;
	text-decoration: none;border-radius: 0;position: relative;
	font-size: 1.4rem;line-height: 1;
	transition: all 0.3s ease;
}
.child-category-link::before {
	content: "｜";color: var(--color-text-black);
	font-family: "MFW-PA1GothicStd-Regular",'A P-OTF A1ゴシック Std R';
	position: absolute;top: .77rem;left: -1.75rem;
}
.child-category-item:first-child .child-category-link:before {
	display: none;
}

.child-category-link:hover {
	color: var(--color-primary);
	transform: translateY(-1px);
}

.child-category-link:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}

/* 現在表示中の子カテゴリ */
.child-category-link.current {
	color: var(--color-primary);
	font-family: "MFW-PA1GothicStd-Bold",'A P-OTF A1ゴシック Std B'
}

/* アクセシビリティ: キーボード操作時のフォーカス表示 */
.tab-button:focus-visible,
.child-category-link:focus-visible {
	outline: 2px solid var(--color-primary);
	outline-offset: 2px;
}

/* 空のコンテンツ用スタイル（オプション） */
.tab-content:empty::after {
	content: "このカテゴリには子カテゴリがありません";
	display: block;
	padding: 2rem;
	text-align: center;
	color: #999;
	font-style: italic;
}

section.contact {
	position: relative;padding: 180px 0 100px;
}
section.contact::before {
	content: "CONTACT FORM";font-size: 3.6rem;line-height: 1;letter-spacing: 1.08rem;
	color: var(--color-gray-200);font-family: "MFW-PA1GothicStd-Medium",'A P-OTF A1ゴシック Std M';
	position: absolute;top: 80px;left: 50%;transform: translateX(-50%);
}
section.contact.tel::before {
	content: "可能な限り迅速に折り返します";font-size: 3.2rem;line-height: 1;letter-spacing: 0;
	color: var(--color-text-black);font-family: "MFW-PA1GothicStd-Medium",'A P-OTF A1ゴシック Std M';
	position: absolute;top: 80px;left: 50%;transform: translateX(-50%);
}
section.contact form {
	width: 800px;margin: 0 auto;
}
section.contact form fieldset {
	display: flex;flex-wrap: wrap;gap: 50px;flex-direction: column;
}
section.contact form fieldset:nth-child(3) {margin: 0 0 50px}
section.contact form .input-box {
	display: flex;flex-wrap: wrap;overflow: hidden;
	border-radius: 40px;border: 1px solid var(--color-gray-200);
}
section.contact form .input-box label {
	width: 298px;display: block;background: var(--color-gray-100);box-sizing: border-box;
	font-size: 1.8em;line-height: 1;
	padding: 30px 40px;border-right: 1px solid var(--color-gray-200);
}
section.contact form .input-box label span {display: block;font-size: 1.3rem;margin: 5px 0 0;}
section.contact form .input-box span.wpcf7-form-control-wrap {
	width: 500px;
}
section.contact form .input-box input[type="text"] ,
section.contact form .input-box input[type="email"] ,
section.contact form .input-box input[type="tel"] ,
section.contact form .input-box textarea {
	background: var(--color-background-white);
	width: 100%;border: none;outline: none;box-sizing: border-box;
	padding: 28px 40px;
	font-size: 1.6rem;line-height: 1.4;
}
section.contact form .input-box textarea {
	line-height: 2;min-height: 270px;resize: vertical;
}
section.contact form .input-box textarea::placeholder {color: #8DBACC}
section.contact .privacybox {
	background: var(--color-background-white);
	padding: 15px 50px;margin: 90px 0 50px;
	height: 125px;overflow-y: scroll;box-sizing: border-box;
	border-radius: 40px;
	scrollbar-width: thin;scrollbar-color: var(--color-primary) var(--color-gray-200);
}
section.contact .privacybox strong {
	display: block;margin: 0 0 10px;
	font-size: 1.4em;text-align: center;
}
section.contact .privacybox p {
	font-size: 1.4em;line-height: 1.4;color: var(--color-gray-400);
	margin: 0 0 20px;
}
section.contact form #submit {
	text-align: center;
}
section.contact form #submit input {
	background: var(--color-primary);color: var(--color-background-white);display: block;
	font-size: 1.6rem;line-height: 1;font-family: "MFW-PA1GothicStd-Medium",'A P-OTF A1ゴシック Std M';
	border: none;width: 100%;padding: 32px 0;border-radius: 40px;cursor: pointer;
	transition: opacity .3s;
}
section.contact form #submit input:hover {opacity: .8}
.wpcf7-spinner {display: none}
section.contactbox {padding: 150px 0;}
section.contactbox ul.menu {
	border-radius: 30px;border: 1px solid var(--color-gray-200);background: #FFF;
	overflow: hidden;
}
section.contactbox ul.menu li {
	width: 50%;box-sizing: border-box;
}
section.contactbox ul.menu li:nth-of-type(1) ,
section.contactbox ul.menu li:nth-of-type(2) {border-bottom: solid 1px var(--color-gray-200)}
section.contactbox ul.menu li:nth-of-type(1) ,
section.contactbox ul.menu li:nth-of-type(3) {border-right: solid 1px var(--color-gray-200)}
section.contactbox ul.menu li:nth-of-type(1) span.title {
	margin: 0 0 13px;
}
section.contactbox ul.menu li:nth-of-type(2) {border-bottom: solid 1px var(--color-gray-200)}
section.contactbox ul.menu li a {
	position: relative;box-sizing: border-box;
	text-align: center;font-size: 1.6rem;line-height: 1.4;
	height: 210px;display: flex;justify-content: center;align-items: center;flex-direction: column;
	transition: background .3s;
}
section.contactbox ul.menu li a:hover {
	background: var(--color-gray-200);
}
section.contactbox ul.menu li span {display: block}
section.contactbox ul.menu li span.title {font-size: 2.4rem}
section.contactbox ul.menu li span.tel {font-size: 3.2rem;margin: 5px 0 0}
section.contactbox ul.menu li a::after {
	content: "";width: 20px;height: 21px;box-sizing: border-box;
	background: url(../../img/icon/arrow04.svg) no-repeat center / 100%;
	filter: invert(1);position: absolute;	top: calc(50% - 10px);right: 60px;
	transform: rotate(-90deg);
}
section.contactbox ul.menu li a::before {
	content: "";width: 38px;height: 32px;position: absolute;top: calc(50% - 16px);left: 60px;
	background: url(../../img/icon/call-take.svg) no-repeat center / 100%;
}
section.contactbox ul.menu li:nth-of-type(2) a::before {
	background: url(../../img/icon/call-give.svg) no-repeat center / 100%;
}
section.contactbox ul.menu li:nth-of-type(3) a::before {
	width: 25px;height: 26px;left: 76px;
	background: url(../../img/icon/check.svg) no-repeat center / 100%;
}
section.contactbox ul.menu li:nth-of-type(4) a::before {
	width: 30px;height: 30px;border-radius: 5px;
	background: #06c755 url(../../img/icon/line.svg) no-repeat center / 70%;
}
.thanksbox {
	width: 800px;margin: 0 auto;text-align: center;
	display: flex;flex-direction: column;gap: 50px;
}
.thanksbox p span#user-email-display {
	background: #ECECEC;border-radius: 5px;padding: 5px 10px;
}

main section.privacy {
	padding: 0 0 140px;
}
section.privacy article {
	width: 800px;margin: 70px auto 0;
}

section.recruit h2 {
	font-size: 1.8rem;line-height: 2;
	margin: 0 0 42px;
}
section.recruit p {
	margin: 0 0 2em;
}
section.recruit p:last-child {margin: 0}
section.recruit .wp-block-columns {
	display: flex;flex-wrap: wrap;padding: 100px 0;
	border-top: solid 1px #ececec;
}
section.recruit .wp-block-columns:first-of-type {padding: 0 0 100px}
section.recruit .wp-block-columns:nth-of-type(1) {border-top: none}

section.recruit .btn2 {
	text-align: left;margin: 0 0 50px;
}
section.recruit .btn2 a {
	display: inline-block;background: var(--color-background-white);
	color: var(--color-text-black);font-size: 1.6rem;line-height: 1;
	padding: 23px 40px;border-radius: 30px;transition: opacity .3s;
	border-radius: 38px;
	box-shadow: 0 0 15px 0 rgba(0, 0, 0, 0.10);
}
section.recruit .btn2 a:hover {opacity: .8}
section.recruit .btn2 a span {
	display: inline-block;padding: 0 50px 0 0;position: relative;
}
section.recruit .btn2 a span::after {
	content: "";width: 16px;height: 16px;position: absolute;top: -100%;bottom: -100%;right: 0;
	background: url(../../img/icon/arrow04.svg) no-repeat center / 100%;margin: auto 0;pointer-events: none;
	border: solid 2px var(--color-text-black);border-radius: 50%;box-sizing: border-box;
	filter: invert(1);transform: rotate(-90deg);
}

/* テーブル */
.entry_main figure.wp-block-table {margin: 0 0 50px;border: solid 1px #ececec;border-radius: 10px;overflow: hidden;}
.entry_main table {
	border: none;width: 100%;line-height: 1.4;margin: 0 0 60px;
	font-size: 1.5em;border-collapse: collapse;vertical-align: middle;
	border-right: solid 1px #ececec;border-top: solid 1px #ececec;
}
.entry_main table td ,
.entry_main table th {
	border-bottom: solid 1px #ececec;border-left: solid 1px #ececec;
	padding: 15px 20px 14px;
}
.entry_main table td {
	padding: 20px 20px 19px;
}
.entry_main figure.wp-block-table table {margin: 0}
.entry_main figure.wp-block-table table th {
	background: #f7f7f7;
	font-family: "MFW-PA1GothicStd-Medium";font-weight: 500;text-align: left;
}

body.page-id-58 .flexbox .img ,
body.page-id-1184 .flexbox .img {
	width: 826px;left: -200px;
	background: url(../../img/web/web01@2x.png) no-repeat center / 826px 609px;
}
body.page-id-58 section:nth-of-type(5) .flexbox .img {
	width: 830px;height: 544px;left: -250px;
	background: url(../../img/web/flow01.svg) no-repeat center / 830px 544px;
}
body.page-id-58 section:nth-of-type(6) .flexbox .img {
	width: 830px;height: 544px;left: auto;right: -110px;top: 80%;
	background: url(../../img/web/price.svg) no-repeat center right / 651px 429px;
}
body.page-id-58 section:nth-of-type(6) .table {width: 1060px}
body.page-id-58 section:nth-of-type(6) .more {margin: 50px 0 0;}

/* 定義リスト */
.entry_main dl {
	display: flex;flex-wrap: wrap;width: 730px;margin: 0 auto;
	font-size: 1.6em;line-height: 1.3;letter-spacing: 0;
}
.entry_main dl dt {
	width: 250px;margin: 0 0 26px;
}
.entry_main dl dt a:link ,
.entry_main dl dt a:visited {color: #111}
.entry_main dl dd {
	width: 480px;margin: 0 0 26px;
}
.entry_main dl dd a:link ,
.entry_main dl dd a:visited {
	color: #737373;margin: 0 0 0 1em;position: relative;
}
.entry_main dl dd a:nth-of-type(1):link ,
.entry_main dl dd a:nth-of-type(1):visited {margin: 0}
.entry_main dl dd a::before {
	content: '-';position: absolute;top: -.2em;left: -.75em;pointer-events: none;
}
.entry_main dl dd a:nth-of-type(1)::before {display: none}

section.areaentry h3 {font-size: 1.8rem;margin: 30px 0 3px;}
section.areaentry ul.wp-block-list {display: flex;flex-wrap: wrap;gap: .3rem 1.8rem;}
section.areaentry ul.wp-block-list li {font-size: 1.6rem;}

/* リスト */
.entry_main ol ,
.entry_main ul {list-style: none;margin: 0 0 50px;}
.entry_main ol ol ,
.entry_main ul ul {margin: 20px 0 25px;}
.entry_main li {
	font-size: 1.5rem;line-height: 1.6;
	position: relative;padding: 0 0 0 1.2em;margin: 0 0 15px;
}
.entry_main ul li:before {
	content: "";width: 3px;height: 3px;border-radius: 50%;background: #111;
	position: absolute;left: 0;top: .6em;
}
.entry_main ol {counter-reset: li2;}
.entry_main ol li:before{
	text-align: center;font-weight: 500;line-height: 1;letter-spacing: 0;
	font-size: 1rem;padding: .2em .1em 0;
	color: #fff;background: #000;border-radius: 50%;
	position: absolute;top: .4em;left: 0;width: 1.2em;height: 1.2em;
	counter-increment: li2;content: counter(li2);
}

.entry_main a:link ,
.entry_main a:visited {
	color: #ED324C;text-decoration: underline;
}
