@charset "utf-8";
html {
  overflow-x: hidden;
  scroll-behavior: smooth;
}

img {
  max-width: 100%;
}

li {
  list-style: none;
}

a {
  text-decoration: none;
}

.wrapper {
  max-width: 80%;
  margin: 10rem 0;
}

#main-content {
  /* background-color: #ede67d; */
  /* background-color: #bca67e; */
  font-family: "Zen Maru Gothic", sans-serif;
  overflow: hidden;
  background: url(../img/back.jpg) repeat;
  background-size: contain;
}

.br {
  display: inline-block;
}

.small {
  font-size: 1rem;
}

.sec_title {
  width: 40%;
  margin: 0 auto;
  rotate: -3deg;
}

.ri_title {
  rotate: 3deg;
}

.back_box {
  width: 100%;
  padding: 3rem 0;
  align-items: center;
  margin-top: -2.8rem;
  box-shadow: 1px 1px 10px rgba(1, 1, 1, .7) ;
  /* background: url(../img/back.jpg) repeat;
  background-size: contain; */
}

.rig_wrap {
  margin-left: auto;
}

.mark_wrap,.hure_wrap {
  text-align: center;
  background-color: #fff578;
  border-radius: 0 50px 50px 0;
}

.trans_wrap,.talk_box {
  padding: 5rem 0;
  border-radius: 50px 0 0 50px;
  text-align: center;
  background-color: #fff578;
}


/* 画像横並び */
.img_box {
  width: 100%;
  margin-top: -2.8rem;
  text-align: center;
}

.img_con {
  display: flex;
  justify-content: space-around;
  gap: 1rem;
  margin-top: 3rem;
  padding: 0 1rem;
}

.img_icon {
  width: calc( 100% / 3 );
  aspect-ratio: 1 / 1;
  margin: 3rem 0;
  border-radius: 15px;
  border: 5px solid #e95513;
  box-shadow: inset 2px 2px 5px #333;
}

/* ボタン */
.button {
  display: inline-flex;
  align-items: center;
  text-align: center;
  justify-content: center;
  min-width: 250px;
  padding: 1.5rem 1rem;
  border-radius: 50px;
  background-color: #7a4c35;
  color: #fff;
  font-size: 1.2rem;
  font-weight: bold;
  transition: all .3s ease;
}

.button::after {
  content: "";
  display: inline-flex;
  align-items: center;
  width: 30px;
  height: 30px;
  margin-left: 1.2rem;
  background: url(../img/niku_wh.png) no-repeat center;
  background-size: contain;
}

.button:hover {
  background: #e95513;
  color: #ede67d;
}

/* ボタンサブ */
.btnsb {
  display: inline-block;
  width: 300px;
  margin: 1rem 0;
  padding: 1.2rem 1rem;
  border-radius: 15px;
  background: #e95513;
  color: #fff;
  font-size: 1.3rem;
  transition: all .5s ease;
  font-weight: bold;
}

.btnsb:hover {
  background: #6bb72d;
  color: #ede67d;
}

.btn-copy {
  font-size: 1rem;
  font-weight: bold;
  position: relative;
  margin: 0 auto .2em;
  text-align: center;
  color: #7a4c35;
  width: 45%;
}

.btn-copy:before {
  content: "";
  width: 2px;
  height: 45px;
  border-radius: 1px;
  background-color: #7a4c35;
  position: absolute;
  bottom: 0;
  left: -3%;
  rotate: -16deg;
}

.btn-copy:after {
  content: "";
  width: 2px;
  height: 45px;
  border-radius: 1px;
  background-color: #7a4c35;
  position: absolute;
  bottom: 0;
  right: -3%;
  rotate: 16deg;
}

@media (max-width: 768px) {
  .btn-copy {
    width: 80%;
  }
}

/* セクション枠 */
.sec_text {
  width: 70%;
  padding: 1rem;
  margin: 2rem auto;
  background-color: rgba(122, 76, 53, .93);
  box-shadow: 0 0 0 8px rgba(122, 76, 53, .93);
  border: 2px dashed #fff;
  color: #fff;
  font-size: 1.3rem;
  border-radius: 5px;
}

.sec_text p {
  margin: 1rem 0;
}

/* 歩く肉球*/
.walk img {
  width: 50px;
  height: 50px;
  position: absolute;
  rotate: 220deg;
}

.walk_01 {
  bottom: 12%;
  right: -10%;
}

.walk_02 {
  bottom: 10%;
  right: -4%;
}

.walk_03 {
  bottom: 0%;
  right: -4.1%;
}

.walk_04 {
  bottom: -2%;
  right: 2%;
}

.walk_05 {
  bottom: -10%;
  right: 4%;
}

