@charset "utf-8";
/* CSS Document */


/* bootstrap.css基本の打消し（同じclass名での書き換え）
---------------------------------------------------- */
body {
    margin: 0px;
    padding: 0px;
}
h1, h2, h3, h4, h5, h6 {
    margin: 0px;
    padding: 0px;
    font-weight: normal;
    clear: both
}
p {
    margin: 0px;
    padding: 0px
}

.navbar {
    margin-bottom: 0px;
    border: none;
}
.table-striped>tbody>tr:nth-of-type(odd) {
    background-color: #efefef;
}
.table {
    margin-bottom: 30px
}
.table th {
    width: 30%
}

@media (min-width: 768px) {
    .btn-group-vertical a {
        padding-top: 15px;
        padding-bottom: 15px
    }
}


/* 全体構造
---------------------------------------------------- */
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, dialog, figure, footer, header,
hgroup, menu, nav, section,
time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
}

.clearfix:after {
    content: ".";
    /* 新しい要素を作る */
    display: block;
    /* ブロックレベル要素に */
    clear: both;
    height: 0;
    visibility: hidden;
}
.clearfix {
    zoom: 1;
    /*for IE 5.5-7*/
    overflow: hidden;
}
* html .clearfix {
    height: 1px;
    /*\*/
    /*/
  height: auto;
  overflow: hidden;
  /**/
}

.clear {
    clear: both;
}

img {
    border: 0;
    vertical-align: bottom;
}

a {
    outline: none;
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
}

hr {
    display: block;
    height: 1px;
    border-top: 1px dotted #333;
    margin: 0;
    padding: 0;
    margin-bottom: 20px
}

body {
    font-size: 90%;
    /* 基本のフォントサイズ */
    line-height: 185%;
    /* 基本の行間 */
    font-family: FontAwesome, "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    color: #333;
    letter-spacing: 0.05em;
}


/* webfont
---------------------------------------------------- */
.gfont-e {
    font-family: 'Kurale';
    /*letter-spacing: 0.03em;*/
}


/* link
---------------------------------------------------- */
a:link, a:visited, a:hover, a:active {
    text-decoration: none;
    color: #666;
}

.tel-link a:link {
    color: #333;
}

/* アンカーリンクの食い込み解除 */
.anchor {
    padding-top: 80px;
    margin-top: -80px;
}
@media (min-width: 768px) {
    .anchor {
        padding-top: 95px;
        margin-top: -95px;
    }
}

/* header
---------------------------------------------------- */
header {
    width: 100%;
    z-index: 1000;
    margin: 0;
    border-bottom: none;
    background-color: #fff;
    /*ヘッダーの背景色*/
    padding-top: 10px;
    padding-bottom: 10px;
}

.logo {
    float: left;
    height: auto;
    width: 100%;
    position: relative;
    z-index: 2;
    /*押す順番*/
}
@media only screen and (max-width: 767px) {
    header {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        background-color: #fff;
    }
    .logo {
        width: 200px;
    }
}
@media print, screen and (min-width: 768px) {
    header {
        /*background:none;*/
        position: absolute;
        top: 0;
        left: 0;
        padding: 0px;
        padding-bottom: 20px;
    }
    /*.logo{ 
    padding-top: 20px;
  }*/
}
@media print, screen and (min-width: 992px) {
    /*.logo{ 
    padding-top: 25px;
    padding-bottom: 25px;
  }*/
}

/* nav
---------------------------------------------------- */
.menu {
    font-size: 100%;
    line-height: 1.0em;
}
/*ナビのフォントサイズ*/
.menu a {
    color: #999;
    font-weight: bold;
}
/*ハンバーガーメニューの色、太さ*/
/*.menu > ul > li a {color: #fff!important; text-align: center!important;}*/
/*ハンバーガーメニュー内のリンク文字色*/
.menu>ul {
    border-bottom: 1px solid #ddd !important;
}
.menu>ul>li a {
    padding: 13px 15px !important;
}
.menu>ul>li a:hover,
.menu li.navi-on a {
    color: #3e8dcf !important;
    /*hover状態の色*/
}
.menu>ul>li {
    border-top: 1px solid #ddd !important;
    border-bottom: none !important;
}
/*ナビ間の線の色*/
/*.menu > ul > li > ul > li a {text-align: left!important;}*/
/*ハンバーガーメニュー内の文字左寄せ*/

.header_language {
    border: 1px solid #999;
    text-align: center;
    margin-top: 4px;
  margin-right: -15px;
}
.header_language a:link {
    color: #333 !important;
}

.header_sns_xs i{ font-size: 140%; margin-top: 8px;}

@media only screen and (max-width: 767px) {
    .menu-container {
        margin-top: -25px !important;
        /*ハンバーガーメニューの位置調整*/
        position: relative;
        z-index: 1;
        /*押す順番*/
    }
}

