@charset "UTF-8";

/*==================================================
* Reset
==================================================*/

html {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	overflow-y: scroll;
	-webkit-text-size-adjust: 100%;
}

*,
::before,
::after {
	-webkit-box-sizing: inherit;
	box-sizing: inherit;
}

::before,
::after {
	text-decoration: inherit;
	vertical-align: inherit;
}

* {
	background-repeat: no-repeat;
	padding: 0;
	margin: 0;
}

audio:not([controls]) {
	display: none;
	height: 0;
}

hr {
	overflow: visible;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
	display: block;
}

summary {
	display: list-item;
}

small {
	font-size: 80%;
}

[hidden],
template {
	display: none;
}

abbr[title] {
	border-bottom: 1px dotted;
	text-decoration: none;
}

a {
	background-color: transparent;
	-webkit-text-decoration-skip: objects;
}

a:active,
a:hover {
	outline-width: 0;
}

code,
kbd,
pre,
samp {
	font-family: monospace, monospace;
}

b,
strong {
	font-weight: bolder;
}

dfn {
	font-style: italic;
}

mark {
	background-color: #ff0;
	color: #000;
}

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

input {
	border-radius: 0;
}

button,
[type="button"],
[type="reset"],
[type="submit"],
[role="button"] {
	cursor: pointer;
}

textarea {
	overflow: auto;
	resize: vertical;
}

button,
input,
optgroup,
select,
textarea {
	font: inherit;
}

button {
	overflow: visible;
}

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
	border-style: 0;
	padding: 0;
}

button:-moz-focusring,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
	outline: 1px dotted ButtonText;
}

button,
html [type="button"],
[type="reset"],
[type="submit"] {
	-webkit-appearance: button;
}

button,
select {
	text-transform: none;
}

button,
input,
textarea {
	background-color: transparent;
	border-style: none;
	color: inherit;
}


/*select{-moz-appearance:none;-webkit-appearance:none}*/

select::-ms-expand {
	display: none;
}

select::-ms-value {
	color: currentColor;
}

::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit;
}

[type="search"] {
	-webkit-appearance: textfield;
	outline-offset: -2px;
}

img {
	border-style: none;
}

progress {
	vertical-align: baseline;
}

svg:not(:root) {
	overflow: hidden;
}

audio,
canvas,
progress,
video {
	display: inline-block;
}

@media screen {
	[hidden~="screen"] {
		display: inherit;
	}
	[hidden~="screen"]:not(:active):not(:focus):not(:target) {
		position: absolute !important;
		clip: rect(0 0 0 0) !important;
	}
}

[aria-busy="true"] {
	cursor: progress;
}

[aria-controls] {
	cursor: pointer;
}

[aria-disabled] {
	cursor: default;
}

::-moz-selection {
	background-color: #b3d4fc;
	color: #000;
	text-shadow: none;
}

::selection {
	background-color: #b3d4fc;
	color: #000;
	text-shadow: none;
}


/*==================================================
* Basic
==================================================*/

html {
	font-size: 62.5%;
	font-size: 10px;
}

body {
	font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif;
	color: #000;
	font-size: 1.6rem;
	line-height: 1.625;
	-webkit-text-size-adjust: 100%;
}

*,
h1,
h2,
h3,
h4,
h5,
p {
	padding: 0;
	margin: 0;
	font-size: inherit;
}

h1,
h2,
h3,
h4 {
	line-height: 1.25;
}

ul,
li {
	list-style: none;
}

a {
	color: inherit;
	text-decoration: none;
	-webkit-transition: all .2s;
	-o-transition: all .2s;
	transition: all .2s;
}

a:hover {
	opacity: .8;
}

img {
	vertical-align: bottom;
	border: 0px;
	max-width: 100%;
	height: auto;
}

input,
textarea {
	background-color: transparent;
	border-style: none;
	color: inherit;
	border: 1px solid #aaa;
	width: 100%;
	max-width: 100%;
	padding: 8px;
	margin: 8px 0 16px;
}

input[type="radio"] {
	border: none;
	width: inherit;
	max-width: 100%;
	padding: 0;
}

div.wpcf7 .ajax-loader {
	position: absolute;
}

.clearfix:after {
	content: "";
	display: table;
	clear: both;
}

.if_noscript {
	background: #f00;
	color: #fff;
	text-align: center;
	font-size: 2rem;
	line-height: 2;
}

#skip-link {
	position: absolute;
	top: 0;
	left: 0;
	overflow: hidden;
	width: 0;
	height: 0;
}


/*==================================================
* layouters
==================================================*/

