@charset "utf-8";
/* CSS Document */
body {
    font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
/*カラー////////////////////////////////////////////////////////////////*/
/*メインカラー*/
#reason ol li::before,.StrongMainC,footer,.footer_menu,.mod li a{
    background: #5e4632;
}
h1,h2,h3,.head_after,#reason ol,#price ul,.FlowBg1,.FlowBg2::after,#PcNav a:link,#PcNav a:visited{
    color: #5e4632;
}
/*アクセントカラーたち*/
.StrongAccentC{
    background: #D6000F;
}
.FlowBg1,.swiper-pagination-bullet-active{
    background: #FFFFAA;
}
.swiper-button-next,.swiper-button-prev{
    color: #FFFFAA;
}

.FlowBg2{
    background: #F2EEDC;
}

/*共通スタイル/////////////////////////////////////////////////////*/
#logo,.ContentsWidth{
    margin-left: auto;
    margin-right: auto;
}
h1,h2,.head_after{
    display: block;
    text-align: center;
}
/*クラススタイル/////////////////////////////////////////////////////*/
.flexbox{
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
}
.ContentsWidth{
    width: 90%;
}
.StrongMainC,.StrongAccentC{
    padding: 0.25em 1em;
    color: white;
    font-size: 0.9em;
    display: inline-block;
    margin-right: 0.5em;
}
.PC{
    display: none;
}
.head_after{
    font-size: 1.25em;
}
.head_after span{
    display: inline-block;
}
/*ベーススタイル////////////////////////////////////////////////////*/
p,small{
    line-height: 1.5;
}
ul,ol{
        text-align: left;
    line-height: 1.5;
}
p,ol,ul{
    margin-bottom: 1em;
}
ul{
    padding-left: 1em;
}
small{
    font-size: 0.9em;
    display: inline-block;
    text-align: left;
}
.under{
      margin: 1em 1em 0 1em;

}
/*見出し/////////////////////////////////////////////////////////*/
h1{
    margin-bottom: 1em;
    font-size: 1.25em;
    width: 100%;
    line-height: 1.5;
}
h2{
    font-size: 2em;
    margin-bottom: 1em;
    border-bottom: solid 1px #5e4632;
    padding-bottom: 0.125em;
    line-height: 1.5;
}
h2 span{
    margin-left: 0.5em;
    font-size: 0.6em;
}
h3{
    font-size: 1.4em;
    margin-bottom: 0.4em;
}

/*ヘッダー//////////////////////////////////////////////////////*/
#main_header{
padding:5px 2.5%;
}
#logo {
    margin-bottom: 0;
    line-height: 0;
}
#logo img{
    height: 60px;
    width: auto;
}
#main_header .flexbox{
}
#PcNav,#main_header address{
    display: none;
}
/*メインビジュアル///////////////////////////////////////////////////*/
#MainVisual{
    margin-bottom: 2em;
}
.swiper-slide img {
    max-height: 600px;
    object-fit: cover;
    object-position: center;
}
.swiper-button-next,.swiper-button-prev{
    font-size: 25px;
    background-image: none;
}
/*フェイスブック///////////////////////////////////////////////////*/
#facebook{
    width: 100%;
    margin-bottom: 2em;
    text-align: center;
}

.banner {
    text-align: center;
  }

  .banner figure img {
    width: 50vw;
    margin: 30px auto;
  }



/*reason/////////////////////////////////////////////*/
#reason{
    text-align: center;
}
#reason ol{
    display: inline-block;
    text-align: left;
    font-weight: bold;
    list-style: none;
    counter-reset: li_count;    /* カウンタをセット */
}
#reason ol li{
    margin-bottom: 1em;
    position: relative;
    padding: 0em 0 0em 2em;
}
#reason ol li::before{
    position: absolute;
    left: 0;
    top: 0;
    counter-increment: li_count;
    content: counter(li_count);
    color: white;
    border-radius: 50%;
    width: 1.5em;
    height: 1.5em;
    display: inline-block;
    line-height: 1;
    padding-top: 0.25em;
    text-align: center;
}
/*price ///////////////////////////;*/
#price{
    text-align: center;
}
#price h3{
    text-align: center;
    height: 0.em;
}
#price img {
    max-width: 600px;
}
#price ul{
    display: inline-block;
    list-style-type: square;
    font-weight: bold;
}
/*メニュー/////////////////////////////*/
#menu>div>section{
    padding-top: 3em;
    position: relative;
}
#menu figure{
    margin-bottom: 0.5em;
    width: 100%;
}
#menu img{
    width: 100%;
    max-height: 400px;
}
#menu h3{
    padding-left: 0.5em;
    border-left: solid 5px #5e4632;
    position: absolute;
    top:0;
}
#menu div.ColumnLeft figure{
    width: 48.75%;
}


