/*------------------------------------------------------------------------------

CSS Name: style css
Author: [ bran-new-days.com ]
Description: 2024/4/3

------------------------------------------------------------------------------*/

/* /////////////////////////////////////////////////////////////////////////////

 全体 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.8;
	background: #f3f1e8;
	background-attachment: fixed;
}

a {
	color: #16b4c1;
	text-decoration: underline;
}

a:hover {
	color: #5bced9;
	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

///////////////////////////////////////////////////////////////////////////// */

.main_contents {
	margin: 0 auto;
}


/* 背景横突き抜け：ブロック
------------------------------------------------------------- */

.contents {
	position: relative;
	clear: both;
	zoom: 100%;
}
.contents.wh {
	background-color: #FFF;
}
.contents.gy {
	background-color: #e0e0e0;
}
.contents.mint {
	background-color: #16b4c1;
	color: #FFF;
}

.contents_inner {
	position: relative;
	max-width: 1030px;
	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: 0;
	font-size: min(1.5rem,5.35vw);
	white-space: nowrap;
}


/* 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: #16b4c1;
	font-size: 1.875rem;
	font-family: 'Questrial', sans-serif;
	font-weight: bold;
	letter-spacing: .1em;
}
.tel_box a ,
.tel_box a:link ,
.tel_box a:visited ,
.tel_box a:hover {
	pointer-events: none;
	text-decoration: none!important;
}
.tel_box a::before ,
.tel_box a::after {
	content: none!important;
	animation: none;
	transform: none;
	transition: unset;
}


/* -----------------------------------------------------------------------------

 .footer

----------------------------------------------------------------------------- */

.footer {
	background: #efeded;
}

.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;
	letter-spacing: .2em;
}
.fnavi .btn_box.btn_contact a {
	padding: 15px 15px;
}

/* copy
-----------------------------------------------------------*/

.copy_area {
	font-size: min(.8125rem,3vw);
}
.copy_area .text {
	margin-bottom: 10px;
}
.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(30, 154, 164, .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: #f4dd79;
	font-weight: 600;
	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;
}
.form_area.send .btn_box a {
	width: 480px;
}

/* 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 a {
	width: 16em;
	max-width: 100%;
}

/* contact */
.btn_box.btn_contact a ,
.btn_box.btn_contact input[type="submit"] ,
.btn_box.btn_contact button {
	color: #303131;
	background: rgb(244,221,121);
	background: linear-gradient(90deg, rgba(244,221,121,1) 0%, rgba(220,196,94,1) 100%);
}

/* request */
.btn_box.btn_request a ,
.btn_box.btn_request input[type="submit"] ,
.btn_box.btn_request button {
	color: #FFF;
	background: rgb(22,180,193);
	background: linear-gradient(90deg, rgba(22,180,193,1) 0%, rgba(30,154,164,1) 100%);
}

/* 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 400ms;
}
.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;
}
.contents_inner .title_block:last-child {
	margin-bottom: 0;
}
.title_block h1 ,
.title_block h2 {
	font-size: min(1.5rem,5.5vw);
}
.title_block h1 b ,
.title_block h1 span {
	display: inline-block;
	vertical-align: middle;
}
.title_block h1.medium {
	font-size: min(1.75rem,6vw);
	line-height: 1.6;
}
.title_block h1.large {
	font-size: min(2.5rem,8vw);
	line-height: 1.4;
}

.title_block .logo_mizukara {
	display: inline-block;
	margin-top: -.75em;
	margin-left: .25em;
	margin-right: .25em;
}
.title_block .large .logo_mizukara {
	margin-top: -.5em;
}
.title_block .large .logo_mizukara img {
	width: auto;
	height: 1.25em;
}
.title_block .logo_mizukara img {
	width: auto;
	height: 1.25em;
}

.title_block .plus {
	font-size: 130%;
}
.title_block .mint {
	color: #16b4c1;
}
.title_block .yw {
	color: #f4dd79;
}
.title_block .pk {
	color: #da4aa6;
}

.title_block .catch {
	margin-top: 1em;
	font-size: min(1.25rem,4.5vw);
}


/* テキスト
-----------------------------------------------------------*/

.text_block p {
	margin-bottom: 1.8em;
}
.text_block p:last-child {
	margin-bottom: .4em;
}

