@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200..900&display=swap");

/*
Theme Name:aozora
Author:corocorotamago
Version:1.0
*/

/* reCaptchaを非表示に */
.grecaptcha-badge {
  visibility: hidden;
}

html,
body {
  height: 100%;
}

body > footer {
  position: sticky;
}

html {
  scroll-behavior: smooth;
  font-size: 62.5%;
}

a {
  text-decoration: none;
  color: #370c00;
}

img {
  max-width: 100%;
  max-height: 100%;
  display: block;
}

.container {
  max-width: 1600px;
  margin: 0 auto;
  width: inherit;
  text-align: justify;
  padding: 0 70px;
}

body {
  font-family:
    "ヒラギノ丸ゴ Pro W4", "ヒラギノ丸ゴ Pro", "Hiragino Maru Gothic Pro",
    "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "HG丸ｺﾞｼｯｸM-PRO",
    "HGMaruGothicMPRO";
  font-size: clamp(16px, 4vw, 1.8rem);
  font-weight: bold;
  color: #370c00;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  background-color: #ffedc2;
}
body.page-id-15 {
  background-color: #ffedf3;
}
footer {
  margin-top: auto;
}

body::after {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
  background-image:
    url(img/jii-mail-r.svg), url(img/jii-mail-r-o.svg), url(img/icon-mail.svg),
    url(img/icon-mail-o.svg), url(img/ba-kyu-r.svg), url(img/ba-kyu-r-o.svg),
    url(img/mail-btn.svg), url(img/jii-mail.png), url(img/mail-btn-o.svg),
    url(img/jii-mail-o.png), url(img/kyu-btn.svg), url(img/ba-kyu.png),
    url(img/kyu-btn-o.svg), url(img/ba-kyu-o.png);
}

.font-s {
  font-size: clamp(16px, 4.5vw, 1.6rem);
}
.font-ss {
  font-size: clamp(16px, 4vw, 1.4rem);
}
.font-mb {
  font-size: clamp(18px, 5vw, 2rem);
}
.font-b {
  font-size: clamp(18px, 6vw, 2.4rem);
}
.box-underline {
  border-bottom: 2px dotted #370c00;
  padding: 0 0 10px 0;
  display: block;
}
.blue-color {
  color: #428fda;
}
.pink-color {
  color: #ea64ce;
}
.pink-color-m {
  color: #ffedf3;
}
.pink-backcolor {
  background-color: #ea64ce;
}

.pink-backcolor-m {
  background-color: rgba(234, 100, 206, 0.3);
}
.blue-border {
  border: 2px solid #428fda;
}
.pink-border {
  border: 2px solid #ea64ce;
}
.link-btn {
  padding: 10px 30px;
  border-radius: 30px;
  width: fit-content;
  margin-top: auto;
}
.blue-btn {
  color: #fff;
  background: #428fda;
}
.pink-btn {
  color: #fff;
  background: #ea64ce;
}
.blue-btn:hover {
  background: rgba(66, 143, 218, 0.7);
}
.pink-btn:hover {
  background: rgba(234, 100, 206, 0.7);
}

/* header */
.hed-second-tit,
.hed-menu-tit {
  position: fixed;
  top: 10px;
  left: 10px;
}
.hed-second-tit {
  z-index: 4;
}

.hed-menu-tit {
  z-index: 6;
}
.hed-first-area {
  z-index: 3;
  width: 100vw;
  position: fixed;
  top: 5px;
  left: 5px;
  display: flex;
}
.hed-tit-area {
  padding-left: 10px;
  z-index: 3;
}
.hed-tit-area img {
  height: 65px;
}

.hed-firstmenu-area {
  display: flex;
  position: fixed;
  top: 15px;
  left: 50%;
  transform: translate(-50%, 0%);
  padding-left: 210px;
  padding-right: 70px;
}
.hed-menubox {
  display: flex;
}
.hed-menu {
  font-size: 1.6rem;
  font-weight: 900;
  padding: 0 20px;
  white-space: nowrap;
  text-align: center;
}
.zaitaku > .hed-menubox a:hover {
  background-color: rgba(66, 143, 218, 0.3);
}
.shokuji > .hed-menubox a:hover {
  background-color: rgba(234, 100, 206, 0.3);
}
.nikki > .hed-menubox a:hover {
  background-color: rgba(255, 223, 96, 0.5);
}
.hed-menubox a {
  border-right: 1px solid #370c00;
}

.hed-menubox > .linenone {
  border-right: none;
}
.hed-telbox {
  margin: 5px;
  display: flex;
  justify-content: center;
  border-radius: 0 0 10px 10px;
  height: 30px;
}

