/* *******************************************************************************
-------------------------------------------------------------
■ PC
-------------------------------------------------------------
 1. link
 ├ 1-1. content text link
 ├ 1-2. tel link
 └ 1-3. side link 
 2. title (h2,h3,h4)
 ├ 2-1. h2
 ├ 2-2. h3
 └ 2-3. h4 
 3. bt
 4. base template
 5. SNS
 6. table
 ├ 6-1. default
 ├ 6-3. table01
 ├ 6-3. table02 
 └ 6-4. hours 
 7. news
 ├ 7-1. default
 └ 7-2. title change
 8. 汎用プロパティ
 ├ 8-1. float
 ├ 8-2. margin
 ├ 8-3. text-align
 ├ 8-4. 画像の配置
 ├ 8-5. 画像の装飾
 ├ 8-6. rollover（透過）
 └ 8-7. pc sp change
 9. other
 ├ 9-1. before-after
 ├ 9-2. list
 ├ 9-3. flow
 └ 9-4. qa
 10. MAP
 11. full
 12. inquiry
 13. singlebox
 ├ 13-1. 2 column
 ├ 13-2. 3 column
 └ 13-3. 4 column
 14. コンテンツ非表示

-------------------------------------------------------------  
■ @media screen and (max-width: 1000px)
-------------------------------------------------------------
 11. full

-------------------------------------------------------------  
■ @media screen and (max-width: 767px)
-------------------------------------------------------------
 1. link
 ├ 1-2. tel link
 └ 1-3. side link 
 3. bt
 4. base template
 6. table
 └ 6-4. hours 
 9. other
 └ 9-1. before-after
 10. MAP
 11. full
 13. singlebox
 └ 13-4. common column

******************************************************************************* */
/* ----------------------------------------------------------
■ PC
----------------------------------------------------------- */


/* =====================================
 1. link
=====================================*/
a:focus, *:focus { outline:none; }
/* 1-1. content text link -------------------------- */
.link a { text-decoration: underline; }

/* 1-2. tel link -------------------------- */
a[href^="tel:"] {
	pointer-events: none;
	cursor:text;
}
button:hover, html input[type=button]:hover, input[type=reset]:hover, input[type=submit]:hover {
    background-color: #F19500;
    color: #fff;
}

button, html input[type=button], input[type=reset], input[type=submit] {
    background-color: #FAF2E1;
    border: #ccc 2px solid;
    border-radius: 10px;
}

/* 1-1. content text link -------------------------- */
.link a { text-decoration: underline; }

/* 1-2. tel link -------------------------- */
a[href^="tel:"] {
	pointer-events: none;
	cursor:text;
}

/* 1-3. side link -------------------------- */
#sidecontact{
  display: block;
  position: fixed;
  bottom: 40%;
  z-index: 1000;
}
#sidecontact.rightContent{
  right:0;
}

/* =====================================
 2. title (h2,h3,h4)
===================================== */
/* 2-1. h2 -------------------------- */
.gnv_tmp_h2_bg {
	border-bottom: 1px solid #ededed;
	border-top: 3px solid #000;
	width: 100%;
}
.gnv_tmp_h2_bg h2 {
	padding: 10px 15px;
	font-size: 120%;
}
.static #content h2.titleBg,
h2.titleBg {
	background: none;
    border-left: none !important;
	border-bottom: 1px solid #ededed;
	border-top: 3px solid #000;
	padding: 10px 15px;
	font-size: 120%;
}

/* 2-2. h3 -------------------------- */
.gnv_tmp_h3_bg {
	border-radius: 6px;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
	padding: 10px;
	background:#F9D786;
	margin-bottom: 25px !important;
	margin-top: 80px;
}
.gnv_tmp_h3_bg h3 {
	color: #4D3926;
	border-left: 3px solid #FBF7F7;
	padding: 0 0 0 20px;
	font-size: 140%;
}

/* 2-3. h4 -------------------------- */
.gnv_tmp_h4_bg {
	position: relative;
	padding: 10px 5px 5px 30px;
	border-bottom: 2px solid #f19500;
	font-weight: normal;
	color: #078FDA;
	font-size: 130%;
	margin-bottom: 25px !important;
        text-align: left;
}

h4 {
    font-weight: normal;
}

h5 {
    color: #4d3926;
    border-left: 3px solid #078FDA;
    padding-left: 10px;
    margin-bottom: 15px;
    text-align: left;
}
.gnv_tmp_h4_bg:before {
	content: "";
	position: absolute;
	background: #078FDA;
	top: 19px;
	left: 0;
	height: 15px;
	width: 15px;
	border-radius: 50%;
}
.gnv_tmp_h4_bg {
    font-size: 120%;
    padding-left: 20px;
}
/* h4 reset */
.b_01 .gnv_tmp_h4_bg,
.b_02 .gnv_tmp_h4_bg {
	margin-bottom: 0;
}

