@charset "UTF-8";

@import url(http://fonts.googleapis.com/earlyaccess/notosansjapanese.css);

/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/
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 {
	border: 0;
	font: inherit;
	font-size: 100%;
	margin: 0;
	padding: 0;
	vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}

ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after, q:before, q:after {
	content: none;
	content: "";
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}



/* ----------------------------------------
	common
---------------------------------------- */
body {
	font-family: helvetica, "Noto Sans Japanese", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", "Osaka", sans-serif;
	color: #333;
	font-size: 14px;
	line-height: 1.75;
	-webkit-text-size-adjust: 100%;
}
* {
	box-sizing: border-box;
}
*:before,
*:after {
	box-sizing: border-box;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after, q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
a {
	color: #52bad5;
	text-decoration: none;
}
img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}


.st-page {
	overflow: hidden;
}

.st-container {
	max-width: 750px;
	margin: 0 auto;
	position: relative;
}
@media screen and (max-width:750px) {
	.st-container {
		width: 100%;
	}
}


/* key visual */
.keyVisual {
	background: url(../images/bg_keyvisual.png) no-repeat center top;
	background-size: 967px auto;
	height: 0;
	padding-top: 650px;
	position: relative;
}
.keyVisual h1 {
	width: 100%;
	text-align: center;
	position: absolute;
	left: 0;
	top: 290px;
}
@media screen and (max-width:750px) {
	.keyVisual {
		background-size: 100% auto;
		padding-top: 80%;
	}
	.keyVisual h1 {
		top: 46%;
	}
	.keyVisual h1 img {
		width: 80%;
	}
}

/* service */
.section-service {
	padding: 10% 0 12%;
	text-align: center;
	position: relative;
	z-index: 0;
}
.section-service:before {
	content: "";
	display: block;
	width: 4000px;
	height: 0;
	background: url(../images/bg_blue.jpg) repeat center top;
	padding-top: 200%;
	transform: rotate(-7deg);
	position: absolute;
	left: 50%;
	top: 3%;
	margin-left: -2000px;
	z-index: -1;
}
.section-service_body {
	padding: 4% 0 0;
}
@media screen and (max-width:750px) {
	.section-service_head img {
		width: 36%;
	}
	.section-service_body img {
		width: 86%;
	}
}

/* problem */
.section-problem {
	padding: 4% 0 6%;
	text-align: center;
	position: relative;
	z-index: 0;
}
.section-problem:before {
	content: "";
	display: block;
	width: 4000px;
	height: 0;
	background: url(../images/bg_yellow.jpg) repeat center top;
	padding-top: 200%;
	transform: rotate(7deg);
	position: absolute;
	left: 50%;
	top: 0;
	margin-left: -2000px;
	z-index: -1;
}
.section-problem_body1 {
	padding: 4% 0 16%;
}
.section-problem_body2 {
	padding: 4% 0 2%;
	position: relative;
}
.section-problem_body2:before {
	content: "";
	display: block;
	width: 4000px;
	height: 0;
	background: #fff;
	background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(230,230,230,1) 100%);
	padding-top: 200%;
	transform: rotate(-7deg);
	position: absolute;
	left: 50%;
	top: 0;
	margin-left: -2000px;
	z-index: -1;
}
@media screen and (max-width:750px) {
	.section-problem_head img {
		width: 86%;
	}
	.section-problem_body1 img {
		width: 86%;
	}
	.section-problem_body2 img {
		width: 86%;
	}
}

/* career */
.section-career {
	padding: 4% 0 10%;
	text-align: center;
	position: relative;
	z-index: 0;
}
.section-career:before {
	content: "";
	display: block;
	width: 4000px;
	height: 0;
	background: url(../images/bg_blue.jpg) repeat center top;
	padding-top: 200%;
	transform: rotate(7deg);
	position: absolute;
	left: 50%;
	top: 0;
	margin-left: -2000px;
	z-index: -1;
}
.section-career_head {
	text-align: left;
}
.section-career_head img {
	width: 64%;
	margin-left: 10%;
}
.section-career_body {
	padding: 5% 0 0;
}
.section-career_body img {
	width: 86%;
}

