@charset "UTF-8";

/* reset */
html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
dl,
dt,
dd,
ol,
ul,
li,
p {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
}

img {
  height: auto;
  font-size: 0;
  line-height: 0;
  border: 0;
}

ol,
ul {
  list-style: none;
}

/* common */
body {
  font-family: 'メイリオ', Meiryo, 'ヒラギノ角ゴシック', 'ＭＳ Ｐゴシック', 'MS PGothic', YuGothic, 'Yu Gothic';
  font-size: 15px;
  color: rgb(50, 50, 50);
  line-height: 1.5;
  text-align: left;
  letter-spacing: 0.1em;
  background: rgb(255, 255, 255);
}

a {
  text-decoration: underline;
  display: inline-block;
  color: rgb(50, 50, 50);
  transition: 0.5s;
}

a:hover {
  opacity: 0.6;
}

img {
  max-width: 100%;
  height: auto;
  border-style: none;
  vertical-align: middle;
}

a img {
  text-decoration: none;
}

.tel a {
  pointer-events: none;
  text-decoration: none;
}

.indent {
  padding-left: 1.2em;
  text-indent: -1.2em;
}

.color_box {
  background: url("images/back.jpg") no-repeat center center / cover;
}

.inner_box {
  width: 1000px;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 20px 0 40px 0;
}

.inner_box_02 {
  width: 1000px;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 100px 0 130px 0;
}

.inner_box_03 {
  width: 1000px;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 100px 0 60px 0;
}

.ue {
  background: url("images/ue.png") no-repeat center bottom -1px / 100%;
  width: 100%;
  height: 130px;
  position: relative;
  z-index: 5;
  margin: 60px auto 0 auto;
}

.ue_02 {
  background: url("images/ue.png") no-repeat center bottom -1px / 100%;
  width: 100%;
  height: 130px;
  position: relative;
  z-index: 5;
  margin: -130px auto 0 auto;
  border-bottom: 1px solid #fff;
}

.shita {
  background: url("images/shita.png") no-repeat center top -1px / 100%;
  width: 100%;
  height: 130px;
  position: relative;
  z-index: 5;
  margin: 0 auto -130px auto;
}

.page_title {
  width: 1000px;
  margin: 20px auto;
  background: url("images/bakc_blue.jpg");
  padding: 10px 30px;
  box-sizing: border-box;
  border-radius: 30px;
}

.page_title img {
  height: 2vw;
}

.section_titile {
  width: 300px;
  margin: 0 auto 30px auto;
}

/* table */
table {
  width: 100%;
  border-collapse: collapse;
}

th {
  border: 1px solid rgba(200, 110, 230, 1);
  padding: 10px;
  text-align: center;
  font-weight: normal;
  background: rgba(200, 110, 230, 0.2);
}

td {
  border: 1px solid rgb(200, 110, 230);
  padding: 10px 20px;
  background: rgba(255, 255, 255, 0.8);
}

.pc {
  display: block !important;
}

.sp {
  display: none !important;
}


/* container */
#container {
  width: 100%;
  min-width: 1100px;
}

/* logo */
#logo a {
  position: absolute;
  z-index: 6;
  top: 60px;
  left: 60px;
  margin: 0 auto;
  width: 240px;
  height: 240px;
  animation: fuwafuwa 2s ease-in-out infinite alternate-reverse;
  background: url("images/logo_kikusuimotomachi.png") no-repeat center center / 100%;
}

.header {
  background: url("images/top.jpg") no-repeat center top / 100%;
  padding: 20px 0 0 0;
}

#contents_02 #logo {
  width: 1000px;
  margin: 0 auto;
  position: relative;
  z-index: 7;
}

#contents_02 #logo a {
  top: 0;
  left: 0;
  right: 0;
  width: 220px;
  height: 220px;
}

@keyframes fuwafuwa {
  0% {
    transform: translateY(-5%);
  }

  100% {
    transform: translateY(5%);
  }
}

