@charset "utf-8";
/* reset */
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
	margin: 0; padding: 0; border: 0; font: inherit;	vertical-align: baseline;	box-sizing: border-box;	-box-sizing: border-box;}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {display: block;}
ol, ul {list-style: none;}

html {
	font-family: sans-serif;
	-webkit-text-size-adjust: 100%;
	font-family: 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', 'Meiryo', "メイリオ", sans-serif;
}

a {
	text-decoration: none;
	color: #0f91ff;
}

a:hover {
	opacity: 0.7;
}
body {
	color: #535353;
	line-height: 1.5;
}

header {
	padding: 4.6% 5.3%;
}
header img {
	display: inline;
	max-width: 31%;
	vertical-align: middle;
	margin-right: 10px;
}

header .code {
	font-size: 2vw;
}

.tCenter {
	text-align: center;
}

main .wrap {
	padding: 0 7vw 7.6vw;
	background-color: #a0d992;
}

.kvArea {
	margin: 0 calc(50% - 50vw);
	width: 100vw;
	display: block;
	background-image:url(/oos/adv/image/tmp_219/img_bg_sp.png);
	background-repeat: no-repeat;
	background-position: top left;
	background-size: 100% auto;
	padding: 5.7% 7vw;
}

img {
	display: block;
	width: auto;
	max-width: 100%;
	margin:auto;
}

h1,h2,h3,h4 {
	font-weight: bold;
}

h2 {
	font-size: 1.357rem;
	text-align: center;
	color: #1f5a38;
}

h3.type02 {
	font-size: 1rem;
	color: #fff;
	background: #1f5a38;
	min-width: 53%;
	height: 20px;
}

.wrap >section {
	margin: auto;
	margin-top: 7.6vw;
}

.wrap >section:not(:first-of-type) {
	background-color: #fff;
	padding: 6.8% 3.8%;
}
.wrap > section#accordion {
	padding: 0;
}

.wrap section > *:not(:first-child) {
	margin-top: 4vw;
}
.wrap section > * > *:not(:first-child) {
	margin-top: 4vw;
}
.wrap section > * > li {
	margin-top: 0 !important;
}
.wrap section > [class^="list_"] {
	margin-top: 2vw;
}
[class^="list_"] {
	padding-left: 1rem;
}
[class^="list_"] > * {
	display: block;
	text-indent: -1.3rem;
}
[class^="list_"] > *:before {
	margin-right: 0.3rem;
}
[class^="list_note"] > *:before {
	content: "※";
}
[class^="list_circle"] > *:before {
	content: "・";
	color: #1f5a38;
}
.list_circle li {
	margin-bottom: 5px;
}
.list_note_01 {
	color: #1f5a38;
}
.list_note_02 {
	margin-top: 20px;
}
.list_circle.blue > *:before {
	content: "・";
	color: #0f91ff;
}
.campaignStep {
	background: none;
}

.campaignStepList li {
	background: #fff;
	position: relative;
	text-align: center;
	vertical-align: middle;
	width: 100%;
	height: 33vw;
}
.campaignStepList li:not(:last-child) {
	margin-bottom: 3rem;
}

.campaignStepList li:not(:last-child)::after {
	content: "";
	display: block;
	position: absolute;
	bottom: -2.1rem;
	right: 50%;
	transform: translatex(50%);
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 1.25rem 1.1rem 0 1.1rem;
	border-color: #1f5a38 transparent transparent transparent;
}
 .campaignStepList li img {
	position: absolute;
	top: 40%;
	left: 3%;
	transform: translateY(-40%);
	width: 30%;
}
.campaignStepList li{
	padding: 1rem 0;
}
.campaignStepList li h3, .campaignStepList li p {
	position: absolute;
	left: 40%;
	padding-right: 5px;
}
.campaignStepList li h3 {
	top: 10%;
	font-size: 1.071rem;
	color: #1f5a38;
}
.campaignStepList li h3 span {
	font-size: 1.142rem;
}
.campaignStepList li p {
	top: 30%;
	transform: translateX(0);
	text-align: left;
	width: 60%;
	margin-top: 5px;
	font-size: 1rem;
	font-weight: bold;
}
.appNote {
	width: 65%;
}

