@charset "UTF-8";
article,aside,details,figcaption,figure,footer,header,hgroup,hr,menu,nav,section{display:block}a,hr{padding:0}abbr,address,article,aside,audio,b,blockquote,body,canvas,caption,cite,code,dd,del,details,dfn,div,dl,dt,em,fieldset,figcaption,figure,footer,form,h1,h2,h3,h4,h5,h6,header,hgroup,html,i,iframe,img,ins,kbd,label,legend,li,mark,menu,nav,object,ol,p,pre,q,samp,section,small,span,strong,sub,summary,sup,table,tbody,td,tfoot,th,thead,time,tr,ul,var,video{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:0 0}ins,mark{background-color:#ff9;color:#000}body{line-height:1}ul{list-style:none}blockquote,q{quotes:none}blockquote:after,blockquote:before,q:after,q:before{content:'';content:none}a{margin:0;font-size:100%;vertical-align:baseline;background:0 0}ins{text-decoration:none}mark{font-style:italic;font-weight:700}del{text-decoration:line-through}abbr[title],dfn[title]{border-bottom:1px dotted;cursor:help}table{border-collapse:collapse;border-spacing:0}hr{height:1px;border:0;border-top:1px solid #ccc;margin:1em 0}input,select{vertical-align:middle}*{box-sizing:border-box}


html{
	width:100%;
	height:100%;
	-webkit-text-size-adjust:none;
	-webkit-font-smoothing: antialiased;
	/*font-size:62.5%;*/
	font-size:0.625vw;
	background:#000;
}
@media screen and (max-width:1600px){
	html{
		font-size:62.5%;
	}
}
body{
	width:100%;
	padding-top: 4.2em;
	font-family: "SF Pro JP", "SF Pro Text", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴPro W3", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴPro", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "游ゴシック", YuGothic, "Yu Gothic", "メイリオ", Meiryo, "MS PGothic", sans-serif;
	line-height:1.7em;
	font-size:1.3rem;
	color:#fff;
	background:#262626;
}
h1,h2,h3,h4,h5,h6{
	font-weight:normal;
}
a{
	color:#ed5595;
	cursor:pointer;
	transition:opacity 0.2s ease 0s;
}
a:hover{
	opacity:0.5;
}
img{
	vertical-align:top;
}
.serif{
	font-family: "Noto Serif JP", serif;
	font-optical-sizing: auto;
	font-weight:400;
	font-feature-settings:"palt" 1;
	&.light{
		font-weight:300;
	}
}
.noto{
	font-family: 'Noto Sans JP', sans-serif;
	font-optical-sizing: auto;
	font-weight:700;
	font-feature-settings:"palt" 1;
}
.text_center{
	text-align:center !important;
}
.text_right{
	text-align:right !important;
}
.text_left{
	text-align:left !important;
}
.text_bold{
	font-weight:bold;
}
.text_red{
	color:#ed0000 !important;
}
.text_gold{
	color:#F5D682 !important;
}
.text_white{
	color:#fff !important;
}
.text_sup{
	font-size:0.6em;
	vertical-align: super;
}
.text_notice{
	display:inline-block;
	font-size:0.8em;
	line-height:1.6em;
}
.underline{
	display: inline;
	box-shadow: 0 -10px 0 #ffff00 inset;
}
img,picture,source,
.img_flex{
	display:block;
	width:100%;
	min-height:auto;
}
img.inline,
.img_flex.inline{
	display:inline-block;
}
.img_icon{
	display:inline-block;
	width:100%;
	max-width:1em;
	margin:0 5px 0 0;
	vertical-align:middle;
	position:relative;
	top:-0.1em;
}
.inline{
	display:inline-block;
}
.clearfix:after{
	content:"";
	clear:both;
	height:0;
	display:block;
	visibility:hidden;
}
.left{
	float:left;
}
.right{
	float:right;
}
.alpha{
	/*backface-visibility:hidden;*/
	transition:opacity 0.2s ease 0s;
	zoom:1;
}
.alpha:hover{
	opacity:0.6;
}
.inview{
	backface-visibility:hidden;
	transition:opacity 0.8s ease 0.6s, top 0.8s ease 0.6s;
	opacity:0;
	position:relative;
	top:20px;
}
.inview.visible{
	opacity:1;
	top:0;
}
.bn_cta,
input[type=submit].bn_cta{
	display:inline-block;
	box-sizing:border-box;
	padding:0.8em 1em;
	position:relative;
	vertical-align:middle;
	font-weight:bold;
	font-size:2rem;
	line-height:1;
	text-decoration:none;
	text-align:center;
	cursor:pointer;
	background: linear-gradient(to right, #FFDF87 0%, #FFBE2A 100%);
	border:solid 1px #FFDF87;
	color:#000;
	border-radius:2em;
	filter: drop-shadow(0px 0px 2px rgba(0, 0, 0, 0.14));
	transition:opacity 0.3s ease 0s, color 0.3s ease 0s, background 0.3s ease 0s, filter 0.3s ease 0s;
	&:hover{
		opacity:0.7;
		filter: drop-shadow(0px 0px 3px rgba(0, 0, 0, 0));
	}
	&.link{
		min-width:17em;
		padding:1em 1em 1.2em;
		background:#000;
		color:#FFDF87;
		font-size:1.5rem;
	}
	&.link:hover{
		background:#FFDF87;
		color:#000;
	}
}
.bn_link{
	display:inline-block;
	font-weight:bold;
	line-height:1;
	text-decoration:none;
	color:#ff8800;
	&:after{
		content:"";
		display:inline-block;
		width:1em;
		height:1em;
		margin:0 0 0 0.4em;
		vertical-align: middle;
		position: relative;
		top: -0.14em;
		background:url(../img/icon_link.svg) no-repeat center right/cover;
	}
	&.white{
		color:#fff;
		&:after{
			background-image:url(../img/icon_link_white.svg);
		}
	}
}
.visually-hidden{
	position: absolute;
	width: 1px;
	height: 1px;
	margin: -1px;
	border: 0;
	padding: 0;
	white-space: nowrap;
	clip-path: inset(100%);
	clip: rect(0 0 0 0);
	overflow: hidden;
}

/* ============================================================
contents_wrapper
============================================================ */
.contents_wrapper{
	width:100%;
	position:relative;
	z-index:1;
}
.contents_inner{
	width:100%;
	max-width:90%;
	margin-left:auto;
	margin-right:auto;
	padding-top:2em;
	padding-bottom:2em;
	box-sizing:border-box;
	position:relative;
	&.full{
		max-width:100%;
		padding-top:0;
		padding-bottom:0;
	}
}
.contents_heading{
	margin:0 0 1em;
	position:relative;
	text-align:center;
	font-size:2.5rem;
	letter-spacing:-0.05em;
	line-height:1.3em;
}

/* ============================================================
header
============================================================ */
#header{
	width:100%;
	padding:1em 5%;
	position:fixed;
	top:0;
	left:0;
	z-index:100;
	background:#000;
	box-shadow: 0px 2.5px 5px 0px rgba(0, 0, 0, 0.17);
}
.header_logo{
	width:50vw;
	margin:0 auto;
}

/* ============================================================
contents_mainvisual
============================================================ */
#contents_mainvisual{
	background:#000;
}