#logo a:hover {
  opacity: 1;
  width: 260px;
  height: 260px;
  ackground: url("images/logo_kikusuimotomachi.png") no-repeat center center / 100%;
  top: 50px;
  left: 50px;
}

#contents_02 #logo a:hover {
  opacity: 1;
  width: 240px;
  height: 240px;
  ackground: url("images/logo_kikusuimotomachi.png") no-repeat center center / 100%;
}

/* menu */
#menu ul {
  width: 1000px;
  margin: -170px auto 0 auto;
  position: relative;
  z-index: 6;
}

#menu li a {
  text-align: center;
  width: 150px;
  height: 150px;
}

#menu li.menu_01 a {
  position: absolute;
  top: -135px;
  left: -20px;
  background: url("images/menu_01.png") no-repeat center center / 100%;
}

#menu li.menu_02 a {
  position: absolute;
  top: -85px;
  left: 125px;
  background: url("images/menu_02.png") no-repeat center center / 100%;
}

#menu li.menu_03 a {
  position: absolute;
  top: -35px;
  left: 275px;
  background: url("images/menu_03.png") no-repeat center center / 100%;
}

#menu li.menu_04 a {
  position: absolute;
  top: 5px;
  left: 425px;
  background: url("images/menu_04.png") no-repeat center center / 100%;
}

#menu li.menu_05 a {
  position: absolute;
  top: -35px;
  left: 575px;
  background: url("images/menu_05.png") no-repeat center center / 100%;
}

#menu li.menu_06 a {
  position: absolute;
  top: -85px;
  left: 725px;
  background: url("images/menu_06.png") no-repeat center center / 100%;
}

#menu li.menu_07 a {
  position: absolute;
  top: -135px;
  left: 870px;
  background: url("images/menu_07.png") no-repeat center center / 100%;
}

#menu li a:hover {
  width: 160px;
  height: 160px;
  margin: -10px 0 0 -10px;
  opacity: 1;
}

#contents_02 #menu ul {
  margin: 0 auto;
  display: flex;
  width: 1050px;
  padding: 220px 0 80px 0;
}

#contents_02 #menu li.menu_01 a,
#contents_02 #menu li.menu_02 a,
#contents_02 #menu li.menu_03 a,
#contents_02 #menu li.menu_04 a,
#contents_02 #menu li.menu_05 a,
#contents_02 #menu li.menu_06 a,
#contents_02 #menu li.menu_07 a {
  position: relative;
  top: auto;
  left: auto;
}

/* swiper */
.swiper {
  width: 100%;
  height: 52%;
  margin: 0 auto;
}

.swiper-slide {
  padding-top: 52%;
  position: relative;
  z-index: 2;
}

.swiper-slide img {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  width: 80%;
  height: 80%;
  margin: auto;
  object-fit: cover;
}

.frame {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  z-index: 3;
  background: url("images/frame.png") no-repeat center bottom / 100%;
}

/*news*/
.news_box {
  display: flex;
  justify-content: space-between;
}

.news_box a {
  width: 24%;
  text-decoration: none;
  word-break: break-all;
}

.news_box ul {
  padding: 20px;
  border-radius: 20px;
  border: 1px solid rgb(200, 110, 230);
  width: 100%;
  box-sizing: border-box;
  height: 100%;
  cursor: pointer;
}

.news_title {
  font-size: 16px;
  border-bottom: 1px solid rgb(200, 110, 230);
  padding: 0 0 5px 0;
  margin: 0 auto 5px auto;
}

.news_date {
  font-size: 13px;
  margin: 0 auto 10px auto;
}

.news_photo {
  width: 100%;
  padding-top: 60%;
  position: relative;
  margin: 10px auto 0 auto;
}

.news_photo img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
  object-fit: cover;
  border-radius: 10px;
}

/* gmap */
.gmap {
  position: relative;
  padding-top: 50%;
  width: 100%;
  margin: 0 auto 40px auto;
}

.gmap iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  margin: 0 auto;
  border-radius: 20px;
}