.marker__txt {
	display: inline;
}
.marker__txt.yw {
	background: #faf6c6;
}
.marker__txt.ywh {
	background: linear-gradient(transparent 50%, #f4dd79 0%);
}
.marker__txt.pkh {
	background: linear-gradient(transparent 50%, #f9deef 0%);
}


/* -----------------------------------------------------------------------------

 lp

----------------------------------------------------------------------------- */

.cover {
	position: relative;
}
.cover.cover_ver01 {
	background: url(../image/cover_bg.jpg) no-repeat 50% 50%;
	background-size: cover;
}
.cover_ver01 .cover_inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 20vh 15px 20vh;
}
.cover_ver01 .cover_inner .cover_logo {
	text-align: center;
}
.cover_ver01 .cover_inner .cover_logo img {
	max-width: 90%;
}
.cover_ver01 .cover_inner .text {
	position: absolute;
	right: .5em;
	bottom: 1em;
	color: #FFF;
	font-size: min(.75rem,3vw);
	text-align: right;
}


/* request
------------------------------------------------------------- */

.request_text {
	text-align: left;
}
.request_text .title_block {
	margin-bottom: 20px;
	text-align: left;
}

.for_block {
	margin-bottom: 20px;
}
.for_block {
	margin-bottom: 20px;
}
.for_block .fig_box {
	margin-bottom: 20px;
}
.for_block .fig_box img {
	max-width: 65%;
}
.for_block h2 {
	margin-bottom: 20px;
	padding: 4px 1em;
	border-radius: 50vh;
	background-color: #f4dd79;
	color: #303131;
	font-size: min(1.25rem, 4.5vw);
	text-align: center;
}

/* check_list */
.check_list {
	font-size: min(1.125rem, 4vw);
	font-weight: bold;
	line-height: 1.5;
}
.check_list li {
	position: relative;
	padding-top: .5em;
	padding-bottom: .5em;
	padding-left: 2em;
	border-bottom: 4px dotted #16b4c1;
	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_check01sq.svg) no-repeat;
}


/* request_form
------------------------------------------------------------- */

.request_area .request_form {
	padding: 20px 10px;
	background: #FFF;
	box-shadow: 0 0 20px rgba(34,40,80,.08);
	border-radius: 15px;
}

.request_form h2 {
	margin-bottom: 20px;
	text-align: center;
	line-height: 1;
}
.request_form h2 b {
	display: inline-block;
	color: #1e9aa4;
	font-size: min(1.5rem);
	letter-spacing: .15em;
	vertical-align: middle;
}
.request_form h2 span {
	display: inline-block;
	margin-left: 1em;
	padding: 6px 8px;
	background: #f4dd79;
	color: #303131;
	font-weight: normal;
	vertical-align: middle;
}
.request_form .text {
	margin-bottom: 30px;
	font-size: .75rem;
	text-align: center;
}
.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;
}


/* fukidashi
------------------------------------------------------------- */

.contents.contents_about {
	padding-bottom: 20px;
}
.contents_about .att_text {
	position: absolute;
	left: 0;
	bottom: -.5em;
	width: 100%;
}
.contents_about .att_text p {
	max-width: 820px;
	margin: 0 auto;
	font-size: min(.75rem,3vw);
	text-align: right;
}

.fukidashi_block {
	position: relative;
	max-width: 820px;
	margin: 0 auto;
}
.fukidashi_box {
	position: relative;
	margin-bottom: 20px;
	padding: 20px;
	border-radius: 15px;
	background-color: #FFF;
	vertical-align: middle;
}
.fukidashi_box::after {
	position: absolute;
	content: '';
	left: 80px;
	bottom: -60px;
	width: 45px;
	height: 65px;
	background-color: #FFF;
	clip-path: polygon(0 0, 100% 100%, 100% 0);
}
.fukidashi_box .marker__txt {
	padding: 2px;
}
.fukidashi_block .fig_box figcaption {
	padding: 8px 4px;
	border-radius: 50vh;
	background-color: #FFF;
	font-size: min(1rem,3.25vw);
	font-weight: 600;
	text-align: center;
}



/* service
------------------------------------------------------------- */

.service_list {
	margin: 0 -10px -40px;
}
.service_list li {
	padding: 0 10px 40px;
}
.service_list .fig_box {
	width: 65%;
	margin: 0 auto 20px;
}
.service_list .label {
	margin-bottom: 20px;
	padding: 8px 0;
	border-radius: 50vh;
	background: #16b4c1;
	color: #f4dd79;
	text-align: center;
}


/* download
------------------------------------------------------------- */