@media (max-width: 768px) {
  .wrapper {
    max-width: 100%;
  }

  .sec_text {
    width: 90%;
    font-size: 1rem;
  }

  .small {
    font-size: .9rem;
  }

  .img_con {
    gap: .3rem;
  }

  .img_icon {
    border: 2px solid #e95513;
  }

  /* 歩く肉球*/
  .walk img {
    width: 35px;
    height: 35px;
  }

  .walk_01 {
    bottom: 12%;
    right: 3%;
  }

  .walk_02 {
    bottom: 5%;
    right: 2%;
  }

  .walk_03 {
    bottom: 3%;
    right: 11%;
  }

  .walk_04 {
    bottom: -4%;
    right: 10%;
  }

  .walk_05 {
    bottom: -5%;
    right: 21%;
  }
}

/* 波 */
/* .nami{
  content: "";
  width: 100%;
  height: 60px;
  overflow:hidden;
  position:relative;
}
.nami::before{
  content:'';
  font-family:'shape divider from ShapeDividers.com';
  position: absolute;
  bottom: -1px;
  left: -1px;
  right: -1px;
  top: -1px;
  z-index: 3;
  pointer-events: none;
  background-repeat: no-repeat; 
  background-size: 100% 30px;
  background-position: 50% 0%;    
  background-image: url('data:image/svg+xml;charset=utf8, <svg preserveAspectRatio="xMidYMax slice" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 2000.4 78.7"><g fill="%23e95513"><path d="M0 59V0h2000v61c-11-1-22-6-32-13-10-6-19-14-30-20a90 90 0 00-91 4c-10 6-18 15-28 21a80 80 0 01-68 8 80 80 0 01-68-8c-10-6-19-15-29-21a90 90 0 00-91-4l-29 20c-10 6-22 12-34 13a33 33 0 01-4-1v1c-12-1-23-6-32-13l-30-20a90 90 0 00-91 4c-10 6-18 15-28 21a80 80 0 01-69 8 80 80 0 01-68-8c-10-6-18-15-28-21a90 90 0 00-91-4c-11 6-20 14-30 20s-21 12-33 13a33 33 0 01-4-1v1c-12-1-23-6-33-13l-29-20a90 90 0 00-92 4c-9 6-18 15-28 21a80 80 0 01-68 8 80 80 0 01-68-8c-10-6-18-15-28-21a89 89 0 00-91-4c-11 6-20 14-30 20l-6 4c-8 5-17 8-27 9a33 33 0 01-5-1v1c-11-1-22-6-32-13-10-6-19-14-30-20l-3-1a87 87 0 00-35-10 90 90 0 00-43 9 81 81 0 00-10 6l-8 6-20 15a80 80 0 01-68 8 80 80 0 01-68-8l-20-15-8-6a82 82 0 00-11-6 90 90 0 00-44-8 87 87 0 00-35 9l-2 1-29 20A79 79 0 010 59z" opacity=".75"/><path d="M1523 0h454a33 33 0 01-16 20h-2a33 33 0 01-22 2 22 22 0 01-16 15 15 15 0 01-6 5 22 22 0 01-13 3 52 52 0 01-14-4l-11-5-35-17a75 75 0 00-51-2 157 157 0 00-41 27 151 151 0 00-46-28c-15-4-31-2-45 3-13 5-24 11-36 17l-11 5a52 52 0 01-13 4 22 22 0 01-14-3 15 15 0 01-6-5 22 22 0 01-16-15 33 33 0 01-22-2h-1a33 33 0 01-17-20z" opacity=".5"/><path d="M1496 0h504v13c-6 11-20 16-31 12a37 37 0 01-10-5c-7-5-14-13-24-15-12-3-24 4-34 12-8 6-15 14-24 19a43 43 0 01-7 3c-14 4-29 1-42-5-11-5-21-12-32-18l-5-3c-13-6-27-10-41-7-14-3-28 1-41 7l-5 3c-11 6-21 13-32 18-13 6-28 9-42 5a43 43 0 01-7-4c-9-4-16-12-24-18-10-8-22-15-34-12-10 2-17 10-24 15a37 37 0 01-10 5c-14 5-31-4-34-19l-1-6z"/><circle cx="1940.6" cy="49.4" r="8.5"/><circle cx="1841.1" cy="46.1" r="5.2"/><circle cx="1624.5" cy="46.1" r="5.2"/><circle cx="1564.4" cy="42" r="7.3"/><circle cx="1894" cy="72.9" r="5.8" opacity=".5"/><circle cx="1679.1" cy="72.9" r="5.8" opacity=".5"/><circle cx="1750" cy="72.9" r="2.8" opacity=".75"/><path d="M1019 0h454a33 33 0 01-17 20h-1a33 33 0 01-22 2 22 22 0 01-17 15 15 15 0 01-5 5 22 22 0 01-14 3 52 52 0 01-13-4l-11-5-36-17a75 75 0 00-50-2 157 157 0 00-41 27 151 151 0 00-46-28c-15-4-31-2-46 3l-35 17-11 5a52 52 0 01-14 4 22 22 0 01-13-3 15 15 0 01-6-5 22 22 0 01-17-15 33 33 0 01-22-2h-1a33 33 0 01-16-20z" opacity=".5"/><path d="M992 0h504v13c-6 11-20 16-32 12a37 37 0 01-9-5c-8-5-15-13-24-15-12-3-25 4-35 12-7 6-15 14-23 19a43 43 0 01-7 3c-14 4-29 1-42-5-11-5-21-12-32-18l-5-3c-13-6-27-10-41-7-14-3-29 1-41 7l-5 3c-11 6-21 13-33 18-13 6-28 9-41 5a43 43 0 01-7-4c-9-4-16-12-24-18-10-8-22-15-35-12-9 2-16 10-24 15a37 37 0 01-9 5c-14 5-31-4-34-19l-1-6z"/><circle cx="1436.3" cy="49.4" r="8.5"/><circle cx="1336.8" cy="46.1" r="5.2"/><circle cx="1120.3" cy="46.1" r="5.2"/><circle cx="1060.2" cy="42" r="7.3"/><circle cx="1389.7" cy="72.9" r="5.8" opacity=".5"/><circle cx="1174.8" cy="72.9" r="5.8" opacity=".5"/><circle cx="1245.7" cy="72.9" r="2.8" opacity=".75"/><path d="M514 0h455a33 33 0 01-17 20h-1a33 33 0 01-22 2 22 22 0 01-17 15 15 15 0 01-6 5 22 22 0 01-13 3 52 52 0 01-13-4l-12-5-35-17a75 75 0 00-50-2 157 157 0 00-41 27 150 150 0 00-46-28c-15-4-31-2-46 3l-36 16-11 5a52 52 0 01-13 4 22 22 0 01-14-2 15 15 0 01-5-5 22 22 0 01-17-15 33 33 0 01-22-2h-1a33 33 0 01-17-20z" opacity=".5"/><path d="M488 0h504v13c-6 11-20 16-32 12a37 37 0 01-9-5c-8-5-15-13-24-15-12-3-25 4-35 12-8 6-15 14-24 18a43 43 0 01-7 4c-13 4-28 1-41-5l-33-18-4-3c-13-6-28-10-42-7-13-3-28 1-41 7l-4 3-33 18c-13 6-28 9-41 5a43 43 0 01-8-4c-8-4-16-12-23-18-10-8-23-15-35-12-9 2-16 10-24 15a37 37 0 01-9 5c-14 5-31-4-35-19V0z"/><circle cx="932" cy="49.4" r="8.5"/><circle cx="832.6" cy="46.1" r="5.2"/><circle cx="616" cy="46.1" r="5.2"/><circle cx="555.9" cy="42" r="7.3"/><circle cx="885.4" cy="72.9" r="5.8" opacity=".5"/><circle cx="670.6" cy="72.9" r="5.8" opacity=".5"/><circle cx="741.4" cy="72.9" r="2.8" opacity=".75"/><path d="M10 0h454a33 33 0 01-16 20h-2a33 33 0 01-21 2 22 22 0 01-17 15 15 15 0 01-6 5 22 22 0 01-13 3 52 52 0 01-14-4l-11-5-35-17a75 75 0 00-50-2 157 157 0 00-41 27 150 150 0 00-47-28c-14-4-31-2-45 3l-36 16-11 5a52 52 0 01-13 4 22 22 0 01-14-2 15 15 0 01-5-5 22 22 0 01-17-15 33 33 0 01-22-2h-1A33 33 0 0110 0z" opacity=".5"/><path d="M0 24V0h488v13c-7 11-20 16-32 12a37 37 0 01-10-5c-7-5-14-13-23-15-13-3-25 4-35 12h-1c-7 7-14 14-23 18a43 43 0 01-7 4c-10 3-21 2-31-1a84 84 0 01-10-4c-12-5-22-12-33-18l-5-3c-12-6-27-10-41-7-14-3-28 1-41 7l-5 3c-11 6-21 13-32 18a83 83 0 01-9 4c-11 3-22 4-33 1a43 43 0 01-7-4c-8-4-15-11-23-18h-1C77 9 64 2 52 5c-9 2-16 10-24 15a37 37 0 01-10 5 26 26 0 01-18-1z"/><circle cx="427.8" cy="49.4" r="8.5"/><circle cx="328.3" cy="46.1" r="5.2"/><circle cx="111.7" cy="46.1" r="5.2"/><circle cx="51.6" cy="42" r="7.3"/><circle cx="381.1" cy="72.9" r="5.8" opacity=".5"/><circle cx="166.3" cy="72.9" r="5.8" opacity=".5"/><circle cx="237.2" cy="72.9" r="2.8" opacity=".75"/></g></svg>'); 
}

@media (min-width:768px){
  .nami::before{
  background-size: 100% 60px;
  background-position: 50% 0%;   
  }  
}

@media (min-width:1025px){
  .nami::before{ 
  bottom: -0.1vw;
  left: -0.1vw;
  right: -0.1vw;
  top: -0.1vw; 
  background-size: 100% 60px;
  background-position: 50% 0%;  
  }
}

@media (min-width:2100px){
  .nami::before{
  background-size: 100% calc(2vw + 60px);
  }
} */


