@charset "UTF-8";

/*!
Theme Name: Cocoon Child
Template:   cocoon-master
Version:    1.0.6
*/

/************************************
** 子テーマ用のスタイルを書く
************************************/
/*必要ならばここにコードを書く*/
body.home {
  margin: 0;
  padding: 0;
  height: 100%;
  /* overflow: hidden; */
}

.appeal {
  position: relative;
}

#video-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

#intro-video {
  width: 100%;
  /* height: 100%; */
  height: calc(631 / 1440 * 100vw);
  /* object-fit: 100% calc(631 / 1440 * 100vw); */
  filter: drop-shadow(0px 0px #000);
}

#skip-button {
  display: inline-block;
  position: absolute;
  bottom: 40px;
  right: 0;
  left: 0;
  color: #adadad;
  cursor: pointer;
  font-size: 19px;
  background-color: transparent;
  z-index: 10000;
  width: auto;
  margin: auto;
  text-align: center;
}

body.home {
  background-color: #fff !important;
}
body.page {
  background-color: #fff9de;
}

body.page .sidebar {
  background-color: #fff9de;
  padding-top: 0;
}

body.single,
body.archive,
body.blog {
  background-color: #ffffff;
}
body.archive .main,
body.single .main,
body.blog .main {
  background-color: #f6f7f2;
  border-radius: 19px;
}
body.archive .sidebar,
body.single .sidebar,
body.blog .sidebar {
  background-color: #f6f7f2;
  border-radius: 19px;
  padding-top: 19px;
}
body.blog .entry-card-wrap,
body.archive .entry-card-wrap {
  background-color: #ffffff;
  box-shadow: 2px 3px 6px #00000029;
}
body.blog .main h1,
body.archive .main h1,
body.single .main h1 {
  text-align: left;
}
body.page-id-34 {
  background-color: #fff;
}
body.page-id-36 {
  background-color: #f4f1ef;
}
body.blog .list,
body.archive .list {
  /* position: relative; */
}

body.blog .entry-card-wrap,
body.archive .entry-card-wrap {
  position: relative;
}

body.blog .list .entry-card,
body.archive .list .entry-card {
  position: inherit;
}

body.blog .list .entry-card .entry-card-thumb,
body.archive .list .entry-card .entry-card-thumb {
  position: inherit;
}

#header-container {
  background-color: #fff;
  border-bottom: solid 1px #d1d1d1;
}

#header-container .hlt-top-menu {
  background-color: #fff;
  padding: 30px 0;
}

#header-container #header {
  background-color: #fff;
}
#header-container .hlt-top-menu #navi {
  background-color: #fff;
}
.header-container-in.hlt-top-menu .logo-header {
  max-height: 74px;
}
.header-container-in.hlt-top-menu .logo-header img {
  max-height: 74px;
}
.site-name-text-link {
  padding: 0;
}

.navi-in > ul li {
  width: 192px;
  height: 34px;
  line-height: 34px;
  margin-left: 16px;
}

#header-container .hlt-top-menu #navi a:hover {
  /* background-color: inherit; */
}

#navi a:hover::after {
  transform: none;
}

#navi a::after {
  content: none;
}

#menu-item-39 a {
  color: #000;
  background-color: #ffe200;
  border-radius: 20px;
  font-weight: bold;
  font-size: 18px;
}

#menu-item-38 {
  width: 150px;
}

#menu-item-38 a {
  color: #fff;
  background-color: #2f2f2f;
  font-weight: bold;
  font-size: 18px;
}

.content-top,
.content-bottom {
  margin: 0;
  background: #ff9d4f;
}
.wwa .box-menu {
  width: 12.5%;
  background: #ff9d4f;
  color: #fff;
}
.box-menu {
  box-shadow: none;
  border-left: solid 1px #ffd0aa;
}
.box-menus:first-child {
  border-right: solid 1px #ffd0aa;
}

#box_menu-2 {
  margin-bottom: 0 !important;
}

#box_menu-2 .box-menus {
  margin-bottom: 0 !important;
}
.box-menu:hover {
  box-shadow: none;
}
.widget-sidebar .box-menu {
  box-shadow: none;
  border-left: solid 1px #fff;
  background: #ff9d4f;
  color: #fff;
  border-bottom: solid 1px #fff;
}
.notoserif {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-style: normal;
}
.home .wp-block-image {
  margin-bottom: 0;
}
.wp-block-column.is-layout-flow.wp-block-column-is-layout-flow p a {
  display: block;
  background: #ff9d4f;
  color: #fff;
  font-size: 14px;
  padding: 24px;
  border-radius: 0 0 14px 14px;
  text-decoration: none;
}

