@charset "utf-8";

#contents {
	color: #333;
}

#contents img {
	width: 100%;
	height: auto;
}


/*==================================================
page header
==================================================*/

#pageHeader {
	width: 100%;
	height: 400px;
	overflow: hidden;
	text-align: center;
	background-color: #accc4f;
	position: relative;
}

#pageHeader .titleArea {
	width: 980px;
	margin: 0 auto;
	padding-top: 70px;
	text-align: left;
	font-family: 'Noto Sans', 'Open Sans', sans-serif;
}

#pageHeader .titleArea .hdmaintitle {
	width: 450px;
	padding-top: 3.4em;
	margin-bottom: 1.5em;
	font-size: 1.5em;
	/*
	color: #fff;
	font-size: 2.5em;
	letter-spacing: .05em;
	font-weight: normal;
*/
	position: relative;
}

#pageHeader .titleArea .hdmaintitle span {
	width: 300px;
	position: absolute;
	top: 0;
	/*
	display: inline-block;
	padding: .2em 1.8em .1em;
	color: #222;
	background-color: #7bcdcd;
	border: solid 2px;
	font-size: 1.4rem;
	position: absolute;
	top: 0;
*/
}

/*
#pageHeader .titleArea .hdmaintitle span::before,
#pageHeader .titleArea .hdmaintitle span::after {
	content: '';
	display: block;
	width: 0;
	height: 0;
	border-left: solid 20px transparent;
	position: absolute;
	top: 100%;
	left: calc(50% - 10px);
}
*/

#pageHeader .titleArea .hdmaintitle span::before {
	border-top: solid 20px #222;
}

#pageHeader .titleArea .hdmaintitle span::after {
	border-top: solid 20px #7bcdcd;
	margin-top: -5px;
	margin-left: -2px;
}

#pageHeader .titleArea .lead {
	line-height: 1.9;
	letter-spacing: .05em;
	font-size: 1.05em;
}

#pageHeader .illust {
	width: 490px;
	position: absolute;
	bottom: 0;
	left: 50%;
}

/* -------------------- smart phone  -------------------- */

@media screen and (max-width:767px) {

	#pageHeader {
		height: auto;
		padding-bottom: 40vw;
	}

	#pageHeader .titleArea {
		width: 90%;
		padding-top: 12vw;
	}

	#pageHeader .titleArea .hdmaintitle {
		width: 100%;
		padding-top: 18vw;
	}

	#pageHeader .titleArea .hdmaintitle span {
		width: 80%;
		left: 10%;
	}

	#pageHeader .titleArea .lead {
		font-size: .95em;
		text-align: justify;
	}

	#pageHeader .illust {
		width: 60%;
		left: 20%;
	}
}

/*==================================================
contents
==================================================*/

.co {
	width: 100%;
	margin: 0 !important;
}

.co .inner {
	width: 980px;
	margin: 0 auto;
	padding: 60px 0;
	position: relative;
	text-align: center;
}

.co h3,
.co h4,
.co h5 {
	letter-spacing: 0.05em;
	margin-bottom: 1.5em;
	line-height: 1.6em;
	font-weight: bold;
}

.co p,
.co li {
	line-height: 1.8em;
}

.co p:not(:last-child),
.co ul:not(:last-child) {
	margin-bottom: 1em;
}

.co sup {
	font-size: .6em;
	vertical-align: .6em;
}

.co .icon {
	width: 200px;
	width: min(200px, 45%);
	margin: 0 auto .5em;
}

.co:not(.intro):not(#recommend) .coH {
	margin-bottom: 1em;
	line-height: 1.8em;
	font-size: 2em;
}

.co:not(.intro):not(#recommend) .coSub {
	display: inline-block;
	margin-bottom: 1.8em;
	padding: .5em 2em .4em;
	line-height: 1.6;
	border: solid 4px;
	font-size: 1.5em;
	font-weight: bold;
	letter-spacing: .05em;
}

.co:not(#recommend) .coSub+p {
	font-size: 1.15em;
	font-weight: bold;
}

.co ul.note {
	display: inline-block;
}

.co ul.numnote_start2 {
	counter-reset: numnote 1;
}

.co ul.numnote_start5 {
	counter-reset: numnote 4;
}

.co ul.numnote_start7 {
	counter-reset: numnote 6;
}