/* kihon */
#kihon table {
  margin: 0 auto 40px auto;
}

#kihon .gmap {
  margin: 0 auto;
}

/* recruit */
#recruit li {
  width: 50%;
  margin: 0 auto;
}

/* post */
.post {
  background: rgba(255, 255, 255, 0.8);
  padding: 40px;
  margin: 0 auto 20px auto;
}

#kaienjikan .post {
  background: url("images/bakc_yellow.jpg");
}

.post:last-of-type {
  margin: 0 auto;
}

.post h4 {
  border-bottom: 1px solid rgba(200, 110, 230, 1);
  font-size: 17px;
  margin: 0 auto 10px auto;
}

.post_flex {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.post_photo {
  width: 35%;
  padding-top: 20%;
  position: relative;
}

.post_photo img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
  object-fit: cover;
  border-radius: 10px;
}

.post_honbun {
  width: 62%;
}

#kaienjikan .post_honbun {
  width: 100%;
}

.post_honbun a {
  text-decoration: underline;
}

#ensha {
  text-align: center;
}


/* year */
.year_box {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 0 auto -1% auto;
}

.month {
  padding: 20px;
  box-sizing: border-box;
  width: 23%;
  margin: 1%;
  background: rgba(255, 255, 255, 0.8);
  border-radius: 20px;
  text-align: center;
}

.month dt {
  width: 40%;
  margin: 0 auto 10px auto;
}

.year_photo {
  width: 100%;
  padding-top: 70%;
  position: relative;
  margin: 0 auto 10px auto;
}

.year_photo img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
  object-fit: cover;
  border-radius: 10px;
}

.free_box {
  border-radius: 20px;
  padding: 20px;
  box-sizing: border-box;
  border: 1px solid rgba(200, 110, 230, 1);
  margin: 40px auto 0 auto;
}

/* daily */
.daily_box {
  display: flex;
  justify-content: space-between;
}

.daily_box div {
  padding: 40px;
  box-sizing: border-box;
  width: 49%;
  border-radius: 20px;
  align-self: flex-start;
}

.daily_title {
  text-align: center;
  margin: 0 auto 20px auto;
  width: 38%;
}

.daily_box dl {
  margin: 0 auto 15px auto;
  padding: 0 0 15px 0;
  border-bottom: 1px dotted rgba(200, 110, 230, 1);
}

.daily_box dl:last-of-type {
  border-bottom: none;
  margin: 0 auto;
  padding: 0;
}

.time {
  color: rgba(200, 110, 230, 1);
  font-size: 20px;
  text-align: center;
  margin: 0 auto 10px auto;
  background: rgba(255, 255, 255, 1);
  padding: 5px 20px;
  border-radius: 20px;
}

.daily_txt {
  margin: 0 auto 10px;
  text-align: center;
}

.daily_l {
  background: url("images/bakc_green.jpg");
}

.daily_r {
  background: url("images/bakc_yellow.jpg");
}

.daily_photo {
  width: 100%;
  padding-top: 60%;
  position: relative;
  margin: 0 auto 10px auto;
}

.daily_photo img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
  object-fit: cover;
  border-radius: 10px;
}

/* blog */
.blog_box {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 0;
}

#sidemenu {
  width: 300px;
}

#sidemenu .category,
#sidemenu .calendar,
#sidemenu .archive {
  margin: 0 auto 20px auto;
  background: url("images/bakc_yellow.jpg");
  padding: 30px;
  box-sizing: border-box;
  border-radius: 20px;
}

#sidemenu h4 {
  margin: 0 auto 15px auto;
  font-size: 17px;
  text-align: center;
  color: rgba(200, 110, 230, 1);
}

#sidemenu .category li a,
#sidemenu .archive li a {
  background: url("images/icon_maru.png") no-repeat left top 6px;
  padding: 0 0 10px 17px;
  font-size: 15px;
  margin: 0 auto 10px auto;
  border-bottom: 2px dotted rgba(200, 110, 230, 1);
  display: block;
  text-decoration: none;
}