#footer-in {
  width: 516px;
}

#footer {
  background-color: #ff9d4f;
}

.footer-bottom-logo {
  position: relative;
  float: none;
}

.footer-bottom-content {
  float: none;
  text-align: center;
  margin-top: 32px;
}

.navi-footer-in > .menu-footer {
  justify-content: center;
}

.navi-footer-in > .menu-footer li {
  padding: 8px 0;
  border-left: none;
}

.footer-bottom.fnm-text-width .menu-footer li {
  width: auto;
  width: 12%;
}

.navi-footer-in > .menu-footer li:last-child {
  border-right: none;
}

.navi-footer-in > .menu-footer li:nth-child(n + 10) {
  width: 33%;
}

.footer #menu-item-79 {
  width: 100%;
}

#footer #navi-footer a {
  display: inline-block;
  color: white;
  font-size: 12px;
  background-color: transparent;
  text-decoration: none;
}

#footer #navi-footer a:hover {
  background-color: transparent;
  color: #fff;
}

.entry-title {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-size: 36px;
  font-style: normal;
  text-align: center;
  font-weight: normal !important;
}

#comment-area {
  border-top: solid 1px #adadad;
}

#comment-area h2 {
  font-size: 24px;
  background-color: transparent !important;
  border-radius: 0;
  margin-bottom: 1rem;
  padding-left: 0;
}

#comment-area .sub-caption {
  margin-left: 1rem;
}

#comment-area h3 {
  border-left: none;
  border-right: none;
  border-top: none;
  border-bottom: none;
  font-size: 17px;
  padding: 0px;
}

#comment-reply-btn {
  font-size: 18px;
  font-weight: bold;
  background: #ffe200;
  border-radius: 23px;
  color: #000;
  border: none;
}

#comment-area .comment-form .submit {
  margin: 1em 0;
  background: #1037a3;
  box-shadow: 0px 3px 6px #00000029;
  border-radius: 23px;
  color: #fff;
}

input[type="submit"].wpcf7-submit {
  background: #1037a3;
  max-width: 345px;
  width: 100%;
  margin: 0 auto;
  box-shadow: 0px 3px 6px #00000029;
  border-radius: 23px;
  color: #fff;
}

#wpdcom.wpd-layout-2 .wpd-form .wpd-avatar img,
#wpdcom.wpd-layout-2 .wpd-form .wpd-avatar img.avatar {
  border-bottom: none;
}

#wpdcom .avatar {
  border-bottom: none !important;
}

.cat-label {
  top: -14px;
  left: -12px;
  max-width: none;
  min-width: 37%;
  border: 0;
}

.sidebar h3 {
  background-color: transparent;
  padding: 0;
  margin: 0;
  font-size: 19px;
}

.copyright {
  color: #fff;
}

.page-id-167 .main {
  background-color: transparent;
}

.page-id-167 .main .entry-card-wrap {
  background-color: #fff;
  box-shadow: 2px 3px 6px #00000029;
  border-radius: 10px;
}
.page-id-167 .main h1 {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 24px;
}
.page-id-167 .main h1::before {
  content: "";
  display: inline-block;
  width: 60px;
  height: 1px;
  background-color: #333333;
  vertical-align: middle;
  margin-right: 20px;
}

.page-id-167 .main h1::after {
  content: "";
  display: inline-block;
  width: 60px;
  height: 1px;
  background-color: #333333;
  vertical-align: middle;
  margin-left: 20px;
}

.page-id-167 .main h2 {
  font-size: 24px;
  padding: 0;
  background-color: transparent;
  border-radius: 0;
  color: #ff9d4f;
}

.about-inner {
  position: relative;
  max-width: 976px;
  width: 98%;
  background: #fff9de;
  border-radius: 200px;
  margin: auto;
  padding: 60px 100px;
}

