@charset "UTF-8";
/*
Theme Name:Original Style - 1column
Version:1.1
2016.11.05
header,nav,footerなどの構成の指定
*/
/* ======== カラーメモ ========

メインカラー: #004097;
メインカラー:hover: #4c8be1;
サブカラー: #004097;
logoサイズ: 283px;

*/
/*===================
Reset
===================*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}
body {
    line-height: 1;
    -webkit-text-size-adjust: 100%;
}
ol, ul {
    list-style: none;
}
blockquote, q {
    quotes: none;
}
blockquote:before, blockquote:after, q:before, q:after {
    content: '';
    content: none;
}
table {
    border-collapse: collapse;
    border-spacing: 0;
}
table.fixed-table {
    table-layout: fixed;
}
@media screen and (min-width: 768px) {
    a[href^="tel:"] {
        pointer-events: none;
    }
}
/*===================
Native
===================*/
/* editor */
.mainblock p, .mce-content-body p {
    display: block;
    margin: 0 0 1em;
}
strong {
    font-weight: bold;
}
em {
    font-style: italic;
}
blockquote {
    display: block;
    -webkit-margin-before: 1em;
    -webkit-margin-after: 1em;
    -webkit-margin-start: 40px;
    -webkit-margin-end: 40px;
}
/**/
img[class*="wp-image-"], img[class*="attachment-"] {
    height: auto;
    max-width: 100%;
}
/* clearfix */
.clearfix {
    overflow: hidden;
    zoom: 1;
}
.clearfix:after {
    content: "";
    display: block;
    clear: both;
}
body {
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", "ＭＳ 明朝", serif;
    color: #121212;
    line-height: 1.8em;
    letter-spacing: 0;
    font-size: 16px;
    box-sizing: border-box;
}
a:focus, *:focus {
    outline: none;
}
a, a img {
    -webkit-transition: none;
    transition: none;
}
a, a:visited {
    color: #212531;
    text-decoration: none;
}
a:hover {
    text-decoration: underline;
    color: #004097;
}
a:hover img {
    opacity: 0.7;
    -moz-opacity: 0.7;
    filter: alpha(opacity=70);
    cursor: pointer;
}
img {
    max-width: 100%;
    max-height: 100%;
}
/*==========================
base
==========================*/
#contents > .inner, #footer .inner { /* コンテンツ幅 */
    width: 1000px;
    margin: 0 auto;
    max-width: 96%;
}
#header > .inner {
    width: 100%;
    margin: 0 auto;
    max-width: 100%;
    overflow: visible;
}
/*==========================
#header
==========================*/
@media screen and  ( min-width : 768px ) {
  #header {
      box-sizing: border-box;
      width: 100%;
      position: fixed;
      top: 0;
      left: 0;
      z-index: 100;
      padding: 0;
      background: #fff;
      border-bottom: 1px solid #004097;
  }
}