.alignleft {
	float: left;
	margin-right: 1.25rem;
	max-width: 50%;
}

.alignright {
	float: right;
	margin-left: 1.25rem;
	max-width: 50%;
}

.aligncenter {
	text-align: center;
	display: block;
	margin-left: auto;
	margin-right: auto;
}

.txt-center {
	text-align: center !important;
}

.txt-left {
	text-align: left !important;
}

.txt-right {
	text-align: right !important;
}

.ib {
	display: inline-block !important;
	vertical-align: middle;
}

.block {
	display: block !important;
}

.flex {
	display: -webkit-box !important;
	display: -ms-flexbox !important;
	display: flex !important;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}

.flex--wrap {
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.flex--between {
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.line-height-0 {
	line-height: 0 !important;
}

.line-height-1 {
	line-height: 1 !important;
}

.line-height-125 {
	line-height: 1.25 !important;
}

.line-height-2 {
	line-height: 2 !important;
}

.m-0 {
	margin: 0 !important;
}

.mt-0,
.my-0 {
	margin-top: 0 !important;
}

.mr-0,
.mx-0 {
	margin-right: 0 !important;
}

.mb-0,
.my-0 {
	margin-bottom: 0 !important;
}

.ml-0,
.mx-0 {
	margin-left: 0 !important;
}

.m-05 {
	margin: 0.25rem !important;
}

.mt-05,
.my-05 {
	margin-top: 0.25rem !important;
}

.mr-05,
.mx-05 {
	margin-right: 0.25rem !important;
}

.mb-05,
.my-05 {
	margin-bottom: 0.25rem !important;
}

.ml-05,
.mx-05 {
	margin-left: 0.25rem !important;
}

.m-1 {
	margin: 0.5rem !important;
}

.mt-1,
.my-1 {
	margin-top: 0.5rem !important;
}

.mr-1,
.mx-1 {
	margin-right: 0.5rem !important;
}

.mb-1,
.my-1 {
	margin-bottom: 0.5rem !important;
}

.ml-1,
.mx-1 {
	margin-left: 0.5rem !important;
}

.m-2 {
	margin: 1rem !important;
}

.mt-2,
.my-2 {
	margin-top: 1rem !important;
}

.mr-2,
.mx-2 {
	margin-right: 1rem !important;
}

.mb-2,
.my-2 {
	margin-bottom: 1rem !important;
}

.ml-2,
.mx-2 {
	margin-left: 1rem !important;
}

.m-3 {
	margin: 1.5rem !important;
}

.mt-3,
.my-3 {
	margin-top: 1.5rem !important;
}

.mr-3,
.mx-3 {
	margin-right: 1.5rem !important;
}

.mb-3,
.my-3 {
	margin-bottom: 1.5rem !important;
}

.ml-3,
.mx-3 {
	margin-left: 1.5rem !important;
}

.m-4 {
	margin: 2rem !important;
}

.mt-4,
.my-4 {
	margin-top: 2rem !important;
}

.mr-4,
.mx-4 {
	margin-right: 2rem !important;
}

.mb-4,
.my-4 {
	margin-bottom: 2rem !important;
}

.ml-4,
.mx-4 {
	margin-left: 2rem !important;
}

.m-5 {
	margin: 2.5rem !important;
}

.mt-5,
.my-5 {
	margin-top: 2.5rem !important;
}

.mr-5,
.mx-5 {
	margin-right: 2.5rem !important;
}

.mb-5,
.my-5 {
	margin-bottom: 2.5rem !important;
}

.ml-5,
.mx-5 {
	margin-left: 2.5rem !important;
}

.m-6 {
	margin: 3rem !important;
}

.mt-6,
.my-6 {
	margin-top: 3rem !important;
}

.mr-6,
.mx-6 {
	margin-right: 3rem !important;
}

.mb-6,
.my-6 {
	margin-bottom: 3rem !important;
}

.ml-6,
.mx-6 {
	margin-left: 3rem !important;
}

.m-7 {
	margin: 3.5rem !important;
}

.mt-7,
.my-7 {
	margin-top: 3.5rem !important;
}

.mr-7,
.mx-7 {
	margin-right: 3.5rem !important;
}

.mb-7,
.my-7 {
	margin-bottom: 3.5rem !important;
}

.ml-7,
.mx-7 {
	margin-left: 3.5rem !important;
}

.m-8 {
	margin: 4rem !important;
}

.mt-8,
.my-8 {
	margin-top: 4rem !important;
}

.mr-8,
.mx-8 {
	margin-right: 4rem !important;
}

.mb-8,
.my-8 {
	margin-bottom: 4rem !important;
}

.ml-8,
.mx-8 {
	margin-left: 4rem !important;
}

.m-9 {
	margin: 4.5rem !important;
}

.mt-9,
.my-9 {
	margin-top: 4.5rem !important;
}

.mr-9,
.mx-9 {
	margin-right: 4.5rem !important;
}

.mb-9,
.my-9 {
	margin-bottom: 4.5rem !important;
}

.ml-9,
.mx-9 {
	margin-left: 4.5rem !important;
}

.m-10 {
	margin: 5rem !important;
}

.mt-10,
.my-10 {
	margin-top: 5rem !important;
}

.mr-10,
.mx-10 {
	margin-right: 5rem !important;
}

.mb-10,
.my-10 {
	margin-bottom: 5rem !important;
}

.ml-10,
.mx-10 {
	margin-left: 5rem !important;
}

.m-11 {
	margin: 5.5rem !important;
}

.mt-11,
.my-11 {
	margin-top: 5.5rem !important;
}

.mr-11,
.mx-11 {
	margin-right: 5.5rem !important;
}

.mb-11,
.my-11 {
	margin-bottom: 5.5rem !important;
}

.ml-11,
.mx-11 {
	margin-left: 5.5rem !important;
}

.m-12 {
	margin: 6rem !important;
}

.mt-12,
.my-12 {
	margin-top: 6rem !important;
}

.mr-12,
.mx-12 {
	margin-right: 6rem !important;
}

.mb-12,
.my-12 {
	margin-bottom: 6rem !important;
}

.ml-12,
.mx-12 {
	margin-left: 6rem !important;
}

.p-0 {
	padding: 0 !important;
}

.pt-0,
.py-0 {
	padding-top: 0 !important;
}

.pr-0,
.px-0 {
	padding-right: 0 !important;
}

.pb-0,
.py-0 {
	padding-bottom: 0 !important;
}

.pl-0,
.px-0 {
	padding-left: 0 !important;
}

.p-05 {
	padding: 0.25rem !important;
}

.pt-05,
.py-05 {
	padding-top: 0.25rem !important;
}

.pr-05,
.px-05 {
	padding-right: 0.25rem !important;
}

.pb-05,
.py-05 {
	padding-bottom: 0.25rem !important;
}

.pl-05,
.px-05 {
	padding-left: 0.25rem !important;
}

.p-1 {
	padding: 0.5rem !important;
}

.pt-1,
.py-1 {
	padding-top: 0.5rem !important;
}

.pr-1,
.px-1 {
	padding-right: 0.5rem !important;
}

.pb-1,
.py-1 {
	padding-bottom: 0.5rem !important;
}

.pl-1,
.px-1 {
	padding-left: 0.5rem !important;
}

.p-2 {
	padding: 1rem !important;
}

.pt-2,
.py-2 {
	padding-top: 1rem !important;
}

.pr-2,
.px-2 {
	padding-right: 1rem !important;
}

.pb-2,
.py-2 {
	padding-bottom: 1rem !important;
}

.pl-2,
.px-2 {
	padding-left: 1rem !important;
}

.p-3 {
	padding: 1.5rem !important;
}

.pt-3,
.py-3 {
	padding-top: 1.5rem !important;
}

.pr-3,
.px-3 {
	padding-right: 1.5rem !important;
}

.pb-3,
.py-3 {
	padding-bottom: 1.5rem !important;
}

.pl-3,
.px-3 {
	padding-left: 1.5rem !important;
}

.p-4 {
	padding: 2rem !important;
}

.pt-4,
.py-4 {
	padding-top: 2rem !important;
}

.pr-4,
.px-4 {
	padding-right: 2rem !important;
}

.pb-4,
.py-4 {
	padding-bottom: 2rem !important;
}

.pl-4,
.px-4 {
	padding-left: 2rem !important;
}

.p-5 {
	padding: 2.5rem !important;
}

.pt-5,
.py-5 {
	padding-top: 2.5rem !important;
}

.pr-5,
.px-5 {
	padding-right: 2.5rem !important;
}

.pb-5,
.py-5 {
	padding-bottom: 2.5rem !important;
}

.pl-5,
.px-5 {
	padding-left: 2.5rem !important;
}

.p-6 {
	padding: 3rem !important;
}

.pt-6,
.py-6 {
	padding-top: 3rem !important;
}

.pr-6,
.px-6 {
	padding-right: 3rem !important;
}

.pb-6,
.py-6 {
	padding-bottom: 3rem !important;
}

.pl-6,
.px-6 {
	padding-left: 3rem !important;
}

.p-7 {
	padding: 3.5rem !important;
}

.pt-7,
.py-7 {
	padding-top: 3.5rem !important;
}

.pr-7,
.px-7 {
	padding-right: 3.5rem !important;
}

.pb-7,
.py-7 {
	padding-bottom: 3.5rem !important;
}

.pl-7,
.px-7 {
	padding-left: 3.5rem !important;
}

.p-8 {
	padding: 4rem !important;
}

.pt-8,
.py-8 {
	padding-top: 4rem !important;
}

.pr-8,
.px-8 {
	padding-right: 4rem !important;
}

.pb-8,
.py-8 {
	padding-bottom: 4rem !important;
}

.pl-8,
.px-8 {
	padding-left: 4rem !important;
}

.p-9 {
	padding: 4.5rem !important;
}

.pt-9,
.py-9 {
	padding-top: 4.5rem !important;
}

.pr-9,
.px-9 {
	padding-right: 4.5rem !important;
}

.pb-9,
.py-9 {
	padding-bottom: 4.5rem !important;
}

.pl-9,
.px-9 {
	padding-left: 4.5rem !important;
}

.p-10 {
	padding: 5rem !important;
}

.pt-10,
.py-10 {
	padding-top: 5rem !important;
}

.pr-10,
.px-10 {
	padding-right: 5rem !important;
}

.pb-10,
.py-10 {
	padding-bottom: 5rem !important;
}

.pl-10,
.px-10 {
	padding-left: 5rem !important;
}

.p-11 {
	padding: 5.5rem !important;
}

.pt-11,
.py-11 {
	padding-top: 5.5rem !important;
}

.pr-11,
.px-11 {
	padding-right: 5.5rem !important;
}

.pb-11,
.py-11 {
	padding-bottom: 5.5rem !important;
}

.pl-11,
.px-11 {
	padding-left: 5.5rem !important;
}

.p-12 {
	padding: 6rem !important;
}

.pt-12,
.py-12 {
	padding-top: 6rem !important;
}

.pr-12,
.px-12 {
	padding-right: 6rem !important;
}

.pb-12,
.py-12 {
	padding-bottom: 6rem !important;
}

.pl-12,
.px-12 {
	padding-left: 6rem !important;
}

.m-auto {
	margin: auto !important;
}

.mt-auto,
.my-auto {
	margin-top: auto !important;
}

.mr-auto,
.mx-auto {
	margin-right: auto !important;
}

.mb-auto,
.my-auto {
	margin-bottom: auto !important;
}

.ml-auto,
.mx-auto {
	margin-left: auto !important;
}


/*==================================================
* Common
==================================================*/

.main {
	background: #fffef7;
}

.inner-sm,
.inner {
	max-width: 1170px;
	margin-left: auto;
	margin-right: auto;
}

@media screen and (max-width: 1170px) {
	.inner-sm,
	.inner {
		padding-left: 3%;
		padding-right: 3%;
		overflow: hidden;
	}
}

.inner-sm {
	max-width: 830px;
}

p {
	margin-bottom: 1rem;
}

p:last-child {
	margin-bottom: 0;
}

.font-mincho {
	font-family: "Times New Roman", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, メイリオ, Meiryo, serif;
}

.font-xxl {
	font-size: 5.2rem;
}

.font-xl {
	font-size: 3.6rem;
}

.font-lg {
	font-size: 2.2rem;
}

.font-md {
	font-size: 1.6rem;
}

.font-sm {
	font-size: 1.4rem;
}

.font-xs {
	font-size: 1.2rem;
}

@media screen and (max-width: 768px) {
	.font-xxl {
		font-size: 3.2rem;
	}
	.font-xl {
		font-size: 2.4rem;
	}
	.font-lg {
		font-size: 1.8rem;
	}
	.font-md {
		font-size: 1.6rem;
	}
	.font-sm {
		font-size: 1.4rem;
	}
	.font-xs {
		font-size: 1.2rem;
	}
}

.font-normal {
	font-weight: normal !important;
}

.font-bold {
	font-weight: bold !important;
}

.txt-shadow {
	text-shadow: 0 0 12px rgba(0, 0, 0, 0.5);
}

.bgw {
	background: #fff !important;
}

.bgbk {
	background: #000 !important;
}

.bgg {
	background: #e6e6e6 !important;
}

.bggp {
	background: rgba(18, 31, 77, 0.1) !important;
}

.bgprimary {
	background: #00ac97 !important;
}

.color-primary {
	color: #00ac97 !important;
}

.color-sec {
	color: #e85298 !important;
}

.color-danger {
	color: #e60012 !important;
}

.icon {
	position: relative;
	display: inline-block;
	padding-left: 25px;
}

.icon:before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	display: block;
	width: 22px;
	height: 22px;
	margin-top: -11px;
	margin-right: 4px;
	background-size: auto;
	background-repeat: no-repeat;
	background-position: left center;
}

.icon.icon-tail {
	padding-left: 0;
	padding-right: 25px;
}

.icon.icon-tail:before {
	left: auto;
	right: 0;
	background-position: right center;
}

.icon.icon-arrow:before {
	width: 9px;
	height: 9px;
	margin-top: -4px;
	border-left: 1px solid;
	border-top: 1px solid;
	border-color: #000;
	-webkit-transform: rotate(135deg);
	-ms-transform: rotate(135deg);
	transform: rotate(135deg);
}

.icon.icon-arrow-up:before {
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
	margin-top: -2px;
}

.icon.icon-arrow-down:before {
	-webkit-transform: rotate(-135deg);
	-ms-transform: rotate(-135deg);
	transform: rotate(-135deg);
	margin-top: -6px;
}

.icon.icon-arrow-white:before {
	border-color: #fff;
}

.icon.icon-arrow-gray:before {
	border-color: #aaa;
}

.icon.icon-arrow-bold:before {
	border-width: 2px;
}

.icon.icon-arrow-sm {
	padding-left: 10px;
}

.icon.icon-arrow-sm:before {
	width: 3px;
	height: 3px;
	margin-top: -1px;
}

.table-common {
	width: 100%;
	font-size: 2rem;
	border-top: 1px solid #000;
	border-left: 1px solid #000;
	border-collapse: collapse;
	border-spacing: 0px;
}

.table-common th,
.table-common td {
	padding: 1rem;
	border-right: 1px solid #000;
	border-bottom: 1px solid #000;
}

.table-common th {
	vertical-align: middle;
	text-align: center;
	background: rgba(18, 31, 77, 0.2);
}

.youtube {
	width: 80%;
	position: relative;
	margin: 0;
	/*padding-bottom: 10%;*/
	padding-top: none;
	overflow: hidden;
}

.youtube iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	margin: 0;
}

