@charset "UTF-8";

html{
  font-size: 62.5%;
  color: #045187;
  font-family:"Roboto Slab" , Garamond , "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;
  height: 100%;
}
body{
  height: 100%;
}
img{
  width: 100%;
}

/**************************************************
PC Layout
***************************************************/
@media screen and (min-width: 992px) {

  /*::::::::::::::::::::::
  MAIN_AREA
  ::::::::::::::::::::::*/
  #main_area{
    width: 100%;
    height: 100%;
    position: relative;
    /*background: url(../img/main_img_01.jpg);*/
    background-size: cover;
    background-attachment: fixed;
  }
  #main_area .main_logo{
    width: 275px;
    height: 235px;
    position: absolute;
    top: -70px;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
  }

  /*::::::::::::::::::::::
  NAV_AREA
  ::::::::::::::::::::::*/
  #navi_area{
    width: 100%;
    /*
    margin: -61px 0 0 0;
    position: absolute;
    */
    background: rgba(255,255,255,0.9);
    position: relative;
    z-index: 999;
  }
  #navi_area .nav_bar{
    width: 100%;
    display: flex;
    display: -webkit-flex;
    justify-content:space-around;
    -webkit-justify-content:space-around;
  }
  #navi_area .nav_bar a{
    width: 20%;
    text-align: center;
    font-size: 1.3rem;
    letter-spacing: 3px;
    padding: 25px 0;
    border-right: 1px solid #e8edf1;
    -webkit-transition: 0.5s ease-in-out;
    -moz-transition: 0.5s ease-in-out;
     -o-transition: 0.5s ease-in-out;
     transition: 0.5s ease-in-out;
  }
  #navi_area .nav_bar a:hover{
    color: #fff;
    background: #045187;
    border-right: 1px solid #CECECE;
  }
  #navi_area .tel{
    width: 300px;
    color: #fff;
    background: #045187;
    text-align: center;
    font-size: 1.3rem;
    letter-spacing: 3px;
    padding: 20px 0;
    line-height: 28px;
  }
  .sp_nav{
    display: none;
  }
  /*::::::::::::::::::::::
  MESSAGE
  ::::::::::::::::::::::*/
  #message{
    width: 100%;
    height: 500px;
    overflow: hidden;
  }
  #message .left{
    float: left;
    width: 50%;
    height: 500px;
    overflow: hidden;
    padding: 5% 5%;
    border-top: 1px solid #e8edf1;
  }
  #message .right{
    float: right;
    width: 50%;
    height: 500px;
    background-image: url(../img/mess_img.jpg);
    background-size: cover;
    z-index: 100;
    position: relative;
  }
  #message .left .title{
    font-size: 3.8rem;
    letter-spacing: 5px;
    position: relative;
  }
  #message .left .title::before{
    position: absolute;
    content: '';
    border-bottom: 3px solid #045187;
    width: 65px;
    top: 72px;
  }
  #message .left .txt{
    font-size: 1.3rem;
    letter-spacing: 0px;
    width: 100%;
    margin: 65px 0 0 0;
    line-height: 28px;
    text-align: justify;
  }


  /*::::::::::::::::::::::
  MENU
  ::::::::::::::::::::::*/
  #menu{
    width: 100%;
    height: 500px;
    overflow: hidden;
  }
  #menu .left{
    float: left;
    width: 50%;
    height: 500px;
    background-image: url(../img/menu_img.jpg);
    background-size: cover;
  }
  #menu .right{
    float: right;
    width: 50%;
    height: 500px;
    overflow: hidden;
    border-top: 1px solid #eee;
    padding: 7% 5%;
  }
  #menu .right .title{
    font-size: 3.8rem;
    letter-spacing: 5px;
    position: relative;
  }
  #menu .right .title::before{
    position: absolute;
    content: '';
    border-bottom: 3px solid #045187;
    width: 65px;
    top: 72px;
  }
  #menu .right .txt{
    font-size: 1.3rem;
    letter-spacing: 2px;
    width: 100%;
    margin: 65px 0 0 0;
    line-height: 28px;
  }
  #menu .right .txt span{
    font-size: 1.2rem;
  }
  #menu .menu_left {
    width: 50%;
    float: left;
  }
  #menu .menu_right {
    width: 30%;
    float: right;
  }
  #menu .min_txt{
    width: 100%;
    font-size: 1rem;
    /* margin: 20px 0 0 0; */
    overflow: hidden;
    padding: 15px 0 0 0;
  }

  /*::::::::::::::::::::::
  ACCESS
  ::::::::::::::::::::::*/
  #access{
    width: 100%;
    height: 500px;
    overflow: hidden;
  }
  #access .left{
    float: left;
    width: 50%;
    height: 500px;
    overflow: hidden;
    border-top: 1px solid #eee;
    padding: 7% 5%;
  }
  #access .right{
    float: right;
    width: 50%;
    height: 500px;
  }
  #access .left .title{
    font-size: 3.8rem;
    letter-spacing: 5px;
    position: relative;
  }
  #access .left .title::before{
    position: absolute;
    content: '';
    border-bottom: 3px solid #045187;
    width: 65px;
    top: 72px;
  }
  #access .left .txt{
    font-size: 1.3rem;
    letter-spacing: 2px;
    width: 100%;
    margin: 65px 0 0 0;
    line-height: 28px;
  }
  #map_canvas{
    width: 100%;
    height: 500px;
  }

  /*::::::::::::::::::::::
  INSTAGRAM
  ::::::::::::::::::::::*/
  #instagram{
    width: 100%;
    padding: 100px 0 70px;
    background: #e8ecef;
  }
  #instagram .title{
    width: 400px;
    text-align: center;
    margin: 0 auto;
    font-size: 3.8rem;
    letter-spacing: 5px;
    position: relative;
  }
  #instagram .title::before{
    position: absolute;
    content: '';
    border-bottom: 3px solid #045187;
    width: 65px;
    top: 80px;
    left: 170px;
  }
  #instagram .insta_box_pc{
    width: 90%;
    margin: 70px auto 0 auto;
  }
  #instagram .insta_box_sp{
    display: none;
  }

  /*::::::::::::::::::::::
  FOOTER
  ::::::::::::::::::::::*/
  footer{
	color: #333; 
	background: #e8ecef;
	padding: 100px 0 30px 0;
  }
  footer .foot_logo{
    width: 215px;
    margin: 48px auto 20px;
  }
  footer .sns{
    width: 92px;
    margin: 10px auto 15px;
    display: flex;
    display: -webkit-flex;
    justify-content:  space-around;
    -webkit-justify-content:  space-around;
  }
  footer .sns .insta{
    width: 32px;
  }
  footer .sns .fb{
    width: 32px;
  }
  footer .tel {
    font-size: 3.2rem;
    width: 100%;
    text-align: center;
    margin:5px 0 10px;
    letter-spacing: 5px;
  }
  footer .time{
    font-size: 1.4rem;
    width: 100%;
    text-align: center;
    margin: 20px 0 10px;
    letter-spacing: 4px;
  }
  footer .address{
    font-size: 1.4rem;
    width: 100%;
    text-align: center;
    margin: 10px 0;
    letter-spacing: 4px;
  }
  footer .mail{
    font-size: 1.4rem;
    width: 100%;
    text-align: center;
    margin: 10px 0;
    letter-spacing: 4px;
  }
  footer .copy{
    font-size: 1.4rem;
    width: 100%;
    text-align: center;
    margin: 65px 0 0px;
    letter-spacing: 4px;
  }
  .fa {
    margin: 0 5px 0 0;
    display: inline-block;
    font-family: FontAwesome;
    font-style: normal;
    font-weight: normal;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
}