@media print, screen and (min-width: 768px) {
    .menu {
        font-size: 70%;
    }
    .menu-container {
        margin-top: 0 !important;
    }
    .menu .show-on-mobile {
        padding-top: 10px !important;
    }
    .menu>ul {
        /*width: auto!important;*/
        -webkit-transition: all 0.3s ease 0s;
        transition: all 0.3s ease 0s;
        border-bottom: none !important;
    }
    .menu>ul>li a {
        padding: 0px 0px !important;
        text-align: center !important;
        margin: 0px;
    }
    .menu>ul>li a:hover,
    .menu li.navi-on a {
        /*border-bottom: 1px solid #333;*/
        /*background: url(../images/navi-on.png) repeat-x bottom;*/
        /*hover時下線を出す*/
    }
    .menu>ul>li img {
        margin: 0px auto;
    }
    .menu>ul>li {
        border-top: 0 !important;
        width: 20%;
        text-align: center;
        vertical-align: middle;
    }
  
  .header_sns i{ float: right; font-size: 160%; margin-right: 20px; margin-top: 13px;}
}

@media print, screen and (min-width: 992px) {
    .menu {
        font-size: 90%;
    }
    /*ナビのフォントサイズ*/
    .menu>ul>li a {
        -webkit-transition: all 0.3s ease 0s;
        transition: all 0.3s ease 0s;
    }
    .menu .show-on-mobile {
        padding-top: 0 !important;
    }
}
@media print, screen and (min-width: 1200px) {
  .menu {
        font-size: 110%;
    }
}


/* nav固定
---------------------------------------------------- */
.cb-header {
    position: fixed;
    /* ヘッダーバーを固定 */
    top: -200px;
    left: 0;
    width: 100%;
    z-index: 1000;
    background-color: #fff;
    /*あとから出てくるナビの背景色*/
    border-bottom: 1px solid #ddd;
}

@media print, screen and (min-width: 768px) {
    .cb-header {
        padding: 20px 0px;
    }
    .cb-header .menu {
        font-size: 70%;
    }
    .cb-header .menu>ul {
        float: none;
        margin: 0px auto;
        width: auto !important;
    }
    .cb-header .menu>ul>li a {
        margin: 0px 5px !important;
        padding: 0px 0px 2px 0px !important;
    }
    .cb-header .menu>ul>li>ul {
        font-size: 100%;
    }
}

@media print, screen and (min-width: 992px) {
    .cb-header .menu {font-size: 85%;}
    /*.cb-header .menu > ul > li a{ margin-left: 40px!important;}*/
}
@media print, screen and (min-width: 1200px) {
    .cb-header nav {font-size: 100%;}
    /**/
}

/* 印刷時表示消す */
@media print {
    .cb-header {
        display: none !important;
        visibility: hidden;
    }
}


/* mainimage
---------------------------------------------------- */
#mainimage {
    background: url("../images/bg_mainimage.jpg") no-repeat center;
    background-size: cover;
}
#mainimage img {
    margin: 0px auto;
}


/* sliderpro */
/*前矢印のアイコンフォント*/
.sp-next-arrow:before,
.sp-next-arrow:after {
    background-color: #666 !important;
}
/*後矢印のアイコンフォント*/
.sp-previous-arrow:before,
.sp-previous-arrow:after {
    background-color: #666 !important;
}


/* ヘッダー固定で上空ける */
#mainimage,
.h2-style {
    margin-top: 60px;
}
@media print, screen and (min-width: 768px) {
    #mainimage,
    .h2-style {
        margin-top: 160px;
    }
}
@media print, screen and (min-width: 992px) {
    #mainimage,
    .h2-style {
        margin-top: 180px;
    }
}
@media print, screen and (min-width: 1200px) {
    #mainimage,
    .h2-style {
        margin-top: 200px;
    }
}


/* main
---------------------------------------------------- */
main {
    background-color: #fafafa;
    padding: 30px 0px 0px;
}
@media print, screen and (min-width: 768px) {
    main {
        padding: 50px 0px 0px;
    }
}
@media print, screen and (min-width: 992px) {
    main {
        padding: 90px 0px 0px;
    }
}


/* footer
---------------------------------------------------- */
footer {
    padding: 20px 0px;
    background-color: #333;
    color: #ccc;
    font-size: 80%;
    line-height: 1.5em;
  text-align: center;
}
footer h3 {
  margin-top: 10px;
  margin-bottom: 10px;
}
footer img {
  width: 15%;
  margin: 0px auto;
}
@media print, screen and (min-width: 768px) {
  footer{
    padding:30px 0px;
  }
  footer img {
    width: 8%;
    margin: 0px auto;
  }
  footer h3 {
    margin-top: 15px;
    margin-bottom: 30px;
  }
}
@media print, screen and (min-width: 992px) {
  footer img {
    width: 5%;
  }
}

/* フッターテキストリンク */
#footer-textlink {
    border-bottom: 1px solid #666;
    margin-bottom: 15px;
}
#footer-textlink li {
    list-style: none;
    border-top: 1px solid #666;
    padding: 10px 10px;
}
#footer-textlink li a {
    display: block;
}
#footer-textlink a:link,
#footer-textlink a:visited,
#footer-textlink a:active {
    color: #ccc;
    text-decoration: none
}
#footer-textlink li a::after {
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "\f105";
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    float: right;
    margin-top: 6px;
}
@media print, screen and (min-width: 768px) {
  #footer-textlink{
    border-bottom:none;
    text-align: center;
  }
  #footer-textlink li{
    display: inline-block;
    padding:0px 30px;
    border-top:none;
    line-height: 1.0em;
  }
  #footer-textlink li a::after { display: none}
}
@media print, screen and (min-width: 992px) {}