.btn_account {
	font-size: 1.166rem;
	height: 16vw;
	margin-top: 1rem;
	margin-bottom: 1rem;
	display: block;
	width: 100%;
	background: #fb8843;
	box-shadow: 0.3rem 0.38rem 0 0 #c4875a;
	border-radius: 10px;
	font-weight: 500;
	color: #fff;
	position: relative;
	margin: auto;
	text-align: center;
	margin-bottom: 0.38rem;
}
.btn_account:hover {
	text-decoration: none;
	opacity: 0.7;
}
.btn_account span:first-child {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateY(-50%) translateX(-50%);
	width: 100%
}
.btn_account span:last-child {
	position: absolute;
	top: 50%;
	right: 5%;
	transform: translateY(-50%);
}
.btn_account .link_window {
	 display: block;
	 margin: auto;
 }

 .btn_02 {
	 margin-top: 7.6vw;
	 margin-bottom: calc(7.6vw + 0.3rem);
 }

 .btn_03 {
	font-size: 1.8rem;
	box-shadow: 0 5px 5px rgba(0,0,0,.2);
	border-radius: 5px;
	background-image: -moz-linear-gradient( -90deg, rgb(255,155,97) 1%, rgb(224,124,60) 75%, rgb(193,92,23) 100%);
	background-image: -webkit-linear-gradient( -90deg, rgb(255,155,97) 1%, rgb(224,124,60) 75%, rgb(193,92,23) 100%);
	background-image: -ms-linear-gradient( -90deg, rgb(255,155,97) 1%, rgb(224,124,60) 75%, rgb(193,92,23) 100%);
	width: 80%;
	margin-bottom: 5vw;
}
.btn_03 span:first-child::before {
	position: absolute;
	content: "";
	background-image: url(/oos/adv/image/tmp_217/btn_03_icon.png);
	top: 50%;
	transform: translateY(-50%);
	left: 1rem;
	width: 20px;
	height: 38px;
	background-size: contain;
	vertical-align: middle;
}
.appli_download ul {
	display: inline-block;
	width: 100%;
}
.appli_download li {
	display: inline-block;
	text-align: center;
	width: 45%;
}
.appli_download li:first-child {
	margin-right: 8%;
}
.appli_download li img {
	width: 100%;
}
.appli_download h3 {
	font-size: 1.142rem;
	margin-bottom: 2.8%;
	display: block;
	color: #1f5a38;
}
.secGaiyou h3{
	max-width: 400px;
	width: 70%;
	color: #fff;
	display: block;
	margin: auto;
	background: #1f5a38;
	text-align: center;
	line-height: 2;
	margin-bottom: 20px;
}
.secGaiyou > section:not(:last-child) {
	margin-bottom: 2.333rem;
}
.link_window {
	display: inline-block;
	width: 1rem;
	margin: 0 0.3rem;
	vertical-align: initial;
}

.strong {
	font-weight: bold;
}
[class^="fontStrong"] {
	font-weight: bold;
	font-size: 4vw;
	text-align: center;
}

.fontStrong01 {
	font-weight: bold;
	font-size: 4.2vw;
}

.fontStrong02 {
	font-weight: inherit;
}
.fontStrong02 span {
	display: inline-block;
	position: relative;
}
.fontStrong02 span::after{
	position: absolute;
	content: " ";
	display: inline-block;
	bottom: 0;
	left: 0;
	width: 100%;
	border-bottom: solid 1px #535353;
}
.fontStrong03 {
	color: #c5601c;
}
.fontStrong04 {
	color: red;
	font-size: inherit;
	font-weight: inherit;
}

[class^="colorBox"] {
	padding: 4vw;
}
.colorBox_01 {
	background: #e0f1cd;
}
.colorBox_02 {
	background: #edc1b3;
}
[class^="colorBox"] h3 {
	padding: 0 10px;
	line-height: 2;
	color: #fff;
	display: inline-block;
	border-radius: 20px;
	width: auto;
	text-align: left;
}
.colorBox_01 h3 {
	background: #619a21;
}
.colorBox_02 h3 {
	background: #e65600;
}
.list_circle_02 > *:before {
    content: "●";
    color: #e65600;
}

#accordion .accordion-content {
	border: solid 4px #1f5a38;
	border-top: none;
	box-sizing: border-box;
	padding: 4vw;
	margin-top: 0;
	line-height: 2;
}
.accordion-container .accordion-title {
  position: relative;
  margin: 0;
	cursor: pointer;
	padding: 35px 0;
	text-align: center;
	border: solid 6px #1f5a38;
	line-height: 0;
	box-sizing: border-box;
}
.accordion-container .accordion-title:hover {
	opacity: 0.8;
}
.accordion-container .accordion-title::before {
  content: "";
  position: absolute;
  top: 48%;
  right: 4vw;
  width: 30px;
  height: 5px;
  /*縦線に*/
  transform: rotate(90deg);
  background: #1f5a38;
  transition: all .3s ease-in-out;
}
.accordion-container .accordion-title::after {
  content: "";
  position: absolute;
  top: 48%;
  right: 4vw;
  /*横線*/
  width: 30px;
  height: 5px;
  background: #1f5a38;
  transition: all .2s ease-in-out;
}
.accordion-container .accordion-title.open::before {
  transform: rotate(180deg);
}
.accordion-container .accordion-title.open::after {
  opacity: 0;
}

footer {
    padding: 0.8rem 1.1rem;
}

.footerContents {
	width: 100%;
	max-width: 1080px;
	margin: auto;
	text-align: right;
}
.footerContents p {
	font-size: 1rem;
	font-weight: bold;
}
.footerContents *:not(:first-child) {
	margin-top: 0.625rem;
}
.footerContents small {
	display: block;
	font-size: 0.857rem;
}
footer .logoArea {
	text-align: center;
}
.footerContents .logoArea img {
    width: 40%;
}

