@charset "UTF-8";



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

kv

----------------------------------------------------------  */
.kv {
	position: relative;
	background-image: url(../img/kv-top.jpg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

.kv>div {
	padding: 4rem 0 4rem 10rem
}

.kv-txt-1 {
	width: 65rem;
}

.kv-txt-2 {
	width: 65rem;
	padding-left: 2rem;
}

.kv-txt-3 {
	width: 20rem;
	position: absolute;
	right: 5rem;
	bottom: 2rem;
}

@media screen and (max-width: 768px) {
	.kv {
		background-image: url(../img/kv-top_sp.jpg);
	}

	.kv>div {
		padding: 4rem 2rem 3rem 2rem;
	}

	.kv-water {
		padding: 2rem 2rem 1.5rem 4rem !important;
	}

	.kv-txt-1 {
		width: 100%;
		margin: 0 auto;
	}

	.kv-txt-2 {
		width: 100%;
		padding-left: 1rem;
		padding-top: 11rem;
	}

	.kv-txt-3 {
		width: 10rem;
		right: 3rem;
		bottom: auto;
		top: 17rem;
		z-index: 11111;
	}
}



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

こんなお悩みありませんか？

----------------------------------------------------------  */
.concern ul {
	display: flex;
	justify-content: space-between
}

.concern ul li {
	width: 32%;
}

.concern ul li dl dt {
	text-align: center;
	font-size: 1.8rem;
	font-weight: 700;
	margin: 1rem 0 0.6rem 0;
}

.concern.arrow {
	position: relative;
}

.concern.arrow::after {
	content: "";
	border-top: solid 5rem var(--red);
	border-left: solid 14rem transparent;
	border-right: solid 14rem transparent;
	position: absolute;
	left: calc(50% - 14rem);
	bottom: -1.5rem;
	z-index: 99;
}

@media screen and (max-width: 768px) {
	.concern ul {
		display: block;
	}

	.concern ul li {
		width: 100%;
	}

	.concern ul li:not(:last-child) {
		margin-bottom: 5rem;
	}
}



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

commit

----------------------------------------------------------  */
.commit {
	background: var(--blue);
	color: #fff;
	padding-top: 2rem;
}

.commit>div {
	display: flex;
	align-items: center;
}

.commit>div>div {
	width: 40%;
}

.commit>div>figure {
	width: 60%;
}

.commit h2 {
	color: var(--yellow);
	font-size: 2.8rem;
	font-weight: 700;
	line-height: 1.4;
	border-bottom: solid 0.12rem var(--yellow);
	margin-bottom: 1rem;
	padding-bottom: 1rem;
}

@media screen and (max-width: 768px) {
	.commit {
		padding: 6rem 3rem 0 3rem;
	}

	.commit>div {
		display: block;
	}

	.commit>div>div {
		width: 100%;
		margin-bottom: 1.5rem;
	}

	.commit>div>figure {
		width: 100%;
	}

	.commit h2 {
		text-align: center;
	}
}



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

今のお困りごとは何ですか？

----------------------------------------------------------  */
.trouble ul {
	display: flex;
	justify-content: space-between;
	margin-bottom: 5rem;
}

.trouble ul li {
	width: 32%;
}

.trouble ul li h3 {
	font-size: 2rem;
	text-align: center;
	margin-bottom: 0.8rem;
}

.trouble ul li dl dt {
	text-align: center;
	font-size: 2rem;
	font-weight: 700;
	margin: 1rem 0 0.6rem 0;
	color: var(--red);
}

.trouble a {
	display: block;
	width: 16rem;
	margin: 2rem auto 0 auto;
}

.trouble p {
	font-size: 1.2rem;
}

@media screen and (max-width: 768px) {
	.trouble ul {
		display: block;
	}

	.trouble ul li {
		width: 100%;
	}

	.trouble ul li:not(:last-child) {
		margin-bottom: 5rem;
	}

	.trouble a {
		width: 24rem;
	}
}



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

対応エリア一覧

----------------------------------------------------------  */
.area {
	background: url(../img/area-top-bg-1.jpg) no-repeat center / cover;
	padding: 5rem 0 8rem 0;
}

.area>div {
	background: rgba(255, 255, 255, 0.6);
	padding: 5rem 8rem;
	position: relative;
}

.area h2 {
	line-height: 1.4;
	font-size: 2.6rem;
	font-weight: 900;
	color: var(--red);
	text-align: center;
	margin-bottom: 2rem;
}

.area p {
	margin-bottom: 3rem;
}

.area>div figure {
	position: absolute;
	right: -8rem;
	bottom: -4rem;
	width: 44rem;
}

.area-list {
	line-height: 1;
	position: relative;
	z-index: 2;
	width: 100%;
}

.area-list a {
	text-decoration: underline;
}

.area-list a:hover {
	text-decoration: none;
}

.area-list>li:not(:last-child) {
	margin-bottom: 1.5rem;
}

.area-list dl {
	display: flex;
}

.area-list dl dt {
	width: 15rem;
	background: url(../img/arrow-1.png) no-repeat top 0.4rem left 7.5em;
	background-size: 0.8rem auto;
}

.area-list dl dd {
	width: calc(100% - 15rem);
}

.area-list dl dd ul {
	display: flex;
	flex-wrap: wrap;
}

.area-list dl dd ul li:not(:last-child) {
	margin-right: 2rem;
	padding-right: 2rem;
	border-right: solid 0.15rem #000;
}

.area-list dl dd ul li {
	white-space: nowrap;
}

.area-low h2 i {
	color: #000;
}

.city-list {
	display: flex;
	flex-wrap: wrap;
	line-height: 1;
	padding-right: 10rem;
	position: relative;
	z-index: 2;
}

.city-list a {
	text-decoration: underline;
}

.city-list a:hover {
	text-decoration: none;
}

.city-list li:not(:last-child) {
	margin-right: 2rem;
	padding-right: 2rem;
	border-right: solid 0.15rem #000;
	margin-bottom: 1.5rem;
}

@media screen and (max-width: 768px) {
	.area {
		padding: 5rem 3rem;
	}

	.area>div {
		padding: 5rem 3rem;
	}

	.area-list {
		line-height: 1.4;
	}

	.area-list>li:not(:last-child) {
		margin-bottom: 2.5rem;
	}

	.area-list dl {
		display: block;
	}

	.area-list dl dt {
		width: auto;
		background: none;
		margin-bottom: 0.5rem;
	}

	.area-list dl dt::before {
		content: "◆";
		color: var(--blue);
	}

	.area-list dl dd {
		width: auto;
	}

	.area-list dl dd ul {
		display: flex;
		flex-wrap: wrap;
	}

	.area-list dl dd ul li:not(:last-child) {
		margin-bottom: 0.8rem;
	}

	.area-list dl dd ul li {
		white-space: normal;
	}

	.city-list {
		padding-right: 0;
	}
}



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

鍵・ガラス・水トラブル解決の流れ

----------------------------------------------------------  */
.solve {
	background: var(--blue);
}

.solve ul li {
	background: #fff;
	border-radius: 1rem;
	padding: 3rem;
	display: flex;
	align-items: center;
}

.solve ul li figure {
	width: 30%;
}

.solve ul li dl {
	width: 70%;
	padding-left: 3rem;
}

.solve ul li dl dt {
	color: var(--blue);
	font-size: 2rem;
	font-weight: 700;
	margin-bottom: 1rem;
}

.solve ul li:not(:last-child) {
	margin-bottom: 3rem;
}

@media screen and (max-width: 768px) {
	.solve ul li {
		display: block;
	}

	.solve ul li figure {
		width: 100%;
		margin-bottom: 2rem;
	}

	.solve ul li dl {
		width: 100%;
		padding-left: 0;
	}
}



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

鍵・ガラス・水のトラブルの解決事例

----------------------------------------------------------  */
.case p {
	margin-bottom: 3rem
}

.case ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.case ul li {
	width: 48%;
	background: #e7f1fa;
	position: relative;
	padding: 4rem 3rem 3rem 3rem;
}

.case ul li:nth-child(n + 3) {
	margin-top: 4%;
}

.case ul li dl dt {
	display: block;
	margin-bottom: 1.5rem;
	line-height: 1.5;
	color: var(--blue);
	font-weight: 700;
	font-size: 1.8rem;
}

.case ul li dl dt img {
	width: 100%;
	height: auto;
	margin-top: 20px;
}

.num {
	width: 7rem;
	height: 7rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	line-height: 1;
	position: absolute;
	left: -0.6rem;
	top: -0.6rem
}

.num::before {
	content: "";
	border-left: solid 7rem var(--yellow);
	border-right: solid 7rem transparent;
	border-bottom: solid 7rem transparent;
	position: absolute;
	left: 0;
	top: 0;
}

.num>span {
	position: relative;
	z-index: 2;
	font-weight: 700;
}

.num>span:nth-child(2) {
	color: var(--blue);
	font-size: 2.8rem;
	margin-top: 0.3rem;
}

.point .num>span:nth-child(2) {
	color: var(--red);
}

@media screen and (max-width: 768px) {
	.case ul {
		display: block;
	}

	.case ul li {
		width: 100%;
		padding: 5rem 3rem 3rem 3rem;
	}

	.case ul li:nth-child(n + 3) {
		margin-top: 0;
	}

	.case ul li:nth-child(n + 2) {
		margin-top: 3rem;
	}
}



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

よくあるご質問

----------------------------------------------------------  */
.faq {
	background: #f0f0f0;
}

.faq ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.faq ul li {
	width: 48%;
}

.faq ul li:nth-child(n + 3) {
	margin-top: 4%;
}

.faq ul li dl dt {
	background: var(--red);
	color: #fff;
	border-radius: 1rem;
	display: flex;
	padding: 1.5rem 2rem;
	font-size: 1.6rem;
	font-weight: 700;
	margin-bottom: 1.5rem;
	position: relative;
	line-height: 1.6;
}

.faq ul li dl dt::before {
	content: "";
	width: calc(100% - 0.6rem);
	height: 3rem;
	background: #c80000;
	border-radius: 0 0 0.7rem 0.7rem;
	position: absolute;
	left: 0.3rem;
	bottom: 0.3rem;
}

.faq ul li dl dt span {
	position: relative;
	z-index: 2;
}

.faq ul li dl dt span:nth-child(1) {
	width: 3rem;
}

.faq ul li dl dt span:nth-child(2) {
	width: calc(100% - 3rem);
}

@media screen and (max-width: 768px) {
	.faq ul {
		display: block;
	}

	.faq ul li {
		width: 100%;
	}

	.faq ul li:nth-child(n + 3) {
		margin-top: 0;
	}

	.faq ul li:nth-child(n + 2) {
		margin-top: 3rem;
	}

	.faq ul li dl dt {
		background: var(--red);
		color: #fff;
		border-radius: 1rem;
		display: flex;
		padding: 1.5rem 2rem;
		font-size: 1.6rem;
		margin-bottom: 1.5rem;
		position: relative;
	}

	.faq ul li dl dt::before {
		content: "";
		width: calc(100% - 0.6rem);
		height: 3rem;
		background: #c80000;
		border-radius: 0 0 0.7rem 0.7rem;
		position: absolute;
		left: 0.3rem;
		bottom: 0.3rem;
	}

	.faq ul li dl dt span {
		position: relative;
		z-index: 2;
	}

	.faq ul li dl dt span:nth-child(1) {
		width: 3rem;
	}

	.faq ul li dl dt span:nth-child(2) {
		width: calc(100% - 3rem);
	}
}



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

アクセスが選ばれる4つの強み

----------------------------------------------------------  */
.point {
	background: #f0f0f0;
}

.point>p {
	margin-bottom: 3rem;
}

.point ul {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.point ul li {
	width: 48%;
	position: relative;
	background: #fff;
	position: relative;
	padding: 4rem 3rem 3rem 3rem;
}

.point ul li:nth-child(n + 3) {
	margin-top: 4%;
}

.point ul li h3 {
	color: var(--red);
	text-align: center;
	font-size: 2.2rem;
	margin-bottom: 2rem;
	line-height: 1.4;
	margin-top: 2rem;
}

.point ul li div {
	display: flex;
}

.point ul li div>figure {
	width: 40%;
}

.point ul li div>figure img {
	width: 100%;
	height: 12rem;
	object-fit: cover;
}

.point ul li div>p {
	width: 60%;
	padding-left: 1.5rem;
}

@media screen and (max-width: 768px) {
	.point ul {
		display: block;
	}

	.point ul li {
		width: 100%;
		padding: 5rem 3rem 3rem 3rem;
	}

	.point ul li:nth-child(n + 3) {
		margin-top: 0;
	}

	.point ul li:nth-child(n + 2) {
		margin-top: 3rem;
	}

	.point ul li div {
		display: block;
	}

	.point ul li div>figure {
		width: 100%;
		margin-bottom: 1.5rem;
	}

	.point ul li div>figure img {
		width: 100%;
		height: 18rem;
	}

	.point ul li div>p {
		width: 100%;
		padding-left: 0;
	}
}



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

search

----------------------------------------------------------  */
.search {
	background: var(--blue);
	color: #fff;
	padding: 3rem 0 3.5rem 0;
	text-align: center;
	font-size: 1.8rem;
}

.green-search-section{
	background: #1E8D4F;
}

.blue-search-section{
	background: #3274D5;
}

.search form {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: 1rem
}

.search form>div {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-right: 1.5rem;
}

.search form span {
	display: block;
	margin: 0 0.3rem 0 0.6rem;
}

.search form select {
	font-size: 1.6rem;
	height: 30px;
	text-align: center;
	cursor: pointer;
}

.search form input {
	cursor: pointer;
}

input[type="submit"] {
	background: #f45b21;
	border: none;
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	width: 8rem;
	height: 3.2rem;
	border-radius: 0.3rem;
	font-size: 1.8rem;
	font-weight: bold;
	-webkit-appearance: button;
	appearance: button;
}

input[type="submit"]::-webkit-search-decoration {
	display: none;
}

input[type="submit"]:disabled {
    color: -internal-light-dark(graytext, rgb(170, 170, 170));
    opacity: 0.7;
    border-color: rgba(118, 118, 118, 0.3);
}

@media screen and (max-width: 768px) {
	.search form {
		flex-direction: column;
	}

	.search form>div {
		margin-bottom: 1.5rem;
	}

	input[type="submit"] {
		width: 85%;
		height: 4.8rem;
		margin: 0 auto;
	}
}



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

cv-1

----------------------------------------------------------  */
.cv-1 {
	background: url(../img/bg-grd.png) repeat-x center;
	background-size: auto 100%;
	padding: 4rem 0 3rem 0;
}

.cv-1 a {
	display: block;
	width: 80rem;
	margin: 0 auto;
	border-radius: 0.8rem;
	background: linear-gradient(to bottom, #bdbebe, #bdbebe, #727171);
	padding: 0.4rem;
	position: relative;
	box-shadow: 0.5rem 0.5rem 0.6rem rgba(0, 0, 0, 0.2);
}

.cv-1 a>div {
	background: linear-gradient(to bottom, #fff, #fafafa 60%, #bdbebe 60%);
	position: relative;
	padding: 2.5rem 0 2.5rem 3rem;
	border-radius: 0.4rem;
	display: flex;
	flex-direction: column;
}

.cv-1 a>div img {
	width: 46rem;
	height: auto;
	margin: 0.5rem 0 0.8rem 0;
}

.cv-1 a>div span {
	font-weight: 900;
	font-style: italic;
	line-height: 1;
	white-space: nowrap;
}

.cv-1 a>div>span:nth-of-type(1) {
	font-size: 1.85rem;
}

.cv-1 a>div>span:nth-of-type(1) strong {
	font-weight: 900;
	color: var(--red);
}

.cv-1 a>div>span:nth-of-type(2) {
	font-size: 1.64rem;
}

.cv-1 a figure {
	position: absolute;
	right: 2rem;
	bottom: 0.5rem;
	width: 26rem;
}

@media screen and (max-width: 768px) {
	.cv-1 a {
		width: calc(100% - 6rem);
		text-decoration: none;
	}

	.cv-1 a>div {
		padding: 2rem 0;
		background: linear-gradient(to bottom, #fff, #fafafa 50%, #bdbebe 50%);
	}

	.cv-1 a>div img {
		width: 100%;
		height: auto;
		margin: 0.5rem 0 0.8rem 0;
		padding: 0 2rem;
	}

	.cv-1 a>div span {
		line-height: 1.3;
		text-align: center;
	}

	.cv-1 a>div>span:nth-of-type(1) strong {
		display: block;
	}

	.cv-1 a>div>span:nth-of-type(2) {
		font-size: 1.6rem;
	}
}



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

cv-2

----------------------------------------------------------  */
.cv-2 {
	overflow: hidden;
}

.cv-2>div {
	display: block;
	border: solid 0.5rem var(--red);
	position: relative;
}

.cv-2 h2 {
	background: linear-gradient(to bottom, var(--red) 65%, #c80000 65%);
	padding: 1.5rem 0 1.5rem 2rem;
}

.cv-2 h2 img {
	width: 50rem;
	height: auto;
}

.cv-2 .wrap {
	width: 50rem;
	padding: 2rem 0 2rem 2rem;
}

.cv-2 p {
	margin: 1rem 0;
}

.cv-2 figure {
	position: absolute;
	right: -4rem;
	bottom: 0;
	width: 40rem;
}

@media screen and (max-width: 768px) {
	.cv-2 h2 {
		padding: 1rem 1rem 1.5rem 1rem;
	}

	.cv-2 h2 img {
		width: 100%;
	}

	.cv-2 .wrap {
		width: auto;
		padding: 2rem;
	}

	.cv-2 .wrap>div:nth-of-type(2) {
		width: 85%;
		margin: 0 auto;
	}

	.cv-2 p {
		margin: 1.5rem 0;
	}

	.cv-2 figure {
		position: relative;
		right: auto;
		bottom: auto;
		width: 95%;
		margin: 0 auto;
	}
}



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

流れ

----------------------------------------------------------  */
.flow ul li {
	padding: 3rem;
	display: flex;
	align-items: center;
	border: 0.3rem solid #c2c4c3;
	border-radius: 1rem;
	background: linear-gradient(to top, #f4f4f4, #fff);
	position: relative;
}

.flow ul li figure {
	width: 30%;
}

.flow ul li dl {
	width: 70%;
	padding-left: 3rem;
}

.flow ul li dl dt {
	color: var(--blue);
	font-size: 2rem;
	font-weight: 700;
	margin-bottom: 1rem;
}

.flow ul li:not(:last-child) {
	margin-bottom: 3rem;
}

.step {
	width: 6rem;
	height: 6rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	line-height: 1;
	position: absolute;
	left: 1rem;
	top: 1rem;
	background: var(--orange);
	color: #fff;
	border-radius: 0.4rem;
}

.step>span {
	position: relative;
	z-index: 2;
	font-weight: 700;
}

.step>span:nth-child(1) {
	font-size: 1.2rem;
}

.step>span:nth-child(2) {
	font-size: 2.4rem;
	margin-top: 0.3rem;
}

@media screen and (max-width: 768px) {
	.flow ul li {
		display: block;
	}

	.flow ul li figure {
		width: 100%;
		margin-bottom: 2rem;
	}

	.flow ul li dl {
		width: 100%;
		padding-left: 0;
	}
}



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

お役立ちコラム

----------------------------------------------------------  */
.column {
	background: var(--orange);
}

.column ul {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.column ul li {
	width: 48.5%;
	background: #fff;
	border-radius: 1rem;
}

.column ul li:nth-child(n + 3) {
	margin-top: 3%;
}

.column ul li a {
	display: flex;
	padding: 1.5rem;
}

.column ul li a>figure {
	width: 25%;
}

.column ul li a>figure img {
	height: 8rem;
	object-fit: cover;
}

.column ul li a>p {
	width: 75%;
	padding-left: 1.5rem;
}

@media screen and (max-width: 768px) {
	.column ul {
		display: block;
	}

	.column ul li {
		width: 100%;
	}

	.column ul li:nth-child(n + 3) {
		margin-top: 0;
	}

	.column ul li:nth-child(n + 2) {
		margin-top: 3rem;
	}

	.column ul li a {
		display: block;
		padding: 2rem;
	}

	.column ul li a>figure {
		width: 100%;
		margin-bottom: 1rem;
	}

	.column ul li a>figure img {
		height: 20rem;
	}

	.column ul li a>p {
		width: 100%;
		padding-left: 0;
	}
}



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

トラブルシューティング

----------------------------------------------------------  */
.trouble-shooting {
	background-image: url(../img/key-trouble-shooting-bg.jpg);
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

.trouble-shooting>div {
	background: #fff;
	border-radius: 1rem;
	padding: 5rem 4rem;
	box-shadow: 0 0 2rem rgba(0, 0, 0, 0.3);
}

.trouble-shooting>div>section:not(:last-of-type) {
	margin-bottom: 3rem;
	padding-bottom: 3rem;
	border-bottom: solid 0.15rem #C8C8C8;
}

.trouble-shooting h3 {
	font-size: 2rem;
	color: var(--red);
	line-height: 1.4;
	margin-bottom: 1.5rem;
}

@media screen and (max-width: 768px) {
	.trouble-shooting>div {
		padding: 3rem;
	}
}



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

トラブルはお任せください

----------------------------------------------------------  */
.caution {
	background: url(../img/caution-trouble-bg-1.jpg) no-repeat center / cover;
	color: #fff;
}

.caution h2 {
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2.6rem;
	line-height: 1.4;
	color: #fff;
	margin-bottom: 4rem;
}

.caution h2 img {
	width: 7rem;
	margin-right: 1rem;
}

.caution ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin-bottom: 5rem;
}

.caution ul li {
	width: 23%;
}

.caution ul li:nth-child(n + 5) {
	margin-top: 3rem;
}

.caution figcaption {
	display: flex;
	align-items: center;
	background: linear-gradient(to top, #000 50%, #4d4948 50%);
	padding: 1rem 0 1rem 1rem;
	position: relative;
	z-index: 2;
	margin-top: -2rem;
}

.caution figcaption img {
	width: 3rem;
	margin-right: 1rem;
}

.case_ttl {
	margin-top: 15px;
	text-align: center;
}

.area_non {
	padding: 0 !important;
}

.footer_item {
	margin-right: 0 !important;
	margin-top: 50px;
}


@media screen and (max-width: 768px) {
	.caution h2 {
		font-size: 2.2rem;
	}

	.caution h2 img {
		width: 5rem;
	}

	.caution ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		margin-bottom: 3rem;
	}

	.caution ul li {
		width: 48.5%;
	}

	.caution ul li:nth-child(n + 5) {
		margin-top: 2rem;
	}

	.caution figcaption {
		justify-content: center;
		font-size: 1.4rem;
	}

	.caution figcaption img {
		width: 1.6rem;
		margin-right: 0.6rem;
	}
}