/* =====================================
 3. bt
===================================== */
.gnv_tmp_bt a {
	line-height: 1.4;
	display: inline-block;
	padding: 10px 20px;
	text-align: center;
	border-radius: 6px;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
	background: none #ededed;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(1.00, #ededed), color-stop(0.00, #fff));
	background: -webkit-linear-gradient(top, #fff 0%, #ededed 100%);
	background: -moz-linear-gradient(top, #fff 0%, #ededed 100%);
	background: -o-linear-gradient(top, #fff 0%, #ededed 100%);
	background: -ms-linear-gradient(top, #fff 0%, #ededed 100%);
	background: linear-gradient(top, #fff 0%, #ededed 100%);
	-webkit-box-shadow: 3px 3px 5px 0 #ccc;
	-moz-box-shadow: 3px 3px 5px 0 #ccc;
	box-shadow: 3px 3px 5px 0 #ccc;
	text-decoration: none;
}

/* btサイズ指定の場合 */
.gnv_tmp_detail a {
	width: 20%;
	float: left;
}

/* =====================================
 4. base template
===================================== */
.text_box {
	float: right;
	width: 67%;
}
.b_11_2_in span img,
.b_11 .b_11_in span img {
	margin: 0 1em 1em 0;
}

.b_11 .b_11_in span img {
    float: right;
    width: 40%;
    margin: 0 0 10px 20px !important;
}

/* =====================================
 6. table
===================================== */
/* 6-1. default -------------------------- */
.b_06 table td,
.b_06 table th {
    border: 1px solid #CCCCCC;
}
.b_06_item {
    background: none repeat scroll 0 0 #EEEEEE;
    width: 30%;
}

/* 6-2. table01 -------------------------- */
table.gnv_tmp_table01 {
	margin-bottom: 1.5em;
    background: #FFFFFF;
	width: 100%;
}
table.gnv_tmp_table01 th,
table.gnv_tmp_table01 td {
    padding: 5px;
    text-align: left;
}
table.gnv_tmp_table01 thead th {
    background: #ddd;
    border-top: 1px dotted #ccc;
}
table.gnv_tmp_table01 th {
    background: #efefef;
    border-top: 1px dotted #ccc;
    border-bottom: 1px dotted #ccc;
}
table.gnv_tmp_table01 td {
    background: #FFFFFF;
    border-bottom: 1px dotted #ccc;
    border-top: 1px dotted #ccc;
}
/* 6-3. table02 -------------------------- */
table.gnv_tmp_table02 {
	margin-bottom: 1.5em;
	width: 100%;
}
table.gnv_tmp_table02 th,
table.gnv_tmp_table02 td {
    padding: 5px;
    text-align: left;
}
table.gnv_tmp_table02 thead th {
    background: #FAF2E1;
    border-top: 1px solid #F19500;
    border-bottom: 1px solid #F19500;
}
table.gnv_tmp_table02 th {
    border-bottom: 1px solid #ccc;
    border-top: 1px solid #ccc;
}
table.gnv_tmp_table02 td {
    border-bottom: 1px solid #ccc;
    border-top: 1px solid #ccc;
}


/* 6-4. hours -------------------------- */
table.gnv_tmp_hours th,
table.gnv_tmp_hours td {
    text-align: center !important;
}



/*table02*/
.table02 th,.table02 td {
	background:none;
	border:none !important
}

.table02 td {
    border-bottom: 1px solid #ccc !important;
}

.table02 th {
    border-bottom: 1px solid #F19601 !important;
}

/* =====================================
 7. news
===================================== */
/* 7-1. default -------------------------- */
#news h2,.static #content h2.titleBg, h2.titleBg {
	display: block;
	padding: 10px;
	border-top: 3px solid #f19500;
	background: none;
	border-bottom: #ccc 1px solid;
	margin: 0 0 1em !important;
	color: #4d3926;
	border-left: none;
}

.static #content h2.titleBg, h2.titleBg {
    font-size: 120%;      margin-top: 30px !important;      border-left: none;
}
#news dt .newsNew {
    background: #f10000;
    color: #fff;
    border-radius: 2px;      
    -webkit-border-radius: 2px;      
    -moz-border-radius: 2px;
    line-height: 1;
    padding: 2px 5px;
    margin-top: 5px;
    display: inline-block;
    vertical-align: top;
}
/* 7-2. title change -------------------------- */
.gnv_tmp_008_title_block h2.gnv_tmp_news_title {
	padding: 10px;
	font-size: 130%;
	border-bottom: 1px solid #ededed;
    margin-bottom: 1em;
}

/* =====================================
8. 汎用プロパティ
===================================== */
/* 8-1. float -------------------------- */
.fl { float: left;}
.fr { float: right;}

/* 8-2. margin -------------------------- */
.m00 { margin: 0 !important;}
.m05 { margin: 5px !important;}
.m10 { margin: 10px !important;}
.m15 { margin: 15px !important;}
.m20 { margin: 20px !important;}
.m25 { margin: 25px !important;}
.m30 { margin: 30px !important;}
.m35 { margin: 35px !important;}
.m40 { margin: 40px !important;}
.m45 { margin: 45px !important;}
.m50 { margin: 50px !important;}

.mt00 { margin-top: 0 !important;}
.mt05 { margin-top: 5px !important;}
.mt10 { margin-top: 10px !important;}
.mt15 { margin-top: 15px !important;}
.mt20 { margin-top: 20px !important;}
.mt25 { margin-top: 25px !important;}
.mt30 { margin-top: 30px !important;}
.mt35 { margin-top: 35px !important;}
.mt40 { margin-top: 40px !important;}
.mt45 { margin-top: 45px !important;}
.mt50 { margin-top: 50px !important;}

.mr00 { margin-right: 0 !important;}
.mr05 { margin-right: 5px !important;}
.mr10 { margin-right: 10px !important;}
.mr15 { margin-right: 15px !important;}
.mr20 { margin-right: 20px !important;}
.mr25 { margin-right: 25px !important;}
.mr30 { margin-right: 30px !important;}
.mr35 { margin-right: 35px !important;}
.mr40 { margin-right: 40px !important;}
.mr45 { margin-right: 45px !important;}
.mr50 { margin-right: 50px !important;}

.mb00 { margin-bottom: 0 !important; text-align: center;}
.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;}
.mb45 { margin-bottom: 45px !important;}
.mb50 { margin-bottom: 50px !important;}

.ml00 { margin-left: 0 !important;}
.ml05 { margin-left: 5px !important;}
.ml10 { margin-left: 10px !important;}
.ml15 { margin-left: 15px !important;}
.ml20 { margin-left: 20px !important;}
.ml25 { margin-left: 25px !important;}
.ml30 { margin-left: 30px !important;}
.ml35 { margin-left: 35px !important;}
.ml40 { margin-left: 40px !important;}
.ml45 { margin-left: 45px !important;}
.ml50 { margin-left: 50px !important;}

/* 8-3. text-align -------------------------- */
.tal { text-align:left;}
.tac { text-align:center;}
.tar { text-align:right;}

/* 8-4. 画像の配置 -------------------------- */
/* 基本設定 */
/* right 
.b_11_2_in span img,
.b_11 .b_11_in span img {
	float: right;
	margin: 0 0 20px 20px;
}*/

/* 個別設定 */
/* left */
.img_l span img {
    float: left !important;
	margin: 0 20px 20px 0 !important;
}

/* right */
.img_r span img {
    float: right !important;
	margin: 0 0 20px 20px !important;
}

/* 8-5. 画像の装飾 -------------------------- */
/* 角丸 */
.image img,
.text_image img,
.gnv_tmp_style img {
	border-radius: 6px;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
}

/* 8-6. rollover（透過） -------------------------- */
.rollover:hover {
	opacity: 0.8;
	filter: alpha(opacity=80);
	-ms-filter: "alpha( opacity=80 )";
}

/* 8-7. pc sp change -------------------------- */
.pc {
	display: block !important;
}

.pc2 {
    display: inline-block !important;
}
.sp {
	display: none !important;
}
@media screen and (max-width: 767px) {
.pc {
	display: none !important;
}
.sp {
	display: block !important;
}
}

/* =====================================
9. other
===================================== */
/* 9-1. before-after -------------------------- */
.ba_box {
	background: url(/asset/ba_ar.png) no-repeat center 55%;
	display: table;
	width: 100%;
}
.ba_box div.column_l,
.ba_box div.column_r {
	display: table-cell;
	width: 30%;
}
.ba_box div.column_l span,
.ba_box div.column_r span {
	width: 100%;
}
.ba_box div.column_l p,
.ba_box div.column_r p,
.ba_box div.column_l span img,
.ba_box div.column_r span img {
	width: 95% !important;
	margin: 0 auto !important;
}
.ba_box .column_r, .ba_box .column_l {
	text-align: center;
	color: #B69440;
    font-size: 120%;
    font-weight: bold;
}
.ba_box .column_r span {
	text-align: right;
}

/* 9-2. list -------------------------- */
/* 通常リスト 01 */
.ic_01 {
	width: 100%;
}
.ic_01 .clearfix {
	padding: 5px 5px 5px 0px;
}
.ic_01 span {
	position: relative;
	line-height: 1;
	padding-left: 15px;
}
.ic_01 span:before {
	content: "";
	position: absolute;
	background: #F19500;
	top: 8px;
	left: 0;
	height: 7px;
	width: 7px;
	border-radius: 50%;
	
}
/* ul */
.ic_01 ul {
	margin: 25px;
}
.ic_01 li {
	position: relative;
	padding: 5px 5px 5px 0;
}
.ic_01 li:before {
	content: "";
	position: absolute;
	background: #000;
	top: 14px;
	left: -16px;
	height: 7px;
	width: 7px;
	border-radius: 50%;
	
}

/* 通常リスト 02 */
.ic_02 .clearfix {
	padding: 5px 5px 5px 35px;
}
.ic_02 .clearfix span {
	position: relative;
	line-height: 1;
}
.ic_02 span:before{
    content:"\00a0";
    display: block;
    border: solid 9px #F19500;
    height: 0;
    width: 0;
    position: absolute;
    left: -29px;
    top: 2px;
} 
.ic_02 span:after{
    content:"\00a0";
    display:block;
    width: 4px;
    height: 7px; 
    border: solid #fff;
    border-width: 0 2px 2px 0;
    position:absolute;
    left: -23px;
    top: 6px;
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    transform: rotate(45deg);
}
/* ul */
.ic_02 ul {
	margin: 35px;
}
.ic_02 li {
	position: relative;
	padding: 5px 5px 5px 0;
}
.ic_02 li:before {
    content:"\00a0";
    display: block;
    border: solid 9px #000;
    height: 0;
    width: 0;
    position: absolute;
    left: -29px;
    top: 10px;	
}
.ic_02 li:after{
    content:"\00a0";
    display:block;
    width: 4px;
    height: 7px; 
    border: solid #fff;
    border-width: 0 2px 2px 0;
    position:absolute;
    left: -23px;
    top: 14px;
    margin-top: 0;  
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    transform: rotate(45deg);
}

/* 矢印リスト 01 */
.ic_arrow_01 .clearfix {
	padding: 5px 5px 5px 25px;
}
.ic_arrow_01 span {
	position: relative;
}
.ic_arrow_01 span:before {
	display: block;
	content: "";
	position: absolute;
    top: 5px;
	left: -15px;
	width: 0;
	height: 0;
	border: 5px solid transparent;
	border-left: 5px solid #000;
}
.ic_arrow_01 span:hover:before {
	left: -12px;
}
/* ul */
.ic_arrow_01 ul {
	margin: 25px;
}
.ic_arrow_01 li {
	position: relative;
	padding: 5px 5px 5px 0;
}
.ic_arrow_01 li:before {
	display: block;
	content: "";
	position: absolute;
    top: 13px;
	left: -15px;
	width: 0;
	height: 0;
	border: 5px solid transparent;
	border-left: 5px solid #000;
}
.ic_arrow_01 li:hover:before {
	left: -12px;
}

/* 矢印リスト 02 */
.ic_arrow_02 .clearfix {
	padding: 5px 5px 5px 30px;
}
.ic_arrow_02 span {
	position: relative;
}
.ic_arrow_02 span:before {
	display: block;
	content: "";
	position: absolute;
    top: 2px;
	left: -25px;
	width: 16px;
	height: 16px;
	border-radius: 50%;
	background: #999;
}
.ic_arrow_02 span:after {
	display: block;
	content: "";
	position: absolute;
    top: 5px;
	left: -19px;
	width: 0;
	height: 0;
	border: 5px solid transparent;
	border-left: 5px solid #fff;
}
.ic_arrow_02 span:hover:before {
	left: -22px;
}
.ic_arrow_02 span:hover:after {
	left: -16px;
}

/* ul */
.ic_arrow_02 ul {
	margin: 30px;
}
.ic_arrow_02 li {
	position: relative;
	padding: 5px 5px 5px 0;
}
.ic_arrow_02 li:before {
	display: block;
	content: "";
	position: absolute;
    top: 10px;
	left: -25px;
	width: 16px;
	height: 16px;
	border-radius: 50%;
	background: #999;
}
.ic_arrow_02 li:after {
	display: block;
	content: "";
	position: absolute;
    top: 13px;
	left: -19px;
	width: 0;
	height: 0;
	border: 5px solid transparent;
	border-left: 5px solid #fff;
}
.ic_arrow_02 li:hover:before {
	left: -22px;
}
.ic_arrow_02 li:hover:after {
	left: -16px;
}

/* 9-3. flow -------------------------- */
img.gnv_tmp_flow_arrow_01 {
	margin: 0 auto;
}
img.gnv_tmp_flow_arrow_02 {
	margin: 10px auto 0;
}

/* 9-4. qa -------------------------- */
.gnv_tmp_qa_q {
	border-left: 3px solid #333;
	margin-bottom: 10px;
	padding: 10px;
	display: table;
}
.gnv_tmp_qa_q span.tit {
	font-size: 200%;
	font-weight: bold;
	color: #333;
	padding-right: 20px;
	display: table-cell;
	width: 30px;
}
.gnv_tmp_qa_a {
	border-left: 3px solid #ccc;
	margin-bottom: 10px;
	padding: 10px;
	display: table;
}
.gnv_tmp_qa_a span.tit {
	font-size: 200%;
	font-weight: bold;
	color: #ccc;
	padding-right: 20px;
	display: table-cell;
	width: 30px;
}
.gnv_tmp_qa_a p,
.gnv_tmp_qa_q p {
	display: table-cell;
	width: 100%;
	vertical-align: top;
	padding-top: 15px;
}
 
/* =====================================
 10. MAP
===================================== */
.gnv_tmp_map {
  position: relative;
  width: 100%;
  padding-top: 40%;
}
.gnv_tmp_map iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
  border: #ccc 1px solid;
  box-sizing: border-box;
}

