@charset "utf-8";

@media screen and (max-width: 768px) {
	.header_comment {
		color: #fff;
	}
}

/* -----------------------------------------------------------
    mv
-------------------------------------------------------------- */
.mv-catch {
	position: absolute;
	top: 55%;
	left: 40px;
	z-index: 3;
}

.mv-catch p{
	color: #fff;
	font-style: italic;
	font-weight: 800;
	font-size: 5.3rem;
	line-height: 1.5;
	letter-spacing: .08em;
}
@media screen and (max-width: 768px) {
	.mv-catch {
		top: 64%;
		width: 100%;
		padding: 0 20px;
		left: auto;
	}
	
	.mv-catch p {
		font-size: 2.2rem;
		line-height: 1.8;
		letter-spacing: .05em;
	}

	#niarea-detail .bread-h1-wrap {
		top: 110px;
		justify-content: flex-end;
	}

	#niarea-detail .under-h1 h1 {
		color: var(--gray);
		padding-right: 20px;
	}
}

/* -----------------------------------------------------------
    top-intro
-------------------------------------------------------------- */
@media screen and (max-width: 768px) {
	#niarea-detail .top-intro-area {
		background: var(--cmnbg2);
		padding-top: 45px;
	}
}

/* -----------------------------------------------------------
    feature-slide
-------------------------------------------------------------- */
.feature-slide {
	display: flex;
	margin: 50px 0 0;
}

.feature-slide li {
	height: 300px;
	width: calc(100% / 4);
}

.feature-slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

@media screen and (max-width: 768px) {
	.feature-slide li {
		width: 200px;
		height: 200px;
	}
}

/* -----------------------------------------------------------
    other-section
-------------------------------------------------------------- */
.sec-imported {
	margin: 94px 0 0;
}

.other-section .service-intro {
	padding: 50px 0 0;
}

.other-section .service-intro p {
	font-size: 1.8rem;
	margin: 20px 0 0;
	letter-spacing: .07em;
	line-height: 2.2;
}

.other-section .service-intro p:first-of-type {
	margin: 0;
}

.other-section .areadetail-service-dl2 {
	width: 100%;
}

.other-section .areadetail-service-dl2.w50 {
	width: calc((100% - 25px) / 2);
}

.other-section .areadetail-service-strong {
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	margin: 10px 0 0;
}

.other-section .areadetail-service-strong li {
	background: #e9edfb;
	font-size: 1.9rem;
	font-weight: 600;
	flex-grow: 1;
	line-height: 1.5;
	padding: 22px 15px 22px 45px;
	position: relative;
	width: calc((100% - 20px) / 2);
}

.other-section .areadetail-service-strong li::before {
	content: "";
	background: url("../img/cmn-check-icon.svg")center/contain no-repeat;
	width: 23px;
	height: 23px;
	left: 15px;
	position: absolute;
	top: 53%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.other-section .areadetail-service-strongtxt {
	margin: 25px 0 0;
}

.other-section .areadetail-service-strongtxt p {
	margin: 20px 0 0;
}

.other-section .areadetail-service-strongtxt p:first-of-type {
	margin: 0;
}

.cmn-service #area .cost-area .cost-model dl {
	max-width: unset;
}

@media screen and (max-width: 768px) {
	.sec-imported {
		margin: 50px 0 0;
	}

	.other-section .service-intro {
		padding: 30px 20px 0;
	}

	.other-section .service-intro p {
		font-size: 1.7rem;
		margin: 20px 0 0;
		letter-spacing: .05em;
		line-height: 2;
	}

	.other-section .areadetail-service-dl2.w50 {
		width: 100%;
	}

	#area .other-head-area .other-head-ttl {
		font-size: 2.4rem;
		letter-spacing: .09em;
	}

	#area .sec-electrical .other-head-area .other-head-ttl {
		font-size: 2.2rem;
	}

	.other-section .areadetail-service-strong li {
		font-size: 1.6rem;
		width: 100%;
		padding: 12px 15px 12px 40px;
		border-width: 0 0 15px;
	}

	.other-section .areadetail-service-strong li::before {
		width: 18px;
		height: 18px;
	}

	#area .cmn-work-gallery {
		padding: 0;
		margin: 10px auto 0;
	}
}

/* -----------------------------------------------------------
    imported-area
-------------------------------------------------------------- */
.imported-area {
	background: var(--cmnbg2);
	padding: 90px 0 100px;
}

.imported-area .imported-intro-description {
	color: #fff;
	font-size: 2.3rem;
	text-align: center;
}