/* copyright*/
footer small {
    margin-top: 15px;
    display: block;
    font-size: 75%;
    margin-right: 15px;
}
footer small i {
    margin-right:5px;
}
@media print, screen and (min-width: 768px) {
    footer small {
        clear: both;
        font-size: 80%;
    }
}


/* pagetop
---------------------------------------------------- */
#pagetop {
    position: fixed;
    bottom: 10px;
    right: 10px;
    z-index: 100;
}
#pagetop img {
    width: 60%;
    float: right;
}
@media print, screen and (min-width: 768px) {
    #pagetop {
        bottom: 40px;
        right: 40px;
    }
    #pagetop img {
        width: auto;
        float: none;
    }
}

/* index.html（トップページ）
---------------------------------------------------- */
/* 3つの入り口 */
.top_text{
  color: #3e8dcf;
  font-weight: bold;
  margin-bottom: 10px;
  font-size: 95%;
}
.top_text2{
  font-size: 95%;
}

/* News */
.top_news {
    background-color: #fff;
    border: 1px solid #ccc;
    padding: 15px;
    margin-bottom: 10px;
}
.top_news dt {
    color: #ed5656;
    font-weight: normal;
    margin-bottom: 5px;
}
@media print, screen and (min-width: 992px) {
    .top_news {
        padding: 20px;
        margin-bottom: 20px;
    }
}

/* Product */
.top_product {
    background-color: #fff;
    border: 1px solid #ccc;
    padding: 15px;
}
.top_product h3 {
    margin-top: 15px;
    color: #3e8dcf;
    font-size: 130%;
}
.top_product span {
    display: block;
    font-size: 85%;
    margin-bottom: 10px;
}
@media print, screen and (min-width: 768px) {
    .top_product {
        padding: 20px;
    }
    .top_product h3 {
        margin-top: 0px;
        font-size: 150%;
    }
}
@media print, screen and (min-width: 992px) {
    .top_product {
        padding: 30px;
    }
    .top_product h3 {
        margin-top: 20px;
        font-size: 180%;
    }
    .top_product span {
        margin-bottom: 20px;
    }
}

/*商品スライダー*/
#bnr_top{
  position: relative;
  width: 100%;
}
#top_item .sp-slide img{
  position: absolute!important;
  top: 0px!important;
  left: 0px!important;
  width: 30%!important;
  margin-left: 0px!important;
  margin-top: 0px!important;
  height: auto!important;

}
#top_item .mainimage_caption{
  position: absolute;
  top: 0px;
  right: 0px;
  width: 70%;
}
#top_item .mainimage_caption h3{
  margin-top: 10px;
  font-size: 110%;
  font-weight: bold;
  margin-bottom: 5px;
}
#top_item .mainimage_caption span{
  display: block;
  font-size: 85%;
  line-height: 1.5em;
  margin-bottom: 10px;
}
#top_item .mainimage_caption p{
  font-size: 90%;
  line-height: 1.2em;
}
#bnr_top .sp-black{ background:none; color: #333; padding-left: 15px;}
@media screen and (max-width: 767px) {
  #top_item .sp-slide,
  #top_item .sp-image-container,
  #top_item .sp-mask,
  #top_item .sp-grab{
    /*height: 150px!important;*/
  }
}
@media print, screen and (min-width: 768px) {
  #top_item .mainimage_caption h3{
    font-size: 130%;
    margin-bottom: 10px;
  }
  #top_item .mainimage_caption p{
    font-size: 100%;
    line-height: 1.5em;
  }
  #bnr_top .sp-black{padding-left: 30px;}
}
@media print, screen and (min-width: 992px) {
  #top_item .mainimage_caption h3{
    font-size: 150%;
  }
}


/* nmn.html（NMNの紹介）
---------------------------------------------------- */
.bg_nmn01 {
    background: url("../images/bg_nmn01.jpg") no-repeat center;
    background-size: cover;
    padding: 40px 0px;
    text-align: center;
    color: #fff;
}
.bg_nmn01 h3 {
    font-size: 120%;
    font-weight: bold;
    margin-bottom: 15px;
}
@media print, screen and (min-width: 768px) {
    .bg_nmn01 {
        padding: 50px 0px;
    }
    .bg_nmn01 h3 {
        font-size: 140%;
    }
}
@media print, screen and (min-width: 992px) {
    .bg_nmn01 {
        padding: 80px 0px;
    }
    .bg_nmn01 h3 {
        font-size: 150%;
    }
}

