@charset "UTF-8";
@import "base.css";
@import "fonts.css";

/*==========================================================================*/
/*//////////////////////////////////////////////////////////////////////////*/
/*//////                                                              //////*/
/*//////  Copyright (C) 2009 株式会社フリーセル All Rights Reserved.  //////*/
/*//////                                                              //////*/
/*//////////////////////////////////////////////////////////////////////////*/
/*                                                                          */
/*    base.css  --> スタイルの初期設定を行うため、変更しないで下さい。      */
/*    fonts.css --> フォントの初期設定を行うため、変更しないで下さい。      */
/*                                                                          */
/*==========================================================================*/

/*==========================================================================*/
/*                           Common-Setting                                 */
/*==========================================================================*/

/* 基本タグのフォントサイズを指定（12px -> 120% or 1.2em ） */
h1,
h2,
h3,
h4,
h5,
h6,
input,
button,
textarea,
select,
p,
blockquote,
th,
td,
pre,
address,
li,
dt,
dd {
	font-size: 100%;
	margin: 0;
	padding: 0;
}

a {
	color: #000;
	text-decoration: underline;
}

a:hover,
a:active {
	color: #999;
	text-decoration: underline;
}

a:visited {}

span,
dt {
	font-weight: bold;
}


/* add
------------------------------------------------------------------------*/

.mb0 {
	margin-bottom: 0px !important;
}

.mb05 {
	margin-bottom: 5px !important;
}

.mb10 {
	margin-bottom: 10px !important;
}

.mb15 {
	margin-bottom: 15px !important;
}

.mb20 {
	margin-bottom: 20px !important;
}

.mb25 {
	margin-bottom: 25px !important;
}

.mb30 {
	margin-bottom: 30px !important;
}

.mb35 {
	margin-bottom: 35px !important;
}

.mb40 {
	margin-bottom: 40px !important;
}

.mb50 {
	margin-bottom: 53px !important;
}


.mt05 {
	margin-top: 5px !important;
}

.mt10 {
	margin-top: 10px !important;
}

.mt15 {
	margin-top: 15px !important;
}

.mt20 {
	margin-top: 20px !important;
}

.mt40 {
	margin-top: 40px !important;
}

.mt50 {
	margin-top: 50px !important;
}

.ml05 {
	margin-left: 5px !important;
}

.ml10 {
	margin-left: 10px !important;
}

.ml15 {
	margin-left: 15px !important;
}

.ml20 {
	margin-left: 20px !important;
}

.mr05 {
	margin-right: 5px !important;
}

.mr10 {
	margin-right: 10px !important;
}

.mr15 {
	margin-right: 15px !important;
}

.mr20 {
	margin-right: 20px !important;
}

.bold {
	font-weight: bold;
}

.pb20 {
	padding-bottom: 20px !important;
}

.pt05 {
	padding-top: 5px !important;
}

.pt20 {
	padding-top: 20px !important;
}

.fn12 {
	font-size: 12px !important;
}

.fn12 td {
	color: #999;
}

.fs85 {
	font-size: 85%;
	font-weight: normal;
	!important;
}

.Last {
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
}

.red {
	color: #F00;
}

.blue {
	color: #4683c6;
}

.left {
	text-align: left !important;
}

.center {
	text-align: center !important;
}

.right {
	text-align: right !important;
}

/**始まり*******************************************************************************/
/*==========================================================================*/
/*                            Container                                     */
/*==========================================================================*/

html {
	background: none;
}

body {
	color: #696969;
	text-align: center;
	background-color: #fafafa;
	font-size: 14px !important;
	line-height: 22px;
	position: relative;
	min-width: 950px !important;
	width: 100%;
}

.link {
	background: url(../images/icon.png) 0 50% no-repeat;
	padding: 0 0 0 15px;
	color: #333;
	text-decoration: none;
}

.link:hover {
	color: #999;
	text-decoration: none;
}

/*==========================================================================*/
/*                               Header                                     */
/*==========================================================================*/

#h1-bg {
	background-color: #e0e3e5;
	height: 20px;
}

h1 {
	font-size: 12px;
	color: #666;
	width: 950px;
	text-align: right;
	line-height: 20px;
	margin: 0 auto;
}



#header {
	width: 100%;
	position: relative;
	z-index: 100;
	background: url(../images/navi_bg.jpg) 0 bottom repeat-x;
	height: 190px;
	background-color: #fafafa;
}

#header #headerInner .logo_none {
	display: block;
}

#header #headerInner .logo_fix {
	display: none;
}

#header.sticky #headerInner .logo_none {
	display: none;
}

#header.sticky #headerInner .logo_fix {
	display: block;
	top: 13px;
}

#header.sticky {
	position: fixed;
	top: 0;
	z-index: 500;
	width: 100%;
	background-color: #fff;
	padding-bottom: 10px;
	opacity: 1;
	height: 150px;
	box-sizing: border-box;
}

#header.sticky #headerInner ul.dropdown {
	top: 98px;
}

#header.sticky #h1-bg {
	display: none;
}

#header.sticky #headerInner p.phone_top {
	position: absolute;
	top: 14px;
	left: 312px;
	right: auto;
}

#header.sticky #headerInner ol {
	position: absolute;
	top: 19px;
	right: 0;
}

#headerInner {
	width: 950px;
	min-width: 950px;
	margin: 0 auto;
	position: relative;
}

#headerInner div {
	position: absolute;
	top: 20px;
	left: 0;
}

#headerInner ul.dropdown {
	position: absolute;
	top: 116px;
	left: 0;
}

#headerInner ul.dropdown li {
	float: left;
	margin: 0;
	padding: 0;
}

#headerInner ul.dropdown li a {
	display: block;
}

#headerInner ul.dropdown ul {
	/* visibility: hidden; */
	position: absolute;
	width: 200px;
	margin: -7px 0 0 0px;
	z-index: 25;
	height: 322px;
	overflow: hidden;
	display: none;
}

#headerInner ul.dropdown ul li {
	margin: 0;
	padding: 0 0 0px;
	height: 46px;
	overflow: hidden;
}

#headerInner ul.dropdown ul li a {
	display: block;
	height: 46px;
	width: 190px;
	overflow: hidden;
}

#headerInner ul.dropdown ul li a:hover {
	display: block;
	height: 46px;
	width: 190px;
	overflow: hidden;
}

#headerInner p {
	position: absolute;
	top: 20px;
	right: 100px;
}


#headerInner ol {
	position: absolute;
	top: 70px;
	right: 0;
}

#headerInner ol li {
	float: left;
	margin: 0 0 0 10px;
	position: relative;
}
.cart-total-items {
	position: absolute;
    pointer-events: none;
    right: -5px;
    top: -5px;
    width: 25px;
    height: 25px;
}

.cart-total-items > span {
    background: #f00;
    color: #fff;
    pointer-events: none;
    right: -5px;
    top: -5px;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    line-height: 1.4em;
}


/*==========================================================================*/
/*                            Gnavi  Contents                               */
/*==========================================================================*/



/*==========================================================================*/
/*                           Main  Contents                               */
/*==========================================================================*/
.sp {
	display: none
}

#slideshow {
	height: 491px;
	overflow: hidden;
	padding: 0;
	position: relative;
	z-index: 5;
	width: 1392px;
	margin: 0 auto;

}


#slideshow ul#nav {
	list-style: none;
	!important;
	position: absolute !important;
	top: 185px !important;
	z-index: 15 !important;
	width: 1392px;
}





#slideshow ul#nav li#prev {
	float: left;
	margin: 0 0 0 120px;
	z-index: 50;
}

#slideshow ul#nav li#next {
	float: right;
	margin: 0 120px 0 0;
	z-index: 50;
}

#slideshow ul#nav li a {
	display: block;
	height: 65px;
	text-indent: -9999px;
	width: 65px;
	z-index: 50;
}

#slideshow ul#nav li#prev a {
	background: url(../images/arrow-left.png) repeat scroll 0 0 transparent;
}

#slideshow ul#nav li#next a {
	background: url(../images/arrow-right.png) repeat scroll 0 0 transparent;
}

#slideshow ul#slides {
	list-style: none outside none;
	height: 491px !important;
}

#slideshow ul#slides li {
	margin: 0;
	height: 491px !important;
}






#main {
	clear: both;
	height: 491px;
	margin: 0 0 30px 0;
	background-color: #fff;
	background: url(../images/main_bg.jpg) repeat-x scroll center top transparent;
}

#main-inner_bg {
	clear: both;
	height: 491px;
	margin: 0 0 40px 0;
	background-color: #fff;
	background: url(../images/main00.jpg) no-repeat scroll center top transparent;
}

#main-inner {
	position: relative;
	width: 950px;
	height: 206px;
	margin: 0 auto;
	clear: both;
	overflow: hidden;
	top: 35px;
}

.nivoSlider {
	margin: 0 auto;
}

.nivoSlider img {
	position: absolute;
	top: 0px;
	left: 0px;
}

#Z01 {
	z-index: 250 !important;
}

#Z02 {
	z-index: 200 !important;
}

#Z03 {
	z-index: 150 !important;
}

#Z04 {
	z-index: 100 !important;
}

#main02 {
	clear: both;
	/*height:724px;*/
	height: 830px;
	margin: 0 0 40px 0;
	border-bottom: 1px solid #bcbcbc;
}

#main-inner02 {
	width: 950px;
	height: 220px;
	margin: 0 auto;
	clear: both;
	padding-bottom: 30px;
}

.main02_l {
	width: 700px;
	float: left;
	padding: 0 20px 0 0;
}

.main02_r {
	width: 230px;
	float: right;
	height: 155px;
}

.main02_r dl {
	margin: 0;
	padding: 0;
	/*height: 190px;*/
}

.main02_r dt {
	border: 0 none !important;
	height: 40px;
	margin: 0 !important;
	padding: 0 !important;
}

.main02_r dd {
	border: 0 none !important;
	margin: 0 !important;
	padding: 0 !important;
}

.main02_r_01 {
	height: 58px;
}

.main02_r_02 {
	height: 55px;
}

.main02_r_03 {
	height: 67px;
}

.step {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	justify-content: space-between;
	padding: 0 30px;
	margin-bottom: 20px;
}

.step li {
	position: relative;
	width: 255px;
}

.step li img {
	display: block;
	margin-bottom: 8px;
	border: 1px solid #DFE3E4;
}

.step li:not(:last-child):after {
	left: 108%;
	top: 50%;
	border: solid transparent;
	content: " ";
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
	border-color: rgba(42, 127, 191, 0);
	border-left-color: #2a7fbf;
	border-width: 25px;
	margin-top: -35px;
}

.step li span:first-child {
	text-align: center;
	display: block;
	margin-bottom: 10px;
	color: #2879B6;
}

.step li span span.pc_none {
	display: inline;
}



/*==========================================================================*/
/*                           Contents                                       */
/*==========================================================================*/