.shadow {
	-webkit-box-shadow: 0 0 12px rgba(0, 0, 0, 0.5);
	box-shadow: 0 0 12px rgba(0, 0, 0, 0.5);
}

.border {
	border: 1px solid #00ac97;
}

.border-bottom-3 {
	border-bottom: 3px solid #00ac97;
}

.sepper {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	/*
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
*/
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}

.sepper.sepper--vm {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}

@media screen and (min-width: 769px) {
	.sepper--pc {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
	}
}

@media screen and (min-width: 769px) {
	.sepper--housiki {
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
	}
	.sepper--housiki > *:first-child {
		width: 40%;
	}
	.sepper--housiki > *:last-child {
		width: calc(60% - 28px);
	}
}

.sepper .sepper__box--2 {
	width: calc( 100% / 2);
	padding-left: 1.2rem;
	padding-right: 1.2rem;
}
.sepper .sepper__box--2:nth-child(n+3) {
	margin-top: 28px;
}

.sepper .sepper__box--3 {
	width: calc( 100% / 3);
	padding-left: 1.2rem;
	padding-right: 1.2rem;
}

.sepper .sepper__box--4 {
	width: calc( 100% / 4);
	padding-left: .8rem;
	padding-right: .8rem;
}
.sepper__box--4:nth-child(n+5) {
	margin-top: 28px;
}