/* =====================================
 11. full
===================================== */
.content_width_full .parts {
	background: #efefef;
}

/* =====================================
 12. inquiry
===================================== */
/*
■問合せタイトルを付けたい場合
1）下記のコメントアウトを削除する
2）パーツ内の「テキスト」でタイトルを「テキスト」に入力する
 */ 
/*
.inquiry #content .contentArea {
	margin-top: 0;
}
.inquiry #content .contentArea {
	margin: 0 0 4em;
}
.inquiry #content .btBox {
	margin: 1em 0 0;
}
body#inquiryBody .message {
	display: none;
}
body#inquiryBody .inquiry_textbox {
	margin-bottom: 20px;
}
body#inquiryBody .inquiry_textbox:first-child {
    border-bottom: 1px solid #dedede;
	background: url(/asset/h2_bg.gif) no-repeat bottom left;
	font-size: 130%;
    line-height: 1.2;
    padding: 15px;
	border-radius: 0;
    position: relative;
}
.inquiryFormTable {
	border: none;
}
*/
/* =====================================
 13. singlebox
===================================== */
/* 2-1. 2 column -------------------------- */
.singlebox2 {
    float: left;
    margin-left: 0;
    margin-right: 0;
    padding: 10px;
    width: 47% !important;
}
/* 2-2. 3 column -------------------------- */
.singlebox3 {
    float: left;
    margin-left: 0;
    margin-right: 0;
    padding: 10px;
    width: 30% !important;
}
/* 2-3. 4 column -------------------------- */
.singlebox4 {
    float: left;
    margin-left: 0;
    margin-right: 0;
    padding: 10px;
    width: 22% !important;
}



