/*------------------------------------------------------------------------------

CSS Name: style css
Author: [ bran-new-days.com ]
Description: 2023/11/9

------------------------------------------------------------------------------*/

/* /////////////////////////////////////////////////////////////////////////////

 全体 style

///////////////////////////////////////////////////////////////////////////// */

/* font-family: 'Questrial', sans-serif; */
@import url('https://fonts.googleapis.com/css2?family=Questrial&display=swap');

main, article, aside, header, canvas, details, figcaption, figure, footer, nav, section, summary {
	display: block;
}

html {
	font-size: 16px;
}

body {
	position: relative;
	left: 0;
	overflow: hidden;
	word-wrap: break-word;
	color: #333;
	font-size: 1rem;
	font-family: 'Hiragino Kaku Gothic Pro','ヒラギノ角ゴ Pro W3','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',sans-serif;
	line-height: 1.6;
	background: #f1ece2;
	background-attachment: fixed;
}

a {
	color: #3d217f;
	color: #309cc5;
	text-decoration: underline;
}

a:hover {
	color: #5c429b;
	color: rgb(87, 126, 176);
	text-decoration: none;
}

a:hover img {
	opacity: 0.7;
	filter: alpha(opacity=70);
}

.font_gothic {
	font-family: 'Hiragino Kaku Gothic Pro','ヒラギノ角ゴ Pro W3','メイリオ',Meiryo,'ＭＳ Ｐゴシック','MS PGothic',sans-serif;
}
.font_mincho {
	font-family: '游明朝', YuMincho, 'Hiragino Mincho ProN W3', 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', 'ＭＳ 明朝', serif;
}

video, object {
	display: block;
	max-width: 100%;
	height: auto;
	border: none;
	vertical-align: bottom;
}

img {
	max-width: 100%;
	height: auto;
	border: none;
	vertical-align: bottom;
}

.vibtn {
	position: absolute;
	visibility: hidden;
}


/* /////////////////////////////////////////////////////////////////////////////

 layout

///////////////////////////////////////////////////////////////////////////// */

.contents_wrapper {
	position: relative;
	margin: 0 auto;
}

.main_contents {
	margin: 0 auto;
}


/* 背景横突き抜け：ブロック
------------------------------------------------------------- */

.contents {
	position: relative;
	clear: both;
	zoom: 100%;
}
.contents.wh {
	background: #FFF;
}
.contents.pk {
	background: rgb(219,138,154);
	background: linear-gradient(135deg, rgba(219,138,154,1) 0%, rgba(215,169,188,1) 100%);
	color: #FFF;
}
.contents.pk::before {
	position: absolute;
	display: block;
	content: '';
	width: 100%;
	height: 100%;
	background-image: radial-gradient(rgba(0,0,0,.15) 30%, transparent 30%);
	background-size: 6px 6px;
}
.contents.arrow::after {
	position: absolute;
	display: block;
	content: '';
	left: 50%;
	bottom: -50px;
	margin-left: -40px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 50px 40px 0 40px;
	border-color: #f1ece2 transparent transparent transparent;
	z-index: 1;
}

.contents_inner {
	position: relative;
	max-width: 1000px;
	margin: 0 auto;
	padding: 60px 15px;
	z-index: 1;
}


/*------------------------------------------------------------------------------

 header

------------------------------------------------------------------------------*/

.header_wrapper {
	height: 94px;
}

.header {
	position: fixed;
	z-index: 999999;
	top: 0;
	left: 0;
	width: 100%;
	background: #FFF;
	transition:all 300ms 0ms ease;
}

