@charset "utf-8";


body{
  font-family: "游ゴシック Medium", YuGothic, "Yu Gothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
  font-size: 1em;
  width: 100%;
  margin: 0 !important;
}
@media only screen and (min-device-width: 900px) {
body{
   font-family: "游ゴシック Medium", YuGothic, "Yu Gothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif; 
}
  }
  h1{
  margin: 0;
}
h1 img{
  width: 65%;
  margin: 0;
}
.flex-box {
    display: flex;
    width: 100%;
}

.flex-item {
    border-radius:  5px;        /* 角丸指定 */
}
 
.flex-item:nth-child(1) {
    margin: 0 0 0 0;
    width: 100%;
}
 
.flex-item:nth-child(2) {
    margin: 0 0 0 0;
    width: 65%;
}
.flex-item:nth-child(2) img{
    width: 95%;
    margin: 0% 0 0 20%;
}
 
.flex-item:nth-child(3) {
    margin: 0 0% 0 0;
    width: 65%;
}
.flex-item:nth-child(3) img{
    width: 75%;
    margin: 0% 0 0 21%;
}
.flex-item:nth-child(4) {
    margin: 0 0 0 0;
    width: 100%;
}
.main_pic img{
  width: 100%;
  max-height: 800px;
}
.nav{
  font-size: 2.2em;
  font-weight: bold;
}
.flex-nav{
    display: flex;
    width: 95%;
    list-style: none;
    text-decoration: none;
    margin: auto;
}
.flex-nav:nth-child(1) li {
    margin: auto;
}
.flex-item:nth-child(2) li {
    margin: 0 0 0 0;
}
.flex-nav:nth-child(3) li {
    margin: 0 0% 0 0;
}
.flex-nav:nth-child(4) li {
    margin: 0 0 0 0;
}
.flex-nav a{
    text-decoration: none;
    color: #000;
}
.info img{
  width: 22%;
  margin: 4% 0% 1% 9%;
}

.content{
  width:85%;
  margin: auto;
}
.flex-content{
    width: 100%;
    overflow: hidden;
    margin: 0 0 4% 0;
}
.flex-img{
  margin: 0 0 3% 0;
}
.flex-img img{
  width: 100%;
  margin: auto;
}
.flex-text{
  width: 60%;
  padding: 0% 0% 0% 2%;
}
.banner{
  width: 50%;
  margin: auto;
}
.banner img{
  width: 100%;
}
.banner a:hover{
  opacity: 0.2;
}
.calendar{
  width: 100%;
  margin: auto;
  padding: 0;
}
.sch{
  width: 27%;
  margin: 4% 0% 1% 1%;
}
.calendar iframe {
  width: 100%;
  height: 800px;
  margin: auto;
  padding: 0;
}
table {
  border-collapse: collapse;
  border: solid 2px orange;/*表全体を線で囲う*/
  margin: auto;
}
table th, table td {
  border: dashed 1px orange;/**/
  /*破線 1px オレンジ*/
  font-weight: normal;
}
/*余白と文字装飾は省略*/
.staff{
  padding: 0;
}
.staff_img{
  width: 27%;
  margin: 4% 0% 1% 1%;
}
.staff_pic{
  margin: 4% 0% 1% 1%;
  padding: 2%;
  text-align: center;
  width: 45%;
}
.staff_pic img{
  width: 80%;
}
.staff_text{
  font-size: 1.7em;
  padding: 2%;
  text-align: center;
}
.staff_link{
  width: 70%;
  margin: auto;
}
.staff_link img{
  width: 80%;
}
.staff_link a:hover{
  opacity: 0.2;
}
.contact_text{
  font-size: 1.7em
}
.footer{
  background-color: #d2f7f6;
  margin: auto;
}
.footer a{
  margin: 0 0 0 0;
  padding: 0% 0 0 32%;
}
.footer_img{
  width: 35%;
  margin: auto;
}
.footer_img a{

}
#c_right{
  letter-spacing: 1px;
  display: block;
  text-align: center;
  width: 100%;
  margin: 0% 0% 0% 0%;
}
#add {
  width: 80%;
  margin: auto;
  position: relative;
  background: #c1f4ff;
  box-shadow: 0px 0px 0px 5px #d9fffc;
  border: dashed 2px white;
  padding: 0.2em 0.5em;
  color: #454545;
  text-align: center;
  font-size: 1.1em;
}