#sidemenu .category li:last-child a,
#sidemenu .archive li:last-child a {
  margin: 0 auto;
}

.calendar_title ul {
  text-align: center;
  display: flex;
  justify-content: center;
  margin: 0 auto 10px auto;
}

.calendar_title li {
  margin: 0 5px;
}

.calendar_title li a {
  text-decoration: none;
}

#sidemenu .calendar table a {
  text-decoration: none;
  color: rgba(200, 110, 230, 1);
  font-weight: bold;
}

#sidemenu .calendar th {
  width: auto;
  padding: 5px;
}

#sidemenu .calendar td {
  width: auto;
  padding: 5px;
  text-align: center;
  letter-spacing: 0;
}

.old_blog a {
  text-decoration: none;
  padding: 10px;
  border-radius: 10px;
  background: rgba(200, 110, 230, 0.8);
  margin: 20px auto;
  box-sizing: border-box;
  display: block;
  text-align: center;
  color: #fff;
}

#kiji_main {
  width: 670px;
}

.kiji_date {
  margin: 0 auto 10px auto;
}

h5 {
  margin: 0 auto 20px auto;
  font-size: 17px;
  border-bottom: 2px dotted rgba(200, 110, 230, 1);
  padding: 0 0 10px 0;
}

.kiji {
  background: rgba(255, 255, 255, 0.8);
  padding: 30px;
  border-radius: 10px;
  box-sizing: border-box;
  margin: 0 auto 20px auto;
}

.kiji:last-of-type {
  margin: 0 auto;
}

.kiji_honbun {
  font-size: 14px;
  text-align: justify;
}

.kiji .pdf {
  display: inline-block;
  margin: 20px auto 0 auto;
}

.kiji_photo {
  display: flex;
  justify-content: flex-start;
  margin: 15px auto 0 auto;
  flex-wrap: wrap;
}

.kiji_photo div {
  width: 31%;
  margin: 1%;
}

.kiji_photo p {
  font-size: 14px;
}

.kiji_img {
  width: 100%;
  padding-top: 60%;
  position: relative;
  margin: 0 auto 5px auto;
}

.kiji_img img {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: auto;
  object-fit: cover;
  border-radius: 10px;
}

.pdf a {
  background: rgba(200, 110, 230, 0.2) url("images/icon_pdf.png") no-repeat left 20px top 12px / 15px;
  display: block;
  padding: 10px 20px 10px 43px;
  border-radius: 10px;
  margin: 0 auto 10px auto;
  text-decoration: none;
}

.video_box {
  position: relative;
  padding-top: 50%;
  margin: 20px auto 0 auto;
}

.video_box iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  margin: 0 auto;
}

.pagination {
  text-align: center;
  margin: 30px auto 0 auto;
  letter-spacing: 0;
}

.pagination a,
.pagination span {
  display: inline-block;
  text-decoration: none;
  background: rgba(200, 110, 230, 1);
  border-radius: 5px;
  color: #fff;
  padding: 2%;
  font-size: 100%;
  margin: 2px;
}

.pagination a.next,
.pagination a.pre {
  display: none;
}

/* download */
#download li a {
  background: rgba(255, 255, 255, 0.8) url("images/icon_pdf.png") no-repeat left 20px top 12px / 15px;
  display: block;
  padding: 10px 20px 10px 43px;
  border-radius: 10px;
  margin: 0 auto 10px auto;
  text-decoration: none;
}

/* mail */
.hissu {
  margin: 20px auto 10px auto;
}

#mail form dl {
  width: 100%;
}

#mail form dt {
  background: rgba(200, 110, 230, 0.4);
  width: 100%;
  text-align: center;
  padding: 10px;
  box-sizing: border-box;
  font-size: 16px;
  line-height: 1;
  color: rgb(80, 80, 80);
  margin: 0 auto 5px auto;
  border-radius: 10px;
}

