@charset "utf-8";

/* ====================
reset
==================== */
.sc-container {
	background: #ffffff;
}
.sc-container, .sc-container div, 
.sc-container ul, .sc-container ol, .sc-container li,
.sc-container h1, .sc-container h2, .sc-container h3, .sc-container h4,
.sc-container p, .sc-container span {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
    border: unset;
}

.sc-container img {
	border: 0;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

.sc-container li {
	list-style: none;
}

.sc-container h1, .sc-container h2,
.sc-container h3, .sc-container h4 {
	font-size: 100%;
	font-weight: normal;
	border: none;
}

.sc-container dl {
	font-size: 0;
}

button{
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
}

/* ====================
***
==================== */
.sc-container {
    width: 100%;
    margin: 48px auto;
    background: #ffffff;
    color: #1a1a1a;
    font-size: 16px;
    font-family: "Noto Sans JP","Yu Gothic Medium","Yu Gothic","YuGothic","Meiryo","Hiragino Kaku Gothic ProN","Hiragino Sans",sans-serif;
    line-height: 1.75;
    overflow: hidden;
	letter-spacing: 0.05em;
}

.sc-container strong {
	font-weight: bold;
}

.sc-container a,
.sc-container a:link,
.sc-container a:visited,
.sc-container a:active {
	text-decoration: none;
}

.sc-container a span {
	-webkit-transition: .4s;
	transition: .4s;
}

.sc-container a:hover,
.sc-container a:active {
	opacity: 1;
	text-decoration: none;
}

#page-top a {
	background: url(../img/btn_pagetop.png) left top;
	width: 100px;
	height: 100px;
	display: block;
	-webkit-transition: .4s;
	transition: .4s;
}

#page-top a:hover {
	opacity: 0.9;
}


/* ====================
keyv-area
==================== */
.sc-container .keyv-area {
    width: 1000px;
    margin: 0 auto 110px;
}

.sc-container .keyv-image {
    margin: 0 auto 60px;
}

.sc-container .keyv-text {
    width: 840px;
    margin: 0 auto;
    line-height: 2.125;
}

/* ====================
	cp-area
==================== */
.sc-container .cp-area {
    width: 100%;
    margin: -15px auto 120px;
    padding: 23px 0 40px;
    background: #cdc7b8;
}

.sc-container .cp-inner {
    width: 750px;
    margin: 0 auto;
}

.sc-container .cp-title {
    margin: 0 0 10px;
    font-size: 24px;
    font-weight: bold;
    line-height: 1.5;
    text-align: center;
    color: #006222;
    letter-spacing: 0.02em;
}

.sc-container .cp-title span {
    font-size: 34px;
    vertical-align: -2px;
    font-weight: bold;
}

.sc-container .cp-bnr {
	position: relative;
	z-index: 0;
    display: block;
    margin: 0 auto 30px;
	box-shadow: 0 5px 15px 0 rgb(0 0 0 / 60%);
}

.sc-container .cp-bnr::after {
	position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%;
    background: #ffffff;
    content: "";
}

.sc-container .cp-bnr a:hover,
.sc-container .cp-bnr a:hover img {
	opacity: 0.8;
}

.sc-container .cp-btn-wrap {
	position: relative;
	z-index: 0;
    width: 350px;
    margin: 0 auto;
}

.sc-container .cp-btn-wrap::after {
	position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%;
    border-radius: 60px;
    background: #ffffff;
    content: "";
}

.sc-container .cp-btn {
    display: block;
	position: relative;
    z-index: 1;
    height: 60px;
    border-radius: 60px;
    background-color: #0a7830;
    color: #eeeeee;
    font-weight: bold;
    font-size: 20px;
    line-height: calc(60px - 2px);
    text-align: center;
	letter-spacing: 0.02em;
}

.sc-container .cp-btn:hover {
	opacity: 0.8;
}

/* ====================
nav-area
==================== */
.sc-container .nav-area {
    width: 100%;
    margin: 0 auto 96px;
    padding: 60px 0 70px;
    background: #dcdcdc;
}