.bg_nmn02 {
    background: url("../images/bg_nmn02.jpg") no-repeat center;
    background-size: cover;
    padding: 40px 0px;
    color: #fff;
}
.bg_nmn02 h3 {
    font-size: 120%;
    font-weight: bold;
    margin-bottom: 15px;
}
@media print, screen and (min-width: 768px) {
    .bg_nmn02 {
        padding: 50px 0px;
    }
    .bg_nmn02 h3 {
        font-size: 140%;
    }
}
@media print, screen and (min-width: 992px) {
    .bg_nmn01 {
        padding: 80px 0px;
    }
    .bg_nmn01 h3 {
        font-size: 150%;
    }
}


/* product.html（健康食品・サプリメント開発）
---------------------------------------------------- */
.product_flow{
  border: 1px solid #ddd;
  padding: 15px;
}
.product_flow dt{
  margin-bottom: 10px;
  font-size: 110%;
}
@media print, screen and (min-width: 768px) {
  .product_flow{
    padding: 20px;
  }
}
@media print, screen and (min-width: 992px) {
  .product_flow{
    padding: 30px;
  }
}


/* about.html（こだわりの原料・オリジナル商品）
---------------------------------------------------- */
.about_item {
    background-color: #fff;
    border: 1px solid #ccc;
    padding: 15px;
    margin-bottom: 30px;
}
.about_item h3 {
    margin-top: 10px;
    font-size: 130%;
}
.about_item h4 {
    font-size: 120%;
    font-weight: bold;
}
.about_item p {
    margin-top: 10px;
}
@media print, screen and (min-width: 768px) {
    .about_item {
        padding: 20px;
        margin-bottom: 50px;
    }
}
@media print, screen and (min-width: 992px) {
    .about_item {
        padding: 40px;
        margin-bottom: 80px;
    }
}


/* news.html（ニュース）
---------------------------------------------------- */
.news{
  height: 400px;
  overflow: auto;
}

.news_item {
    border-bottom: 1px solid #666;
    padding: 15px 0px;
    display: table;
    width: 100%;
}
.news_item_date {
    display: table-cell;
    width: 15%;
    text-align: center;
}
.news_item_date dt {
    font-size: 200%;
    font-weight: normal;
}
.news_item_date dd {
    font-size: 80%;
}
.news_item_text {
    display: table-cell;
    vertical-align: top;
    width: 85%;
    padding-left: 15px;
}
.news_item_text dt {
    font-weight: normal;
    margin-bottom: 10px;
}
.news_item_text dt span {
    font-family: 'Kurale';
    font-size: 80%;
    font-weight: normal;
    margin-left: 10px;
    color: #ed5656;
}
@media print, screen and (min-width: 768px) {
    .news_item {
        padding: 30px 0px;
    }
    .news_item_text dt {
        font-size: 110%;
    }
}
@media print, screen and (min-width: 992px) {
    .news_item {
        padding: 50px 0px;
    }
}


/* company.html（会社概要）
---------------------------------------------------- */
.bg_company01 {
    background: url("../images/bg_company01.jpg") no-repeat center;
    background-size: cover;
    padding: 40px 0px;
}
.bg_company01 h3 {
    font-size: 120%;
    font-weight: bold;
    margin-bottom: 15px;
}
@media print, screen and (min-width: 768px) {
    .bg_company01 {
        padding: 50px 0px;
    }
    .bg_company01 h3 {
        font-size: 170%;
        margin-bottom: 20px;
    }
}
@media print, screen and (min-width: 992px) {
    .bg_company01 {
        padding: 80px 0px;
    }
    .bg_company01 h3 {
        font-size: 200%;
        margin-bottom: 30px;
    }
}

.company_contact {
    background-color: #fff;
    padding: 15px;
}
@media print, screen and (min-width: 768px) {
    .company_contact {
        padding: 20px;
    }
}
@media print, screen and (min-width: 992px) {
    .company_contact {
        padding: 40px;
    }
}





/* タイトル
---------------------------------------------------- */
#h2_nmn {
    background: url("../images/bg_h2_nmn.jpg") no-repeat center;
    background-size: cover;
}
#h2_product {
    background: url("../images/bg_h2_product.jpg") no-repeat center;
    background-size: cover;
}
#h2_about {
    background: url("../images/bg_h2_about.jpg") no-repeat center;
    background-size: cover;
}
#h2_company{
    background: url("../images/bg_h2_company.jpg") no-repeat center;
    background-size: cover;
}
.h2-style {
    padding: 40px 0px;
}
.h2-style h2 {
    font-size: 120%;
    font-weight: normal;
    text-align: center;
    font-weight: bold;
    text-shadow: 
      #fff 1px 1px 10px, #fff -1px 1px 10px,
      #fff 1px -1px 10px, #fff -1px -1px 10px;
}
@media print, screen and (min-width: 768px) {
    .h2-style {
        padding: 50px 0px;
    }
    .h2-style h2 {
        font-size: 150%;
    }
}
@media print, screen and (min-width: 992px) {
    .h2-style {
        padding: 80px 0px;
    }
    .h2-style h2 {
        font-size: 200%;
    }
}

