@charset "utf-8";

/* .c-
 * ============================================================================== */
/*====== .c-box-1024(960px以下の指定がcommonにないため追加) =====*/
@media screen and (min-width: 601px) {
	.c-box-1024 {
		width: 96%;
		margin-right: auto; margin-left: auto;
		padding-right: 0; padding-left: 0;
	}
}

@media screen and (max-width: 600px) {
	.c-box-1024 {
		width: 90%;
		margin-right: auto; margin-left: auto;
	}
}


/*====== 引継ぎCSS =====*/
main ul,
main ol {
    margin: 1em 0;
}

main h1,
main h2, 
main h3,
main h4,
main h5,
main h6 {
    line-height: inherit;
}

main h2 {
    margin: 0.83em 0;
}

main h3 {
    font-size: 1.17em;
    margin: 1em 0;
}

main p {
    margin: 1em 0;
}

.l-main * {
    box-sizing: content-box;
	letter-spacing: -0.01em;
}


/*====== .c-ttl =====*/
.c-ttl-underline-center {
	text-align: center;
	font-size: 3rem;
	line-height: 1.5;
	position: relative;
	background: none;
	padding: 0;
	margin-top: 0;
	margin-bottom: 40px;
	color: #00A580;
}

.c-ttl-underline-center-sub {
	display: block;
	font-size: 2rem;
	margin-bottom: 10px;
}

.c-ttl-consulting-sub {
	color: #00A580;
	font-size: 2rem;
	line-height: 1.5;
}

@media screen and (min-width: 960px) {
	.c-ttl-underline-center {
		letter-spacing: 3.2px;
	}
}

@media screen and (max-width: 600px) {
	.c-ttl-underline-center {
		font-size: 2.2rem;
	}
}


/*====== .c-bt =====*/
.c-btn-rounded-yellow {
	background: #F79611;
	border: 1px solid #F79611;
	color: #fff;
	border-radius: calc(1px / 0);
	display: flex;
	justify-content: center;
	align-items: center;
	width: 240px;
	height: 50px;
	font-size: 1.6rem;
	transition: opacity 0.5s;
}

.c-btn-rounded-yellow:hover {
	background: #fff;
	color: #F79611;
	opacity: 1;
}

.c-btn-rounded-yellow img {
	margin-left: 1em;
	filter: invert(99%) sepia(85%) saturate(0%) hue-rotate(182deg) brightness(109%) contrast(100%);
}

.c-btn-rounded-yellow:hover img  { filter: invert(57%) sepia(88%) saturate(992%) hue-rotate(354deg) brightness(100%) contrast(95%);}

.c-btn-rounded-coral {
	background: #FA5462;
	border: 1px solid #FA5462;
	color: #fff;
	border-radius: calc(1px / 0);
	display: flex;
	justify-content: center;
	align-items: center;
	width: 240px;
	height: 50px;
	font-size: 1.6rem;
	transition: opacity 0.5s;
}

.c-btn-rounded-coral:hover {
	background: #fff;
	color: #FA5462;
	opacity: 1;
}

.c-btn-rounded-coral img {
	margin-left: 1em;
	filter: invert(99%) sepia(85%) saturate(0%) hue-rotate(182deg) brightness(109%) contrast(100%);
}

.c-btn-rounded-coral:hover img  { filter: invert(43%) sepia(24%) saturate(3316%) hue-rotate(322deg) brightness(104%) contrast(96%);}

.c-btn-rounded-green {
	background: #00A580;
	border: 1px solid #00A580;
	color: #fff;
	border-radius: calc(1px / 0);
	display: flex;
	justify-content: center;
	align-items: center;
	width: 200px;
	height: 33px;
	font-size: 1.6rem;
	transition: opacity 0.5s;
}

.c-btn-rounded-green:hover {
	background: #fff;
	color: #00A580;
	opacity: 1;
}

.c-btn-rounded-green img {
	margin-left: 1em;
	filter: invert(99%) sepia(85%) saturate(0%) hue-rotate(182deg) brightness(109%) contrast(100%);
}

.c-btn-rounded-green:hover img  { filter: invert(36%) sepia(94%) saturate(2156%) hue-rotate(145deg) brightness(97%) contrast(101%);}