/* before after */
.section-beforeafter {
	padding: 8% 0 10%;
	text-align: center;
	position: relative;
	z-index: 0;
}
.section-beforeafter:before {
	content: "";
	display: block;
	width: 4000px;
	height: 0;
	background: url(../images/bg_yellow.jpg) repeat center top;
	padding-top: 200%;
	transform: rotate(-7deg);
	position: absolute;
	left: 50%;
	top: 0;
	margin-left: -2000px;
	z-index: -1;
}
.section-beforeafter_head img {
	width: 86%;
}
.section-beforeafter_body {
	width: 92%;
	margin: 6% auto 0;
	height: 0;
	overflow: hidden;
	padding-top: 63.5%;
	position: relative;
}
.section-beforeafter_body iframe {
	max-width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
}

/* point */
.section-point {
	padding: 8% 0 10%;
	text-align: center;
	position: relative;
	z-index: 0;
}
.section-point:before {
	content: "";
	display: block;
	width: 4000px;
	height: 0;
	background: url(../images/bg_blue.jpg) repeat center top;
	padding-top: 200%;
	transform: rotate(7deg);
	position: absolute;
	left: 50%;
	top: 0;
	margin-left: -2000px;
	z-index: -1;
}
.section-point_body {
	padding: 8% 0 0;
}
@media screen and (max-width:750px) {
	.section-point_head img {
		width: 68%;
	}
	.section-point_body img {
		width: 86%;
	}
}

/* comic */
.section-comic {
	padding: 8% 0 12%;
	text-align: center;
	position: relative;
	z-index: 0;
}
.section-comic:before {
	content: "";
	display: block;
	width: 4000px;
	height: 0;
	background: #fff;
	padding-top: 200%;
	transform: rotate(7deg);
	position: absolute;
	left: 50%;
	top: 0;
	margin-left: -2000px;
	z-index: -1;
}
.section-comic_body1 {
	padding: 4% 0 0;
}
.section-comic_body2 {
	padding: 2% 0 0;
}
@media screen and (max-width:750px) {
	.section-comic_head img {
		width: 88%;
	}
	.section-comic_body1 img {
		width: 86%;
	}
	.section-comic_body2 img {
		width: 86%;
	}
}

/* price */
.section-price {
	padding: 8% 0 10%;
	text-align: center;
	position: relative;
	z-index: 0;
}
.section-price:before {
	content: "";
	display: block;
	width: 4000px;
	height: 0;
	background: url(../images/bg_blue.jpg) repeat center top;
	padding-top: 200%;
	transform: rotate(7deg);
	position: absolute;
	left: 50%;
	top: 0;
	margin-left: -2000px;
	z-index: -1;
}
.section-price_body {
	padding: 6% 0 0;
}
@media screen and (max-width:750px) {
	.section-price_head img {
		width: 52%;
	}
	.section-price_body img {
		width: 86%;
	}
}

/* flow */
.section-flow {
	padding: 8% 0 4%;
	text-align: center;
	position: relative;
	z-index: 0;
}
.section-flow:before {
	content: "";
	display: block;
	width: 4000px;
	height: 0;
	background: #fff;
	padding-top: 200%;
	transform: rotate(7deg);
	position: absolute;
	left: 50%;
	top: 0;
	margin-left: -2000px;
	z-index: -1;
}
.section-flow_body {
	padding: 6% 0 0;
}
@media screen and (max-width:750px) {
	.section-flow_head img {
		width: 76%;
	}
	.section-flow_body img {
		width: 86%;
	}
}

/* contact */
.section-contact {
	background: url(../images/bg_blue.jpg) repeat center top;
	padding: 70px 0 10%;
	position: relative;
	z-index: 0;
}
.section-contact:before {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 40px 375px 0 375px;
	border-color: #fff transparent transparent transparent;
	position: absolute;
	left: 50%;
	margin-left: -375px;
	top: 0;
}
.section-contact:after {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 375px 40px 375px;
	border-color: transparent transparent #fff transparent;
	position: absolute;
	left: 50%;
	margin-left: -375px;
	bottom: -1px;
}
.section-contact_head {
	text-align: center;
}
.section-contact_head img {
	width: 86%;
}
.section-contact_body {
	width: 86%;
	margin: 0 auto;
	padding: 8% 0 0;
}