#header h1 {
    display: block;
    float: left;
    max-width: 35%;
    width: 650px;
}
#header h1 img {
    width: 100%;
}
#header h1 a:hover img {
    opacity: 1;
    -moz-opacity: 1;
    filter: alpha(opacity=100);
}
/*==========================
#nav
==========================*/
.menu-sp-nav-container { /* スマホ用メニューを隠す */
    display: none;
}
#nav {
    box-sizing: border-box;
}
/*==========================
#contents
==========================*/
/* H2タイトル -------------*/
.page-title {
    background: url(img/under_title.jpg) no-repeat center / cover;
    padding: 4.5em 0;
}
.page-title h2 {
    font-size: 36px;
    font-weight: bold;
    color: #212531;
    letter-spacing: 0.1em;
    position: relative;
    text-align: center;
    line-height: 1.4;
    margin: 0 auto;
}
/* パンくず -------------*/
.bread_wrap {
    margin-bottom: 2.5em;
}
.home .bread_wrap {
    margin-bottom: 0;
}
.bread_wrap .bread {
    box-sizing: border-box;
    margin-left: auto;
    margin-right: auto;
    width: 1000px;
    max-width: 96%;
}
.bread {
    padding: 0.4em 0 0.4em;
    font-size: 82%; /*13px*/
    margin-bottom: 0.5em;
    text-align: left;
}
.bread li {
    display: inline-block;
    line-height: 1.3em;
}
.bread li a {
    color: #121212;
}
.bread li a:hover {
    text-decoration: none;
}
/* コンテンツの下部余白 -------------*/
.mainblock.under {
    padding-bottom: 2.5em;
}
/*==========================
#aside
==========================*/
.inq01 {
    position: fixed;
    bottom: 0px;
    right: 0;
    z-index: 100;
}
/*==========================
.contentbottom
==========================*/
.bottom01 {
    padding: 3% 0;
    background: #004097;
}
/*==========================
#footer
==========================*/
#footer {
    padding: 4em 0 0;
    background: url(img/footer_bg.jpg) no-repeat center / cover;
    text-align: left;
}
#menu-footer-nav .menu-item-has-children > .nav_title {
    font-size: 18px;
    font-weight: bold;
    color: #004097;
    letter-spacing: 0.1em;
    line-height: 1.3;
    margin-bottom: 1.2em;
    pointer-events: none;
    display: block;
    padding: 0 0 0.5em 0.5em;
    border-bottom: 1px solid #004097;
}
#menu-footer-nav .sub-menu {
    font-size: 16px;
    margin: 0;
    display: block;
}
#menu-footer-nav .sub-menu:last-child {
    margin-bottom: 2em;
}
#menu-footer-nav .sub-menu li {
    line-height: 1.5;
    position: relative;
    margin: 0 0 0.7em;
    padding-left: 0.8em;
    letter-spacing: 0.1em;
}
#menu-footer-nav .sub-menu li::before {
    content: '-';
    position: absolute;
    top: 0;
    left: 0;
    margin: auto;
}
#menu-footer-nav .sub-menu li a {
    text-decoration: none;
    color: #121212;
}
#menu-footer-nav .sub-menu li a:hover {
    color: #004097;
}
#footer .googlemap iframe {
    box-sizing: border-box;
}
#footer .logo {
    margin-bottom: 4%;
}
#footer .time-table {
    margin-bottom: 0.5em;
}
#footer .time-table + p {
    margin-left: 1.2em;
    margin-bottom: 2em;
}
#footer .info-table {
    margin-bottom: 0.5em;
}
#footer .info-table + p a {
    margin-left: 1.2em;
}
#footer .info-table + p a:before {
    content: '>';
}
.copyright {
    padding: 1em 0;
    font-size: 16px;
    line-height: 1.5;
    text-align: center;
    position: relative;
    background: #eaf9ff;
}
/* .copyright:after {
  content: '';
  display: block;
  margin: auto;
  position: absolute;
  background: #eaf9ff;
  height: 3px;
  width: 100%;
  top: 0;
  bottom: auto;
  left: 0;
  right: 0;
} */
/********************************
Responsive
*********************************/
@media screen and (min-width: 768px) {
    /* タブレットまで */
    .sp {
        display: none !important;
    }
    /*==========================
base
==========================*/
    /*-- 2カラム時の設定 ------------
#main {
  width:720px;
  float:right;
}
#aside {
  width:240px;
  float:left;
  margin-bottom:20px;
}
--------------*/
    /*==========================
#header
==========================*/
    #header {}
    #header h1 {
        height: 120px;
        margin: 0 2% 0 3%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
    }
    .h_info {
        position: absolute;
        top: 0;
        right: 0;
        margin: auto;
    }
    /*==========================
#nav
==========================*/
    #nav {
        width: 100%;
        z-index: 100;
        box-sizing: content-box;
        padding: 0;
    }
    #nav .inner {}
    /* PC用グローバルナビゲーション */
    #menu-header-nav {
        float: right;
        padding-right: 390px;
        display: -webkit-box !important;
        display: -ms-flexbox !important;
        display: flex !important;
        -webkit-box-pack: end;
        justify-content: flex-end;
    }
    #menu-header-nav li {
        box-sizing: border-box;
    }
    #menu-header-nav a, #menu-header-nav > li > span {
        text-decoration: none;
        display: block;
        text-align: center;
        background-repeat: no-repeat;
        line-height: 1.35em;
        box-sizing: border-box;
        -webkit-transition: none;
        transition: none;
    }
    #menu-header-nav > li {
        position: relative;
        float: left;
    }
    #menu-header-nav > li > a, #menu-header-nav > li > span {
        font-size: 16px;
        height: 120px;
        box-sizing: border-box;
        padding: 10px 1.5vw;
        color: #004097;
        position: relative;
        z-index: 20000;
        line-height: 1.5;
        letter-spacing: 0.1em;
        transition: 200ms;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        justify-content: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
    }
    #menu-header-nav > li > a span.nav_span, #menu-header-nav > li > span span.nav_span {
        font-size: 12px;
        display: block;
        color: #004097;
    }
    #menu-header-nav > li.nav01 > a::before {
        left: 0;
    }
    #menu-header-nav > li > a:hover, #menu-header-nav > li > span:hover {
        color: #fff;
        cursor: pointer;
        background: #004097;
    }
    #menu-header-nav > li > a:hover span.nav_span {
        color: #fff;
    }
    #menu-header-nav li {
        transition: .2s;
        border-left: 1px solid #004097;
    }
    #menu-header-nav li:last-child {
      border-right: 1px solid #004097;
    }
    #menu-header-nav ul.sub-menu {
        position: absolute;
        padding: 0;
        background: none;
        z-index: 9;
        top: 0;
        left: 0;
        width: 100%;
        box-sizing: border-box;
        text-align: center;
        transition: .2s;
    }
    #menu-header-nav > li > ul.sub-menu {
        height: auto;
        overflow: hidden;
    }
    #menu-header-nav > li:hover > ul.sub-menu {
        height: auto;
        top: 100%;
        padding-top: 0;
        padding-bottom: 0;
        background: #004097;
        width: 180%;
        left: -40%;
        border-top: 1px solid #fff;
    }
    #menu-header-nav > li > ul.sub-menu > li {
        width: 100%;
        height: 0;
        border-left: none;
        border-right: none;
    }
    #menu-header-nav > li:hover > ul.sub-menu > li {
        float: none;
        height: auto;
        border-bottom: 1px solid #fff;
    }
    #menu-header-nav > li > ul.sub-menu > li a {
        font-size: 16px;
        text-align: center;
        text-indent: inherit;
        color: #fff;
        padding: 10px 10px 8px;
        display: block;
    }
    #menu-header-nav ul.sub-menu li a:hover {
        color: #fff;
        background: #4c8be1;
    }
    /*仕切りボーダー*/
    /* #menu-header-nav li > a, #menu-header-nav li > span {
  position: relative;
  border-right: 1px solid #e0dbc8;
}
#menu-header-nav li.nav01 > a {
  border-left: 1px solid #e0dbc8;
} */
    /* サブ */
    #menu-header-nav > li.wide {
        position: inherit;
    }
    #menu-header-nav li .submenu-wrap {
        height: 0;
        overflow: hidden;
        position: absolute;
        left: 0;
        transition: .2s;
    }
    #menu-header-nav li:hover .submenu-wrap {
        display: block;
        width: 100%;
        z-index: 4;
        background: #004097;
        overflow: hidden;
        height: auto;
        padding-bottom: 2em;
        padding-top: 2em;
        border-top: 1px solid #fff;
    }
    #menu-header-nav li .submenu-wrap .submenu-inner {
        width: 1000px;
        max-width: 96%;
        margin: 0 auto 0;
        overflow: hidden;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }
    #menu-header-nav li .submenu-wrap .menutitle {
        text-align: left;
        overflow: hidden;
        display: block;
        font-size: 16px;
        top: 0;
        height: 0;
        position: relative;
        padding-left: 22px;
        font-weight: bold;
        margin-bottom: 10px;
        margin-left: 10px;
        margin-right: 10px;
        transition: .2s;
        color: #fff;
    }
    #menu-header-nav .submenu-wrap ul.sub-menu li.menutitle a {
        background: none;
        color: #fff;
        text-align: left;
        padding: 0.3em 0.2em 0.3em;
        font-size: 16px;
        border-right: none;
    }
    #menu-header-nav li .submenu-wrap .menutitle::before {
        display: none;
    }
    #menu-header-nav li .submenu-wrap .menutitle a {
        display: inline;
        background: none;
        color: #fff;
        padding: 0;
    }
    #menu-header-nav li .submenu-wrap .menutitle a:hover {
        color: #fff !important;
    }
    #menu-header-nav li:hover .submenu-wrap .menutitle {
        height: auto;
        top: 0;
        padding-bottom: 5px;
        padding-top: 5px;
        border-bottom: 1px solid #ccc;
        padding-left: 0;
    }
    #menu-header-nav .submenu-wrap ul.sub-menu {
        position: relative;
        background: none;
        margin-left: 0;
        text-align: left;
        box-sizing: border-box;
        padding-left: 10px;
        padding-right: 10px;
    }
    #menu-header-nav .submenu-wrap ul.sub-menu li {
        position: relative;
        padding-left: 1.5em;
        float: left;
        width: 100%;
        border-left: none;
        border-right: none;
    }
    #menu-header-nav .submenu-wrap ul.sub-menu li.submenu-title {
        padding-left: 0.4em;
        font-weight: bold;
        line-height: 1.3;
        font-size: 15px;
        margin-bottom: 10px;
    }
    #menu-header-nav .submenu-wrap ul.sub-menu li.submenu-title::before {
        display: none;
    }
    #menu-header-nav .submenu-wrap ul.sub-menu li::before {
        position: absolute;
        content: "";
        width: 5px;
        height: 5px;
        top: 10px;
        left: 10px;
        border-top: solid 1px #fff;
        border-right: solid 1px #fff;
        -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
        transform: rotate(45deg);
        transition: .2s;
    }
    #menu-header-nav .submenu-wrap ul.sub-menu li:hover:before {
      left: 15px;
      transition: .2s;
      opacity: .7;
    }
    #menu-header-nav .submenu-wrap ul.sub-menu li a {
        background: none;
        color: #fff;
        text-align: left;
        padding: 0.3em 0.2em 0.3em;
        font-size: 16px;
        border-right: none;
    }
    #menu-header-nav > li:hover .submenu-wrap ul.sub-menu li a:hover {
        color: #fff;
        text-decoration: none;
    }
    #menu-header-nav ul.sub-menu {
        position: absolute;
        padding: 0;
        z-index: 9999;
        top: 0;
        left: 0;
        width: 100%;
        box-sizing: border-box;
        text-align: center;
        transition: .2s;
    }
    #menu-header-nav > li > ul.sub-menu a {
        border-right: none;
        border-top: none;
    }
    #menu-header-nav li ul li {
        width: 100%;
        height: 0;
    }
    #menu-header-nav > li:hover ul li {
        float: none;
        height: auto;
    }
    #menu-header-nav li > a, #menu-header-nav li > span {
        position: relative;
    }
    /* サブメニュー矢印 */
    #menu-header-nav li.has_children > a::after {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        bottom: 5px;
        margin: auto;
        width: 0;
        height: 0;
        border-top: 6px solid #004097 !important;
        border: 4px solid transparent;
    }
    #menu-header-nav li.has_children > a:hover:after {
        border-top: 6px solid #fff !important;
    }
    #menu-header-nav .submenu-wrap ul.sub-menu li.submenu_ttl {
        font-weight: bold;
        padding-left: 0;
        margin: 0 0 5px;
        color: #fff;
        border-bottom: 2px solid #fff;
        text-align: center;
    }
    #menu-header-nav .submenu-wrap ul.sub-menu li.submenu_ttl:before {
        display: none;
    }
    #menu-header-nav .submenu-wrap ul.sub-menu li.last {
        margin-bottom: 1em;
    }
    /*==========================
#contents
==========================*/
    /* コンテンツのmin-height -------------*/
    #contents #main {
        min-height: 600px;
    }
    /*==========================
#aside
==========================*/
    #aside .inq {
        position: fixed;
        right: 0;
        bottom: 20%;
        z-index: 5;
    }
    #aside .inq a {
        display: block;
    }
    #aside .inq .clearfix a:not(:last-child) {
        margin-bottom: 10px;
    }
    #aside .inq a:hover img {
        opacity: 0.8;
        -moz-opacity: 0.8;
        filter: alpha(opacity=80);
    }
    #aside .inq01 {
        position: fixed;
        bottom: 0;
        right: 0;
        z-index: 100;
    }
    @media screen and (max-width: 1300px), (max-height: 700px) {
        #aside .inq {}
    }
    /*-- ブログページ ------------*/
    .post-type-blog #main {
        float: left;
        width: 72%;
    }
    .post-type-blog #aside {
        float: right;
        width: 24%;
    }
    /*==========================
.contentbottom
==========================*/
    /*==========================
#footer
==========================*/
    #footer #menu-footer-nav {
        width: 49%;
        box-sizing: border-box;
        margin-right: 2%;
        float: left;
    }
    #footer .menu-item-has-children {
        float: left;
        margin-left: 2%;
        width: 49%;
    }
    #footer .menu-item-has-children:first-child {
        margin-left: 0;
    }
    #footer .footer_info {
        width: 49%;
        float: left;
        box-sizing: border-box;
    }
}
@media screen and (max-width: 1630px) and (min-width: 768px) {
    .h_info {
        overflow: hidden;
    }
    .h_info .time {
        transform: translateX(290px);
        transition: 200ms;
        position: relative;
        z-index: 100000;
    }
    .h_info .time:hover {
        transform: none;
    }
    #menu-header-nav {
        padding-right: 100px;
    }
    #menu-header-nav li {
        box-sizing: border-box;
    }
    #menu-header-nav > li a, #menu-header-nav > li > span {
        font-size: 1.5vw;
    }
    #menu-header-nav > li > ul.sub-menu > li a, #menu-header-nav .submenu-wrap ul.sub-menu li a {
        font-size: 16px;
    }
    #menu-header-nav .submenu-wrap ul.sub-menu li::before {
        top: 8px;
    }
}
@media screen and (max-width: 1042px) {
    /*コンテンツが横幅いっぱいになったら*/
    /*==========================
  base
  ==========================*/
    /*-- 2カラム時の設定 ------------
  #main {
  width:720px;
  max-width:100%;
  float:none;
  margin:0 auto 2.5em;
}
.home #main {
width:720px;
}

#aside {
width:490px;
max-width:100%;
float:none;
margin:0 auto 20px;
}
#aside .sideinner {
overflow:hidden;
margin-bottom:20px;
}
------------------*/
    /*==========================
#nav
==========================*/
    /*==========================
#footer
==========================*/
    #footer #menu-footer-nav {
        width: 100%;
    }
    #footer .footer_info {
        width: 100%;
        margin-bottom: 1.5em;
    }
    #footer .sub-menu li {
        font-size: 14px;
    }
}
@media screen and (min-width: 768px) and (max-width: 768px) {
    #footer li, #footer li a, #menu-sitemap li, #menu-sitemap li a {
        vertical-align: top;
    }
}
@media screen and (max-width: 767px) {
    /* スマホ */
    .pc {
        display: none !important;
    }
    .page-title {
        padding: 2.5em 0;
    }
    /*==========================
  base
  ==========================*/
    /*-- 2カラム時の設定 ------------
  #main , #aside{
  width:480px;
  max-width:96%;
  float:none;
  }*/
    /*==========================
  #header
  ==========================*/
    #header {
        padding: 0;
    }
    #header h1 {
        padding: 0;
        max-width: 45%;
        text-align: center;
        margin: 3% 0 0 3%;
    }
    #header > .inner, #nav > .inner {
        max-width: 100%;
    }
    /* SP Gメニュー*/
    .headerinner ul.sp {
        overflow: hidden;
        padding: 0;
        z-index: 99999999;
        list-style: none;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        float: right;
        max-width: 50%;
    }
    .headerinner ul li {
        box-sizing: border-box;
    }
    .headerinner ul li:not(:last-child) {
        border-right: 1px solid #fff;
    }
    .headerinner ul img {
        max-width: 100%;
        width: 100%;
        margin: 0 auto;
        box-sizing: border-box;
    }
    #nav {
        box-sizing: border-box;
        z-index: 999999;
        padding: 0;
    }
    #nav.fixed {
        height: 100%;
        overflow-x: scroll;
    }
    #nav.fixed {
        position: inherit !important;
        top: auto !important;
    }
    /* #menu-header-nav ------*/
    #menu-header-nav, #menu-header-nav .sub-menu { /* スライドダウンさせるために隠す */
        display: block;
    }
    #menu-header-nav { /* スライドダウンさせるために隠す */
        display: none;
    }
    #menu-header-nav.menu {
        background: #fff;
        left: 0;
        margin: 0;
        width: 100%;
        position: absolute;
        z-index: 99;
        border-top: 1px solid #ccc;
    }
    #menu-header-nav li .subtxt {
        display: none;
    }
    #menu-header-nav li > a br {
        display: none;
    }
    #menu-header-nav.menu {
        background: #fff;
        top: 100%;
        left: 0;
        margin: 0;
        width: 100%;
        position: absolute;
        z-index: 99999999;
        border-top: 1px solid #ccc;
    }
    #menu-header-nav li {
        display: block;
        text-align: left;
        background: none;
        float: none;
        height: auto;
        width: 100%;
        padding: 0;
        box-sizing: border-box;
        border: none;
        border-bottom: 1px solid #ccc;
        margin: 0;
    }
    #menu-header-nav li a, #menu-header-nav li > span {
        display: block;
        padding: 20px 6px 20px 15px;
        background-position: 5px center;
        background-size: 16px auto;
        width: 100%;
        float: none;
        box-sizing: border-box;
        text-align: left;
        height: auto;
        line-height: 1.5;
        font-size: 16px;
        text-decoration: none;
        position: relative;
        color: #444;
        transition: 200ms;
    }
    #menu-header-nav li ul li.last {
        border-bottom: none;
    }
    #menu-header-nav li span:hover {
        cursor: pointer;
    }
    #menu-header-nav li a:hover, #menu-header-nav li span:hover {
        color: #fff;
        background: #004097;
    }
    #menu-header-nav li.has_children > a::after {
        display: block;
        content: "";
        position: absolute;
        width: 8px;
        height: 8px;
        top: 50%;
        right: 18px;
        margin: -5px 0 0 0;
        border-bottom: solid 3px #ccc;
        border-right: solid 3px #ccc;
        -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
        transform: rotate(45deg);
    }
    #menu-header-nav li:first-child a {
        border-left: none;
    }
    #menu-header-nav .submenu-title {
        font-size: 15px;
        font-weight: bold;
        line-height: 1.3;
        padding: 10px 30px 0;
        border-bottom: none;
    }
    #menu-header-nav .submenu-wrap .menutitle {
        border-top: 1px solid #ccc;
        display: block;
        padding: 0;
        background: #d4e6ff;
        padding-left: 10px;
    }
    #menu-header-nav .sub-menu {
        background: #d4e6ff;
        font-size: 15px;
    }
    #menu-header-nav .sub-menu li a {
        padding-left: 25px;
    }
    #menu-header-nav .sub-menu li a:after {
      display: block;
      content: "";
      position: absolute;
      width: 8px;
      height: 8px;
      top: 50%;
      right: 18px;
      margin: -5px 0 0 0;
      border-bottom: solid 3px #ccc;
      border-right: solid 3px #ccc;
      -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
      transform: rotate(-45deg);
    }
    #menu-header-nav .nav_span {
        display: none;
    }
    #menu-header-nav .submenu-wrap .menutitle {
        display: none;
    }
    #menu-header-nav .submenu-wrap {
        border-top: none;
    }
    /* #menu-header-nav .sub-menu li:last-child {
        border-bottom: none;
    } */
    #menu-header-nav li.menutitle {
        background: #d4e6ff;
    }
    #menu-header-nav li.menutitle a {
        font-size: 13px !important;
        font-weight: bold;
        padding-left: 27px;
    }
    #menu-header-nav li.menutitle a:hover {
        color: #444;
    }
    #menu-header-nav li.menutitle a:before {
        display: none;
    }
    /*==========================
  #contents
  ==========================*/
    .bread_wrap {
        margin-bottom: 1em;
    }
    #contents {
        margin-bottom: 0;
    }
    /*==========================
  #aside
  ==========================*/
    #aside .inq {
        bottom: 0;
        position: fixed;
        z-index: 10;
        right: 0;
    }
    #aside .inq .clearfix a {
        float: left;
        width: 50%;
    }
    #aside .inq .clearfix a:hover img{
        opacity:1;
    }
    #aside {
        margin-bottom: 0;
    }
    #aside .inq01 {
        position: fixed;
        z-index: 1;
        right: 2%;
        bottom: 15vw;
        width: 100%;
        max-width: 70px;
    }
    /*==========================
  .contentbottom
  ==========================*/
    .bottom01 .column {
        margin: 2% 0 !important;
    }
    /*==========================
  #footer
  ==========================*/
    #footer .footer_info {
        margin-bottom: 1.5em;
    }
    #footer li.parent, #footer li.parent2, #footer li.parent3 {
        float: none;
        width: auto;
        display: block;
    }
    #footer li.menu-item-has-children, #footer li.menu-item-has-children:last-child {
        float: none;
        height: auto;
        width: 100%;
        border-left: none;
        padding-left: 1%;
    }
    #footer .sub-menu li {
        vertical-align: top;
    }
    .copyright {
        padding: 1.2em 0 15%;
    }
}
@media screen and (max-width: 480px) {
    /* スマホ480px */
    /*==========================
  #header
  ==========================*/
    /*==========================
  #nav
  ==========================*/
    /*==========================
  #contents
  ==========================*/
    .bread {
        margin-bottom: 0.5em;
        padding: 0.3em 0 0.2em;
        text-align: right;
    }
    /*==========================
  #footer
  ==========================*/
}