#wrapper {
	width: 950px;
	margin: 0 auto 30px auto;
}

#wrapper:after {
	content: "";
	display: block;
	clear: both;
}

#Contents {
	width: 700px;
	float: left;
	text-align: left;
	line-height: 22px;
	clear: both;
}

.idx-in #Contents {
	width: 100%;
}

#Contents p {
	margin: 10px 0;
}

#Contents h2 {
	border-top: 2px #000 solid;
	font-size: 18px;
	color: #000;
	padding: 20px 0;
}


#sub {
	clear: both;
	height: 169px;
	margin: 0 0 30px 0;
	background-color: #fff;
	border-bottom: 1px solid #CCC;
}

#sub-inner {
	width: 950px;
	height: 170px;
	margin: 0 auto;
	clear: both;
	overflow: hidden;
}

#sub.kv-sheet,
#sub.kv-new2,
#sub.kv-pool,
#sub.kv-sheet #sub-inner,
#sub.kv-new2 #sub-inner,
#sub.kv-pool #sub-inner {
	position: relative;
	height: auto;
}

#sub #sub-inner {
	background-repeat: no-repeat;
	background-position: 50%;
	background-size: cover;
}

#sub.kv-new2 #sub-inner {
	background-image: url(../images/new2_kv_bg.jpg);
}

#sub.kv-pool #sub-inner {
	background-image: url(../images/pool_kv_bg.jpg);
	background-position: 50% 70%;
}

#sub .kv_icon {
	position: absolute;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	top: 10px;
	left: 14px;
	width: 88px;
	height: 88px;
	padding-top: 3px;
	box-sizing: border-box;
	border-radius: 50%;
	background: #DF3C3C;
	font-size: 22px;
	color: #fff;
}

#sub .kv_flexbox {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	height: 313px;
	padding: 50px 35px 0;
	box-sizing: border-box;
}

#sub.kv-pool .kv_flexbox {
	padding-top: 6px;
}

#sub .kv_title {
	width: 100%;
	color: #fff;
	font-size: 50px;
	font-weight: 600;
	line-height: 1.4;
}

#sub.kv-pool .kv_title {
	color: #707070;
	text-shadow: 0px 3px 6px #00000029;
}

#sub .kv_title .txt-small {
	display: block;
	width: 100%;
	font-size: .6em;
	font-weight: 600;
}

#sub .kv_img {
	margin: 0;
}

@media (max-width: 769px) {
	#sub .kv_icon {
		top: 5px;
		left: 5px;
		width: 58px;
		height: 58px;
		font-size: 14px;
	}

	#sub .kv_flexbox {
		display: block;
		height: unset;
		padding: 60px 10px 0;
		box-sizing: border-box;
	}

	#sub.kv-pool .kv_flexbox {
		padding-top: 60px;
	}

	#sub .kv_title {
		display: block;
		font-size: 26px !important;
		background: none;
		text-shadow: none;
		text-align: center;
		min-height: unset
	}

	#sub .kv_title .txt-small {
		margin-bottom: .3em;
	}

	#sub .kv_img img {
		display: block;
	}
}

#Sub-wrapper {
	width: 950px;
	margin: 0 auto;
}

#Sub-wrapper:after {
	content: "";
	display: block;
	clear: both;
}

#Sub-Contents {
	width: 700px;
	float: right;
	text-align: left;
	line-height: 22px;
	clear: both;
}

#Sub-Contents p {
	margin: 20px 0;
}

#sub-Contents-link {
	width: 700px;
	text-align: center;
}

#sub-Contents-link li {
	margin: 0 10px 0 0;
	display: inline-block;
	display: inline;
	/* IE用ハック */
	zoom: 1;
	/* IE用ハック */
	line-height: 30px;
}

#sub-Contents-link li a {
	width: 200px;
	height: 30px;
	display: block;
	border: 1px solid #E0E0E0;
	text-decoration: none;
	background: url(../images/dot_bg.jpg) 0 0 repeat;
}

#fmail .flex_cal {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
}

#fmail .flex_cal .item_cal {
	box-sizing: border-box;
	display: flex;
	text-align: center;
	width: 20%;
}

#fmail .flex_cal .item_cal p {
	margin: 0;
}

#fmail .flex_cal .item_cal .txt_note {
	color: #555;
	font-weight: normal;
	font-size: 90%;
}

#fmail .flex_cal .item_cal input {
	margin: 3px 0;
	width: 90%;
	padding: 0 3px;
}

#fmail .flex_cal .item_cal.w5 {
	width: 5%;
	text-align: center;
	display: flex;
	justify-content: center;
}

#fmail .flex_cal .item_cal.total {
	width: 25%;
}

#fmail .flex_cal .item_cal.total p.equal,
#fmail .flex_cal .item_cal.transfer p.plus {
	display: none;
}

/*==========================================================================*/
/*                              Menu                                        */
/*==========================================================================*/

#Menu {
	width: 230px;
	float: right;
	text-align: left;
	margin: 0 0 0 20px;
}

#Menu div {
	margin: 0 0 10px 0;
}

#Menu p {
	margin: 0 0 10px 0;
}

#Menu ul {
	margin: 3px 0 30px 0;
}

#Menu ul.ul01 {
	height: 203px;
}

#Menu ul li {
	font-size: 0;
	line-height: 0;
}


#Menu ul li img {
	vertical-align: top;
}

#Menu dl {
	margin-bottom: 25px;
	text-align: left;
}

#Menu dt {
	margin: 0 5px 8px 5px;
	padding: 15px 0 15px 23px;
	border-bottom: 1px #CCC dotted;
	border-top: 2px #000 solid;
	background: url(../images/icon01.jpg) 0 50% no-repeat;
	color: #000;
}

#Menu dd {
	margin: 8px 0;
	padding: 8px 0;
	border-bottom: 1px #CCC dotted;
	font-size: 12px;
}

#Menu dd span {
	margin: 0 15px 0 0;
	color: #77ba4b;
	font-size: 14px;
}

#Menu dd a {
	color: #000;
	text-decoration: none;
}

#Menu dd a:hover {
	color: #999;
	text-decoration: none;
}

.none-border {
	border-bottom: none !important;
}

/*==========================================================================*/
/*                              Footer                                      */
/*==========================================================================*/

#pagetop p {
	clear: both;
	margin: 10px 0;
	text-align: right;
	width: 950px;
}


#footer {
	margin: 50px 0 0 0;
	width: 100%;
	clear: both;
	display: block;
	border-top: 1px solid #CCC;
	text-align: left;
	background-color: #f6f6f6;
	height: 150px;
}

#footer-Inner {
	width: 950px;
	margin: 0 auto;
}

#footer-Inner ul {}

#footer-Inner ul:after {
	content: "";
	display: block;
	clear: both;
	position: relative;
}

.f_logo {
	width: 400px;
	float: left;
	height: 129px;
}

.f_logo img {
	padding-top: 20px;
}

.f_logo p {
	padding: 10px 0;
}

.f_r {
	width: 550px;
	float: right;
	position: relative;
}

.f_r ul {
	position: absolute;
	right: 0;
	top: 30px;
}

.f_r ol {
	position: absolute;
	right: 0;
	top: 70px;
}

.f_r ol li {
	float: left;
	margin: 0 0 0 10px;
	position: relative;
}

#footer-Inner ul li {
	float: left;
	margin-left: 23px;
}

#footer-Inner dl {
	margin-bottom: 25px;
	text-align: left;
}

#footer-Inner dt {
	margin: 8px 5px;
	padding: 8px 0 8px 23px;
	border-bottom: 1px #CCC dotted;
	background: url(../images/icon01.jpg) 0 50% no-repeat;
	color: #000;
}

#footer-Inner dd {
	margin: 7px 0;
	font-size: 12px;
}

#footer-Inner dd span {
	margin: 0 15px 0 0;
	color: #77ba4b;
	font-size: 14px;
}

#footer-Inner dd a {
	color: #000;
	text-decoration: none;
}

#footer-Inner dd a:hover {
	color: #999;
	text-decoration: none;
}




#Copyright {
	background-color: #2879B6;
	border-top: 1px solid #CCCCCC;
	clear: both;
	color: #FFFFFF;
	display: block;
	height: 40px;
	width: 100%;
}

#Copyright div {
	width: 950px;
	position: relative;
	font-size: 12px;
	margin: 0 auto !important;
}

#Copyright address {
	line-height: 40px;
	text-align: center;
	font-size: 12px;
}

#Copyright address a {
	text-decoration: none;
}

/*==========================================================================*/
/*                                 共通CONTENT                              */
/*==========================================================================*/
/****************************/

.half-box {
	width: 700px;
	margin: 20px 0;
}

.half-box li {
	width: 200px;
	float: left;
	margin: 0 15px 20px 15px;
	text-align: center;
}

.half-box li dt {
	margin: 0 0 10px 0;
}


.half-box:after {
	content: "";
	display: block;
	clear: both;
}




/***********************/
.R-img {
	width: 700px;
	margin: 0px auto 30px auto;
}

.R-img div {
	float: right;
	margin: 0 0 10px 30px;
}

.R-img ul {
	margin: 20px 0 0 0;
}

.R-img li {
	display: inline;
	margin: 0 20px 0 0;
}

.R-img .list-displayBlock {
	margin: 0 0 2em;
}

.R-img .list-displayBlock li {
	display: block;
	margin: 0;
}

.R-img:after {
	content: "";
	display: block;
	clear: both;
}

.R-img p {
	line-height: 26px;
	margin-top: 0 !important;
}


.R-img02 {
	width: 670px;
	margin: 0px auto 30px auto;
}

.R-img02 div {
	float: right;
	margin: 0 0 10px 30px;
}

.R-img02 ul {
	margin: 20px 0 0 0;
}

.R-img02 li {
	display: inline;
	margin: 0 20px 0 0;
}

.R-img02:after {
	content: "";
	display: block;
	clear: both;
}

.R-img02 p {
	line-height: 26px;
	margin-top: 0 !important;
}


/***********************/
.L-img {
	width: 700px;
	margin: 0 auto;
	clear: both;
	padding: 5px 0 20px 0;
}

.L-img div {
	float: left;
	padding: 0 20px 0 0;
	background-color: #FFF;
}

.L-img dd {
	border-bottom: 1px #CCC dotted;
	margin: 0 0 20px 0;
}

.L-img:after {
	content: "";
	display: block;
	clear: both;
}

.L-img p {
	line-height: 26px;
	margin-top: 0 !important;
}

.L-img02 {
	width: 670px;
	margin: 0 auto;
	clear: both;
	padding: 5px 0 20px 0;
}

.L-img02 div {
	float: left;
	padding: 0 20px 0 0;
}

.L-img02 dd {
	border-bottom: 1px #CCC dotted;
	margin: 0 0 20px 0;
}

.L-img02:after {
	content: "";
	display: block;
	clear: both;
}