.h3-style {
    text-align: center;
    margin-bottom: 20px;
}
.h3-style h3 {
    position: relative;
    display: inline-block;
    padding: 0 60px;
    font-size: 120%;
    color: #3e8dcf;
}
.h3-style h3:before,
.h3-style h3:after {
    content: '';
    position: absolute;
    top: 50%;
    display: inline-block;
    width: 45px;
    height: 2px;
    background-color: #3e8dcf;
}
.h3-style h3:before {
    left: 0;
}
.h3-style h3:after {
    right: 0;
}
@media print, screen and (min-width: 768px) {
    .h3-style {
        margin-bottom: 25px;
    }
    .h3-style h3 {
        padding: 0 90px;
        font-size: 180%;
    }
    .h3-style h3:before,
    .h3-style h3:after {
        width: 70px;
    }
}
@media print, screen and (min-width: 992px) {
    .h3-style {
        margin-bottom: 30px;
    }
    .h3-style h3 {
        padding: 0 100px;
        font-size: 200%;
    }
    .h3-style h3:before,
    .h3-style h3:after {
        width: 80px;
    }
}

.title01 {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 500;
    font-size: 120%;
    border-left: solid 2px #3e8dcf;
    padding: 10px 0px 10px 15px;
    margin-bottom: 15px;
}
@media print, screen and (min-width: 768px) {
    .title01 {
        font-size: 130%;
    }
}
@media print, screen and (min-width: 992px) {
    .title01 {
        font-size: 170%;
    }
}


/* table
---------------------------------------------------- */
.table-style {
    width: 100%;
}
.table-style th {
    display: block;
    text-align: left;
    font-weight: bold;
    padding: 5px 0px 0px;
}
.table-style td {
    display: block;
    padding: 0px 0px 5px;
    border-bottom: 1px solid #ddd;
}
@media print, screen and (min-width: 768px) {
    .table-style th {
        display: table-cell;
        vertical-align: middle;
        padding: 10px;
        width: 35%;
        border-bottom: 1px solid #ddd;
    }
    .table-style td {
        display: table-cell;
        padding: 10px;
    }
}
@media print, screen and (min-width: 992px) {
    .table-style th {
        padding: 15px;
        font-size: 105%;
    }
    .table-style td {
        padding: 15px;
    }
}

.table-style2 {
    width: 100%;
}
.table-style2 th {
    display: block;
    padding: 10px 0px 5px 0px;
}
.table-style2 td {
    display: block;
    padding: 0px 0px 10px 0px;
    border-bottom: 1px solid #ddd;
}
@media print, screen and (min-width: 768px) {
    .table-style2 th {
        display: table-cell;
        vertical-align: middle;
        width: 25%;
        border-bottom: 1px solid #ddd;
        padding: 5px 10px;
    }
    .table-style2 td {
        display: table-cell;
        padding: 5px 10px;
    }
}
@media print, screen and (min-width: 992px) {
    .table-style2 td {
        padding: 10px 15px;
    }
}


/* ボタン
---------------------------------------------------- */
.btn-style {
    display: block;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: bold;
    line-height: normal;
    background-color: #3e8dcf;
    border: 2px solid #3e8dcf;
    padding: 10px 10px;
    text-align: center;
    -webkit-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
}
.btn-style:link,
.btn-style:visited,
.btn-style:active {
    color: #fff;
    text-decoration: none
}
.btn-style:hover {
    color: #3e8dcf;
    border: 2px solid #3e8dcf;
    background-color: #fff;
}
.btn-style i {
    float: right;
    padding-top: 5px
}
@media print, screen and (min-width: 992px) {
    .btn-style {
        padding: 15px 10px;
    }
}

.btn-detail {
    display: inline-block;
    border: 2px solid #111;
    background-color: #111;
    padding: 5px 10px;
    line-height: normal;
    border-radius: 30px;
    -webkit-transition: all 0.3s ease 0s;
    transition: all 0.3s ease 0s;
}
.btn-detail:link,
.btn-detail:visited {
    color: #fff;
    text-decoration: none;
}
.btn-detail:hover {
    border: 2px solid #111;
    background-color: #fff;
    color: #111;
}
.btn-detail i {
    margin-right: 5px;
}
@media print, screen and (min-width: 992px) {
    .btn-detail {
        padding: 10px;
        display: inline-block;
        margin-right: 20px;
    }
}

/* 戻るボタン */
.btn-back {
    margin-top: 20px;
    background-color: #007440;
    padding: 10px 0px;
    text-align: center;
    display: block;
    border-radius: 50px;
}
.btn-back:link,
.btn-back:visited {
    color: #fff;
    text-decoration: none
}
.btn-back:before {
    content: " \f104";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    line-height: 1.5em;
    padding-right: 10px
}
@media print, screen and (min-width: 768px) {
    .btn-back {
        margin-top: 30px;
    }
    .btn-back {
        padding: 10px 40px;
        display: inline;
    }
}

/* マップへのボタン */
.btn-map {
    background-color: #333;
    border-radius: 50px;
    padding: 10px 0px;
    text-align: center;
    display: block;
}
.btn-map:link,
.btn-map:visited {
    color: #fff;
    text-decoration: none
}
.btn-map:before {
    content: " \f3c5";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    line-height: 1.5em;
    padding-right: 5px
}
@media (min-width: 768px) {
    .btn-map {
        margin-top: 12px;
        text-align: right
    }
    .btn-map {
        padding: 10px 40px;
        display: inline;
    }
}