.mainimage img {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .mainimage .slider1, .mainimage .slider2, .mainimage .slider3 {
    background-position: center;
    background-size: auto 100%;
    height: 0;
    padding-bottom: 730px;
  }
  .mainimage .slider1 {
    background-image: url("img/mainimage01.jpg");
  }
  .mainimage .slider2 {
    background-image: url("img/mainimage02.jpg");
  }
  .mainimage .slider3 {
    background-image: url("img/mainimage03.jpg");
  }
}
@media print, screen and (min-width: 767px) and (max-width: 1500px) {
  .mainimage .slider1, .mainimage .slider2, .mainimage .slider3 {
    padding-bottom: 45%;
    height: 0;
  }
}


@media screen and  ( max-width : 767px ) {
  #menu-header-nav li.submenu_ttl {
    background: #fff5c4;
    font-weight: bold;
  }
  #menu-header-nav li.submenu_ttl span {
    text-align: center;
  }
}

.google_map iframe {
  width: 100%;
  height: 400px;
}
.footer_bottom .google_map {
  height: 400px;
}
@media screen and  ( min-width : 768px ) {
  .google_map iframe {
    width: 100%;
    height: 450px;
  }
  .footer_bottom .google_map iframe {
    width: 100%;
    height: 500px;
  }
  .footer_bottom .google_map {
    height: 500px;
  }
}