.sc-container .nav-title {
	position: relative;
    margin: 0 auto 50px;
    padding: 0 0 5px;
    font-size: 20px;
    text-align: center;
    font-family: 'Poppins', sans-serif;
}

.sc-container .nav-title::before,
.sc-container .nav-title::after {
    display: block;
    position: absolute;
    content: "";
}

.sc-container .nav-title::before {
    top: -100px;
    left: 50%;
    width: 1px;
    height: 80px;
    background: #373737;
    transform: scaleY(0);
}

.sc-container .nav-title.scrollin::before {
	transform: scaleY(1);
}

.sc-container .nav-title::after {
    bottom: 0;
    left: calc(50% - 60px);
    width: 120px;
    height: 1px;
    background: #373737;
}

.sc-container .nav-inner {
    display: -webkit-box;
    display: flex;
    -webkit-box-pack: justify;
    justify-content: space-between;
    width: 980px;
    margin: 0 auto;
}

.sc-container .nav-box {
	width: 300px;
}

.sc-container .nav-box-title {
    display: -webkit-box;
    display: flex;
    -webkit-box-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    align-items: center;
    height: 70px;
    margin: 0 auto 10px;
    padding: 10px 0;
    border: solid 1px #373737;
    font-weight: 500;
    line-height: 1.5;
    text-align: center;
}

.sc-container .nav-list-item {
    position: relative;
}

.sc-container .nav-list-item::before,
.sc-container .nav-list-item::after {
    display: block;
    position: absolute;
    content: "";
}

.sc-container .nav-list-item::before {
	top: calc(50% - 6px);
    left: 9px;
    width: 12px;
    height: 12px;
    background: url(../img/icon_square_pc.png) no-repeat;
    background-size: contain;
    -webkit-transition: .4s;
    transition: .4s;
}

.sc-container .nav-list-item:hover::before {
    background: url(../img/icon_square_o_pc.png) no-repeat;
    background-size: contain;
}

.sc-container .nav-list-item::after {
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background: #373737;
}

.sc-container .nav-list-item-link {
    display: block;
    padding: 16px 0 16px 30px;
    font-size: 14px;
}


/* ====================
intro-area
==================== */
.sc-container .intro-area {
	width: 1000px;
}

.sc-container #design.intro-area {
    margin: 0 auto 115px;
}

.sc-container #function.intro-area {
    margin: 0 auto 120px;
}

.sc-container .intro-title {
    margin: 0 auto 38px;
    font-size: 24px;
    font-weight: 700;
    text-align: center;
    line-height: 1.43;
}

.sc-container .intro-title span {
    display: block;
    margin-top: 3px;
    font-size: 16px;
    font-weight: 600;
    font-family: 'Poppins', sans-serif;
    font-style: italic;
}

.sc-container .intro-list-item {
    display: -webkit-box;
    display: flex;
    -webkit-box-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    align-items: center;
    margin: 0 auto 80px;
}

.sc-container .intro-list-item:nth-child(even) {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
}

.sc-container .intro-list-item-image {
    width: 550px;
    height: 358px;
    text-align: center;
}

.sc-container .intro-list-item-image img {
	width: auto;
    height: 100%;
}

.sc-container .intro-list-item-desc {
	width: 410px;
}

.sc-container .intro-list-item-title {
    margin: 0 0 18px 0;
    font-size: 20px;
    font-weight: 700;
    line-height: 1.43;
}

.sc-container .intro-btn-box {
    display: -webkit-box;
    display: flex;
    -webkit-box-pack: justify;
    justify-content: space-between;
    margin: 34px 0 8px;
}

.sc-container .intro-btn-link {
    display: block;
    width: 200px;
    height: 50px;
    border: solid 1.5px #f3e98d;
    box-sizing: border-box;
	color: #1a1a1a;
    line-height: calc(50px - 5px);
    text-align: center;
    -webkit-transition: .4s;
    transition: .4s;
}


/* ====================
section
==================== */
.sc-container .section {
	position: relative;
	z-index: 0;
    margin: 0 auto 78px;
    padding: 50px 0;
}