.zaitaku > .hed-telbox {
  border-top: 3px solid #428fda;
  background-color: rgba(66, 143, 218, 0.3);
}
.shokuji > .hed-telbox {
  border-top: 3px solid #ea64ce;
  background-color: rgba(234, 100, 206, 0.3);
}
.anchor {
  scroll-margin-top: 80px;
}
/* ハンバーガーメニュー */
.burger {
  width: 60px;
  height: 60px;
  background-image: url(img/burger-menu.svg);
  background-color: #ffdf60;
  background-position: center;
  background-repeat: no-repeat;
  margin-left: auto;
  cursor: pointer;
  border-radius: 10px;
  z-index: 5;
  position: fixed;
  top: 10px;
  right: 10px;
}

.burger:hover {
  border: none;
  background-color: #82ceff;
}
.burger.is-active {
  background-image: url(img/burger-close.svg);
}

.menu {
  /*  display: flex;*/
  align-items: center;
  justify-content: center;
  width: 100vw;
  height: 100vh;
  background-color: #b8e3ff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 4;
  display: none;
}
.menu.is-active {
  display: flex;
}
.menu-back-illust-box {
  position: fixed;
  width: 100%;
  bottom: 20px;
  padding: 0 20px;
  display: flex;
  justify-content: space-between;
  gap: 16px; /* 画像同士の余白 */
}
.menu-back-illust-box img {
  max-height: 60px;
  flex: 1; /* 画面に合わせて縮む */
}

.menu-green-area {
  position: fixed;
  bottom: 0px;
  height: 30px;
  width: 100vw;
  background-color: #63a55e;
}

.burger-area {
  max-width: 1000px;
  height: 75vh;
  margin: auto;
  display: flex;
  width: inherit;
  text-align: justify;
  z-index: 7;
}
.burger-menu-area,
.burger-infoarea {
  width: 50%;
}
.burger-menu-area {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background-color: rgba(255, 255, 255, 0.5);
  border-radius: 20px;
  padding: 20px;
}

.burger-menu {
  text-align: center;
  white-space: nowrap;
  justify-content: space-between;
  padding: 5px 20px;
}

.burger-menu:hover {
  background-color: #ffdf60;
  border-radius: 10px;
}

.burger-menu-smoll {
  font-size: clamp(14px, 4.5vw, 1.6rem);
}

.burger-infoarea {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  margin-right: 40px;
  text-align: center;
}
.burger-tel-area {
  border-radius: 20px;
  padding: 20px;
  margin-top: 20px;
  display: block;
  align-items: center;
}
.burger-zaitaku {
  background-color: rgba(66, 143, 218, 0.3);
}
.burger-shokuji {
  background-color: rgba(234, 100, 206, 0.3);
}
.burger-tel-box {
  padding: 10px 0 10px 37px;
  position: relative;
  display: flex;
  align-items: center;
  margin: 0 auto;
  width: fit-content;
}
.burger-tel-box::before {
  content: "";
  display: block;
  width: 30px;
  height: 30px;
  background: url(img/icon-tel.svg) no-repeat center center;
  background-size: contain;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
}
.burger-time-area {
  margin: 0 auto;
  text-align: left;
}
.burger-time {
  padding-right: 20px;
}
.burger-info-btn {
  padding: 5px 20px 5px 57px;
  position: relative;
  display: flex;
  align-items: center;
  margin: 10px auto;
  width: fit-content;
  border: 2px solid #370c00;
  border-radius: 30px;
}
.burger-info-btn::before {
  content: "";
  display: block;
  width: 30px;
  height: 30px;
  background: url(img/icon-mail.svg) no-repeat center center;
  background-size: contain;
  position: absolute;
  top: 50%;
  left: 20px;
  transform: translate(0, -50%);
}

.burger-info-btn:hover {
  background: #370c00;
  color: #ffdf60;
}

.burger-info-btn:hover::before {
  content: "";
  display: block;
  width: 30px;
  height: 30px;
  background: url(img/icon-mail-o.svg) no-repeat center center;
  background-size: contain;
  position: absolute;
  top: 50%;
  left: 20px;
  transform: translate(0, -50%);
}

.burger-info-shokuji-s {
  border-top: 2px dotted #370c00;
  padding: 10px 0;
  display: block;
}
.burger-info-com {
  text-align: left;
}

/*********************/
.right-btn-area,
.right-btn-area-top {
  position: fixed;
  top: 85px;
  right: 10px;
  z-index: 3;
  display: flex;
  flex-direction: column;
  width: fit-content;
}
.right-btn-box,
.right-btn-box-top {
  display: flex;
  align-items: end;
  width: fit-content;
  margin: 5px 0;
}

/* じいの後にボタン */
.jii > .right-btn-illust-top {
  width: 62px;
  height: 64px;
  background-image: url(img/jii-mail-r.svg);
}
.jii > .right-btn-illust-top:hover {
  background-image: url(img/jii-mail-r-o.svg);
}
/* ばぁの後にボタン */
.baa > .right-btn-illust-top {
  width: 62px;
  height: 64px;
  background-image: url(img/ba-kyu-r.svg);
}
.baa > .right-btn-illust-top:hover {
  background-image: url(img/ba-kyu-r-o.svg);
}
/* じぃのボタン */
.jii .right-btn-com {
  width: 160px;
  height: 55px;
  background-image: url(img/mail-btn.svg);
}
.jii .right-btn-illust {
  width: 62px;
  height: 64px;
  background-image: url(img/jii-mail.png);
}
.jii:hover {
  .right-btn-com {
    background-image: url(img/mail-btn-o.svg);
  }
  .right-btn-illust {
    background-image: url(img/jii-mail-o.png);
  }
}