.L-img02 p {
	line-height: 26px;
	margin-top: 0 !important;
}


/***********************/
.tableA {
	background-color: #ccc;
	vertical-align: middle;
	font-size: 14px;
	margin: 0 0 20px 0;
}

.tableA th {
	background-color: #2879B6;
	padding: 15px;
	color: #fff;
	font-weight: bold;
}

.tableA td {
	background-color: #fff;
	padding: 15px;
	text-align: left;
	vertical-align: text-top !important;
}

.tableB {
	border-top: 1px #000 solid;
	border-bottom: 1px #000 solid;
	vertical-align: middle;
	font-size: 14px;
	margin: 20px 0;
}

.tableB th {
	border-bottom: 1px #e9e9e9 solid;
	border-right: 1px #666 dotted;
	background-color: #f8f8f8;
	padding: 15px;
	color: #283424;
	font-size: 14px;
	font-weight: bold;
}

.tableB td {
	border-bottom: 1px #e9e9e9 solid;
	padding: 15px 20px;
	text-align: left;
	line-height: 22px;
}

.tableB td strong {
	font-size: 12px;
	color: #666;
	font-weight: normal;
	line-height: 16px !important;
}

.tableB td dt {
	margin: 0 0 10px 0;
	color: #333;
}

.tableB td dd {
	font-size: 12px !important;
	margin: 0 0 5px 0;
}

.tableC {
	background-color: #dcdcdc;
	vertical-align: middle;
	font-size: 14px;
	margin: 20px 0;
}

.tableC th {
	background-color: #f8f8f8;
	padding: 15px;
	color: #283424;
	font-size: 14px;
	font-weight: bold;
	text-align: center;
}

.tableC td {
	vertical-align: top;
	background-color: #fff;
	padding: 15px 15px;
	text-align: left;
	color: #666;
	line-height: 22px;
}

.tableC td strong {
	font-size: 12px;
	color: #666;
	font-weight: normal;
	line-height: 16px !important;
}

.tableC td dt {
	margin: 0 0 10px 0;
	color: #333;
}

.tableC td dd {
	margin: 0 0 15px 0;
}

.dot-line {
	border-right: 1px #e2e2e2 dotted;
	border-left: 1px #e2e2e2 dotted;
}

.tableD {
	border-top: 1px #000 solid;
	border-bottom: 1px #000 solid;
	vertical-align: middle;
	font-size: 14px;
	margin: 20px 0;
}

.tableD th {
	border-bottom: 1px #e9e9e9 solid;
	border-right: 1px #666 dotted;
	background-color: #f8f8f8;
	padding: 15px;
	color: #000;
	font-size: 14px;
	font-weight: normal;
}

.tableD td {
	vertical-align: top;
	border-bottom: 1px #e9e9e9 solid;
	padding: 15px 15px;
	text-align: left;
	color: #666;
	line-height: 22px;
}

.tableD th span {
	font-weight: bold;
}

.table_method {
	background-color: #ccc;
	vertical-align: middle;
	font-size: 14px;
	margin: 0 0 20px 0;
}

.table_method th {
	background-color: #2879B6;
	padding: 8px 15px;
	color: #fff;
	font-weight: bold;
}

.table_method td {
	background-color: #fff;
	padding: 3px;
	text-align: center;
}

.table_method td.cell01 {
	background-color: #D9EAF7;
}

.table_method td.cell02 {
	background-color: #E8E8E8;
}

/* .table_method.table_01 td{
    border: 1px solid #ccc;
  } */
/***********************/
#Common {
	width: 660px;
	clear: both;
	background: url(../images/common_bg.jpg) 0 0 no-repeat;
	margin: 0 auto;
	text-align: right;
	padding: 80px 40px 0 0;
	height: 60px;
}

#Common:after {
	content: "";
	display: block;
	clear: both;
}

/***********************/
.floatlist {
	width: 100%;
	margin: 0 auto 20px auto;
}

.floatlist li {
	float: left;
	margin: 0 10px 0 0;
}

.floatlist:after {
	content: "";
	display: block;
	clear: both;
}

/***********************/
.line-box {
	width: 660px;
	padding: 10px 16px;
	margin: 20px auto;
	border: 4px #ebf5f8 solid;
}

.line-box dt {
	font-size: 14px;
	color: #58400d;
	font-weight: bold;
	margin: 5px 0 10px 0;
}

.line-box dt span {
	color: #F60;
}

.line-box dd {
	margin: 10px 0;
}

.line-box:after {
	content: "";
	display: block;
	clear: both;
}


/***********************/
.box {
	width: 660px;
	margin: 0 0 50px 0;
	border: 1px #cdcdc2 solid;
	padding: 15px 20px;
}

.box div {
	width: 630px;
	margin: 0 auto;
	border: 1px #e0e0ce solid;
	background-color: #fff;
	padding: 10px 19px;
}

.box2 {
	width: 670px;
	margin: 20px auto;
	border: 1px #cdcdc2 solid;
	background-color: #fafcfc;
	padding: 15px;
}

.box2 div {
	width: 630px;
	margin: 0 auto;
	border: 1px #e0e0ce solid;
	background-color: #fff;
	padding: 10px 19px;
}

.box3 {
	background-color: #FFFFFF;
	border: 1px solid #CDCDC2;
	font-weight: 700;
	margin: 20px auto;
	padding: 0 15px;
	text-align: center;
	width: 670px;
}

.box4 {
	background-color: #FAFCFC;
	border: 1px solid #CDCDC2;
	font-weight: 700;
	margin: 20px auto;
	padding: 0 15px;
	text-align: center;
	width: 670px;
}

/***********************/



/*==========================================================================*/
/*                              Index  Contents                             */
/*==========================================================================*/


#ct01 {
	background-color: #FFFFFF;
	border: 1px solid #CCCCCC;
	margin: 20px 0 0;
	padding: 20px 29px;
	height: 316px;
}

#ct01:after {
	content: "";
	display: block;
	clear: both;
}

#ct01 ul li {
	float: left;
	text-align: left;
	padding-right: 30px;
	width: 276px;
	border: none;
}

#ct01 ul li dt {
	margin: 0 0 20px 0;
}

#ct01 ul li dd {
	margin: 0 0 15px 0;
}

#ct01 ul li dd a {
	font-size: 12px;
}

.X-list {
	width: 950px;
	margin: 10px auto 20px auto;
	background: url(../images/X-list_bg.png) no-repeat scroll 0 0 transparent;
	height: 300px;
	position: relative;
}

.X-list:after {
	content: "";
	display: block;
	clear: both;
}

.X-list ul {
	position: absolute;
	top: 210px;
}

.X-list li {
	width: 160px;
	height: 100px !important;
	float: left;
	margin-right: 20px;
}

#ct01 .Last {
	border: medium none !important;
	margin: 0 !important;
	padding: 0 !important;
	width: 278px;
}

#ctn03 {
	margin: 20px 0 40px;
	padding: 0;
	width: 100%
}

#ctn03 p {
	line-height: 24px;
	text-align: left;
	margin-bottom: 15px;
}

.top_h4 {
	text-align: left;
	margin: 0;
	padding: 0 0 20px 0;
	border-bottom: none;
	background: none repeat scroll 0 0 transparent;
}

/*==========================================================================*/
/*                              Sub  Contents                               */
/*==========================================================================*/

/***********************/
#Sub-main {
	clear: both;
	height: 110px;
	margin: 30px 0 40px 0;
}

#Sub-main h2 {
	background: url(../images/sub_h2_bg.jpg) 0 0 no-repeat;
	height: 110px;
	width: 920px;
	padding: 0 0 0 30px;
	margin: 0 auto;
	clear: both;
	font-size: 24px;
	line-height: 110px;
	text-align: left;
	color: #000;
}

h3 {
	font-size: 18px;
	color: #000;
	padding: 0 0 10px 0;
}

h4 {
	background: url(../images/h4_a.jpg) no-repeat scroll 0% 60% transparent;
	border-bottom: 1px dotted #000000;
	color: #000000;
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 1px;
	line-height: 26px;
	margin: 10px 0 20px;
	padding: 16px 0 10px 30px;
}

h5 {
	background: url(../images/h5_bg.jpg) repeat-x scroll 0 0 transparent;
	border-left: 2px solid #3081BB;
	color: #2878B5;
	display: block;
	font-size: 14px;
	font-weight: 900;
	margin: 20px 0;
	padding: 5px 0 5px 15px;
}

h5 span {
	background-color: #FFF !important;
	padding: 0 10px 0 0 !important;
}

/***********************/
#Location {
	background-color: #fafafa;
	height: 30px;
	border-bottom: 1px #f1f1f1 solid;
}

#Location ul {
	width: 950px;
	margin: 0 auto;
	float: none;
}

#Location li {
	float: left;
	background: url(../images/icon.png) 0 center no-repeat;
	padding: 0 0 0 10px;
	margin: 0 20px 0 0;
	line-height: 30px;
	font-size: 12px;
}

#Location li a {
	text-decoration: none;
}

#Location:after {
	content: "";
	display: block;
	clear: both;
}

/***********************/



/***********************/
.flow {
	margin: 0 0 20px 0;
	border: 1px solid #d7dce3;
	line-height: 26px;
}

.flow dt {
	background-color: #FCFCFC;
	border-bottom: 1px solid #d7dce3;
	color: #333;
	padding: 7px 15px;
}

.flow dt span {
	color: #a1a1a1;
	margin: 0 15px 0 0;
}

.flow dd {
	padding: 15px;
}

/***********************/

.faq {
	margin: 0 0 40px 0;
}

.faq dt {
	padding: 5px 0 10px 30px;
	background: url(../images/q.jpg) 0 6px no-repeat;
	font-weight: 900;
	margin: 20px 0 0 0;
	color: #3f3c3c;
}

.faq dd {
	padding: 5px 0 25px 30px;
	background: url(../images/a.jpg) 0 6px no-repeat;
	margin: 0 0 30px 0;
	border-bottom: 1px dotted #cbc3b0;
}

.list_faq li {
	list-style: none outside none;
	margin-bottom: 10px;
}

/***********************/

.course-list {
	margin: 0 0 40px 0;
	font-weight: bold;
	line-height: 40px;
}

.staff-list {
	line-height: 30px;
	margin: 0 0 20px 0;
}

.staff-list span {
	color: #999;
	font-weight: normal;
	font-size: 12px;
	margin: 0 20px 0 0;
}

.Big-button {
	background-color: #2879B6;
	color: #FFFFFF;
	display: block;
	font-size: 14px;
	font-weight: 800;
	line-height: 18px;
	padding: 8px 0;
	text-align: center;
	text-decoration: none;
	vertical-align: middle;
}


.Big-button:hover {
	background-color: #4D80BD !important;
	color: #FFFFFF !important;
	text-decoration: none !important;
}

.example-anchor {
	width: 700px;
	text-align: center;
	margin: 0 0 30px 0;
}

