@charset "utf-8";


/* リセットcss */

main {
    display: block;
}

body, html, ul, li {
    margin: 0;
    padding: 0;
    font-family: 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
}


img {
    border: 0;
    vertical-align: middle;
}

ul {
    list-style: none;
}

a {
    text-decoration: none;
}

.clearfix:after {
    content: ".";
    display: block;
    clear: both;
    height: 0;
    visibility: hidden;
}

.clearfix {
    min-height: 1px;
}

* html .clearfix {
    height: 1px;
    /*¥*//*/  
    height: auto;
    overflow: hidden;
    /**/
}



/* ヘッダー */
h1#page_top {
    margin: 0 auto;
    padding: 1px 0;
    color: #666;
    font-size: 12px;
    font-weight: normal;
    line-height: 1;
    text-align: left;
    width: 1000px;
}

.head_frame {
    position: relative;
    background: #C5EE96;
}



/* ヘッダー1段目 */
.head_01 {
    position: relative;
    vertical-align: middle;
    box-sizing: border-box;
    width: 1000px;
    margin: 0 auto;
    padding-left: 252px;
    line-height: 70px;
    font-size: 12px;
    color: #4e4e4e;
    
}

.head_site_logo {
    position: absolute;
    display: block;
    margin: 0;
    padding: 0;
    top: 0;
    left: 0;
    transition: .2s;
}

h1.head_site_logo {
    left: 50%;
    margin-left: -500px;
}

.head_01_link {
    position: relative;
    display: inline-block;
    height: 70px;
    line-height: 70px;
    transition: .2s;
}

.head_01_link > img {
    vertical-align: middle;
}

a.head_site_logo ,
a.head_01_link {
    border-radius: 10px;
}
a.head_site_logo:hover ,
a.head_01_link:hover {
    background: rgba(70, 70, 70, 0.2);
}

.head_01_count {
    margin: 0 2px 0 12px;
    font-size: 13px;
    font-weight: 900;
}

.head_right_btn_list {
    position: absolute;
    top: 10px;
    right: 0;
    height: 50px;
    border-radius: 6px;
    border: 1px solid #598D2C;
    background: #fff;
    overflow: hidden;
}

.head_right_btn {
    float: right;
    position: relative;
    width: 60px;
    margin-right: 1px;
    transition: background-color .2s;
}

a.head_right_btn:hover {
    background-color: #eee;
}

.head_right_btn > img {
    display: block;
    margin:0 auto;
    height: 50px;
}

.head_right_btn:first-child {
    margin-right: 0;
}

.head_right_btn:before {
    position: absolute;
    content: "";
    display: block;
    border-left: 1px solid #ddd;
    height: 36px;
    top: 7px;
    right: -1px;
}

.head_right_btn:first-child:before {
    border: 0;
}






/* ヘッダー2段目 */
.head_02 {
    position: relative;
    width: 1000px;
    margin: 0 auto;
    padding: 3px 0 4px;
}

.head_02_wrap {
    padding: 0 0 9px;
}

.head_frame.head_fixed .head_02_wrap{
    padding: 0;
}

#head_area_navi_btn ,
#head_kind_navi_btn {
    position: relative;
    display: inline-block;
    vertical-align: middle;
    box-sizing: border-box;
    border: 1px solid #598D2C;
    box-shadow: 0 3px #598D2C;
    background: #fff;
    color: #333;
    width: 170px;
    line-height: 40px;
    font-size: 14px;
    font-weight: bold;
    border-radius: 5px;
    padding: 0px 20px 0px 12px;
    text-align: center;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: .2s;   
}

a#head_area_navi_btn.hover ,
a#head_kind_navi_btn.hover {
    background: #ddd;    
}

#head_area_navi_btn:after ,
#head_kind_navi_btn:after {
    position: absolute;
    content: "";
    display: inline-block;
    top: 50%;
    right: 8px;
    width: 14px;
    height: 14px;
    background: url(https://img.fujoho.jp/share/fa_png/caret-down-solid_333333_28px.tiny.png) center center no-repeat;
    background-size:  contain;   
    margin-top: -8px; 
}

/* 
#head_area_navi_btn:after ,
#head_kind_navi_btn:after {
    position: relative;
    content: "";
    display: inline-block;
    width: 14px;
    height: 14px;
    background: url(https://img.fujoho.jp/share/fa_png/caret-down-solid_333333_28px.tiny.png) center center no-repeat;
    background-size:  contain;   
    vertical-align: middle;
    margin: 0 -12px 0 0px; 
}
 */

.head_X {
    display: inline-block;
    vertical-align: middle;
    box-sizing: border-box;
    color: #598D2C;
    font-size: 14px;    
    line-height: 40px;
    margin: 0 2px;
    font-weight: bold;
}