/*追記*/
.top #mainimage {
    margin-top: 220px;
    width: 100%;   
    min-width: 1000px;   overflow: hidden;
}

.top #mainimage p.pc {
    width: 1000px;   margin: 0 auto;
}

.top #mainimage p.pc img {
    display: block;   
    margin: 0 -500px;
    width: 2000px;
}

.bg1 {
    background-color: #f9f4eb;
    margin-top: 5px;
}

.top .link_box02 {
    background: none;
}

.link_box02_in.clearfix {
    line-height: 1.3;
    color: #4d3926;
    padding-top: 49px;
    width: 100%;
    margin: 0;
    height: 100px;
}

p.lead_txtb {
    font-size: 120%;
    font-weight: bold;
    margin-bottom: 10px !important;
}

.top .link_box02_in .btn_style {
    width: 25%;
    float: right;
}

.btn_style a {
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#ffffff+0,ffffff+100 */  background: #ffffff; /* Old browsers */  background: -moz-linear-gradient(top,  #ffffff 0%, #ffffff 100%); /* FF3.6+ */  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ffffff), color-stop(100%,#ffffff)); /* Chrome,Safari4+ */  background: -webkit-linear-gradient(top,  #ffffff 0%,#ffffff 100%); /* Chrome10+,Safari5.1+ */  background: -o-linear-gradient(top,  #ffffff 0%,#ffffff 100%); /* Opera 11.10+ */  background: -ms-linear-gradient(top,  #ffffff 0%,#ffffff 100%); /* IE10+ */  background: linear-gradient(to bottom,  #ffffff 0%,#ffffff 100%); /* W3C */  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#ffffff',GradientType=0 ); /* IE6-9 */;
 border-radius: 10px;
 border: 1px solid #ccc;
 
      -webkit-box-shadow: none;      
      -moz-box-shadow: none;      
      box-shadow: none;
      position: relative;
      display: block;
      line-height: 1.4;
      color: #4d3926;
      padding: 15px 10px  15px 21px;
}

.btn_style a:before {
    content: '';      
    height: 9px;      
    width: 9px;      display: block;      
    border: 2px solid #f19705;      border-left-width: 0;      border-top-width: 0;      transform: rotate(-45deg);      -webkit-transform: rotate(-45deg);      -moz-transform: rotate(-45deg);      -o-transform: rotate(-45deg);      -ms-transform: rotate(-45deg);      position: absolute;      
    top: 41%; /* IE8以下とAndroid4.3以下用フォールバック */                
    left: 10px;
    line-height: 1.4;
    display: inline-block;
    box-sizing: border-box;
}

.top .link_box02_in .btn_style a {
    line-height: 1.4;
    height: auto;
    width: auto;
    margin: -10px auto 0;
}

.btn_style a:hover {
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#faf2e1+0,faf2e1+100 */  background: #faf2e1; /* Old browsers */  background: -moz-linear-gradient(top,  #faf2e1 0%, #faf2e1 100%); /* FF3.6+ */  background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#faf2e1), color-stop(100%,#faf2e1)); /* Chrome,Safari4+ */  background: -webkit-linear-gradient(top,  #faf2e1 0%,#faf2e1 100%); /* Chrome10+,Safari5.1+ */  background: -o-linear-gradient(top,  #faf2e1 0%,#faf2e1 100%); /* Opera 11.10+ */  background: -ms-linear-gradient(top,  #faf2e1 0%,#faf2e1 100%); /* IE10+ */  background: linear-gradient(to bottom,  #faf2e1 0%,#faf2e1 100%); /* W3C */  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#faf2e1', endColorstr='#faf2e1',GradientType=0 ); /* IE6-9 */;
}

#news .newsBt {
    font-size: 80%;
    top: 17px;
    right: 0;
}

#news dd a:hover {
    text-decoration: none;
}

.top .contents01 .col_box .btn_style a {
    padding: 15px 10px 15px 21px;
    width: 230px;
    float: none;
    box-sizing: border-box;
}

.top .contents01 .col_box .col_img {
    width: 45%;
    max-width: 320px;
}

.top .contents01 .col_box .col_content {
    width: 52%;
}

p.lead_txt {
    font-size: 120%;
    font-weight: bold;
    margin-bottom: 10px !important;
    padding-bottom: 0 !im;
}

.top .contents01 .col_box .col_content p {
    margin-bottom: 0 !important;
}

.top .contents01 {
    background: url(/asset/top_bg01.png) no-repeat center top;
    height: 630px;
    background-size: cover;
}
.top .contents02 .menu_box li .menu_effect_box img {
    border-radius: 10px;
}
.bg2 {
    background: url(/asset/top_bg02.png) center top repeat;
    margin-bottom: 0;
}