/* スプラッシュ画面 */
#splash {
  position: fixed;
  width: 100%;
  height: 100%;
  background: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
  animation: splashFadeOut .5s ease forwards;
  animation-delay: 3s;
}

@keyframes splashFadeOut {
  to {
    opacity: 0;
    visibility: hidden;
  }
}

.trai {
  position: relative;
  width: 100%;
  height: 100%;
}

.paw {
  position: absolute;
  top: var(--top,50%);
  left: var(--left,50%);
  width: clamp(40px, 8vw, 100px);
  opacity: 0;
  transform: scale(0.6) rotate(-10deg);
  animation: pop 0.6s ease forwards;
  animation-delay: var(--delay,0s);
  rotate: 90deg;
}

@keyframes pop {
  0% {
    opacity: 0;
    transform: scale(0.6) rotate(-10deg);
  }

  50% {
    opacity: 1;
    transform: scale(1.2) rotate(-10deg);
  }

  100% {
    opacity: 1;
    transform: scale(1) rotate(-10deg);
  }
}

.paw_01 {
  top: 40%;
  left: 35%;
  animation-delay: 0s;
}

.paw_02 {
  top: 50%;
  left: 42%;
  animation-delay: .6s;
}

.paw_03 {
  top: 40%;
  left: 49%;
  animation-delay: 1.2s;
}