.formItem + .formItem {
	margin-top: 6%;
}
.formItem_label {
	color: #fff;
	font-size: 20px;
	font-weight: bold;
	text-align: center;
}
.formItem_label .require {
	display: inline-block;
	margin-left: 8px;
	border-radius: 3px;
	background-color: #fff;
	padding: 4px 8px 2px;
	vertical-align: text-top;
	color: #00b0a7;
	font-size: 16px;
	font-weight: normal;
	line-height: 1;
}
.formButton {
	margin: 6% auto 0;
	width: 88%;
	text-align: center;
}
.formButton button {
	transition: .4s;
	cursor: pointer;
}
.formButton button:hover {
	opacity: .8;
}
@media screen and (max-width:750px) {
	.section-contact {
		padding-bottom: 20%;
	}
}

/* mailformpro */
.mfp_element_all {
	max-width: 100%;
}
.mfp_element_submit {
	box-shadow: none !important;
	margin: 0;
	border-radius: 0;
	border: 0;
	background: none !important;
	padding: 0;
}
#mfp_button_send {
	border: solid 1px #00b0a7;
	background: #00b0a7;
	color: #fff;
	text-shadow: none;
}
#mfp_button_cancel {
	background: #ddd;
	text-shadow: none;
}



/* footer
---------------------------------------- */
.st-footer {
	padding: 4% 0;
	color: #333;
}
.st-footer p + p {
	margin-top: 1%;
}
.st-footer a {
	display: inline-block;
	color: #333;
}
.st-footer a + a {
	margin-left: 6%;
}
.st-footer a:hover {
	text-decoration: underline;
}
@media screen and (max-width:750px) {
	.st-footer p {
		width: 86%;
		margin: 0 auto;
		font-size: 13px;
	}
	.st-footer a {
		display: block;
	}
	.st-footer a + a {
		margin-left: 0;
	}
}


/* sub page */
.header {
	background: url(../images/bg_blue.jpg) center top;
	padding: 10px;
	text-align: center;
}
.subPage {
	background: url(../images/bg_white.jpg) center top;
	padding: 80px 0;
}
.section-privacy_head,
.section-specified_head {
	font-size: 30px;
	font-weight: bold;
	text-align: center;
}
.section-privacy_body,
.section-specified_body {
	margin-top: 40px;
}
.section-privacy_body p + p,
.section-specified_body p + p {
	margin-top: 1.5em;
}
@media screen and (max-width:750px) {
	.header {
		padding: 10px 40px;
	}
	.subPage {
		padding: 40px 20px;
	}
	.section-privacy_head,
	.section-specified_head {
		font-size: 20px;
	}
	.section-privacy_body,
	.section-specified_body {
		margin-top: 20px;
	}
}

/* thanks page */
.section-thanks {
	padding-bottom: 200px;
}
.section-thanks_head {
	font-size: 28px;
	font-weight: bold;
	line-height: 1.2;
	text-align: center;
}
.section-thanks_head br {
	display: none;
}
.section-thanks_body {
	margin-top: 40px;
	font-size: 16px;
	text-align: center;
}
.section-thanks_body p + p {
	margin-top: 20px;
}
@media screen and (max-width:750px) {
	.section-thanks_head {
		font-size: 24px;
	}
	.section-thanks_head br {
		display: inline;
	}
	.section-thanks_body {
		font-size: 14px;
	}
}



/* ----------------------------------------
	modules
---------------------------------------- */

/* page top */
.contactBanner {
	width: 286px;
	position: fixed;
	right: 1%;
	bottom: 2%;
}
.contactBanner a {
	transition: .4s;
}
.contactBanner a:hover {
	opacity: .8;
}
@media screen and (max-width:750px) {
	.contactBanner {
		width: 120px;
	}
}

/* fadein */
.fadein {
  opacity: 0;
  transform : translate(0, 50px);
  transition : all 1000ms;
}

.fadein.scrollin{
  opacity: 1;
  transform: translate(0, 0);
}