#add:after {
  position: absolute;
  content: '';
  left: -7px;
  top: -7px;
  border-width: 0 0 15px 15px;
  border-style: solid;
  border-color: #fff #fff #a8d4ff;
  box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.15);
}
/*ハンバーガーボタン*/
.el_humburger {
  position: fixed;
  top: 45px;
  right: 60px;
  width: 46px;
  height: 25px;
  padding-top: 1px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding-top: 0px;
  z-index: 20;
  cursor: pointer;
  pointer-events: auto;
  background-color: #fff;
  text-align: center;
}













 
@media screen and (max-width: 849px) {
#wrapper{
  width: 100%;
}
.flex-box {
    display: flex;
    width: 100%;
}
.flex-content{
  display: block;
  background-color:#fff;
}
.flex-img{
  width: 100%;
  margin: 0 0 3% 0;
}
h1 img{
  width: 75%;
  margin: 0;
}
.flex-item:nth-child(2) {
    margin: 0 0 0 0;
    width: 65%;
}
.flex-item:nth-child(2) img{
    width: 100%;
    margin: 3% 0 0 -15%;
}
.flex-item:nth-child(3) {
    margin: 0 0% 0 0;
    width: 65%;
}
.flex-item:nth-child(3) img{
    width: 79%;
    margin: 3% 0 0 -4%;
}
.nav{
  font-size: 1.0em;
  font-weight: bold;
  padding: 0 0 0 0;
}
.flex-nav{
    display: flex;
    width: 90%;
    list-style: none;
    text-decoration: none;
    margin: auto;
    padding: 0 0 0 0;
}
.flex-nav:nth-child(1) li {
    margin: auto;
}
.flex-item:nth-child(2) li {
    margin: 0 0 0 0;
}
.flex-nav:nth-child(3) li {
    margin: 0 0% 0 0;
}
.flex-nav:nth-child(4) li {
    margin: 0 0 0 0;
}
.flex-nav a{
    text-decoration: none;
    color: #000;
}
.txt-top{
  width: 93%;
}
.txt-botton{
  width: 93%;  
}
.flex-text{
  width: 100%;
  margin: 0 0 0 0;
}
.banner{
  width: 60%;
  margin: auto;
}
.banner img{
  width: 100%;
}
.staff{
  display: none;
}
#flavor {
  position: relative;
  padding: 0.6em;
  background: -webkit-repeating-linear-gradient(-45deg, #fff5df, #fff5df 4px,#ffe4b1 3px, #ffe4b1 8px);
  background: repeating-linear-gradient(-45deg, #fff5df, #fff5df 4px,#ffe4b1 3px, #ffe4b1 8px);
  border-radius: 7px;
}

#flavor :after {
  position: absolute;
  content: '';
  top: 100%;
  left: 30px;
  border: 15px solid transparent;
  border-top: 15px solid #ffebbe;
  width: 0;
  height: 0;
}
.staff_img{
  width: 27%;
  margin: 4% 0% 1% 1%;
}
.staff_text{
  font-size: 1em
}
.contact_img{
  width: 25%;
  margin: 4% 0% 1% 1%;
}
.contact_text{
  font-size: 1em
}
.contact a{
  margin: 0 0 2% 0;
}
  .el_humburger {
    display: block;
    right: 0;
    top: 0;
    padding-top: 15px;
    width: 70px;
    height: 55px;
    border-radius:  5px;
}
}
}
    #factory .el_humburger {
      display: none; 
} 
  .el_humburger_wrapper {
    margin-bottom: 5px;
    width: 42px;
    display: inline-block; 
}


}
 
.el_humburger_wrapper {
  margin-bottom: 5px;
  width: 42px;
  display: inline-block; 
}
 



















@media screen and (max-width: 840px) {
  .el_humburger_wrapper {
    margin-bottom: 5px;
    width: 30px; } }
 
.el_humburger_text {
  font-size: 12px;
  letter-spacing: 0.1em;
  font-family: "游ゴシック Medium", YuGothic, "Yu Gothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif; }
 
.js_humburgerOpen .el_humburger_text.el_humburger_text__menu {
  display: none; }
 
.el_humburger_text.el_humburger_text__close {
  display: none; }
 
.js_humburgerOpen .el_humburger_text.el_humburger_text__close {
  display: block; }
 
@media screen and (max-width: 840px) {
  .el_humburger_text {
    font-size: 10px;
    padding-top: 2px; } 

.calendar{
  width:100%;
}
.calendar iframe{
  width:100%;
  height: 450px;
}
.info img{
  width: 30%;
  margin: 4% 0% -3% 8%;
  padding: 0 0 0 0;
}
.sch{
  width: 27%;
  margin: 4% 0% -3% 1%;
  padding: 0 0 0 0;
}
.staff_img{
  width: 39%;
  margin: 4% 0% -3% 0%;
}
#contact_img img{
  width: 35%;
}
.contact_img{
  width: 32%;
  margin: 4% 0% -3% 1%;
}
.contact_img img{
  width: 32%;
  margin: 4% 0% -3% 1%;
}

}
 