.about-inner::before {
  content: "";
  position: absolute;
  display: block;
  width: 0;
  height: 0;
  border-radius: 50%;
  transform: rotate(135deg);
  left: 0;
  bottom: -27px;
  border-left: 30px solid transparent;
  border-top: 30px solid transparent;
  border-right: 39px solid #fff9de;
  border-bottom: 25px solid #fff9de;
  right: 0;
  margin: auto;
}
.about-inner::after {
  content: "";
  position: absolute;
  display: block;
  width: 0;
  height: 0;
  border-radius: 50%;
  transform: rotate(135deg);
  left: 0;
  bottom: -27px;
  border-left: 20px solid transparent;
  border-top: 0px solid transparent;
  border-right: 9px solid #fff;
  border-bottom: 26px solid #fff;
  right: 0;
  margin: auto;
}
.about-inner h1 {
  font-family: "Noto Serif JP", serif;
  font-size: 36px;
  font-weight: normal;
  text-align: center;
  margin-bottom: 30px;
}

.about-inner h2 {
  font-family: "Noto Serif JP", serif;
  font-size: 22px;
  font-weight: bold;
  color: #ff9d4f;
  text-align: center;
  padding: 0;
  background-color: transparent;
  margin-top: 3rem;
  margin-bottom: 1rem;
}

.about-inner p {
  margin-top: 1rem;
}

.go-to-top .go-to-top-button {
  box-shadow: 0px -6px 2px #0000001a;
}

.box-menu-icon * {
  max-width: 54px;
  /* max-height: 54px; */
  max-height: 44px;
}

.mb-half {
  margin-bottom: 0.9em !important;
}

.footer {
  padding-bottom: 30px;
}

.footer-bottom {
  margin-top: 0;
}

.footer-bottom-content {
  margin-top: 0;
}

.go-to-top-button {
  width: 78px;
  height: 78px;
  border-radius: 24px;
}

.card-thumb img {
  border-radius: 8px;
}

.decent-comments .comment-avatar {
  padding-right: 4px;
  width: 20%;
  float: left;
}

.decent-comments .comment-author {
  width: 80%;
  font-size: 14px;
  float: right;
}

.comment-date {
  width: 80%;
  font-size: 12px;
  float: left;
}

.comment-link {
  display: block;
  font-size: 12px;
}

.comment-link a {
  color: #ff9d4f;
  font-size: 12px;
}

.decent-comments ul {
  padding: 0;
}

.decent-comments ul li {
  list-style: none;
  border-bottom: solid 1px #e1e1e1;
  padding-bottom: 13px;
  margin-top: 30px;
}

.decent-comments .comment-excerpt {
  display: block;
  position: relative;
  background: #fff;
  border: 1px solid #d1d1d1;
  border-radius: 4px;
  font-size: 12px;
  padding: 10px;
}

.decent-comments .comment-excerpt:before {
  content: "";
  position: absolute;
  top: -16px;
  left: 19px;
  border: 8px solid transparent;
  border-bottom: 8px solid #fff;
  z-index: 2;
}

.decent-comments .comment-excerpt:after {
  content: "";
  position: absolute;
  top: -20px;
  left: 17px;
  border: 10px solid transparent;
  border-bottom: 10px solid #d1d1d1;
  z-index: 1;
}

.main {
  border-radius: 19px;
}
#sp-about {
  display: none;
}

.appeal-in {
  width: 100%;
  height: calc(631 / 1440 * 100vw);
  min-height: auto;
  padding: 0;
}

.box-menus {
  display: flex;
  flex-wrap: wrap;
  align-items: end;
}

.box-menu {
  height: 114px;
}

.box-menus:first-child {
  border-right: none;
}

#wpdcom .wmu-attached-images {
  border-bottom: 0;
}

.wpd-cf-label {
  display: none;
}

.wpd-cf-value {
  font-size: 24px;
  color: #333333;
  font-weight: bold;
  border-bottom: none;
  padding: 0;
  display: block;
  margin-bottom: 0 0.5rem;
}

.ect-vertical-card .entry-card-wrap .entry-card {
  background-color: #fff;
}

.ect-vertical-card.ect-tile-card .entry-card-content {
  padding: 0.5rem;
}

/************************************
** レスポンシブデザイン用のメディアクエリ
************************************/
/*1240px以下*/
@media screen and (max-width: 1240px) {
  /*必要ならばここにコードを書く*/
  #header-container .hlt-top-menu {
    padding: 30px 20px;
  }
  .cat-label {
    top: calc(-14px / 1255 * 100vw);
    left: calc(-12px / 1255 * 100vw);
  }
}