.paw_04 {
  top: 50%;
  left: 56%;
  animation-delay: 1.8s;
}

.paw_05 {
  top: 40%;
  left: 63%;
  animation-delay: 2.4s;
}

@media (max-width: 768px) {

  .paw_01 {
    top: 40%;
    left: 20%;
  }
  
  .paw_02 {
    top: 47%;
    left: 30%;
  }
  
  .paw_03 {
    top: 40%;
    left: 43%;
  }
  
  .paw_04 {
    top: 47%;
    left: 54%;
  }
  
  .paw_05 {
    top: 40%;
    left: 65%;
  }
}

/* フェードイン */
.fade {
  opacity: 0;
  transition: opacity .8s ease-out, transform .8s ease-out;
}

.fade.is-inview {
  opacity: 1;
  transition-delay: .8s;
}

.fadeUp {
  opacity: 0;
  transform: translateY(50px);
  transition: opacity .5s ease-out, transform .5s ease-out;
}

.fadeUp.is-inview {
  opacity: 1;
  transform: translateY(0);
  transition-delay: .5s;
}

.fadeLeft {
  opacity: 0;
  transform: translateX(-50px);
  transition: opacity .5s ease-out, transform .5s ease-out;
}

.fadeLeft.is-inview {
  opacity: 1;
  transform: translate(0);
  transition-delay: .5s;
}

.fadeRight {
  opacity: 0;
  transform: translateX(50px);
  transition: opacity .5s ease-out, transform .5s ease-out;
}

.fadeRight.is-inview {
  opacity: 1;
  transform: translate(0);
  transition-delay: .5s;
}

/* トップへ戻るボタン */
#page_top {
  width: 100px;
  aspect-ratio: 5 / 4;
  position: fixed;
  bottom: -90px;
  right: 3%;
  background: url(../img/niku_toppage.png) no-repeat;
  background-size: contain;
  opacity: 1;
  z-index: 90;
  cursor: pointer;
}

.top_niku {
  display: block;
  width: 100%;
  height: 100%;
}

@media (max-width: 768px) {
  #page_top {
    width: 70px;
  }
}

/*ナビゲーション*/
.menu {
  width: 100%;
  position: fixed;
  top: 0;
  z-index: 30;
  transition: all 0.4s ease;
  opacity: 1;
  transform: translateY(0);
  display: flex;
  align-items: center;
}

.menu.hide {
  transform: translateY(-160%);
  transition: transform 0.4s ease;
}

.menu.show {
  transform: translateY(0);
  transition: transform 0.4s ease;
}

.nav {
  width: 100%;
  height: 80px;
  display: flex;
  justify-content: space-around;
  margin: 0 auto;
  padding: 1rem 0;
  background-color: rgba(237, 230, 125, 1);
  align-items: center;
  font-weight: bold;
  font-size: 1.2rem;
  z-index: 99;
}

.nav li a {
  display: inline-block;
  position: relative;
  padding: 1rem 1rem .7rem;
  color: #7a4c35;
  font-weight: bold;
  transition: .3s;
  letter-spacing: .2rem;
}

.nav li a:hover {
  color: #e95513;
}

.nav li a:hover::after {
  content: "";
  position: absolute;
  bottom: -17%;
  left: 50%;
  transform: translateX(-50%);
  width: 25px;
  height: 25px;
  background: url(../img/niku.png) no-repeat;
  background-size: contain;
}