.imported-area .imported-intro-description a {
	text-decoration: underline;
}

.imported-area .imported-intro-anchor {
	display: flex;
	gap: 15px;
	flex-wrap: wrap;
	margin: 30px auto 80px;
	justify-content: center;
}

.imported-area .imported-intro-anchor a {
	display: flex;
	padding: 10px 35px 10px 15px;
	position: relative;
	border: 1px solid var(--gray);
	color: #fff;
	font-size: 1.8rem;
}

.imported-area .imported-intro-anchor a::before {
	content: "\f078";
	color: #fff;
	font: 900 1.1rem/1 var(--webicon);
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	transition: .05s;
	right: 13px;
}

.imported-area .imported-case {
	margin: 70px 0 0;
}

.imported-area .imported-inner {
	padding: 0 40px;
}

.imported-area .imported-inner .imported-case:first-of-type {
	margin: 0;
}

.imported-area .imported-case__header {
	font-size: 3.5rem;
	font-weight: bold;
	color: #fff;
}

.imported-area .imported-case__list {
	gap: 20px;
	display: flex;
	margin: 35px 0 0;
}

.imported-area .imported-case__item {
	width: calc((100% - 40px) / 3);
}

.imported-area .imported-case__link {
	background: #39393f;
	display: block;
	padding: 3.2% 6% 6%;
}

.imported-area .imported-case__info {
	display: flex;
	gap: 20px;
}

.imported-area .imported-case__bawrap {
	align-items: center;
	display: flex;
	justify-content: space-between;
}

[data-areaimported_ba="before"] {
	width: 39%;
	aspect-ratio: 23/16;
	position: relative;
}

[data-areaimported_ba="before"]::before {
	background: url(../img/cmnworks-arrow.svg)center/contain no-repeat;
	content: "";
	right: -24px;
	position: absolute;
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
	width: 17px;
	height: 24px;
}

[data-areaimported_ba="after"] {
	width: 55%;
	aspect-ratio: 34/22;
}

.imported-area .imported-imgwrap {
	width: 100%;
	height: 100%;
	position: relative;
}

.imported-area .imported-img {
	width: 100%;
	height: 100%;
}

.imported-area .imported-case__thumb {
	margin: 18px 0 0;
}

.imported-area .imported-case__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.imported-area .imported-cap {
	font-family: var(--en);
	font-style: italic;
	left: 0;
	top: calc(-1em + 2px);
	position: absolute;
}

[data-areaimported_ba="before"] .imported-cap {
	color: var(--sub4);
	font-size: 1.6rem;
	font-weight: 500;
	position: absolute;
}

[data-areaimported_ba="after"] .imported-cap {
	color: #aec1f8 !important;
	font-size: 2.1rem;
	font-weight: 800;
}

.imported-area .imported-case__element {
	display: flex;
	align-items: center;
	gap: 10px;
}

.imported-area .imported-case__model {
	color: #fff;
	font-size: 2rem;
}

.imported-area .cmnwork-info-service {
	color: #fff;
	font-size: 1.9rem;
	font-weight: 600;
}

.imported-area .imported-case__time, .imported-case__money {
	align-items: center;
	display: flex;
	background: #fff;
	color: var(--main);
	font-weight: 600;
	justify-content: center;
	height: 34px;
}

.imported-area .imported-case__time {
	font-size: 1.8rem;
	padding: 8px 15px 10px;
}

.imported-area .imported-case__money {
	padding: 8px 15px;
}

.imported-area .imported-case__money span {
	font: 700 2.3rem /1 var(--en);
	margin: 0 2px 0 0;
}

.imported-area .imported-case__detail {
	align-items: center;
	flex-wrap: wrap;
	display: flex;
	gap: 10px;
	margin: 20px 0 0;
}

.imported-area .imported-case__option {
	display: flex;
	align-items: center;
	gap: 10px;
}

.imported-area .imported-case__option [class^="works-flag-"] {
	color: #bdc4d9;
	margin: 18px 15px 0 0;
}

.imported-area .imported-case__option [class^="works-flag-"]::before {
	content: "#";
}

.imported-area .imported-case__option li:last-child {
	margin-right: 0;
}

/*1枚の時--------------------*/
.imported-area .single-image [data-areaimported_ba="after"] .imported-cap {
	display: none;
}

.imported-area .single-image [data-areaimported_ba="after"] {
	width: 290px;
	height: 190px;
	overflow: hidden;
	margin: 0 auto;
}