.footer_bottom .ftr_text {
  font-weight: bold;
  letter-spacing:0.18em;
  margin-bottom: 1em;
}

.footer_bottom .footer_bottom_inner {
  background: #eaf9ff;
  padding: 10% 0 0;
}
.footer_bottom .footer_bottom_inner .logo {
  text-align: center;
  margin-bottom: 60px;
}
.footer_bottom .footer_bottom_inner .text_center {
  text-align: center;
}
@media screen and (min-width: 768px) {
  .footer_bottom .footer_bottom_inner {
    padding: 6% 0 0;
  }

  .footer_bottom .columns .col_2 {
    width: 48%;
  }
  .footer_bottom .columns .col_2:last-child {
    margin-left: 4%;
  }
}
@media screen and  ( min-width : 1000px ) {
  .footer_bottom .topinner {
    max-width: 100%;
  }
}

.footer_bottom dl dt {
  font-weight: bold;
}
.footer_bottom .btn-style {
  margin-top: 1em;
}
.footer_bottom .btn-style a {
  max-width: 300px;
  padding: .63em 2.3em;
}
.footer_bottom dl dt, .footer_bottom dl dd {
  padding-bottom: .8em;
}
.footer_bottom dl dt {
  float: left;
}
.footer_bottom dl dt:nth-child(3) {
  padding-bottom: 2em;
}
.footer_bottom dl dd {
  padding-left: 120px;
}
@media screen and (min-width: 768px) {
  .footer_bottom .btn-style a {
    margin: 0;
  }
}