@media screen and (max-width: 1240px) {
  .hamburger {
    position: fixed;
    top: 15px;
    right: 20px;
    width: 50px;
    z-index: 10;
    padding: .5rem;
    border-radius: 5px;
    background-color: #7a4c35;
    /* cursor: pointer; */
    z-index: 150;
  }

  .hamburger span {
    display: block;
    height: 3px;
    width: 100%;
    background-color: #ede67d;
    margin: 5px 0;
    transition: .4s;
    border-radius: 3px;
  }

  .menu {
    position: fixed;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(237, 230, 125, 1);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.5s ease;
    padding: 20px;
    box-sizing: border-box;
    z-index: 5;
    flex-direction: column;
    align-items: center;
    z-index: 99;
  }

  .nav {
    flex-direction: column;
    margin: 0;
    width: 100%;
    height: 100%;
    align-items: center;
    justify-content: center;
    background-color: rgba(255, 55, 36, 0.01);
  }

  .nav li {
    margin: 5px;
  }

  .nav li a {
    padding: 1.3rem 1rem;
  }

  .menu.open {
    opacity: 1;
    pointer-events: auto;
  }

  .hamburger.active span:nth-child(1) {
    transform: rotate(45deg) translate(5px, 5px);
  }

  .hamburger.active span:nth-child(2) {
    opacity: 0;
  }

  .hamburger.active span:nth-child(3) {
    transform: rotate(-45deg) translate(6px, -6px);
  }

  .nav li a:hover {
    text-shadow: none;
    color: #fff;
  }

  .nav li a:hover::after {
    display: none;
  }
}

/* メインビジュアル */
.mv {
  width: 100%;
  position: relative;
  top: 75px;
}

.husen_le,.husen_ri {
  position: absolute;
  width: 15.5%;
  height: 23%;
}

.husen_le {
  top: 8%;
  left: 28.5%;
  animation: move 2s linear infinite;
  background: url(../img/husen_le.png) no-repeat;
  background-size: contain;
}

.husen_ri {
  top: 8%;
  right: 24%;
  animation: move 3s linear infinite;
  background: url(../img/husen_ri.png) no-repeat;
  background-size: contain;
}

@keyframes move {
  0%   { transform: translateY(0); }
  50%  { transform: translateY(15px); }
  100% { transform: translateY(0); }
}

.flag-container .flag {
  position: absolute;
  top: 8.6%;
  left: 49.55%;
  width: 10%;
  height: auto;
}

picture img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.time {
  background-color: #7a4c35;
  text-align: center;
}

.time img {
  width: 80%;
}

@media (max-width: 768px) {
  .husen_le {
    width: 26%;
  }

  .husen_ri {
    width: 19%;
  }

  .husen_le {
    top: 6%;
    left: 20%;
  }

  .husen_ri {
    top: 13%;
    right: 17.5%;
  }

  .flag-container .flag {
    width: 16%;
    left: 50%;
    top: 12%;
  }

  .sec_title {
    width: 90%;
    padding: 1rem;
  }
}

/* 概要 */
#view {
  text-align: center;
  margin: 6rem auto;
  padding-top: 3rem;
}

.view_box {
  max-width: 1000px;
  margin: 3rem auto;
  display: flex;
  align-items: center;
  gap: 20px;
}

.map {
  width: 40%;
}

.spon {
  width: 60%;
}

.spon_item {
  width: 100%;
  display: flex;
  gap: 10px;
  align-items: center;
  margin-bottom: 1rem;
}

.spon_item h3 {
  width: 25%;
}

.spon_logo {
  width: 75%;
  text-align: left;
}

.spon_logo img {
  width: 80%;
  border-radius: 10px;
}

.spon_sb {
  text-align: left;
  width: 75%;
}

@media (max-width: 768px) {
  .view_box {
    flex-direction: column;
  }

  .map {
    width: 100%;
  }

  .spon {
    width: 100%;
  }
}

/* 番組内容 */
#about {
  background-color: #83e2fa;
  height: 110vh;
  padding: 1rem;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-size: 1.3rem;
  z-index: 0;
  overflow: hidden;
}

.about_wrap {
  max-width: 900px;
  padding: 3rem 1rem 2rem;
  margin-top: -8rem;
  background-color: rgba( 255, 255, 255, .8);
  border-radius: 15px;
  z-index: 12;
  letter-spacing: .1rem;
  line-height: 1.7;
}

.about_wrap h2 {
  margin-bottom: 1.5rem;
}

.about_wrap p {
  margin-bottom: 1rem;
}

.kumo {
  position: absolute;
  width: 20%;
  height: 38%;
  background: url(../img/kumo.png) no-repeat;
  background-size: contain;
  opacity: .8;
}

.kumo_01 {
  top: 0;
  left: 6%;
  animation: floatScale 10s ease-in-out infinite;
}

.kumo_02 {
  bottom: -6.5%;
  left: 20%;
  animation: floatScale 8s ease-in-out infinite;
}

.kumo_03 {
  width: 16%;
  top: 7%;
  right: -4%;
  animation: floatScale 16s ease-in-out infinite;
}