.bg2 .gnv_tmp_width_1000 {
    position: relative;
    table-layout: inherit;
    height: auto;
    display: block;
    margin-top: 80px;
}

.bg2 .gnv_tmp_width_1000:before {
    width: 538px;
    content: "";
    display: block;
    background: url(/asset/top_img03.png) left bottom no-repeat;
    top: -30px;
    position: absolute;
    height: 110%; /* IE8以下とAndroid4.3以下用フォールバック */     
    height: -webkit-calc(100% + 30px);     
    height: calc(100% + 30px);
    background-size: contain;
}

.bg2 .link_box02 {
    padding-left: 50%;
    box-sizing: border-box;
}

.top .bg2 .link_box02_in {
    height: auto;
    width: inherit !important;
    padding-bottom: 80px;
    padding-top: 57px;
}

.top .bg2 .link_box02_in .lead_txt {
    padding-top: 10px;
    width: 100%;
    padding-left: 60px;
    padding-right: 60px;
    font-size: 130%;
    float: none;
    height: auto;
    line-height: 1.6;
    box-sizing: border-box;
}

.top .bg2 .link_box02_in .btn_style {
    width: 250px;
    float: none;
    height: auto;
}

.top .bg2 .link_box02_in .btn_style a {
    margin: 0;
}

.top .link_box02_in .lead_txt {
    margin: 0;
    line-height: 1.6;
}


.top .contents01 .col_box .col_content {
    width: 53%;
}

.top .contents02 .menu_box li {
    margin: 0 2% 13px 0;
}

.top .contents02 .menu_box li:nth-child(3n) {
    margin-right: 0;
}

/* =====================================
 14. コンテンツ非表示
===================================== */
/* TOPのみ解除 上書き（解除しない） */
.top .hikoukai {
    display: none !important;
}
.top #drag-temp-pre-content .parts.hikoukai {
    background: none repeat scroll 0 0 #555;
    border: 5px solid #777;
    display: block !important;
    padding: 20px 0;
}

/* ----------------------------------------------------------
■ @media screen and (max-width: 1000px)
----------------------------------------------------------- */
@media screen and (max-width: 1000px) {
/* =====================================
 11. full
===================================== */
.top #mainimage {
    width: 100%;   
    min-width: 100%;   overflow: hidden;
}

.top #mainimage p.pc {
    width: 100%;   margin: 0 auto;
}

.top #mainimage p.pc img {
    display: block;   
    margin: 0 -82%;
    width: 190%;
}

.content_width_full.under .contents_block {
	margin: 0;
}

.content_width_full .parts {
	background: none;
}



.top .link_box02_in .btn_style {
    float: none;
}

.top .link_box02_in .lead_txt {
    float: none;
}

.link_box02_in.clearfix {
    height: auto;
    padding-bottom: 30px;
    padding-top: 0px;
}

.header_right_box img.pc_tel {
    width: 90%;
}

.top .contents02 .menu_box li {
    width: 32%;
}

.top .contents02 .menu_box {
    padding: 0 20px;
    box-sizing: border-box;
}

.bg2 .gnv_tmp_width_1000:before {
    width: 40%;                  
    background: url(/asset/top_img03.png) left bottom no-repeat;                                    
    background-size: contain;
    top: -10px;
    height: 110%;      
    height: -webkit-calc(100% + 10px);      
    height: calc(100% + 10px);      background-size: contain;
}

.top .bg2 .link_box02_in {
    padding-top: 10px;
    padding-bottom: 10px;
}

.top .bg2 .link_box02_in .lead_txt {
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 0px;
}

.bg2 .link_box02 {
    padding-left: 45%;
}
.top .link_box02_in .btn_style {
    width: 300px;
}
}

/* ----------------------------------------------------------
■ @media screen and (max-width: 767px)
----------------------------------------------------------- */
@media screen and (max-width: 767px) {
/* =====================================
 1. link
=====================================*/
/* 1-2. tel link -------------------------- */
a[href^="tel:"] {
	pointer-events: auto;
	cursor:pointer;
}
/* 1-3. side link -------------------------- */
#sidecontact{
    display: none;
}

/* =====================================
 3. bt
===================================== */
.gnv_tmp_detail a {
	width: auto;
	margin: 0 auto;
	float: none;
}

/* =====================================
 4. base template
===================================== */
.text_box {
	float: right;
	width: 67%;
}
.b_11_2_in span img,
.b_11 .b_11_in span img {
	margin: 0 1em 1em 0;
}

/* =====================================
 6. table
===================================== */
/* 6-4. hours -------------------------- */
table.gnv_tmp_hours th,
table.gnv_tmp_hours td {
	font-size: 70%;
}

/* =====================================
9. other
===================================== */
/* 9-1. before-after -------------------------- */
.ba_box {
	background: url(/asset/ba_ar_sp.png) no-repeat center 50%;
	margin: 0 auto 5em !important;
}
.ba_box div.column_l,
.ba_box div.column_r {
	width: 100%;
	display: block;
}
.ba_box .column_l {
	margin-bottom: 2em!important;
}
.ba_box .column_r span {
	text-align: center;
}

/* =====================================
 10. MAP
===================================== */
.gnv_tmp_map {
  padding-top: 70%;
}
.gnv_tmp_map iframe {
  right: 10%;
  width: 80% !important;
}
/* =====================================
 11. full
===================================== */
.content_width_full .b_10.b_10_column3 div.column_blank,
.content_width_full .b_11_2.b_11_2_column3 div.column_blank,
.content_width_full .b_11.b_11_column3 div.column_blank,
.content_width_full .b_11_3.b_11_3_column3 div.column_blank {
    display: block !important;
}

/* =====================================
 13. singlebox
===================================== */
/* 13-4. common column -------------------------- */
.singlebox2,
.singlebox3,
.singlebox4 {
    width: 100% !important;
    padding: 0;
}
.singlebox2 .b_11_2_in,
.singlebox3 .b_11_2_in,
.singlebox4 .b_11_2_in {
    padding: 5px;
}
.singlebox2 .b_11_2_in span img,
.singlebox3 .b_11_2_in span img,
.singlebox4 .b_11_2_in span img {
    margin: 0;
}




.gnv_tmp_h3_bg h3 {
    font-size: 120%;
    padding-left: 10px;
}

.gnv_tmp_h4_bg:before {
    width: 12px;
    height: 12px;
    top: 19px;
}

.gnv_tmp_h3_bg {
    margin-top: 40px;
}