/* ajax部分 */
#head_area_ajax_frame ,
#head_kind_ajax_frame {
    position: absolute;
    top: 100%;
    top: calc(100% - 3px);
    left: 0;
    background: #fff;
    z-index: 999;
    box-shadow: 0 1px 10px rgba(0, 0, 0, 0.3);
    padding: 21px;
    padding: 0;
    display: none;
}
#head_kind_ajax_frame {
    left: 186px;    
}

#head_area_ajax_frame .now_loading,
#head_kind_ajax_frame .now_loading {
    display: block;
    margin: 200px 330px;
}

#head_area_ajax_box ,
#head_kind_ajax_box {
    min-width: 400px;
    max-width: 780px;
    min-height: 300px;
    max-height: 600px;
    overflow: auto;
    overflow-x: hidden;
    transition: 1s;
}
#head_kind_ajax_box {
    padding-bottom: 30px;
}

#head_area_ajax_close_btn ,
#head_kind_ajax_close_btn {
    display: block;
    position: absolute;
    width: 25px;
    height: 25px;
    top: 0px;
    right: 0px;
}
#head_area_ajax_close_btn:hover ,
#head_kind_ajax_close_btn:hover {
    cursor: pointer;
}




/* ヘッダ固定のためのcss */
.head_frame.head_fixed {
    position: fixed;
    z-index: 999;
    top: -70px;
    left: 0;
    right: 0;
    box-shadow: 0 -10px 10px 12px rgba(0,0,0,0.3);
}
body.head_fixed {
    padding-top: 128px;
}





/* ヘッダー、ドロップダウンメニュー */
.head_navi_menu {
    text-transform: uppercase;
    position: absolute;
    top: 3px;
    right: 0;
    box-sizing: border-box;
    border-radius: 5px;
    border: 1px solid #598D2C;
    box-shadow: 0 3px #598D2C;
    background: #fff;
}

.head_navi_menu li {
    float: left;
    position: relative;
    font-weight: 700;
}
.head_navi_menu li:hover {
    transition: .2s;
    background: #eee;
}
.head_navi_menu li > span,
.head_navi_menu li a {
    display: block;
    color: #4c4c4c;
    background: #fff;
    font-size: 14px;
    line-height: 20px;
    padding: 10px 20px;
    transition: .2s;
}
.head_navi_menu li > span {
    cursor: default;
    background: transparent;
}

.head_navi_menu > ul > li {
    margin: 0 0 0 1px;
} 
.head_navi_menu > ul > li:before {
    content: "";
    display: block;
    height: 20px;
    border-left: 1px solid #ddd;
    position: absolute;
    top: 11px;
    left: -1px;
}

.head_navi_menu > ul > li:first-child {
    margin: 0;
} 
.head_navi_menu > ul > li:first-child:before {
    border: 0;
}

.head_navi_menu li a:hover {
    background: #ddd;
}

.head_navi_menu ul li:hover > ul {
    display: block;
    background: #fff;
    z-index: 9999;
    box-shadow: 0 1px 10px rgba(0, 0, 0, 0.3);
}
.head_navi_menu ul ul {
    display: none;
    position: absolute;
}
.head_navi_menu ul ul li {
    width: 242px;
}
.head_navi_menu ul ul li a {
    padding: 12px 20px;
}
.head_navi_menu ul ul ul {
    left: 100%;
    top: 0;
}

.head_navi_menu > ul > li {
   position: relative;
}

.head_navi_menu .separator {
    border-top: 1px solid #ddd;
}