/* ============================================================
contents_case_main
============================================================ */
#contents_case_main{
	background:#000;
}
.case_main_video_wrap{
	background:url(../img/img_case_main_video_wrap_sp.webp) no-repeat center center/cover;
}
.video_block{
	width: 100%;
	aspect-ratio: 9 / 16;
	object-fit: cover;
	position:relative;
}
.video_loading{
	position:absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width:60px;
}
video{
	display:block;
}
.case_text{
	font-size:1.1rem;
	line-height:1.3em;
	text-align:left;
	#contents_case_main &{
		padding:1em;
	}
}

/* ============================================================
contents_problem
============================================================ */
#contents_problem{
	background: linear-gradient(to bottom, #202020 0%, #4C4C4C 70%);
	.contents_inner{
		padding-top:2em;
	}
}
.problem_title{
	filter: drop-shadow(0px 0px 3px rgba(0, 0, 0, 0.8));
}

/* ============================================================
contents_case
============================================================ */
.case_title{
	font-size:2.2rem;
}
.case_item{
	margin:0 0 1em;
	background:#000;
	&:last-child{
		margin:0;
	}
	.video_block{
		aspect-ratio: 1 / 1;
	}
	.case_text{
		padding:0 0.7em 0.7em;
	}
}

/* ============================================================
contents_solution
============================================================ */
.solution_title{
	margin: 0 0 0.7em;
	font-size:2.5rem;
}
.solution_item{
	margin:0 0 1em;
	padding:1em 0;
	border:solid 1px #605B53;
	&.hamura{
		border:solid 1px #F5D682;
	}
}
.solution_item_title{
	margin:0.4em 0 0.2em;
	font-size:2.0rem;
}
.solution_item_desc{
	line-height:1.4em;
}
.solution_tri{
	width:2em;
	margin:0 auto;
}