.example-anchor:after {
	content: "";
	display: block;
	clear: both;
}

.example-anchor li {
	width: 145px;
	float: left;
	background: url(../images/dot_bg.jpg) 0 0 repeat;
	padding: 3px 10px;
	margin: 0 5px;
}

.example-anchor li a {
	text-decoration: none;
	display: block;
}

/**********************/
.example-gallery {
	width: 700px;
	margin: 0 0 30px 0;
}

.example-gallery:after {
	content: "";
	display: block;
	clear: both;
}

.mod_gallery {
	width: 340px;
	float: left;
}

.mod_gallery_navi {
	width: 360px;
	float: right;
}

.mod_gallery_navi li {
	width: 100px;
	height: 75px;
	float: left;
	margin: 0 0 20px 20px;
}

.mod_gallery_navi li a {
	display: block;
}

.mod_gallery_navi li a:link {}

.mod_gallery_navi li a:visited {}

.mod_gallery_navi li a:hover {
	opacity: 0.8;
}

.mod_gallery_navi li a:active {
	opacity: 0.8;
}

/* IE用 ↓*/
.mod_gallery_navi li a:hover img {
	filter: alpha(opacity=80);
}

/* mod_gallery_photo */
.mod_gallery_photo {
	width: 340px;
	height: 255px;
}

.mod_gallery_photo img {
	position: absolute;
}

.example-comment {
	width: 670px;
	border: 1px solid #E0E0E0;
	padding: 15px 15px 0 15px;
	margin: 0 0 40px 0;
	line-height: 20px;
}

.example-comment dt {
	margin: 0 0 5px 0;
}

.example-comment dd {
	color: #707070;
	margin: 0 0 15px 0;
}

/**********************/
.information-list {
	width: 700px;
	margin: 0 0 30px 0;
	line-height: 24px;
}

.information-list:after {
	content: "";
	display: block;
	clear: both;
}

.information-list li {

	margin: 10px 0;
	padding: 0 0 0 10px;
	background: url(../images/icon.png) 0 8px no-repeat;
	white-space: nowrap;
}

.information-list a {
	text-decoration: none;
}

/**********************/
.fmail_p {
	color: #000000;
	font-size: 18px;
	padding: 20px 0 10px;
}

.evidence-list {
	height: 1300px;
}

.ad_h4 {
	border-bottom: medium none !important;
	padding: 16px 0 10px !important;
}

.advantage_caption {
	background: none;
	border-left: none;
	color: #333;
	display: block;
	font-size: 20px;
	margin: 0 0 .5em;
	padding: 0;
}

.advantage_caption .advantage_caption_num {
	display: inline-block;
	color: #2979B6;
	background: none !important;
}

.advantage_list-pic {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
}

.advantage_list-pic .advantage_list_item {
	position: relative;
}

.advantage_list-pic .advantage_list_item::before {
	content: "";
	position: absolute;
	border-color: transparent transparent transparent #2879B6;
	border-style: solid;
	box-sizing: border-box;
}

.advantage_list-pic .advantage_list_item:last-child::before {
	content: none;
}

@media (min-width: 769px) {
	.advantage_list-pic.list-doubleColumn .advantage_list_item {
		width: 308px;
	}

	.advantage_list-pic.list-doubleColumn .advantage_list_item+.advantage_list_item:nth-child(2n) {
		margin-left: 27px;
	}

	.advantage_list-pic.list-doubleColumn .advantage_list_item:not(:nth-child(-n + 2)) {
		margin-top: 40px;
	}

	.advantage_list-pic.list-doubleColumn .advantage_list_item::before {
		right: -20px;
		top: 95px;
		width: 12px;
		height: 30px;
		border-width: 15px 0 15px 12px;
	}

	.advantage_list-pic.list-tripleColumn .advantage_list_item {
		width: 216px;
	}

	.advantage_list-pic.list-tripleColumn .advantage_list_item+.advantage_list_item:not(:nth-child(3n+1)) {
		margin-left: 19px;
	}

	.advantage_list-pic.list-tripleColumn .advantage_list_item:not(:nth-child(-n + 3)) {
		margin-top: 40px;
	}

	.advantage_list-pic.list-tripleColumn .advantage_list_item::before {
		right: -14px;
		top: 68px;
		width: 9px;
		height: 20px;
		border-width: 10px 0 10px 9px;
	}
}

.advantage_list_img {
	margin: 0;
}

.advantage_list_figcaption {
	display: block;
	margin-top: 1em;
}

@media (max-width: 768px) {
	.advantage_caption {
		font-size: 16px;
		margin: 0 0 .5em;
	}

	.advantage_list-pic {
		display: block;
		margin-bottom: 40px;
	}

	.advantage_list-pic .advantage_list_item+.advantage_list_item {
		margin-top: 30px;
	}

	.advantage_list-pic .advantage_list_item::before {
		left: 50%;
		bottom: -20px;
		transform: translateX(-50%);
		border-color: #2879B6 transparent transparent transparent;
		border-width: 10px 15px 0 15px;
		width: 30px;
		height: 10px;
	}

	.advantage_list-pic .advantage_list_item:last-child::before {
		content: none;
	}

	.advantage_list_img {
		text-align: center;
	}

	.advantage_list_img img {
		width: 100%;
		max-width: 300px;
		height: auto;
	}
}


.adText {
	padding: 162px 0 0 0;
	max-width: 98%;
	margin: 0 auto;
}

.adText img {
	width: 100%;
}

#Menu .tinyBlock p {
	padding: 0;
	margin: 0;
}

.tinyBlock {
	margin: 0 auto 50px;
	width: 700px;
}

.tinyC {
	border: 1px solid #cbccd0;
	border-top: none;
	background: #fff;
	padding: 10px 5px 20px 10px;
	height: 122px;
}

.no_js {
	border: solid 2px #F00;
	margin: 30px auto;
	width: 450px;
	height: 70px;
}

.no_js p {
	font-weight: 700;
	font-size: 16px;
	color: #F00;
	padding: 10px;
}

.left_box {
	margin-left: -25px;
}

.img_box {
	float: left;
	width: 150px;
	text-align: center;
}

.img_box img {
	text-align: center;
	border: 1px solid #CCC;
}


.float_l {
	float: left;
}

.float_r {
	float: right;
}

.hover_op:hover {
	opacity: 0.7;
}

.check {
	color: #F00;
	font-size: 20px;
	font-weight: 700;
	margin: 30px 0 -10px !important;
}

#en1262055277,
#en1262055277_match,
#fmail_mailaddr,
#fmail_mailaddr2 {
	font-size: 20px;
	width: 289px !important;
}

.video {
	margin-bottom: 30px;
}

.ul01 {
	overflow: hidden;
	display: block;
	clear: both;
	margin-bottom: 10px;
}

.ul01 li {
	margin: 5px 0;
}

.ul01 li a {
	display: block;
}

.txt01 {
	font-weight: bold;
	text-decoration: underline;
}

/* 170525 */

.feature-box {
	margin-bottom: -20px;
}

.feature-box dl {
	width: 210px;
	margin: 0 35px 20px 0;
	float: left;
	border: 1px solid #e0e0e0;
	position: relative;
	box-sizing: border-box;
}

.feature-box dl:nth-of-type(3n) {
	margin-right: 0;
}

.feature-box dl:not(:nth-of-type(3n))::after {
	content: "";
	position: absolute;
	border: 15px solid;
	border-color: transparent transparent transparent #999;
	right: -42px;
	top: 0;
	bottom: 0;
	margin: auto;
	width: 0;
	height: 0;
}

.feature-box dt {
	border-bottom: 1px solid #e0e0e0;
	padding: 5px;
	text-align: center;
}

.feature-box dd span {
	display: block;
	margin: 10px 5px;
	font-weight: normal;
	font-size: 12px;
	text-align: center;
}

.feature-box dd {}

.contact_img_box {
	width: 220px;
	padding: 5px;
}

/*170530*/
.red_text {
	border: 3px solid #FF0004;
	color: #FF0004;
	padding: 15px;
	font-weight: 700;
	text-align: center;
}

.f-size {
	font-size: 20px;
}

span.money_text {
	font-weight: normal;
	display: block;
}

.anchor_wrapper {
	width: 1392px;
	height: 0px;
	margin: 0 auto;
	position: relative;
}

.anchor_box {
	display: block;
	position: absolute;
	width: 217px;
	height: 218px;
	bottom: 17px;
	right: 281px;
	border-radius: 50%;
	z-index: 9999;
}

.t_img {
	padding-top: 60px;
}

.mr10 {
	margin-right: 10px !important;
}

.txt02 {
	padding: 4px 10px 1px;
	background: #c00000;
	color: #fff;
	margin-left: 10px;
	font-size: 14px;
}

.txt_org {
	font-weight: 700;
	color: #DE5F00;
}

@media screen and (min-width: 769px) {

	.pc_none,
	.sp_nav,
	#fix_menu {
		display: none !important;
	}

	a.pc_click_none {
		pointer-events: none;
		display: block;
	}

}