/*スタッフ////////////////////////////*/
#staff section{
    margin-bottom: 2em;
}
#staff figure{
    float: left;
    width: 40%;
}
#staff h3{
    margin-bottom: 0.25em;
}
#staff h3,#staff ul{
    float: right;
    width: 55%;
    list-style: square;
}
#staff ul{
        font-size: 0.9em;
}
#staff p{
    clear: both;
}
/*Flow///////////////////////*/
#flow>div>div{
    margin-bottom: 1em;
    text-align: center;
}
#flow ul{
    padding: 1em 1em 1em 2em;
    font-weight: bold;
    display: inline-block;
    margin-bottom: 0;
}
.FlowBg2{
    padding: 1em 1em;
    margin-bottom: 3em;
    position: relative;
}
.FlowBg2 p{
    margin-bottom: 0;
}
.FlowBg2::after{
    content: "▼";
    position: absolute;
    bottom: -2em;
    font-size: 20px;
    display: block;
    text-align: center;
    width: 100%;
    left: 0;
}
#flow h3{
    font-size: 1.5em;
    margin-bottom: 0.125em;
}
#flow>div .FlowBg2:last-child::after{
    display: none;
}
/*院内紹介/////////////////////////////*/
#intro{
    text-align: center;
}
#intro section{
    margin-bottom: 1em;
}
#intro .img_wrap{
    margin-bottom: 0.25em;
}
#intro img{
    max-height: 500px;
}
#intro h3{
    margin-bottom: 0.125em;
}
/*アクセス/////////////////////////////////*/
#access{
    text-align: center;
}
#access strong{
    font-size: 1.25em;
}
#access p>img{
    max-width: 500px;
    margin-bottom: 1em;
}
#access address{
    margin-bottom: 1em;
}
#access #btns{
    width: 250px;
    margin: auto;
}
#access #btns ul{
    list-style: none;
    padding: 0;
}
#access #btns li{
    margin-bottom: 1em;
}
#GoogleMap iframe{
    max-width: 100%;
    margin-bottom: 2em;
}
/*フッター*/
footer{
    color: white;
    padding: 1em;
    text-align: center;
    padding-bottom: 90px;
}
footer p{
    margin: 0;
}
/*カスタムフッターナビ*/
ul.footer_menu{
    padding: 5px 0;
}
ul.footer_menu li{
    font-size: 11px;
}
ul.footer_menu li a i{
    font-size: 40px;
}
.modal-window .modal-close:after{
 top:20px;
}
.modal-window .modal-inner{
    top: 50px;
}
/*PC//////////////////////////////////////////////////////////*/
@media screen and (min-width: 960px){
    html {
  scroll-padding-top: 90px; /* 固定ヘッダの高さ分 */
}
    main{
        padding-top: 90px;
    }
    .SP,ul.footer_menu{
        display: none;
    }
    .PC{
        display: block;
    }
    .ContentsWidth{
        width: 900px;
    }
    #title_face{
        justify-content: space-around;
    }
    #title_face h1,#title_face aside{
        width: 50%
    }
    h1{
        font-size: 1.5em;
        line-height: 2;
    }
    h2{
        margin-bottom: 1.5em;
        margin-top: 1em;
        font-size: 2.25em;
    }
    .head_after{
        margin-bottom: 1.5em;
    }
    #reason ol{
        font-size: 1.25em;
    }
    /*ヘッダー*/
    #main_header{
        width: 100%;
        padding: 10px 1.25%;
        position: fixed;
        top:0;
        z-index: 9;
    background: white;
    }
    .MaxWidth{
        max-width: 1200px;
        margin: auto;
    }
    header p{
        margin: 0;
    }
    #main_header address img{
        object-fit: contain;
    }
    #PcNav,#main_header address{
        display: block;
    }
    #logo{
        margin: 0;
    }
    #logo img{
        width: 100%;
        object-fit: contain;
    }
    #PcNav{
        width: 60%;
    }
    #PcNav ul{
        list-style: none;
        margin-bottom: 0;
    }
    #PcNav a:link{
        text-decoration: none;
        font-weight: bold;
    }
    #logo,header address{
        width: 18%;
    }



/*メニュー */
    #menu>div>section{
        align-items: flex-start;
        padding-top: 0;
        margin-bottom: 2em;
    }
    #menu .ColumnLeft{
        width: 33%;
    }
    #menu .ColumnRight{
        width: 63%
    }
    #menu h3{
        position: relative;
    }
    #menu div.ColumnLeft figure{
        width: 100%;
    }
/*スタッフ*/
    #staff p{
        clear: none;
    }
    #staff section{
        clear: both;
        margin-bottom: 2em;
            overflow: hidden;
    }
    #staff h3, #staff ul,#staff p{
        float: right;
        width: 75%
    }
    #staff figure{
        width: 22%;
    }
/*    flow*/
    .FlowBg2{
        padding: 1.5em 6em;
    }
    #flow ul{
        font-size: 1.25em;
    }
  /*  院内案内*/
    #intro>div{
        align-items: flex-start;
    }
    #intro>div>section{
        width: 48.75%;
    }
/*    アクセス*/
    #access>div>p{
        margin-bottom: 2em;
    }
    #access #btns{
width: 100%;
    }
    #btns ul{
        justify-content: space-around;
    }
    #btns li{
        width: 30%;
    }
    #btns li img{
        max-height: 150px;
        object-fit: contain;
    }
    #access iframe{
        width: 100%;
        height: 600px;
    }
    /*フッター*/
    footer{
        padding-bottom: 1em;
    }
}
/* 1st_anni */
.greetings{
  width: 80%;
  margin: 0 auto;
  padding: 35px;
}
.greetings p{
  line-height: 2em;
}