@keyframes floatScale {
  0% {
    transform: translate(0px, 0px) scale(1);
  }
  25% {
    transform: translate(10px, -5px) scale(1.05);
  }
  50% {
    transform: translate(-10px, 5px) scale(0.95);
  }
  75% {
    transform: translate(5px, -5px) scale(1.02);
  }
  100% {
    transform: translate(0px, 0px) scale(1);
  }
}

.kusa_yama {
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 30vh;
  background: url(../img/kusa.png) no-repeat;
  background-size: cover;
}

.omise_le {
  position: absolute;
  width: 20%;
  height: 33%;
  bottom: 0%;
  left: 17%;
  background: url(../img/omise_le.png) no-repeat;
  background-size: contain;
}

.omise_ri {
  position: absolute;
  width: 20%;
  height: 35%;
  bottom: -7%;
  right: 17%;
  background: url(../img/omise_ri.png) no-repeat;
  background-size: contain;
}

.tree {
  position: absolute;
  width: 8%;
  height: 10%;
  background: url(../img/tree.png) no-repeat center;
  background-size: contain;
}

.tr01 {
  bottom: 15%;
  right: 6%;
}

.tr02 {
  bottom: 11%;
  right: 37%;
}

.tr03 {
  bottom: 0;
  left: 42%;
}

.tr04 {
  bottom: 7%;
  left: 9%;
}

@media (max-width: 768px) {
  #about {
    font-size: 1rem;
    height: 120vh;
  }

  .about_wrap {
    letter-spacing: 0.05rem;
    margin-top: -13rem;
  }

  .omise_le {
    width: 38%;
    height: 20%;
    bottom: 3%;
    left: 5%;
  }

  .omise_ri {
    width: 38%;
    height: 20%;
    bottom: -4%;
    right: 13%;
  }

  .tree {
    width: 17%;
  }

  .tr01 {
    bottom: 11%;
    right: 7%;
  }

  .tr02 {
    bottom: 15%;
    right: 27%;
  }

  .tr03 {
    bottom: 17%;
    left: 28%;
  }

  .tr04 {
    bottom: 2%;
    left: 0;
  }

  .kumo {
    width: 30%;
  }

  .kumo_02 {
    bottom: -7.5%;
    left: -6%;
  }

  .kumo_03 {
    width: 24%;
  }
}

/* マルシェ */ 
#market {
  position: relative;
}

.ma_01 {
  background: url(../img/ma_01.jpg) no-repeat center;
  background-size: cover;
}

.ma_02 {
  background: url(../img/ma_02.jpg) no-repeat center;
  background-size: cover;

}

.ma_03 {
  background: url(../img/ma_03.jpg) no-repeat center;
  background-size: cover;
}

@media (max-width: 768px) {
  .button {
    font-size: 1rem;
  }
}

/* 保護猫譲渡会 */
#transfer,#talk {
  position: relative;
}

.ho_01 {
  background: url(../img/ho_01.jpg) no-repeat center;
  background-size: cover;
}

.ho_02 {
  background: url(../img/ho_02.jpg) no-repeat center;
  background-size: cover;

}

.ho_03 {
  background: url(../img/ho_03.jpg) no-repeat center;
  background-size: cover;
}

.tyousei {
  font-size: 1.2rem;
  font-weight: bold;
}

.neko_01,.neko_02,.wan_01 {
  position: absolute;
  content: "";
  width: 150px;
  height: 150px;
  z-index: 9;
}

.neko_01 {
  background: url(../img/neko_01.png) no-repeat;
  background-size: contain;
  top: -1%;
  left: -6%;
}

.neko_02 {
  background: url(../img/neko_02.png) no-repeat;
  background-size: contain;
  top: -10%;
  left: 6%;
}

.hogo_shop {
  text-align: center;
}

.hogo_shop-box {
  display: flex;
  width: 60%;
  margin: 0 auto 3rem;
  gap: 3rem;
  justify-content: center;
  align-items: center;
}

.calendar {
  width: calc( 100% / 2 );
}

.sec_flex {
  display: flex;
  align-items: center;
  gap: 2rem;
}

.sec_box {
  width: calc(100% / 2 - 2rem);
}

.shushu {
  text-align: center;
  width: calc(100% / 2);
}

.shushu_img {
  width: 50%;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background: url(../img/shushu.jpg) no-repeat top;
  background-size: contain;
  margin: 0 auto 0;
  box-shadow: inset 1px 1px 6px #333;
}

.shushu .balloon {
  font-size: 1.1rem;
  background-color: #ede67d;
  padding: 1rem;
  margin: 0 0 1rem 0;
  color: #7a4c35;
  font-weight: bold;
}

.shushu .balloon::after {
  border: solid 10px #ede67d;
}

.balloon {
  position: relative;
  display: inline-block;
  background: #7a4c35;
  color: #fff;
  margin: 2rem 0;
  padding: 2rem 1.3rem;
  border-radius: 12px;
  max-width: 500px;
  z-index: 0;
}

.balloon::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 20px;
  border: solid 10px #7a4c35;
  rotate: -45deg;
  z-index: -1;
}