@media screen and (max-width: 768px) {

	.pc_none,
	#header.sticky #headerInner .logo_none,
	#header.sticky #h1-bg {
		display: block;
	}

	.sp_none,
	#topimg img,
	#contents_r,
	#headerInner ul.dropdown,
	#headerInner ol,
	#headerInner p,
	#header.sticky #headerInner ol,
	#header.sticky #headerInner .logo_fix,
	h4.top_h4:before,
	.f_r ol,
	#sub img {
		display: none;
	}

	.sp {
		display: block
	}

	#header,
	#headerInner,
	#slideshow,
	.main02_l,
	#main-inner02,
	#main02,
	ul#slides li,
	.main02_r,
	#ct01 ul li,
	#wrapper,
	#footer,
	h1,
	iframe,
	.youtube,
	#Copyright div,
	#ctn03,
	#ctn02,
	#ctn01,
	body,
	.X-list,
	#pagetop p,
	#ct01,
	#slideshow ul#slides li,
	#h1-bg,
	#main,
	#sub-inner,
	#Contents,
	.R-img,
	.R-img div,
	.R-img02,
	.R-img02 div,
	.L-img,
	.L-img div,
	#footer-Inner,
	.f_logo,
	.f_r,
	#Copyright,
	#sub,
	.float_l,
	.float_r,
	.example-comment,
	.box2 {
		width: auto !important;
		min-width: initial !important;
		float: none !important;
		height: initial !important;
		margin-left: auto;
		margin-right: auto;
	}

	#header,
	#headerInner div,
	#header.sticky,
	#footer-Inner ul {
		position: initial;
		top: inherit;
		left: inherit;
		margin-left: auto;
	}

	#header {
		border-bottom: 1px solid #cccccc;
		padding: 0 !important;
	}

	html,
	body,
	form,
	fieldset,
	h1,
	h2,
	h3,
	h4,
	h5,
	h6,
	pre,
	blockquote,
	ul,
	ol,
	dl,
	dt,
	dd,
	address {
		margin: 0;
		padding: 0;
	}

	* {
		-webkit-box-sizing: border-box;
		/* Safari,Google ChromeIN */
		-moz-box-sizing: border-box;
		/* FirefoxIN */
		-ms-box-sizing: border-box;
		/* Internet Explorer 8IN */
		box-sizing: border-box;
		/* OperaIN */
		min-width: inherit !important;
		margin-left: auto;
		margin-right: auto;
		word-break: break-all;
		float: none;
		word-break: break-word;
	}

	html {
		font-size: 62.5%;
	}

	body {
		-webkit-text-size-adjust: none;
		font-size: 1.4rem;
		line-height: 1.6;
		letter-spacing: 0;
		margin-bottom: 55px;
		overflow: auto;
		padding-top: 0 !important;
	}

	img {
		max-width: 100%;
		height: initial;
		display: block;
		margin: auto;
	}

	h2,
	h3,
	h4,
	h5,
	h6 {
		line-height: 1.3;
	}

	h1 {
		font-size: 1rem !important;
		float: none;
		text-align: left;
		padding: 5px 10px;
		min-height: 50px;
		line-height: 1.3;
		display: flex;
		align-items: center;
	}

	h2 {
		font-size: 2rem !important;
	}

	h3 {
		font-size: 1.5rem !important;
		margin-bottom: 10px;
	}

	h3.mb30,
	h4.mb30 {
		margin-bottom: 15px !important;
	}

	h4,
	.faq dt {
		font-size: 1.5rem !important;
		position: relative;
		border-bottom: 1px dotted #000;
		background: none;
		padding: 5px 0 6px 10px;
		margin-bottom: 10px;
		display: flex;
	}

	h4:before {
		content: "";
		width: 5px;
		background: #2573b1;
		position: absolute;
		top: 5px;
		left: 0;
		bottom: 10px;
		border-radius: 15px;
	}

	h4.ad_h4 {
		padding: 0 !important;
		margin-bottom: 0;
	}

	h5 {
		font-size: 1.4rem;
		padding: 5px 0 5px 10px;
		margin-bottom: 10px;
		background: rgba(235, 235, 235, 0.6);
	}

	h6 {
		font-size: 1.4rem;
	}

	table,
	table[class] {
		width: 100% !important;
		table-layout: fixed;
		margin-bottom: 30px;
	}

	th,
	td {
		vertical-align: top;
		padding: 10px;
		word-break: break-all;
	}

	.tableA th,
	.tableA td,
	.mailform th,
	.mailform td {
		display: block;
		width: 100% !important;
	}

	.mailform tr:nth-child(1) th {
		border-top: solid 1px #CCCCCC;
	}

	.scroll_sp {
		margin-bottom: 20px;
		overflow-x: auto;
	}

	.scroll_sp::-webkit-scrollbar {
		width: 5px;
		background: #ccc;
	}

	.scroll_sp::-webkit-scrollbar:horizontal {
		height: 5px;
		background: #ccc;
	}

	.scroll_sp::-webkit-scrollbar-thumb {
		background: #969696;
		border-radius: 2px;
	}

	.scroll_sp::-webkit-scrollbar-thumb:horizontal {
		background: #969696;
		border-radius: 2px;
	}

	.scroll_sp table {
		width: 700px !important;
	}

	table tr>*[width] {
		width: inherit;
	}

	table.tableB th,
	table.tableB td {
		display: block;
	}

	table.tableB th {
		border-bottom: 1px #666 dotted;
		border-right: none;
	}

	.mailform {
		margin: 0 0 10px;
	}

	.scroll_sp th,
	.tbl_pc th,
	.scroll_sp td,
	.tbl_pc td {
		display: table-cell;
		width: auto !important;
	}

	.scroll_sp .w01 {
		width: 35% !important;
	}

	.scroll_sp table.tablePool {
		table-layout: inherit
	}

	#fix_menu ul {
		display: -webkit-box;
		display: -webkit-flex;
		display: -moz-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: justify;
		-webkit-justify-content: space-between;
		-moz-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}

	#fix_menu ul {
		width: 310px;
		margin: auto;
	}

	#fix_menu {
		background: rgba(255, 255, 255, 0.8);
		padding: 5px;
		overflow: auto;
		position: fixed;
		bottom: 0;
		left: 0;
		right: 0;
		display: none;
		z-index: 999;
	}

	#fix_menu a {
		display: block;
		padding: 4px;
		font-size: 1.4rem;
		width: 100%;
		box-sizing: border-box;
		text-align: center;
		text-decoration: none;
		position: relative;
	}

	#sp-nav-toggle {
		display: block;
		position: absolute;
		right: 10px;
		top: 70px;
		width: 50px;
		height: 50px;
		cursor: pointer;
		background: white;
		padding: 10px;
		-webkit-border-radius: 5px;
		-moz-border-radius: 5px;
		border-radius: 5px;
		/* color: white; */
		margin: 0 !important;
		z-index: 99999;
		border: 1px solid #e0e0e2;
	}

	#sp-nav-toggle:after {
		content: "MENU";
		position: absolute;
		bottom: 4px;
		left: 0;
		right: 0;
		font-size: 1.2rem;
		text-align: center;
	}

	#sp-nav-toggle.open:after {
		content: "CLOSE";
	}

	#sp-nav-toggle div {
		position: relative;
		width: 100%;
	}

	/*span?IAaAD°IAO≫OAe?I?A?E?・?T?1*/
	#sp-nav-toggle span {
		display: block;
		position: absolute;
		/*#navToggle div ?EAD?・?A*/
		width: 100%;
		border-bottom: solid 3px;
		-webkit-transition: .35s ease-in-out;
		-moz-transition: .35s ease-in-out;
		-o-transition: .35s ease-in-out;
		transition: .35s ease-in-out
	}

	#sp-nav-toggle span:nth-child(1) {
		top: -2px;
	}

	#sp-nav-toggle span:nth-child(2) {
		top: 5px
	}

	#sp-nav-toggle span:nth-child(3) {
		top: 12px
	}

	#sp-nav-toggle.open span:nth-child(1) {
		top: 6px;
		-webkit-transform: rotate(-45deg);
		-moz-transform: rotate(-45deg);
		-ms-transform: rotate(-45deg);
		-o-transform: rotate(-45deg);
		transform: rotate(-45deg)
	}

	#sp-nav-toggle.open span:nth-child(2),
	#sp-nav-toggle.open span:nth-child(3) {
		top: 6px;
		-webkit-transform: rotate(45deg);
		-moz-transform: rotate(45deg);
		-ms-transform: rotate(45deg);
		-o-transform: rotate(45deg);
		transform: rotate(45deg)
	}

	.sp_nav {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		z-index: 9999;
		display: none;
		background: rgba(201, 201, 201, 0.8);
		text-align: center;
		padding-top: 110px;
		overflow: auto !important;
	}

	.sp_nav dt {
		position: relative;
		background: #cacaca;
		/* color: white; */
		padding: 10px;
		border-bottom: 1px dotted #c3c3c3;
	}

	.sp_nav dt.open {
		border-bottom: none;
	}

	.sp_nav dt:after {
		right: 10px;
		bottom: 0;
		top: 0;
		border: solid transparent;
		content: " ";
		height: 0;
		width: 0;
		position: absolute;
		border-color: rgba(7, 167, 129, 0);
		border-left-color: white;
		border-width: 5px;
		margin: auto;
		transform: rotate(90deg) translate(20%, 0);
	}

	.sp_nav dt.open:after {
		transform: rotate(-90deg) translate(20%, 0);
	}

	.sp_nav dd {
		display: none;
	}

	.sp_nav dd a {
		padding-left: 6px;
	}

	.sp_nav dd a:before {
		content: "└";
		margin-right: 10px;
	}

	.sp_nav dd a br,
	#Menu {
		display: none;
	}

	.sp_nav dd dt {
		background: #07a781;
	}

	.sp_nav dd dt:after {
		display: none;
	}

	.sp_nav ul {
		display: flex;
		flex-wrap: wrap;
		border-top: 1px dotted #c3c3c3;
	}

	.sp_nav li {
		width: 100%;
		/* display: flex; */
	}

	.sp_nav a,
	.sp_nav .close {
		text-align: left;
		display: flex;
		padding: 10px;
		text-decoration: none;
		border-bottom: 1px dotted #c3c3c3;
		width: 100%;
		color: inherit;
		align-items: center;
		justify-content: start;
		position: relative;
		background: rgba(255, 255, 255, 0.8);
	}

	.sp_nav a {
		padding: 10px 20px 10px 10px;
	}

	.sp_nav a:after,
	.sp_nav .close:after {
		content: "";
		right: 5px;
		top: 0;
		border: solid transparent;
		content: " ";
		height: 0;
		width: 0;
		position: absolute;
		border-color: rgba(136, 183, 213, 0);
		border-left-color: white;
		border-width: 5px;
		bottom: 0;
		margin: auto;
	}

	.sp_nav a:after,
	.sp_nav .close:after {
		border-left-color: #cacaca;
	}

	.sp_nav .close {
		text-align: center;
		justify-content: center;
	}

	.logo_none {
		max-width: 240px;
		margin: 0 !important;
		padding: 0;
	}

	#headerInner {
		background: #fafafa;
		padding: 10px;
	}

	#slideshow ul#slides {
		height: 90vw !important;
	}

	#slideshow ul#slides li,
	#slideshow ul#slides img {
		width: 100% !important;
	}

	@media only screen and (orientation : landscape) {

		/*横向きの際に適用*/
		#slideshow ul#slides {
			height: 163vh !important;
		}
	}

	.main02_l {
		padding: 0;
	}

	div#main {
		margin: 0;
	}

	div#main02,
	#wrapper {
		padding: 10px;
	}

	.tinyC {
		overflow: hidden;
		height: 140px;
	}

	.ttl_tinyBlock:after {
		border-bottom: 1px solid #DFE2E4;
		content: "";
		position: absolute;
		left: 9px;
		right: 9px;
		bottom: 0
	}

	.ttl_tinyBlock {
		position: relative;
		background: -webkit-gradient(linear, left top, left bottom, color-stop(1.00, #E4E2E2), color-stop(0.00, #fff));
		background: -moz-linear-gradient(center top, #fff 0%, #E4E2E2 100%);
		background: -ms-linear-gradient(top, #fff 0%, #E4E2E2 100%);
		background: -webkit-linear-gradient(#F5F5F5, #FCFCFC);
		background: -o-linear-gradient(#fff, #E4E2E2);
		padding: 10px 10px 10px 20px;
		color: #000000;
		border: 1px solid #cbccd0;
		border-bottom: none;
		text-align: left;
	}

	.ttl_tinyBlock:before {
		border-left: 2px solid #2E7DB7;
		content: "";
		left: 10px;
		position: absolute;
		top: 10px;
		bottom: 10px
	}

	.main02_r>*:nth-child(-n + 2) {
		display: none;
	}

	.main02_r {
		margin-top: 20px;
	}

	.ttl_h3 {
		background: -webkit-gradient(linear, left top, left bottom, color-stop(1.00, #E4E2E2), color-stop(0.00, #fff));
		background: -moz-linear-gradient(center top, #fff 0%, #E4E2E2 100%);
		background: -ms-linear-gradient(top, #fff 0%, #E4E2E2 100%);
		background: -webkit-linear-gradient(#FFF, #F4F4F4);
		background: -o-linear-gradient(#fff, #E4E2E2);
		border: 1px solid #DFE0E4;
		padding: 10px 10px 10px 30px;
		border-radius: 4px;
		box-shadow: 0 0 0 1px #fff inset;
		margin: 0 0 10px;
		position: relative;
		color: #000000;
		font-weight: 700;
		text-align: left;
		width: 100%;
	}

	.ttl_h3:before {
		content: "";
		position: absolute;
		left: 10px;
		top: 11px;
		width: 8px;
		height: 8px;
		border: 4px solid #dd6000;
		border-radius: 50%;
	}

	.X-list {
		background-size: contain;
	}

	.adText {
		padding: 20% 0 0;
	}

	#ct01 {
		padding: 10px;
	}

	#ct01 ul li {
		padding: 0;
	}

	#ct01 ul li+li,
	#ct01 .Last {
		margin-top: 40px !important;
	}

	#ctn03 {
		background: none;
	}

	#ctn03 p {
		margin: 0 !important;
	}

	.f_logo p {
		padding: 10px 10px;
	}

	#footer-Inner ul,
	h4.ad_h4:before {
		display: none;
	}

	#Copyright address {
		line-height: initial;
		padding: 10px;
	}

	.f_logo img {
		margin-bottom: 10px;
	}

	.f_btn {
		margin: 10px 10px 20px;
	}

	div#sub-inner h2 {
		background: url(../images/h2_03.jpg) top -5px right 35%;
		background-size: 190%;
		min-height: 100px;
		color: #cd4350;
		display: flex;
		align-items: center;
		text-align: left;
		padding: 10px;
		text-shadow: 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff, 0 0 5px #fff;
	}

	#sub-inner h2 span {
		width: 100%;
	}

	#Contents p {
		margin: 10px 0 20px;
	}

	span.txt02 {
		padding: 5px 5px;
		font-size: 1rem;
		word-break: keep-all;
		align-items: center;
		display: flex;
		margin-left: 5px;
	}

	.L-img,
	.R-img {
		padding-bottom: 0;
		overflow: auto;
	}

	.L-img div,
	.R-img div,
	.t_img {
		padding: 0 !important;
		margin-bottom: 10px;
	}

	/*.float_l,.float_r {
    margin: 0 0 10px!important;
  }*/

	.feature-box dl:not(:last-child):after {
		right: 0 !important;
		top: initial !important;
		left: 0;
		bottom: -45px !important;
		transform: rotate(90deg);
		margin: auto;
		width: 0;
		height: 0;
		content: "";
		position: absolute;
		border: 15px solid;
		border-color: transparent transparent transparent #999;
	}

	.feature-box dl {
		width: 100%;
	}

	.feature-box dl:not(:last-child) {
		margin-bottom: 40px;
	}

	/*インプットにはこれをいれる*/
	#fmail input[type="text"] {
		width: 100% !important;
		max-width: 100% !important;
		ox-sizing: border-box;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
		-o-box-sizing: border-box;
		-ms-box-sizing: border-box;
	}

	/*テキストエリアにはこれを入れる*/
	#fmail textarea {
		height: 200px;
		width: 100% !important;
		max-width: 100% !important;
		box-sizing: border-box;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
		-o-box-sizing: border-box;
		-ms-box-sizing: border-box;
	}

	input[value="郵便番号から住所を入力"] {
		display: none;
	}

	#twex {
		display: none !important;
	}

	form.fmail_submit,
	form.fmail_cancel {
		width: 100% !important;
		text-align: center !important;
	}

	span#fmail_title_default,
	span#fmail_title_confirm,
	span#fmail_title_error,
	span#fmail_title_thanks {
		display: none !important;
	}

	table.mailform .left_box {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}

	.img_box.contact_img_box {
		width: 48%;
	}

	.left_box.clearfix:after {
		display: none;
	}

	p+iframe {
		margin: 0 auto 20px;
		display: block;
	}

	.gMap.gMapZoom17 {
		width: 100% !important;
		height: 200px !important;
	}

	.step li {
		position: relative;
		width: 255px;
		margin: 0 5px;
	}

	.step {
		padding: 0;
	}

	ul.step li:not(:last-child):after {
		display: none;
	}
}