#footer {
  padding: 10% 0;
  background: #eaf9ff;
}
#footer ul li a {
  position: relative;
}
#footer ul li a:after {
  content: '';
  display: block;
  margin: auto;
  position: absolute;
  background: #004097;
  left: 8px;
  right: auto;
  top: 0;
  bottom: 0;
}
@media screen and (min-width:768px) and ( max-width:1000px) {
  #footer ul li a:after {
    left: 5px;
  }
}

#footer ul li a:hover {
  text-decoration: none;
  opacity: .7;
}
#footer .ftr_list01 li {
  font-size: 18px;
  margin-bottom: 1em;
}
#footer .ftr_list01 li a {
  padding-left: 25px;
}
#footer .ftr_list01 li a:after {
  width: 16px;
  height: 16px;
}
#footer .ftr_list02 li, #footer .ftr_list01 li {
  margin-bottom: 1em;
}

#footer .ftr_list_title {
  color: #004097;
  font-weight: bold;
  letter-spacing:0.16em;
  border-bottom: 1px solid #004097;
  padding-bottom: 5px;
  padding-left: 1em;
  margin-bottom: 1em;
}

#footer .ftr_list02 li a {
  padding-left: 24px;
}

@media screen and (min-width:768px) and ( max-width:1000px) {
  #footer .ftr_list02 li a {
    padding-left: 14px;
  }
}