.sepper .sepper__box--5 {
	width: calc( 100% / 5);
	padding-left: .6rem;
	padding-right: .6rem;
}

@media screen and (max-width: 768px) {
	.sepper .sepper__box--3 {
		width: calc( 100% / 2);
	}
	.sepper .sepper__box--3:nth-child(n+3) {
		margin-top: 20px;
	}
}

@media screen and (max-width: 640px) {
	.sepper .sepper__box--2,
	.sepper .sepper__box--3 {
		width: 100%;
		padding-left: 0;
		padding-right: 0;
	}
	.sepper .sepper__box--2:not(:first-child),
	.sepper .sepper__box--3:not(:first-child) {
		margin-top: 20px;
	}
}

@media screen and (max-width: 768px) {
	.sepper .sepper__box--4,
	.sepper .sepper__box--5 {
		width: calc( 100% / 2);
	}
	.sepper .sepper__box--5:nth-child(n+3),
	.sepper .sepper__box--4:nth-child(n+3) {
		margin-top: 20px;
	}
}

.order--2 {
	order: 2;
}

.sp_menu_btn_wrap {
	width: 100%;
	height: 48px;
	background: #00ac97;
	position: absolute;
	top: 0;
	left: 0;
}

@media screen and (min-width: 769px) {
	.sp_menu_btn_wrap {
		display: none;
	}
}