.cta_block{
	text-align:center;
}
.cta_block_image{
	max-width:80%;
	margin:0 auto;
	position:relative;
}
.cta_block_bn{
	display:inline-block;
	position:relative;
	margin-top:-1em;
	padding:1em;
	border-radius:4em;
	background:rgba(255,204,82,0.5);
	.bn_cta{
		min-width:14em;
	}
}

/* ============================================================
contents_namida
============================================================ */
#contents_namida{
	background:#000;
	.contents_heading{
		margin: 0 0 0.4em;
		font-size: 2.7rem;
	}
}

/* ============================================================
contents_namida
============================================================ */
#contents_appeal{
	background:#000;
	border-top:solid 1px #F5D682;
}
.appeal_point{
	display:flex;
	max-width:86%;
	margin:1em auto 0;
}

/* ============================================================
contents_point
============================================================ */
#contents_point{
	background: linear-gradient(to bottom, #000 0%, #262626 120px);
	.contents_heading{
		display:inline-block;
		margin-top:-0.2em;
		padding:0.3em 1em;
		position:relative;
		background-image:url(../img/img_point_title_bg_left.svg), url(../img/img_point_title_bg_right.svg);
		background-repeat:no-repeat;
		background-size:contain;
		background-position:left top, right top;
		font-size:2.3rem;
	}
}
.point_logo{
		max-width:3em;
		margin:0 auto;
}
.point_item{
	position:relative;
	margin:0 0 1em;
	&:before{
		content:"";
		display:block;
		width:100%;
		height:1px;
		background:#F5D682;
		position:absolute;
		left:0;
		top:25px;
	}
}
.point_item_num{
	max-width:5em;
	margin:0 auto;
	position:relative;
}
.point_item_title{
	margin:0 0 0.5em;
	position:relative;
	text-align:center;
	font-size:2.8rem;
	letter-spacing:-0.05em;
	line-height:1.2em;
}
.point_item_image{
	margin:0 0 1em;
	img:not(:last-child){
		margin:0 0 10px;
	}
}
.point_item_desc{
	text-align:left;
	line-height:1.6em;
}

/* ============================================================
contents_dr
============================================================ */
#contents_dr{
	border-top:solid 1px #F5D682;
}
.dr_subtitle{
	font-size:1.7rem;
	line-height:1em;
}
.dr_title{
	font-size:3rem;
	line-height:1.5em;
	small{
		font-size:0.6em;
	}
}
.dr_desc{
	margin:0.5em 0 0;
	font-size:1.35rem;
	line-height:1.8em;
}