@media screen and (max-width: 840px) {
  .el_humburger_text svg path {
    -webkit-transition: all 200ms cubic-bezier(0.16, 0.52, 0.25, 1);
    -o-transition: all 200ms cubic-bezier(0.16, 0.52, 0.25, 1);
    transition: all 200ms cubic-bezier(0.16, 0.52, 0.25, 1);
    fill: #000; } }
 
@media screen and (max-width: 840px) {
  .js_humburgerOpen .el_humburger_text svg path {
    fill: #000; } }
 
.el_humburger span.el_humburger_bar {
  display: block;
  width: 100%;
  margin: 0 auto 9px;
  height: 1px;
  background: #000;
  -webkit-transition: all .2s ease-in-out;
  -o-transition: all .2s ease-in-out;
  transition: all .2s ease-in-out; }
 
.el_humburger span.el_humburger_bar:last-child {
  margin-bottom: 0; }
 
.js_humburgerOpen .el_humburger span.el_humburger_bar {
  background: #000; }
 
@media screen and (max-width: 840px) {
  .el_humburger span.el_humburger_bar {
    left: 0;
    top: 0;
    background: #000; } }
 
.js_humburgerOpen .el_humburger span.el_humburger_bar.top {
  -webkit-transform: translateY(9px) rotate(-45deg);
  -ms-transform: translateY(9px) rotate(-45deg);
  transform: translateY(9px) rotate(-45deg); }
 
.js_humburgerOpen .el_humburger span.el_humburger_bar.middle {
  opacity: 0; }
 
.js_humburgerOpen .el_humburger span.el_humburger_bar.bottom {
  -webkit-transform: translateY(-11px) rotate(45deg);
  -ms-transform: translateY(-11px) rotate(45deg);
  transform: translateY(-11px) rotate(45deg); }
 
.el_humburgerButton.el_humburgerButton__close {
  top: 2%;
  right: 2%; }
 
.el_humburgerButton__close span.el_humburger_bar {
  display: block;
  width: 35px;
  margin: 0 auto;
  height: 4px;
  background: #000; }
 
.el_humburgerButton__close span.el_humburger_bar.top {
  -webkit-transform: translateY(5px) rotate(-45deg);
  -ms-transform: translateY(5px) rotate(-45deg);
  transform: translateY(5px) rotate(-45deg); }
 
.el_humburgerButton__close span.el_humburger_bar.bottom {
  -webkit-transform: translateY(-6px) rotate(45deg);
  -ms-transform: translateY(-6px) rotate(45deg);
  transform: translateY(-6px) rotate(45deg); }
 
.navi {
  position: fixed;
  right: 0;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.9);
  width: 30px;
  z-index: 3;
  padding-top: 100px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: all 600ms ease-out;
  -o-transition: all 600ms ease-out;
  transition: all 600ms ease-out;
  transform:translateZ(0) translateX(100%);
  overflow: auto; }
  .js_humburgerOpen .navi {
    transform:translateZ(0) translateX(0); 
}


@media screen and (max-width: 840px) {
      .navi {
        padding: 100px 5% 0; }
      .js_humburgerOpen .navi {
        width: 35%;
      } 
}
 
.navi_item {
  margin-bottom: 28px;
  font-size: 20px;
  font-family: "Marcellus", serif !important;
  white-space: nowrap;
  margin-left: 90px; }
  .navi_item.op_innerLink {
    cursor: pointer; }
  @media screen and (max-width: 840px) {
    .navi_item {
      margin-left: 0;
      font-size: 18px; } 
}


@media screen and (min-width: 849px) {
  .hidden{
  display: none;
}
.staff_sp{
  display: none;
}

#flavor {
  width: 75%;
  position: relative;
  padding: 0.6em;
  background: -webkit-repeating-linear-gradient(-45deg, #fff5df, #fff5df 4px,#ffe4b1 3px, #ffe4b1 8px);
  background: repeating-linear-gradient(-45deg, #fff5df, #fff5df 4px,#ffe4b1 3px, #ffe4b1 8px);
  border-radius: 7px;
  font-size: 1.3em;
}

#flavor :after {
  position: absolute;
  content: '';
  top: 100%;
  left: 155px;
  border: 15px solid transparent;
  border-top: 15px solid #ffebbe;
  width: 0;
  height: 0;
}
table {
  border-collapse: collapse;
  border: solid 2px orange;/*表全体を線で囲う*/
  margin: 0% 0% 7% 0%;
}
table th, table td {
  border: dashed 1px orange;/**/
  /*破線 1px オレンジ*/
  font-weight: normal;
}
/*余白と文字装飾は省略*/
.staff_img img{
  width: 115%;
  margin: 4% 0% 0% -2%;
}
.staff_pic{
  margin: 4% 0% 1% 1%;
  padding: 2%;
}
.staff_pic img{
  width: 50%;
}
.staff_text{
  font-size: 1.7em;
  padding: 1%;
}

.staff_link{
  width: 70%;
  margin: auto;
}
.staff_link img{
  width: 80%;
}
.staff_link a:hover{
  opacity: 0.2;
}
}