@media screen and (min-width: 769px) and (max-width: 1600px) {
	.imported-area .imported-case__header {
		padding: 0 40px;
	}

	.imported-area .imported-case__list {
		overflow-x: scroll;
		padding: 0 40px;
	}

	.imported-area .imported-inner {
		padding: 0;
	}

	.imported-area .imported-case__item {
		width: 600px;
		flex-shrink: 0;
	}
}

@media screen and (max-width: 768px) {
	.imported-area {
		padding: 50px 0;
	}

	.imported-area .imported-intro-description {
		font-size: 1.7rem;
		letter-spacing: .07em;
		margin: 0 0 30px;
		text-align: left;
	}

	.imported-area .imported-intro-anchor {
		display: none;
	}

	.imported-area .imported-inner {
		padding: 0;
	}

	.imported-area .imported-case__header {
		font-size: 2rem;
		width: 100%;
		padding: 25px 20px 20px;
		border-top: 1px solid #fff;
		display: flex;
		align-items: center;
		gap: 10px;
	}

	.imported-area .imported-case__header span {
		position: relative;
		width: 22px;
		height: 22px;
	}

	.imported-area .imported-case__header span::before {
		content: "";
		position: absolute;
		top: 50%;
		-webkit-transform: translateY(-50%);
		transform: translateY(-50%);
		right: 0;
		background: url(../img/accordion_plus.jpg)center/contain no-repeat;
		width: 100%;
		height: 100%;
	}

	.imported-case__header.default-imported-case.active-imported-case span::before {
		background: url(../img/accordion_minus.jpg)center/contain no-repeat;
	}

	.imported-case__header.active-imported-case span::before {
		background: url(../img/accordion_minus.jpg)center/contain no-repeat;
	}

	.imported-area .imported-case__body {
		display: none;
	}

	.imported-area .imported-case__list {
		overflow-x: scroll;
		/*display: none;*/
		margin: 10px 0 0;
		padding: 0 20px 10px;
	}

	.imported-case__body.default-imported-case.active-imported-case {
		display: flex;
	}

	.imported-area .imported-case__item {
		width: 300px;
		flex-shrink: 0;
	}

	.imported-area .imported-case__link {
		padding: 15px 20px 25px 20px;
	}

	.imported-area .imported-case {
		margin: 0;
		padding: 0 0 10px;
	}

	.imported-area .imported-case .anchor {
		display: none;
	}

	.imported-area .cmnwork-info-service {
		font-size: 1.7rem;
		width: 100%;
	}

	.imported-area .imported-case__model {
		font-size: 1.7rem;
	}

	.imported-area .imported-case__detail {
		gap: 15px 8px;
		margin: 15px 0 0;
	}

	.imported-area .imported-case__time {
		font-size: 1.5rem;
		padding: 6px 10px 8px;
	}

	.imported-area .imported-case__money {
		padding: 6px 10px 8px;
	}

	.imported-area .imported-case__money span {
		font-size: 1.8rem;
	}

	.imported-area .imported-case__option {
		font-size: 1.4rem;
	}

	.imported-area .imported-case__option [class^="works-flag-"] {
		margin: 15px 10px 0 0;
	}

	.imported-area .imported-case__bawrap {
		align-items: flex-start;
		flex-direction: column;
		gap: 30px;
	}

	[data-areaimported_ba="after"] {
		width: 100%;
	}

	[data-areaimported_ba="before"] {
		width: 162px;
		height: 112px;
	}

	.imported-area .single-image [data-areaimported_ba="after"] {
		aspect-ratio: 34/22;
		width: 100%;
	}

	[data-areaimported_ba="before"]::before {
		bottom: -25px;
		left: 50%;
		top: auto;
		-webkit-transform: translateX(-50%) rotate(270deg);
		transform: translateX(-50%) rotate(-270deg);
	}

	[data-areaimported_ba="after"] .imported-cap {
		font-size: 1.6rem;
	}

	[data-areaimported_ba="before"] .imported-cap {
		font-size: 1.4rem;
	}
}

/* -----------------------------------------------------------
    sec-other
-------------------------------------------------------------- */
.sec-other {
	padding: 100px 0;
	background: var(--cmnbg2);
	position: relative;
	overflow: hidden;
}

.sec-other-inner {
	position: relative;
}

.sec-other-mv {
	flex-shrink: 0;
	aspect-ratio: 580/410;
	width: 500px;
}

.sec-other-mv img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.sec-other-ttl {
	color: #fff;
	font-size: 3.3rem;
	font-weight: bold;
	line-height: 1.6;
	letter-spacing: .1em;
}

