@charset "utf-8";
html {
	scroll-behavior:smooth;
}
body {
	font: normal 18px/1.7 "Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3","メイリオ",Meiryo,"ＭＳ Ｐゴシック",Arial,Verdana,sans-serif;
	text-align: left;
	color:#333;
	text-align: justify;
	overflow-x: hidden;
	line-height: 1.5;
}


body .sp-item {
    display: none !important; }
  body .pc-item {
    display: block !important; }

  @media screen and (max-width: 640px) {
    body {
      min-width: inherit;
	  height:100%;
	  }
      body .sp-item {
        display: block !important; }
      body .pc-item {
        display: none !important; }
	  body .sp-item img {
		width:100%;}
}

@media screen and (max-width: 640px) {
	.sp img{
		max-width:90%;
}
	.sp02 img{
		max-width:100%;
}
.sp03 img{
		max-width:70%;
}
}
.ov_hd {
	overflow: hidden;
}
.bg_none {
	background-image: none!important;
}
.rollover:hover {
	filter: brightness(1.07);
	transition : all 0.3s ease 0s;
}
.center {
	text-align: center;
}
.right {
	text-align:right;
}
.small {
	font-size: 0.7em;
}
.bold {
	font-weight: bold;
}
/* ----------------------------------------------------

    ここから書く

---------------------------------------------------- */
/*共通*/
.sec {
	padding-top: 40px;
	padding-bottom: 40px;
}
.sec-wrap {
	width: 850px;
	max-width: 100%;
	margin: 0 auto;
	box-sizing: border-box;/
}
.sec-wrap-inner {
	padding: 0;
}
.wrap-inner {
	padding:0 2%;
}
img {
	width: 100%;
}
.pink {
	color: #E73645;
}
.yellow-line {
	background: linear-gradient(transparent 0%,#FFFFDD 0%);
}
@media screen and (max-width: 640px) {
	.sec {
		padding-top: 30px;
	padding-bottom: 30px;
	}
	.sec-wrap {
		width: 100%;
	}
	.sec-wrap-inner {
		padding: 0 2%;
	}
	.autoimg img {
		width: 100%;
	}
}
/* ----------------------------------------------------
ヘッダー
---------------------------------------------------- */
nav {
	background-color: #fff;
	opacity: 0.95;
	width: 100%;
	position: fixed;
	right: 0;
	top: 0;
	z-index: 100;
	box-shadow: 0px 6px 6px -6px rgba(0, 0, 0, 0.1);
}
nav ul {
	font-size: 15px;
	font-weight: bold;
	height: 50px;
	display: flex;
	justify-content: center;	
	align-items: center;
}
nav ul .item {
	padding: 0 1em;
}
nav ul .item a {
	text-decoration: none;
	color: #333;
	transition : all 0.3s ease 0s;
}
nav ul .item a:hover {
	color: #666;
}
@media screen and (max-width: 640px) {
	nav ul {
		font-size: 12px;
	}
	nav ul .item {
		padding: 0 0.6em;
	}
}
/* ----------------------------------------------------
sec1 メインビジュアル
---------------------------------------------------- */
.sec1 {
	background:url(../images/mv-bg.webp) top center no-repeat;
	background-size: cover;
}
.sec1-wrap {
	width: 1000px;
	max-width: 100%;
	margin: 0 auto;
}
.sec1 h1 {
	padding-top:90px;
	padding-bottom: 40px;
	}
@media screen and (max-width: 640px) {
	.sec1 {
		background:url(../images/s-mv-bg.webp) top center no-repeat;
		background-size: cover;
	}
	.sec1-wrap {
		width: 100%;
	}
	.sec1 h1 {
		padding-top:80px;
		padding-bottom: 30px;
		}
}
/* ----------------------------------------------------
sec2
---------------------------------------------------- */
.sec2 {
	background:url(../images/sec2-bg.webp) top center no-repeat;
	background-size: cover;
	padding: 40px 0 80px;
}
.sec2 h2:before {
	content: "";
	display: block;
	height: 60px;
	margin-top: -60px;
	visibility: hidden;
}
.sec2 h2 {
	padding-bottom: 40px;
}
.sec2 p {
	color: #fff;
	text-align: center;
	font-size: 20px;
	line-height: 2;
	letter-spacing: 0.06em;
}
.t-bottom {
	padding-bottom: 40px;
}
@media screen and (max-width: 640px) {
	.sec2 {
		background:url(../images/s-sec2-bg.webp) top center no-repeat;
		background-size: cover;
	}
	.sec2 h2 {
		padding-bottom: 30px;
	}
	.sec2 p {
		font-size: 16px;
	}
	.t-bottom {
		padding-bottom: 30px;
	}
}
/* ----------------------------------------------------
sec3
---------------------------------------------------- */
.sec3 {
	background:url(../images/sec3-bg.webp) top center no-repeat;
	background-size: cover;
}
.sec3 h2:before {
	content: "";
	display: block;
	height: 60px;
	margin-top: -60px;
	visibility: hidden;
}
.sec3 h2 {
	padding-bottom: 80px;
}
.product-list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.product-item {
	width: 47%;
	margin-bottom: 20px;
	padding: 0px;
	box-sizing: border-box;
}
.product-item h3 {
	font-size: 18px;
	font-weight: bold;
}
.product-item p {
	font-size: 16px;
}
@media screen and (max-width: 640px) {
	.sec3 {
		background:url(../images/s-sec3-bg.webp) top center repeat-y;
		background-size: contain;
	}
	.sec3 h2 {
		padding-bottom: 30px;
	}
	.product-list {
		justify-content: space-around;
	}
	.product-item {
		width: 90%;
		margin-bottom: 30px; 
}
.product-item h3 {
	font-size: 17px;
	font-weight: bold;
}
.product-item p {
	font-size: 15px;
}
}
/* ----------------------------------------------------
sec4
---------------------------------------------------- */
.sec4 {
	background:url(../images/sec4-bg.webp) top center no-repeat;
	background-size: cover;
}
.sec4 h2 {
	padding-bottom: 60px;
}
.sec4 p {
	max-width: 468px;
	margin: 0 auto;
}
@media screen and (max-width: 640px) {
	.sec4 {
		background:url(../images/s-sec4-bg.webp) top center no-repeat;
		background-size: cover;
	}
	.sec4 h2 {
		padding-bottom: 30px;
	}
	.sec4 p {
		max-width: 100%;
		margin: 0 auto;
	}
}
/* ----------------------------------------------------
sec5
---------------------------------------------------- */
.sec5 {
	background:url(../images/sec5-bg.webp) top center no-repeat;
	background-size: cover;
}
.sec5 h2:before {
	content: "";
	display: block;
	height: 60px;
	margin-top: -60px;
	visibility: hidden;
}
.sec5 h2 {
	padding-bottom: 80px;
}
.sec5 p {
	padding-bottom: 80px;
}
.sec5 p:nth-child(n+8) {
	padding-bottom: 40px;
}
@media screen and (max-width: 640px) {
	.sec5 {
		background:url(../images/s-sec5-bg.webp) top center no-repeat;
		background-size: cover;
	}
	.sec5 h2 {
		padding-bottom: 30px;
	}
	.sec5 p {
		padding-bottom: 50px;
	}
	.sec5 p:nth-child(n+8) {
		padding-bottom: 50px;
	}
	.sec5 p:nth-child(n+9) {
		padding-bottom: 20px;
	}
}
/* ----------------------------------------------------
sec6
---------------------------------------------------- */
.sec6 {
	background-color: #F2F2F2;
}
.sec6 h2:before {
	content: "";
	display: block;
	height: 60px;
	margin-top: -60px;
	visibility: hidden;
}
.sec6 h2 {
	padding-bottom: 80px;
}
.shop-box {
	background-color: #fff;
	border-radius: 20px;
	padding: 40px;
	box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.07);
	display: flex;
	flex-wrap: wrap; /* 商品が複数行にわたるように設定 */
	justify-content: space-around;
}
.list-shop {
	width: 45%;
	box-sizing: border-box;
}
.list-shop h3 {
	font-size: 18px;
	font-weight: bold;
	text-align: center;
	padding-bottom: 40px;
}
.shop-btn {
	background-color: #2078B7;
	max-width: 337px;
	margin: 0 auto 20px;
	padding: 0.7em 0.7em 0.7em 2em;	
	background-image: url(../images/sec6-icon.webp);
	background-repeat: no-repeat;
	background-size: 1em;
	background-position: right 1em top 50%;
	transition : all 0.3s ease 0s;
}
.last-btn {
	margin: 0 auto;
}
.shop-btn p {
	font-size: 16px;
	color: #fff;
}
.shop-item {
	text-decoration: none;
}
@media screen and (max-width: 640px) {
	.sec6 h2 {
		padding-bottom: 30px;
	}
	.shop-box {
		background-color: #fff;
		border-radius: 20px;
		padding: 25px;
		box-shadow: 0px 0px 15px 0px rgba(0, 0, 0, 0.07);
	}
	.list-shop {
		width: 95%;
	}
	.list-shop h3 {
		font-size: 17px;
		font-weight: bold;
		text-align: center;
		padding-bottom: 20px;
	}
	.shop-btn {
		background-color: #2078B7;
		max-width: 100%;
		margin: 0 auto 20px;
		padding: 0.7em 0.7em 0.7em 2em;	
		background-image: url(../images/sec6-icon.webp);
		background-repeat: no-repeat;
		background-size: 0.8em;
		background-position: right 1em top 50%;
		transition : all 0.3s ease 0s;
	}
	.shop-btn p {
		font-size: 15px;
	}
}
/* ----------------------------------------------------
sec7
---------------------------------------------------- */
.sec7 {
	background-color: #CCCCCC;
}
.sec7 p {
	font-size: 15px;
	line-height: 1.5;
}
.footer {
	display: flex;
	align-items: center;
	justify-content: start;
}
.company {
	padding-right: 20px;
}
@media screen and (max-width: 640px) {
	.sec7 {
		padding-bottom: 70px;
	}
	.sec7 p {
		font-size: 14px;
		line-height: 1.5;
	}
	.footer {
		display: block;	
	}
	.company {
		padding-right: 0px;
		
		padding-bottom: 30px;
	}
	.logo {
		max-width: 185px;
		margin: 0 auto;
	}
}
/* ----------------------------------------------------
下部固定ボタン
---------------------------------------------------- */
.fixd-btn {
	background-color: #008080;
	padding: 0.7em 0.7em 0.7em 2em;	
	background-image: url(../images/sec6-icon.webp);
	background-repeat: no-repeat;
	background-size: 1em;
	background-position: right 1em top 50%;
	transition : all 0.3s ease 0s;
}
#floating a {
	font-size: 16px;
	color: #fff;
	text-decoration: none;
}
#floating {
	position: fixed;
	width: 250px;
	right: 8px;
	bottom: 8px;
	z-index: 100;
	visibility: hidden;
	transition: .5s;
	opacity: 0;
}
#floating.on {
	visibility: inherit;
	opacity: 1;
}

@media screen and (max-width: 640px) {
	.fixd-btn {
		background-color: #008080;
		padding: 0.7em 0.7em 0.7em 2em;	
		background-image: url(../images/sec6-icon.webp);
		background-repeat: no-repeat;
		background-size: 0.8em;
		background-position: right 1em top 50%;
		transition : all 0.3s ease 0s;
	}
	#floating a {
		font-size: 15px;
	}
	#floating {
		position: fixed;
		width: 85%;
		right: 0px;
		left: 50%;
		transform: translateX(-50%);
		bottom: 8px;
		z-index: 100;
	}
}