.tgl_menu_btn {
	-webkit-touch-callout: none;
}

.menu_btn_right {
	position: absolute;
	top: 4px;
	right: 10px;
	display: block;
	height: 40px;
	color: #fff;
}

.menu_btn_right .txt {
	display: block;
	padding-top: 8px;
	padding-left: 32px;
}

.menu_icon,
.menu_icon:before,
.menu_icon:after {
	position: absolute;
	top: 50%;
	display: block;
	width: 20px;
	height: 3px;
	margin-top: -1px;
	background: #fff;
	-webkit-transition: all .3s linear;
	-o-transition: all .3s linear;
	transition: all .3s linear;
	border-radius: 1px;
}

.menu_icon:before,
.menu_icon:after {
	content: "";
	top: auto;
	margin-top: 0;
	left: 0;
}

.menu_icon:before {
	top: -8px;
}

.menu_icon:after {
	bottom: -8px;
}

.open .menu_icon {
	background: none;
}

.open .menu_icon:before,
.open .menu_icon:after {
	top: 0;
	bottom: 0;
}

.open .menu_icon:before {
	-webkit-transform: rotate(-45deg);
	-ms-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

.open .menu_icon:after {
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
}

#main-menu {
	position: relative;
	text-align: center;
	line-height: 1.25;
	border-top: 1px solid #fff;
	border-bottom: 1px solid #fff;
	letter-spacing: .1rem;
	-webkit-box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
	background: #fff;
}