#mail form dd {
  width: 100%;
  margin: 0 auto 15px auto;
}

#mail input[type=text] {
  width: 100%;
  box-sizing: border-box;
  padding: 10px;
  border: 1px solid rgba(200, 110, 230, 1);
  border-radius: 10px;
  font-size: 16px;
}

#mail input[type=radio] {
  margin: 10px auto 20px auto;
}

#mail textarea {
  width: 100%;
  padding: 10px;
  box-sizing: border-box;
  height: 12em;
  border-radius: 10px;
  border: 1px solid rgba(200, 110, 230, 1);
  font-size: 16px;
}

#mail .syozoku textarea,
#mail .hensinhoho textarea {
  height: 2.5em;
  margin: -10px auto 0 auto;
}

#mail input[type=submit],
#mail input[type=reset] {
  appearance: none;
  -webkit-appearance: none;
}

#mail input[type=submit],
#mail input[type=reset] {
  border: 1px solid rgba(200, 110, 230, 1);
  border-radius: 5px;
  background: #fff;
  color: rgba(200, 110, 230, 1);
  font-weight: normal;
  padding: 10px 30px;
  font-size: 16px;
}

#mail .form_btn input:hover {
  background: rgba(200, 110, 230, 1);
  color: #fff;
  cursor: pointer;
}

#mail form dl.form_btn {
  display: flex;
  justify-content: center;
  align-content: center;
  text-align: center;
  margin: 0 auto;
}

#mail form .form_btn dt {
  background: none;
  width: auto;
  text-align: center;
  margin: 10px;
  padding: 0;
}

#mail form .form_btn dd {
  margin: 10px;
  width: auto;
}



/* footer */
#footer {
  background: url("images/footer.png") no-repeat right bottom / 100%, url("images/bakc_blue.jpg") no-repeat center center / cover;
  padding: 5% 0 9% 0;
  position: relative;
}

#footer a {
  text-decoration: none;
}

.copy {
  text-align: center;
  margin: 0 auto 40px auto;
  font-size: 15px;
  width: 1000px;
}

.counter {
  text-align: center;
  padding: 0 0 40px 0;
}

.footer_ad {
  display: flex;
  justify-content: center;
  width: 1000px;
  margin: 0 auto 20px auto;
  border-bottom: 1px solid rgb(200, 110, 230);
  padding: 0 0 20px 0;
}

.footer_logo {
  width: 26%;
  margin: 0 30px 0 0;
}

.footer_link ul {
  display: flex;
  justify-content: center;
  width: 1000px;
  margin: 0 auto;
}

.footer_link li {
  width: 14%;
  margin: 0 2%;
}

.baloon_01 {
  width: 39px;
  height: 80px;
  background: url("images/baloon_01.png") no-repeat center center / 100%;
  position: absolute;
  bottom: 55%;
  right: 3%;
  animation: ballon_01 4s ease-in-out infinite normal;
}

.baloon_02 {
  width: 39px;
  height: 80px;
  background: url("images/baloon_02.png") no-repeat center center / 100%;
  position: absolute;
  bottom: 40%;
  right: 8%;
  animation: ballon_02 5s ease-in-out infinite normal;
}

.soap_01 {
  width: 30px;
  height: 30px;
  background: url("images/soap_01.png") no-repeat center center / 100%;
  position: absolute;
  bottom: 45%;
  right: 15%;
  animation: ballon_01 4s ease-in-out infinite normal;
}

.soap_02 {
  width: 20px;
  height: 20px;
  background: url("images/soap_02.png") no-repeat center center / 100%;
  position: absolute;
  bottom: 35%;
  right: 20%;
  animation: ballon_02 4s ease-in-out infinite normal;
  animation-delay: 0.5s;
  opacity: 0;
}

.soap_03 {
  width: 25px;
  height: 25px;
  background: url("images/soap_03.png") no-repeat center center / 100%;
  position: absolute;
  bottom: 40%;
  right: 18%;
  animation: ballon_01 4s ease-in-out infinite normal;
}

