@charset "utf-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@200..900&family=Noto+Serif+JP:wght@200..900&family=Roboto:wght@100..900&display=swap');

html,body{
	font-family:YakuHanJP,Roboto,'Noto Sans JP','Noto Serif JP',sans-serif;
	font-weight:400;
	font-size:1.0em;
	line-height:2.0em;
	box-sizing: border-box;
	font-feature-settings:"palt";
	margin:0;
	padding:0;
	position:relative;
	background-color: transparent;}

img	{vertical-align:bottom;}
*	{text-align:justify;}

@media (max-width: 640px) {
.sp	{display:inline !important;}
}

/*---------------
  body
---------------*/
body {
	min-height: 100vh;

	background:
	/* 上段：最上部の縦グラデーション */
	linear-gradient(
		to bottom,
		#f2c873 0%,
		rgba(242, 200, 115, 0) 300px
	) top center / 100% 300px no-repeat,

	/* 中段：中央上に画像配置、縦方向リピート */
	url("../../../img/camp/premium_coupon/back.png") top center / auto repeat-y,

	/* 下段：最背面の全画面グラデーション */
	linear-gradient(
		to right,
		#fcf6d4 0%,
		#f8dfda 100%
	) top center / 100% 100% no-repeat;}

@media (max-width: 640px) {
body {
	background:
	linear-gradient(
		to bottom,
		#f2c873 0%,
		rgba(242, 200, 115, 0) 300px
	) top center / 100% 300px no-repeat,

	url("../../../img/camp/premium_coupon/back.png") top center / 100% auto repeat-y,

	linear-gradient(
		to right,
		#fcf6d4 0%,
		#f8dfda 100%
	) top center / 100% 100% no-repeat;}
}



/*---------------
  header
---------------*/
header{
	width:1100px;
	margin:30px auto 50px;
	display:flex;
	flex-direction:column;
	justify-content:center;
	align-items:center;}

header .comingsoon{
	width:890px;
	height:80px;
	margin-bottom:10px;}

header .head_title{
	width:860px;
	height:163px;
	margin-bottom:40px;}

header .head_title.v260901{
	width:900px;
	height:auto;
	margin-bottom:30px;}

header .main{
	width:100%;
	margin-top:-10px;}

@media (max-width: 640px){
header{
	width:calc(100% - 40px);
	margin:20px auto;}

header .comingsoon{
	width:100%;
	height:auto;
	margin-bottom:5px;}

header .head_title{
	width:100%;
	height:auto;}

header .head_title.v260901{
	width:100%;
	height:auto;
	margin-bottom:20px;}

header .main{
	margin-top:-5px;}
}



/*---------------
  article
---------------*/
article{
	width:1100px;
	margin:0 auto;}