@media screen and (min-width: 769px) {
	#main-menu {
		display: block !important;
	}
	#main-menu ul {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}
	#main-menu ul li a {
		display: block;
		font-size: 1.6rem;
		font-weight: bold;
		text-align: center;
		padding: 3rem 1rem;
	}
}

@media screen and (max-width: 768px) {
	#main-menu {
		display: none;
		position: absolute;
		width: 100%;
		top: 48px;
		padding: 0;
		font-size: 1.4rem;
		background: #fff;
		z-index: 9999;
	}
	#main-menu li {
		display: block;
		width: 100%;
		border-top: 1px solid #eee;
	}
	#main-menu li:first-child {
		border-top: none;
	}
	#main-menu li > a {
		position: relative;
		display: block;
		padding: 0;
		line-height: 48px;
	}
	#main-menu > ul > li {
		width: 100%;
	}
	#main-menu > ul > li > a {
		border: none;
	}
}

#main-menu.navpita {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 5000;
}

.footer {
	background: #00ac97;
	color: #fff;
	padding: 8rem 0 6rem;
}

#page-top {
	position: fixed;
	bottom: 0;
	z-index: 5000;
}

@media screen and (min-width: 769px) {
	#page-top {
		right: 50%;
		margin-right: -580px;
	}
}

@media screen and (max-width: 768px) {
	#page-top {
		right: 0;
	}
}

#page-top a {
	position: relative;
	display: block;
	width: 52px;
	height: 52px;
	background: #000;
	-webkit-transition: all .2s;
	-o-transition: all .2s;
	transition: all .2s;
	opacity: 0;
	pointer-events: none;
}

#page-top a.fix {
	opacity: 1;
	pointer-events: auto;
}

#page-top a:after {
	content: "";
	display: block;
	position: absolute;
	width: 10px;
	height: 10px;
	border-top: 2px solid #fff;
	border-left: 2px solid #fff;
	left: 50%;
	top: 50%;
	margin-top: -2px;
	margin-left: -5px;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
}

.mv-wrap {
	padding: 40px 0 20px;
	text-align: center;
	background: url(../images/mv_bg3.jpg) no-repeat center/cover;
}

@media screen and (max-width: 768px) {
	.mv-wrap {
		/*			padding-bottom: 80px;*/
		margin-top: 48px;
		padding-top: 20px;
	}
}

.productname-box {
	background: #00ac97;
	text-align: center;
	padding: 10px;
}

.productname-box img {
	max-width: 50%;
}

.section--basic {
	padding: 8rem 0 4rem;
}

@media screen and (max-width: 768px) {
	.section--basic {
		padding-top: 3rem;
		padding-bottom: 2rem;
	}
}