.c-btn-rounded-white {
	background: #fff;
	color: #4A43CB;
	border-radius: calc(1px / 0);
	display: flex;
	justify-content: center;
	align-items: center;
	width: 380px;
	height: 70px;
	font-size: 2rem;
	transition: opacity 0.5s;
}

.c-btn-rounded-white:hover {
	opacity: 0.7;
	color: #4A43CB;
}



/* .u-
 * ============================================================================== */
/*====== .u-mb =====*/
.u-mb100 { margin-bottom: 100px;}


/*====== .u-marker =====*/
.u-marker {
	background: linear-gradient(transparent 50%, #F8FF97 50%);
}


/*====== .u-font-weight =====*/
.u-fw-bold {
	font-weight: bold;
}


/*====== .u-ta-center =====*/
.u-ta-center {
	text-align: center;
}


/*====== .u-xx-non =====*/
@media screen and (min-width:960px) {
	.u-pc-non { display: none;}
}

@media screen and (min-width:601px) and (max-width:959px) {
	.u-tb-non { display: none;}
}

@media screen and (max-width: 600px) {
	.u-sp-non { display: none;}
}


/* .p-
 * ============================================================================== */
/*====== .p-mv =====*/
.p-mv {
	background: #E8F9F4;
	display: flex;
	flex-direction: column;
	align-items: center;
	align-self: center;
	margin-bottom: 43px;
}

.p-mv-inner {
	display: flex;
	align-items: center;
	gap: 40px;
	align-self: stretch;
}

.p-mv-content {
	display: flex;
	flex-direction: column;
	align-self: center;
}

.p-mv-ttl {
	font-weight: bold;
	color: #00A580;
}

.p-mv-ttl .p-mv-ttl-main {
	font-size: 4rem;
	line-height: 1.5;
}

.p-mv-ttl .p-mv-ttl-sub {
	font-size: 3.0rem;
}

.p-mv-text {
	font-size: 1.6rem;
	font-style: normal;
	font-weight: 400;
	line-height: 1.66;
	font-weight: bold;
}

.p-mv-links {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	gap: 10px;
	flex-shrink: 0;
	align-self: stretch;
}

@media screen and (min-width: 601px) {
	.p-mv-content {
		padding-top: 30px;
		padding-bottom: 30px;
		flex: 1;
	}

    .p-mv-img {
        width: calc(454 / 1024 * 100%);
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
    }
}

@media screen and (max-width: 600px) {
	.p-mv-inner {
		flex-direction: column;
		gap: 20px;
		padding-top: 40px;
		padding-bottom: 190px;
		position: relative;
	}

	.p-mv-content {
		width: auto;
	}

	.p-mv-ttl .p-mv-ttl-main {
		font-size: 2.8rem;
	}

	.p-mv-ttl .p-mv-ttl-sub {
		font-size: 2rem;
	}

	.p-mv-text {
		margin-top: 8px;
		margin-bottom: 0;
	}

	.p-mv-links {
		flex-direction: column;
		height: auto;
		gap: 20px;
		margin-top: 20px;
		position: absolute;
		bottom: 40px;
		width: 100%;
	}

	.p-mv-links a { width: 100%;}

	.p-mv-img {
		padding-right: 15px;
	}
}


/*====== .p-bnr =====*/
.p-bnr {
	text-align: center;
	margin-bottom: 43px;
	max-width: 1024px;
	margin-right: auto;
	margin-left: auto;
}

.p-bnr a:hover { opacity: 0.7;}

@media screen and (max-width: 600px) {
	.p-bnr {
		width: 90%;
		margin-right: auto;
		margin-left: auto;
	}
}


/*====== .p-news =====*/
.p-news {
	border-radius: 8px;
	border: 4px solid #DAEDE7;
	padding: 12px 0 24px;
	font-size: 1.5rem;
	line-height: 1.5;
	margin-bottom: 65px;
}

.p-news-ttl {
	font-size: 2.4rem;
	margin-top: 0;
	margin-bottom: 0;
	padding-top: 0;
	padding-bottom: 8px;
	text-align: center;
	background: none;
	position: relative;
}

.p-news-ttl::after {
	content: '';
	display: block;
	max-width: 920px;
	width: calc(100% - 52px - 26px);
	border-top: 1px dashed #00A580;
	position: absolute;
	bottom: 0;
	left: 52px;
}

.p-news-box {
	padding-top: 1px;
	margin-left: 52px;
	margin-right: 10px;
	overflow-y: scroll;
}

.p-news-list {
	margin-top: 0;
	margin-bottom: 0;
	padding-top: 6px;
	padding-left: 0;
	position: relative;
	height: 100px;
	max-width: 920px;
	width: 100%;
}

.p-news-item {
	display: flex;
	justify-content: flex-start; align-items: flex-start;
	gap: 16px;
	padding-top: 6px;
	padding-bottom: 6px;
}

[class^="p-news-category-"] {
	display: flex;
	padding-top: 2px; padding-right: 16px; padding-left: 16px;
	justify-content: center;
	align-items: center;
	align-self: stretch;
	border-radius: 4px;
	width: 88px;
	height: 25px;
	line-height: 1.1;
}

.p-news-category-blue  { border: 1px solid #0066B5; color: #0066B5;}
.p-news-category-green { border: 1px solid #00A580; color: #00A580;}

.p-news-date {
	font-size: 1.4rem;
	padding-top: 5px;
	width: 9em;
	font-weight: bold;
}

.p-news-content {
	padding-top: 5px;
	flex: 1;
}

.p-news-content a {
	color: inherit !important;
	text-decoration: none !important;
}

.p-news-content a:hover {
	text-decoration: underline !important;
}

@media screen and (min-width:601px) and (max-width:959px) {
	.p-news-box {
		width: 92%;
		margin-left: auto;
	}

	.p-news-box::before {
		width: 96%;
	}

	.p-news-list {
		width: 95%;
		padding-left: 0;
	}
}

@media screen and (max-width: 600px) {
	.p-news {
		margin-bottom: 20px;
	}

	.p-news-ttl::after {
		left: 20px;
		width: calc(100% - 40px - 16px);
	}

	.p-news-box {
		margin-left: 20px;
		margin-right: 20px;
		width: calc(100% - 40px);
	}

	.p-news-list {
		width: 95%;
		height: 250px;
		padding-left: 0;
	}

	.p-news-item {
		flex-wrap: wrap;
		gap: 6px 16px;
	}

	.p-news-content {
		flex: none;
		width: 100%;
	}
}



/*====== .p-trouble =====*/
.p-trouble .c-ttl-underline-center {
	color: #333;
}

.p-trouble-list {
	font-size: 2rem;
	line-height: 1.5;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	margin-right: auto; margin-left: auto;
}

.p-trouble-list dt {
	padding-left: 40px;
	position: relative;
	font-size: 2.4rem;
	display: inline-block;
	padding-bottom: 3px;
	font-weight: bold;
	margin-bottom: 10px;
}

.p-trouble-list dt::before {
	content: '';
	width: 30px;
	height: 30px;
	background: url(/pickup/brms/images/brms-icon-check_re.png) no-repeat;
	background-size: cover;
	position: absolute;
	top: 2px;
	left: 0;
}

.p-trouble-list dt::after {
	content: '';
	width: calc(100% - 40px);
	height: 5px;
	background: #F79611;
	position: absolute;
	left: 40px;
	bottom: 0;
}

.p-trouble-list dd + dt {
	margin-top: 50px;
}

.p-trouble-list dd {
	padding-left: 40px;
}


@media screen and (min-width: 960px) {
}

@media screen and (max-width: 600px) {
	.p-trouble .c-box-1024 {
		background-position: center top;
		background-size: auto 120px;
		padding-top: 60px;
	}

	.p-trouble-list dt {
		font-size: 2rem;
		padding-left: 30px;
	}

	.p-trouble-list dt::after {
		width: calc(100% - 30px);
		left: 30px;
	}

	.p-trouble-list dt::before {
		width: 20px;
		height: 20px;
	}

	.p-trouble-item::before {
		width: 21px;
		height: 17px;
		top: 4px;
	}
}


/*====== .p-solution =====*/
.p-solution {
	background: rgba(218, 237, 231, 0.50);
	padding-top: 40px;
	padding-bottom: 54px;
	font-size: 1.6rem;
	line-height: 1.5;
}

.p-solution-ttl {
	text-align: center;
	font-size: 3rem;
	background: none;
}

.p-solution-ttl-sub {
	font-size: 2.6rem;
	color: #00A580;
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.p-solution-ttl-sub::after {
	content: '';
	width: 600px;
	height: 8px;
	background: #00A580;
	margin-top: 10px;
}

.p-solution-about-ttl {
	color: #00A580;
	font-size: 2.4rem;
}

.p-solution-system {
	margin-bottom: 76px;
}

.p-solution-system-card-wrap {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
	margin-top: 52px;
}

.p-solution-system-card {
	background: #fff;
	display: flex;
	padding: 40px 24px 20px;
	flex-direction: column;
	align-items: center;
	gap: 14px;
	border-radius: 20px;
	font-weight: bold;
}

.p-solution-advantage {
	margin-bottom: 68px;
}

.p-solution-advantage p {
	margin-bottom: 10px;
}

.p-solution-advantage-block {
	background: #fff;
	border: 3px solid #DAEDE7;
	display: flex;
	padding: 25px;
	align-items: center;
	gap: 10px;
}

.p-solution-advantage-txt {
	flex: 1;
}

.p-solution-advantage-note {
	font-size: 1.0rem;
}

.p-solution-advantage-btn {
	display: flex;
	justify-content: flex-end;
}

.p-solution-plan {
	margin-bottom: 24px;
}

@media screen and (max-width: 600px) {
	.p-solution {
		padding-top: 40px;
		padding-bottom: 40px;
	}

	.p-solution-ttl {
		font-size: 2.2rem;
	}

	.p-solution-ttl-sub {
		font-size: 2rem;
	}

	.p-solution-ttl-sub::after {
		width: 100%;
		height: 5px;
	}

	.p-solution-about-ttl {
		font-size: 1.8rem;
	}

	.p-solution-system-card-wrap {
		grid-template-columns: repeat(1, 1fr);
	}

	.p-solution-system-card {
		padding-top: 30px; padding-bottom: 10px;
	}

	.p-solution-advantage-block {
		flex-direction: column;
		padding-top: 10px;
	}

	.p-solution-advantage-btn {
		justify-content: center;
	}
}


/*====== .p-point =====*/
.p-point-summary {
	text-align: center;
	margin-bottom: 40px;
	font-size: 1.6rem;
	line-height: 1.5;
}

.p-point-wrap {
	display: grid;
	grid-template-columns:repeat(3, minmax(0,1fr));
	gap: 20px;
	grid-template-rows: auto auto 1fr auto;
}

.p-point-block {
	display:grid;
	grid-template-rows: subgrid;
	grid-row: span 4;
	gap: 24px;
	background: #edf6f3;
	border-radius: 8px;
	padding: 24px;
	font-size: 1.6rem;
	line-height: 1.5;
}

.p-point-block:hover {
	opacity: 0.8;
	color: inherit;
}

.p-point-block:hover .c-btn-rounded-green {
    background: #fff;
    color: #00A580;
	opacity: 1;
}

.p-point-block:hover .c-btn-rounded-green img {
	filter: invert(36%) sepia(94%) saturate(2156%) hue-rotate(145deg) brightness(97%) contrast(101%);
}

.p-point-img {
	grid-row:1;
	display:flex;
	align-items:center;
	justify-content:center;
}

.p-point-img img {
	display:block;
	max-width:100%;
	height:auto;
}

.p-point-ttl{
	grid-row:2;
	text-align: center;
}

.p-point-ttl-small {
	font-size: 1.4rem;
}

.p-point-text {
	grid-row:3;
}

.p-point-text p {
	margin-top: 0;
}

.p-point-btn {
	margin:auto;
	grid-row:4;
	align-self:end;
}

@media screen and (min-width: 601px) and (max-width: 959px) {
	.p-point-wrap {
		gap: 10px;
	}

	.p-point-block {
		padding-right: 10px;
		padding-left: 10px;
	}

	.p-point-img {
		width: 100%;
	}

	.p-point-btn .c-btn-rounded-green {
		width: calc(100% + 20px);
		transform: translateX(-10px);
	}
}

@media screen and (max-width: 600px) {
	.p-point-wrap {
		grid-template-columns: repeat(1, 1fr);
	}

	.p-point-list {
		margin-bottom: 0;
	}
}


/*====== .p-step =====*/
.p-step-block {
	display: flex;
	padding: 10px 0;	
	justify-content: space-between;
	align-items: stretch;
	gap: 50px;
	font-size: 1.6rem;
	line-height: 1.5;
}

.p-step-stage {
	min-height: 122px;
	width: 230px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: relative;
	color: #00A580;
	font-size: 2rem;
	line-height: 1.5;
	font-weight: bold;
}

.p-step-stage::before,
.p-step-stage::after {
	content: '';
	display: block;
	border-bottom: 37px solid #fff;
	position: absolute;
	bottom: 0;
}

.p-step-stage::before {
	border-right: 114px solid transparent;
	left: 0;
}

.p-step-stage::after {
	border-left: 114px solid transparent;
	right: 0;
}

.p-step-block:nth-of-type(1) .p-step-stage { background: #f2faf9;}
.p-step-block:nth-of-type(2) .p-step-stage { background: #e6f6f3;}
.p-step-block:nth-of-type(3) .p-step-stage { background: #d9f2ec;}
.p-step-block:nth-of-type(4) .p-step-stage { background: #ccede6;}
.p-step-block:nth-of-type(5) .p-step-stage { background: #bfe8df;}

.p-step-number {
	font-size: 3.8rem;
}

.p-step-content {
	flex: 1;
	position: relative;
	
}

.p-step-ttl {
	font-size: 2.4rem;
	color: #00A580;
	font-weight: bold;
	margin-top: 0;
	margin-bottom: 12px;
}

.p-step-term {
	position: absolute;
	top: 0;
	right: 0;
	background: #80A6D3;
	text-align: center;
	color: #fff;
	padding: 6px 15px 4px;
	margin-top: 0;
	margin-bottom: 0;
}

@media screen and (max-width: 959px) {
	.p-step-ttl {
		margin-bottom: 8px;
	}

	.p-step-term {
		position: relative;
	}
}

@media screen and (max-width: 600px) {
	.p-step-block {
		align-items: flex-start;
		gap: 20px;
	}

	.p-step-stage {
		width: 100px;
		min-height: 80px;
		font-size: 1.4rem;
	}

	.p-step-stage::before,
	.p-step-stage::after {
		border-bottom: 16px solid #fff;
	}

	.p-step-stage::before {
		border-right: 50px solid transparent;
	}

	.p-step-stage::after {
		border-left: 50px solid transparent;
	}

	.p-step-number {
		font-size: 3.2rem;
		line-height: 1.2;
	}

	.p-step-ttl {
		font-size: 1.8rem;
	}

	.p-step-term {
		font-size: 1.5rem;
		padding-top: 4px; padding-bottom: 1px;
		text-align: left;
	}
}


/*====== .p-contact =====*/
.p-contact {
	background: #F4F5F9;
	text-align: center;
	padding-top: 80px;
	padding-bottom: 80px;
	margin-bottom: 80px;
}

.p-contact-ttl {
	background: none;
	text-align: center;
	font-size: 3.2rem;
	padding: 0;
	margin: 0;
}

.p-contact-lead {
	margin-top: 36px;
	margin-bottom: 36px;
	font-size: 1.6rem;
}

.p-contact-buttons {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-right: auto;
	margin-left: auto;
	gap: 9.3%;
}

.p-contact-buttons .c-btn-rounded-yellow,
.p-contact-buttons .c-btn-rounded-coral {
	width: 380px;
    height: 70px;
    font-size: 2rem;
}

@media screen and (max-width: 600px) {
	.p-contact {
		padding-top: 40px;
		padding-bottom: 40px;
	}

	.p-contact-ttl {
		font-size: 2rem;
		margin-top: 0;
		margin-bottom: 0;
	}

	.p-contact-lead {
		margin-top: 25px;
		margin-bottom: 25px;
	}

	.p-contact-buttons {
		flex-direction: column;
		gap: 30px;
	}

	.p-contact-buttons a { width: 98%;}
}


/*====== .p-related =====*/
.p-related { margin-bottom: 140px;}

.p-related-card-wrap {
	display: grid;
	grid-template-columns:repeat(3, minmax(0,1fr));
	gap: 20px;
	grid-template-rows: auto auto 1fr auto;
}

.p-related-card {
	display:grid;
	grid-template-rows: subgrid;
	grid-row: span 4;
	font-size: 1.6rem;
	line-height: 1.5;
	background: #F4F5F9;
	padding: 24px;
}

.p-related-card:hover {
	opacity: 0.8;
	color: inherit;
}

.p-related-card:hover .c-btn-rounded-green {
    background: #fff;
    color: #00A580;
	opacity: 1;
}

.p-related-card:hover .c-btn-rounded-green img {
	filter: invert(36%) sepia(94%) saturate(2156%) hue-rotate(145deg) brightness(97%) contrast(101%);
}

.p-related-card-img {
	grid-row:1;
	display:flex;
	align-items:center;
	justify-content:center;
}

.p-related-card-img img {
	display:block;
	max-width:100%;
	height:auto;
}

.p-related-card-ttl {
	grid-row:2;
	text-align: center;
	margin-top: 0;
	margin-bottom: 0;
}

.p-related-card-txt {
	grid-row:3;
	margin-top: 0;
	margin-bottom: 0;
}

.p-related-card-btn {
	margin:auto;
	grid-row:4;
	align-self:end;
}

@media screen and (min-width: 601px) and (max-width: 959px) {
	.p-related-card-wrap {
		gap: 10px;
	}

	.p-related-card-block {
		padding-right: 10px;
		padding-left: 10px;
	}

	.p-related-card-img {
		width: 100%;
	}

	.p-related-card-btn .c-btn-rounded-green {
		width: calc(100% + 60px);
		transform: translateX(-30px);
	}
}

@media screen and (max-width: 600px) {
	.p-related-card-wrap {
		grid-template-columns: repeat(1, 1fr);
	}
}


/*====== .p-side-nav =====*/
.p-side-nav {
	display: flex;
	justify-content: space-between;
	gap: 14px;
	margin: 0;
	padding: 0;
	border: 0;
	position: fixed;
	right: 0;
	bottom: 0;
	z-index: 99;
}

.p-side-nav a {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 10px;
	border-radius: 8px;
	width: 130px;
	height: 70px;
	margin: 0;
	padding: 0;
	border: none;
	background-repeat: no-repeat;
	font-size: 1.5rem;
	color: #fff;
	text-align: center;
	cursor: pointer;
	line-height: 1;
}

.p-side-nav a:nth-child(1) {
	background-color: #F79611;
	border: 1px solid #F79611;
}

.p-side-nav a:nth-child(2) {
	background-color: #FA5462;
	border: 1px solid #FA5462;
}

.p-side-nav a img {
	filter: invert(99%) sepia(85%) saturate(0%) hue-rotate(182deg) brightness(109%) contrast(100%);
}

.p-side-nav a:nth-child(1):hover {
	background: #fff;
	color: #F79611;
	opacity: 1;
}

.p-side-nav a:nth-child(2):hover {
	background: #fff;
	color: #FA5462;
	opacity: 1;
}

.p-side-nav a:nth-child(1):hover img { filter: invert(57%) sepia(88%) saturate(992%) hue-rotate(354deg) brightness(100%) contrast(95%);}
.p-side-nav a:nth-child(2):hover img { filter: invert(43%) sepia(24%) saturate(3316%) hue-rotate(322deg) brightness(104%) contrast(96%);}

@media only screen and (max-width: 600px) {
	.p-side-nav {
		width: 100vw;
		gap: 2vw;
	}

	.p-side-nav a {
		width: 54vw;
		border-radius: 10px 10px 0 0;
		height: 6rem;
		line-height: 6rem;
		margin: 0;
		padding: 0;
		flex-direction: row;
	}

}



/* .js-
 * ============================================================================== */
/*====== .js-accordion =====*/
.js-accordion:hover {
	cursor: pointer;
	opacity: 0.8;
}