.sc-container .section::before {
    display: block;
	position: absolute;
	top: 0;
	z-index: -1;
	width: 100%;
	height: 400px;
	content: "";
}

.sc-container .section-title {
    margin: 0 auto 30px;
    font-size: 24px;
    font-weight: 700;
    text-align: center;
}

.sc-container .section-list {
    display: -webkit-box;
    display: flex;
    -webkit-box-pack: justify;
    justify-content: space-between;
    width: 500px;
    margin: 0 auto 40px;
}
#sec40 .section-list {
    flex-wrap: wrap;
    justify-content: center;
    column-gap: 20px;
    row-gap: 20px;
}

.sc-container .section-list-item {
    /* width: 120px; */
    width: auto;
}

.sc-container .section-list-item-link {
    display: block;
    position: relative;
    padding: 0 0 8px;
    border-bottom: solid 1px #000000;
	color: #1a1a1a;
    font-size: 12px;
    text-align: center;
    line-height: 1;
}

.sc-container .section-list-item-link:hover {
	opacity: 0.8;
}

.sc-container .section-list-item-link span {
    display: block;
    margin-top: 8px;
    font-size: 20px;
    font-weight: 600;
    font-family: 'Poppins', sans-serif;
}

.sc-container .brand-area ~ .brand-area {
    margin: 130px auto 0;
}

.sc-container .brand-intro {
    margin: 0 auto 46px;
}

.sc-container .brand-intro-image {
    width: 690px;
    height: 376px;
    margin: 0 auto 25px;
    text-align: center;
}

.sc-container .brand-intro-image img {
	width: auto;
    height: 100%;
}

.sc-container .brand-intro-title {
    margin: 0 auto 15px;
    font-size: 20px;
    font-weight: 700;
    line-height: 1.5;
    width: 690px;
}

.sc-container .brand-intro-title span {
    margin-left: 13px;
    font-size: 16px;
    font-weight: 700;
    vertical-align: 2px;
}

.sc-container .brand-intro-text {
    width: 690px;
    margin: 0 auto;
}

.sc-container .brand-comment {
    width: 690px;
    margin: 0 auto 60px;
}

.sc-container .brand-comment-title {
    margin: 0 auto 13px;
    font-weight: 700;
    font-size: 18px;
}

.sc-container .brand-comment-list {
    display: -webkit-box;
    display: flex;
    -webkit-box-pack: justify;
    justify-content: space-between;
}

.sc-container .brand-comment-list-item {
    display: -webkit-box;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    position: relative;
    height: 140px;
    padding: 0 30px;
    width: 330px;
}

.sc-container .brand-comment-list-item::after {
	position: absolute;
    bottom: calc(50% - 30px);
    border: 20px solid transparent;
    content: "";
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
}

.sc-container .brand-comment-list-item:nth-child(odd)::after {
    left: -20px;
}

.sc-container .brand-comment-list-item:nth-child(even)::after {
    right: -20px;
}


/* ====================
sc-itemlist-area
==================== */
.sc-container .sc-itemlist {
    display: -webkit-box;
    display: flex;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    justify-content: space-between;
    width: 860px;
    margin: 0 auto 50px;
}

.sc-container .list {
    position: relative;
    width: 200px;
    padding-bottom: 115px;
    text-align: center;
}

.sc-container .item-image {
    display: block;
    position: relative;
    z-index: 0;
}

.sc-container .item-image img {
    width: 100%;
    height: 242px;
    max-height: 242px;
    object-fit: cover;
}
/* 
.sc-container #brand30-02 .list:nth-child(3) .item-image img {
    width: 80%;
} */

.sc-container .item-image:hover img {
	opacity: 0.8;
}

.sc-container .item-name {
	display: block;
    position: absolute;
    bottom: 82px;
    width: 100%;
	color: #1a1a1a;
    margin-top: 8px;
    line-height: 1.5;
}

.sc-container .item-price {
	display: block;
    position: absolute;
    bottom: 58px;
    width: 100%;
    margin-top: 6px;
    padding-left: 0.5em;
	color: #1a1a1a;
    font-size: 18px;
    line-height: 1;
}