.section--nolife {
	color: #fff;
	background: url(../images/nolife_bg.jpg) no-repeat center/cover;
}

.section--answer {
	color: #fff;
	background: url(../images/answer_bg.jpg) no-repeat center/cover;
}

.section--hosiki {
	padding-top: 6rem;
}

@media screen and (max-width: 768px) {
	.section--hosiki {
		padding-top: 3rem;
	}
}

.section--products {
	padding-top: 8rem;
	padding-bottom: 6rem;
}

@media screen and (max-width: 768px) {
	.section--products {
		padding-top: 3rem;
	}
}

.section__box:not(:last-child) {
	margin-bottom: 6rem;
}

@media screen and (max-width: 768px) {
	.section__box:not(: last-child) {
		margin-bottom: 3rem;
	}
}

.section__bottom {}

.tile {
	margin-bottom: 28px;
}

.tile__box {
  -webkit-box-shadow: 8px 8px 0 rgba(0, 172, 151, 0.3);
  box-shadow: 8px 8px 0 rgba(0, 172, 151, 0.3);
	padding: 2.8rem;
	font-size: 2rem;
	background: #fff;
	;
}

.plans {
	padding: 20px;
	border: #e85298 2px solid;
	border-radius: 28px;
	background: #fff;
}

.plans__ttl {
	margin-bottom: 12px;
}

@media screen and (min-width: 769px) {
	.plans {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
	}
	.plans__box {
		width: calc(100% / 3);
		padding: 0 32px;
	}
	.plans__box:not(:last-child) {
		border-right: #e85298 2px solid;
	}
}

@media screen and (max-width: 768px) {
	.plans__box {
		padding: 24px 0;
	}
	.plans__box:not(:last-child) {
		border-bottom: #e85298 2px solid;
	}
}

.common_h2 {
	position: relative;
	margin-bottom: 2.8rem;
	padding-bottom: 2rem;
	font-size: 3.2rem;
	text-align: center;
	color: #00ac97;
}

.common_h2:after {
	content: "";
	display: block;
	position: absolute;
	bottom: 0;
	left: 50%;
	width: 160px;
	height: 2px;
	background: #00ac97;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
}

.common_h2_2 {
	font-size: 3.2rem;
	border-left: 8px solid #00ac97;
	padding-left: 2rem;
	margin-bottom: 4rem;
}

.common_h3 {
	position: relative;
	font-size: 3.2rem;
	/*	font-weight: normal;*/
	margin-top: 40px;
	margin-bottom: 40px;
	/*	background: #00ac97;*/
	color: #00ac97;
	border: 2px solid #00ac97;
	border-left: 14px solid #00ac97;
	border-right: none;
	padding: .5rem 1.5rem;
}.common_h3__copy {display: block;font-size: 1.6rem;}

.common_h3:before {
	content: "";
	display: block;
	position: absolute;
	border: 8px solid transparent;
	border-left: 8px solid #00ac97;
	top: 50%;
	margin-top: -8px;
	left: 0;
}

@media screen and (max-width: 768px) {
	.common_h3 {
		font-size: 2.4rem;
	}
}

.common_h4 {
	color: #e85298;
	margin: 12px 0 8px;
	font-size: 2.4rem;
}

.hosiki_h2 {
	margin-bottom: 2rem;
	font-size: 4rem;
	text-align: center;
}

.hosiki_h2 span {
	display: inline-block;
}

.hosiki_h2 .hosiki--main {
	font-size: 8rem;
	font-weight: bold;
	color: #e60012;
}

.hosiki_h2 .hosiki--hosiki {
	font-size: 5.6rem;
}

.hosiki_h2 .hosiki--kakko {
	font-size: 2.8rem;
}

.hosiki_h2 .hosiki--md {
	font-size: 2.8rem;
}

.bnr-a {
	display: block;
	background: url(../images/bnr_a_bg.jpg) no-repeat center bottom/cover;
	border-radius: 1rem;
	overflow: hidden;
	padding: 1.2rem 2.4rem;
}

@media screen and (min-width: 769px) {
	.bnr-a {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
	}
}

.bnr-a__ttl {
	margin-right: 2rem;
}

@media screen and (max-width: 768px) {
	.bnr-a__ttl {
		margin-bottom: 1rem;
	}
}

.strong {
	color: #2d4fc7;
	font-weight: bold;
	font-size: 105%;
}

.required-mark {
	display: inline-block;
	margin-left: .5rem;
	font-size: 80%;
	color: #f00;
}

.form-box {
	position: relative;
}