/* ============================================================
contents_sns
============================================================ */
#contents_sns{
	.contents_inner{
		padding-top:2em;
		padding-bottom:2em;
	}
}
.sns_title{
	font-size: 2.5rem;
	line-height: 1em;
	img{
		max-width:2em;
		margin:0 auto 0.3em;
	}
}
.sns_desc{
	width:90%;
	margin:1em auto;
}
.sns_wrap_ig_inner{
	margin:1em 0 4em;
	background:url(../img/img_sns_wrap_ig_bg.webp) no-repeat center center/100% 92%;
	.row_01, .row_02{
		display:flex;
		a, figure{
			display:block;
			width:49%;
			position:relative;
		}
	}
	#sns_wrap_ig_image_02,
	#sns_wrap_ig_image_04{
		top:3em;
	}
}
.sns_wrap_ig_slogan{
	font-size: 9vw;
	letter-spacing: -0.05em;
	line-height: 1em;
	small{
		font-size:0.75em;
	}
	.rainbow{
		background:url(../img/img_sns_wrap_ig_grad.webp) no-repeat center center/100%;
		position: relative;
		display: inline-block;
		background-size: 100%;
		background-repeat: repeat;
		background-clip: text;
		-webkit-text-fill-color: transparent;
	}
}
.sns_wrap_hr{
	display:block;
	width:90%;
	height:1px;
	margin:3em auto;
	background:#F5D682;
	border:none;
	outline:none;
}
.yt_video{
	margin:2em 0 0;
}
.yt_video_embed{
	width: 100%;
	position:relative;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	overflow:hidden;
	iframe{
		display:block;
		width:100%;
		height:100%;
	}
}

/* ============================================================
contents_qa
============================================================ */
#contents_qa{
	background:#000;
}
.qa_item{
	max-width:65em;
	margin:0 auto 1em;
	padding:1.5rem;
	box-sizing:border-box;
	position:relative;
	background:#fff;
	&:last-child{
		margin:0 auto;
	}
}
.qa_body{
	display: flex;
	justify-content: flex-start;
}
.qa_body.question{
	align-items:center;
	margin:0 0 0.7em;
	padding:0 0 0.7em;
	border-bottom:solid 1px #ddd;
}
.qa_icon{
	font-size:1.6rem;
	font-weight:bold;
	color:#fff;
	span{
		display:block;
		width:1.8em;
		line-height:1.8em;
		border-radius:1.8em;
		text-align:center;
		background:#a5a5a5;
	}
	.answer & span{
		background:#D3AC4C;
	}
}
.qa_text{
	padding:0 0 0 1em;
	flex-grow:1;
	color:#000;
	.question &{
		font-weight:bold;
		font-size:1.5rem;
		line-height:1.3em;
	}
	.answer &{
		font-size:1.3rem;
	}
}

/* ============================================================
contents_access
============================================================ */
#contents_access{
	background:#000;
}
.access_paragraph{
	max-width:40em;
	margin:0 auto;
}
.access_paragraph:not(:last-child){
	margin:0 auto 1em;
	padding:0 0 1em;
	border-bottom:solid 1px #666;
}
.access_title{
	margin:0 0 0.6em;
	font-weight:normal;
	font-size:1.8rem;
}
.access_desc{
	li{
		margin: 0 0 0.2em 1.5em;
		list-style:disc;
		list-style-type:disc;
		font-weight:bold;
		&:last-child{
			margin-bottom:0;
		}
		span{
			display:block;
			font-weight:normal;
			line-height:1.3em;
		}
	}
}
.access_map{
	filter: drop-shadow(0px 0px 2px rgba(0,0,0,0.05));
	iframe{
		display:block;
	}
}