/* フォームパーツリセット */
input, button, textarea, select {
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

/* テキストフィールド */
.sw-formText input[type="text"],
.sw-formText input[type="number"] {
	width: 100%;
	border-radius: 3px;
	border: solid 1px #ccc;
	background-color: #fff;
	padding: 10px;
	font-size: 14px;
}
.sw-formTextPostal input[type="number"] {
	display: inline-block;
	margin-left: 10px;
	width: auto;
}
@media screen and (max-width:750px) {
	.sw-formText input[type="text"],
	.sw-formText input[type="number"] {
		font-size: 16px;
	}
}

/* テキストエリア */
.sw-formTextArea textarea {
	width: 100% !important;
	min-height: 200px;
	border-radius: 3px;
	border: solid 1px #ccc;
	background-color: #fff;
	padding: 10px;
	font-size: 14px;
}
@media screen and (max-width:750px) {
	.sw-formTextArea textarea {
		font-size: 16px;
	}
}

/* ラジオボタン */
.sw-formRadio label {
	cursor: pointer;
}
.sw-formRadio label + label {
	margin-left: 20px;
}
.sw-formRadio label input[type="radio"] {
	content: "";
	display: inline-block;
	vertical-align: text-top;
	margin-right: 5px;
	width: 15px;
	height: 15px;
	border-radius: 50%;
	border: 1px solid #ccc;
	position: relative;
	cursor: pointer;
}
.sw-formRadio label input[type="radio"]:before {
	content: "";
	display: block;
	width: 11px;
	height: 11px;
	background: #009a9a;
	border-radius: 50%;
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	margin: auto;
	opacity: 0;
	transition: .2s;
}
.sw-formRadio label input[type="radio"]:checked:before {
	opacity: 1;
}

/* ラジオボタン2 */
.sw-formRadio2 {
	display: flex;
	justify-content: space-between;
}
.sw-formRadio2 label {
	width: 30%;
	cursor: pointer;
}
.sw-formRadio2 label input[type="radio"] {
	display: none;
}
.sw-formRadio2 label span {
	display: block;
	border-radius: 3px;
	border: solid 1px #ccc;
	padding: 5px 15px;
	transition: .2s;
}
.sw-formRadio2 label input[type="radio"]:checked + span {
	border: solid 1px #009a9a;
	background-color: #009a9a;
	color: #fff;
}

/* チェックボックス */
.sw-formCheckbox label {
	cursor: pointer;
}
.sw-formCheckbox label + label {
	margin-left: 20px;
}
.sw-formCheckbox input[type="checkbox"] {
	content: "";
	display: inline-block;
	vertical-align: text-top;
	margin-right: 5px;
	width: 15px;
	height: 15px;
	border-radius: 2px;
	border: 1px solid #ccc;
	position: relative;
	cursor: pointer;
}
.sw-formCheckbox input[type="checkbox"]:before {
	content: "";
	display: block;
	width: 8px;
	height: 18px;
	transform: rotate(40deg);
	border-bottom: 3px solid #009a9a;
	border-right: 3px solid #009a9a;
	position: absolute;
	left: 2px;
	right: 0;
	top: 0;
	bottom: 7px;
	margin: auto;
	opacity: 0;
	transition: .2s;
}
.sw-formCheckbox input[type="checkbox"]:checked:before {
	opacity: 1;
}

/* チェックボックス2 */
.sw-formCheckbox2 {
	display: flex;
	justify-content: space-between;
}
.sw-formCheckbox2 label {
	width: 30%;
	cursor: pointer;
	position: relative;
}
.sw-formCheckbox2 input[type="checkbox"] {
	content: "";
	display: inline-block;
	vertical-align: text-top;
	margin-right: 5px;
	width: 15px;
	height: 15px;
	border-radius: 2px;
	border: 1px solid #ccc;
	position: absolute;
	left: 10px;
	top: 50%;
	margin-top: -7px;
	z-index: 1;
}
.sw-formCheckbox2 input[type="checkbox"]:before {
	content: "";
	display: block;
	width: 8px;
	height: 18px;
	transform: rotate(40deg);
	border-bottom: 3px solid #009a9a;
	border-right: 3px solid #009a9a;
	position: absolute;
	left: 2px;
	right: 0;
	top: 0;
	bottom: 7px;
	margin: auto;
	z-index: 2;
	opacity: 0;
	transition: .2s;
}
.sw-formCheckbox2 label span {
	display: block;
	border-radius: 3px;
	border: solid 1px #ccc;
	padding: 5px 0 5px 35px;
	position: relative;
	transition: .2s;
}
.sw-formCheckbox2 label input[type="checkbox"]:checked {
	border: 1px solid #fff;
}
.sw-formCheckbox2 label input[type="checkbox"]:checked:before {
	border-bottom: 3px solid #fff;
	border-right: 3px solid #fff;
	opacity: 1;
}
.sw-formCheckbox2 label input[type="checkbox"]:checked + span {
	border: solid 1px #009a9a;
	background-color: #009a9a;
	color: #fff;
}

/* セレクトボックス */
.sw-formSelect {
	position: relative;
}
.sw-formSelect:before {
	width: 0;
	height: 0;
	padding: 0;
	content: '';
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 6px solid #666666;
	pointer-events: none;
	position: absolute;
	top: 50%;
	margin-top: -2px;
	right: 20px;
}
.sw-formSelect select {
	width: 100%;
	border-radius: 2px;
	border: 1px solid #ccc;
	background-color: #fff;
	padding: 10px;
	font-size: 14px;
}
.sw-formSelect select::-ms-expand {
	display: none;
}
@media screen and (max-width:750px) {
	.sw-formSelect select {
		font-size: 16px;
	}
}

/* ボタン */
.sw-buttons {
	text-align: center;
}
.sw-buttons .sw-button {
	display: inline-block;
	margin: 0 10px;
}
.sw-button a,
.sw-button input[type="button"],
.sw-button button {
	display: block;
	border-radius: 2px;
	border: solid 1px #0f9ada;
	background-color: #03a9f4;
	box-shadow: inset 0 1px 0 rgba(255,255,255,0.2);
	padding: 10px 30px;
	color: #FFF;
	font-size: 16px;
	line-height: 1;
	text-shadow: 0 1px 0 rgba(0,0,0,0.2);
	cursor: pointer;
}
.sw-button a:hover,
.sw-button input[type="button"]:hover,
.sw-button button:hover {
	border: solid 1px #03a9f4;
	box-shadow: none;
}
.sw-button-cancel a,
.sw-button-cancel input[type="button"],
.sw-button-cancel button {
	border: solid 1px #999;
	background-color: #aaa;
}
.sw-button-cancel a:hover,
.sw-button-cancel input[type="button"]:hover,
.sw-button-cancel button:hover {
	border: solid 1px #aaa;
	box-shadow: none;
}
.sw-button-disable a,
.sw-button-disable input[type="button"],
.sw-button-disable button {
	border: solid 1px #ccc;
	background-color: #eee;
	color: #bbb;
	text-shadow: none;
	pointer-events: none;
}
@media screen and (max-width:959px) {
	.sw-buttons .sw-button {
		display: block;
		width: 80%;
		margin: 0 auto;
	}
	.sw-buttons .sw-button + .sw-button {
		margin-top: 10px;
	}
}



/* ----------------------------------------
	adjustments
---------------------------------------- */
.mt0 {margin-top: 0 !important;}
.mt5 {margin-top: 5x !important;}
.mt10 {margin-top: 10px !important;}
.mt15 {margin-top: 15px !important;}
.mt20 {margin-top: 20px !important;}
.mt25 {margin-top: 25px !important;}
.mt30 {margin-top: 30px !important;}
.mt35 {margin-top: 35px !important;}
.mt40 {margin-top: 40px !important;}
.mt45 {margin-top: 45px !important;}
.mt50 {margin-top: 50px !important;}
.mb0 {margin-bottom: 0 !important;}
.mb5 {margin-bottom: 5x !important;}
.mb10 {margin-bottom: 10px !important;}
.mb15 {margin-bottom: 15px !important;}
.mb20 {margin-bottom: 20px !important;}
.mb25 {margin-bottom: 25px !important;}
.mb30 {margin-bottom: 30px !important;}
.mb35 {margin-bottom: 35px !important;}
.mb40 {margin-bottom: 40px !important;}
.mb45 {margin-bottom: 45px !important;}
.mb50 {margin-bottom: 50px !important;}
.ta-l {text-align: left;}
.ta-c {text-align: center;}
.ta-r {text-align: right;}