.sec-other-note {
	align-items: center;
	margin: 50px 0 0;
	display: flex;
	gap: 30px;
}

.sec-other-note p {
	color: var(--gray2);
	letter-spacing: .12em;
	line-height: 2.2;
	margin: 25px 0 0;
}

.sec-other-note p:first-of-type {
	margin: 0;
}

.sec-other-list-wrap {
	background: #4962ac;
	margin: 60px 0 0;
}

.sec-other-list-catch {
	padding: 30px 50px 0;
}

.sec-other-list-catch .catch {
	align-items: center;
	color: #fff;
	display: flex;
	gap: 10px;
	padding: 0 0 0 95px;
	position: relative;
	font-size: 2.3rem;
	font-weight: 600;
	letter-spacing: .05em;
}

.sec-other-list-catch .catch::before {
	content: "";
	position: absolute;
	left: 0;
	bottom: -10px;
	background: url("../img/cmn-staff.png") center/contain no-repeat;
	width: 80px;
	height: 98px;
}

.sec-other-list-catch .note {
	color: #fff;
	margin: 25px 0 0;
	line-height: 2.4;
	letter-spacing: .1em;
}

.sec-other-list {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	padding: 25px 50px 40px;
}

.sec-other-item {
	align-items: center;
	background: #fff;
	display: flex;
	gap: 15px;
	padding: 20px 15px 22px 53px;
	position: relative;
	flex-grow: 1;
	width: calc((100% - 20px) / 3);
	font-size: 1.9rem;
	font-weight: bold;
	line-height: 1.6;
	letter-spacing: .05em;
}

.sec-other-item::before {
	content: "";
	background: url("../img/cmn-check-icon.svg")center/contain no-repeat;
	width: 28px;
	height: 28px;
	left: 15px;
	position: absolute;
	top: 53%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

#area .cmn-other-anchor {
	margin: 70px 0 0;
	padding: 0;
}

@media screen and (min-width: 769px) {
	#area .cmn-other-anchor {
		gap: 40px 20px;
	}

	#area .cmn-other-anchor a {
		width: calc((100% - 60px) / 4);
	}

	#area .cmn-other-anchor figcaption {
		font-size: 1.9rem;
	}

	#area .cmn-other-anchor [data-otheranc="electrical"] figcaption {
		font-size: 1.7rem;
	}

	#area .carfilm-work-table thead th:first-of-type {
		width: 300px;
	}
}

@media screen and (max-width: 768px) {
	.sec-other {
		padding: 50px 0;
	}

	.sec-other::before {
		background: url("../img/bg-grad-flash-l-sp.jpg")right top/100% auto no-repeat;
		width: 100%;
		aspect-ratio: 750/942;
		right: 0;
		left: auto;
		height: auto;
		opacity: .6;
	}

	.sec-other-ttl {
		font-size: 2.2rem;
	}
	
	.sec-other-mv {
		width: 100%;
	}
	
	.sec-other-note .txt {
		margin: 25px 0 0;
	}
	
	.sec-other-note {
		display: block;
		margin: 25px 0 0;
	}

	.sec-other-note p {
		font-size: 1.6rem;
		letter-spacing: .07em;
		margin: 20px 0 0;
	}

	.sec-other-list-wrap {
		margin: 40px 0 0;
	}

	.sec-other-list-catch {
		padding: 20px 20px 0;
	}

	.sec-other-list-catch .catch {
		padding: 0 0 0 85px;
	}

	.sec-other-list-catch .catch p {
		font-size: 1.8rem;
		line-height: 1.5;
	}

	.sec-other-list-catch .catch::before {
		width: 70px;
		height: 88px;
		bottom: 0;
	}

	.sec-other-list-catch .note {
		line-height: 2.4;
		letter-spacing: .12em;
		margin: 20px 0 0;
	}

	.sec-other-list {
		padding: 20px;
	}

	.sec-other-item {
		width: 100%;
		font-size: 1.6rem;
		padding: 12px 15px 12px 44px;
	}

	.sec-other-item::before {
		width: 21px;
		height: 21px;
	}

	#area .cmn-other-anchor {
		margin: 40px 0 0;
	}
}

/* -----------------------------------------------------------
    niwork-relation-area
-------------------------------------------------------------- */
#area .niwork-relation-area {
	margin: 0;
}

/* -----------------------------------------------------------
    faq-area
-------------------------------------------------------------- */
.cmn-service #area .faq-area {
	padding: 100px 0;
}