/* ============================================================
contents_contact
============================================================ */
#contents_contact{
}
.contact_intro{
	margin:0 0 4em;
}
#contents_form{
 max-width:60em;
	margin:0 auto;
}
.contents_form_input{
	margin:0 auto 2em;
}
.contents_form_input_wrap{
	display:flex;
	justify-content:space-between;
	margin:0 auto 2em;
}
.contents_form_input_wrap .contents_form_input{
	width:48%;
	margin:0;
}
.contact_form_submit{
	margin:3em auto 0;
}
.contents_form_input .input{
	position:relative;
}
.contents_form_input label:not(.checkbox){
	display:inline-block;
	font-weight:bold;
	margin:0 0 0.2em;
}
.contents_form_input label .sup{
	font-weight:normal;
}
.contents_form_input label .notice{
	display:inline-block;
	margin:0 0 0 4px;
	color:#ff3636;
	font-size:1.3rem;
}
.contents_form_input input::placeholder{
	color:#777;
}
.contents_form_input{
	input:focus::-webkit-input-placeholder {
		color: transparent;
	}
	input:focus::-moz-placeholder {
		color: transparent;
	}
	input:focus::-ms-input-placeholder {
		color: transparent;
	}
	input:focus::placeholder {
		color: transparent;
	}
}
.contents_form_input input:not([type=checkbox]):not([type=radio]):not([type=submit]),
.contents_form_input textarea,
.contents_form_input select{
	display:inline-block;
	width:100%;
	padding:0.7em;
	box-sizing:border-box;
	font-size:1.5rem;
	text-transform:none;
	border:solid 1px #494949;
	border-radius:4px;
	background:#353535;
	color:#eee;
	box-shadow:inset 0 1px 3px rgba(0,0,0,.05);
	-webkit-appearance:none;
	transition:background 0.2s ease 0s, border 0.2s ease 0s;
	font-family: inherit;
}
.contents_form_input input:not([type=checkbox]):not([type=radio]):not([type=submit]):focus,
.contents_form_input textarea:focus{
	text-decoration:none;
	outline:none;
	border:solid 1px #eee;
}
.contents_form_input input:not([type=checkbox]):not([type=radio]):not([type=submit]).error,
.contents_form_input textarea.error,
.contents_form_input select.error{
	background:rgba(255,0,0,0.2);
	border:solid 1px #FF0000;
}
.contents_form_input [type="radio"]{
	margin:0;
}
@media screen and (min-width:769px) {
	.contents_form_input select{
		padding:0.9em;
		-webkit-appearance:none;
		transition:background 0.2s ease 0s;
		-webkit-appearance:none;
		-moz-appearance:none;
		appearance:none;
	}
	.contents_form_input select::-ms-expand {
		display:none;
	}
	.select_box,
	.select_wrap{
		position:relative;
	}
	.select_box:after,
	.select_wrap:after {
		content: '';
		display: block;
		width: 0;
		height: 0;
		border-style: solid;
		border-width: 0.8em 0.5em 0 0.5em;
		border-color: #999 transparent transparent transparent;
		position: absolute;
		right: 0.5em;
		top: 1.1em;
	}
}
.contents_form_input .checkbox_wrapper > p{
	display:inline-block;
	margin:0 1em 0 0;
}
.contents_form_input label.checkbox{
	display:inline-block;
	line-height:1;
	cursor:pointer;
}
.contents_form_input .checkbox_wrapper [type="checkbox"]:not(:checked),
.contents_form_input .checkbox_wrapper [type="checkbox"]:checked,
.contents_form_input .checkbox_wrapper [type="radio"]:not(:checked),
.contents_form_input .checkbox_wrapper [type="radio"]:checked{
	position:absolute;
	left:-9999px;
}
.contents_form_input .checkbox_wrapper [type="checkbox"]:not(:checked) + label,
.contents_form_input .checkbox_wrapper [type="checkbox"]:checked + label,
.contents_form_input .checkbox_wrapper [type="radio"]:not(:checked) + label,
.contents_form_input .checkbox_wrapper [type="radio"]:checked + label {
	position:relative;
	padding-left:1.6em;
	cursor:pointer;
}

/* checkbox aspect */
.contents_form_input .checkbox_wrapper [type="checkbox"]:not(:checked) + label:before,
.contents_form_input .checkbox_wrapper [type="checkbox"]:checked + label:before,
.contents_form_input .checkbox_wrapper [type="radio"]:not(:checked) + label:before,
.contents_form_input .checkbox_wrapper [type="radio"]:checked + label:before{
	content:'';
	position:absolute;
	left:0; top:0;
	width:1.25em; height:1.25em;
	border: solid 1px #ddd;
	background:#F4F4F4;
	border-radius:4px;
	box-shadow:inset 0 1px 3px rgba(0,0,0,.1);
}
/* checked mark aspect */
.contents_form_input .checkbox_wrapper [type="checkbox"]:not(:checked) + label:after,
.contents_form_input .checkbox_wrapper [type="checkbox"]:checked + label:after,
.contents_form_input .checkbox_wrapper [type="radio"]:not(:checked) + label:after,
.contents_form_input .checkbox_wrapper [type="radio"]:checked + label:after{
	content:'\2713\0020';
	position:absolute;
	top:.15em; left:.22em;
	font-size:1.3em;
	line-height:0.8;
	color:#09ad7e;
	transition:all .2s;
	font-family:'Lucida Sans Unicode', 'Arial Unicode MS', Arial;
}
/* checked mark aspect changes */
.contents_form_input .checkbox_wrapper [type="checkbox"]:not(:checked) + label:after,
.contents_form_input .checkbox_wrapper [type="radio"]:not(:checked) + label:after {
	opacity:0;
	transform:scale(0);
}
.contents_form_input .checkbox_wrapper [type="checkbox"]:checked + label:after,
.contents_form_input .checkbox_wrapper [type="radio"]:checked + label:after{
	opacity:1;
	transform:scale(1);
}
.contents_form_input .valid_msg{
	display: block !important;
	padding:4px 0 0;
	color:#ff3636;
	font-weight:bold;
	line-height:1;
}
.contents_form_input .bn_cta,
.contents_form_input input[type=submit]{
	display:block;
	width:100%;
	cursor:pointer;
	appearance:none;
	-webkit-appearance:none;
	outline:none;
	border:none;
	font-size:2rem;
	padding: 0.8em;
}