.head_navi_menu > ul > li > span:after ,
.head_navi_menu > ul > li > a:after {
    content: "";
    display: inline-block;
    width: 14px;
    height: 14px;
    vertical-align: middle;
    background: url(https://img.fujoho.jp/share/fa_png/caret-down-solid_333333_28px.tiny.png) center center no-repeat;
    background-size:  contain;   
    margin: -3px -8px 0 2px; 
}
.head_navi_menu .head_navi_sub_menu .menu_has_children > a:after {
    content: "";
    display: inline-block;
    width: 12px;
    height: 12px;
    vertical-align: middle;
    background: url(https://img.fujoho.jp/share/fa_png/chevron-right-regular_666666.tiny.png) center center no-repeat;
    background-size:  contain;    
    margin: -2px -0 0 6px; 
}
.head_navi_menu .head_navi_sub_menu .menu_indent > a:before {
    content: "";
    display: inline-block;
    width: 12px;
    height: 12px;
    vertical-align: middle;
    background: url(https://img.fujoho.jp/share/fa_png/chevron-right-regular_666666.tiny.png) center center no-repeat;
    background-size:  contain;    
    margin: -2px 4px 0 10px; 
}
.head_navi_menu > ul > li > ul {
    display: block;
    position: absolute;
    opacity: 0;
    top: 75%;
    visibility: hidden;
    transition: .2s;
}
.head_navi_menu > ul > li:hover > ul {
    top: 100%;
    visibility: visible;
    opacity: 1;
}
.head_navi_menu > ul > li > ul > li > ul {
    display: block;
    position: absolute;
    opacity: 0;
    visibility: hidden;
    transition: .2s;
}
.head_navi_menu > ul > li > ul > li:hover > ul {
    display: block;
    visibility: visible;
    opacity: 1;
}
.head_navi_menu > ul > li:last-child > ul {
    right: 0;
}
.head_navi_menu_update_time {
    color: #f33;
    font-size: 10px;
    font-weight: normal;
    float: right;
    line-height: 20px;
}

.head_navi_menu > ul > li > span {
    padding: 10px 16px;
    min-width: 60px;
    text-align: center;
}





/* パンくず */
#nav_pankuzu_frame {
    padding: 1px 0;
    background: #fff;
    border-bottom: 1px solid #ccc;
    box-shadow: 0 1px 10px rgba(0, 0, 0, 0.3);
}

.nav_pankuzu_list {
    width: 1000px;
    margin: 0 auto;
    font-size: 0;
}

.nav_pankuzu_list > li {
    display: inline-block;
}

.nav_pankuzu_list > li > a ,
.nav_pankuzu_list > li > span {
    position: relative;
    display: block;
    white-space: nowrap;
    font-weight: normal;
    color: #000;
    padding: 8px 0 8px 4px;
    font-size: 12px;
    line-height: 18px;
    transition: .2s;
}

.nav_pankuzu_list > li > a:hover {
    background: #eee;    
}

.nav_pankuzu_list>li>span {
    font-weight: normal;
    color: #888;
}

.nav_pankuzu_list > li > a:after {
    content: '＞';
    color: #888;
    margin: 0 0 0 4px;
}

.nav_pankuzu_list > li:first-child > a:before{
    display: inline-block;
    content: "";
    width: 22px;
    height: 16px;
    background: url(img/icon_top.tiny.png) left center no-repeat;
    background-size: contain;
    margin: -1px  0 -4px;
}



/* 通報ボタン */
.accuse {
    width: 1000px;
    height: 30px;
    position: relative;
    margin: 10px auto 0;
}

.accuse a {
    display: block;
    width: 156px;
    height: 26px;
    font-size: 11px;
    line-height: 28px;
    background: #fff;
    border: 1px solid #ccc;
    border-radius: 5px;
    position: absolute;
    right: 0;
    text-align: center;
    color: #666;
    text-decoration: none;
}

.accuse a:hover {
    color: #666;
    border: 1px solid #ccc;
    opacity: 1;
}

.accuse img {
    width: 16px;
    height: 18px;
    margin-right: 5px;
    opacity: 0.7;
    vertical-align: middle;
}



/* ページの先頭に戻るボタン */
#goto_page_top_frame {
    position: fixed;
    bottom: -90px;
    right: 12px;
    z-index: 99;
    transition: bottom 0.5s;   
}

#goto_page_top {
    display: block;
    width: 80px;
    height: 80px;
    opacity: 0.4;
}

#goto_page_top:hover {
    opacity: 0.9;
}



/* フッター */
#page_footer {
    position: relative;
	background-color:#f7f7f7;
	border-top: 1px solid #ccc;
    color: #666;	
    margin: 10px 0 0 0;
    padding:25px 0 40px 0;
    box-shadow: 0 -1px 10px rgba(0, 0, 0, 0.3);
}

.foot_links_frame {
    position: relative;
    margin: 0 auto;
    width: 1000px;
    height: 280px;
}

.foot_quick_link_frame {
    position: absolute;
    left: 0;
    text-align: left;
}

.foot_quick_link_list {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    height: 230px;
    width: 840px;
    margin-top: 4px;
}

.foot_quick_link_list > li {
    display: inline-block;
    margin: 0;
    padding: 0 4px 0 0;
    line-height: 16px;
}

.foot_quick_link {
	color:#666;
    font-size: 12px;
    line-height: 18px;
    text-decoration: none;
}

a.foot_quick_link:hover {
    color:#f33;
}

.foot_about_link_list {
    margin-top: 4px;
}

.foot_about_link_list > li {
    margin: 0;
    padding: 0;
    line-height: 16px;
}

.foot_about_link_frame {
    position: absolute;
    right: 0;
    text-align: left;
}

.foot_about_link_frame .foot_quick_link_list {
    width: auto;
}

.foot_copyright {
    text-align: center;
    font-size: 12px;
}

a.foot_copyright_link {
    color: inherit;
    text-decoration: none;
}