.pagetop {
    display: none;
    position: fixed;
    bottom: 1rem;
    right: 1.3rem;
}

/* 768px以下のみ指定 (スマホのみ) */
@media (max-width: 767px){
	html {
	font-size: 14px;
	}
	.spNone {
		display: none;
	}
	.pagetop {
		bottom: 1.6rem;
		right: 0;
	}
	.pagetop img {
		width: 60%;
	}
}
/* スマホサイズ以上 */
@media (min-width: 768px) {
	html {
		font-size: 18px;
	}
	.appli_download li {
    width: 46%;
	}
	.appli_download li:first-child {
    margin-right: 5%;
	}
	.appli_download li img {
		width: 60%;
		display: inline-block;
		vertical-align: middle;
	}
	.appli_download li span img {
		width: 30%;
	}
	.appli_download li {
    display: inline-block;
		text-align: center;
	}
		[class^="fontStrong"] {
		font-size: 1.222rem;
	}
	.fontStrong04 {
		font-size: inherit;
	}
	.fontStrong01 {
		font-size: 1.222rem;
	}
	.btn_account .link_window {
		width: auto;
	}
}
/* デバイス幅がPCコンテンツ幅以上 */
@media (min-width: 1080px) {
	/* html {
		font-size: 18px;
	} */
	.kvArea {
	width: 100%;
	margin: 0;
	padding: 37px 0 55px;
	}
	header {
    width: 100%;
    max-width: 1080px;
    box-sizing: border-box;
    margin: auto;
    padding: 8px 9px;
	}
	header .code {
    font-size: 0.75rem;
	}
	main .wrap {
		padding: 0 0 7.6vw;
	}
	.wrap > section {
		width: 1080px;
		margin-top: 100px;
	}
	.wrap section > *:not(:first-child) {
		margin-top: 50px;
	}
	.wrap section > * > *:not(:first-child) {
		margin-top: 25px;
	}
	.wrap section > * > li {
	margin-top: 0 !important;
	}
	.wrap section > [class^="list_"] {
		margin-top: 20px;
	}
	.wrap section h4 + .list_circle {
		margin-top: 10px;
	}
	.pcNone {
		display: none;
	}
	.wrap >section:not(:first-of-type) {
		padding: 3.75rem;
	}
	h2 {
		font-size: 1.666rem;
	}
	.btn_account {
		font-size: 1.666rem;
	}
	.appli_download h3 {
		font-size: 1.333rem;
	}
	.secGaiyou h3 {
		font-size: 1.111rem;
	}
	.appNote {
		width: auto;
		max-width: 100%;
	}
	.wrap > section#accordion {
		padding: 0;
	}
	section.campaignStep {
		padding: 0 30px;
	}
	.campaignStepList {
		width: 1000px;
	}
	.campaignStepList li:not(:last-child) {
		margin-right: 26px;
		margin-bottom: 0;
	}
	.campaignStepList li {
		width: 310px;
    height: 300px;
		padding: 20px 0;
		display: inline-block;
		text-align: center;
		position: relative;
	}
	.campaignStepList li:not(:last-child)::after {
    bottom: 50%;
    transform: translateY(50%);
    right: -28px;
    border-width: 18px 0 18px 20px;
    border-color: transparent transparent transparent #1f5a38;
	}
	.campaignStepList li img {
    top: 40%;
		left: 50%;
		width: auto;
    transform: translateY(-40%) translateX(-50%);
	}
	.campaignStepList li p {
    width: 100%;
    top: 225px;
    left: 50%;
		transform: translateX(-50%);
		text-align: center;
	}
	.btn_account {
		width: 900px;
		max-width: 100%;
		height: 100px;
	}
	.secGaiyou > section:not(:last-child) {
		margin-bottom: 50px;
	}

	.btn_02 {
		height: 160px;
		margin-top: 100px;
		margin-bottom: calc(100px + 0.3rem);
	}
	.btn_03 {
		width: 300px;
		height: 80px;
	}
	.btn_03 span:first-child::before {
		width: 26px;
		height: 48px;
	}

	[class^="colorBox"] {
		padding: 30px;
	}
	.footerContents .logoArea img {
		width: auto;
	}
	.box_01 {
		width: auto;
		display: block;
		text-align: center;
	}
	.box_01 p, .box_01 img {
		display: inline-block;
		margin: 0;
		margin-top: 0 !important;
		vertical-align: middle;
	}
	.box_01 p:first-of-type {
		margin-right: 1rem;
	}
	.fontStrong02 span::after {
		border-bottom: none;
	}
	.fontStrong02 {
		position: relative;
		display: inline-block;
	}
	.fontStrong02::after {
		position: absolute;
    content: " ";
    display: inline-block;
    bottom: 0;
    left: 0;
    width: 100%;
    border-bottom: solid 1px #535353;
	}

} /* PC表示 */


/* iphone5等小さめのスマホ対応 */
@media (max-width: 320px) {
	.btn_03 {
		font-size: 1.6rem;
	}
	.btn_02 {
		height: 18vw;
	}
	.btn_account span:last-child {
		right: 3%;
	}
}