.bor_img {
	background: url(../images/menu07_bor.jpg) 0 bottom no-repeat;
	padding: 16px 0 12px;
}

.f_left {
	float: left;
	width: 340px;
}

.f_right {
	float: right;
	width: 340px;
}

#Contents .f_left p,
#Contents .f_right p {
	margin: 0 0 20px 0;
}



/* ===============css new ====================*/

.container {
	width: 950px;
	margin: 0 auto;
	padding-bottom: 30px;
	text-align: left;
}

.main_new {
	background: #fafafa;
	margin-bottom: 30px;
}


.container p {
	margin-bottom: 15px;
}

.idx_box01 {
	background: url("../images/bg01.jpg") no-repeat left top -20px, url("../images/bg02.jpg") no-repeat right -20px center #f0fafc;
	padding: 30px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 50px;
	border: 4px solid #50add6;
	position: relative;
}

.idx_box01 p {
	margin: 0;
	position: absolute;
	right: 40px;
	bottom: 5px;
}

.idx_box01 ul {
	background: rgba(255, 255, 255, 0.7);
	padding: 20px 30px;
	width: 100%;
}

.idx_box01 ul li {
	line-height: 30px;
	color: #333;
	margin-bottom: 3px;
	font-size: 16px;
	position: relative;
	padding: 0 0 0 20px;
	border-bottom: 1px dotted #333;
	max-width: 420px;
}

.idx_box01 ul li:after {
	content: "・";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
}


.h3_tit {
	font-size: 26px;
	color: #0e3578;
	font-weight: bold;
	margin-bottom: 20px;
}

.box_image04 {
	display: flex;
	justify-content: space-between;

}

.box_image04 li {}

.box_image04 .slick-track {}

.box_image04 .slick-slide {
	text-align: center;
	border: 1px solid #d4d4d4;
	margin: 0 5px;
	padding: 10px 10px 40px 10px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	position: relative;
	display: flex;
	flex-direction: column;
}

.box_image04 .slick-slide p {
	text-align: left;
}

.box_image04 .slick-prev {
	width: 40px;
	height: 40px;
	left: -40px;
}

.box_image04 .slick-next {
	width: 40px;
	height: 40px;
	right: -40px;
}

.box_image04 .slick-prev::before {
	content: '';
	display: block;
	background: url("../images/arrow-left1.png") no-repeat 0 0 / 100%;
	width: 40px;
	height: 40px;
}

.box_image04 .slick-next::before {
	content: '';
	display: block;
	background: url("../images/arrow-right1.png") no-repeat 0 0 / 100%;
	width: 40px;
	height: 40px;
}

.box_image04 .btn_bot {
	position: absolute;
	width: 100%;
	bottom: 20px;
}

.box_image04 .btn_bot a,
.box_image04 .btn_bot a img {
	margin: 0 auto 0;

}

.tit_new span {
	display: block;
	color: #f00;
	font-size: 16px;
	font-weight: bold;
}

.tit_new {
	font-size: 15px;
	font-weight: bold;
}

.txt_dot {
	position: relative;
	padding-left: 15px;
}

.txt_dot:after {
	content: "・";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
}


.btn_bot {
	position: absolute;
	bottom: 13px;
	left: 0;
	width: 100%;
	margin-bottom: 0 !important;
}


.bx_btn a {
	display: block;
	width: 100%;
	margin: 50px 0;
}



.bx_btn a:hover {
	opacity: .9;
}


p.tit_brown {
	font-weight: bold;
	font-size: 20px;
	margin-bottom: 30px;
}

.box_ar p {
	text-align: center;
	font-weight: bold;
	font-size: 15px;
	margin-bottom: 10px;
}

.box_ar {
	display: flex;
	justify-content: space-between;
	margin-bottom: 50px;
}

.box_ar li {
	width: 23%;
	position: relative;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

.box_ar li img {
	width: 100%;
}

.box_ar li:after {
	position: absolute;
	content: "";
	display: block;
	top: 55%;
	transform: translateY(-50%);
	right: -23px;
	width: 20px;
	height: 20px;
	background: url("../images/ar_39.png") no-repeat center center;
}

.box_ar li:last-child:after {
	display: none;
}

.box_grey {
	padding: 20px;
	background: #f5f5f5;
	margin: 50px 0;
}

.box_grey .step {
	padding: 0;
}

#sub.kv-sheet #sub-inner {
	background-image: url(../images/sheet_kv_bg.jpg);
}

#sub .kv_title.sheet {
	font-size: 37px;
}

#sub .kv_title.sheet .txt-small {
	font-size: .65em;
	letter-spacing: 2px;
}

.sheet_caption {
	background: none;
	border-left: none;
	color: #333;
	display: block;
	font-size: 16px;
	margin: 0 0 1em;
	padding: 0;
}

.sheet_caption .advantage_caption_num {
	display: inline-block;
	color: #2979B6;
	background: none !important;
}

.tb_sheet td {
	text-align: left;
	padding: 3px 5px;
	vertical-align: middle;
}

.tb_sheet td.w26 {
	width: 26%;
}



@media screen and (max-width: 768px) {

	.bx_btn a {
		margin: 20px 0;
	}

	.container {
		width: 100%;
		padding: 30px 15px;
	}

	.idx_box01 {
		background: url("../images/bg01.jpg") no-repeat left top -20px, url("../images/bg03.jpg") no-repeat left bottom / 100% #f0fafc;
		padding: 15px;
		display: block;
		position: relative
	}

	.idx_box01 ul {
		margin-bottom: 20px;
		padding: 12px 12px 25vh;
	}

	.idx_box01 p {
		right: 5%;
		bottom: 0;
		width: 90%;
	}

	.idx_box01 ul li {
		font-size: 14px;
		border-bottom: 1px dotted #333;
		padding: 5px 0 5px 12px;
	}

	.main_new {
		margin-bottom: 0;
	}

	.idx_box01 ul li:after {
		top: 5px;
	}

	.idx_box01 ul {
		margin-bottom: 20px;
	}

	.box_ar li {}

	.tinyBlock {
		margin: 0 auto 50px;
		width: 100%;
	}

	.box_image04 .slick-slide {
		margin: 0 8px;
	}

	.box_image04 .slick-prev {
		z-index: 9;
		left: -12px;
	}

	.box_image04 .slick-next {
		z-index: 9;
		right: -12px;
	}

}