/*1030px以下*/
@media screen and (max-width: 1030px) {
  /*必要ならばここにコードを書く*/
  #video-container {
    top: -175px;
  }
  .appeal-in {
    /* min-height: 631px; */
  }
  .home #header-container {
    display: none;
  }
  #sp-about {
    display: block;
    text-align: center;
    margin-top: 2rem;
  }

  #sp-about a {
    color: #000;
    background-color: #ffe200;
    border-radius: 20px;
    font-weight: bold;
    font-size: 18px;
    text-decoration: none;
    padding: 0.25rem 3rem;
  }
  .content-top {
    background: #fff;
  }
  .wwa .box-menu {
    width: 24.3%;
    /* border-left: solid 5px #fff; */
  }
  #header-container {
    border-bottom: none;
  }

  #box_menu-2 .box-menus {
    align-items: inherit;
    justify-content: center;
    gap: 5px;
    gap: 5px 0.9%;
  }
  #footer {
    display: none;
  }

  #navi-menu-content {
    background: #ffead9;
  }

  .menu-close-button {
    text-align: right;
    font-size: 2em;
  }

  .menu-close-button span {
    margin-right: 1.5rem;
    color: #d0b9aa;
  }

  .menu-drawer li {
    margin-bottom: 1rem;
  }

  .menu-drawer li a {
    border: none;
    background: #ff9d4f;
    border-radius: 5px;
    text-align: center;
    color: #fff;
  }

  .menu-drawer .sub-menu {
    padding-left: 20px;
    margin-top: 1rem;
    padding-left: 0.5rem;
  }

  .menu-drawer li .sub-menu li {
    margin-bottom: 0.5rem;
  }

  .menu-drawer li .sub-menu li a {
    display: inline-block;
    background: transparent;
    color: #707070;
    border: none;
    text-align: left;
  }

  .menu-drawer li .sub-menu li a::before {
    content: "▶";
    margin-right: 0.5rem;
  }
  .about-inner h1 {
    font-size: 24px;
  }
  .about-inner {
    border-radius: 50px;
    padding: 40px 20px;
  }
}

/*768px以下*/
@media screen and (max-width: 768px) {
  /*必要ならばここにコードを書く*/
}

/*480px以下*/
@media screen and (max-width: 480px) {
  /*必要ならばここにコードを書く*/
  .appeal .appeal-in {
    min-height: auto;
  }
  #skip-button {
    bottom: 15px;
    font-size: 14px;
  }

  .box-menu-label {
    font-size: 12px;
  }

  .wwa .box-menu {
    border-bottom: 0;
  }

  #box_menu-2 .box-menu:nth-child(2n) {
    border-right: 0;
  }

  #box_menu-2 .box-menu:nth-child(-n + 4) {
    border-bottom: 0;
  }

  .mobile-footer-menu-buttons {
    bottom: 0 !important;
    background: #646464;
    color: #fff;
  }
  .mobile-menu-buttons .menu-button > a {
    color: #fff;
  }
  .sp-24,
  .sp-24 span {
    font-size: 24px;
  }

  .wp-block-column.is-layout-flow.wp-block-column-is-layout-flow p a {
    font-size: 12px;
  }

  .wp-image-62 {
    width: 70px !important;
  }

  .sp-14 {
    font-size: 14px;
  }

  #header-container {
    border-bottom: none;
  }

  .page-id-167 .main h2 {
    font-size: 16px;
    margin-bottom: 0.25rem;
  }

  .page-id-167 .ect-entry-card .card-snippet,
  .page-id-167 .rect-entry-card .card-snippet,
  .page-id-167 .ect-big-card-first .card-snippet {
    clear: inherit;
    font-size: 11px;
  }
  .page-id-167 .entry-card-content {
    padding-bottom: 0;
  }

  .page-id-167 .ect-entry-card .card-thumb,
  .page-id-167 .rect-entry-card .card-thumb,
  .page-id-167 .ect-big-card-first .card-thumb {
    margin-right: 16px;
  }

  .page-id-167 .main .entry-card-wrap {
    background-color: #fff;
    box-shadow: 2px 3px 6px #00000029;
    border-radius: 10px;
    padding-top: 20px;
    padding-bottom: 20px;
    padding-left: 15px;
    padding-right: 15px;
  }

  .entry-title {
    font-size: 28px;
  }

  .entry-content {
    font-size: 14px;
  }

  .menu-item.menu-item-type-post_type.menu-item-object-page.menu-item-privacy-policy.menu-item-229
    a {
    background: none;
    color: #000;
  }
  .wpd-cf-value {
    font-size: 18px;
  }
  .e-card-title {
    padding-top: 1.25rem;
  }
  .cat-label {
    top: -8px;
    left: -5px;
    font-size: 12px;
    padding: 2px 5px;
  }
}