.header_inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 10px 10px;
	transition:all 300ms 0ms ease;
}
.header_main {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

/* logo */
.header_inner .logo {
	width: 45%;
	margin-top: 6px;
	line-height: 1.6;
	transition:all 300ms 0ms ease;
}
.header_inner .logo a {
	display: block;
	text-decoration: none;
}
.header_inner .logo img {
	width: 100%;
}

/* tel */
.header_inner .tel_block {
	width: 50%;
	margin-left: 5%;
	margin-bottom: 6px;
}
.header_inner .tel_block .tel_box .time {
	font-size: .75rem;
}
.header_inner .tel_block .tel_box .number {
	padding-left: .1em;
	font-size: min(6vw , 1.5rem);
}



/* gnavi
------------------------------------------------------------- */

.gnavi_block {
	width: 100%;
}
.gnavi {
	display: -webkit-flex;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	transition:all 300ms 0ms ease;
}
.gnavi li {
	margin-left: 4px;
}
.gnavi a {
	transition:all 300ms 0ms ease;
}

.gnavi .tel_box {
	margin-bottom: -2px;
}

/* header/footer 共通 */
.tel_box {
	text-align: center;
	line-height: 1;
}
.tel_box .time {
	display: block;
	margin-bottom: 4px;
	font-size: 1.125rem;
}
.tel_box .number {
	display: block;
	padding-left: .1em;
	color: #3d217f;
	font-size: 1.875rem;
	font-family: 'Questrial', sans-serif;
	font-weight: normal;
	letter-spacing: .1em;
}


/* -----------------------------------------------------------------------------

 .footer

----------------------------------------------------------------------------- */

.footer {
	background: #FFF;
}

.footer_inner {
	max-width: 1100px;
	margin: 0 auto;
	padding: 40px 15px;
}


/* fnavi
------------------------------------------------------------- */

.fnavi {
	margin-bottom: 20px;
	text-align: center;
}
.fnavi li {
	display: inline-block;
	margin-bottom: 15px;
	vertical-align: middle;
}

.fnavi .tel_box {
	margin-bottom: -2px;
}
.fnavi .tel_box .time {
	display: inline-block;
	margin-left: 1em;
}
.fnavi .tel_box .number {
	display: inline-block;
	margin-left: 1em;
}

/* copy
-----------------------------------------------------------*/

.copy_area {
	font-size: .8125rem;
}
.copy_area .copy {
	text-align: center;
}


/* page top
-----------------------------------------------------------*/

.page_top_fx {
	position: fixed;
	overflow: hidden;
	bottom: 10px;
	right: 10px;
	z-index: 99999;
}

.page_top_fx a {
	position: relative;
	display: block;
	cursor: pointer;
	width: 60px;
	height: 60px;
	border-radius: 50vw;
	background: rgba(89, 64, 147, .5);
	background-size: 40% auto;
	text-indent: 100%;
	white-space: nowrap;
}
.page_top_fx a::before {
	position: absolute;
	display: block;
	content: '';
	top: 24px;
	left: 19px;
	width: 20px;
	height: 20px;
	border-top: 2px solid #FFF;
	border-left: 2px solid #FFF;
	transform: rotate(45deg);
}


/* /////////////////////////////////////////////////////////////////////////////

 メインコンテンツ

///////////////////////////////////////////////////////////////////////////// */

/* パンくず
-----------------------------------------------------------*/

.breadcrumb {
	clear: both;
	max-width: 1040px;
	margin: 20px auto 20px;
	padding: 0 20px;
	color: #666;
	font-size: .875rem;
}

.breadcrumb li {
	display: inline-block;
	padding: 0 8px 0 0;
}

/* ボタンボックス
-----------------------------------------------------------*/

.btn_box {
	margin: 0;
	text-align: center;
}
.btn_box a ,
.btn_box input[type="submit"] ,
.btn_box button {
	cursor: pointer;
	display: inline-block;
	width: 360px;
	max-width: 100%;
	padding: 2px 10px;
	border-radius: 50vh;
	border: none;
	background: #8597ce;
	color: #FFF;
	text-decoration: none;
	letter-spacing: .2em;
}
.btn_box a:hover ,
.btn_box input:hover ,
.btn_box button:hover {
	opacity: .65;
}
.btn_box a span {
	display: inline-block;
	padding-left: .2em;
}

/* p */
p.btn_box {
	padding: 20px 0 30px;
}
p.btn_box + p.btn_box {
	padding-top: 0;
}

.btn_box.btn_textL a {
	width: 440px;
	max-width: 100%;
	padding: 12px 10px;
	font-size: 1.125rem;
	letter-spacing: 0;
}

/* btn header/footer */
.gnavi .btn_box a {
	width: 11em;
	max-width: 100%;
}
.fnavi .btn_box {
	margin-bottom: 0
}
.fnavi .btn_box a {
	width: 16em;
	max-width: 100%;
}

/* contact */
.btn_box.btn_contact a ,
.btn_box.btn_contact input[type="submit"] ,
.btn_box.btn_contact button {
	background: rgb(47,179,131);
	background: linear-gradient(135deg, rgba(47,179,131,1) 15%, rgba(48,156,197,1) 85%);
}

/* request */
.btn_box.btn_request a ,
.btn_box.btn_request input[type="submit"] ,
.btn_box.btn_request button {
	background: rgb(203,86,145);
	background: linear-gradient(135deg, rgba(203,86,145,1) 15%, rgba(146,78,171,1) 85%);
}

/* disabled */
.btn_box.btn_contact button:disabled ,
.btn_box.btn_contact input:disabled ,
.btn_box.btn_request button:disabled ,
.btn_box.btn_request input:disabled {
	opacity: .5;
}

/* text link */
.link_box a {
	display: inline-block;
}


/* animation parts
------------------------------------------------------------- */

/* fadein */
.fadein {
	opacity : 0;
	transform : translate(0, 50px);
	transition : all 800ms;
}
.fadein.scrollin {
	opacity : 1;
	transform : translate(0, 0);
}

.fadein.fast {
	opacity : 0;
	transform : translate(0, 50px);
	transition : all 250ms;
}
.fadein.fast.scrollin {
	opacity : 1;
	transform : translate(0, 0);
}

.fadein.left {
	opacity : 0;
	transform : translate(-100px, 0);
	transition : all 250ms;
}
.fadein.left.scrollin {
	opacity : 1;
	transform : translate(0, 0);
}


/* ページタイトル
-----------------------------------------------------------*/

/* title */
.title_block {
	margin-bottom: 20px;
	text-align: center;
}
.title_block h1 {
	font-size: 1.25rem;
}
.title_block h1 b ,
.title_block h1 span {
	display: inline-block;
	vertical-align: middle;
}
.title_block h1 .medium {
	margin-top: -10px;
	font-size: 1.5rem;
}
.title_block h1 .large {
	font-size: 1.75rem;
}
.title_block .dpk {
	color: #ab4e7d;
}
.title_block .pk {
	color: #c93d84;
}
.title_block .yw {
	color: #fff8a5;
}
.title_block .lsp2 {
	padding-right: .1em;
	letter-spacing: .1em;
}
.title_block p {
	margin-top: 20px;
}
.title_block p.catch {
	font-size: 1.125rem;
	font-weight: bold;
}

.title_min {
	font-size: 2.25rem;
}


/* -----------------------------------------------------------------------------

 lp

----------------------------------------------------------------------------- */

.cover {
	position: relative;
	padding: 5% 15px 0;
	background: rgb(219,138,154);
	background: linear-gradient(135deg, rgba(219,138,154,1) 0%, rgba(215,169,188,1) 100%);
}
.cover::before {
	position: absolute;
	display: block;
	content: '';
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-image: radial-gradient(rgba(0,0,0,.15) 30%, transparent 30%);
	background-size: 6px 6px;
}
.cover_area ,
.request_area {
	position: relative;
	max-width: 1200px;
	margin: 0 auto;
	z-index: 1;
}
.cover_catch {
	padding-bottom: 20px;
}

/* cover_catch */
.cover_catch .catchs {
	color: #FFF;
	line-height: 1.4;
}
.cover_catch .catchs img {
	display: block;
	width: 100%;
}
.cover_catch .catch02 {
	display: inline-block;
	width: 100%;
	max-width: 22em;
	margin-bottom: 15px;
	padding: 8px .5em;
	background: rgb(170,134,152);
	background: linear-gradient(135deg, rgba(170,134,152,1) 0%, rgba(167,155,168,1) 100%);
	font-size: 1.25rem;
}
.cover_catch .catch03 {
	margin-bottom: 15px;
	width: 100%;
	max-width: 23em;
	font-size: 1.25rem;
}
.cover_catch .catch01 {
	font-size: 9.4vw;
	letter-spacing: -.025em;
}


/* request
------------------------------------------------------------- */

.request_area .title_block h1 .medium {
	font-size: min(4vw , 2rem);
}

.request_text {
	text-align: left;
}
.request_text .title_block {
	text-align: left;
}

.for_area {
	margin-bottom: 20px;
	padding: 15px 20px 10px;
	background: #f6f3ec;
	color: #333;
}
.for_area h2 {
	color: #e97228;
	font-size: min(5vw , 1.75rem);
	text-align: center;
}

/* check_list */
.check_list {
	font-size: min(4.5vw , 1.5rem);
	font-weight: bold;
	line-height: 1.5;
	letter-spacing: .2em;
}
.check_list li {
	position: relative;
	padding-top: .5em;
	padding-bottom: .5em;
	padding-left: 2em;
	background: url(../image/line_dash01.svg) repeat-x 0% 100%;
	background-size: auto 2px;
}
.check_list li:last-child {
	background: none;
}
.check_list > li::before {
	position: absolute;
	display: block;
	content: '';
	top: .7em;
	left: .25em;
	width: 30px;
	height: 24px;
	background: url(../image/icon_check04.svg) no-repeat;
}


/* request_form
------------------------------------------------------------- */

.cover_area .request_form ,
.request_area .request_form {
	margin-left: -15px;
	margin-right: -15px;
	padding: 20px 10px;
	background: #f1ece2;
	box-shadow: 0 0 35px rgba(10,4,7,.15);
	color: #333;
}

.request_form h2 {
	margin-bottom: 20px;
	text-align: center;
	line-height: 1;
}
.request_form h2 b {
	display: inline-block;
	width: 8em;
	color: #c93d84;
	font-size: 1.75rem;
	vertical-align: middle;
}
.request_form h2 span {
	display: inline-block;
	margin-left: 1em;
	padding: 6px 8px;
	background: #c93d84;
	color: #FFF;
	font-weight: normal;
	vertical-align: middle;
}
.request_form .text {
	margin-bottom: 30px;
	font-size: .75rem;
	text-align: center;
}
.cover_area .form_box ,
.request_form .form_box {
	max-width: 520px;
	margin: 0 auto;
}
.request_form .form_box {
	margin-bottom: 10px;
	font-size: .875rem;
}
.request_form .privacy_check {
	font-size: .75rem;
}
.request_form .btn_box.btn_request button {
	letter-spacing: 0;
}


/* slide layout
------------------------------------------------------------- */

/* 上部 */

.cover_slide.pc_hide {
	margin-bottom: -100px;
}
.cover_slide.sp_hide {
	margin-top: -160px;
}


/* 下部 */

.bottom_slide {
	position: relative;
	z-index: 1;
}
.bottom_slide.pc_hide {
	margin-bottom: -80px;
}
.bottom_slide.sp_hide {
	margin-bottom: -120px;
}


/* infinite slide
------------------------------------------------------------- */

.infinite_slide {
	position: relative;
}
.infinite_slide_inner {
	display: flex;
}
.infinite_slide_list {
	display: flex;
	align-items: center;
}
.infinite_slide_list.left {
	animation :infinity-scroll-left 30s infinite linear .4s both;
}
.infinite_slide_list.right {
	animation :infinity-scroll-right 30s infinite linear .4s both;
}
.infinite_slide_list li {
	flex: 0;
	padding: 0 10px;
}
.infinite_slide_list img {
	max-width: 180px;
	max-height: 180px;
	box-shadow: 0 0 10px rgba(0,0,0,.2);
}
@media only screen and (min-width: 769px) {
	.infinite_slide_list img {
		max-width: 300px;
		max-height: 300px;
	}
}
@keyframes infinity-scroll-left {
	from { transform: translateX(0); }
	to { transform: translateX(-100%); }
}
@keyframes infinity-scroll-right {
	from { transform: translateX(-100%); }
	to { transform: translateX(0%); }
}


/* kadai
------------------------------------------------------------- */

.kadai_list {
	margin: 0 -10px -40px;
}
.kadai_list li {
	padding: 0 10px 40px;
}
.kadai_list .fig {
	width: 75%;
	margin: 0 auto;
}
.kadai_list .label {
	padding: 8px 0;
	border-radius: 50vh;
	background: #ab4e7d;
	color: #FFF;
	text-align: center;
}


/* message
------------------------------------------------------------- */

.message_area {
	font-size: .9375rem;
}


/* service
------------------------------------------------------------- */

.service_area {
	margin-top: 40px;
}

.service_list {
	max-width: 840px;
	margin: 0 auto -40px;
}
.service_list li {
	margin-bottom: 40px;
}

.service_list h2 {
	margin-bottom: 10px;
	text-align: center;
}
.service_list h2 em {
	display: block;
	width: 75%;
	margin: 0 auto 10px;
	padding: 4px;
	border-radius: 50vh;
	background: #c93d84;
	color: #FFF;
}
.service_list h2 span {
	display: inline-block;
	color: #c93d84;
	font-size: 1.25rem;
}

.service_list .inner .fig {
	width: 65%;
	margin: 0 auto;
}
.service_list .inner .text {
	font-weight: bold;
}


/* tokucho
------------------------------------------------------------- */

.tokucho_area {
	margin-top: 40px;
}

.tokucho_list {
	margin: 0 auto -20px;
}
.tokucho_list li {
	margin-bottom: 20px;
	border-radius: 15px;
	background: #f1ece2;
}
.tokucho_list .fig {
	padding: 20px 40px;
	text-align: center;
}
.tokucho_list .fig img {
	width: 75%;
}
.tokucho_list .text {
	padding: 20px;
	border-radius: 15px;
	background: #c93d84;
	color: #FFF;
}
.tokucho_list .text h2 {
	margin: 0 -15px 10px;
	font-size: 1.125rem;
	text-align: center;
	line-height: 1.6;
}


/* download
------------------------------------------------------------- */

.download_area {
	padding: 40px 20px;
	border-radius: 20px;
	background: #FFF;
	box-shadow: 0 20px 35px rgba(0,0,0,.25);
}



/* jirei
------------------------------------------------------------- */

.jirei_area {
	margin-top: 40px;
}

.jirei_list {
	max-width: 960px;
	margin: 0 auto;
}
.jirei_list li {
	margin-bottom: 20px;
	padding: 20px 20px;
	border-radius: 15px;
	background: #FFF;
	color: #333;
}
.jirei_list li:last-child {
	margin-bottom: 0;
}
.jirei_list .logo_block {
	width: 50%;
	margin: 0 auto 20px;
}
.jirei_list .logo_block .logo {
	background: #f1ece2;
	border-radius: 50%;
}
.jirei_list .text_block {
	font-size: 1rem;
}
.jirei_list .text_block .name {
	display: block;
	text-align: center;
}
.jirei_list .text_block .name span {
	display: inline-block;
	padding: 4px 1em;
	border-radius: 50vh;
	background: #c93d84;
	color: #FFF;
}
.jirei_list .text_block h2 {
	margin-top: 10px;
	margin-bottom: 10px;
	font-size: 1.25rem;
}


/* nissen
------------------------------------------------------------- */

.nissen_area .text_block {
	margin-bottom: 15px;
}


/* flow
------------------------------------------------------------- */

.flow_area {
	margin-top: 40px;
}

.flow_list li {
	position: relative;
	margin-bottom: 40px;
	border-radius: 15px;
	background: #FFF;
	box-shadow: 0 0 25px rgba(0,0,0,.15);
}
.flow_list li:last-child {
	margin-bottom: 0;
}
.flow_list li::after {
	position: absolute;
	display: block;
	content: '';
	left: 50%;
	bottom: -30px;
	margin-left: -18px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 30px 18px 0 18px;
	border-color: #FFF transparent transparent transparent;
	z-index: 1;
}
.flow_list li:last-child::after {
	content: none;
}
.flow_list li .caption {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 10px 10px;
	border-radius: 15px 15px 0 0;
	background: #c93d84;
	color: #FFF;
}
.flow_list li .caption h2 {
	padding-left: .2em;
	font-size: 1.25rem;
	letter-spacing: .2em;
}
.flow_list li .text {
	flex: 1;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	padding: 15px 20px;
}
.flow_list li .text p {
	font-weight: bold;
}


/* contact form
------------------------------------------------------------- */

.form_info {
	max-width: 800px;
	margin: 0 auto 20px;
}
.form_info > p {
	margin-bottom: 20px;
}


/* step
------------------------------------------------------------- */

.form_step {
	overflow: hidden;
	display: flex;
	justify-content: center;
	max-width: 520px;
	margin: 0 auto 20px;
	padding: 10px 0;
	font-size: 1.125rem;
	font-weight: bold;
}
.form_step li {
	position: relative;
	padding: 0 20px;
	text-align: center;
}
.form_step li::after {
	position: absolute;
	display: block;
	content: '';
	top: 50%;
	right: -5px;
	width: 9px;
	height: 16px;
	margin-top: -8px;
	background-image: url(../image/icon_arrow_no.svg);
	background-repeat: no-repeat;
	background-size: 100% auto;
	opacity: .5;
}
.form_step li:last-child::after {
	content: none;
}
.form_step .active {
	color: #c93d84;
	font-weight: bold;
}


/* form
------------------------------------------------------------- */

.form_area {
	max-width: 720px;
	margin: 0 auto 20px;
}

/* ul */
ul.form_box {
	margin: 0 -5px 35px;
}
.form_box li {
	display: flex;
	margin-bottom: 18px;
}

/* items */
.form_box .form-item {
	display: block;
	flex: 1;
	padding: 0 5px;
}
.form-item.select {
	position: relative;
}
.form-item.select .label {
	position: absolute;
	display: block;
	display: none;
	top: 2px;
	left: 9px;
	padding-right: 4em;
	height: calc(2em - 2px);
	background: #FFF;
	color: #999;
	font-size: .75rem;
	line-height: 2;
}

.form_box input[type="text"] ,
.form_box input[type="email"] ,
.form_box input[type="tel"] ,
.form_box select ,
.form_box textarea {
	width: 100%;
	height: 3em;
	padding: 0 8px;
	border: 1px solid #CCC;
	background: #FFF;
	border-radius: 4px;
}

::placeholder{
	color: #999;
	font-size: .75rem;
}

.privacy_check {
	margin-bottom: 20px;
	text-align: center;
	font-size: .875rem;
}
.privacy_check .form-item {
	display: block;
	margin-bottom: 10px;
}

/* btns */
.form_btn_list {
	text-align: center;
}
.form_btn_list li {
	margin-bottom: 10px;
}
.form_btn_list li button ,
.form_btn_list li a {
	width: 14em;
}


/* /////////////////////////////////////////////////////////////////////////////

 汎用CSS

///////////////////////////////////////////////////////////////////////////// */

/* テキスト関係 --------------------- */

.attention { /* 注意色(基本赤) */
	color: #CC0000;
}

.attentionB { /* 注意色(基本赤) */
	color: #CC0000;
	font-weight: bold;
}

.bold {
	font-weight: bold;
}

.text_SS {
	font-size: 75%;
}

.text_S {
	font-size: 86%;
}

.text_L {
	font-size: 120%;
}

.text_LL {
	font-size: 150%;
}

.text_LLL {
	font-size: 180%;
}


/* テキスト位置設定 ---------------- */

.entry_content p.center ,
.center {
	margin: auto;
	text-align: center;
}

.left {
	text-align: left;
}

.right {
	text-align: right;
}


/* マージン関係 ------------------- */

.m0 {
	margin: 0;
}

.m10 {
	margin: 10px;
}

.mT10 {
	margin-top: 10px;
}

.mT20 {
	margin-top: 20px;
}

.mB5 {
	margin-bottom: 5px;
}

.mB10 {
	margin-bottom: 10px;
}

.mB20 {
	margin-bottom: 20px;
}

.mR5 {
	margin-right: 5px;
}

.mR10 {
	margin-right: 10px;
}

.mR20 {
	margin-right: 20px;
}

.mL5 {
	margin-left: 5px;
}

.mL10 {
	margin-left: 10px;
}

.mL20 {
	margin-left: 20px;
}

.mRL10 {
	margin: auto 10px;
}

/*　パディング関係 ------------------ */
.p0 {
	padding: 0;
}

.p10 {
	padding: 10px;
}

.pT5 {
	padding-top: 5px;
}

.pT10 {
	padding-top: 10px;
}

.pB10 {
	padding-bottom: 10px;
}

.pR10 {
	padding-right: 10px;
}

.pL10 {
	padding-left: 10px;
}

.pB20 {
	padding-bottom: 20px;
}

.pRL10 {
	padding: auto 10px;
}

/* フロート関係 ------------------- */

.floatLeft {
	float: left;
}

.floatRight {
	float: right;
}

.clear,
.clearBoth {
	clear: both;
}

.clearfix {
	/zoom : 1; /* IE6-7 */
}

.clearfix::after { /* modern */
	content : '';
	display : block;
	clear : both;
	height: 0;
}


/* 画像関係
-----------------------------------------------------------*/

.figOne {
	margin-bottom: 40px;
}

.figLeft,
.figRight {
	display: block;
	margin: 0 auto 15px;
	text-align: center;
}

.fig_list {
	margin: 0 -10px 20px;
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.fig_list li {
	flex-grow: 0;
	width: 33.33333%;
}

.fig_list li div {
	padding: 0 10px 20px;
}



/* /////////////////////////////////////////////////////////////////////////////

 デバイス別

///////////////////////////////////////////////////////////////////////////// */

/*media Queries スマホ / PC
-----------------------------------------------------------*/

@media only screen and (max-width: 820px) {
	.sp_hide {
		display: none;
	}

	/* main ////////////////////////// sp */
	/* index ------------------------- sp */
	.cover_area .cover_slide.pc_hide + .request_form {
		padding-top: 120px;
	}
	.request_area .bottom_slide.pc_hide + .request_form {
		padding-top: 120px;
	}
	.contents_request .contents_inner {
		padding-bottom: 0;
	}
}

@media only screen and (min-width: 640px) {
	.header_wrapper {
		height: 65px;
	}
	.header_main {
		justify-content: space-between;
		flex-wrap: nowrap;
		align-items: center;
	}
	.header_inner .logo {
		width: 20%;
	}
	.header_inner .tel_block {
		width: 25%;
		margin-left: 2%;
	}
	.gnavi_block {
		width: 50%;
	}
}

@media only screen and (min-width: 821px) {
	.pc_hide {
		display: none;
	}
	.contents_inner {
		padding: 80px 15px;
	}
	.header_wrapper {
		height: 100px;
	}
	.header_inner {
		padding: 25px 20px;
	}
	.header_main {
		justify-content: space-between;
		flex-wrap: nowrap;
		align-items: center;
	}
	.header_main .logo {
		width: 290px;
		max-width: 23%;
		margin-bottom: 0;
	}
	.header_inner .tel_block {
		width: 30%;
		margin-left: 2%;
	}
	.header_inner .tel_block .tel_box .number {
		font-size: min(6vw , 1.875rem);
	}
	.gnavi_block {
		width: 460px;
		max-width: 40%;
	}
	.gnavi {
		justify-content: flex-end;
	}
	.gnavi li {
		flex-grow: 1;
		margin-left: 20px;
	}
	.header_slim {
		box-shadow: 0 0 4px rgba(0,0,0,.2);
	}
	.header_slim .header_inner {
		padding: 12px 20px;
	}
	.header_slim .header_inner .logo {
		width: 20%;
	}
	.header_slim .btn_box a {
		padding: 5px 20px;
	}
	.footer_inner {
		padding: 50px 20px;
	}
	.fnavi {
		margin-bottom: 40px;
	}
	.copy_area {
		display: flex;
		justify-content: space-between;
		font-size: .8125rem;
	}
	.copy_area .text ,
	.copy_area .copy {
		white-space: nowrap;
	}

	/* main ////////////////////////// pc */
	.btn_box a ,
	.btn_box input[type="submit"] ,
	.btn_box button {
		padding: 10px 10px;
		font-size: 1.125rem;
	}
	.btn_box.btn_textL a {
		font-size: 1.5rem;
	}
	.link_box a {
		font-size: 1.25rem;
	}

	.title_block {
		margin-bottom: 20px;
	}
	.title_block h1 {
		font-size: 2rem;
	}
	.title_block h1 .medium {
		margin-top: -10px;
		font-size: 2.5rem;
	}
	.title_block h1 .large {
		font-size: 3.125rem;
	}
	.title_block .lsp2 {
		padding-right: .2em;
		letter-spacing: .2em;
	}
	.title_block p.catch {
		font-size: 1.625rem;
	}

	/* LP ---------------------------- pc */
	.cover {
		padding-top: 15px;
		padding-bottom: 0px;
	}
	.cover_area ,
	.request_area {
		padding: 50px 10px;
		display: flex;
	}
	.cover_area {
		align-items: flex-start;
	}
	.request_area {
		align-items: center;
	}
	.cover_catch {
		flex: 1;
		padding-bottom: 120px;
	}
	.request_text {
		flex: 1;
	}
	.cover_catch .catch02 {
		margin-bottom: 30px;
		padding: 15px 1em;
		font-size: 1.375rem;
	}
	.cover_catch .catch03 {
		margin-bottom: 20px;
		font-size: 1.375rem;
	}
	.cover_catch .catch01 {
		font-size: 4rem;
	}

	/* request */
	.contents_request .contents_inner {
		max-width: 1200px;
		padding-top: 160px;
	}
	.for_area {
		display: inline-block;
		margin-bottom: 0;
		margin-right: 20px;
		padding: 30px 8% 25px;
	}
	.for_area h2 {
		font-size: 1.875rem;
	}
	.check_list {
		font-size: 1.5rem;
	}

	/* request_form */
	.cover_area .request_form ,
	.request_area .request_form {
		max-width: 430px;
		margin-left: auto;
		margin-right: auto;
		padding: 50px 30px 60px;
		border-radius: 15px;
	}
	.request_form .privacy_check {
		margin-bottom: 25px;
	}

	/* kadai */
	.kadai_list {
		display: flex;
		flex-wrap: wrap;
		margin: 0 -10px -60px;
	}
	.kadai_list li {
		width: 50%;
		padding: 0 30px 60px;
	}
	.kadai_list .fig {
		width: auto;
	}
	.kadai_list .label {
		padding: 10px 0;
		font-size: 1.25rem;
	}

	/* message */
	.message_area {
		font-size: 1.625rem;
		text-align: center;
	}

	/* service */
	.service_list h2 {
		margin-bottom: 20px;
	}
	.service_list h2 em {
		display: inline-block;
		min-width: 10em;
		width: auto;
		margin-right: 1em;
		padding: 8px 1em;
		font-size: 1.875rem;
	}
	.service_list h2 span {
		font-size: 1.875rem;
	}
	.service_list .inner {
		display: flex;
		align-items: center;
		margin-right: -20px;
	}
	.service_list .inner .fig {
		width: 320px;
		max-width: 40%;
		margin-right: 20px;
	}
	.service_list .inner .text {
		flex: 1;
		font-size: 1.25rem;
	}

	/* tokucho */
	.tokucho_list {
		display: flex;
		flex-wrap: wrap;
		margin: 0 -10px -40px;
	}
	.tokucho_list li {
		width: calc(50% - 40px);
		margin: 0 20px 50px;
	}
	.tokucho_list .fig img {
		width: 95%;
	}
	.tokucho_list .text h2 {
		font-size: 1.625rem;
	}
	.tokucho_list .text h2.one_line {
		line-height: 3.2;
	}
	.tokucho_list .text p {
		min-height: 4.6em;
	}

	/* jirei */
	.jirei_list li {
		margin-bottom: 30px;
		padding: 30px 40px;
	}
	.jirei_list li > div {
		display: flex;
		align-items: center;
	}
	.jirei_list .logo_block {
		width: 250px;
		max-width: 35%;
		margin: 0 40px 0 0;
	}
	.jirei_list .text_block {
		flex: 1;
		font-size: 1.125rem;
	}
	.jirei_list .text_block .name {
		text-align: left;
	}
	.jirei_list .text_block h2 {
		margin-top: 15px;
		margin-bottom: 15px;
		font-size: 1.875rem;
	}

	/* nissen */
	.nissen_area {
		display: flex;
		align-items: center;
	}
	.nissen_area .text_block {
		flex: 1;
		margin-bottom: 0px;
		font-size: 1.125rem;
	}
	.nissen_area .fig_block {
		width: 480px;
		max-width: 50%;
		margin-left: 40px;
	}

	/* flow */
	.flow_list li {
		display: flex;
		margin-bottom: 60px;
	}
	.flow_list li .caption {
		width: 280px;
		padding: 20px 10px;
		border-radius: 15px 0 0 15px;
	}
	.flow_list li .caption h2 {
		padding-left: .2em;
		font-size: 1.875rem;
		letter-spacing: .2em;
	}
	.flow_list li .text {
		padding: 30px 40px;
	}
	.flow_list li .text p {
		font-size: 1.125rem;
	}


	/* form ------------------------- pc */
	.form_box dt {
		padding: 20px 40px 10px;
	}
	.form_box dd {
		padding: 0 40px 20px;
	}
	.form_btn_list {
		display: flex;
		justify-content: center;
		flex-direction: row-reverse;
	}
	.form_btn_list li {
		margin-bottom: 0;
		padding: 0 10px;
	}

	/* common //////////////////////// pc */
	.figLeft {
		float: left;
		margin-right: 30px;
		margin-bottom: 10px;
	}
	.figRight {
		float: right;
		margin-left: 20px;
		margin-bottom: 10px;
	}
}

@media only screen and (min-width: 1100px) {
	.cover_catch .catch02 {
		font-size: 1.75rem;
	}
	.cover_catch .catch03 {
		font-size: 1.75rem;
	}
	.cover_catch .catch01 {
		font-size: 4.25rem;
	}
}