article a{
	color:#ea5514;}

@media (max-width: 640px){
article{
	width:calc(100% - 40px);}
}



/*---------------
  section / 共通
---------------*/
section{
	position:relative;
	overflow:hidden;
	width:1100px;
	margin:0 auto 50px;
	border-radius:50px;
	padding:50px;
	background:#fff;
	box-shadow:3px 3px 5px 0px rgba(0, 0, 0, 0.15);
	box-sizing:border-box;}

section h2{
	position: relative;
	width:100%;
	display: inline-block;
	font-size:2em;
	letter-spacing:0;
	isolation: isolate;}

section h2::before{
	content: "";
	position: absolute;
	left: -0.15em;
	right: -0.15em;
	top: 20px;
	height: 30px;
	background: rgba(245, 211, 143, 0.5);
	border-radius: 10px;
	z-index:-1;}

section ul{
	display:flex;
	justify-content:space-between;}

section ul li{
	width:calc(50% - 20px);
	padding:20px;
	border-radius:25px;
	box-sizing:border-box;}

section ul li:nth-child(odd){
	background:rgba(155,216,226,0.15);}

section ul li:nth-child(even){
	background:rgba(241,158,174,0.15);}

section ul li h3{
	display:block;
	font-size:1.6em;
	letter-spacing:0;
	text-align:center;
	margin-bottom:20px;}

section ul li .sub_title{
	text-align:center;
	font-size:1.4em;
	font-weight:600;
	padding-bottom:10px;
	border-bottom:2px solid #fff;
	margin-bottom:10px;}

@media (max-width: 640px){
section{
	width:100%;
	padding:20px;
	margin:0 auto 30px;}

section h2{
	position: relative;
	width:100%;
	display: inline-block;
	font-size:1.4em;
	line-height:1.5em;
	isolation: isolate;
	margin-bottom:10px;}

section ul{
	display:flex;
	flex-direction:column;}

section ul li{
	width:100%;
	padding:20px;}

section ul li:nth-child(odd){
	margin-bottom:20px;}

section ul li h3{
	font-size:1.4em;
	margin-bottom:15px;}
}



/*---------------
  whats / クーポンってなに？
---------------*/
section.whats h2{
	text-align:left;}

section.whats::before{
	content: "";
	background: url("../../../img/camp/premium_coupon/01.png") center / contain no-repeat;
	position: absolute;
	bottom:0;
	right:20px;
	width:340px;
	height:310px;
	z-index:10;}

section.whats .txt_l{
	font-size:2em;
	line-height:1.5em;
	color:#ea5514;}

section.whats .txt_l span{
	font-size:1rem;
	line-height:1.5em;
	color:#000;}

@media (max-width: 640px){
section.whats{
	padding:20px 20px 0;}

section.whats h2{
	text-align:center;}

section.whats::before{
	display:none;}

section.whats .txt_l{
	font-size:1.5em;
	line-height:1.5em;}

section.whats .photo{
	display:block !important;
	margin-top:15px;
	text-align:center;}

section.whats .photo img{
	width:80%;}
}



/*---------------
  usage / クーポンでできること
---------------*/
section.usage li .photo{
	text-align:center;
	margin-bottom:20px;}

section.usage li .photo img{
	max-width:80%;
	max-height:320px;}



/*---------------
  simple / シンプルに使える
---------------*/
section.simple li{
	padding:20px 0;}

section.simple li .photo img{
	width:100%;}

section.simple .simple_otoku{
	margin-top:20px;}

section.simple .simple_otoku h3{
	display:block;
	text-align:center;
	font-size:1.8em;
	line-height:1.8em;
	color:#ea5514;}

section.simple .simple_otoku p{
	text-align:center;}

@media (max-width: 640px){
section.simple .simple_otoku{
	margin-top:20px;}

section.simple .simple_otoku h3{
	font-size:1.4em;
	line-height:1.4em;
	margin-bottom:10px;}

section.simple .simple_otoku p{
	text-align:justify;}

section.simple .simple_otoku p.indent{
	text-indent:-1em;
	padding-left:1em;}
}



/*---------------
  category / カテゴリー
---------------*/
section.category .copy{
	margin-bottom:30px;}

section.category .copy h3{
	display:block;
	text-align:center;
	font-size:1.4em;
	line-height:1.8em;
	color:#000;}

section.category .copy h3 span{
	color:#ea5514;}

section.category .icon{
	display:flex;
	justify-content:center;
	flex-wrap:wrap;
	gap:40px 5%;}

section.category .icon img{
	width:30%;}

@media (max-width: 640px){
section.category .copy{
	margin-top:25px;
	margin-bottom:15px;}

section.category .copy h3{
	font-size:1.2em;
	line-height:1.4em;
	margin-bottom:0px;}

section.category .icon{
	display:flex;
	justify-content:center;
	flex-wrap:wrap;
	gap:20px 5%;}

section.category .icon img{
	width:47%;}
}



/*---------------
  osusume / おすすめ
---------------*/
section.osusume .icon{
	display:flex;
	justify-content:center;
	flex-wrap:wrap;
	gap:20px 0;}

section.osusume .icon div{
	width:50%;}

section.osusume .icon div.all{
	width:100%;
	text-align:center;}

section.osusume .icon img{
	width:auto;}

@media (max-width: 640px){
section.osusume .icon{
	margin-top:25px;
	margin-bottom:10px;
	gap:5px;}

section.osusume .icon div{
	width:100%;}

section.osusume .icon div.all{
	text-align:left;}

section.osusume .icon div img{
	width:100%;}
}



/*---------------
  service / ちょっと豊かにするサービス
---------------*/
article.service{
	position:relative;
	overflow:hidden;
	width:100%;
	margin:0;
	border-radius:0;
	padding:50px 0;
	background:rgba(255,255,255,0.9);
	box-shadow:none;
	box-sizing:border-box;}

article.service section{
	position:relative;
	overflow:hidden;
	width:1100px;
	margin:0 auto;;
	border-radius:0;
	padding:0;
	background:none;
	box-shadow:none;
	box-sizing:border-box;}

article.service h2{
	position: relative;
	width:100%;
	display: inline-block;
	font-size:2em;
	margin-bottom:20px;
	letter-spacing:0;
	isolation: isolate;}

article.service section h2::before{
	display:none;}

article.service .copy{
	margin-bottom:30px;}

article.service .copy h3{
	display:block;
	text-align:center;
	font-size:1.4em;
	line-height:1.8em;
	font-weight:500;
	color:#000;}

article.service .block{
	display:flex;
	justify-content:space-between;
	align-items:center;
	gap:50px;}

article.service .block .text{
	width:calc(100% - 370px);}

article.service .block .btn{
	margin-bottom:30px;}

article.service .block .btn a{
	display:flex;
	flex-direction:column;
	align-items:center;
	padding:20px 15px 15px;
	border-radius:30px;
	color:#fff;
	background:#009865;
	text-decoration:none;
	box-shadow:3px 3px 5px 0px rgba(0, 0, 0, 0.15);
	transition:0.3s;}

article.service .block .btn a:hover{
	background:#fff;
	color:#009865;}

article.service .block .btn a h4{
	font-size:1.8em;
	line-height:1.5em;
	font-weight:800;
	text-align:center;
	margin-bottom:5px;}

article.service .block .text p{
	line-height:1.8em;}

article.service .block .text .indent{
	text-indent:-1em;
	padding-left:1em}

article.service .block .photo{
	width:370px;}

article.service .start{
	width:890px;
	margin-top:50px;
	text-align:center;
	padding:15px 10px;
	font-size:2.0em;
	font-weight:700;
	color:#fff;
	background:#c00000;
	border-radius:15px;
	box-sizing:border-box;}

header .start{
	width:890px;
	margin-top:20px;
	margin-bottom:30px;
	text-align:center;
	padding:10px;
	font-size:1.8em;
	font-weight:700;
	color:#fff;
	background:#c00000;
	border-radius:15px;
	box-sizing:border-box;}

@media (max-width: 640px){
article.service{
	width:100%;
	padding:30px 20px;}

article.service section{
	position:relative;
	overflow:hidden;
	width:100%;
	margin:0 auto;
	border-radius:0;
	padding:0;
	background:none;
	box-shadow:none;
	box-sizing:border-box;}

article.service .copy{
	margin-bottom:20px;}

article.service .block{
	display:flex;
	flex-direction:column-reverse;
	gap:20px;}

article.service .block .btn{
	margin-bottom:20px;}

article.service .block .text{
	width:100%;}

article.service .block .photo{
	width:75%;}

article.service .block .photo img{
	width:100%;}

article.service .start{
	width:100%;
	margin-top:20px;
	text-align:center;
	padding:10px;
	font-size:1.2em;
	font-weight:700;
	color:#fff;
	background:#c00000;
	border-radius:15px;
	box-sizing:border-box;}

header .start{
	width:100%;
	margin-top:20px;
	text-align:center;
	padding:10px;
	font-size:1.2em;
	font-weight:700;
	color:#fff;
	background:#c00000;
	border-radius:15px;
	box-sizing:border-box;}
}



/*---------------
  topに戻るボタン
---------------*/
.float-button__wrap {
	display: none;/*最初は隠す*/
	width: 75px;
	height: 75px;
	position: fixed;
	bottom: 140px;
	right: 20px;
	z-index: 10;}

.float-button__wrap a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	text-decoration: none;}

@media screen and (max-width:640px){
.float-button__wrap {
	width: 50px;
	height: 50px;
	bottom: 20px !important;}
}