@charset "utf-8";
/* --------------------------------------------------
	reset
-------------------------------------------------- */
* { margin: 0; padding: 0; box-sizing: border-box;}

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,
form, 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 {
	margin: 0; padding: 0;
	border: 0;
	font-size: 100%;
	vertical-align: baseline;
}

img{ vertical-align: bottom;}
ul{ list-style: none;}
ul li{ list-style-type: none;}
figure { margin: 0;}


/* =============================================================================
   Forms
   ========================================================================== */
form { margin: 0;}
fieldset { border: 1px solid #c0c0c0; margin: 0 2px; padding: 0.35em 0.625em 0.75em;}
legend { border: 0;}
button,
input,
select,
textarea { font-size: 100%; margin: 0; vertical-align: baseline;}
button,
input { line-height: normal;}
button,
input[type="button"], 
input[type="reset"], 
input[type="submit"] { cursor: pointer; -webkit-appearance: button; }
input[type="checkbox"],
input[type="radio"] { box-sizing: border-box; padding: 0;}
input[type="search"] {
  -webkit-appearance: textfield;
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
}
input[type="search"]::-webkit-search-decoration { -webkit-appearance: none;}

button::-moz-focus-inner,
input::-moz-focus-inner { border: 0; padding: 0; }
textarea { overflow: auto; vertical-align: top;}
input[type="search"]:focus { outline: none;}

table {
    border-collapse: collapse;
    border-spacing: 0;
}


/*		font-style
-------------------------------------------------- */
body {
	font-family: "Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3","メイリオ","Meiryo","ＭＳ Ｐゴシック",sans-serif;
/*	font-family: "游ゴシック","Yu Gothic","Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3", "メイリオ","Meiryo",sans-serif;*/
	font-size: 16px;
	*font-size:small;
	*font:x-small;
	line-height: 1.6;
}
input, textarea {font-family: "Hiragino Kaku Gothic Pro","ヒラギノ角ゴ Pro W3","メイリオ","Meiryo","ＭＳ Ｐゴシック",sans-serif;}

.min {font-family: "游明朝", "Yu Mincho", "YuMincho", serif;}

::selection{ background: #feffaf; color: #000;}
::-moz-selection{ background: #feffaf; color: #000;}


a { color:#002159; text-decoration: underline;}
a:link   { color:#002159;}
a:visited{ color:#002159;}
a:hover  { color:#002159;}
a:active { color:#002159;}

em{ font-style: normal;}


/*		utility
-------------------------------------------------- */
.cf{ /zoom: 1; clear: both;}
.cf:after{ content: ''; display: block; clear: both;}

@media (max-width: 641px) {
}






/* Slider */
.slick-slider { position: relative; display: block; box-sizing: border-box;
-webkit-user-select: none;
   -moz-user-select: none;
    -ms-user-select: none;
        user-select: none;

-webkit-touch-callout: none;
	-khtml-user-select: none;
	-ms-touch-action: pan-y;
  	  touch-action: pan-y;
-webkit-tap-highlight-color: transparent;
}

.slick-list { position: relative; display: block; overflow: hidden; margin: 0; padding: 0;}
.slick-list:focus { outline: none;}
.slick-list.dragging{ cursor: pointer; cursor: hand;}
.slick-slider .slick-track,
.slick-slider .slick-list{
-webkit-transform: translate3d(0, 0, 0);
   -moz-transform: translate3d(0, 0, 0);
    -ms-transform: translate3d(0, 0, 0);
     -o-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
}
.slick-track { position: relative; top: 0; left: 0; display: block;}
.slick-track:before,
.slick-track:after { display: table; content: '';}
.slick-track:after { clear: both;}
.slick-loading .slick-track { visibility: hidden;}
.slick-slide { display: none; float: left; height: 100%; min-height: 1px;}
[dir='rtl'] .slick-slide { float: right;}
.slick-slide img { display: block; }
.slick-slide.slick-loading img { display: none;}
.slick-slide.dragging img { pointer-events: none;}
.slick-initialized .slick-slide { display: block;}
.slick-loading .slick-slide { visibility: hidden;}
.slick-vertical .slick-slide{ display: block; height: auto; border: 1px solid transparent;}
.slick-arrow.slick-hidden { display: none;}

.slick-arrow{ position: absolute; top: 50%; width: 50px; height: 50px; background: #8f3946; border: solid 2px #fff; z-index: 100;
 -webkit-border-radius: 50%; border-radius: 50%; text-indent: -9999em; outline: none;
}
.slick-prev { left: 20px;}
.slick-next { right: 20px;}
.slick-arrow:before{ position: absolute; content: ''; display: block; width: 15px; height: 15px; top: 15px;}
.slick-prev:before { left: 18px; border-left: solid 2px #fff;border-bottom: solid 2px #fff; -webkit-transform: rotate(45deg); transform: rotate(45deg);}
.slick-next:before { left: 10px; border-right: solid 2px #fff;border-top: solid 2px #fff; -webkit-transform: rotate(45deg); transform: rotate(45deg);}
@media (max-width: 481px) {
}



/* 
------------------------------------------------------------------------------------------------------------------------
1. BASIC STYLE  
------------------------------------------------------------------------------------------------------------------------
*/

.mCustomScrollbar{ -ms-touch-action: pinch-zoom; touch-action: pinch-zoom; /* direct pointer events to js */ }
.mCustomScrollbar.mCS_no_scrollbar, .mCustomScrollbar.mCS_touch_action{ -ms-touch-action: auto; touch-action: auto; }
.mCustomScrollBox{ position: relative; overflow: hidden; height: 100%; max-width: 100%; outline: none; direction: ltr;}
.mCSB_container { overflow: hidden; width: auto; height: auto;}



/* 
------------------------------------------------------------------------------------------------------------------------
2. VERTICAL SCROLLBAR 
y-axis
------------------------------------------------------------------------------------------------------------------------
*/

.mCSB_inside > .mCSB_container{ margin-right: 15px; }
.mCSB_container.mCS_no_scrollbar_y.mCS_y_hidden{ margin-right: 0; } /* non-visible scrollbar */
.mCS-dir-rtl > .mCSB_inside > .mCSB_container{ margin-right: 0; margin-left: 30px;}
.mCS-dir-rtl > .mCSB_inside > .mCSB_container.mCS_no_scrollbar_y.mCS_y_hidden{ margin-left: 0; } /* RTL direction/left-side scrollbar */

.mCSB_scrollTools{ position: absolute; width: 16px; height: auto; left: auto; top: 0; right: 0;	bottom: 0;}

.mCSB_outside + .mCSB_scrollTools{ right: -26px; } /* scrollbar position: outside */
.mCS-dir-rtl > .mCSB_inside > .mCSB_scrollTools, 
.mCS-dir-rtl > .mCSB_outside + .mCSB_scrollTools{ right: auto; left: 0;}
.mCS-dir-rtl > .mCSB_outside + .mCSB_scrollTools{ left: -26px; }

.mCSB_scrollTools .mCSB_draggerContainer { position: absolute; top: 0; left: 0; bottom: 0; right: 0; height: auto;}
.mCSB_scrollTools a + .mCSB_draggerContainer{ margin: 20px 0; }

.mCSB_scrollTools .mCSB_draggerRail{ width: 6px; height: 100%; margin: 0 auto;}

.mCSB_scrollTools .mCSB_dragger{ cursor: pointer; width: 100%; height: 30px; /* minimum dragger height */ z-index: 1;}
.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{ /* the dragger element */
	position: relative; width: 6px; height: 100%; margin: 0 auto;	text-align: center;
}

.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded .mCSB_dragger_bar, 
.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_dragger .mCSB_dragger_bar{ width: 3px;}

.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger.mCSB_dragger_onDrag_expanded + .mCSB_draggerRail, 
.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerContainer:hover .mCSB_draggerRail{ width: 3px; }

.mCSB_scrollTools .mCSB_buttonUp,
.mCSB_scrollTools .mCSB_buttonDown{
	display: block;
	position: absolute;
	height: 20px;
	width: 100%;
	overflow: hidden;
	margin: 0 auto;
	cursor: pointer;
}

.mCSB_scrollTools .mCSB_buttonDown{ bottom: 0; }




/* 
------------------------------------------------------------------------------------------------------------------------
4. VERTICAL AND HORIZONTAL SCROLLBARS 
yx-axis 
------------------------------------------------------------------------------------------------------------------------
*/

.mCSB_container_wrapper{ height: auto; width: auto; overflow: hidden; 
	position: absolute; top: 0; left: 0; right: 0; bottom: 0; margin-right: 30px; margin-bottom: 30px;
}

.mCSB_container_wrapper > .mCSB_container{ padding-right: 30px; padding-bottom: 30px;
	-webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box;
}

.mCSB_vertical_horizontal > .mCSB_scrollTools.mCSB_scrollTools_vertical{ bottom: 20px; }

.mCSB_vertical_horizontal > .mCSB_scrollTools.mCSB_scrollTools_horizontal{ right: 20px; }

/* non-visible horizontal scrollbar */
.mCSB_container_wrapper.mCS_no_scrollbar_x.mCS_x_hidden + .mCSB_scrollTools.mCSB_scrollTools_vertical{ bottom: 0; }

/* non-visible vertical scrollbar/RTL direction/left-side scrollbar */
.mCSB_container_wrapper.mCS_no_scrollbar_y.mCS_y_hidden + .mCSB_scrollTools ~ .mCSB_scrollTools.mCSB_scrollTools_horizontal, 
.mCS-dir-rtl > .mCustomScrollBox.mCSB_vertical_horizontal.mCSB_inside > .mCSB_scrollTools.mCSB_scrollTools_horizontal{ right: 0; }

/* RTL direction/left-side scrollbar */
.mCS-dir-rtl > .mCustomScrollBox.mCSB_vertical_horizontal.mCSB_inside > .mCSB_scrollTools.mCSB_scrollTools_horizontal{ left: 20px; }

/* non-visible scrollbar/RTL direction/left-side scrollbar */
.mCS-dir-rtl > .mCustomScrollBox.mCSB_vertical_horizontal.mCSB_inside > .mCSB_container_wrapper.mCS_no_scrollbar_y.mCS_y_hidden + .mCSB_scrollTools ~ .mCSB_scrollTools.mCSB_scrollTools_horizontal{ left: 0; }

.mCS-dir-rtl > .mCSB_inside > .mCSB_container_wrapper{ /* RTL direction/left-side scrollbar */
	margin-right: 0;
	margin-left: 30px;
}

.mCSB_container_wrapper.mCS_no_scrollbar_y.mCS_y_hidden > .mCSB_container{ padding-right: 0; }
.mCSB_container_wrapper.mCS_no_scrollbar_x.mCS_x_hidden > .mCSB_container{ padding-bottom: 0;}
.mCustomScrollBox.mCSB_vertical_horizontal.mCSB_inside > .mCSB_container_wrapper.mCS_no_scrollbar_y.mCS_y_hidden{
	margin-right: 0; /* non-visible scrollbar */
	margin-left: 0;
}

/* non-visible horizontal scrollbar */
.mCustomScrollBox.mCSB_vertical_horizontal.mCSB_inside > .mCSB_container_wrapper.mCS_no_scrollbar_x.mCS_x_hidden{ margin-bottom: 0; }



/* 
------------------------------------------------------------------------------------------------------------------------
5. TRANSITIONS  
------------------------------------------------------------------------------------------------------------------------
*/
.mCSB_scrollTools, 
.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar, 
.mCSB_scrollTools .mCSB_buttonUp,
.mCSB_scrollTools .mCSB_buttonDown,
.mCSB_scrollTools .mCSB_buttonLeft,
.mCSB_scrollTools .mCSB_buttonRight{
	-webkit-transition: opacity .2s ease-in-out, background-color .2s ease-in-out;
	-moz-transition: opacity .2s ease-in-out, background-color .2s ease-in-out;
	-o-transition: opacity .2s ease-in-out, background-color .2s ease-in-out;
	transition: opacity .2s ease-in-out, background-color .2s ease-in-out;
}

.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_dragger_bar, /* auto-expanded scrollbar */
.mCSB_scrollTools_vertical.mCSB_scrollTools_onDrag_expand .mCSB_draggerRail, 
.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_dragger_bar, 
.mCSB_scrollTools_horizontal.mCSB_scrollTools_onDrag_expand .mCSB_draggerRail{
	-webkit-transition: width .2s ease-out .2s, height .2s ease-out .2s, 
				margin-left .2s ease-out .2s, margin-right .2s ease-out .2s, 
				margin-top .2s ease-out .2s, margin-bottom .2s ease-out .2s,
				opacity .2s ease-in-out, background-color .2s ease-in-out; 
	-moz-transition: width .2s ease-out .2s, height .2s ease-out .2s, 
				margin-left .2s ease-out .2s, margin-right .2s ease-out .2s, 
				margin-top .2s ease-out .2s, margin-bottom .2s ease-out .2s,
				opacity .2s ease-in-out, background-color .2s ease-in-out; 
	-o-transition: width .2s ease-out .2s, height .2s ease-out .2s, 
				margin-left .2s ease-out .2s, margin-right .2s ease-out .2s, 
				margin-top .2s ease-out .2s, margin-bottom .2s ease-out .2s,
				opacity .2s ease-in-out, background-color .2s ease-in-out; 
	transition: width .2s ease-out .2s, height .2s ease-out .2s, 
				margin-left .2s ease-out .2s, margin-right .2s ease-out .2s, 
				margin-top .2s ease-out .2s, margin-bottom .2s ease-out .2s,
				opacity .2s ease-in-out, background-color .2s ease-in-out; 
}


/* theme: "dark-2" */
.mCSB_scrollTools .mCSB_draggerRail{
	background-color: #ededed; background-color: rgba(235,235,235,1.0);
	-webkit-border-radius: 1px; -moz-border-radius: 1px; border-radius: 1px;
}

.mCSB_scrollTools .mCSB_dragger .mCSB_dragger_bar{
	background-color: #333; background-color: rgba(50,50,50,0.75);
	-webkit-border-radius: 10px; -moz-border-radius: 10px; border-radius: 10px;
}

.mCSB_scrollTools .mCSB_dragger:hover .mCSB_dragger_bar{ background-color: #333; background-color: rgba(50,50,50,0.75); }

.mCSB_scrollTools .mCSB_dragger:active .mCSB_dragger_bar,
.mCSB_scrollTools .mCSB_dragger.mCSB_dragger_onDrag .mCSB_dragger_bar{ background-color: #333; background-color: rgba(50,50,50,0.75);}
.mCSB_scrollTools .mCSB_buttonUp{ background-position: -112px 0; }
.mCSB_scrollTools .mCSB_buttonDown{ background-position: -112px -20px; }
.mCSB_scrollTools .mCSB_buttonLeft{ background-position: -120px -40px; }
.mCSB_scrollTools .mCSB_buttonRight{	background-position: -120px -56px;}






/*			HEADER
--------------------------------------------- */
#hd { position: fixed; left: 0; top: -200px; width: 100%; background:#fff; box-shadow: 0 0 15px #666; z-index: 1000; transition: 0.4s linear;}
#hd.fixed { top: 0;}
#hd .inner-hd{ position: relative; width: 96%; margin: 0 auto; padding: 0;}
#hd h1{ float: left; padding-top: 20px;}
#hd ul{ font-size: 0; text-align: right; padding-left: 180px;}
#hd ul li{ display: inline-block; color: #081f38; line-height: 1; vertical-align: middle;}
#hd ul li.tel { width: 26%;}
#hd ul li.tel span { display: block;}
#hd ul li.tel span.min{ font-size: 36px; text-align: center;}
#hd ul li.tel span.min:before{ content: ''; display: inline-block; width: 30px; height: 26px; background: url(../img/icn-tel.png) no-repeat 0 50%; background-size: auto 26px;}
#hd ul li.tel span.time{ font-size: 16px; text-align: center; text-indent: 10px;}
#hd ul li.btn1 { margin-left: 30px; width: 23%; max-width: 275px;}
#hd ul li.btn1 a { display: block;}
#hd ul li.btn2 { margin-left: 10px; width: 44%; max-width: 460px;}
#hd ul li.btn2 a { display: block;}
#hd ul li.btn1 img,
#hd ul li.btn2 img{ width: 100%;}
#hd ul li a:hover{ opacity: 0.85;}
@media (max-width: 1201px) {
	#hd ul li.tel span.min { font-size: 32px;}
	#hd ul li.tel span.time{ font-size: 14px;}
}
@media (max-width: 1001px) {
	#hd h1{ padding-top: 10px;}
	#hd h1 img{ width: 150px;}
	#hd ul{ padding-left: 160px;}
	#hd ul li.tel span.min { font-size: 28px;}
	#hd ul li.tel span.time{ font-size: 12px;}
}
@media (max-width: 481px) {
	#hd { display: none;}
}



/*			FOOTER
--------------------------------------------- */
.pagetop{ display: none; position: fixed; right: 4%; bottom: 40px; width: 58px; height: 58px; }
.sp-btn { display: none; position: fixed; bottom: 0; left: 0; width: 100%; background: #fff;}
.sp-btn ul{ width: 94%; margin: 0 auto; padding: 8px 0 15px; font-size: 0; text-align: center;}
.sp-btn ul li{ display: inline-block; width: 33%; }
.sp-btn ul li a { display: block; width: 96%; max-width: 226px; margin: 0 auto;}
.sp-btn ul li a img{ width: 100%;}
#ft { padding: 20px 0 30px; text-align: center;}
#ft p { margin: 0 auto 25px;}
#ft address { font-size: 12px; font-style: normal; font-weight: 700;}
@media (max-width: 481px) {
	.pagetop{ bottom: 80px;}
	.sp-btn {}
	#ft { padding: 20px 0 80px;}
}

.ttl { margin: 0 auto 80px; text-align: center;}
.ttl h2 { margin-bottom: 40px; color: #245da7; font-size: 82px; line-height: 1;}
.ttl p { color: #081f38; font-size: 40px; line-height: 1;}
.ttl p:before,
.ttl p:after { content: ''; display: inline-block; width: 45px; height: 2px; background: #081f38; vertical-align: middle;}
.ttl p span { display: inline-block; margin: 0 20px; vertical-align: middle;}
.stl { margin: 0 auto 40px;}
.stl h2{ color: #fff; font-size: 50px; font-weight: 100; line-height: 1.4; text-align: center;}
.stl h2 span.br{ display: block;}
.stl h2 span.line{ display: inline-block; padding: 10px 0px; border-bottom: solid 1px #fff;}
.stl h2 em{ font-size: 70px;}
@media (max-width: 1001px) {
	.ttl h2 { font-size: 60px;}
	.ttl p { font-size: 30px;}
	.stl h2{ font-size: 40px;}
	.stl h2 em{ font-size: 50px;}
}
@media (max-width: 769px) {
	.ttl h2 { font-size: 50px;}
	.ttl p { font-size: 24px;}
	.stl h2{ font-size: 30px;}
	.stl h2 em{ font-size: 40px;}
}
@media (max-width: 641px) {
	.ttl{ margin: 0 auto 40px;}
	.ttl h2 { margin-bottom: 20px;}	
}
@media (max-width: 481px) {
	.ttl h2 { font-size: 36px;}
	.ttl p { font-size: 20px;}
	.ttl p:before,
	.ttl p:after { width: 30px; height: 1px;}
	.ttl p span { margin: 0 10px;}

	.stl h2{ font-size: 18px;}
	.stl h2 em{ font-size: 24px;}
}


.ye { color: #fff100;}

#kv .inner-kv { width: 100%; border: solid 13px #fff;}
#kv .kv1{ background: url(../img/kv1.jpg) no-repeat 50% 0; background-size: cover;}
#kv .kv2{ background: url(../img/kv2.jpg) no-repeat 50% 0; background-size: cover;}
#kv .kv3{ background: url(../img/kv3.jpg) no-repeat 50% 0; background-size: cover;}
#kv .kv-box { position: relative; padding: 150px 0;}
#kv .kv-box h1 { position: absolute; left: 30px; top: 30px;}
#kv .kv-box h2 { line-height: 1; text-align: center;}
#kv .kv-box h2 img{ width: 88%; max-width: 1100px; margin: 0 auto;}
#kv .kv-box h2 img.sp{ display: none;}
.scroll{ position: relative; z-index: 2;}
.scroll a{ display: block; width: 15px; height: 160px; position: absolute; left: 5%; bottom: -50px;}
.scroll a:after{ content: ''; display: block; width: 1px; height: 0; margin: 0 auto; background: #081f38; animation: 3s line ease infinite;}
.scroll a img{ margin: 0 auto 15px; height: auto; vertical-align: right: 0;}
@keyframes line{ 
	0% { height: 0;}
	50% { height: 100px;}
	100% { height: 0;}
}
@media (max-width: 641px) {
	#kv .kv1{ background: url(../img/kv1-sp.jpg) no-repeat 50% 0; background-size: cover;}
	#kv .kv2{ background: url(../img/kv2-sp.jpg) no-repeat 50% 0; background-size: cover;}
	#kv .kv3{ background: url(../img/kv3-sp.jpg) no-repeat 50% 0; background-size: cover;}
	#kv .kv-box h2 img.pc{ display: none;}
	#kv .kv-box h2 img.sp{ display: block;}
}
@media (max-width: 481px) {
	#kv .inner-kv { border: solid 6px #fff;}
	#kv .kv-box h1 { top: 20px; left: 20px;}
	#kv .kv-box h1 img{ width: 85px;}
	#kv .kv-box h2 img{ width: 82%;}
	#kv .kv-box { position: relative; padding: 70px 0 80px;}
	.scroll a{ height: 120px;}
}

#problem { position: relative; background: #f1f1f1;}
#problem #sct{ position: absolute; top: -30px;}
#problem .inner { padding: 60px 0 100px;}
#problem .board { position: relative; width: 92%; max-width: 1000px; margin: 0 auto 50px; border: solid 2px #235ca6;}
#problem .board .inner-board{ position: relative; top: -9px; left: -9px; padding: 40px 0 20px; background: linear-gradient(#235ca6, #4279c3);}
#problem .board h2 { margin-bottom: 20px; color: #fff; font-size: 46px; font-weight: 100; text-align: center;}
#problem .board h2 span{ display: block;}
#problem .board h2 em{ font-size: 64px;}
#problem .board ul { padding: 40px 0; background: url(../img/line.png) no-repeat 50% 0;}
#problem .board ul li { width: 88%; margin: 0 auto 15px; padding-left: 50px; background: url(../img/icn-check.png) no-repeat 0 8px; color: #fff; font-size: 30px;}
#problem .board ul li:last-child{ margin: 0 auto;}
#problem p { color: #081f38; font-size: 57px; text-align: center;}
#problem p span { font-size: 72px;}
#problem p em{ font-size: 100px;}
#problem p br { display: none;}
@media (max-width: 1001px) {
	#problem .board h2 { font-size: 36px;}
	#problem .board h2 em{ font-size: 56px;}
	#problem .board ul li { font-size: 24px;}
	#problem p { font-size: 42px;}
	#problem p span { font-size: 52px;}
	#problem p em{ font-size: 72px;}
}
@media (max-width: 769px) {
	#problem .inner { padding: 40px 0 50px;}
	#problem .board h2 { font-size: 30px;}
	#problem .board h2 em{ font-size: 42px;}
	#problem .board ul li { font-size: 20px;}

	#problem p { font-size: 36px;}
	#problem p span { font-size: 42px;}
	#problem p em{ font-size: 56px;}
}
@media (max-width: 641px) {
	#problem .board h2 { font-size: 24px;}
	#problem .board h2 em{ font-size: 36px;}
	#problem .board ul li { padding-left: 35px; background-size: auto 18px; background-position: 0 4px; font-size: 17px;}

	#problem p { font-size: 30px;}
	#problem p span { font-size: 36px;}
	#problem p em{ font-size: 42px;}
}
@media (max-width: 481px) {
	#problem .board .inner-board{ padding: 40px 0 20px;}
	#problem .board h2 { font-size: 17px;}
	#problem .board h2 em{ font-size: 21px;}
	#problem .board ul li { font-size: 15px;}

	#problem p { font-size: 30px;}
	#problem p span { font-size: 36px;}
	#problem p em{ font-size: 42px;}
	#problem p br { display: block;}
}



#read .inner { width: 94%; max-width: 1200px; margin: 0 auto; padding: 160px 0 100px;}
#read .read-bloc { display: flex; }
#read .bloc1 { margin: 0 auto 140px; flex-direction: row-reverse;}
#read .read-bloc .pht { width: 50%; max-width: 600px; }
#read .read-bloc .pht figure { position: relative; width: 100%;}
#read .read-bloc .pht figure img{ width: 100%; box-shadow: 9px 9px 0 #d5e6fd;}
#read .read-bloc .txt { width: 50%;}
#read .read-bloc.bloc2 .txt { padding-left: 40px;}
#read .read-bloc .txt p { color: #333; font-size: 27px; line-height: 1.8;}
#read .read-bloc .txt p span { display: block;}
@media (max-width: 1001px) {
	#read .read-bloc .txt p { font-size: 21px;}
}
@media (max-width: 769px) {
	#read .inner { padding: 80px 0 50px;}
	#read .bloc1{ margin: 0 auto 60px;}
	#read .read-bloc .txt p { font-size: 17px;}
}
@media (max-width: 641px) {
	#read .read-bloc { display: block;}
	#read .read-bloc .pht { width: 80%; margin: 0 auto 30px;}
	#read .read-bloc .txt { width: 80%; margin: 0 auto;}
	#read .read-bloc.bloc2 .txt { padding-left: 0px;}
	#read .read-bloc .txt p { text-align: justify;}
	#read .read-bloc .txt p span{ display: inline;}
}
@media (max-width: 641px) {
	#read .inner { padding: 40px 0;}
}

#theme { background: linear-gradient(#235ca6, #4279c3);}
#theme .inner { width: 94%; max-width: 1200px; margin: 0 auto; padding: 90px 0 50px;}
#theme p { margin: 0 auto 40px; color: #fff; font-size: 22px; line-height: 1.8; text-align: center;}
#theme .cf { margin: 0 auto 40px;}
#theme .fL { width: 44%; max-width: 500px; float: left;}
#theme .fR { width: 53%; max-width: 600px; float: right;}
#theme figure img{ width: 100%; box-shadow: 0 0 15px #666;}
#theme .btn { width: 100%; max-width: 870px; margin: 0 auto;}
#theme .btn img { width: 100%;}
#theme .btn a:hover{ opacity: 0.8;}
@media (max-width: 1001px) {
	#theme p span{ display: block;}
}
@media (max-width: 641px) {
	#theme p { font-size: 16px;}
	#theme .fL { width: 80%; float: none; margin: 0 auto 20px;}
	#theme .fR { width: 80%; float:none; margin: 0 auto;}
}
@media (max-width: 481px) {
	#theme .inner { padding: 50px 0;}
	#theme p { width: 92%; margin: 0 auto 40px; font-size: 14px; text-align: justify;}
	#theme p span{ display: inline;}
}

#promote { background: #f1f1f1;}
#promote .inner { width: 94%; max-width: 1200px; margin: 0 auto; padding: 90px 0 50px;}
#promote .topic { text-align: center;}
#promote .topic p { color: #245da7; font-size: 40px;}
#promote .topic p span{ display: inline-block; vertical-align: middle; margin: 0 10px;}
#promote .topic p:before,
#promote .topic p:after { content: ''; display: inline-block; width: 45px; height: 2px; background: #245da7; vertical-align: middle;}
#promote .topic h2{ color: #081f38; font-size: 50px; font-weight: 100;}
#promote .topic h2 span{ font-size: 80px;}
#promote .lead { display: flex; width: 100%; align-items: center; margin: 0 auto 30px;}
#promote .lead .fig { width: 45%; max-width: 500px;}
#promote .lead .fig img{ width: 100%;}
#promote .lead .txt { width: 55%; padding-left: 20px;}
#promote .lead p { color: #333; font-size: 27px; line-height: 1.8;}
#promote .lead p span{ display: block;}

#promote .box { width: 100%; max-width: 1000px; margin: 0 auto 40px; border: solid 2px #235ca6;}
#promote .box .inner-box { width: 100%; padding: 40px 0; position: relative; top: -9px; left: -9px; background: linear-gradient(#235ca6, #4279c3);}
#promote .box h3 { margin-bottom: 40px; color: #fff; font-size: 55px; font-weight: 100; line-height: 1; text-align: center;}
#promote .box h3 span{ font-size: 75px;}
#promote .box h3 span em { margin: 0 -15px; font-size: 110px;}
#promote .box p { margin-bottom: 40px; color: #fff; font-size: 22px; text-align: center;}
#promote .box p span{ display: block;}
#promote .box p span.sp{ display: inline;}
#promote .box ul{ width: 92%; margin: 0 auto;}
#promote .box ul li { padding: 60px 0 60px 300px; border-top: dashed 1px #fff;}
#promote .box ul li:first-child{ background: url(../img/badge-1.png) no-repeat 0 50%; background-size: 280px auto;}
#promote .box ul li:last-child { background: url(../img/badge-2.png) no-repeat 0 50%; background-size: 280px auto;}
#promote .box ul dl { position: relative; margin: 0 auto 60px;}
#promote .box ul dl.mb0{ margin: 0 auto;}
#promote .box ul dl dt { position: relative; width: 52%; padding: 35px 35px 30px; background: #fff; font-size: 22px; line-height: 1.4; box-shadow: 0 0 10px #666;}
#promote .box ul dl dt span.no { position: absolute; left: -30px; top: -30px; width: 68px; height: 68px; line-height: 68px;
 border-radius: 50%; box-shadow: 0 0 10px #666; color: #fff; font-size: 50px; text-align: center;
}
#promote .box ul dl dt span.hard{ background: #d35c5c;}
#promote .box ul dl dt span.soft{ background: #aad870; color: #081f38;}
#promote .box ul dl dt em { display: block; margin-bottom: 8px; font-size: 36px;}
#promote .box ul dl dt em.short{ font-size: 30px;}
#promote .box ul dl dd { position: absolute; right: 20px; bottom: -15px; width: 50%; max-width: 316px;}
#promote .box ul dl dd img{ width: 100%; box-shadow: 0 0 10px #666;}
#promote .arw { margin: 0 auto 20px;}
#promote .arw:before{ content: ''; display: block; width: 0; height: 0; margin: auto;
 border: solid 230px transparent; border-top: solid 50px #b3b3b3; border-bottom: 0;
}
#promote .process h3 { margin-bottom: 30px; font-size: 55px; font-weight: 100; text-align: center;}
#promote .process h3 span { font-size: 75px;}
#promote .process h3 span em { margin: 0 -15px; font-size: 110px;}
#promote .process p { color: #333; font-size: 22px; text-align: center;}
#promote .process figure img{ width: 100%;}
#promote .process figure img.sp{ display: none;}
#promote .process ul { width: 94%; margin: 0 auto; font-size: 0; text-align: center;}
#promote .process ul li { display: inline-block; width: 33%; vertical-align: top;}
#promote .process ul li dl { width: 90%; margin: 0 auto;}
#promote .process ul li:first-child dl{ margin: 0 auto 0 0;}
#promote .process ul li:last-child dl { margin: 0 0 0 auto;}
#promote .process ul dl dt { margin-bottom: 10px; color: #081f38; font-size: 34px; line-height: 1.2;}
#promote .process ul dl dd { color: #333; font-size: 22px; text-align: justify;}
@media (max-width: 1001px) {
	#promote .topic h2{ font-size: 42px;}
	#promote .topic h2 span{ font-size: 56px;}
	#promote .lead .fig { width: 40%;}
	#promote .lead .txt { width: 60%;}
	#promote .lead p { font-size: 21px;}

	#promote .box p span.sp{ display: block;}
	#promote .box ul dl dt { font-size: 18px;}
	#promote .box ul dl dt em { font-size: 30px;}
	#promote .box ul dl dt em.short{ font-size: 24px;}

	#promote .process p span{ display: block;}

	#promote .process ul dl dt { font-size: 26px;}
	#promote .process ul dl dd { font-size: 18px;}
}
@media (max-width: 769px) {
	#promote .topic h2{ font-size: 36px;}
	#promote .topic h2 span{ font-size: 48px;}
	#promote .lead p { font-size: 16px;}

	#promote .box h3{ font-size: 40px;}
	#promote .box h3 span{ font-size: 60px;}
	#promote .box h3 span em { margin: 0 -10px; font-size: 80px;}

	#promote .box ul li { padding: 300px 0 60px;}
	#promote .box ul li:first-child{ background-position: 50% 0; background-size: auto 280px;}
	#promote .box ul li:last-child { background-position: 50% 0; background-size: auto 280px;}
	#promote .box ul dl { width: 90%;}

	#promote .process h3 { margin-bottom: 10px; font-size: 40px;}
	#promote .process h3 span { font-size: 60px;}
	#promote .process h3 span em { margin: 0 -10px; font-size: 80px;}
	#promote .process .bloc{ display: flex; padding-top: 20px;}
	#promote .process figure { width: 35%;}
	#promote .process figure img.pc{ display: none;}
	#promote .process figure img.sp{ display: block;}
	#promote .process ul { width: 65%;}
	#promote .process ul li { display: block; width: 100%; text-align: justify;}
	#promote .process ul li dl{ min-height: 140px; padding: 20px 0;}

	#promote .process ul li:first-child dl{ margin: 0 auto;}
	#promote .process ul li:last-child dl { margin: 0 auto;}
}
@media (max-width: 641px) {
	#promote .topic p { font-size: 24px;}
	#promote .topic h2{ margin-bottom: 30px; font-size: 30px; line-height: 1.4;}
	#promote .topic h2 span{ display: block; font-size: 48px;}
	#promote .lead .fig { width: 35%;}
	#promote .lead .txt { width: 65%;}
	#promote .lead p { font-size: 15px;}

	#promote .box h3{ font-size: 30px;}
	#promote .box h3 span{ font-size: 50px;}
	#promote .box h3 span em { font-size: 60px;}
	#promote .box p { font-size: 18px;}

	#promote .box ul li { padding: 250px 0 60px;}
	#promote .box ul li:first-child{ background-position: 50% 0; background-size: auto 220px;}
	#promote .box ul li:last-child { background-position: 50% 0; background-size: auto 220px;}
	#promote .box ul dl dt { width: 60%;font-size: 16px;}
	#promote .box ul dl dt em { font-size: 24px;}
	#promote .box ul dl dt em.short{ font-size: 21px;}
	#promote .box ul dl dd { right: 0px;}
	#promote .process h3 { font-size: 30px;}
	#promote .process h3 span { font-size: 50px;}
	#promote .process h3 span em { font-size: 60px;}
	#promote .process p { font-size: 16px;}

	#promote .process ul li dl{ padding: 25px 0 10px;}
	#promote .process ul dl dt { font-size: 24px;}
	#promote .process ul dl dd { font-size: 14px;}
}
@media (max-width: 481px) {
	#promote .inner { padding: 40px 0;}
	#promote .topic h2{ margin-bottom: 20px; font-size: 24px;}
	#promote .topic h2 span{ font-size: 36px;}
	#promote .arw:before{ border: solid 100px transparent; border-top: solid 30px #b3b3b3; border-bottom: 0;}

	#promote .lead { display: block; width: 100%;}
	#promote .lead .fig { width: 80%; margin: 0 auto 10px;}
	#promote .lead .txt { width: 90%; margin: 0 auto; padding-left: 0px;}
	#promote .lead .txt p span{ display: inline;}

	#promote .box .inner-box{ padding: 40px 0 0;}
	#promote .box h3{ font-size: 21px;}
	#promote .box h3 span{ font-size: 30px;}
	#promote .box h3 span em { margin: 0; font-size: 36px;}
	#promote .box p { width: 90%; margin: 0 auto 20px; font-size: 16px; text-align: justify;}
	#promote .box p span,
	#promote .box p span.sp { display: inline;}
	#promote .box ul li { padding: 210px 0 60px;}
	#promote .box ul li:first-child{ background-size: auto 200px;}
	#promote .box ul li:last-child { background-size: auto 200px;}
	#promote .box ul dl dt { width: 65%; padding: 25px 15px 10px; font-size: 15px;}
	#promote .box ul dl dt span.no { position: absolute; left: -10px; top: -30px; width: 50px; height: 50px; line-height: 50px; font-size: 30px;}
	#promote .box ul dl dt em { font-size: 21px;}
	#promote .box ul dl dt em.short{ font-size: 18px;}
	#promote .box ul dl dd { width: 45%;}

	#promote .process h3 { font-size: 21px;}
	#promote .process h3 span { font-size: 30px;}
	#promote .process h3 span em { font-size: 36px;}
	#promote .process p { font-size: 15px;}
	#promote .process figure { width: 50%;}
	#promote .process ul li dl{ min-height: auto; padding: 8px 0;}
	#promote .process ul dl dt { margin-bottom: 5px; font-size: 18px;}
	#promote .process ul dl dd { font-size: 11px;}
}


#reason { background: linear-gradient(#235ca6, #4279c3);}
#reason .inner{ width: 94%; max-width: 1200px; margin: 0 auto; padding: 90px 0 50px;}
#reason p.lead { margin-bottom: 50px; color: #fff; font-size: 25px; line-height: 1.8; text-align: center;}
#reason p.lead span{ display: block;}
#reason .box { margin: 0 auto 40px; padding: 50px 0px; background: #fff;}
#reason .box .prof{ display: flex; flex-direction: row-reverse; width: 94%; margin: 0 auto 30px; padding-bottom: 40px; border-bottom: dashed 1px #ccc;}
#reason .box .pht { width: 42%;}
#reason .box .pht figure { width: 94%; max-width: 400px; margin: 0 auto; border: solid 3px #fff; box-shadow: 0 0 8px #666;}
#reason .box .pht figure img { width: 100%;}
#reason .box .txt { width: 58%; padding-right: 20px;}
#reason .box .txt h3 { margin-bottom: 20px; font-size: 28px; font-weight: 100;}
#reason .box .txt h3 span { display: block; font-size: 30px;}
#reason .box .txt h3 span em { font-size: 38px;}
#reason .box .txt p{ font-size: 20px; line-height: 1.8;}
#reason .feature h3 { margin: 0 auto 30px; color: #081f38; font-size: 30px; font-weight: 100; text-align: center;}
#reason .feature ul { width: 94%; margin: 0 auto;
 background: url(../img/bg-promote.jpg) no-repeat 50% 50%; background-size: 100% auto; border-radius: 10px;
 font-size: 0;}
#reason .feature ul li { display: inline-block; width: 25%; vertical-align: top;}
#reason .feature ul dl { width: 90%; margin: 0 auto; padding: 80px 0 70px;}
#reason .feature ul dl dt { margin-bottom: 30px; color: #081f38; font-size: 32px; font-weight: 100; text-align: center;}
#reason .feature ul dl dt span{ display: block;}
#reason .feature ul dl dd { font-size: 16px; text-align: center;}
#reason .feature ul li:nth-child(2) dl dd { padding-right: 20px; padding-top: 15px;}
#reason .feature ul li:nth-child(3) dl dd { padding-right: 30px;}
#reason .feature figure{ display: none;}
#reason .aside { width: 90%; margin: 0 auto; padding-bottom: 40px; border-bottom: solid 1px #fff;}
#reason .aside h3 { position: relative; margin-bottom: 40px; color: #fff; font-size: 35px; font-weight: 100; line-height: 1; text-align: center;}
#reason .aside h3:before,
#reason .aside h3:after { content: ''; display: block; width: 40%; height: 1px; background: #fff; position: absolute; top: 17px;}
#reason .aside h3:before{ left: 0;}
#reason .aside h3:after { right: 0;}
#reason .aside h3 span{ display: block; position: relative; }
#reason .aside p { color: #fff; font-size: 18px; line-height: 1.8;}
@media (max-width: 1001px) {
	#reason .box .txt h3 { font-size: 24px;}
	#reason .feature ul dl { width: 92%; padding: 60px 0;}
	#reason .feature ul dl dd { font-size: 13px;}
}
@media (max-width: 769px) {
	#reason p.lead { font-size: 18px;}
	#reason .box .txt h3 { font-size: 20px;}
	#reason .box .txt h3 span { font-size: 24px;}
	#reason .box .txt h3 span em { font-size: 30px;}
	#reason .box .txt p{ font-size: 15px;}

	#reason .feature h3 { margin: 0 auto 20px; font-size: 24px;}
	#reason .feature ul { width: 94%; max-width: 600px; margin: 0 auto;
	 background: url(../img/bg-promote-sp.jpg) no-repeat 50% 0%; background-size: 100% 100%;}
	#reason .feature ul li { display: block; width: 100%;}
	#reason .feature ul dl { display: table; width: 100%; padding: 20px 0;}
	#reason .feature ul dl dt { display: table-cell; width: 40%; margin-bottom: 0px; font-size: 24px; vertical-align: middle;}
	#reason .feature ul dl dt img{ width: 75px;}
	#reason .feature ul dl dd { display: table-cell; width: 60%; font-size: 16px; text-align: center; vertical-align: middle;}
	#reason .feature ul li:nth-child(2) dl dd { padding-right: 0px; padding-top: 0px;}
	#reason .feature ul li:nth-child(3) dl dd { padding-right: 0px;}
	
	#reason .aside h3{ margin-bottom: 10px; font-size: 24px;}
	#reason .aside h3:before,
	#reason .aside h3:after { width: 35%; position: absolute; top: 12px;}
	#reason .aside p { font-size: 16px;}
}
@media (max-width: 641px) {
	#reason .box .pht { width: 36%;}
	#reason .box .txt { width: 64%;}
	#reason .box .txt p{ font-size: 14px;}

	#reason .feature h3 { font-size: 21px;}
	#reason .feature ul dl dt { font-size: 21px;}
	#reason .feature ul dl dd { font-size: 15px;}

	#reason .aside h3{ margin-bottom: 15px; font-size: 21px;}
	#reason .aside p { font-size: 14px;}
}
@media (max-width: 481px) {
	#reason .stl h2 { font-size: 24px;}
	#reason .inner{ padding: 40px 0;}
	#reason p.lead { width: 90%; margin: 0 auto 20px; font-size: 15px; text-align: justify;}
	#reason p.lead span{ display: inline;}
	#reason .box .prof{ display: block; margin: 0 auto 30px; padding-bottom: 40px;}
	#reason .box .pht { width: 100%; margin: 0 auto 20px;}
	#reason .box .pht figure { width: 60%; margin: 0 auto;}
	#reason .box .txt { width: 95%; margin: 0 auto; padding-right: 0px;}
	#reason .box .txt h3 { font-size: 18px; line-height: 1.4;}
	#reason .box .txt h3 span { font-size: 21px;}
	#reason .box .txt h3 span em { font-size: 24px;}
	#reason .box .txt p{ text-align: justify;}
	#reason .feature h3 span{ display: block;}
	#reason .feature ul { display: none; }
/*
	#reason .feature ul dl { padding: 15px 0;}
	#reason .feature ul dl dt { width: 30%; font-size: 16px; vertical-align: top;}
	#reason .feature ul dl dt img{ width: 50px;}
	#reason .feature ul dl dd { width: 70%; font-size: 13px;}
*/
	#reason .feature figure{ display: block; width: 80%; margin: 0 auto;}
	#reason .feature figure img { width: 100%;}
	#reason .aside { padding-bottom: 20px;}
}




#case { background: #f1f1f1;}
#case .inner{ width: 94%; max-width: 1200px; margin: 0 auto; padding: 90px 0 50px;}
#case .ttl{ margin: 0 auto 30px;}
#case p.lead { margin-bottom: 30px; font-size: 24px; text-align: center;}
#case .step-topic dl { position: relative; display: table; width: 100%; overflow: hidden;
 border: solid 2px #c45555; border-radius: 10px; background: #fff; box-shadow: 0 0 15px #999;
}
#case .step-topic dl dt,
#case .step-topic dl dd { display: table-cell; vertical-align: middle;}
#case .step-topic dl dt { color: #081f38; font-size: 43px; text-align: center;}
#case .step-topic dl dd { padding: 30px 60px; background: #fadada; color: #d35b5b; font-size: 40px;}
#case .step-topic dl dd span.note{ color: #333; font-size: 24px; position: absolute; right: 10px; bottom: 10px;}
#case .step .box { padding-bottom: 30px; background: #fff; border-radius: 10px; box-shadow: 0 0 15px #999; overflow: hidden;}
#case .step .point { padding: 40px 0; background: linear-gradient(#235ca6, #4279c3); text-align: center;}
#case .step .point h3 { color: #fff; font-size: 50px; font-weight: 100; line-height: 1.2;}
#case .step .box.box-1st figure { width: 90%; max-width: 975px; margin: 0 auto 30px; padding-top: 10px;}
#case .step .box.box-1st figure img{ width: 100%;}
#case .step .box.box-1st p { width: 92%; margin: 0 auto; color: #333; font-size: 30px;}
#case .step .box-2nd { padding-top: 40px; padding-left: 40px;}
#case .step .box-2nd .inner-box { position: relative; padding-left: 350px; background: #fff; border: solid 2px #2760aa; border-radius: 10px; box-shadow: 0 0 15px #999;}
#case .step .box-2nd figure { width: 80%; max-width: 350px; position: absolute; left: -30px; top: -30px; box-shadow: 0 0 15px #666;}
#case .step .box-2nd figure img{ width: 100%;}
#case .step .box-2nd .txt{ width: 92%; padding: 60px 0;}
#case .step .box-2nd .txt p{ color: #2860aa; font-size: 40px; }
#case .step .box-3rd .inner-box { display: flex; align-items: center; width: 94%; margin: 0 auto; padding-top: 40px;}
#case .step .box-3rd figure { width: 60%; position: relative; padding-bottom: 100px;}
#case .step .box-3rd figure img { position: relative; width: 70%; max-width: 350px; box-shadow: 0 0 15px #666;}
#case .step .box-3rd figure img.img2{ position: absolute; top: 70px; right: 50px;}
#case .step .box-3rd .txt { width: 40%;}
#case .step .box-3rd .txt p{ width: 95%; color: #333; font-size: 30px;}
#case .step .box-fin { border-radius: 10px; box-shadow: 0 0 15px #999; overflow: hidden;}
#case .step .box-fin .point h3 { font-size: 40px;}
#case .step .box-fin .inner-box{ padding-bottom: 30px; background: #fff;}
#case .step .box-fin .box-ctn { display: flex; width: 92%; margin: 0 auto; padding-top: 40px;}
#case .step .box-fin .box-ctn.box1{ flex-direction: row-reverse;}
#case .step .box-fin figure { width: 38%; max-width: 380px;}
#case .step .box-fin figure img { width: 100%; box-shadow: 0 0 15px #666;}
#case .step .box-fin .txt{ width: 65%;}
#case .step .box-fin .box-ctn.box1 .txt{ padding-right: 40px;}
#case .step .box-fin .box-ctn.box2 .txt{ padding-left: 40px;}
#case .step .box-fin .txt p{ font-size: 22px; }
#case .step .box-fin .txt p em{ color: #d35b5b;}
#case .step .result { padding: 100px 0 50px; background: url(../img/bg-arw.png) no-repeat 50% 0; background-size: 100% auto;}
#case .step .result h3 { margin: 0 auto 30px; color: #d35b5b; font-size: 55px; text-align: center;}
#case .step .result h3 span { border-bottom: solid 1px #d35b5b;}
#case .step .result p { margin: 0 auto 30px; color: #081f38; font-size: 26px; text-align: center;}
#case .step .result p span{ display: block;}
#case .step .result p span.sp{ display: inline;}
#case .step .result ul { width: 92%; margin: 0 auto; border-radius: 10px; overflow: hidden; font-size: 0; text-align: center;}
#case .step .result ul li { display: inline-block; width: 50%; vertical-align: top;}
#case .step .result ul li:first-child{ border-right: solid 1px #b6b6b6}
#case .step .result ul li:last-child{ border-left: solid 1px #b6b6b6}
#case .step .result ul li:first-child dl{ min-height: 280px; background: #cdd4df;}
#case .step .result ul li:last-child dl { min-height: 280px; background: #e6d4d4;}
#case .step .result ul li dl dt{ color: #fff; font-size: 48px; padding: 10px;}
#case .step .result ul li:first-child dl dt{ background: #245da7;}
#case .step .result ul li:last-child dl dt { background: #d35b5b;}
#case .step .result ul li dl dd{ font-size: 22px; padding: 10px;}
#case .step .result ul li:first-child dl dd{ color: #333; background: #d4dce7;}
#case .step .result ul li:last-child dl dd { color: #d35b5b; background: #eddcdc;}
#case .step .result ul li:first-child dl dd:nth-child(even){ background: #cdd4df;}
#case .step .result ul li:last-child dl dd:nth-child(even) { background: #e6d4d4;}
#case .step-txt{ display: flex; width: 94%; margin: 0 auto; padding: 30px 0 30px 100px; background: url(../img/arw-1.png) no-repeat 0 100%; }
#case .step-txt .tit { width: 28%; }
#case .step-txt .tit h3 { color: #081f38; font-size: 42px; line-height: 1.4;}
#case .step-txt .tit h3 span{ display: block; color: #d35b5b; font-size: 60px;}
#case .step-txt .txt { width: 72%; padding-left: 50px; background: url(../img/arw-2.png) no-repeat 0 50%;}
#case .step-txt .txt p { font-size: 18px; font-weight: 700;}
#case .step-txt .txt p.min { margin-bottom: 10px; color: #081f38; font-size: 36px;}
#case .step-txt .txt p.min span{ display: block;}
@media (max-width: 1001px) {
	#case .step-topic dl dt { font-size: 32px;}
	#case .step-topic dl dd { font-size: 30px;}
	#case .step-topic dl dd span.note{ font-size: 18px;}

	#case .step .point h3 { font-size: 36px;}
	#case .step .box.box-1st p { font-size: 24px;}
	#case .step .box-2nd .txt p{ font-size: 30px;}
	#case .step .box-3rd figure img { width: 50%;}
	#case .step .box-3rd .txt p{ font-size: 24px;}

	#case .step-txt .tit h3 { font-size: 36px;}
	#case .step-txt .tit h3 span{ font-size: 42px;}
	#case .step-txt .txt p { font-size: 15px;}
	#case .step-txt .txt p.min { font-size: 24px;}

	#case .step .result p { font-size: 21px;}
	#case .step .result ul li dl dt{ font-size: 36px;}
	#case .step .result ul li dl dd{ font-size: 18px;}
}
@media (max-width: 769px) {
	#case p.lead { font-size: 18px;}
	#case .step-topic dl dt,
	#case .step-topic dl dd {}
	#case .step-topic dl dt { width: 35%; font-size: 28px;}
	#case .step-topic dl dd { width: 65%; padding: 20px 30px 40px; font-size: 26px;}

	#case .step .point h3 { font-size: 30px;}
	#case .step .box.box-1st p { font-size: 20px;}
	#case .step .box-2nd .txt p{ font-size: 24px;}
	#case .step .box-3rd .txt p{ font-size: 20px;}
	#case .step .box-fin .box-ctn { display: block;}
	#case .step .box-fin figure { width: 80%; margin: 0 auto 20px;}
	#case .step .box-fin figure img { width: 100%;}
	#case .step .box-fin .txt{ width: 100%;}
	#case .step .box-fin .box-ctn.box1 .txt{ padding-right: 0px;}
	#case .step .box-fin .box-ctn.box2 .txt{ padding-left: 0px;}
	#case .step .box-fin .txt p{ font-size: 16px;}

	#case .step-txt .tit h3 { font-size: 24px;}
	#case .step-txt .tit h3 span{ font-size: 30px;}
	#case .step-txt .txt { padding-left: 30px;}
	#case .step-txt .txt p { font-size: 14px;}
	#case .step-txt .txt p.min { font-size: 20px;}
	#case .step-txt .txt p.min span{ display: block;}

	#case .step .result h3 { margin: 0 auto 20px; font-size: 40px;}
	#case .step .result p { font-size: 18px;}
	#case .step .result ul li dl dt{ font-size: 36px;}
	#case .step .result ul li dl dd{}
	#case .step .result p span.sp{ display: block;}

	#case .step .result ul li dl dt{ font-size: 30px;}
	#case .step .result ul li dl dd{ font-size: 14px;}
}
@media (max-width: 641px) {
	#case p.lead span{ display: block;}
	#case .step-topic dl dt { font-size: 24px;}
	#case .step-topic dl dd { font-size: 20px;}
	#case .step-topic dl dd span.note{ font-size: 14px;}

	#case .step .point { padding: 20px 0;}
	#case .step .point h3 { font-size: 24px;}
	#case .step .box.box-1st figure { margin: 0 auto 10px;}
	#case .step .box.box-1st p { font-size: 18px;}
	#case .step .box-2nd .inner-box { padding-left: 220px;}
	#case .step .box-2nd figure { width: 50%; max-width: 220px;}
	#case .step .box-2nd .txt { padding: 20px 0 30px;}
	#case .step .box-2nd .txt p{ font-size: 20px;}
	#case .step .box-3rd .inner-box { padding-top: 20px;}
	#case .step .box-3rd figure { width: 50%; padding-bottom: 60px;}
	#case .step .box-3rd figure img { width: 55%;}
	#case .step .box-3rd figure img.img2{ right: 20px;}
	#case .step .box-3rd .txt { width: 50%;}
	#case .step .box-3rd .txt p{ font-size: 18px;}
	#case .step .box-fin .point h3 { font-size: 24px;}

	#case .step-txt { padding: 20px 0 20px 60px; background-size: 30px auto;}
	#case .step-txt .tit { width: 24%; }
	#case .step-txt .tit h3 { font-size: 20px;}
	#case .step-txt .tit h3 span{ font-size: 24px;}
	#case .step-txt .txt{ width: 76%; padding-left: 40px;}
	#case .step-txt .txt p { font-size: 14px;}
	#case .step-txt .txt p.min { font-size: 18px;}
	
	#case .step .result ul li { display: block; width: 100%;}
	#case .step .result ul li:first-child{ border-right: none;}
	#case .step .result ul li:last-child{ border-left: none;}
	#case .step .result ul li:first-child dl{ min-height: auto;}
	#case .step .result ul li:last-child dl { min-height: auto;}
	#case .step .result ul li dl dt{ font-size: 24px; padding: 6px;}
}
@media (max-width: 481px) {
	#case .inner{ padding: 40px 0;}
	#case .step-topic dl dt { font-size: 18px;}
	#case .step-topic dl dd { padding: 15px 8px 40px; font-size: 15px;}
	#case .step-topic dl dd span.note{ font-size: 13px;}
	#case .step .box { padding-bottom: 15px;}
	#case .step .box.box-1st p { font-size: 14px;}
	#case .step .box-2nd { padding-left: 20px;}
	#case .step .box-2nd .inner-box { padding: 80px 0 0;}
	#case .step .box-2nd figure { width: 50%; left: -10px; top: -30px;}
	#case .step .box-2nd .txt { margin: 0 auto; padding: 15px 0;}
	#case .step .box-3rd .inner-box { display: block; padding-top: 20px;}
	#case .step .box-3rd figure { width: 100%; padding-bottom: 80px;}
	#case .step .box-3rd figure img { width: 55%;}
	#case .step .box-3rd figure img.img2{ right: 0px;}
	#case .step .box-3rd .txt { width: 100%;}
	#case .step .box-3rd .txt p{ font-size: 14px;}
	#case .step .point h3 { font-size: 18px;}

	#case .step-txt{  display: block; background-size: 25px auto; background-position: 15px 100%;}
	#case .step-txt .txt{ padding: 20px 0 20px 60px;}

	#case .step-txt .tit { width: 100%; margin-bottom: 8px;}
	#case .step-txt .tit h3 { font-size: 20px;}
	#case .step-txt .tit h3 span{ display: inline-block; margin-right: 10px; font-size: 24px;}
	#case .step-txt .txt{ width: 100%; padding: 10px 0 0; border-top: dashed 1px #333; background: none;}
	#case .step-txt .txt p { font-size: 14px;}
	#case .step-txt .txt p.min { font-size: 18px;}

	#case .step .result { padding: 50px 0;}
	#case .step .result h3 { font-size: 24px;}
	#case .step .result p { width:90%; margin: 0 auto 30px; font-size: 15px; text-align: justify;}
	#case .step .result p span,
	#case .step .result p span.sp { display: inline;}
}


#contact .inner{ width: 94%; max-width: 1000px; margin: 0 auto; padding: 60px 0 100px;}
#contact .box { width: 100%; margin: 0 auto; padding: 30px 0; border: solid 2px #235ca6;}
#contact .box p { margin: 0 auto 30px; text-align: center;}
#contact .box p.must { color: #f00; font-size: 14px;}
#contact .box ul { width: 90%; margin: 0 auto 30px; border-top: dashed 1px #aaa;}
#contact .box ul li { border-bottom: dashed 1px #aaa;}
#contact .box ul dl { display: table; width: 100%;}
#contact .box ul dl dt,
#contact .box ul dl dd { display: table-cell; vertical-align: middle; padding: 20px 10px;}
#contact .box ul dl dt { width: 35%;}
#contact .box ul dl dt sup { color: #f00;}
#contact .box ul dl dd { position: relative; width: 65%;}
#contact .box ul dl dd input { width: 100%; padding: 8px; background: #f2f2f2; border: solid 1px #dcdcdc;}
#contact .box ul dl dd textarea { width: 100%; height: 150px; padding: 8px; background: #f2f2f2; border: solid 1px #dcdcdc;}
#contact .text { width: 85%; height: 200px; margin: 0 auto 20px; background: #f2f2f2; border: solid 1px #dcdcdc;}
#contact .text .scroll-box{ width: 100%; height: 100%; padding: 10px  0 10px 30px;}
#contact .text h3{ margin: 0 auto 20px; font-size: 18px;}
#contact .text p { text-align: justify;}
#contact .text ol { width: 92%; margin: 0 auto;}
#contact .text ol li { margin: 0 auto  10px;}
#contact .text ol li span { display: block;}
#contact .btn { width: 80%; max-width: 420px; margin: 0 auto; background: linear-gradient(90deg, #bf4949, #be4848);
 box-shadow: 0 0 20px #999; text-align: center;}
#contact .btn input { display: block; width: 100%; height: 60px; line-height: 60px; border: none; background: rgba(255,255,255,0); color: #fff; font-size: 24px;}
#contact .btn input:hover{ background: rgba(255,255,255,0.085);}
#contact .btn input#submit[disabled] { background: #eee; color: #ddd;}
@media (max-width: 641px) {
	#contact .box ul dl dt,
	#contact .box ul dl dd { display: block; width: 100%;}
	#contact .box ul dl dt { padding: 8px 0 0;}
	#contact .box ul dl dd { padding: 4px 0 15px;}
	#contact .text h3{ margin: 0 auto 10px; font-size: 16px;}
	#contact .text p { font-size: 14px;}
	#contact .text ol li { font-size: 14px;}
}
@media (max-width: 481px) {
	#case p.lead { font-size: 16px;}
}
/* フォーム部分 */
#contact ul li label.error {
	position: absolute; top: -30px; left: -10px;
	padding: 5px 8px;
	background: #d00; border-radius: 5px;
	color: #fff; font-size: 12px;
	opacity: 0;
	animation: .5s showError linear forwards .2s;
}
#contact ul li label.error:before{ content: ''; display: block; width: 8px; height: 8px; background: #d00;
	transform: rotate(45deg);
	position: absolute; bottom: -4px; left: 20px;
}
@keyframes showError{
	100%{ opacity: 1;}
}

.send-msg .inner{ width: 92%; margin: 0 auto; padding: 100px 0;}
.send-msg p{ text-align: left; margin: 0 auto 40px;}
.send-msg .btn{ width: 60%; margin: 0 auto; text-align: center;}
.send-msg .btn a:hover{ text-decoration: none;}


#service { background: #f1f1f1;}
#service .inner{ width: 92%; max-width: 1000px; margin: 0 auto; padding: 60px 0 80px;}
#service .box { position: relative; width: 100%; margin: 0 auto 60px; border: solid 1px #235ca6;}
#service .box:last-child { margin: 0 auto 60px;}
#service .box .inner-box { display: flex; align-items: center; position: relative; width: 100%; background: #fff; top: -9px; left: -9px;}
#service .box .inner-box.odd{ flex-direction: row-reverse;}
#service .box .pht,
#service .box .txt{ width: 50%;}
#service .box .pht img { width: 100%;}
#service .box .txt h3{ position: relative; width: 84%; margin:0 auto 20px; padding-left: 40px; color: #081f38; font-size: 36px; line-height: 1;}
#service .box .txt h3:before { content: ''; display: block; width: 24px; height: 24px; border: solid 3px #245da7; border-radius: 50%;
 position: absolute; left: 0; top: 0;
}
#service .box .txt p { width: 84%; margin:0 auto; color: #333; font-size: 20px; font-weight: 700; text-align: justify;}
@media (max-width: 1001px) {
	#service .box .txt h3{ font-size: 30px;}
}
@media (max-width: 769px) {
	#service .box .txt h3{ font-size: 21px;}
	#service .box .txt h3:before { width: 15px; height: 15px;	}
	#service .box .txt p { font-size: 15px;}
}
@media (max-width: 641px) {
	#service .box .inner-box { display: block; padding: 20px 0;}
	#service .box .pht{ width: 80%; margin: 0 auto 20px;;}
	#service .box .txt{ width: 90%; margin: 0 auto;}
}
@media (max-width: 481px) {
	#service .inner{ padding: 40px 0px;}
	#service .box .txt h3{ width: 94%; margin: 0 auto 10px;}
	#service .box .txt p { width: 94%;}
}

.company-data .inner{ width: 92%; max-width: 920px; margin: 0 auto; padding: 60px 0;}
.company-data ul{ width: 100%; margin: 0 auto 60px; border: solid 2px #a50026;}
.company-data ul li dl { display: table; width: 100%;}
.company-data ul li dl dt,
.company-data ul li dl dd{ display: table-cell; vertical-align: middle;}
.company-data ul li dl dt{ width: 13%; padding: 15px 0; border-top: solid 1px #fff; background: #a50026; color: #fff; font-size: 14px; text-align: center;}
.company-data ul li dl dd{ width: 87%; padding: 15px; border-top: solid 1px #a50026; font-size: 13px;}
.company-data ul li {}
.company-data ul li:first-child dl dt,
.company-data ul li:first-child dl dd{ border-top: 0;}
.company-data .map{ width: 100%; height: 450px;}
.company-data #mapView{ width: 100%; height: 100%;}
@media (max-width: 641px) {
	.company-data ul li dl dt,
	.company-data ul li dl dd{ display: block; width: 100%;}
	.company-data ul li dl dt { padding: 8px 0;}
}
@media (max-width: 481px) {
}