.soap_04 {
  width: 15px;
  height: 15px;
  background: url("images/soap_03.png") no-repeat center center / 100%;
  position: absolute;
  bottom: 40%;
  right: 17%;
  animation: ballon_01 4s ease-in-out infinite normal;
  animation-delay: 0.5s;
  opacity: 0;
}

.soap_05 {
  width: 20px;
  height: 20px;
  background: url("images/soap_02.png") no-repeat center center / 100%;
  position: absolute;
  bottom: 40%;
  right: 18%;
  animation: ballon_02 4s ease-in-out infinite normal;
  animation-delay: 1s;
  opacity: 0;
}

.soap_06 {
  width: 25px;
  height: 25px;
  background: url("images/soap_01.png") no-repeat center center / 100%;
  position: absolute;
  bottom: 45%;
  right: 22%;
  animation: ballon_01 4s ease-in-out infinite normal;
  animation-delay: 2s;
  opacity: 0;
}

@keyframes ballon_01 {
  0% {
    transform: translateY(70%);
    opacity: 0
  }

  50% {
    opacity: 100%;
  }

  100% {
    transform: translateY(5%);
    opacity: 0;
  }
}

@keyframes ballon_02 {
  0% {
    transform: translateY(50%);
    opacity: 0
  }

  50% {
    opacity: 100%;
  }

  100% {
    transform: translateY(0);
    opacity: 0;
  }
}

/* pagetop */
.pagetop {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 6;
  width: 40px;
  height: 40px;
}