.b_11 .b_11_in span img {
    float: none;
    width: 100%;
    margin: 0 0 15px 0 !important;
}
.top #mainimage {
    margin-top: 0;
}
.top_h2 {
    font-size: 23px !important;
}
.top .contents01_in {
    height: auto;
}

.top .contents01_inner_box {
    position: inherit;
    height: auto;
    padding-bottom: 20px;
}

.top .contents01 {
    height: auto;
}

.bg2 .gnv_tmp_width_1000 {
    margin-top: 30px;
}
.top .bg2 .link_box02_in .lead_txt {
    font-size: 110%;
}


.top .bg2 .link_box02_in .lead_txt {
    font-size: 110%;
}

.top .contents02 .menu_box li {
    float: none;
    max-width: 345px;
    width: 100%;
    margin-right: auto;
    margin-left: auto;
}

.top .contents02 .menu_box {
}

.top .contents02 .menu_box li:nth-child(3n) {
    margin-left: auto;
    margin-right: auto;
}

.bg2 .gnv_tmp_width_1000:before {
    bottom: 0;
    width: 100%;
    height: 65% !important;
    background: url(/asset/top_img03.png) center bottom no-repeat;
    background-size: contain;
    bottom: 0;
    position: absolute;
    top: inherit;
}

.bg2 .gnv_tmp_width_1000 {
    padding-bottom: 50%;
    position: relative;
}

.bg2 .link_box02 {
    padding-left: 0;
}
.top .contents01 .col_box .btn_style a {
    padding: 15px 10px 15px 25px;
    width: inherit;
    display: inline-block;
}
.top .link_box02_in .btn_style a {
    display: block;
    margin-left: auto !important;
    margin-right: auto !important;
    box-sizing: border-box;
    max-width: inherit;
    width: 80%;
}

.top .link_box02_in .btn_style {
    width: auto;
}

}
.adult_menu{
    display:inline-block;
    width: 24%;
    padding-left: 2%;
    box-sizing: border-box;
    vertical-align:top;
}

@media screen and (max-width: 550px){
.bg2 .gnv_tmp_width_1000:before {
    height: 45% !important;
}
.header_right_box img,
.header_right_box img.pc_tel{
width:115%;
}
}
@media screen and (max-width: 767px){
.adult_menu{
    padding-left: 2%;
    display:block;
    width: inherit;
}
}

@media screen and (max-width: 320px){
ul.header_right_box{
   width:35%;
}
.bg2 .gnv_tmp_width_1000:before {
    height: 45% !important;
}
}
.top_h2_wrap {
    padding: 0px 20px 20px 20px;
    text-align:center
}
.top_h2{
    text-align:center;
    font-size:30px;
    padding: 0;
    color: #F19500;
    max-width: 1000px;
    margin: 0 auto;
    border-bottom: dotted #F19500 3px;
    display: inline-block;
    text-align: center;
    width: inherit;
}

@media screen and (max-width: 387px){
.header_block h1{
width: 54% !important;
padding-top: 3%;
}
ul.header_right_box{
   width:38% !important;
}
}


/* ヘッダー追加 */
.top #mainimage {
    margin-top: 0;
    padding: 25px 0;
}
@media screen and (max-width: 767px) {

.top #mainimage {
    margin-top: 0;
    padding: 15px 0;
}
}

.new_container {
	max-width: 1120px;
	margin: 0 auto;
	padding: 0 20px;
box-sizing: border-box;
}
#header {
    position: relative;
    top: 0;
    left: 0;
    z-index: 200;
    width: 100%;
    -moz-transition-duration: 0.7s;
    -o-transition-duration: 0.7s;
    -webkit-transition-duration: 0.7s;
    transition-duration: 0.7s;
    background: #E4F2F9;
    border-bottom: 0;
    box-sizing: border-box;
}
.under #header {
    position: fixed;
    z-index: 1000;
    top: 0;
    left: 0;
    width: 100%;
    -moz-transition-duration: 0.7s;
    -o-transition-duration: 0.7s;
    -webkit-transition-duration: 0.7s;
    transition-duration: 0.7s;
    background: #E4F2F9;
    border-bottom: 0;
    box-sizing: border-box;
}


.home #header {
	background: none;
}

#header .wrap {
	margin: 0 !important;
	padding: 0;
	max-width: inherit;
}


/* logo */

.header_top {
    margin-bottom: 0;
    padding: 38px 0 32px;
}

#header h1 {
    width: 335px !important;
    margin: 0;
    padding: 0 !important;
    max-width: 335px;
    float: left;
}

.header_tel {
    float: right;
    margin-right: 0;
    margin-top: 0;
}

#header h1 img {
	width: 100%;
}

#header h1 a:hover {
	text-decoration: none;
}


/* header right box */

#header .right {
	width: 178px !important;
	line-height: 0;
}

#header .right .right_box > div {
	margin-top: 1px;
}

#header .right img {
	width: 100%;
	max-width: 100%;
}


/* gnav */

#header .header_menu {
    float: none;
    margin-right: 0px;
    max-width: 100% !important;
    height: auto;
    padding: 0 !important;
}

#header .header_menu .g_nav {
	display: block;
}

#header .header_menu .g_nav > li {
	vertical-align: middle;
	border-left: 0;
	position: relative;
}

#header .header_menu .g_nav > li:first-child {
	position: relative;
}

#header .header_menu .g_nav > li > a,
#header .header_menu .g_nav > li > span {
    align-items: center;
    text-align: center !important;
    vertical-align: middle;
    color: #5C5C5C;
    line-height: 37px;
    cursor: pointer;
    font-size: 16px;
    letter-spacing: 0.0em;
    height: 37px;
    padding: 0 5px;
    -moz-transition-duration: 0.7s;
    -o-transition-duration: 0.7s;
    -webkit-transition-duration: 0.7s;
    transition-duration: 0.7s;
    width: auto;
    box-sizing: border-box;
    border-left: 0;
    margin-right: 0px;
    background-position: left bottom;
    font-family: "秀英丸ゴシック L", "Shuei MaruGo L";
}

#header .header_menu .g_nav > li > a > span,
#header .header_menu .g_nav > li > span > span {
	display: block;
	margin: 0 auto;
}

#header .header_menu .g_nav > li > a sub,
#header .header_menu .g_nav > li > span sub {
	line-height: 1.2;
	display: block;
	letter-spacing: 0.15em;
	padding-top: 16px;
	color: #40845C !important;
	font-size: 10px;
}

#header .header_menu .g_nav > li > span:hover + dl,
#header .header_menu .g_nav > li > span ul:hover {
	pointer-events: auto;
	filter: progid: DXImageTransform.Microsoft.Alpha(enabled=false);
	opacity: 1;
}