/* ばぁのボタン */
.baa .right-btn-com {
  width: 160px;
  height: 55px;
  background-image: url(img/kyu-btn.svg);
}
.baa .right-btn-illust {
  width: 62px;
  height: 64px;
  background-image: url(img/ba-kyu.png);
}
.baa:hover {
  .right-btn-com {
    background-image: url(img/kyu-btn-o.svg);
  }
  .right-btn-illust {
    background-image: url(img/ba-kyu-o.png);
  }
}

/***********************/
/* scroll */
.scroll {
  width: 20px;
  position: fixed;
  bottom: 10px;
  right: 30px;
  z-index: 3;
  animation: fluffy1 2s ease infinite;
}
@keyframes fluffy1 {
  0% {
    transform: translateY(0);
  }
  5% {
    transform: translateY(0);
  }
  10% {
    transform: translateY(0);
  }
  20% {
    transform: translateY(-10px);
  }
  25% {
    transform: translateY(0);
  }
  30% {
    transform: translateY(-10px);
  }
  50% {
    transform: translateY(0);
  }
  100% {
    transform: translateY(0);
  }
}
/* header end */

/* fv start */

.fv-area {
  position: relative;
  display: grid;
  place-items: center;
  width: 100%;
  height: 100vh;
  max-height: 100vh;
  background: #b8e3ff;
}
.fv-green-area {
  width: 100%;
  height: 240px;
  bottom: 0;
}
.fv-green-illust-box {
  height: 40px;
  background: url("img/fv-green-top.svg") repeat-x left bottom;
  background-size: auto 40px; /* ← これ重要 */
  display: block;
  line-height: 0;
  font-size: 0;
  /*  margin-bottom: -1px;*/
}
.fv-green-box {
  margin-top: 0;
  background: #63a55e;
  height: 200px;
}
.taiyou {
  top: 13%;
  left: 10%;
}
.ojiichan {
  bottom: 170px;
  left: 2%;
}
.obaachan {
  bottom: 180px;
  right: 55%;
}
.aozora-illust {
  width: 50%;
  bottom: 100px;
  right: 0;
}
.fv-img {
  position: absolute;
}
.fv-catch {
  top: 50%;
  left: 18%;
  transform: translate(0, -50%);
  padding: 0 40px;
  writing-mode: vertical-rl;
  display: flex;
  flex-direction: column;
  justify-content: center;
  white-space: nowrap;
  position: absolute;
  font-size: clamp(1.2rem, 4vw, 2.2rem);
}
.fv-catch-b {
  font-size: clamp(1.6rem, 5vw, 2.5rem);
}
.fade-in {
  opacity: 0;
  animation: fadeIn 1s ease-out forwards;
}

@keyframes fadeIn {
  to {
    opacity: 1;
  }
}

.fv-info-area {
  bottom: 30px;
  padding: 0 50px 0 0;
  position: absolute;
}
.fv-info-area-tit {
  color: #ffdf60;
}
.fv-info-box {
  min-width: 280px;
  background-color: #fff;
  border-radius: 10px;
  padding: 10px 20px;
  margin-top: 5px;
}
.fv-info-box-tit:hover {
  color: #ff8800;
}
.fv-info-box-day {
  width: fit-content;
  color: #7f7f7f;
  margin-left: auto;
}
/* fv end */

/* トップページ */
.aisatsu-area {
  width: 100%;
  background: #63a55e;
}
.aisatsu-box {
  width: fit-content;
  margin: 0 auto;
  padding: 100px 0;
  color: #ffedc2;
  line-height: 2;
  text-align: center;
  font-size: clamp(1.2remm, 3vw, 1.8rem);
}

.fade {
  opacity: 0;
  transform: translateY(20px);
  transition: all 2s ease;
}

.fade.show {
  opacity: 1;
  transform: translateY(0);
}

.second-green-area {
  height: 40px;
  background: url("img/second-green.svg") repeat-x top center;
}
.mori-second-area {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 20px; /* 画像同士の余白 */
  margin-top: -60px;
}
.mori-second-img {
  width: fit-content;
  max-height: 60px;
}
.mori-second-area img {
  flex: 1; /* 画面に合わせて縮む */
}