/* CMSページ関係
---------------------------------------------------- */
/* 縦横比固定 */
.photo-ofi {
    height: 0;
    display: block;
    padding-bottom: 75%;
    /* 高さを指定（ボックスの横幅を基準） */
    /*background-color: #EFEFEF;*/
    overflow: hidden;
    position: relative;
    /*margin-bottom: 10px;*/
}
.photo-ofi img {
    max-width: inherit;
    max-height: inherit;
    width: 100%;
    height: 100%;
    -o-object-fit: scale-down;
    object-fit: scale-down;
    font-family: 'object-fit: scale-down;';
    position: absolute;
    left: 0;
    top: 0;
}

/* paging */
div.paging {
    text-align: center;
}
div.paging span.current,
div.paging span.paging-text {
    margin: 0px;
    background-color: #fff;
    border: 1px solid #111;
    color: #333;
    display: inline;
    zoom: 1;
    display: inline-block;
    overflow: hidden;
    text-decoration: none;
}
div.paging span.paging-text a {
    padding: 2px 8px;
    display: block;
    color: #333;
}
div.paging span.current {
    background-color: #111;
    color: #fff;
    display: inline;
    zoom: 1;
    padding: 2px 8px;
    text-decoration: none;
    display: inline-block;
    cursor: pointer;
}
div.paging span.paging-text a:hover {
    background: #111;
    color: #fff;
    text-decoration: none;
    cursor: pointer;
}
@media print, screen and (min-width: 768px) {
    div.paging span.paging-text a {
        padding: 5px 10px;
    }
    div.paging span.current {
        padding: 5px 10px;
    }
}


/* form
---------------------------------------------------- */
.table_form {
    width: 100%;
    border-collapse: collapse;
    background-color: #fff;
    border-bottom: 1px solid #ddd;
}
.table_form th {
    border-top: 1px solid #ddd;
    border-left: 1px solid #ddd;
    border-right: 1px solid #ddd;
    padding: 10px;
    background-color: #f1f1f1;
    vertical-align: top;
    text-align: left;
    display: block;
}
.table_form td {
    border-left: 1px solid #ddd;
    border-right: 1px solid #ddd;
    padding: 10px;
    display: block;
}
@media print, screen and (min-width: 768px) {
    .table_form th {
        padding: 15px;
        vertical-align: middle;
        display: table-cell;
        width: 30%;
    }
    .table_form td {
        border-top: 1px solid #ddd;
        padding: 15px;
        display: table-cell;
    }
}

/* 必須・任意 */
p.need:before {
    content: "必須";
    background-color: #c00;
    color: #fff;
    padding: 3px 5px;
    font-size: 11px;
    font-weight: normal;
    margin-right: 5px;
    vertical-align: middle;
    border-radius: 3px;
}
.table_form th.need:after {
    content: "必須";
    background-color: #c00;
    color: #fff;
    padding: 3px 5px;
    font-size: 11px;
    font-weight: normal;
    line-height: normal;
    vertical-align: middle;
    float: right;
    border-radius: 3px;
}
.table_form th.any:after {
    content: "任意";
    background-color: #999;
    color: #fff;
    padding: 3px 5px;
    font-size: 11px;
    font-weight: normal;
    line-height: normal;
    vertical-align: middle;
    float: right;
    border-radius: 3px;
}
.need input[type="text"],
.need input[type="password"],
.need select,
.need textarea {
    border: 1px solid #fcc;
    /*background-color:#fee;*/
    padding: 14px;
}
.need input[type="text"]:focus,
.need input[type="password"]:focus,
.need select:focus,
.need textarea:focus {
    border: 1px solid #f66;
}

/* テキストボックスのサイズ */
.form-xs {
    width: 60px;
}
.form-s, .form-m, .form-l, .form100 {
    width: 100%
}
.form-h {
    width: 100%;
    height: 100px;
}
@media print, screen and (min-width: 768px) {
    .form-s {
        width: 200px
    }
    .form-m {
        width: 300px
    }
    .form-l {
        width: 100%
    }
    .form-h {
        width: 100%;
        height: 150px;
    }
}

/* フォーム関係タグの初期設定とデザイン */
input[type="checkbox"], input[type="radio"] {
    vertical-align: text-top;
}
input[type="text"] {
    font-size: 100%;
    vertical-align: middle;
    padding: 14px;
}
textarea {
    width: 95%;
    height: 100px;
}
input[type="text"],
input[type="password"],
select,
textarea {
    border: 1px solid #ddd;
    /*background-color:#eee;*/
    padding: 14px;
    border-radius: 4px
}
input[type="text"]:focus,
input[type="password"]:focus,
select:focus,
textarea:focus {
    border: 1px solid #999;
}
label {
    font-weight: normal
}