#header .header_menu .g_nav > li > span:hover {
	position: relative;
}

#header .header_menu .g_nav > li dl {
	pointer-events: none;
	position: absolute;
	top: 68px;
	display: block;
	width: 200px;
	padding: 0px !important;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	background: #fff;
	-moz-transition-duration: 0.6s;
	-o-transition-duration: 0.6s;
	-webkit-transition-duration: 0.6s;
	transition-duration: 0.6s;
	filter: progid: DXImageTransform.Microsoft.Alpha(Opacity=0);
	opacity: 0;
	z-index: 99;
	/* border-radius: 5px; */
	margin-left: -100px;
	left: 50%;
	border-radius: 5px;
}

#header .header_menu .g_nav > li dl dt {
	max-width: 1000px;
	margin: 0 auto 15px;
	font-size: 24px;
	letter-spacing: 3px;
	color: #2d4a81;
	line-height: 1.2;
	font-family: "ヒラギノ角ゴ W6 JIS2004", "Hiragino Kaku Gothic W6 JIS2004";
	display: none;
}

#header .header_menu .g_nav > li dl ul {
	max-width: 1000px;
	margin: 0 auto;
}

#header .header_menu .g_nav > li dl li {
	display: block;
	padding: 0 20px;
	box-sizing: border-box;
	margin-right: 0;
}

#header .header_menu .g_nav > li dl li:hover {
	background: rgba(139, 233, 216, 0.7);
}

#header .header_menu .g_nav > li dl li:last-child {
	margin-right: 0;
}

#header .header_menu .g_nav > li dl li a {
	color: #727272;
	font-size: 15px;
	padding-left: 15px;
	letter-spacing: 0;
	display: block;
	border-bottom: 1px solid #3fcab0;
	padding-top: 13px;
	padding-bottom: 12px;
	text-decoration: none;
	line-height: 1.3;
	font-family: "秀英明朝 L", "Shuei Mincho L";
	text-align: left;
}

#header .header_menu .g_nav > li dl li:last-child a {
	border-bottom: 0;
}

#header .header_menu .g_nav > li dl a:hover {
	opacity: 1;
	text-decoration: none;
}

#header .header_menu .g_nav > li dl:hover {
	pointer-events: auto;
	filter: progid: DXImageTransform.Microsoft.Alpha(enabled=false);
	opacity: 1;
}

#header .header_menu .g_nav > li dl .icon-arrow01:before {
	color: #3fcab0;
	font-size: 12px;
	float: left;
	margin-top: 17px;
}

@media (max-width: 1023px) {
.header_top {
    margin-bottom: 0;
    padding: 25px 0 32px;
}
.header_tel {
    width: 420px;
    margin-top: 6px;
}
#header h1 {
    width: 280px !important;
}
}

@media (max-width: 959px) {

}

@media (min-width: 768px) {
	#header .header_menu .g_nav > li {
position: relative;
    display: inline-block;
    float: none;
    width: 14.8%;
    height: auto;
    border-right:0;
	}
#header .header_menu .g_nav > li.nav01 {
    width: 13.5%;
}
#header .header_menu .g_nav > li.nav04 {
  width: 18.5%;
}
#header .header_menu .g_nav > li.nav05 {
    width:23.5%;
}
	#header .header_menu .g_nav > li:last-child:after {
    position: absolute;
    content: "";
    display: block;
    width: 0px;
    height: 100%;
    right: 0;
    top: 0;
    border-right: 1px dashed #707070;
	}
	#header .header_menu .g_nav > li dl {
		pointer-events: none;
	}
	#header .header_menu .g_nav > li:before {
   position: absolute;
    content: "";
    display: block;
    width: 0;
    height: 100%;
    left: 0;
    top: 0;
    border-right: 1px dashed #707070;
	}
	#header .header_menu .g_nav > li dl:after {
		position: absolute;
		content: "";
		display: block;
		width: 100%;
		height: 15px;
		left: 0;
		top: -12px;
	}
	/*#header .header_menu .g_nav > li > span:hover:before {
		content: "";
		position: absolute;
		bottom: -20px;
		left: -49px;
		display: block;
		width: 72px;
		height: 100px;
		-webkit-transform: rotate(45deg);
		-moz-transform: rotate(45deg);
		-ms-transform: rotate(45deg);
		-o-transform: rotate(45deg);
		transform: rotate(45deg);
		z-index: 9999;
	}
	#header .header_menu .g_nav > li > span:hover:after {
		content: "";
		position: absolute;
		bottom: -20px;
		right: -44px;
		z-index: 2;
		display: block;
		width: 72px;
		height: 100px;
		-webkit-transform: rotate(-45deg);
		-moz-transform: rotate(-45deg);
		-ms-transform: rotate(-45deg);
		-o-transform: rotate(-45deg);
		transform: rotate(-45deg);
		z-index: 999;
	}*/
	#header .header_menu .g_nav {
		    margin-right: 0px;
    display: block;
    font-size: 0;
    letter-spacing: 0;
    line-height: 0;
    text-align: center;
    padding: 0;
    box-sizing: border-box;
    margin-bottom: 25px;
	}
	#header .header_menu .g_nav > li dl:before {
		position: absolute;
		content: "";
		display: block;
		width: 0;
		height: 0;
		border-width: 0px 10px 10px 10px;
		border-style: solid;
		border-color: transparent;
		border-bottom: 10px solid #ffffff;
		top: -10px;
		left: 50%;
		margin-left: -10px;
	}
	#header .header_menu .g_nav > li dl dd {
		border-radius: 10px;
		overflow: hidden;
	}
}


/*@media screen and (max-width: 1060px) and (min-width: 768px) {
	#header .header_menu {
		float: none;
		clear: both;
		width: 100%;
	}
	#header .header_menu .g_nav > li {
		width: 20%;
	}
	#header .header_menu .g_nav > li > a,
	#header .header_menu .g_nav > li > span {
		text-align: center;
		margin-right: 0;
		height: 80px;
	}
	#header .header_menu .g_nav > li dl {
		top: 146px;
	}
}*/