.tel_wrap{
	.wpcf7-form-control-wrap{
		position:static;
	}
	#form_tel_01,
	#form_tel_02,
	#form_tel_03{
		width:29%;
	}
	#valid_required-form_tel_01,
	#valid_required-form_tel_02,
	#valid_required-form_tel_03{
		position:absolute;
		bottom: -1.3em;
	}
}

.ui-datepicker-week-end .ui-state-default {
	background-color: #fce4ec;
	color: #d32f2f;
}
.ui-datepicker-week-end:nth-child(1) .ui-state-default {
	color: #e53935; /* 日曜 */
}
.ui-datepicker-week-end:nth-child(7) .ui-state-default {
	color: #1e88e5; /* 土曜 */
}

.form_counseling_wrap{
	display:flex;
	justify-content:flex-start;
	grid-gap:2em;
	width:100%;
	margin:0 0 0.5em;
}
.form_counseling_item{
	display:flex;
	justify-content:flex-start;
	align-items:center;
	grid-gap:0.5em;
	p{
		font-size: 1.5rem;
		font-weight:bold;
		white-space:nowrap;
	}
}

.form_notice{
	margin:5px 0 0;
	font-size:0.8em;
}
.contents_form_input .wpcf7-spinner{
	display: block;
	position: absolute;
	left: 50%;
	margin-top: 20px;
	margin-left: -12px;
}
.contents_form_input .ajax-loader {
	display:block !important;
}
.contents_form_input .wpcf7-not-valid-tip {
	display:none !important;
}
.privacy_wrap{
	margin:3em 0 0;
}
.privacy_desc{
	margin:0 0 2em;
	h3{
		margin:0 0 1em;
		font-weight:bold;
		font-size:1.6rem;
	}
}

/* ============================================================
contents_footer
============================================================ */
#contents_footer .contents_inner{
	padding-top:2em;
	padding-bottom:10em;
	font-size:1.2rem;
}

/* ============================================================
cta_bottom
============================================================ */
#cta_bottom{
	position:fixed;
	width:100%;
	bottom: -8em;
	left:0;
	z-index:4;
	padding:0.6em 0.5em;
	background: linear-gradient(to bottom, #404040 0%, #1A1A1A 30%);
	transition: all 0.4s ease 0s;
	&.scroll{
		bottom:0;
	}
}
.cta_bottom_text{
	margin:0 0 0.6em;
	color:#fff;
	line-height:1;
	font-size:1.4rem;
	span{
		display:inline-block;
		color:#ddb97a;
		margin:0 0.3em 0 0;
	}
}
.cta_bn_wrap{
	display:flex;
	justify-content:center;
	grid-gap:0.5em;
	.bn_cta{
		min-width:0;
		padding: 0.5em 0.8em;
		font-size:1.5rem;
		font-weight:normal;
		letter-spacing:0;
	}
}
.bn_cta.tel{
	.img_icon{
		max-width: 1.3em;
	}
}
.bn_cta.access{
	.img_icon{
		max-width: 0.8em;
	}
}