#transfer .small {
  text-align: left;
  width: 70%;
  margin: 0 auto;
}

@media (max-width: 768px) {
  .neko_01 {
    top: -13%;
    left: 30%;
  }

  .sec_flex {
    flex-direction: column;
  }

  .sec_box {
    width: 100%;
  }

  .shushu {
    width: 100%;
  }

}

/* ふれあいコーナー */
#hureai {
  position: relative;
}

.wan_01 {
  background: url(../img/wan_01.png) no-repeat;
  background-size: contain;
  top: -6%;
  right: 0;
}

.hu_01 {
  background: url(../img/hu_01.jpg) no-repeat center;
  background-size: cover;
}

.hu_02 {
  background: url(../img/hu_02.jpg) no-repeat center;
  background-size: cover;

}

.hu_03 {
  background: url(../img/hu_03.jpg) no-repeat center;
  background-size: cover;
}

.sec_text .button {
  background-color: #fff;
  color: #7a4c35;
  margin: 1rem 0;
  box-shadow: inset 1px 1px 6px #333;
}

.sec_text .button:hover {
  background-color: #ede67d;
}

@media (max-width: 768px) {
    /* 歩く肉球*/
  #hureai .walk_01 {
    bottom: 4%;
    right: 3%;
  }

  #hureai .walk_02 {
    bottom: -1%;
    right: 2%;
  }

  #hureai .walk_03 {
    bottom: -1%;
    right: 13%;
  }

  #hureai .walk_04 {
    bottom: -6%;
    right: 10%;
  }

  #hureai .walk_05 {
    bottom: -6%;
    right: 21%;
  }

  .wan_01 {
    top: -14%;
  }
}

/* トークショー */
.talk_box {
  text-align: left;
  display: flex;
  flex-wrap: wrap-reverse;
  flex-direction: row-reverse;
  justify-content: start;
  align-items: start;
}

.timeline {
  position: relative;
  margin-left: 2rem;
  border-left: 4px solid #7a4c35;
  padding: 1rem 0 1rem 1rem;
  width: 60%;
}

.timeline-item {
  position: relative;
  margin-block: 2rem;
}

.timeline-date {
  font-weight: bold;
  color: #111;
  font-size: 1.1rem;
}

.timeline-content {
  margin-top: 0.5rem;
}

.timeline-content h3 {
  color: #e95513;
  margin-bottom: 1rem;
}

.timeline-content img {
  width: 20%;
  border-radius: 15px;
}

.timeline-item::before {
  content: "";
  position: absolute;
  left: -1.5rem;
  top: 0.25rem;
  width: 12px;
  height: 12px;
  background: #6bb72d;
  border: 2px solid #111;
  border-radius: 50%;
}

.nare {
  width: 30%;
  text-align: center;
  display: flex;
  flex-direction: column;
}

.nare_img {
  width: 70%;
  margin: 0 auto;
  z-index: 0;
}

.nare_img img {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  z-index: 1;
  border: 5px solid #e95513;
  z-index: 3;
}

.nare p {
  color: #fff;
  background-color: #e95513;
  border-radius: 15px;
  margin-top: -2rem;
  z-index: 6;
}

.ehon_box {
  display: flex;
  width: 60%;
  margin: 2rem auto 0;
}

.ehon_item {
  width: 100%;
  aspect-ratio: 5 / 7;
  border-radius: 15px;
}

.ehon_01 {
  background: url(../img/ehon_01.png) no-repeat;
  background-size: contain;
}

/* .ehon_02 {
  background: url(../img/ehon_02.png) no-repeat;
  background-size: contain;
} */

@media (max-width: 768px) {
  .talk_box {
    justify-content: center;
  }

  .nare {
    width: 60%;
  }

  .timeline {
    width: 100%;
    padding: 1rem;
  }

  .timeline-content img {
    width: 40%;
  }
}


/* フードコーナー */
#food .food_title {
  rotate: 0deg;
}

.food_wrapper {
  width: 80%;
  margin: 3rem auto;
}

.food_wrap {
  padding: 2rem 1rem;
  text-align: center;
  border-radius: 0 50px 50px 0;
  font-size: 1.2rem;
}

@media (max-width: 768px) {
  .food_wrapper {
    width: 100%;
  }
}

/* フッター */
#footer {
  position: relative;
  background-color: #9ec277;
  width: 100%;
  margin-top: 5rem;
  padding: 5rem 0;
}

.foot_kusa {
  position: absolute;
  contain: "";
  width: 100%;
  height: 75px;
  background: url(../img/kusa_foot.png) no-repeat;
  background-size: cover;
  top: -15%;
  z-index: 0;
}

.wan_foot,.neko_foot {
  position: absolute;
  content: "";
  width: 150px;
  height: 150px;
  z-index: 3;
}

.wan_foot {
  background: url(../img/wan_foot.png) no-repeat;
  background-size: contain;
  top: -45%;
  right: 20%;
}