.sc-container .tax {
    font-size: 12px;
    vertical-align: 2px;
}

.sc-container .item-btn {
    display: block;
    position: absolute;
    bottom: 0;
    width: 200px;
    height: 40px;
    margin: 18px auto 0;
	color: #1a1a1a;
    line-height: calc(40px - 3px);
    text-align: center;
    -webkit-transition: .4s;
    transition: .4s;
}

.sc-container .brand-btn {
    display: -webkit-box;
    display: flex;
    -webkit-box-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    align-items: center;
    width: 320px;
    height: 60px;
    margin: 0 auto 0;
    text-align: center;
    -webkit-transition: .4s;
    transition: .4s;
}

.sc-container .brand-btn-link {
	color: #1a1a1a;
}

/* 個別指定 */
.sc-container #sec20.section::before {
    background: #77acae;
}

.sc-container #sec20 .brand-comment-title {
	color: #77acae;
}

.sc-container #sec20 .brand-comment-list-item {
	background: #bbd5d6;
}

.sc-container #sec20 .brand-comment-list-item::after {
    border-right: 20px solid #bbd5d6;
}

.sc-container #sec20 .item-btn,
.sc-container #sec20 .brand-btn {
    border: solid 1px #77acae;
}

.sc-container #sec20 .item-btn:hover,
.sc-container #sec20 .brand-btn:hover {
	background: #77acae;
}

.sc-container #sec30.section::before {
    background: #f8b8bb;
}

.sc-container #sec30 .brand-comment-title {
	color: #f8b8bb;
}

.sc-container #sec30 .brand-comment-list-item {
	background: #fbdbdd;
}

.sc-container #sec30 .brand-comment-list-item::after {
    border-right: 20px solid #fbdbdd;
}
/* 
.sc-container #brand30-02 .list:nth-child(4) .item-image img {
    width: 80%;
} */

.sc-container #sec30 .item-btn,
.sc-container #sec30 .brand-btn {
    border: solid 1px #f8b8bb;
}

.sc-container #sec30 .item-btn:hover,
.sc-container #sec30 .brand-btn:hover {
	background: #f8b8bb;
}

.sc-container #sec40.section::before {
    background: #f3e98d;
}

.sc-container #sec40 .section-list {
    width: 620px;
}

.sc-container #sec40 .section-list-item:nth-child(1) {
	width: 300px;
}

.sc-container #sec40 .brand-comment-title {
	color: #f3e98d;
}

.sc-container #sec40 .brand-comment-list-item {
	background: #f9f4c6;
}

.sc-container #sec40 .brand-comment-list-item::after {
    border-right: 20px solid #f9f4c6;
}

.sc-container #sec40 .item-btn,
.sc-container #sec40 .brand-btn {
    border: solid 1px #f3e98d;
}

.sc-container .intro-btn-link:hover,
.sc-container #sec40 .item-btn:hover,
.sc-container #sec40 .brand-btn:hover {
	background: #f3e98d;
}

.sc-container #brand30-03 .brand-btn {
    width: 480px;
}
.sc-container #brand40-01 .brand-btn {
    width: 480px;
}
.sc-container #brand40-04 .brand-btn {
    width: 480px;
}

/* icon */
.sc-container .icon-wrap {
    display: flex;
    justify-content: center;
    position: relative;
    z-index: 1;
    margin-top: 10px;
    column-gap: 10px;
}

.sc-container .icon {
    display: block;
    width: 90px;
    height: 25px;
    margin: 0 auto;
	color: #1a1a1a;
    font-size: 12px;
    line-height: calc(25px - 1px);
    text-align: center;
}

.sc-container #sec20 .icon-other,
.sc-container #sec20 .icon-rsol,
.sc-container #sec20 .icon-sol { background: #bbd5d6; }

.sc-container #sec30 .icon-other,
.sc-container #sec30 .icon-rsol,
.sc-container #sec30 .icon-sol { background: #fbdbdd; }