/* ラジオボタンのデザイン */
input[type="radio"] {
    display: none;
    width: 20px;
    height: 20px;
}
input[type="radio"]+label {
    display: inline;
    font-size: 100%;
    border: 1px solid #333;
    border-radius: 30px;
    padding: 5px 10px;
    background: #fff;
    color: #333;
    line-height: 2.5em;
    cursor: pointer;
}
input[type="radio"]:checked+label {
    background: #333;
    color: #fff;
}

/* チェックボックスのデザイン */
input[type="checkbox"]+label {
    padding-left: 40px;
    display: inline-block;
    cursor: pointer;
    position: relative;
}
input[type="checkbox"]+label:before {
    content: '';
    width: 30px;
    height: 30px;
    display: inline-block;
    position: absolute;
    left: 0;
    background-color: #fff;
    border: 1px solid #666;
    border-radius: 5px;
}
input[type="checkbox"] {
    display: none;
}
input[type="checkbox"]:checked+label:before {
    content: "\f00c";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 20px;
    color: #fff;
    background-color: #666;
    vertical-align: middle;
}

/* placeholder */
::-webkit-input-placeholder {
    color: #999;
    opacity: 1;
}
:-moz-placeholder {
    color: #999;
}
::-moz-placeholder {
    color: #999;
    opacity: 1;
}
:-ms-input-placeholder {
    color: #999;
}

/* プライバシーポリシー */
.contact_privacy {
    margin: 20px 0px;
    height: 300px;
    overflow: auto;
    font-size: 90%;
    line-height: 1.5em;
    /*background-color:#eee;*/
    border: 1px solid #ccc;
    padding: 15px;
}
.contact_privacy h3 {
    font-size: 140%;
    text-align: center;
    line-height: normal;
    margin-bottom: 10px;
}
.contact_privacy h3 span {
    display: block;
    font-size: 80%;
    font-weight: bold;
}
.contact_privacy h4 {
    margin-top: 15px;
    overflow: hidden;
    font-size: 100%;
    font-weight: bold;
    margin-bottom: 10px
}
.contact_privacy h4 span {
    position: relative;
    display: inline-block;
    margin-right: 0 2.5em;
    padding-right: 0.5em;
    text-align: left;
}
.contact_privacy h4 span::before,
.contact_privacy h4 span::after {
    position: absolute;
    top: 50%;
    content: '';
    width: 800%;
    height: 1px;
    background-color: #333;
}
.contact_privacy h4 span::before {
    right: 100%;
}
.contact_privacy h4 span::after {
    left: 100%;
}
.contact_privacy ol {
    margin-left: 20px;
}
@media print, screen and (min-width: 768px) {
    .contact_privacy {
        margin: 30px 0px;
        padding: 20px;
    }
    .contact_privacy h3 {
        font-size: 150%;
        margin-bottom: 20px;
    }
}
@media print, screen and (min-width: 992px) {
    .contact_privacy {
        padding: 30px;
    }
}

/* buttonのデザイン */
input[type="button"], input[type="submit"] {
    -webkit-appearance: none;
    border-radius: 0;
}
/*iosのグラデ、角丸解除*/
.submit {
    width: 100%;
    display: block;
    background-color: #3e8dcf;
    border: 1px solid #3e8dcf;
    color: #fff;
    font-weight: normal;
    cursor: pointer;
    padding: 10px 20px;
    border-radius: 30px;
}
@media print, screen and (min-width: 768px) {
    .submit {
        width: auto;
        display: inline;
        padding: 20px 50px;
        height: auto;
        border-radius: 40px;
    }
}
@media print, screen and (min-width: 992px) {
    .submit {
        padding: 20px 80px;
    }
}


/* googlemap
---------------------------------------------------- */
.access iframe {
    height: 300px;
}
@media print, screen and (min-width: 768px) {
    .access iframe {
        height: 450px;
    }
}


/* common
---------------------------------------------------- */
a:hover img {
    opacity: 0.8;
    filter: alpha(opacity=80);
}

iframe {
    vertical-align: bottom;
}

.f-left {
    float: left;
}
.f-right {
    float: right;
}

.lsn {
    list-style: none;
}
.block {
    display: block
}
.bold {
    font-weight: bold;
}
.indent {
    text-indent: -1em;
    margin-left: 1em;
}

@media print, screen and (min-width: 768px) {
    .tac-sm {
        text-align: center;
    }
}

/* フォントサイズ */
.small-xxs {
    font-size: 70%;
}
@media print, screen and (min-width: 768px) {
    .small-xxs {
        font-size: 100%;
    }
}
.small-xs {
    font-size: 80%;
}
@media print, screen and (min-width: 768px) {
    .small-xs {
        font-size: 100%;
    }
}
.small {
    font-size: 85%;
    line-height: 1.5em;
    font-weight: normal
}
.regular {
    font-size: 100%;
}
.middle {
    font-size: 110%;
    line-height: 1.5em;
}
@media print, screen and (min-width: 768px) {
    .middle {
        font-size: 120%;
        line-height: 1.8em;
    }
}
@media print, screen and (min-width: 992px) {
    .middle {
        font-size: 130%;
        line-height: 1.8em;
    }
}
.large {
    font-size: 130%;
    line-height: normal;
}
@media print, screen and (min-width: 768px) {
    .large {
        font-size: 150%;
    }
}
@media print, screen and (min-width: 992px) {
    .large {
        font-size: 170%;
    }
}
.x-large {
    font-size: 140%;
}
@media print, screen and (min-width: 768px) {
    .x-large {
        font-size: 180%;
    }
}
@media print, screen and (min-width: 992px) {
    .x-large {
        font-size: 240%;
    }
}