.download_area {
	margin-top: 0;
}
.download_area .title_block h1 {
	position: relative;
	display: inline-block;
	line-height: 1.4;
}
.download_area .title_block h1::before ,
.download_area .title_block h1::after {
	position: absolute;
	display: block;
	content: '';
	top: 10%;
	width: 0;
	height: 80%;
	border-left: 2px solid #333;
}
.download_area .title_block h1::before {
	left: 1em;
	transform:rotate(-35deg);
}
.download_area .title_block h1::after {
	right: 1em;
	transform:rotate(35deg);
}
.btn_block {
	text-align: center;
}
.btn_dl_box {
	margin-bottom: 20px;
}
.kaitai_area + .btn_block {
	margin-top: 30px;
}
.kaitai_area + .btn_block .btn_dl_box {
	margin-bottom: 0;
}
.btn_dl_box a {
	display: inline-block;
	width: 465px;
	max-width: 100%;
	padding: 10px 10px;
	background: url(../image/btn_dl_bg.png) 0 0;
	background-size: 100% 100%;
	box-shadow: 12px 12px 18px rgba(34, 40, 80, .35);
	color: #FFF;
	font-size: min(1.375rem,5vw);
	font-weight: 600;
	border-radius: 50vh;
	text-decoration: none;
}
.btn_dl_box a:hover {
	opacity: .5;
}


/* how
------------------------------------------------------------- */

.how_area {
	margin-top: 40px;
}

.how_list {
	max-width: 960px;
	margin: 0 auto;
}
.how_list li {
	margin-bottom: 20px;
	padding: 20px 20px;
	border-radius: 15px;
	background: #FFF;
	color: #333;
}
.how_list li:last-child {
	margin-bottom: 0;
}
.how_list .fig_box {
	width: 50%;
	margin: 0 auto 20px;
}
.how_list .text_box {
	font-size: 1rem;
}
.how_list .text_box h2 {
	margin-bottom: 15px;
	color: #16b4c1;
	font-size: min(1.75rem,6vw);
	text-align: center;
}


/* flow
------------------------------------------------------------- */

.title_block.flow {
	position: relative;
	margin-bottom: 40px;
	padding-bottom: 120px;
	border-bottom: 3px solid #1b1b3c;
}

.title_block.flow .fig {
	position: absolute;
	right: 0;
	bottom: 0;
	width: 140px;
}

.flow_area {
	max-width: 780px;
	margin: 0 auto;
}
.flow_list li {
	position: relative;
	margin-bottom: 40px;
}
.flow_list li:last-child {
	margin-bottom: 0;
}
.flow_list li::after {
	position: absolute;
	display: block;
	content: '';
	left: 50%;
	bottom: -30px;
	margin-left: -12px;
	width: 24px;
	height: 16px;
	background: url('data:image/svg+xml,%3Csvg%20height%3D%2224.5%22%20width%3D%2233.5%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22m26.814%207.5-11.314%2011.314-11.314-11.314%22%20fill%3D%22none%22%20stroke%3D%22%23c4c4c4%22%20stroke-linecap%3D%22round%22%20stroke-width%3D%225%22%2F%3E%3C%2Fsvg%3E') no-repeat;
	background-size: 100% auto;
}
.flow_list li:last-child::after {
	content: none;
}
.flow_list li .caption {
	position: relative;
}
.flow_list li .caption h2 {
	margin-bottom: 15px;
	padding: 6px;
	border-radius: 50vh;
	background: #16b4c1;
	color: #FFF;
	font-size: min(1.375rem);
	text-align: center;
}
.flow_list li .text {
	flex: 1;
}


/* kaitai
------------------------------------------------------------- */

.kaitai_area .fig_block {
	margin-bottom: 20px;
}
.kaitai_area .title_block h1 {
	position: relative;
	display: inline-block;
}
.kaitai_area .title_block h1::before ,
.kaitai_area .title_block h1::after {
	position: absolute;
	display: block;
	content: '';
	top: 10%;
	width: 0;
	height: 80%;
	border-left: 2px solid #333;
}
.kaitai_area .title_block h1::before {
	left: -.5em;
	transform:rotate(-35deg);
}
.kaitai_area .title_block h1::after {
	right: -.5em;
	transform:rotate(35deg);
}
.kaitai_area .text_box {
	font-size: .875rem;
}