.sc-container #sec40 .icon-other,
.sc-container #sec40 .icon-rsol,
.sc-container #sec40 .icon-sol { background: #f9f4c6; }


/* ====================
faq-area
==================== */
.sc-container .faq-area {
    margin: 0 auto 78px;
}

.sc-container .faq-title {
	margin: 0 auto 36px;
    font-size: 24px;
    font-weight: 700;
    text-align: center;
    line-height: 1.43;
}

.sc-container .faq-title span {
	display: block;
    margin-top: 3px;
    font-size: 16px;
    font-weight: 600;
    font-family: 'Poppins', sans-serif;
    font-style: italic;
}

.sc-container .faq-list {
	display: -webkit-box;
    display: flex;
    flex-wrap: wrap;
    width: 1000px;
    margin: 0 auto;
}

.sc-container .faq-list-item {
    width: 480px;
    margin: 0 0 32px 40px;
}

.sc-container .faq-list-item:nth-child(2n+1) {
    margin: 0 0 32px 0;
}

.sc-container .faq-list-item-number {
    position: relative;
    margin: 0 auto 20px;
    font-size: 30px;
    font-weight: 600;
    font-family: 'Poppins', sans-serif;
    text-align: center;
}

.sc-container .faq-list-item-number::after {
	display: block;
    position: absolute;
    bottom: 0;
    left: calc(50% - 21px);
    width: 42px;
    height: 1px;
    background: #373737;
    content: "";
}

.sc-container .faq-list-item-title {
	margin: 0 auto 14px;
    font-size: 20px;
    font-weight: 700;
    text-align: center;
}

.sc-container .faq-list-item-image {
    width: 480px;
    height: 216px;
    margin: 0 auto 12px;
    text-align: center;
}

.sc-container .faq-list-item:nth-child(4) .faq-list-item-image {
    height: 224px;
}

.sc-container .faq-list-item-image img {
    width: auto;
    height: 100%;
}

.sc-container .faq-list-item-image a:hover img {
	opacity: 0.8;
}


/* ====================
スクロール
==================== */
/* 伸びるライン */
.nav-title.fadein::before{-webkit-transform-origin: top;transform-origin: top;}
.nav-title.fadein.scrollin::before{-webkit-transition:1s .2s ease;transition:1s .2s ease;}

/* 左からふわっと */
.nav-list-item-link.fadein,
.intro-list-item:nth-child(odd) .intro-list-item-image.fadein,
.brand-comment-list-item:nth-child(odd).fadein {opacity:0;transform:translateX(-40px)}
.nav-list-item-link.fadein.scrollin,
.intro-list-item:nth-child(odd) .intro-list-item-image.fadein.scrollin,
.brand-comment-list-item:nth-child(odd).fadein.scrollin {opacity:1;transition:.8s .4s ease;transform:none}

/* 右からふわっと */
.intro-list-item:nth-child(even) .intro-list-item-image.fadein,
.brand-comment-list-item:nth-child(even).fadein {opacity:0;transform:translateX(40px)}
.intro-list-item:nth-child(even) .intro-list-item-image.fadein.scrollin,
.brand-comment-list-item:nth-child(even).fadein.scrollin {opacity:1;transition:.8s .4s ease;transform:none}

/* 下からふわっと */
.brand-intro-image.fadein,
.item-image.fadein,
.faq-list-item-image.fadein {opacity:0;transform:translateY(40px)}
.brand-intro-image.fadein.scrollin,
.item-image.fadein.scrollin,
.faq-list-item-image.scrollin {opacity:1;transition:.8s .4s ease;transform:none}

/* 左から順に */
.fadein.section-list {opacity:1;transform:none}
.fadein.section-list li {opacity:0;transform:translateX(-40px)}
.fadein.scrollin.section-list li {opacity:1;transition:.8s .2s ease;transform:none}
.fadein.scrollin.section-list li:nth-child(2) {opacity:1;transition:.8s .5s ease;transform:none}
.fadein.scrollin.section-list li:nth-child(3) {opacity:1;transition:.8s .8s ease;transform:none}