@media screen and (max-width:768px) {


  .pc {
    display: none !important;
  }

  .sp {
    display: block !important;
  }


  .inner_box {
    width: 80%;
    padding: 4% 0 8% 0;
  }

  .inner_box_02 {
    width: 80%;
    padding: 10% 0 12% 0;
  }

  .inner_box_03 {
    width: 80%;
    padding: 10% 0 12% 0;
  }

  .ue {
    height: 9vw;
    margin: -9vw auto 0 auto;
  }

  .ue_02 {
    height: 9vw;
    margin: -9vw auto 0 auto;
  }

  .shita {
    height: 9vw;
    margin: 0 auto -9vw auto;
  }

  .page_title {
    width: 90%;
    margin: 30px auto;
  }

  .page_title img {
    height: 5vw;
  }

  .section_titile {
    width: 60%;
    margin: 0 auto 6% auto;
  }


  /* table */
  table {
    border-left: 1px solid rgb(200, 110, 230);
    border-right: 1px solid rgb(200, 110, 230);
    border-bottom: 1px solid rgb(200, 110, 230);
  }

  th {
    width: 100%;
    display: block;
    box-sizing: border-box;
    border-left: none;
    border-right: none;
  }

  td {
    width: 100%;
    display: block;
    box-sizing: border-box;
    border: none;
  }

  /* container */
  #container {
    min-width: 1px;
  }

  .header {
    background: url("images/top_2.jpg") no-repeat center top / 100%;
    padding: 20px 0 0 0;
    height: 60vw;
  }

  /* logo */
  #logo a {
    top: 0;
    left: 5%;
    width: 30%;
    height: 30%;
  }

  #logo a:hover {
    width: 30%;
    height: 30%;
    top: 0;
    left: 5%;
  }

  #contents_02 #logo {
    width: 50%;
    height: 50vw;
  }

  #contents_02 #logo a {
    width: 100%;
    height: 100%;
  }

  /* menu */
  body.stop {
    overflow: hidden;
  }

  .toggle {
    position: fixed;
    right: 0;
    top: 0;
    z-index: 8;
    width: 70px;
    height: 70px;
    background: url("images/menu_btn.jpg") no-repeat right top / 100%;
    transition: 0.3s;
  }

  .toggle.close {
    background: url("images/menu_btn2.jpg") no-repeat right top / 100%;

  }

  .toggle:hover {
    cursor: pointer;
  }

  #menu {
    margin: 0 auto;
    background: rgba(255, 255, 255, 0.9);
    width: 100%;
    height: 100vh;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 7;
    padding: 10% 0 30% 0;
    box-sizing: border-box;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    display: none;
  }

  #menu ul,
  #contents_02 #menu ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 90%;
    margin: 0 auto;
    padding: 0;
  }

  #menu li {
    width: 48%;
    margin: 0;
  }

  #menu li a {
    text-align: center;
    width: 100%;
    height: 41vw;
  }

  #menu li.menu_01 a,
  #contents_02 #menu li.menu_01 a {
    position: relative;
    top: auto;
    left: auto;
    background: url("images/menu_01.png") no-repeat bottom center / 100%;
  }

  #menu li.menu_02 a,
  #contents_02 #menu li.menu_02 a {
    position: relative;
    top: auto;
    left: auto;
    background: url("images/menu_02.png") no-repeat bottom center / 100%;
  }

  #menu li.menu_03 a,
  #contents_02 #menu li.menu_03 a {
    position: relative;
    top: auto;
    left: auto;
    background: url("images/menu_03.png") no-repeat bottom center / 100%;
  }

  #menu li.menu_04 a,
  #contents_02 #menu li.menu_04 a {
    position: relative;
    top: auto;
    left: auto;
    background: url("images/menu_04.png") no-repeat bottom center / 100%;
  }

  #menu li.menu_05 a,
  #contents_02 #menu li.menu_05 a {
    position: relative;
    top: auto;
    left: auto;
    background: url("images/menu_05.png") no-repeat bottom center / 100%;
  }

  #menu li.menu_06 a,
  #contents_02 #menu li.menu_06 a {
    position: relative;
    top: auto;
    left: auto;
    background: url("images/menu_06.png") no-repeat center center / 100%;
  }

  #menu li.menu_07 a,
  #contents_02 #menu li.menu_07 a {
    position: relative;
    top: auto;
    left: auto;
    background: url("images/menu_07.png") no-repeat bottom center / 100%;
  }

  #menu li a:hover {
    width: 150px;
    height: 150px;
    margin: 0 auto;
  }

  /* swiper */
  .swiper {
    height: 102%;
  }

  .swiper-slide {
    padding-top: 102%;
  }

  .swiper-slide img {
    width: 100%;
    height: 100%;
  }

  .frame {
    background: url("images/frame_02.png") no-repeat center bottom / 100%;
  }


  /*news*/
  .news_box {
    flex-wrap: wrap;
  }

  .news_box a {
    width: 48%;
    margin: 1%;
  }

  .news_box ul {
    padding: 5%;
    width: 100%;
  }

  /* gmap */
  .gmap {
    padding-top: 60%;
  }

  /* kihon */
  #kihon table {
    margin: 0 auto 5% auto;
  }

  /* recruit */
  #recruit li {
    width: 90%;
  }

  /* post */
  .post {
    padding: 5%;
  }

  .post h4 {
    margin: 0 auto 10px auto;
  }

  .post_flex {
    display: block;
  }

  .post_photo {
    width: 100%;
    padding-top: 60%;
    margin: 0 auto 10px auto;
  }

  .post_honbun {
    width: 100%;
  }

  /* year */
  .month {
    width: 48%;
  }


  /* daily */
  .daily_btn {
    display: flex;
    justify-content: space-between;
    margin: 0 auto 20px auto;
  }

  .daily_btn li {
    width: 48%;
    line-height: 1.2;
    background: rgba(200, 110, 230, 0.7);
    box-sizing: border-box;
    padding: 5px 10px;
    border-radius: 10px;
  }

  .daily_btn li a {
    color: #fff;
    text-decoration: none;
    display: block;
    text-align: center;
  }

  .daily_box {
    display: block;
  }

  .daily_box div {
    padding: 8%;
    width: 100%;
  }

  .daily_l {
    margin: 0 auto 20px auto;
  }



  /* blog */
  .blog_box {
    flex-wrap: wrap;
  }

  #sidemenu {
    order: 2;
    margin: 60px auto 0 auto;
    width: 100%;
  }

  #sidemenu .calendar th,
  #sidemenu .calendar td {
    border: 1px solid rgb(200, 110, 230);
    display: table-cell;
  }

  .kiji_photo div {
    width: 48%;
  }

  /* download */
  #download li a {
    background: rgba(255, 255, 255, 0.8) url("images/icon_pdf.png") no-repeat left 20px top 12px / 15px;
    display: block;
    padding: 10px 20px 10px 43px;
    border-radius: 10px;
    margin: 0 auto 10px auto;
    text-decoration: none;
  }

  /* mail */
  #mail .syozoku textarea,
  #mail .hensinhoho textarea {
    height: 4em;
    margin: -10px auto 0 auto;
  }

  /* footer */
  #footer {
    background: url("images/footer_02.png") no-repeat center bottom / 100%, url("images/bakc_blue.jpg");
    padding: 10% 0 80%;
    position: relative;
  }

  .copy {
    text-align: center;
    margin: 0 auto 40px auto;
    font-size: 15px;
    width: 90%;
  }

  .footer_ad {
    display: block;
    width: 90%;
    margin: 0 auto 20px auto;
    border-bottom: 1px solid rgb(200, 110, 230);
    padding: 0 0 20px 0;
    text-align: center
  }

  .footer_logo {
    width: 50%;
    margin: 0 auto 10px auto;
  }

  .footer_link ul {
    width: 90%;
  }

  .footer_link li {
    width: 25%;
  }

  .baloon_01 {
    width: 8%;
    height: 18%;
    bottom: 35%;
    right: 85%;
  }

  .baloon_02 {
    width: 8%;
    height: 18%;
    bottom: 30%;
    right: 70%;
  }

  .soap_01 {
    width: 5%;
    height: 5%;
    bottom: 15%;
    right: 45%;
  }

  .soap_02 {
    width: 4%;
    height: 4%;
    bottom: 28%;
    right: 55%;
  }

  .soap_03 {
    width: 5%;
    height: 5%;
    bottom: 20%;
    right: 55%;
  }

  .soap_04 {
    width: 4%;
    height: 4%;
    bottom: 20%;
    right: 40%;
  }

  .soap_05 {
    width: 5%;
    height: 5%;
    bottom: 10%;
    right: 30%;
  }

  .soap_06 {
    width: 5%;
    height: 5%;
    bottom: 15%;
    right: 45%;
  }



}