@media screen and (min-width: 769px) {
	.form-box {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: start;
		-ms-flex-align: start;
		align-items: flex-start;
	}
	.form-box .form-label {
		width: 20%;
		margin-top: 1.75rem;
		margin-right: 1rem;
	}
	.form-box .form-item {
		width: 80%;
		margin: auto;
	}
}

.form-box.error .help-block,
.form-box.success .help-block {
	position: absolute;
	bottom: 0;
	right: 0;
	background: #fff;
	border: 1px solid #f00;
	color: #f00;
	font-size: 80%;
	padding: .25rem 1rem;
	border-radius: 4px;
}

.form-box--lonely-check {
	margin: 2rem auto;
}

.form-box--lonely-check .form-item {
	display: inline-block;
	width: auto;
}

.form-box--lonely-check .form-item input {
	width: auto;
	margin-right: 1rem;
}

.submit-form {
	text-align: center;
}

.submit-form .btn {
	display: inline-block;
	padding: 1rem 2rem;
	text-align: center;
	background: #00ac97;
	color: #fff;
}

.submit-form .btn:hover {
	opacity: .8;
}

.post-data dt {
	margin-top: 2rem;
}

.privacy-tkn {
	margin-top: 4rem;
}

.privacy-tkn h3 {
	margin-bottom: 1rem;
	font-weight: normal;
}

.privacy-tkn .box {
	border: 1px solid #aaa;
	margin-bottom: 2rem;
	padding: 8px;
	overflow: auto;
	height: 320px;
}

pre {
	white-space: -moz-pre-wrap;
	white-space: -pre-wrap;
	white-space: -o-pre-wrap;
	white-space: pre-wrap;
}

.movie {
	padding-top: 20px;
	padding-bottom: 20px;
	background-color: #dddddd;
}

.video-container {
	position: relative;
	padding-bottom: 56.25%;
	padding-top: 30px;
	height: 0;
	overflow: hidden;
}

.video-container iframe,
.video-container object,
.video-container embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.attention {
	background-color: #dddddd;
	padding: 20px;
	margin-bottom: 40px;
}

.product-box {
	position: relative;
	margin-bottom: 60px;
}

.product-box__ttl {
	font-size: 5.6rem;
	margin-bottom: 12px;
}

.product-box__ttl--copy {
	display: block;
	font-size: 2.4rem;
	font-weight: normal;
}

.product-box--a .product-box__icons {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

.product-box--a .product-box__icons > div {
	margin-right: 6px;
}

@media screen and (min-width: 769px) {
	.product-box--a {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
	}
	.product-box--a .product-box__ttl {
		width: 60%;
		padding-bottom: 50px;
	}
	.product-box--a .product-box__img {
		/*
		position: absolute;
		top: 0;
		right: 0;
*/
		width: 40%;
		text-align: right;
	}
	.product-box--a .product-box__icons {
		position: absolute;
		bottom: 0;
		left: 0;
		width: 60%;
	}

	.product-box--b {
		padding-bottom: 24%;
	}
	.product-box--b .product-box__ttl {
		position: relative;
		z-index: 1;
	}
	.product-box--b .product-box__img,
	.product-box--b .product-box__icons {
		position: absolute;
	}
	.product-box--b .product-box__img {
		top: 0;
		right: 0;
		max-width: 70%;
		height: 100%;
	}
	.product-box--b .product-box__img img {
		max-height: 100%;
	}
	.product-box--b .product-box__icons {
		max-width: 28%;
		left: 0;
		bottom: 0;
	}
}

@media screen and (max-width: 768px) {
	.product-box .product-box__img {
		margin-bottom: 20px;
	}
	.product-box--a {}
	.product-box__ttl {
		font-size: 3.6rem;
	}
	.product-box__ttl--copy {
		font-size: 1.6rem;
	}
	.product-box--a .product-box__icons {
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		-webkit-box-pack: center;
		-ms-flex-pack: center;
		justify-content: center;
	}
	.product-box--a .product-box__icons > div {
		margin-top: 8px;
	}
}

.product-fea {
	border: #00ac97 2px solid;
	border-radius: 12px;
	background: #fff;
	padding: 12px;
	height: 100%;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		-ms-flex-line-pack: start;
		align-content: flex-start;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}.product-fea > .product-fea__ttl,.product-fea > p {width: 100%;}

.product-fea__ttl {
	border-bottom: #00ac97 solid 2px;
	padding-bottom: 5px;
	margin-bottom: 10px;
}
.product-fea__img {
	width: 30%;
}.product-fea__cts {
	width: calc(70% - 20px);
}