@media screen and (max-width: 550px) {
	#fmail .flex_cal .item_cal {
		width: 30%;
	}

	#fmail .flex_cal {
		justify-content: center;
		max-width: 500px;
		margin: 0 auto;
	}

	#fmail .flex_cal .item_cal.total {
		width: 100%;
		justify-content: center;
		max-width: 500px;
		margin: 20px auto 0;
		align-items: center;
	}

	#fmail .flex_cal .item_cal.total p.equal {
		line-height: 0;
	}

	#fmail .flex_cal .item_cal.equal {
		display: none;
	}
}

@media screen and (max-width: 480px) {
	.box_image04 li {
		width: 100%;
		margin-bottom: 20px;
	}


	.box_image04 {
		display: block;
	}

	.fix_step_sp {
		display: block;
		max-width: 255px;
		margin: 0 auto;
	}

	.fix_step_sp li {
		margin: 0 0 20px 0;
		;
	}

	.box_image04 .slick-slide {
		margin: 0 30px;
	}

	.box_image04 .txt_dot {
		margin: 0 0 10px;
	}

	.idx_box01 ul li {
		font-size: 3vw;
		line-height: 1.4
	}
}


@media screen and (max-width: 375px) {
	.box_image04 .slick-slide {
		margin: 0 20px;
	}

	.box_image04 .slick-prev {
		width: 30px;
		height: 30px;
	}

	.box_image04 .slick-next {
		width: 30px;
		height: 30px;
	}

	.box_image04 .slick-prev::before,
	.box_image04 .slick-next::before {
		width: 30px;
		height: 30px;
	}

	.idx_box01 {
		padding: 12px;
	}

	.idx_box01 ul {
		padding: 10px 10px 25vh;
	}

	#fmail .flex_cal .item_cal.transfer {
		width: 100%;
	}

	#fmail .flex_cal .item_cal {
		width: 47%;
		padding: 0 5px;
	}

	#fmail .flex_cal .item_cal.plus {
		display: none;
	}

	#fmail .flex_cal .item_cal.transfer {
		width: 100%;
		justify-content: center;
		max-width: 500px;
		margin: 20px auto 0;
		align-items: center;
	}

	#fmail .flex_cal .item_cal.transfer p.plus {
		line-height: 0;
		display: block;
	}
}


@media screen and (max-width: 549px) {

	.box_ar {
		display: block;
		max-width: 224px;
		margin: 0 auto;
	}

	.box_ar li {
		width: 100%;
		padding-bottom: 30px;
		background: url("../images/arr_39.png") no-repeat bottom 10px center;
	}

	.box_ar li:after {
		display: none;
	}

	.box_ar li:last-child {
		background: none;
	}

}

@media screen and (min-width: 550px) and (max-width: 768px) {
	.box_ar li:after {
		width: 11px;
		height: 21px;
		background-size: 100%;
		right: -12px;
		top: 60%;
	}


}


@media screen and (min-width: 769px) {

	#main02,
	#main-inner02,
	.main02_r {
		height: auto !important;
	}


}

.index_price table {
	background-color: #ccc;
	vertical-align: middle;
	font-size: 14px;
	margin: 0 0 20px 0;
	width: 100%;
	padding: 0;
	border-collapse: separate;
	border-spacing: 1px;
	line-height: 1.4;
}

.index_price table th,
.index_price table td {
	text-align: center;
	margin: 0;
	padding: 0;
	padding: 3px;
}

.index_price table th {
	background-color: #D9EAF7;
	font-weight: 600;
	color: #2879B6;
}

.index_price table td {
	background-color: #FFF;
}

.index_price table dl {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.index_price table dt {
	font-weight: normal;
	width: 60%;
}

.index_price table dd {
	font-weight: normal;
	width: 40%;
}

.w35 {
	width: 35%;
}

.w15 {
	width: 15%;
}

.w20 {
	width: 20%;
}

.index_price h3 {
	color: #bb0000;
	font-weight: 600;
	text-align: center;
}

.acc_support .bnt,
.acc_support .bnt2 {
	max-width: 250px;
	padding: 10px;
	margin: 0 auto 20px !important;
	background: #0e3578;
	color: #fff;
	text-align: center;
	cursor: pointer;
}

.acc_support .bnt:hover {
	opacity: 0.8;
}

.acc_support .accordiam {
	display: none;
}

/* .acc_support .scroll_sp{
display: none;
}
.acc_support .scroll_sp.open{
  display:block;
} */
.block-contact {
	background: #fff;
	box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px, rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
	padding-bottom: 10px;
	max-width: 600px;
	margin: auto;
	border: 4px solid #D9EAF7;
}

#Contents .ttl-zone {
	background-color: #D9EAF7;
	padding: 10px;
	text-align: center;
	font-weight: bold;
	margin: 0;
	font-size: 18px;
	color: #000;
}

#Contents .icon-phone {
	font-size: 24px;
	font-weight: bold;
	position: relative;
	padding-left: 35px;
	color: #000;
	text-align: center;
	width: max-content;
	margin: 15px auto 0;
}

#Contents .icon-phone:before {
	content: '';
	position: absolute;
	background: url(../images/phone-icon.svg) no-repeat;
	width: 30px;
	height: 40px;
	top: -10px;
	left: 0;
	z-index: 1;
	background-position: center;
	background-size: contain;
}

#Contents .icon-phone span {
	margin-left: 40px;
	font-size: 14px;
}

#Contents .item-contact {
	display: flex;
	justify-content: center;
	align-items: center;
}

#Contents .item01 {
	margin-right: 20px;
}

#Contents .item-contact a {
	text-decoration: none;
	color: #fff;
	font-weight: bold;
	font-size: 16px;
	padding: 10px;
	width: 240px;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 5px;
	box-shadow: rgba(99, 99, 99, 0.2) 0px 2px 8px 0px;
}

#Contents .item-contact a:hover {
	opacity: .8;
}

#Contents .item-contact .item01 a {
	background: #2879B6;
}

#Contents .item-contact .item02 a {
	background: #F3C04F;
	background: linear-gradient(180deg, rgba(243, 192, 79, 1) 0%, rgba(247, 173, 18, 1) 50%, rgba(233, 139, 43, 1) 100%);
}

#Contents .item-contact a img {
	width: 24px;
	margin-right: 10px;
}

.txt-color {
	color: red;
}

.anchor-list {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: 40px;
}

.anchor-item {
	position: relative;
}

.anchor-item.pl a {
	padding-left: 40px;
}

.shape {
	background: #DF3C3C;
	border-radius: 100%;
	padding: 5px;
	color: #fff;
	font-weight: bold;
	font-size: 12px;
	position: absolute;
	width: 50px;
	height: 50px;
	display: flex;
	justify-content: center;
	align-items: center;
	top: -30px;
	left: -20px;
}

.anchor-list a {
	background: #ed7d31;
	text-decoration: none;
	color: #fff;
	font-weight: bold;
	display: block;
	padding: 10px 20px;
	font-size: 16px;
	margin-right: 20px;
}

.anchor-list .anchor-item:hover {
	opacity: .8;
}

.top-bnr {
	margin-bottom: 30px;
}

.box_image04.cus {
	background: #deebf7;
	display: grid;
	grid-template-columns: repeat(2, 2fr);
	grid-column-gap: 30px;
	grid-row-gap: 30px;
	padding: 0 30px 30px;
}

.box_image04.cus .heightLine {
	background: #ffffff;
	border: 2px solid #fff;
}

.box_image04.cus .heightLine {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 30px 5px;
	position: relative;
}

.container .box_image04.cus .heightLine p {
	margin-bottom: 8px;
	font-size: 16px;
}

.box_image04.cus .heightLine p img {
	width: 130px;
}

.box_image04.cus .btn_bot {
	position: static;
	margin-top: 20px;
}

.box_image04.cus .heightLine .btn_bot img {
	width: auto;
}

.heightLine_content {
	margin-left: 10px;
}

.bg-box04 {
	background: #deebf7;
	padding: 40px 40px 10px;
}

.h3_tit.h3-title {
	text-align: center;
	font-size: 32px;
}

.h3_tit.h3-title span {
	display: block;
	font-size: 18px;
	padding-bottom: 5px;
}

.shape_cus {
	position: absolute;
	background: #ff0000;
	color: #fff;
	border-radius: 20px;
	padding: 5px 20px;
	top: -17px;
	right: 0;
	transform: skewY(3deg);
}

.ttl-inner {
	background: #fff;
	border: 2px solid #2e75b6;
	border-radius: 10px;
	text-align: center;
	width: 220px;
	padding: 10px;
	font-weight: bold;
	font-size: 18px;
	color: #333;
	margin: auto;
}

.caption_cus {
	font-size: 12px;
	display: block;
	text-align: center;
}

.slides-cus {
	position: relative;
}

.slides-cus .link01 {
	position: absolute;
	z-index: 2;
	top: 37%;
	left: 0;
	width: 41.2%;
	text-align: right;
}

.slides-cus .link02 {
	position: absolute;
	z-index: 2;
	bottom: 9%;
	right: 0;
	width: 39.1%;
	text-align: left;
}

.homepage #main {
	background: none;
	box-shadow: rgba(0, 0, 0, 0.05) 0px 6px 24px 0px, rgba(0, 0, 0, 0.08) 0px 0px 0px 1px;
}

@media screen and (max-width: 768px) {
	#slideshow ul#slides .slides-cus a img {
		width: 80% !important;
	}

	.slides-cus .link01 {
		top: 23%;
		left: 120px;
		width: 41.2%;
	}

	.slides-cus .link02 {
		right: auto;
		left: 28%;
		width: 41.2%;
	}

	#header.header-scroll {
		width: 100% !important;
		z-index: 99;
		position: fixed;
		box-shadow: rgba(0, 0, 0, 0.15) 1.95px 1.95px 2.6px;
	}

	#header.header-scroll #sp-nav-toggle {
		top: 10px;
	}

	#header.header-scroll h1 {
		display: none;
	}

	#header.header-scroll .logo_none img {
		width: 150px;
		margin-left: 0;
	}

	.block-contact {
		padding-bottom: 15px;
	}

	#Contents .item-contact {
		display: block;
	}

	#Contents .icon-phone span {
		display: block;
		text-align: center;
		margin-left: 0;
	}

	#Contents .ttl-zone {
		font-size: 16px;
	}

	#Contents .item-contact a img {
		margin: 0 10px 0 0;
	}

	#Contents .item01 {
		margin-right: 0;
		margin-bottom: 10px;
	}

	#Contents .item-contact p {
		margin: 10px 0 0;
	}

	#Contents .anchor-item {
		margin-left: auto;
		margin-right: auto;
		width: max-content;
	}

	.anchor-list {
		display: block;
	}

	.anchor-list a {
		width: 280px;
		margin: auto;
	}

	.shape {
		width: 60px;
		height: 60px;
	}

	.top-bnr {
		padding: 0 15px;
		margin-top: 50px;
		margin-bottom: 0;
	}

	.box_image04.cus {
		grid-template-columns: repeat(1, 1fr);
		padding: 0 15px 15px;
	}

	.box_image04.cus .heightLine {
		display: block;
	}

	.box_image04.cus .heightLine.cus {
		padding-top: 40px;
	}

	.box_image04.cus .tit_new span {
		display: none;
	}

	.h3_tit.h3-title {
		font-size: 26px !important;
	}

	.bg-box04 {
		padding: 40px 15px 10px;
		margin-bottom: 40px;
	}

	.box_image04.cus .heightLine p img {
		width: auto;
	}

	.box_image04.cus .btn_bot {
		margin-top: 15px;
	}

	.box3,
	.box4,
	.box2 div,
	.half-box {
		width: auto;
	}

	.half-box li {
		float: unset;
		margin: 0 auto 20px;
	}
}