@media screen and (max-width: 768px) {
	.cmn-service #area .faq-area {
		padding: 50px 0;
	}
}

/* -----------------------------------------------------------
    以下  エリアCMS詳細   当道府県＆市区町村＆駅  共通
-------------------------------------------------------------- */
/* -----------------------------------------------------------
    niareadetail-feature
-------------------------------------------------------------- */
.niareadetail-feature {
	background: var(--cmnbg2);
	padding: 25vw 0 120px;
	position: relative;
	overflow: hidden;
}

@media screen and (min-width: 769px) and (max-width: 1600px) {
	.niareadetail-feature {
		padding-top: 400px;
	}
}

.niareadetail-feature .inner {
	position: relative;
}

.niareadetail-feature-ttl {
	color: #fff;
	font-size: 3.7rem;
	font-weight: bold;
	line-height: 1.6;
	letter-spacing: .1em;
}

.niareadetail-feature__contents {
	margin: 30px 0 0;
}

.niareadetail-feature__contents p {
	color: var(--gray2);
	font-size: 1.9rem;
	letter-spacing: .12em;
	line-height: 2.5;
}

@media screen and (max-width: 768px) {
	.niareadetail-feature {
		padding: 50px 0 0;
	}

	.niareadetail-feature.bg-flash::before {
		display: none;
	}

	.niareadetail-feature-ttl {
		font-size: 2.4rem;
	}

	.niareadetail-feature .niareadetail-feature__contents {
		margin: 20px 0 0;
	}

	.niareadetail-feature__contents p {
		font-size: 1.6rem;
		margin: 0 !important;
		letter-spacing: .07em;
		line-height: 2.4;
	}
}

/* -----------------------------------------------------------
    niareadetail-free
-------------------------------------------------------------- */
.niareadetail-free {
	background: #fff;
	padding: 50px 0 100px;
}

@media screen and (max-width: 768px) {
	.niareadetail-free {
		padding: 20px 0 50px;
	}
}

/* -------------------------------------------------------------
    フルリッチ
-------------------------------------------------------------- */
.niarea-fullrich h1, .niarea-fullrich h2, .niarea-fullrich h3, .niarea-fullrich h4 {
	font-weight: bold;
	line-height: 1.4;
}

.niarea-fullrich h1 {
	font-size: 2.7rem;
	font-weight: bold;
	border-bottom: 6px solid var(--main);
	padding: 0 0 15px;
	margin: 50px 0 30px;
}

.niarea-fullrich h2 {
	background: var(--main);
	color: #fff;
	font-size: 2.6rem;
	margin: 50px 0 30px;
	padding: 10px 20px 12px;
	position: relative;
	letter-spacing: .05em;
}

.niarea-fullrich h3 {
	border-bottom: dotted 3px var(--main);
	color: var(--main);
	margin: 40px 0 30px;
	padding: 0 0 10px;
	font-size: 2.4rem;
	letter-spacing: .05em;
}

.niarea-fullrich h4 {
	margin: 30px 0 20px;
	padding: 4px 0 0 16px;
	font-size: 2.3rem;
	position: relative;
}

.niarea-fullrich h4::before {
	background: var(--main);
	position: absolute;
	top: 2px;
	left: 0;
	display: block;
	content: '';
	width: 6px;
	height: 100%;
}

.niarea-fullrich img {
	max-width: 100%;
	height: auto;
	display: inline-block;
}

.niarea-fullrich a:link {
	color: var(--link);
	display: inline-block;
	text-decoration: underline;
}

.niarea-fullrich p {
	margin: 1em 0;
}

@media screen and (max-width: 768px) {
	.niarea-fullrich h1, .niarea-fullrich h2, .niarea-fullrich h3, .niarea-fullrich h4 {
		line-height: 1.5;
	}

	.niarea-fullrich h1 {
		border-bottom-width: 4px;
		font-size: 2.3rem;
		line-height: 1.5;
		margin: 30px 0 20px;
		padding: 0 0 10px;
	}

	.niarea-fullrich h2 {
		margin: 30px 0 20px;
		padding: 8px 15px 10px;
		font-size: 2rem;
	}

	.niarea-fullrich h3 {
		margin: 30px 0;
		padding: 0 0 10px;
		font-size: 1.9rem;
	}

	.niarea-fullrich h4 {
		margin: 30px 0 20px;
		padding: 0 0 0 12px;
		font-size: 1.8rem;
	}

	.niarea-fullrich h4::before {
		top: 0;
		width: 5px;
	}

	.niarea-fullrich img {
		max-width: 100%;
	}
}