@media screen and (max-width:480px) {

  .tel a {
    pointer-events: auto;

  }

  .section_titile {
    width: 70%;
  }

  .kiji_photo div {
    width: 100%;
    margin: 1% 0;
  }

  /* logo */
  #logo a {
    top: -5%;
    left: 5%;
    width: 35%;
    height: 35%;
  }

  #logo a:hover {
    width: 35%;
    height: 35%;
    top: -5%;
    left: 5%;
  }

  /*news*/
  .news_box a {
    width: 100%;
    margin: 0 0 4% 0;
  }

  .news_box a:last-of-type {
    margin: 0;
  }

  .news_box ul {
    height: auto;
  }


  /* recruit */
  #recruit li {
    width: 100%;
  }

  /* year */
  .month {
    width: 100%;
  }

  .month dt {
    width: 30%;
  }

  /* mail */
  #mail input[type=submit],
  #mail input[type=reset] {
    padding: 10px 5%;
    box-sizing: border-box;
    width: 80%;
    margin: 0 auto 15px auto;
  }

  #mail form dl.form_btn {
    display: block;
    margin: 0 auto;
  }

  #mail form .form_btn dt {
    width: 100%;
    margin: 0 auto;
  }

  #mail form .form_btn dd {
    margin: 0 auto;
    width: 100%;
  }

}


.mwform-checkbox-field label,
.mwform-radio-field label {
  cursor: pointer;
}