.co ul.note li {
	font-size: .85em;
	text-align: left;
	color: #666;
}

/*
@media screen and (min-width:768px) {
	.co ul.note li::before {
		position: relative;
		margin-right: .3em;
	}
}
*/

.co .fig {
	padding: 3em 2em;
	margin: 3em auto;
	background-color: #fff;
	text-align: center;
	position: relative;
}

.co .fig .figTitle {
	margin-bottom: .6em;
	font-size: 1.5em;
	font-weight: bold;
}

.co .fig .figTitle+p {
	letter-spacing: .08em;
	font-size: 1.15em;
	font-weight: bold;
}

.co .fig picture {
	display: block;
	width: 760px;
	width: min(90vw, 760px);
	margin: 2em auto 0;
}

.co .fig img {
	margin-bottom: 10px;
}

.co .fig p.note {
	display: inline-block;
	margin: .5em auto 0;
	font-size: .9em;
	color: #666;
	text-align: left;
	text-indent: -1.8em;
}

#co2 .fig p.note {
	margin-top: 0;
	position: relative;
	top: -1em;
}

.intro .coH {
	display: inline-block;
	margin-bottom: 1em;
	padding: .2em 1em .2em 1.2em;
	border-radius: 5px;
	color: #fff;
	font-size: 1.17em;
	background-color: #accc4f;
}

.intro .coSub {
	margin-bottom: 1em;
	line-height: 1.6em;
	font-size: 1.7em;
	font-weight: bold;
	text-align: center;
	color: #accc4f;
}

.intro .mode-kind {
	display: flex;
	justify-content: space-between;
	margin: 2em auto 2.5em !important;
}

.intro .mode-kind li {
	width: 32%;
	padding: 1.5em 1em;
}

.intro .mode-kind li .icon {
	margin-bottom: .5em;
}

.intro .mode-kind li h4 {
	font-size: 1.25em;
	margin-right: -.7em;
	margin-bottom: 1em;
}

.intro .mode-kind li p {
	font-size: .95em;
}

.intro .mode-kind li .note {
	padding-left: 1em;
	text-indent: -1em;
	font-size: .8em;
	text-align: left;
	color: #666;
}

.intro .lbox {
	display: inline-block;
	padding: .6em 3em;
	color: #fff;
	background-color: #accc4f;
	text-decoration: none;
	border-radius: 2em;
	letter-spacing: .05em;
}

.intro .lbox~p {
	margin-top: 3em;
	font-size: 1.15em;
	font-weight: bold;
}

#lBox {
	width: 960px;
	/* left: calc(50% - 480px); */
	left: 50%;
	font-size: 16px;
}

#lBox .drive_mode {
	padding: 50px 40px 40px;
	border: solid 1px #ccc;
	background-color: #fff;
}

#lBox .drive_mode h3 {
	margin-bottom: 2em;
	font-size: 1.4em;
	font-size: min(1.4em, 4.8vw);
	color: #accc4f;
}

#lBox .drive_mode ul {
	display: flex;
	justify-content: space-between;
}

#lBox .drive_mode li {
	width: 30%;
	position: relative;
}

#lBox .drive_mode li:not(:last-child)::after {
	content: '';
	display: block;
	width: 0;
	height: 0;
	border: solid 10px transparent;
	border-left: solid 15px #accc4f;
	position: absolute;
	left: 105%;
	top: calc(50% - 2em);
}

#lBox .drive_mode .thumb {
	width: 100%;
	margin-bottom: .5em;
}

#lBox .drive_mode p {
	/* 	width: 50%; */
	line-height: 1.6;
	text-align: left;
}

#lBox .drive_mode .thumb {
	/* 	width: 50%; */
}

#lBox .drive_mode .thumb img {
	width: 100%;
	height: auto;
}

#co1,
.co1 {
	background-color: #e6f0ca;
}

.co1 h4,
#co1 .coH,
#co1 .coSub,
#co1 .figTitle {
	color: #3ba74c;
}

#co2,
.co2 {
	background-color: #caebeb;
}

.co2 h4,
#co2 .coH,
#co2 .coSub,
#co2 .figTitle {
	color: #0068b6;
}

#co3,
.co3 {
	background-color: #fbdcdd;
}

.co3 h4,
#co3 .coH,
#co3 .coSub,
#co3 .figTitle {
	color: #ee7278;
}