/* カラー */
.red {
    color: #c00;
}
.blue {
    color: #3e8dcf;
}

/* サイズ指定 */
.w-25 {
    width: 25%
}
.w-30 {
    width: 30%
}
.w-40 {
    width: 40%
}
.w-48 {
    width: 48%
}
.w-50 {
    width: 50%
}
.w-60 {
    width: 60%
}
.w-70 {
    width: 70%
}
.w-80 {
    width: 80%
}

.mb05 {
    margin-bottom: 5px
}
.mb10 {
    margin-bottom: 10px
}
.mb15 {
    margin-bottom: 15px
}
.mb20 {
    margin-bottom: 20px
}
.mb30 {
    margin-bottom: 30px
}
.mb40 {
    margin-bottom: 40px
}
.mb50 {
    margin-bottom: 50px
}
.mb60 {
    margin-bottom: 60px
}
.mb70 {
    margin-bottom: 70px
}
.mb80 {
    margin-bottom: 80px
}
.mt10 {
    margin-top: 10px
}
.mt20 {
    margin-top: 20px
}
.ml05 {
    margin-left: 5px
}
.ml10 {
    margin-left: 10px
}
.ml20 {
    margin-left: 20px
}
.mr05 {
    margin-right: 5px
}
.mr10 {
    margin-right: 10px
}

.mb-xs {
    margin-bottom: 15px;
}
@media print, screen and (min-width: 768px) {
    .mb-xs {
        margin-bottom: 0px;
    }
    /*解除*/
}

.mbottom {
    margin-bottom: 30px;
}
@media print, screen and (min-width: 768px) {
    .mbottom {
        margin-bottom: 50px;
    }
}
@media print, screen and (min-width: 992px) {
    .mbottom {
        margin-bottom: 90px;
    }
}
.mbottom2 {
    margin-bottom: 10px;
}
@media print, screen and (min-width: 768px) {
    .mbottom2 {
        margin-bottom: 20px;
    }
}
@media print, screen and (min-width: 992px) {
    .mbottom2 {
        margin-bottom: 30px;
    }
}



/*==========================    全画面用   ===============================*/

#fade-nav1 {overflow-y: auto;background:rgba(0,0,0,0.5) ;border-radius: 15px;padding: 15px;margin: 15px;height: 260px;position: fixed;color: #fff;top: 0;left: 0;right: 0;bottom: 0;z-index: -1;font-size: 14px;opacity: 0;-webkit-transition: opacity .6s ease, visibility .6s ease;transition: opacity .6s ease, visibility .6s ease;}
#fade-nav1 li{list-style: none;}
#fade-nav1 a {color: #fff;display: block;text-align: center;padding: 10px;}
.open1 {overflow: hidden;}
.open1 #fade-nav1 {visibility: visible;opacity: 0.95;z-index: 990;}
.closeBtn1{position: absolute;top: 15px;right: 15px;}

#toggle2 { font-size: 25px; float: right; margin-top: 5px;}
#fade-nav2 {overflow-y: auto;background:rgba(0,0,0,0.5) ;border-radius: 15px;padding: 15px;margin: 15px;height: 355px;position: fixed;color: #fff;top: 0;left: 0;right: 0;bottom: 0;z-index: -1;font-size: 14px;opacity: 0;-webkit-transition: opacity .6s ease, visibility .6s ease;transition: opacity .6s ease, visibility .6s ease;}
#fade-nav2 li{list-style: none;}
#fade-nav2 a {color: #fff;display: block;text-align: center;padding: 10px;}
.open2 {overflow: hidden;}
.open2 #fade-nav2 {visibility: visible;opacity: 0.95;z-index: 990;}
.closeBtn2{position: absolute;top: 15px;right: 15px;}

@media print, screen and (min-width: 768px) {
  #fade-nav1,
  #fade-nav2{ display: none;}
}

.header_lang {height: 24px;position: relative;float: right;margin-top: 10px; z-index: 999999;}
.header_lang:after{ contents:"";clear:both; display:block;}
.header_lang a {border: 1px solid #999;padding: 5px 10px;font-size: 75%;color: #333;margin: 0px 5px; line-height: 100%;}
.header_lang ul { padding: 0px; width: 100%; margin: 2px 0px 0px;}
.header_lang li{ height: 0px; overflow: hidden; transition: .5s;list-style: none;}
.header_lang li a{ display: block;background:rgba(255,255,255,0.9);}
.header_lang:hover li{ height: 24px;  overflow: visible;}


.img-ren {
    image-rendering: -webkit-optimize-contrast;
}

.br_20220609 p {
    word-break: break-all;
}