/* トップメイン */
.top-main-area {
  padding: 100px 0;
}
.top-main-title-area {
  width: fit-content;
  margin: 0 auto 100px;
  font-size: 3rem;
}
.top-main-about-area {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.top-main-about-area > div {
  flex: 0 0 30%;
  margin-bottom: 70px;
}
.top-main-about-area > div:last-child {
  flex: 0 1 65%;
}
.top-main-about-box {
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: 30px;
  padding: 30px 0;
  align-items: center;
}

.top-main-about-img {
  display: flex;
  align-items: baseline;
  justify-content: flex-end;
  width: fit-content;
  max-height: 220px;
  margin: -80px auto 0;
}
.top-main-about-box img {
  flex: 1; /* 画面に合わせて縮む */
}
.top-main-about-cach {
  width: fit-content;
  margin: 20px auto 3px;
}

.top-mian-about-tit {
  width: fit-content;
  margin: 0 auto;
  font-size: 2.4rem;
}
.top-main-about-com {
  text-align: center;
  padding: 20px;
}
.height-min {
  height: fit-content;
}
.top-main-sub-area {
  display: flex;
  flex-direction: column;
  border-bottom: 2px solid #370c00;
}
.top-main-sub-tit {
  font-size: 2rem;
  padding: 15px;
}
.top-main-sub-box {
  border-top: 2px solid #370c00;
  padding: 15px;
  display: flex;
  flex-direction: column;
  height: 100%;
}
.top-main-sub-btn-area {
  margin-top: auto;
  margin-left: auto;
}
.top-main-sub-btn {
  padding: 10px 0 10px 37px;
  position: relative;
  display: flex;
  align-items: center;
  width: fit-content;
  color: #ff8800;
}

.top-main-sub-btn:hover {
  color: rgba(255, 136, 0, 0.7);
}
.top-main-sub-btn::before {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  background: url(img/sankaku.svg) no-repeat center center;
  background-size: contain;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
}
/* TOP お知らせと日記 */
.bottom-oshirase-area {
  background: #ffdf60;
  border-radius: 20px;
  display: flex;
  flex-direction: column;
  padding: 30px;
}

.bottom-oshirase-tit {
  width: fit-content;
  margin: 0 auto;
  font-size: 2.4rem;
}

.bottom-oshirase-btn {
  width: fit-content;
  margin-top: 10px;
  margin-left: auto;
  background: #ff8800;
  color: #fff;
  border-radius: 15px;
  padding: 2px 15px;
}
.bottom-oshirase-btn:hover {
  background: rgba(255, 136, 0, 0.7);
}

/* お知らせと日記 */
.oshirase-kijiarea {
  display: flex;
  flex-wrap: wrap;
}

.oshirase-box {
  padding: 30px 0;
  flex: 0 0 30%;
  margin: 1.66%;
}

.oshirase-photo-area:hover {
  opacity: 0.7;
}
.oshirase-photo-area img {
  object-fit: cover;
  width: 100%;
  height: 300px;
  border-radius: 20px;
  margin: 0 auto;
}

.oshirase-cat-area {
  margin: 5px 0;
  display: flex;
  flex-wrap: wrap;
}
.oshirase-cat {
  width: fit-content;
  border-radius: 15px;
  background: #fff;
  color: #ff8800;
  padding: 2px 15px;
  margin: 3px;
}
.oshirase-cat:hover {
  opacity: 0.7;
}
.oshirase-daytit {
  word-break: break-word;
  overflow-wrap: break-word;
}
.oshirase-daytit:hover {
  color: #ff8800;
}

.ohirase-day-area {
  width: fit-content;
  display: flex;
  margin-left: auto;
  align-items: center;
}
.oshirase-day {
  width: fit-content;
  color: #7f7f7f;
  margin-left: auto;
}

.new {
  font-size: 1.2rem;
  margin: 5px 0;
  width: fit-content;
  margin: 0 auto;
  padding-right: 20px;
  color: #d73c3c;
}

.archive-link {
  width: fit-content;
  margin: 50px auto 0;
}

.archive-link {
  padding: 30px 0 100px;
  width: fit-content;
  margin: 0 auto;
  color: #7f7f7f;
  letter-spacing: 3px;
}
.archive-link a {
  background-color: #ffdf60;
  padding: 5px 10px;
  color: #370c00;
  border-radius: 10px;
}

.archive-link a:hover {
  background-color: #82ceff;
}
/* お知らせと日記ここまで */
/* single */
.single-com {
  width: fit-content;
  margin: 0 auto;
}
.single-btn-area {
  width: fit-content;
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin: 50px auto;
  justify-content: center;
}
.single-url-btn {
  background-color: #ffdf60;
  color: #370c00;
  padding: 5px 15px;
  border-radius: 15px;
  margin-bottom: 10px;
}
.single-url-btn:hover {
  background-color: #82ceff;
}
.single-img-area {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.single-img-box {
  flex: 0 0 30%;
  margin: 1.66%;
  padding-bottom: 30px;
}
.single-img-box:hover {
  opacity: 0.8;
}
.single-img-box img {
  width: 100%;
  border-radius: 20px;
}
.single-img-com {
  margin-top: 10px;
}
.single-back-btn-area {
  display: flex;
  justify-content: space-between;
  margin: 70px 0;
}
.back-btn:hover {
  opacity: 0.7;
}

/* footer start */
/* footer 空エリア */
.foot-sora-area {
  height: 80px;
  background: url("img/food-sora-back.svg") repeat-x bottom center;
}
.sora-second-area {
  display: flex;
  align-items: baseline;
  gap: 20px;
  margin-top: -80px;
}
.sora-second-area img {
  flex: 1; /* 画面に合わせて縮む */
}
.sora-second-img-right,
.sora-second-img-left {
  width: fit-content;
  max-height: 49px;
}
.sora-second-img-left {
  margin-left: auto;
}
.food-sora-com-area {
  background: #b8e3ff;
  padding: 50px 0 70px;
}
.food-sora-com-box {
  margin: 0px auto;
  padding: 70px 0 50px;
  width: fit-content;
  line-height: 1.6;
  text-align: center;
}
.food-sora-tel-area {
  display: flex;
  width: fit-content;
  margin: 0 auto;
}

.foot-sora-tel-box,
.foot-sora-mail-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  border: 2px solid #370c00;
  border-radius: 20px;
  width: fit-content;
  padding: 20px;
  margin: 10px;
}
.food-tel-btn {
  margin: 20px auto;
  background-color: #370c00;
  color: #fff;
  border-radius: 15px;
  padding: 3px 15px;
}

.food-sora-shokuji-time {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: fit-content;
  padding: 20px;
  margin: 10px;
}
.foot-sora-mail-box:hover {
  background: rgba(55, 12, 0, 0.1);
}

.foot-info-btn {
  padding: 0 0 0 40px;
  position: relative;
  display: flex;
  align-items: center;
  margin: auto;
  width: fit-content;
}
.foot-info-btn::before {
  content: "";
  display: block;
  width: 30px;
  height: 30px;
  background: url(img/icon-mail.svg) no-repeat center center;
  background-size: contain;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
}
/* footer 森エリア */
.food-mori-area {
  height: 30px;
  background: #63a55e url("img/food-mori-back.svg") repeat-x top center;
}
.food-mori-box {
  background: #63a55e;
}
.food-area {
  padding: 50px 30px 0;
  display: flex;
}
.food-tit-area {
  display: flex;
  flex-direction: column;
}

.food-tit-box {
  width: fit-content;
  display: flex;
  flex-direction: column;
}
.food-add-area {
  padding-top: 10px;
}
.food-oshirase-area {
  padding: 50px 0 20px;
  width: fit-content;
  display: flex;
}
.food-oshirase-box {
  width: fit-content;
  margin-right: 20px;
  display: flex;
  flex-direction: column;
}
.food-oshirase-titbar {
  background: #370c00;
  color: #fff;
  text-align: center;
  padding: 2px 20px;
  margin-bottom: 20px;
}
.food-oshirase-stit {
  padding: 2px 10px;
  text-align: center;
}
.food-oshirase-link-btn-box {
  display: flex;
  border: 2px solid #370c00;
  border-radius: 15px;
  margin: 5px 20px 15px;
}
.food-oshirase-link-btn {
  padding: 3px 15px 3px 45px;
  position: relative;
  display: flex;
  align-items: center;
  margin: 0 auto;
  width: fit-content;
}
.food-oshirase-fukushi-btn {
  padding: 3px 20px;
  position: relative;
  display: flex;
  align-items: center;
  margin: 0 auto;
  width: fit-content;
}
.food-oshirase-link-btn::before {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  background: url(img/instagram.svg) no-repeat center center;
  background-size: contain;
  position: absolute;
  top: 50%;
  left: 15px;
  transform: translate(0, -50%);
}
.food-oshirase-link-btn-box:hover {
  background: rgba(55, 12, 0, 0.2);
}

.food-menu-area {
  margin-left: auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.food-menu-area a {
  width: fit-content;
  margin-left: auto;
  padding: 5px 0;
}
.food-menu-area a:hover {
  color: #ffdf60;
}
.food-mo-insta-area {
  width: fit-content;
  margin: 20px auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.food-mo-insta-area a {
  margin: 5px;
}

/* コピーライト */
.copy-area {
  border-top: 1px solid #370c00;
  text-align: right;
  padding: 5px 20px;
}
.copy-box {
  width: fit-content;
  padding: 0 10px;
  margin-left: auto;
}

/* ページ */

.top-go-btn {
  display: flex;
  width: fit-content;
  margin: 100px auto;
}

.shokuji-area {
  background: #ffedf3;
}
.page-tit-area {
  display: flex;
  align-items: flex-end;
  padding: 130px 0 50px;
}
.page-tit-box {
  display: flex;
  flex-direction: column;
  width: fit-content;
  margin: 0 auto;
}
.page-tit-scom {
  width: fit-content;
  font-size: clamp(16px, 5vw, 1.8rem);
}
.tit-center {
  margin: 0 auto;
}

.page-tit {
  margin: 0 auto;
  font-size: clamp(16px, 7vw, 4rem);
}
.page-tit-area img {
  margin: 0 auto;
  max-width: 80%;
  height: auto;
  padding-right: 60px;
}
.page-tit-com-area {
  width: fit-content;
  margin: 0 auto;
  text-align: center;
  line-height: 2;
  font-size: clamp(16px, 4vw, 1.8rem);
}

.page-sub-tit {
  padding: 3px 3px 3px 50px;
  position: relative;
  display: flex;
  align-items: center;
  margin: 100px auto 70px;
  width: fit-content;
}
.page-sub-tit::before {
  content: "";
  display: block;
  width: 40px;
  height: 40px;
  background: url(img/taiyou-s.svg) no-repeat center center;
  background-size: contain;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
}

.page-komidashi {
  width: fit-content;
  margin: 0 auto 50px;
}

.page-com-area {
  width: fit-content;
  margin: 0 auto 50px;
  text-align: center;
  line-height: 1.6;
}
.page-com-list-area {
  width: fit-content;
  margin: 0 auto;
  line-height: 1.6;
}
ul {
  padding-left: 20px;
}
.page-table-area {
  display: flex;
  flex-direction: column;
  width: fit-content;
  margin: 60px auto 0;
}

.page-table-box {
  display: flex;
  width: 100%;
  padding: 20px 10px;
  border-bottom: 1px dotted #370c00;
}
.page-table-area div:last-child {
  border: none;
}

.page-table-tit {
  width: 150px;
}
.page-table-com {
  width: fit-content;
}
.day-nagare-area {
  background-color: #fff;
  padding: 50px 30px;
  border-radius: 20px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: fit-content;
  margin: 100px auto 0;
}
.day-nagare-area > .page-sub-tit {
  margin: 0 auto 50px;
}
.day-nagare-wrap {
  padding: 0 0 70px;
  display: grid;
  align-items: center;
  grid-template-columns: repeat(10, auto);
}

.day-nagare {
  display: flex;
  align-items: center;
  background: #370c00;
  color: #fff;
  border-radius: 20px;
  height: 150px;
  width: 200px;
  margin: 10px;
}
.day-nagare-wrap img {
  width: 24px;
  height: auto;
}
.day-nagare div {
  margin: 0 auto;
  width: fit-content;
}
.day-reku-area {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.day-reku-box {
  border-radius: 20px;
  border: 2px solid #370c00;
  padding: 2px 20px;
  margin: 10px;
}

.heimen {
  margin: 0 auto;
  width: 90%;
}

.day-access-area {
  display: flex;
}
.day-access-photo-area {
  display: flex;
  flex-direction: column;
  width: 48%;
}

.access-photo {
  border-radius: 20px;
}
.day-access-add {
  width: fit-content;
  margin: 10px auto 0;
}
.day-access-map {
  position: relative;
  width: 50%;
  margin-left: auto;
}

.day-access-map iframe {
  border-radius: 20px;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.day-access-bus-area {
  margin: 50px 0;
  padding: 20px 20px 40px 20px;
  border: 2px dotted #370c00;
}

.day-access-bus-area div {
  width: fit-content;
}
.day-access-bus-tit {
  margin: 0 auto 20px;
}
.day-access-bus-s {
  display: flex;
  margin: 0 auto;
}
.bus-shudan,
.bus-time {
  padding-left: 10px;
  padding-right: 10px;
}
.bus-time {
  border-top: 1px dashed #370c00;
  transform: translate(0, 50%);
  padding-top: 2px;
}
.page-insuta-area {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: fit-content;
  margin: 50px auto 100px;
  border-radius: 20px;
  gap: 30px;
  padding: 10px 0;
}

.page-insta-com {
  width: fit-content;
  margin: 0 auto;
}
.page-insta-btn {
  padding: 10px 30px 10px 55px;
  border-radius: 30px;
  position: relative;
  display: flex;
  align-items: center;
  margin: 0 auto;
  width: fit-content;
}
.page-insta-btn::before {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  background: url(img/Instagram-w.svg) no-repeat center center;
  background-size: contain;
  position: absolute;
  top: 50%;
  left: 25px;
  transform: translate(0, -50%);
}
.page-insta-qr-area:hover {
  opacity: 0.7;
}
.page-insta-qr-tit {
  text-align: center;
}
.houmon-naiyou-area {
  display: flex;
  gap: 40px;
}
.houmon-naiyou-tit {
  background: #370c00;
  border-radius: 20px;
  color: #fff;
  text-align: center;
  margin-bottom: 20px;
}
.houmon-naiyou-stit {
  align-items: center;
  display: flex;
}
.houmon-naiyou-stit::before,
.houmon-naiyou-stit::after {
  background-color: #370c00;
  border-radius: 5px;
  content: "";
  flex-grow: 1;
  height: 2px;
}
.houmon-naiyou-stit::before {
  margin-right: 15px;
}
.houmon-naiyou-stit::after {
  margin-left: 15px;
}
.table-div {
  width: fit-content;
}

/* アコーディオン */
.toggle_contents {
  margin: 70px 0;
  background-color: #fff;
  border-radius: 15px;
  padding: 30px 0;
}
.toggle_title {
  padding: 10px 20px;
  position: relative;
  cursor: pointer;
  padding-right: 40px;
  overflow-wrap: break-word;
  text-align: center;
}

.q-txt {
  font-size: 3.5rem;
  padding-right: 50px;
  color: #ea64ce;
}

.toggle_btn {
  position: absolute;
  /*  bottom: 15%;*/
  top: 50%;
  right: 50px;
  transform: translateY(-50%);
  background: #ea64ce;
  display: block;
  width: 24px;
  height: 24px;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  border-radius: 50%;
}
.toggle_btn:before,
.toggle_btn:after {
  display: block;
  content: "";
  background-color: #fff;
  position: absolute;
  width: 10px;
  height: 2px;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.toggle_btn:before {
  width: 2px;
  height: 10px;
}
.toggle_title.selected .toggle_btn:before {
  content: normal;
}
.toggle_contents .activitytxt {
  display: none;
}
.activitytxt {
  padding-top: 20px;
  width: 95%;
  margin: 0 auto;
  word-break: keep-all;
}
/* 中身の装飾 */
.chiiki-tit {
  margin: 10px 0;
}
.chiiki-ichiran {
  word-break: normal;
  overflow-wrap: break-word;
  text-align: center;
}
.place {
  white-space: nowrap;
  padding: 0 10px;
}
/* アコーディオン ここまで */

/* 写真横スクロール */

.slider-bento {
  width: 70%;
  margin: 70px auto 30px;
  display: flex;
  background-color: #efefef;
  overflow: hidden;
  border-radius: 20px;
}

.slider-bento-list {
  display: flex;
  margin: 0;
  padding: 0;
  align-items: center;
  animation: slideShow 50s infinite linear;
  list-style: none;
}

.slider-bento-item {
  width: 250px;
  height: 300px;
}

.slider-bento-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  margin: 0 0.5rem;
}

.slider-bento:hover .slider-bento-list {
  animation-play-state: paused;
}

@keyframes slideShow {
  0% {
    transform: translateX(0%);
  }

  100% {
    transform: translateX(-100%);
  }
}
/* 写真横スクロール ここまで */

.haitatsu-menu-area {
  width: 70%;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 0 auto;
}
.haitatsu-menu-box {
  width: 100%;
  display: flex;
  flex-direction: column;
  margin: 30px auto 0;
}
.haitatsu-menu-bar-area {
  display: flex;
  border-radius: 20px;
  padding: 2px 20px;
  align-items: center;
}
.haitatsu-menu-s {
  padding-left: 20px;
}
.haitatsu-menu-yen {
  width: fit-content;
  margin-left: auto;
  padding: 5px 0;
}
.haitatsu-choshoku-com {
  margin: 10px;
}

.magokoro,
.koharu,
.okazu,
.chosyoku {
  padding: 3px 0 0 40px;
  position: relative;
  display: flex;
  align-items: center;
  width: fit-content;
}
.magokoro:before {
  content: "";
  display: block;
  width: 30px;
  height: 30px;
  background: url(img/icon-ha-to.svg) no-repeat center center;
  background-size: contain;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
}
.koharu:before {
  content: "";
  display: block;
  width: 30px;
  height: 30px;
  background: url(img/icon-sakura.svg) no-repeat center center;
  background-size: contain;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
}
.okazu:before {
  content: "";
  display: block;
  width: 30px;
  height: 30px;
  background: url(img/icon-okazu.svg) no-repeat center center;
  background-size: contain;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
}
.chosyoku:before {
  content: "";
  display: block;
  width: 30px;
  height: 30px;
  background: url(img/icon-pan.svg) no-repeat center center;
  background-size: contain;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
}
.kondate-area {
  display: flex;
  flex-direction: column;
  width: fit-content;
  margin: 100px auto;
}

.kondate-tit-area {
  display: flex;
  align-items: center;
}
.kondate-tit {
  width: fit-content;
  padding: 5px 20px;
  background-color: #370c00;
  color: #fff;
  border-radius: 20px;
  margin-bottom: 20px;
}
.kondate-com {
  padding-left: 20px;
}
.kondate-box {
  display: flex;
}
.kondate-box img {
  width: 50%;
}
/* 配達サービス イラスト挿入 */

.haitatsu-menu-illust {
  position: relative;
  z-index: 1;
}

.usagi {
  margin: 20px auto 0;
}
.hana {
  position: absolute;
  top: 100%;
  right: 10px;
  transform: translate(0, -100%);
}

.momo {
  position: absolute;
  top: 90px;
  left: 10px;
  transform: translate(0, -100%);
}
.pengin {
  position: absolute;
  top: -76px;
  right: 100px;
}
.yuki {
  position: absolute;
  top: -40px;
  right: 22%;
}

.neko {
  position: absolute;
  top: -70px;
  right: 40%;
  z-index: -1;
}

/* 配達サービス イラスト挿入 ここまで */
/* 個人情報 */
.kojin-com {
  width: fit-content;
  margin: 20px auto;
}
ol.kojin-ol {
  margin: 100px 0;
  padding-left: 20px;
}
ol.kojin-ol li {
  margin: 20px 0 0;
  line-height: 2;
}
ol.in-ol li {
  margin: 0;
}

ol.in-ol {
  list-style: none;
  counter-reset: num;
  padding-left: 0;
}
ol.in-ol li {
  counter-increment: num;
  padding-left: 2em;
  position: relative;
}
ol.in-ol li::before {
  content: counter(num) "）";
  position: absolute;
  left: 0;
}
ul.in-ul {
  list-style-type: disc;
}
ul.in-ul li {
  margin: 0;
}
.kojin-name {
  width: fit-content;
  margin-left: auto;
  margin-bottom: 100px;
}
/* 個人情報 ここまで */

/* 求人情報 ここから */

.job-table-area {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: flex-start;
  margin: 0 auto 50px;
}
.job-table-box {
  width: 95%;
  margin: 0 auto;
}
.job-list-tit,
.job-list-com {
  padding: 10px 0;
  vertical-align: top;
}
.job-table-tr {
  border-bottom: 1px solid #7f7f7f;
  display: flex;
}
.job-list-tit {
  width: 20%;
  color: #428fda;
  white-space: nowrap;
}
.job-list-com {
  width: 80%;
  padding-left: 20px;
}
.job-contact-area {
  max-width: 80%;
  width: fit-content;
  margin: 0 auto 70px;
}
.job-contact-com {
  width: fit-content;
}
.left-poji {
  margin-left: auto;
}
.job-rei-area {
  background-color: #fff;
  border-radius: 20px;
  padding: 50px 20px;
  margin-bottom: 50px;
}
.job-rei-tit {
  width: fit-content;
  margin: 0 auto 30px;
}
.job-rei-box-area {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: flex-start;
  gap: 40px;
}
.job-rei-box {
  width: 100%;
  table-layout: fixed;
  border-collapse: collapse;
}
.job-rei-box-tit {
  background-color: #ffdf60;
  padding: 10px;
}
.job-rei-box-com {
  padding: 10px;
}
/* 求人情報 ここまで */

/****************************************************/

/* お問い合わせ */

.contact-area {
  width: 70%;
  margin: 0 auto 100px;
}
.contact-area iframe {
  width: fit-content;
}

.contact-message {
  width: fit-content;
  margin: 50px auto 0;
}
.turnstile-wrap {
  text-align: center;
}
.contact-area p {
  margin-top: 30px;
}
.contact-tel-area {
  position: relative;
  display: flex;
  width: fit-content;
  margin: 70px auto;
  border: 2px solid #370c00;
  border-radius: 20px;
}
.contact-box-title {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  background: #ffedc2;
  padding: 0 10px;
  white-space: nowrap;
}
.contact-tel-box {
  width: fit-content;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 30px auto 20px;
  padding: 0 20px;
}
.border-left {
  border-right: 2px dashed #370c00;
}

/* 入力項目を見やすく */
.yours {
  width: 100%;
  padding: 8px 15px;
  margin: 5px 0;
  border: 1px solid #333;
  border-radius: 3px;
}

.yours-s {
  padding: 8px 15px;
  margin: 5px 0;
  border: 1px solid #333;
  border-radius: 3px;
}

/* 「送信する」ボタン */
input.wpcf7-submit {
  display: block;
  padding: 15px;
  width: 200px;
  height: 60px;
  background: #f2955e;
  border: 3px solid #f2955e;
  font-size: 1.8rem;
  font-weight: bold;
  border-radius: 30px;
  margin: 15px auto;
}
.contact-privacy-area {
  width: fit-content;
  margin: 0 auto 70px;
}
.privacychecktxt {
  width: fit-content;
  margin: 0 auto;
  padding-left: 50px;
  font-size: 1.4rem;
  padding-bottom: 30px;
}
.privacychecktxt a {
  border-bottom: 1px solid #333;
  padding-bottom: 2px;
}
.privacychecktxt a:hover {
  color: #f2955e;
  border-bottom: 1px solid #f2955e;
}
.underline {
  text-decoration: underline;
  text-decoration-color: #333;
}

.underline a:hover {
  color: #f2955e;
  text-decoration: underline;
  text-decoration-color: #f2955e;
}

input.wpcf7-submit:hover {
  border: 3px solid #333333;
  background: none;
}
/* エラーメッセージを見やすく */
span.wpcf7-not-valid-tip,
.wpcf7-response-output.wpcf7-validation-errors {
  color: red;
  font-weight: 600;
}
.wpcf7-response-output {
  font-size: 1.6rem;
  font-weight: bold;
  width: fit-content;
  margin: 0 auto !important;
  border: 0 !important;
  background: #f2e744;
}