/**************************************************
Tablet Layout
**************************************************/
@media screen and (max-width: 991px) {

  /*::::::::::::::::::::::
  MAIN_AREA
  ::::::::::::::::::::::*/
  #main_area{
    width: 100%;
    height: 100%;
    position: relative;
    background: url(../img/main_img_01_sp.jpg);
    background-size: contain;
    background-attachment: fixed;
  }
  #main_area .main_logo{
    width: 30%;
    height: 30%;
    position: absolute;
    top: 0px;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
  }

  /*::::::::::::::::::::::
  NAV_AREA
  ::::::::::::::::::::::*/
  
  #navi_area{
    display: none;
  }

  .sp_nav{
    background-color: #fff;
    text-align: center;
    width: 100%;
    display: flex;
    display: -webkit-flex;
  }
  .sp_nav a.sp_tel{
    background-color: #045187;
    text-align: center;
    display: block;
    font-size: 1.3rem;
    padding: 5% 5%;
    width: 50%;
    margin: 0 auto;
    border-right: 1px solid #045187;
    color: #fff;

  }
  .sp_nav a.sp_tel:hover{
    background-color: #045187;
    color: #fff;
  }

  .sp_nav a.sp_map{
    background-color: #fff;
    text-align: center;
    display: block;
    font-size: 1.3rem;
    padding: 5% 5%;
    width: 40%;
    margin: 0 auto;
    color: #045187;

  }
  .sp_nav a.sp_map:hover{
    background-color: #045187;
    color: #fff;
  }


  /*::::::::::::::::::::::
  MESSAGE
  ::::::::::::::::::::::*/
  #message{
    width: 100%;
    overflow: hidden;
  }
  #message .left{
    width: 100%;
    height: 100%;
    overflow: hidden;
    padding: 15% 10%;
    border-top: 1px solid #eee;
  }
  #message .right{
    width: 100%;
    height: 300px;
    background-image: url(../img/mess_img.jpg);
    background-size: cover;
    z-index: 100;
    position: relative;
    background-position:30% 60%;
  }
  #message .left .title{
    width: 100%;
    text-align: left;
    font-size: 2.8rem;
    letter-spacing: 8px;
    position: relative;
  }
  #message .left .title::before{
    position: absolute;
    content: '';
    border-bottom: 2px solid #333;
    width: 20%;
    top: 60px;
    left: 0;

  }
  #message .left .txt{
    font-size: 1.3rem;
    letter-spacing: 0px;
    width: 100%;
    margin: 50px 0 0 0;
    line-height: 28px;
    text-align: justify;
  }


  /*::::::::::::::::::::::
  MENU
  ::::::::::::::::::::::*/
  #menu{
    width: 100%;
    overflow: hidden;
  }
  #menu .left{
    width: 100%;
    height: 300px;
    background-image: url(../img/menu_img.jpg);
    background-size: cover;
    background-position:30% 60%;
  }
  #menu .right{
    width: 100%;
    overflow: hidden;
    border-top: 1px solid #eee;
    padding: 15% 10%;
  }
  #menu .right .title{
    font-size: 2.8rem;
    letter-spacing: 8px;
    position: relative;
  }
  #menu .right .title::before{
    position: absolute;
    content: '';
    border-bottom: 2px solid #333;
    width: 20%;
    top: 60px;
    left: 0;
  }
  #menu .right .txt{
    font-size: 1.4rem;
    letter-spacing: 2px;
    width: 100%;
    margin: 50px 0 0 0;
    line-height: 28px;
  }
  #menu .right .txt span{
    font-size: 1.2rem;
  }
  #menu .menu_left {
    width: 60%;
    float: left;
    overflow: hidden;
  }
  #menu .menu_right {
    width: 25%;
    float: right;
    overflow: hidden;
  }
  #menu .min_txt{
  	width: 100%;
    font-size: 1.2rem;
    padding: 15px 0 0 0;
    overflow: hidden;
  }

  /*::::::::::::::::::::::
  ACCESS
  ::::::::::::::::::::::*/
  #access{
    width: 100%;
    overflow: hidden;
  }
  #access .left{
    width: 100%;
    overflow: hidden;
    border-top: 1px solid #eee;
    padding: 15% 10%;
  }
  #access .right{
    width: 100%;
    height: 300px;
  }
  #access .left .title{
    font-size: 2.8rem;
    letter-spacing: 8px;
    position: relative;
  }
  #access .left .title::before{
    position: absolute;
    content: '';
    border-bottom: 2px solid #333;
    width: 20%;
    top: 60px;
    left: 0;
  }
  #access .left .txt{
    font-size: 1.4rem;
    letter-spacing: 2px;
    width: 100%;
    margin: 65px 0 0 0;
    line-height: 28px;
  }
  #map_canvas{
    width: 100%;
    height: 300px;
  }

  /*::::::::::::::::::::::
  INSTAGRAM
  ::::::::::::::::::::::*/
  #instagram{
    width: 100%;
    padding: 10% 0;
    background: #e8ecef;
  }
  #instagram .title{
    width: 100%;
    text-align: center;
    font-size: 2.8rem;
    letter-spacing: 8px;
    position: relative;
  }
  #instagram .title::before{
    position: absolute;
    content: '';
    border-bottom: 2px solid #333;
    width: 20%;
    top: 60px;
    left: 0;
    right: 0;
    margin: 0 auto;
  }
  #instagram .insta_box_pc{
    display: none;
  }
  #instagram .insta_box_sp{
    width: 90%;
    margin: 70px auto 0 auto;  }

  /*::::::::::::::::::::::
  FOOTER
  ::::::::::::::::::::::*/

  footer .foot_logo{
    width: 30%;
    margin: 60px auto 20px;
  }
  footer .sns{
    width: 92px;
    margin: 10px auto 15px;
    display: flex;
    display: -webkit-flex;
    justify-content:  space-around;
    -webkit-justify-content:  space-around;
  }
  footer .sns .insta{
    width: 32px;
  }
  footer .sns .fb{
    width: 32px;
  }
  footer .tel {
    font-size: 2.2rem;
    width: 90%;
    text-align: center;
    margin:5px auto 10px;
    letter-spacing: 3px;
  }
  footer .tel a{
    color: #000;
  }
  footer .time{
    font-size: 1.2rem;
    width: 90%;
    text-align: center;
    margin: 20px auto 10px;
    line-height: 20px;
    letter-spacing: 3px;
  }
  footer .address{
    font-size: 1.2rem;
    width: 90%;
    text-align: center;
    margin: 20px auto 10px;
    line-height: 20px;
    letter-spacing: 2px;
    word-break:break-all;
    
  }
  footer .mail{
    font-size: 1.2rem;
    width: 100%;
    text-align: center;
    margin: 10px 0;
    letter-spacing: 3px;
  }
  footer .copy{
    font-size: 1rem;
    width: 100%;
    text-align: center;
    padding: 20px 0 10px;
    letter-spacing: 3px;
    overflow: hidden;
  }
  .fa {
    margin: 0 5px 0 0;
    display: inline-block;
    font-family: FontAwesome;
    font-style: normal;
    font-weight: normal;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

}