/* ============================================================
Responsive
============================================================ */
@media screen and (min-width:769px){
	.pc_hide{
		display:none !important;
	}
	html{
		background:#333;
	}	
	body{
		max-width:750px;
		margin:0 auto;
		padding-top: 70px;
		box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.3);
		font-size:1.5rem;
	}

	/* ============================================================
	contents_wrapper
	============================================================ */
	.contents_inner{
		max-width:96%;
		padding-top:3em;
		padding-bottom:3em;
	}
	.contents_heading{
		font-size:4rem;
	}

	/* ============================================================
	header
	============================================================ */
	#header {
		padding: 20px 5%;
	}
	.header_logo{
		width:200px;
	}
	
	/* ============================================================
	contents_case_main
	============================================================ */
	.case_text{
		font-size:1.4rem;
		line-height:1.5em;
	}
	
	/* ============================================================
	contents_solution
	============================================================ */
	.solution_item{
		padding:1.5em 0;
	}
	.solution_item_title{
		margin:0.4em 0 0.5em;
		font-size:2.5rem;
	}
	.cta_block_image{
		max-width:500px;
	}
	.cta_block_bn{
		.bn_cta{
			min-width:22em;
		}
	}

	/* ============================================================
	contents_point
	============================================================ */
	#contents_point{
		.contents_heading{
			font-size:3.5rem;
		}
	}
	.point_logo{
			max-width:4em;
	}
	.point_item{
		margin:0 0 1.5em;
		&:before{
			top:45px;
		}
	}
	.point_item_num{
		max-width:6em;
	}
	.point_item_title{
		margin:0.2em 0 0.5em;
		font-size:3.5rem;
	}
	
	/* ============================================================
	contents_dr
	============================================================ */
	.dr_subtitle{
		font-size:2.3rem;
	}
	.dr_title{
		font-size:4rem;
	}
	.dr_desc{
		font-size:1.6rem;
	}

	/* ============================================================
	contents_sns
	============================================================ */
	#contents_sns{
		.contents_inner{
			padding-top:3em;
			padding-bottom:3em;
		}
	}
	.sns_title{
		font-size: 3rem;
	}
	.sns_desc{
		width:94%;
	}
	.sns_wrap_ig_slogan{
		font-size: 3.2em;
		letter-spacing: 0;
	}
	.sns_wrap_hr{
		width:94%;
		height:1px;
	}
	
	/* ============================================================
	contents_qa
	============================================================ */
	.qa_icon{
		font-size:1.8rem;
	}
	.qa_text{
		.question &{
			font-size:1.7rem;
		}
		.answer &{
			font-size:1.5rem;
		}
	}
	
	/* ============================================================
	contents_access
	============================================================ */
	.access_paragraph{
		max-width:90%;
	}
	.access_title{
		font-size:2rem;
	}
	.access_map{
		iframe{
			height:400px;
		}
	}


	/* ============================================================
	cta_bottom
	============================================================ */
	#cta_bottom{
		bottom: -8em;
		padding:1em 0;
	}
	.cta_bottom_text{
		font-size:1.7rem;
	}
	.cta_bn_wrap{
		.bn_cta{
			font-size:1.9rem;
		}
	}

}


@media screen and (max-width:768px) {
	.sp_hide{
		display:none !important;
	}

	/* ============================================================
	contents_contact
	============================================================ */
	.contents_form_input{
		margin:0 auto 1.5em;
	}
	.contents_form_input_wrap{
		display:block;
		margin:0;
	}
	.contents_form_input_wrap .contents_form_input{
		width:100%;
		margin:0 auto 1.2em;
	}
	.contents_form_input label:not(.checkbox){
		margin: 0 0 0.4em;
		font-size:1.45rem;
	}
	.contents_form_input label .notice{
		font-size:1.2rem;
	}
	.contents_form_input .bn_cta,
	.contents_form_input input[type=submit]{
		width:100%;
		font-size:2rem;
	}

	.privacy_wrap{
		text-align:left !important;
		label{
			display:block !important;
			text-align:left !important;
			line-height:1.5em !important;
		}
	}

	.form_counseling_wrap{
		display:block;
	}
	.form_counseling_item{
		margin:0 0 0.8em;
		grid-gap:1em;
		p{
			font-size: 1.4rem;
			flex-shrink:0;
		}
	}

}