/* 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: #16b4c1;
	font-weight: bold;
}

/* 20240605追記
------------------------------------------------------------- */
.news-inner {
	padding-top:40px !important;
	padding-bottom:40px !important
};
.news-area {
	display:table;
}
.news-text {
	width:380px;
	display:table-cell;
	vertical-align: middle;
}
.news-img {
	width:650px;
	display:table-cell;
}
p.news-sub {
	font-size:20px;
}
p.news-copy {
	font-size:min(1.75rem,6vw);
	margin-top:30px;
	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: 4em;
	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 (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 (max-width: 820px) {
	.sp_hide {
		display: none;
	}
		/* 20240605追記
	------------------------------------------------------------- */
	.news-area {
		display:block;
	}
	.news-text {
		width:100%;
		display:block;
		vertical-align: middle;
	}
	.news-img {
		width:100%;
		display:block;
	}
	p.news-sub {
		font-size:18px;
		text-align:center;
	}
	p.news-copy {
		font-size:min(1.75rem,6vw);
		margin:12px 0 24px 0;
		font-weight:bold;
		text-align:center;
	}
}

@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;
	}
	.fnavi .btn_box {
		margin-bottom: 0
	}
	.fnavi .tel_box .number {
		margin-left: .7em;
	}	
	.copy_area {
		text-align: center;
	}
	.copy_area .text {
		margin-bottom: 15px;
	}
	.copy_area .text ,
	.copy_area .copy {
		white-space: nowrap;
	}

	/* main ////////////////////////// pc */
	.btn_box a {
		padding: 10px 10px;
		font-size: 1.125rem;
	}
	.form_area .btn_box a ,
	.btn_box input[type="submit"] ,
	.btn_box button {
		padding: 15px 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: 40px;
	}

	/* LP ---------------------------- pc */
	/* cover */
	.cover_ver01 .cover_inner {
		padding: 10vw 15px 12vw;
	}
	
	/* request */
	.request_area {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	.request_text {
		flex: 1;
	}
	.for_block {
		position: relative;
		margin-bottom: 0;
		margin-right: 40px;
	}

	/* request_form */
	.request_area .request_form {
		max-width: 410px;
		margin-left: auto;
		margin-right: auto;
		padding: 60px 30px 60px;
	}
	.request_form h2 {
		margin-bottom: 30px;
	}
	.request_form .text {
		margin-bottom: 40px;
	}
	.request_form .privacy_check {
		margin-bottom: 25px;
	}

	/* fukidashi */
	.contents.contents_about {
		padding-bottom: 50px;
	}
	.contents_about .att_text {
		bottom: -2.5em;
	}	
	.fukidashi_block {
		display: flex;
		align-items: center;
	}
	.fukidashi_box {
		flex: 1;
		margin-bottom: 0;
		padding: 40px;
		border-radius: 25px;
	}
	.fukidashi_box::after {
		position: absolute;
		content: '';
		left: auto;
		right: -70px;
		bottom: 50%;
		width: 75px;
		height: 45px;
		clip-path: polygon(0 0, 0 100%, 100% 0);
	}
	.fukidashi_block .fig_box {
		position: relative;
		margin-left: -100px;
		margin-bottom: -175px;
		width: 430px;
		max-width: 50%;
		z-index: 2;
	}

	/* service */
	.service_list {
		display: flex;
		flex-wrap: wrap;
		margin: 0 -10px -60px;
	}
	.service_list li {
		width: 33.33333%;
		padding: 0 30px 60px;
	}
	.service_list .fig_box {
		width: auto;
	}
	.service_list .label {
		padding: 10px 0;
		font-size: 1.25rem;
	}

	.download_area .title_block h1::before ,
	.download_area .title_block h1::after {
		top: 0;
		height: 120%;
	}
	.download_area .title_block h1::before {
		left: -1em;
	}
	.download_area .title_block h1::after {
		right: -1em;
	}


	/* how */
	.how_list li {
		margin-bottom: 30px;
		padding: 30px 40px;
	}
	.how_list li > div {
		display: flex;
		align-items: center;
	}
	.how_list li:nth-child(2n) > div {
		flex-direction: row-reverse;
	}
	.how_list .fig_box {
		width: 250px;
		max-width: 35%;
	}
	.how_list li:nth-child(2n) .fig_box {
		margin: 0 0 0 40px;
	}
	.how_list li:nth-child(2n-1) .fig_box {
		margin: 0 40px 0 0;
	}
	.how_list .text_box {
		flex: 1;
	}
	.how_list .text_box h2 {
		margin-bottom: 25px;
	}

	/* flow */
	.title_block.flow {
		margin-bottom: 50px;
		padding-bottom: 40px;
	}
	.title_block.flow .fig {
		right: 30px;
		bottom: 0;
		width: 210px;
	}	
	.flow_list li {
		display: flex;
		margin-bottom: 44px;
	}
	.flow_list li::after {
		left: 73px;
		margin-left: 0;
	}
	.flow_list li .caption {
		width: 170px;
		margin-right: 60px;
	}
	.flow_list li .caption h2 {
		margin-bottom: 0;
	}

	/* kaitai */
	.kaitai_area {
		display: flex;
	}
	.kaitai_area .fig_block {
		max-width: 480px;
		margin-right: 40px;
	}
	.kaitai_area .text_block {
		flex: 1;
	}
	.kaitai_area .title_block {
		margin-bottom: 20px;
	}

	/* 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) {
}