#co3 .fig a.arrow {
	display: inline-block;
	margin-top: 2em;
	padding: .6em 3em;
	color: #fff;
	background-color: #ee7278;
	text-decoration: none;
	border-radius: 2em;
	letter-spacing: .05em;
}

a.arrow {
	position: relative;
}

a.arrow::after {
	content: '\e902';
	font-family: 'regular';
	position: absolute;
	right: .5em;
	top: calc(50% - .45em);
	color: inherit;
	font-size: 0.9em;
	font-weight: normal;
	line-height: 1;
}

#recommend {
	background-color: #f9f9f9;
}

#recommend .coH {
	width: 7em;
	margin: 0 auto .3em;
	font-size: 1.7em;
}

#recommend .coSub {
	margin-bottom: 3em;
}

#recommend .bannerList li {
	width: 360px;
	margin: 0 30px;
	position: relative;
}

#recommend .bannerList li:nth-child(1) {
	background-color: #fbb03b;
}

#recommend .bannerList li:nth-child(2) {
	background-color: #42b1ba;
}

#recommend .bannerList li a {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	transition: border-width .2s 0s;
}

#recommend .bannerList li:nth-child(1) a {
	border: solid 2px #fbb03b;
}

#recommend .bannerList li:nth-child(2) a {
	border: solid 2px #42b1ba;
}

#recommend .bannerList li a:hover {
	border-width: 4px;
}

#recommend .bannerList li p {
	margin: 0;
	padding: .5em 0 .4em;
	color: #fff;
	font-size: .95em;
}

@media screen and (max-width:767px) {

	.co {
		font-size: min(3.2vw, 14px);
	}

	.co .inner {
		width: 90vw !important;
		margin: 0 auto;
		padding: 30px 0;
		position: relative;
	}

	.co.intro {
		text-align: left;
	}

	.co.intro br {
		display: none;
	}

	.co h3 {
		font-size: 1.25em;
	}

	.co h4,
	.co h5 {
		font-size: 1.05em;
	}

	.co .coH {
		margin-bottom: 1.6em;
		line-height: 1.6em;
		font-size: 1.3em;
	}

	.co:not(.intro):not(#recommend) .coSub {
		width: 100%;
		padding: .5em .5em .4em;
	}

	.co:not(#recommend) .coSub+p {
		text-align: left;
	}

	.co:not(#recommend) .coSub+p br {
		display: none;
	}

	.co ul.note li {
		margin-bottom: .5em;
		text-align: left;
		line-height: 1.6;
		font-size: .9em;
	}

	.co .fig {
		padding: 2.5em 1.5em;
	}

	.co .illust,
	.co .fig {
		margin: 2em auto;
	}

	.co .flex .illust,
	.co .flex .fig {
		margin: 0 auto;
	}

	.co .fig p.note {
		padding-left: 1.3em;
	}

	.co .fig picture {
		width: 100%;
	}

	.intro .mode-kind {
		flex-wrap: wrap;
	}

	.intro .mode-kind li {
		width: 100%;
		padding: 1.5em 2em;
		margin: .5em 0;
	}

	.intro .mode-kind li p {
		font-size: 1em;
	}

	.intro .mode-kind li p br {
		display: block;
	}

	.intro .mode-kind+p {
		text-align: left;
	}

	#lBox {
		width: 90%;
		left: 5%;
	}

	#lBox .drive_mode {
		padding: 7vw 5vw;
	}

	#lBox .drive_mode ul {
		display: block;
	}

	#lBox .drive_mode li {
		width: 100%;
	}

	#lBox .drive_mode li:not(:last-child) {
		margin-bottom: 3em;
	}

	#lBox .drive_mode li:not(:last-child)::after {
		border: solid 10px transparent;
		border-top: solid 15px #accc4f;
		left: calc(50% - 10px);
		top: calc(100% + 1.5em - 7px);
	}

	#lBox .drive_mode p {
		font-size: .85em;
	}

	#guidelinks h1 {
		font-size: 1.2em !important;
	}

	#guidelinks.solar_battery h1+.note {
		font-size: .8em !important;
	}

	#recommend .coSub {
		margin-bottom: 2em;
	}

	#recommend .bannerList {
		justify-content: space-between;
	}

	#recommend .bannerList li {
		width: 49%;
		margin: 0;
	}

	#recommend .bannerList li p {
		line-height: 1.5;
	}
}