/*
#Contents .item-contact a:before {
	content: '';
    position: absolute;
	width: 24px;
    height: 42px;
    top: 0;
    left: 0;
    z-index: 1;
}
#Contents .item-contact .item01 a:before {
    background: url("../images/shopping-icon.png") no-repeat;
	background-position: center;
    background-size: contain;
	left: 35px;
}
#Contents .item-contact .item02 a:before {
    background: url("../images/mail-icon.png") no-repeat;
	background-position: center;
    background-size: contain;
	left: 20px;
}
*/



a.heightLine {
	display: block;
	color: inherit;
	text-decoration: none;
}

a.heightLine:hover {
	opacity: 0.8;
}

.list_ovn {
	display: grid;
	grid-template-columns: repeat(3, 3fr);
	grid-column-gap: 20px;
	grid-row-gap: 20px;
}
.list_ovn li {
	box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;
    background: #fff;
    padding: 15px 10px;
    border-radius: 4px;
}
.list_ovn li a {
	text-decoration: none;
}
#Contents .list_ovn p.img {
	width: 100%;
    height: 185px;
    overflow: hidden;
    position: relative;
	margin: 0 0 15px;
}
.list_ovn p.img img {
	display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    max-height: 100%;
	max-width: 100%;
}
#Contents .ttl-ovn {
	color: #000000;
    font-size: 16px;
    letter-spacing: 1px;
    line-height: 26px;
	margin: 0 0 15px;
}
#Contents .btn-more {
	margin: 0 auto;
}
#Contents .list_ovn .desc {
	margin-bottom: 20px;
}
#Contents .list_ovn .desc p {
	margin: 0;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	-o-text-overflow: ellipsis;
	display: -webkit-box;
	overflow: hidden;
	text-overflow: ellipsis;
}
.btn-more {
	display: block;
    color: #fff;
    text-decoration: none;
    text-align: center;
    font-weight: bold;
    width: 120px;
    padding: 5px;
    border-radius: 4px;
    background: #3c78b4 url(../images/icon_right.png) no-repeat;
    background-size: 7px;
    background-position: 110px;
}

#Contents .pagination {
	display: flex;
    justify-content: center;
    flex-wrap: wrap;
    text-align: center;
    margin: 30px auto 0;
}
#Contents .pagination li {
	margin: 0 5px;
}
#Contents .pagination li.disabled {
	display: none;
}
#Contents .pagination li a {
	width: 40px;
    height: 40px;
    text-align: center;
    border: 1px solid #3c78b4;
    background: #fff;
    display: flex;
    color: #3c78b4;
    justify-content: center;
    align-items: center;
    border-radius: 5px;
	text-decoration: none;
}
#Contents .pagination li.active a {
	pointer-events: none;
}
#Contents .pagination li.active a {
	background: #3c78b4;
    color: #fff;
}
#Contents h2.h2-title {
	font-size: 20px;
    font-weight: bold;
    text-align: center;
    padding: 0;
    margin: 0 0 40px;
	border-top: 0;
}
.box_ovn {
	margin-bottom: 50px;
}
.box_ovn.last {
	margin-bottom: 0;
}
.group-img {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
}
#Contents .group-img p {
	margin: 0 80px 0 0;
	width: 50%;
}
#Contents .group-img p:last-child {
	margin: 0;
}
.group-img:after {
	content: "";
    position: absolute;
    border: 15px solid;
    border-color: transparent transparent transparent #999;
    top: 0;
    bottom: 0;
    margin: auto;
    width: 0;
    height: 0;
    left: 51%;
    transform: translateX(-50%);
    text-align: center;
}
.box_bf-af {
	margin-bottom: 50px;
}
.list_category {
	margin-bottom: 40px;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
}
.list_category li {
	margin: 10px 20px 0 0;
}
.list_category li:last-child {
	margin-right: 0;
}
.list_category li a {
	background: #3c78b4;
    color: #fff;
    text-decoration: none;
    padding: 10px 20px;
    display: block;
    text-align: center;
    line-height: 1.4em;
    font-size: 16px;
    font-weight: bold;
	border-radius: 4px;
    box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;
}
.ovn_detail img {
	height: auto;
	width: auto;
	max-width: 100%;
}
.contribute_detail_header p label input {
	width: 80%;
    margin-left: 20px;
}
/*-- cart */
.insert-cart-area {
	display: flex;
	justify-content: center;
	gap: 10px;
	position: relative;
}
.under-table-select select {
    width: 180px;
    height: 41px;
    border: 1px solid #504b46;
    outline: none;
    padding: 5px 10px;
}
body form.cart_sender input.form_submit {
    text-decoration: none;
    display: inline-block;
    font-size: 16px;
    position: relative;
    padding: 10px;
    border: 1px solid #B72331;
    font-weight: 500;
    width: 180px;
    text-align: center;
    line-height: 1.4em;
    background: #B72331;
    outline: none;
    height: 41px;
    font-weight: bold;
    color: #fff;
    cursor: pointer;
    transition: 0.3s all;
}
body form.cart_sender input.form_submit:hover {
	background: #000;
	border: 1px solid #000;
}
div.loading {
    position: absolute;
    top: 50%;
    left: 50%;
    display: none;
    padding: 5px 20px;
    background: #EEFFAA;
    border: 1px solid #aaaaaa;
    z-index: 9999;
}

.cart-block-btn ul {
	display: flex;
	justify-content: center;
	gap: 10px;
}
.in-btn {
    position: relative;
    display: inline-block;
    text-decoration: none;
    font-size: 16px;
    color: #504b46;
    line-height: 1.2em;
    padding: 16px 35px 17px;
    min-width: 275px;
    font-weight: bold;
    text-align: center;
    border: 1px solid #504b46;
    transition: all 0.3s ease-in-out;
}
.in-btn::before {
    position: absolute;
    content: "";
    border: solid #504b46;
    padding: 7px;
    border-width: 1px 1px 0 0;
    top: 51%;
    right: 21px;
    transform: translateY(-50%) rotateZ(45deg);
}
.in-btn.cart .btn-item>span {
    position: relative;
    z-index: 2;
    padding: 2px 15px;
}
.in-btn.cart::before {display: none;}
.in-btn.cart .btn-item>span:before {
    position: absolute;
    content: '';
    display: inline-block;
    background-size: contain;
    background-image: url(../images/icon-cart.png);
    background-position: center left;
    background-repeat: no-repeat;
    z-index: 1;
    top: 2px;
    left: 0px;
    width: 24px;
    height: 24px;
}

.in-btn.cart {
    background-color: #2879B6;
    color: #fff;
}
.in-btn.cart:hover {
	background: #000;
}
.in-btn:hover::before {
    border: solid #fff;
    border-width: 1px 1px 0 0;
}
.in-btn:hover {
	text-decoration: none;
	background: #000;
	color: #fff;
}
form.cart_total input.submit, p.window_close,form.cart_confirm input.submit:hover {
	cursor: pointer;
}
body form.cart_confirm input.submit {
	margin: 0;
}
#fmail select.fmail {
	visibility: visible !important;
}
#fmail textarea.fmail#en1766383493 {
	width: calc(100% - 10px);
    background: #fff;
    padding: 10px;
    box-sizing: border-box;
    height: 100px;
}
#fmail textarea.fmail#en1245939490 {
	width: calc(100% - 10px);
    background: #fff;
    padding: 10px;
    box-sizing: border-box;
    overflow: hidden;
  resize: none;
  border: none;

}
#fmail textarea.fmail#en1245939490:focus {
  outline: none;
  box-shadow: none;
}
/* end cart */
.indent1 {
	margin-left: 14px;
	display: block;
	font-weight: normal;
}
@media screen and (min-width: 769px) {
	.content_ovn {
		display: flex;
		justify-content: space-between;
	}
	.content_ovn .box_content {
		order: 1;
		width: 80%;
	}
	.content_ovn .img {
		order: 2;
		margin-left: 20px;
		width: 40%;
	}
	.h3-title {
		padding: 0;
	}
	.h3-title .ttl_h3 {
		background: -webkit-gradient(linear, left top, left bottom, color-stop(1.00, #E4E2E2), color-stop(0.00, #fff));
		background: -moz-linear-gradient(center top, #fff 0%, #E4E2E2 100%);
		background: -ms-linear-gradient(top, #fff 0%, #E4E2E2 100%);
		background: -webkit-linear-gradient(#FFF, #F4F4F4);
		background: -o-linear-gradient(#fff, #E4E2E2);
		border: 1px solid #DFE0E4;
		padding: 10px 10px 10px 30px;
		border-radius: 4px;
		box-shadow: 0 0 0 1px #fff inset;
		margin: 0 0 10px;
		position: relative;
		color: #000000;
		font-weight: 700;
		text-align: left;
		display: block;
		width: max-content;
	}

	.h3-title .ttl_h3:before {
		content: "";
		position: absolute;
		left: 10px;
		top: 11px;
		width: 8px;
		height: 8px;
		border: 4px solid #dd6000;
		border-radius: 50%;
	}
}

@media screen and (max-width: 768px) {
	.list_ovn {
		grid-template-columns: repeat(2, 2fr);
		grid-column-gap: 15px;
		grid-row-gap: 15px;
	}
	h3.h3-title {
		margin-bottom: 25px;
	}
	.group-img:after {
		left: 52%;
	}
	body form.cart_total p.submit {
		text-align: center;
	}
	body form.cart_confirm p.submit {
		text-align: center;
	}
}

@media screen and (max-width: 520px) {
.under-table-select select {
    width: 70px;
}
.cart-block-btn ul {
	flex-wrap: wrap;
	justify-content: center;
}
.cart-block-btn ul li {
	width: 100%;
	box-sizing: border-box;
	max-width: 280px;
	margin: 0 auto;
}
.cart-block-btn ul li a {
	width: 100%;
}
}