@media screen and (max-width: 767px) {
#header .new_container {
    padding: 0 !important;
}
	#header {
		position: static;
		top: 0 !important;
		border-bottom: 0;
	}
	.header_top {
	    margin-bottom: 0px;
    float: left;
    padding: 0;
	}
	#header h1 {
    margin: 7px 0 0 20px;
    width: 265px !important;
    min-width: 0;
    font-size: 0;
    letter-spacing: 0;
    line-height: 0;
	}
	#header .toggleMenu {
		display: block;
	}
	.toggleMenu {
    float: right;
    width: 40px;
    height: 60px;
    background: none;
    text-align: left;
    color: #fff;
    cursor: pointer;
    margin-right: 0;
    padding: 3px 20px 0 0;
    background: none;
	}
	.menu-trigger,
	.menu-trigger span {
		display: inline-block;
		transition: all .4s;
		box-sizing: border-box;
	}
.menu-trigger {
    position: relative;
    width: 40px;
    height: 24px;
    margin: 7px auto 0;
    text-align: center;
    text-decoration: none !important;
}
	.menu-trigger:after {
	    content: "MENU";
    display: block;
    line-height: 1;
    font-size: 10px;
    letter-spacing: 0.14em;
    font-weight: bold;
    margin-top: 30px;
    color: #FFB24A;
    margin-left: 1px;
    font-family: "秀英丸ゴシック L", "Shuei MaruGo L";
	}
	.menu-trigger span {
		position: absolute;
		left: 0;
		width: 100%;
		    height: 3px;
    background-color: #FFB24A;
	}
	.menu-trigger span:nth-of-type(1) {
		top: 0;
	}
	.menu-trigger span:nth-of-type(2) {
		top: 10px;
	}
	.menu-trigger span:nth-of-type(3) {
		bottom: 0;
	}
	.toggleMenu.active .menu-trigger span:nth-of-type(1) {
		-webkit-transform: translateY(10px) rotate(-45deg);
		transform: translateY(10px) rotate(-45deg);
	}
	.toggleMenu.active .menu-trigger span:nth-of-type(2) {
		opacity: 0;
	}
	.toggleMenu.active .menu-trigger span:nth-of-type(3) {
		-webkit-transform: translateY(-10px) rotate(45deg);
		transform: translateY(-10px) rotate(45deg);
	}
	.header_right_box {
		display: none;
	}
	#header .right {
		width: 38px !important;
		height: auto;
		margin-right: 20px;
		margin-top: 18px;
		margin-bottom: 15px;
	}
	#header .right_box,
	#header .g_nav {
		display: none;
	}
	#header .header_menu .g_nav {
		margin-right: 0px !important;
	}
	#header .header_menu {
		float: none;
		clear: both;
		margin-right: 0;
	}
	#header .header_menu .g_nav {
    display: block;
    text-align: center;
    background: #f4b938;
    border-top: 0;
    padding: 5px 10px 10px 10px;
    box-sizing: border-box;
	}
	#header .header_menu .g_nav > li {
		position: relative;
		border-bottom: 0;
		border-left: none;
		width: 100% !important;
    height: auto;
	}
	#header .header_menu .g_nav > li > a,
	#header .header_menu .g_nav > li > span {
	    width: 100% !important;
    padding: 15px 45px 15px 30px;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    display: block;
    text-align: left !IMPORTANT;
    height: auto;
    background: #f4b938;
    font-size: 16px;
    color: #fff !important;
    letter-spacing: 2px;
    border-left: 0;
    border-bottom: 1px solid #fff;
    line-height: 1.7;
	}
.header_menu .g_nav li a:before {
    background-color: #fff;
}

	#header .header_menu .g_nav > li > a:hover,
	#header .header_menu .g_nav > li > span:hover {
		background: #d3e6d8;
		opacity: 1;
	}
	#header .header_menu .g_nav > li > a span,
	#header .header_menu .g_nav > li > span span {
		margin: 0;
	}
	#header .header_menu .g_nav > li > a sub,
	#header .header_menu .g_nav > li > span sub {
		margin: 0px 0 0 8px;
		display: inline-block;
		vertical-align: middle;
		bottom: 0;
		padding-top: 0;
		color: #A2D8CF !important;
		letter-spacing: 1px;
	}
	#header .header_menu .g_nav > li:nth-child(4)>a sub {
		padding-top: 0;
	}
	#header .header_menu .g_nav > li > span:after {
		content: "";
		position: absolute;
		top: 22px;
		right: 20px;
		width: 16px;
		height: 16px;
		border-bottom: 2px solid #577957;
		border-left: 2px solid #577957;
		box-sizing: border-box;
		-moz-transform: rotate(-45deg);
		-ms-transform: rotate(-45deg);
		-webkit-transform: rotate(-45deg);
		transform: rotate(-45deg);
		-moz-transition-duration: 0.2s;
		-o-transition-duration: 0.2s;
		-webkit-transition-duration: 0.2s;
		transition-duration: 0.2s;
	}
	#header .header_menu .g_nav > li dl {
		position: relative;
		top: 0;
		background: none;
		width: 100%;
		margin-left: 0;
		left: 0;
		padding: 0 !important;
	}
	#header .header_menu .g_nav > li dl li:before {
		display: none;
	}
	#header .header_menu .g_nav > li dt {
		display: none;
	}
	#header .header_menu .g_nav > li ul {
		position: inherit;
		background: #eff1fb;
		display: none;
		top: 0;
		padding: 0;
	}
	#header .header_menu .g_nav > li ul li {
		display: block;
		margin-right: 0;
		border-top: 1px solid #577956;
		padding: 0;
	}
	#header .header_menu .g_nav > li ul li a {
		position: relative;
		display: block;
		padding: 15px 20px 12px 21px;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
		text-align: left;
		background: #fbfffa;
		color: #727272 !important;
		border-bottom: 0;
	}
	#header .header_menu .g_nav > li ul li a:hover {
		text-decoration: none;
		background: #D9EAE0;
		opacity: 1;
	}
	#header .header_menu .g_nav > li.hover ul {
		display: block;
		filter: progid: DXImageTransform.Microsoft.Alpha(enabled=false);
		opacity: 1;
	}
	#header .header_menu .g_nav > li.hover > span:after {
		top: 32px;
		-moz-transform: rotate(135deg);
		-ms-transform: rotate(135deg);
		-webkit-transform: rotate(135deg);
		transform: rotate(135deg);
	}
	/*スマホ時サブメニューが消える現象を回避*/
	#header .header_menu .g_nav > li > span {
		position: relative;
	}
	#header .header_menu .g_nav > li.hover > span + dl,
	#header .header_menu .g_nav > li > span:hover + dl {
		pointer-events: auto;
		opacity: 1;
	}
}

@media screen and (max-width: 413px) {
	#header h1 {
    margin: 7px 0 0 12px;
    width: 220px !important;
}
	.toggleMenu {
		padding: 0px 12px 0;
	}
}