/**************************************************
Mobile Layout
**************************************************/
@media screen and (max-width: 480px) {

  /*::::::::::::::::::::::
  MAIN_AREA
  ::::::::::::::::::::::*/
  #main_area{
    width: 100%;
    height: 100%;
    position: relative;
    background: url(../img/main_img_01_sp.jpg);
    background-size: contain;
    background-attachment: fixed;
  }
  #main_area .main_logo{
    width: 50%;
    height: 40%;
    position: absolute;
    top: 0px;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
  }

  /*::::::::::::::::::::::
  NAV_AREA
  ::::::::::::::::::::::*/
  #navi_area{
    display: none;
  }

  .sp_nav{
    background-color: #fff;
    text-align: center;
    width: 100%;
    display: flex;
    display: -webkit-flex;
  }
  .sp_nav a.sp_tel{
    background-color: #045187;
    text-align: center;
    display: block;
    font-size: 1.3rem;
    padding: 5% 5%;
    width: 50%;
    margin: 0 auto;
    border-right: 1px solid #bfbfbf;
    color: #fff;
  }
  .sp_nav a.sp_tel:hover{
    background-color: #045187;
    color: #fff;
  }

  .sp_nav a.sp_map{
    background-color: #fff;
    text-align: center;
    display: block;
    font-size: 1.3rem;
    padding: 5% 5%;
    width: 50%;
    margin: 0 auto;
    color: #045187;
  }
  .sp_nav a.sp_map:hover{
    background-color: #045187;
    color: #fff;
  }


  /*::::::::::::::::::::::
  MESSAGE
  ::::::::::::::::::::::*/
  #message{
    width: 100%;
    overflow: hidden;
  }
  #message .left{
    width: 100%;
    height: 100%;
    overflow: hidden;
    padding: 15% 10%;
    border-top: 1px solid #eee;
  }
  #message .right{
    width: 100%;
    height: 200px;
    background-image: url(../img/mess_img.jpg);
    background-size: cover;
    z-index: 100;
    position: relative;
    background-position:30% 60%;
  }
  #message .left .title{
    width: 100%;
    text-align: left;
    font-size: 2.7rem;
    letter-spacing: 5px;
    position: relative;
  }
  #message .left .title::before{
    position: absolute;
    content: '';
    border-bottom: 3px solid #045187;
    width: 20%;
    top: 53px;
    left: 0;
  }
  #message .left .txt{
    font-size: 1.3rem;
    letter-spacing: 0px;
    width: 100%;
    margin: 50px 0 0 0;
    line-height: 22px;
    text-align: justify;
    color: #045187;
  }


  /*::::::::::::::::::::::
  MENU
  ::::::::::::::::::::::*/
  #menu{
    width: 100%;
    overflow: hidden;
  }
  #menu .left{
    width: 100%;
    height: 200px;
    background-image: url(../img/menu_img.jpg);
    background-size: cover;
    background-position:30% 60%;
  }
  #menu .right{
    width: 100%;
    overflow: hidden;
    border-top: 1px solid #eee;
    padding: 15% 10%;
  }
  #menu .right .title{
    font-size: 2.7rem;
    letter-spacing: 5px;
    position: relative;
  }
  #menu .right .title::before{
    position: absolute;
    content: '';
    border-bottom: 3px solid #045187;
    width: 20%;
    top: 53px;
    left: 0;
  }
  #menu .right .txt{
    font-size: 1.4rem;
    letter-spacing: 2px;
    width: 100%;
    margin: 50px 0 0 0;
    line-height: 28px;
    color: #045187;
  }
  #menu .right .txt span{
    font-size: 1.2rem;
  }
  #menu .menu_left {
    width: 60%;
    float: left;
    overflow: hidden;
  }
  #menu .menu_right {
    width: 25%;
    float: right;
    overflow: hidden;
  }
  #menu .min_txt{
  	width: 100%;
    font-size: 1.2rem;
    padding: 15px 0 0 0;
    overflow: hidden;
    color: #045187;
  }

  /*::::::::::::::::::::::
  ACCESS
  ::::::::::::::::::::::*/
  #access{
    width: 100%;
    overflow: hidden;
  }
  #access .left{
    width: 100%;
    overflow: hidden;
    border-top: 1px solid #eee;
    padding: 15% 10%;
  }
  #access .right{
    width: 100%;
    height: 200px;
  }
  #access .left .title{
    font-size: 2.7rem;
    letter-spacing: 5px;
    position: relative;
  }
  #access .left .title::before{
    position: absolute;
    content: '';
    border-bottom: 3px solid #045187;
    width: 20%;
    top: 53px;
    left: 0;
  }
  #access .left .txt{
    font-size: 1.4rem;
    letter-spacing: 2px;
    width: 100%;
    margin: 45px 0 0 0;
    line-height: 28px;
    color: #045187;
  }
  #map_canvas{
    width: 100%;
    height: 200px;
  }

  /*::::::::::::::::::::::
  INSTAGRAM
  ::::::::::::::::::::::*/
  #instagram{
    width: 100%;
    padding: 10% 0;
    background: #e8ecef;
  }
  #instagram .title{
    width: 100%;
    text-align: center;
    font-size: 2.7rem;
    letter-spacing: 5px;
    position: relative;
  }
  #instagram .title::before{
    position: absolute;
    content: '';
    border-bottom: 3px solid #045187;
    width: 20%;
    top: 53px;
    left: 0;
    right: 0;
    margin: 0 auto;
  }
  #instagram .insta_box_pc{
    display: none;
  }
  #instagram .insta_box_sp{
    width: 90%;
    margin: 70px auto 0 auto;  }

  /*::::::::::::::::::::::
  FOOTER
  ::::::::::::::::::::::*/
  footer{
	color: #333; 
  }
  footer .foot_logo{
    width: 50%;
    margin: 60px auto 20px;
  }
  footer .sns{
    width: 92px;
    margin: 10px auto 15px;
    display: flex;
    display: -webkit-flex;
    justify-content:  space-around;
    -webkit-justify-content:  space-around;
  }
  footer .sns .insta{
    width: 32px;
  }
  footer .sns .fb{
    width: 32px;
  }
  footer .tel {
    font-size: 2.2rem;
    width: 90%;
    text-align: center;
    margin:5px auto 10px;
    letter-spacing: 3px;
  }
  footer .tel a{
    color: #000;
  }
  footer .time{
    font-size: 1.2rem;
    width: 90%;
    text-align: center;
    margin: 20px auto 10px;
    line-height: 20px;
    letter-spacing: 3px;
  }
  footer .address{
    font-size: 1.2rem;
    width: 90%;
    text-align: center;
    margin: 20px auto 10px;
    line-height: 20px;
    letter-spacing: 2px;
    word-break:break-all;
    
  }
  footer .mail{
    font-size: 1.2rem;
    width: 100%;
    text-align: center;
    margin: 10px 0;
    letter-spacing: 3px;
  }
  footer .copy{
    font-size: 1rem;
    width: 100%;
    text-align: center;
    padding: 20px 0 10px;
    letter-spacing: 3px;
    overflow: hidden;
  }
  .fa {
    margin: 0 5px 0 0;
    display: inline-block;
    font-family: FontAwesome;
    font-style: normal;
    font-weight: normal;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

}