.neko_foot {
  background: url(../img/neko_foot.png) no-repeat;
  background-size: contain;
  top: -45%;
  left: 20%;
}

.inquiry {
  max-width: 50%;
  margin: 0 auto;
  text-align: center;
}

@media (max-width: 768px) {
  .inquiry {
    max-width: 90%;
  }

  .wan_foot,.neko_foot {
    width: 70px;
    height: 70px;
    top: -25%;
  }
}


/* マルシェ別ページ */
.mark_head {
  height: 50vh;
  width: 100%;
  background: url(../img/back.jpg) center;
  background-size: contain;
  display: flex;
  justify-content: center;
  align-items: center;
  border-bottom: solid 15px #7a4c35;
}

.mark_contain {
  margin: 10rem auto;
}

.mark_title {
  rotate: 0deg;
}

.market_box {
  text-align: center;
}

.cards {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  margin: 5rem auto;
  padding: 1rem;
  gap: 12rem 2rem;
}

.card {
  position: relative;
  display: inline-block;
  /* perspective: 1000; */
  width: calc(100% / 2 - 2rem);
  border-radius: 2px;
  box-shadow: 0 0 3px 0 rgb(0 0 0 / 12%), 0 2px 3px 0 rgb(0 0 0 / 22%);
  background: #fff;
  padding: 0;
  margin-bottom: 25px;
  text-align: left;
  cursor: pointer;
  z-index: 1;
  transition: all .3s ease-in;
  border-radius: 15px 15px 0 0;
}

.card_img_holder {
  height: 0;
  padding-bottom: 56%;
  background: rgba(0,0,0,0.1);
  overflow: hidden;
  border-radius: 15px 15px 0 0;
}

.card_img_holder img {
  transition: all .1s ease-in;
}

.card:hover > .card_img_holder img {
  transform: scale(1.05);
}

.card img {
  width: 100%;
}

.card_title {
  position: relative;
  padding: 8px 18px 14px;
  background: #fff;
  z-index: 0;
}

.btn {
  position: relative;
  background: #7a4c35;
  color: #fff;
  display: inline-block;
  border-radius: 4px;
  box-shadow: 0 2px 0px 0 rgba(0,0,0,0.25);
  padding: 6px 30px 6px;
  transition: all .1s ease-out;
}

.btn:hover {
  background: #83e2fa;
  box-shadow: 0px 8px 2px 0 rgba(0,0,0,0.075);
  transform: translateY(-2px);
  transition: all .25s ease-out;
}

.btn:active {
  background: #83e2fa;
  box-shadow: 0 1px 0px 0 rgba(255,255,255,0.25);
  transform: translate3d(0,1px,0);
  transition: all .25s ease-out;
}

.card_title a.toggle_info {
  position: absolute;
  width: 32px;
  height: 32px;
  border-radius: 32px;
  top: 8px;
  right: 16px;
  padding: 0;
  margin: 0 !important;
}

.toggle_info span {
  display: block;
  position: absolute;
  top: 16px;
  width: 12px;
  height: 2px;
  background: #fff;
  transition: all .15s ease-out;
}

.left {
  right: 14px;
  transform: rotate(45deg);
}

.right {
  left: 14px;
  transform: rotate(-45deg);
}

.card_title p {
  color: #7a4c35;
  margin: 6px 0 3px;
  padding: 0;
  font-weight: bold;
  font-size: 1.2rem;
  letter-spacing: .05rem;
}

.card_description {
  position: relative;
  color: #313131;
  padding: 1rem;
  font-size: 1rem;
  line-height: 1.7;
}

.card_description p {
  margin-bottom: 1rem;
}

.card_flap {
  position: absolute;
  width: 100%;
  transform-origin: top;
  transform: rotateX(-90deg);
  background: #d9d9d9;
  box-shadow:  0 0 3px 0 rgb(0 0 0 / 12%), 0 2px 3px 0 rgb(0 0 0 / 22%);
  transition: all .3s ease-out;
  z-index: -1;
}

.card.show .card_flap {
  background: #fff;
  transform: rotateX(0deg);
}

.card.show {
  opacity: 1;
  transform: scale(1);
}

.card.show .toggle_info {
  background: #ff6666;
}

.card.show .toggle_info span {
  top: 15px;
}

.card.show .left {
  right: 10px;
}

.card.show .right {
  left: 10px;
}

.Reprise {
  position: relative;
}

.repr_ball {
  position: absolute;
  top: -30%;
  left: 3%;
  font-size: 1.1rem;
  font-weight: bold;
  max-width: 500px;
}

.pc_none {
  display: none;
}

@media screen and (max-width: 1220px) {
  .repr_ball {
    top: -60%;
    font-size: 1rem;
  }
}

@media (max-width: 768px) {
  .cards {
    flex-direction: column;
    gap: 5rem 2rem;
  }

  .card {
    width: 100%;
  }

  .repr_ball {
    display: none;
  }

  .pc_none {
    display: block;
    margin-top: .5rem;
    font-size: .85rem;
  }
}