#footer .ftr_list02 li a:after {
  width: 5px;
  height: 2px;
}
@media screen and (max-width: 767px) {
  #footer .columns .col_2 {
    margin-bottom: 0;
  }
}
@media screen and (min-width: 768px) {
  #footer {
    padding: 2.5% 0 3%;
  }
  #footer .columns .col_3:nth-child(1) {
    width: 32%;
  }
  #footer .columns .col_3:nth-child(2) {
    width: 66%;
    margin-left: 2%;
  }
  #footer .ftr_list01 {
    width: 150px;
    margin: auto 0 auto auto;
    margin-bottom: 2em;
  }
  #footer .ftr_list01:last-child {
    margin-bottom: 1em;
  }
  #footer .ftr_list01 li {
    text-align: left;
  }
}

@media screen and  ( max-width : 767px ) {
  #header {
    box-sizing: border-box;
      width: 100%;
      position: fixed;
      top: 0;
      left: 0;
      z-index: 100;
      padding: 0;
      background: #fff;
  }
  #menu-header-nav {
    overflow-y: scroll;
  }
}

#footer .ftr_bnr01, #footer .ftr_bnr02 {
  text-align: center;
}

@media screen and  ( max-width : 767px ) {
  #footer .ftr_bnr01 {
    margin-bottom: 1.5em;
  }
}

@media screen and  ( min-width : 768px ) {
  #footer .ftr_bnr .columns .col_2 {
    width: 48%;
  }
  #footer .ftr_bnr .columns .col_2:last-child {
    margin-left: 4%;
  }
  #footer .ftr_bnr01 {
    text-align: right;
  }
  #footer .ftr_bnr02 {
    text-align: left;
  }
}

.ajax-loader {
  position: absolute!important;
}
