@charset "UTF-8";
.sp_none {
  display: inherit;
}
@media only screen and (max-width: 959px) {
  .sp_none {
    display: none;
  }
}

.pc_none {
  display: none;
}
@media only screen and (max-width: 959px) {
  .pc_none {
    display: inherit;
  }
}

body {
  font-family: "Zen Kaku Gothic New", sans-serif;
  margin: 0;
  padding: 0;
  line-height: 1.8;
}

.root {
  overflow: hidden;
  background: url(../img/common/root_bg.webp);
  padding-top: 104px;
  font-size: 18px;
}
@media only screen and (max-width: 959px) {
  .root {
    padding-top: 50px;
  }
}
@media only screen and (max-width: 767px) {
  .root {
    padding-top: 50px;
  }
}

.logged-in header {
  top: 32px;
}
@media only screen and (max-width: 959px) {
  .logged-in header {
    top: 0;
  }
}
@media only screen and (max-width: 767px) {
  .logged-in header {
    top: 0;
  }
}
@media only screen and (max-width: 959px) {
  .logged-in #wpadminbar {
    display: none;
  }
}
@media only screen and (max-width: 767px) {
  .logged-in #wpadminbar {
    display: none;
  }
}

header {
  background: #ffffff;
  position: fixed;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  z-index: 14;
  width: 100%;
  min-height: 110px;
  -webkit-transition: 0.5s all;
  transition: 0.5s all;
  top: 0;
  -webkit-box-shadow: 0 5px 30px rgba(0, 0, 0, 0.2);
          box-shadow: 0 5px 30px rgba(0, 0, 0, 0.2);
}
@media only screen and (max-width: 959px) {
  header {
    -webkit-box-shadow: 0 0 3px rgba(0, 0, 0, 0.2);
            box-shadow: 0 0 3px rgba(0, 0, 0, 0.2);
    padding: 0;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
    min-height: 50px;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 100;
  }
}
@media only screen and (min-width: 960px) {
  header.hidden {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
  header.hidden .header_sideimg::before, header.hidden .header_sideimg::after {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
}

.header_sideimg {
  width: 1200px;
  padding: 0 15px;
  margin: 0 auto;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  display: block;
}
@media only screen and (max-width: 1600px) {
  .header_sideimg {
    position: relative;
  }
}
.header_sideimg::before, .header_sideimg::after {
  content: "";
  display: block;
  width: 250px;
  height: 90px;
  position: absolute;
  bottom: -20px;
  pointer-events: none;
  z-index: 101;
  -webkit-transition: 0.5s -webkit-transform;
  transition: 0.5s -webkit-transform;
  transition: 0.5s transform;
  transition: 0.5s transform, 0.5s -webkit-transform;
}
@media only screen and (max-width: 959px) {
  .header_sideimg::before, .header_sideimg::after {
    content: none;
  }
}
@media only screen and (max-width: 767px) {
  .header_sideimg::before, .header_sideimg::after {
    content: none;
  }
}
.header_sideimg::before {
  background: url(../img/common/header_bg_l.webp) 50% 50%/cover no-repeat;
  left: 0;
}
@media only screen and (max-width: 1600px) {
  .header_sideimg::before {
    left: -200px;
  }
}
.header_sideimg::after {
  background: url(../img/common/header_bg_r.webp) 50% 50%/cover no-repeat;
  right: 0;
}
@media only screen and (max-width: 1600px) {
  .header_sideimg::after {
    right: -200px;
  }
}
.is-root-container .header_sideimg {
  display: none;
}

.header_content {
  width: 1200px;
  max-width: 100%;
  padding: 0 15px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media only screen and (max-width: 959px) {
  .header_content {
    padding: 0;
  }
}
@media only screen and (max-width: 767px) {
  .header_content {
    padding: 0;
  }
}
.header_content .header_title_column {
  gap: 10px !important;
}
.header_content .header_title_column > * {
  -ms-flex-preferred-size: auto !important;
      flex-basis: auto !important;
}
@media only screen and (max-width: 959px) {
  .header_content .header_chara {
    width: 33px !important;
    margin: 0;
  }
}
.header_content .header_chara img {
  display: block;
  margin: 5px 0 0;
  max-height: 80px;
  width: auto !important;
  -o-object-fit: fill !important;
     object-fit: fill !important;
}
@media only screen and (max-width: 959px) {
  .header_content .header_chara img {
    margin: 3px 0 -6px;
    height: auto !important;
    width: 33px !important;
  }
}
.header_content .header_title {
  padding: 25px 0 20px;
}
@media only screen and (max-width: 959px) {
  .header_content .header_title {
    padding: 5px 5px;
  }
}
@media only screen and (max-width: 767px) {
  .header_content .header_title {
    padding: 5px 5px;
  }
}
.header_content .header_title img {
  max-height: 60px;
  width: auto !important;
  height: auto !important;
  display: block;
}
@media only screen and (max-width: 959px) {
  .header_content .header_title img {
    max-height: 40px;
  }
}
@media only screen and (max-width: 767px) {
  .header_content .header_title img {
    max-height: 40px;
  }
}
.header_content .hmenu {
  -ms-flex-item-align: end;
      -ms-grid-row-align: end;
      align-self: end;
  margin-top: 5px;
}
@media only screen and (max-width: 959px) {
  .header_content .hmenu {
    display: none;
  }
}
@media only screen and (max-width: 767px) {
  .header_content .hmenu {
    display: none;
  }
}
.header_content .hmenu a {
  color: #333333;
  text-decoration: none;
}
.header_content .hmenu .hnav {
  font-size: 16px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: end;
  margin-right: 0.8em;
}
.header_content .hmenu .hnav .search_keyword {
  width: 220px;
  height: 34px;
  background: #f9f5f1;
  border-radius: 17px 17px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.header_content .hmenu .hnav .search_keyword input[type=text] {
  height: 100%;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border: none;
  background: transparent;
  padding: 0 0 0 1em;
  width: 100%;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 16px;
  line-height: 34px;
}
.header_content .hmenu .hnav .search_keyword button {
  display: block;
  height: 100%;
  aspect-ratio: 1/1;
  padding: 0;
  margin: 0;
  background: transparent;
  border: none;
}
.header_content .hmenu .hnav .search_keyword button img {
  display: block;
  max-width: 100%;
  max-height: 100%;
}
.header_content .hmenu .hnav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: end;
  list-style-type: none;
  margin: 0;
  padding: 0;
}
.header_content .hmenu .hnav ul li {
  padding: 0;
  margin: 0 0 0 2em;
}
.header_content .hmenu .hnav ul li img.hnav_icon {
  display: inline-block;
  max-height: 16px;
  vertical-align: -12%;
  margin-right: 8px;
}
.header_content .hmenu .hnav ul li a {
  display: inline-block;
  letter-spacing: 0.1ex;
  padding-top: 1ex;
  padding-bottom: 1ex;
  line-height: 1.4;
}
.header_content .hmenu .gnav {
  font-size: 20px;
}
@media only screen and (min-width: 960px) and (max-width: 1229px) {
  .header_content .hmenu .gnav {
    font-size: 17px;
  }
}
.header_content .hmenu .gnav > ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  list-style-type: none;
  margin: 0;
  padding: 0;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: end;
}
.header_content .hmenu .gnav > ul > li {
  margin: 0 0 0;
  padding: 0;
}
.header_content .hmenu .gnav > ul > li > a {
  display: block;
  padding: 0.7em 0.8em 0.8em;
  letter-spacing: 0.1em;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
  border-radius: 5px 5px 0 0;
  position: relative;
}
@media only screen and (min-width: 960px) and (max-width: 1229px) {
  .header_content .hmenu .gnav > ul > li > a {
    font-size: 17px;
    padding: 0.7em 0.4em 0.8em;
  }
}
.header_content .hmenu .gnav > ul > li > a:hover, .header_content .hmenu .gnav > ul > li > a:active {
  background-color: #f9f5f1;
}
.header_content .hmenu .gnav > ul > li > a > span {
  display: block;
}
.header_content .hmenu .gnav > ul > li > a > span._jp {
  position: relative;
  padding-left: 15px;
  line-height: 1.2;
}
.header_content .hmenu .gnav > ul > li > a > span._jp::before {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  height: 100%;
  aspect-ratio: 0.8660254038;
  clip-path: polygon(10% 5%, 85% 40%, 100% 50%, 85% 60%, 10% 95%, 0% 50%);
  background: #00bfb2;
  -webkit-transform: scale(45%);
          transform: scale(45%);
  -webkit-transform-origin: 0 50%;
          transform-origin: 0 50%;
}
.header_content .hmenu .gnav > ul > li > a > span._en {
  font-size: 12px;
  text-align: center;
  font-weight: 700;
}
@media only screen and (min-width: 960px) and (max-width: 1229px) {
  .header_content .hmenu .gnav > ul > li > a > span._en {
    font-size: 11px;
  }
}
.header_content .hmenu .gnav > ul > li.gnav_root:hover > a::after {
  content: "";
  display: block;
  height: 2px;
  background: #5a7cc3;
  position: absolute;
  bottom: 0;
  width: 100%;
  left: 0;
}
.header_content .hmenu .gnav > ul > li:hover .subnav {
  -webkit-transform: perspective(2000px) rotateX(0deg) scale(1);
          transform: perspective(2000px) rotateX(0deg) scale(1);
  opacity: 1;
}
.header_content .hmenu .subnav {
  font-size: 18px;
  position: absolute;
  top: 100%;
  width: 100%;
  left: 0;
  z-index: 100;
  -webkit-transform-origin: top center;
          transform-origin: top center;
  -webkit-transform: perspective(2000px) rotateX(89.9deg);
          transform: perspective(2000px) rotateX(89.9deg);
  opacity: 0;
  -webkit-transition: all 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition: all 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955);
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(5px) grayscale(80%);
}
@media only print {
  .header_content .hmenu .subnav {
    display: none;
  }
}
@media only screen and (max-height: 959px) {
  .header_content .hmenu .subnav {
    font-size: 16px;
  }
}
.header_content .hmenu .subnav > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 1200px;
  max-width: 100%;
  position: relative;
  margin: 0 auto 0;
  padding: 2em 0;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.header_content .hmenu .subnav > div > *:first-child {
  width: 30%;
  position: relative;
  text-align: center;
  font-size: 140%;
  text-decoration: none;
  font-family: "Kosugi Maru", sans-serif;
}
.header_content .hmenu .subnav > div > *:first-child > span {
  display: inline-block;
  padding: 0.25ex 1ex;
  border-bottom: 2px solid;
}
.header_content .hmenu .subnav > div > *:last-child {
  width: 70%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding-left: 30px;
  border-left: 1px solid rgba(106, 95, 61, 0.25);
}
.header_content .hmenu .subnav > div > *:last-child > * {
  min-width: 33.3%;
}
.header_content .hmenu .subnav > div > ul {
  position: relative;
  z-index: 2;
  list-style-type: none;
  margin: 0;
  padding: 0;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  padding: 0;
}
.header_content .hmenu .subnav > div > ul li {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
  min-width: 33%;
}
.header_content .hmenu .subnav > div > ul li.wide {
  width: 100%;
}
.header_content .hmenu .subnav > div > ul li.wide > ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.header_content .hmenu .subnav > div > ul li a {
  text-decoration: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 1.1ex 10px 1.1ex 30px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  width: 100%;
  line-height: 1.5;
  color: #333333;
  -webkit-transition: 0.2s background;
  transition: 0.2s background;
  border-radius: 5px;
}
.header_content .hmenu .subnav > div > ul li a::before {
  content: "";
  position: absolute;
  display: block;
  top: 1em;
  left: 12px;
  height: 12px;
  aspect-ratio: 0.8660254038;
  clip-path: polygon(10% 5%, 85% 40%, 100% 50%, 85% 60%, 10% 95%, 0% 50%);
  background: #00bfb2;
  -webkit-transform-origin: 0 50%;
          transform-origin: 0 50%;
}
@media only screen and (max-height: 959px) {
  .header_content .hmenu .subnav > div > ul li a {
    padding: 0.5ex 10px 0.5ex 30px;
  }
  .header_content .hmenu .subnav > div > ul li a::before {
    top: 0.7em;
  }
}
.header_content .hmenu .subnav > div > ul li a:hover, .header_content .hmenu .subnav > div > ul li a:active {
  color: #ffffff;
  background-color: #3bb394;
}
.header_content .hmenu .subnav > div > ul li a:hover::before, .header_content .hmenu .subnav > div > ul li a:active::before {
  background: #ffffff !important;
}
.header_content .hmenu .subnav > div > ul li ul {
  margin: 0;
  padding: 0;
  list-style-type: none;
  position: relative;
}
.header_content .hmenu .subnav > div > ul li ul::before, .header_content .hmenu .subnav > div > ul li ul::after {
  content: "";
  display: block;
  position: absolute;
  height: 1px;
  width: 90%;
  left: 5%;
}
.header_content .hmenu .subnav > div > ul li ul a {
  padding: 0.3ex 10px 0.3ex 45px;
  font-size: 16px;
}
.header_content .hmenu .subnav > div > ul li ul a::before {
  content: "";
  position: absolute;
  display: block;
  top: 10px;
  left: 30px;
  height: 10px;
  aspect-ratio: 0.8660254038;
  clip-path: polygon(10% 5%, 85% 40%, 100% 50%, 85% 60%, 10% 95%, 0% 50%);
  background: #00bfb2;
  -webkit-transform-origin: 0 50%;
          transform-origin: 0 50%;
}
.header_content .hmenu .subnav > div > ul li ul ul a {
  padding: 0.3ex 10px 0.3ex 60px;
  background-position: 42px 50%;
}
.header_content .hmenu .subnav > div > ul li ul ul a::before {
  left: 45px;
}

.search_keyword {
  width: 220px;
  height: 34px;
  background: #f9f5f1;
  border-radius: 17px 17px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.search_keyword input[type=text] {
  height: 100%;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border: none;
  background: transparent;
  padding: 0 0 0 1em;
  width: 100%;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 16px;
  line-height: 34px;
}
.search_keyword button {
  display: block;
  height: 100%;
  aspect-ratio: 1/1;
  padding: 0;
  margin: 0;
  background: transparent;
  border: none;
  cursor: pointer;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
.search_keyword button:hover, .search_keyword button:active {
  opacity: 0.6;
}
.search_keyword button img {
  display: block;
  max-width: 100%;
  max-height: 100%;
}

.header_hamburger {
  width: 50px;
  -webkit-box-flex: 0;
      -ms-flex-positive: 0;
          flex-grow: 0;
  display: none;
}
@media only screen and (max-width: 959px) {
  .header_hamburger {
    display: block;
  }
}
@media only screen and (max-width: 767px) {
  .header_hamburger {
    display: block;
  }
}
.header_hamburger button {
  display: block;
  margin-left: auto;
  width: 50px;
  height: 50px;
  padding: 5px 15px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background: none;
  border: none;
  cursor: pointer;
}
.header_hamburger button span {
  display: block;
  height: 3px;
  width: 20px;
  background-color: #39567f;
  margin: 5px 0;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
  border-radius: 5px;
}
.spmenu_active .header_hamburger button span:nth-child(1) {
  -webkit-transform: translateY(8px) rotate(-45deg);
          transform: translateY(8px) rotate(-45deg);
}
.spmenu_active .header_hamburger button span:nth-child(2) {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.spmenu_active .header_hamburger button span:nth-child(3) {
  -webkit-transform: translateY(-8px) rotate(-45deg);
          transform: translateY(-8px) rotate(-45deg);
}

#sp_menu_overlay {
  pointer-events: none;
  backdrop-filter: blur(0);
  opacity: 0;
  position: fixed;
  height: 100vh;
  width: 100vW;
  top: 50px;
  left: 0;
  z-index: 210;
}
.spmenu_active #sp_menu_overlay {
  pointer-events: auto;
  backdrop-filter: blur(5px) grayscale(80%);
  opacity: 1;
  background: rgba(255, 255, 255, 0.5);
}

#sp_menu {
  width: 100%;
  background-color: #f8f4f1;
  position: fixed;
  top: 50px;
  left: 0;
  color: #ffffff;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
  z-index: 220;
  display: none;
  -webkit-box-shadow: 0 5px 0 rgba(0, 0, 0, 0.2);
          box-shadow: 0 5px 0 rgba(0, 0, 0, 0.2);
  max-height: calc(100svh - 50px);
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  overflow: auto;
}
@media only screen and (max-width: 959px) {
  .spmenu_active #sp_menu {
    display: block;
  }
}
#sp_menu > div {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
#sp_menu nav#sp_nav {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
#sp_menu nav#sp_nav ul {
  list-style-type: none;
  margin: 0;
  padding: 0 0 0 20px;
}
#sp_menu nav#sp_nav > ul {
  margin: 0px 0 20px;
  padding: 0;
  font-size: 16px;
  letter-spacing: 0.1ex;
  font-weight: 500;
  min-height: 200px;
  border-bottom: 1px solid #b7a090;
}
#sp_menu nav#sp_nav > ul ul {
  display: none;
}
#sp_menu nav#sp_nav > ul > li:first-child {
  border-top: none;
}
#sp_menu nav#sp_nav > ul li {
  margin: 0;
  padding: 0;
  border-top: 1px solid #b7a090;
  position: relative;
}
#sp_menu nav#sp_nav > ul li > div {
  position: relative;
  padding-right: 34px;
}
#sp_menu nav#sp_nav > ul li a {
  -webkit-transform: rotate(0.05deg);
          transform: rotate(0.05deg);
  padding: 0.8em 1ex;
  display: block;
  text-decoration: none;
  color: #333333;
  -webkit-transition: 0.2s all;
  transition: 0.2s all;
}
#sp_menu nav#sp_nav > ul li a:hover, #sp_menu nav#sp_nav > ul li a:active {
  background-color: rgba(255, 255, 255, 0.2);
}
#sp_menu .search_keyword {
  border: 1px solid #808080;
  background: #ffffff;
  width: 280px;
  margin: 1ex auto 1em;
}
#sp_menu .sp_menu_btns .btn {
  max-width: 250px;
  display: block;
  border-radius: 10px;
  padding: 1.2ex 3em 1.3ex 2em;
}
#sp_menu .sp_menu_btns .btn:not(:first-child) {
  margin-top: 15px;
}
#sp_menu .hasmenu button {
  display: none;
}
#sp_menu .hasmenu .submenu-toggle {
  display: block;
  background: none;
  border: none;
  width: 34px;
  height: 100%;
  position: absolute;
  right: 0;
  top: 0;
  overflow: hidden;
  text-indent: -100px;
  cursor: pointer;
}
#sp_menu .hasmenu .submenu-toggle::before, #sp_menu .hasmenu .submenu-toggle::after {
  content: "";
  display: block;
  width: 14px;
  left: 50%;
  height: 3px;
  border-radius: 2px;
  position: absolute;
  background: #814921;
  top: 50%;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
#sp_menu .hasmenu .submenu-toggle::before {
  -webkit-transform: translate(-50%, -50%) rotate(90deg);
          transform: translate(-50%, -50%) rotate(90deg);
}
#sp_menu .hasmenu .submenu-toggle.active::before, #sp_menu .hasmenu .submenu-toggle.active::after {
  -webkit-transform: translate(-50%, -50%) rotate(180deg);
          transform: translate(-50%, -50%) rotate(180deg);
}

#fixnav {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 60px;
  background: rgba(255, 255, 255, 0.7333333333);
  backdrop-filter: blur(5px);
  -webkit-box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
          box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);
  z-index: 100;
  -webkit-transition: 0.5s all;
  transition: 0.5s all;
}
#fixnav.hidden {
  top: -80px;
}
@media only screen and (max-width: 767px) {
  #fixnav {
    display: none;
  }
}
#fixnav > ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  list-style-type: none;
  margin: 0;
  padding: 0;
  height: 100%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}
#fixnav > ul li {
  margin: 0;
  padding: 0;
  position: relative;
}
#fixnav > ul li::after {
  content: "";
  width: 1px;
  height: 50%;
  -webkit-transform: rotate(20deg);
          transform: rotate(20deg);
  display: block;
  background: #999999;
  right: 0;
  top: 30%;
  position: absolute;
}
#fixnav > ul li:last-child::after {
  content: none;
}
#fixnav > ul li a {
  text-decoration: none;
  font-family: "Shippori Mincho", serif;
  font-weight: 700;
  font-size: 18px;
  padding: 0 1em;
  display: block;
  color: #002060;
}
#fixnav > ul li a:hover, #fixnav > ul li a:active {
  color: #246cff;
}
#fixnav > ul li a::after {
  content: "";
  position: absolute;
  width: 100%;
  height: 2px;
  background: #002060;
  bottom: -1ex;
  left: 0;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
  -webkit-transform: scaleX(0);
          transform: scaleX(0);
}
#fixnav > ul li a:not(.hnav_contact):hover::after, #fixnav > ul li a:not(.hnav_contact):active::after {
  -webkit-transform: scaleX(1);
          transform: scaleX(1);
  background: #246cff;
}

.is-root-container .footer_img {
  display: none;
}

body.spring .footer_img_inner {
  max-width: 1200px;
  margin: auto;
  position: relative;
  height: 100%;
}
body.spring .footer_img {
  background-image: url(../img/common/footer_top_spring.webp);
}
body.spring .footer_img .footer_img_l {
  left: 0;
  -webkit-animation: tractor_moveX_frame 24s cubic-bezier(0.445, 0.05, 0.55, 0.95) infinite;
          animation: tractor_moveX_frame 24s cubic-bezier(0.445, 0.05, 0.55, 0.95) infinite;
  z-index: 2;
  bottom: -40px;
  -webkit-transform-origin: 25% 0;
          transform-origin: 25% 0;
}
@media only screen and (max-width: 959px) {
  body.spring .footer_img .footer_img_l {
    bottom: 0px;
  }
}
@-webkit-keyframes tractor_moveX_frame {
  0% {
    -webkit-transform: scaleX(-1);
            transform: scaleX(-1);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
    left: 0%;
  }
  5% {
    -webkit-transform: scaleX(-1);
            transform: scaleX(-1);
    left: 4%;
    -webkit-animation-timing-function: linear;
            animation-timing-function: linear;
  }
  48% {
    -webkit-transform: scaleX(-1);
            transform: scaleX(-1);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
    left: 80%;
  }
  50% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
    left: 80%;
  }
  55% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    left: 76%;
    -webkit-animation-timing-function: linear;
            animation-timing-function: linear;
  }
  98% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
    left: 0%;
  }
  100% {
    -webkit-transform: scaleX(-1);
            transform: scaleX(-1);
    left: 0%;
  }
}
@keyframes tractor_moveX_frame {
  0% {
    -webkit-transform: scaleX(-1);
            transform: scaleX(-1);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
    left: 0%;
  }
  5% {
    -webkit-transform: scaleX(-1);
            transform: scaleX(-1);
    left: 4%;
    -webkit-animation-timing-function: linear;
            animation-timing-function: linear;
  }
  48% {
    -webkit-transform: scaleX(-1);
            transform: scaleX(-1);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
    left: 80%;
  }
  50% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
    left: 80%;
  }
  55% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    left: 76%;
    -webkit-animation-timing-function: linear;
            animation-timing-function: linear;
  }
  98% {
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
    left: 0%;
  }
  100% {
    -webkit-transform: scaleX(-1);
            transform: scaleX(-1);
    left: 0%;
  }
}
body.spring .footer_img .footer_img_l::after {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  background-image: url(../img/common/footer_top_spring_l.webp);
  background-size: 100% auto;
  -webkit-animation: tractor_frame 24s steps(1) infinite;
          animation: tractor_frame 24s steps(1) infinite;
}
@-webkit-keyframes tractor_frame {
  0% {
    background-position-y: 0%;
  }
  2% {
    background-position-y: 50%;
  }
  4% {
    background-position-y: 0%;
  }
  6% {
    background-position-y: 50%;
  }
  8% {
    background-position-y: 0%;
  }
  10% {
    background-position-y: 50%;
  }
  12% {
    background-position-y: 0%;
  }
  14% {
    background-position-y: 50%;
  }
  16% {
    background-position-y: 0%;
  }
  18% {
    background-position-y: 50%;
  }
  20% {
    background-position-y: 0%;
  }
  22% {
    background-position-y: 50%;
  }
  24% {
    background-position-y: 0%;
  }
  26% {
    background-position-y: 50%;
  }
  28% {
    background-position-y: 0%;
  }
  30% {
    background-position-y: 50%;
  }
  32% {
    background-position-y: 0%;
  }
  34% {
    background-position-y: 50%;
  }
  36% {
    background-position-y: 0%;
  }
  38% {
    background-position-y: 50%;
  }
  40% {
    background-position-y: 0%;
  }
  42% {
    background-position-y: 50%;
  }
  44% {
    background-position-y: 0%;
  }
  46% {
    background-position-y: 50%;
  }
  48% {
    background-position-y: 100%;
  }
  50% {
    background-position-y: 100%;
  }
  52% {
    background-position-y: 50%;
  }
  54% {
    background-position-y: 0%;
  }
  56% {
    background-position-y: 50%;
  }
  58% {
    background-position-y: 0%;
  }
  60% {
    background-position-y: 50%;
  }
  62% {
    background-position-y: 0%;
  }
  64% {
    background-position-y: 50%;
  }
  66% {
    background-position-y: 0%;
  }
  68% {
    background-position-y: 50%;
  }
  70% {
    background-position-y: 0%;
  }
  72% {
    background-position-y: 50%;
  }
  74% {
    background-position-y: 0%;
  }
  76% {
    background-position-y: 50%;
  }
  78% {
    background-position-y: 0%;
  }
  80% {
    background-position-y: 50%;
  }
  82% {
    background-position-y: 0%;
  }
  84% {
    background-position-y: 50%;
  }
  86% {
    background-position-y: 0%;
  }
  88% {
    background-position-y: 50%;
  }
  90% {
    background-position-y: 0%;
  }
  92% {
    background-position-y: 50%;
  }
  94% {
    background-position-y: 0%;
  }
  96% {
    background-position-y: 50%;
  }
  98% {
    background-position-y: 100%;
  }
  100% {
    background-position-y: 100%;
  }
}
@keyframes tractor_frame {
  0% {
    background-position-y: 0%;
  }
  2% {
    background-position-y: 50%;
  }
  4% {
    background-position-y: 0%;
  }
  6% {
    background-position-y: 50%;
  }
  8% {
    background-position-y: 0%;
  }
  10% {
    background-position-y: 50%;
  }
  12% {
    background-position-y: 0%;
  }
  14% {
    background-position-y: 50%;
  }
  16% {
    background-position-y: 0%;
  }
  18% {
    background-position-y: 50%;
  }
  20% {
    background-position-y: 0%;
  }
  22% {
    background-position-y: 50%;
  }
  24% {
    background-position-y: 0%;
  }
  26% {
    background-position-y: 50%;
  }
  28% {
    background-position-y: 0%;
  }
  30% {
    background-position-y: 50%;
  }
  32% {
    background-position-y: 0%;
  }
  34% {
    background-position-y: 50%;
  }
  36% {
    background-position-y: 0%;
  }
  38% {
    background-position-y: 50%;
  }
  40% {
    background-position-y: 0%;
  }
  42% {
    background-position-y: 50%;
  }
  44% {
    background-position-y: 0%;
  }
  46% {
    background-position-y: 50%;
  }
  48% {
    background-position-y: 100%;
  }
  50% {
    background-position-y: 100%;
  }
  52% {
    background-position-y: 50%;
  }
  54% {
    background-position-y: 0%;
  }
  56% {
    background-position-y: 50%;
  }
  58% {
    background-position-y: 0%;
  }
  60% {
    background-position-y: 50%;
  }
  62% {
    background-position-y: 0%;
  }
  64% {
    background-position-y: 50%;
  }
  66% {
    background-position-y: 0%;
  }
  68% {
    background-position-y: 50%;
  }
  70% {
    background-position-y: 0%;
  }
  72% {
    background-position-y: 50%;
  }
  74% {
    background-position-y: 0%;
  }
  76% {
    background-position-y: 50%;
  }
  78% {
    background-position-y: 0%;
  }
  80% {
    background-position-y: 50%;
  }
  82% {
    background-position-y: 0%;
  }
  84% {
    background-position-y: 50%;
  }
  86% {
    background-position-y: 0%;
  }
  88% {
    background-position-y: 50%;
  }
  90% {
    background-position-y: 0%;
  }
  92% {
    background-position-y: 50%;
  }
  94% {
    background-position-y: 0%;
  }
  96% {
    background-position-y: 50%;
  }
  98% {
    background-position-y: 100%;
  }
  100% {
    background-position-y: 100%;
  }
}
body.spring .footer_img .footer_img_r {
  right: -160px;
  -webkit-animation: keitora_spring_moveX_frame 8s cubic-bezier(0.445, 0.05, 0.55, 0.95) infinite;
          animation: keitora_spring_moveX_frame 8s cubic-bezier(0.445, 0.05, 0.55, 0.95) infinite;
}
@-webkit-keyframes keitora_spring_moveX_frame {
  0% {
    -webkit-animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
            animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
    -webkit-transform: translateX(400px) scaleX(1);
            transform: translateX(400px) scaleX(1);
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  30% {
    -webkit-transform: translateX(0) scaleX(1);
            transform: translateX(0) scaleX(1);
  }
  32% {
    -webkit-transform: translateX(0) scaleX(-1);
            transform: translateX(0) scaleX(-1);
  }
  60% {
    -webkit-transform: translateX(0) scaleX(-1);
            transform: translateX(0) scaleX(-1);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
  }
  80% {
    opacity: 1;
  }
  90% {
    -webkit-transform: translateX(400px) scaleX(-1);
            transform: translateX(400px) scaleX(-1);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(400px) scaleX(-1);
            transform: translateX(400px) scaleX(-1);
    opacity: 0;
  }
}
@keyframes keitora_spring_moveX_frame {
  0% {
    -webkit-animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
            animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
    -webkit-transform: translateX(400px) scaleX(1);
            transform: translateX(400px) scaleX(1);
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  30% {
    -webkit-transform: translateX(0) scaleX(1);
            transform: translateX(0) scaleX(1);
  }
  32% {
    -webkit-transform: translateX(0) scaleX(-1);
            transform: translateX(0) scaleX(-1);
  }
  60% {
    -webkit-transform: translateX(0) scaleX(-1);
            transform: translateX(0) scaleX(-1);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
  }
  80% {
    opacity: 1;
  }
  90% {
    -webkit-transform: translateX(400px) scaleX(-1);
            transform: translateX(400px) scaleX(-1);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(400px) scaleX(-1);
            transform: translateX(400px) scaleX(-1);
    opacity: 0;
  }
}
body.spring .footer_img .footer_img_r::after {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  background-image: url(../img/common/footer_top_spring_r.webp);
  -webkit-animation: keitora_spring_frame 8s steps(1) infinite;
          animation: keitora_spring_frame 8s steps(1) infinite;
}
@-webkit-keyframes keitora_spring_frame {
  0% {
    background-position-y: 100%;
  }
  50% {
    background-position-y: 50%;
  }
  55% {
    background-position-y: 0%;
  }
  100% {
    background-position-y: 0;
  }
}
@keyframes keitora_spring_frame {
  0% {
    background-position-y: 100%;
  }
  50% {
    background-position-y: 50%;
  }
  55% {
    background-position-y: 0%;
  }
  100% {
    background-position-y: 0;
  }
}
body.summer .footer_img {
  background-image: url(../img/common/footer_top_summer.webp);
}
body.summer .footer_img .footer_img_l {
  position: absolute;
  pointer-events: none;
  width: 112.5px;
  height: 75px;
  left: 50px;
  bottom: 5px;
  -webkit-animation: kaeru_moveX_frame 8s cubic-bezier(0.445, 0.05, 0.55, 0.95) infinite;
          animation: kaeru_moveX_frame 8s cubic-bezier(0.445, 0.05, 0.55, 0.95) infinite;
}
@media only screen and (max-width: 959px) {
  body.summer .footer_img .footer_img_l {
    width: 90px;
    height: 60px;
  }
}
@media only screen and (max-width: 767px) {
  body.summer .footer_img .footer_img_l {
    left: 20px;
    width: 90px;
    height: 60px;
    bottom: 15px;
  }
}
@-webkit-keyframes kaeru_moveX_frame {
  0% {
    -webkit-transform: translateX(0) scaleX(1);
            transform: translateX(0) scaleX(1);
  }
  40% {
    -webkit-transform: translateX(0) scaleX(1);
            transform: translateX(0) scaleX(1);
  }
  45% {
    -webkit-transform: translateX(50px);
            transform: translateX(50px);
  }
  84.9% {
    -webkit-transform: translateX(50px) scaleX(1);
            transform: translateX(50px) scaleX(1);
  }
  85% {
    -webkit-transform: translateX(50px) scaleX(-1);
            transform: translateX(50px) scaleX(-1);
  }
  90% {
    -webkit-transform: translateX(50px) scaleX(-1);
            transform: translateX(50px) scaleX(-1);
  }
  95% {
    -webkit-transform: translateX(0) scaleX(-1);
            transform: translateX(0) scaleX(-1);
  }
  100% {
    -webkit-transform: translateX(0) scaleX(-1);
            transform: translateX(0) scaleX(-1);
  }
}
@keyframes kaeru_moveX_frame {
  0% {
    -webkit-transform: translateX(0) scaleX(1);
            transform: translateX(0) scaleX(1);
  }
  40% {
    -webkit-transform: translateX(0) scaleX(1);
            transform: translateX(0) scaleX(1);
  }
  45% {
    -webkit-transform: translateX(50px);
            transform: translateX(50px);
  }
  84.9% {
    -webkit-transform: translateX(50px) scaleX(1);
            transform: translateX(50px) scaleX(1);
  }
  85% {
    -webkit-transform: translateX(50px) scaleX(-1);
            transform: translateX(50px) scaleX(-1);
  }
  90% {
    -webkit-transform: translateX(50px) scaleX(-1);
            transform: translateX(50px) scaleX(-1);
  }
  95% {
    -webkit-transform: translateX(0) scaleX(-1);
            transform: translateX(0) scaleX(-1);
  }
  100% {
    -webkit-transform: translateX(0) scaleX(-1);
            transform: translateX(0) scaleX(-1);
  }
}
body.summer .footer_img .footer_img_l > div {
  position: absolute;
  width: 100%;
  height: 100%;
  -webkit-animation: kaeru_moveY_frame 8s cubic-bezier(0.445, 0.05, 0.55, 0.95) infinite;
          animation: kaeru_moveY_frame 8s cubic-bezier(0.445, 0.05, 0.55, 0.95) infinite;
}
@-webkit-keyframes kaeru_moveY_frame {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  40% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    -webkit-animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
            animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
  }
  42.5% {
    -webkit-transform: translateY(-100px);
            transform: translateY(-100px);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
  }
  45% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  90% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    -webkit-animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
            animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
  }
  92.5% {
    -webkit-transform: translateY(-100px);
            transform: translateY(-100px);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
  }
  95% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes kaeru_moveY_frame {
  0% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  40% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    -webkit-animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
            animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
  }
  42.5% {
    -webkit-transform: translateY(-100px);
            transform: translateY(-100px);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
  }
  45% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  90% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    -webkit-animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
            animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
  }
  92.5% {
    -webkit-transform: translateY(-100px);
            transform: translateY(-100px);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
  }
  95% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
body.summer .footer_img .footer_img_l > div::after {
  background: url(../img/common/footer_top_summer_l.webp) repeat-x;
  background-size: 100% 400%;
  background-position: 0 0;
  position: absolute;
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  -webkit-animation: kaeru_frame 8s steps(1) infinite;
          animation: kaeru_frame 8s steps(1) infinite;
}
@-webkit-keyframes kaeru_frame {
  0% {
    background-position-y: 0;
  }
  3% {
    background-position-y: 33.3%;
  }
  10% {
    background-position-y: 0;
  }
  15% {
    background-position-y: 33.3%;
  }
  25% {
    background-position-y: 0;
  }
  35% {
    background-position-y: 66.6%;
  }
  40% {
    background-position-y: 100%;
  }
  45% {
    background-position-y: 66.6%;
  }
  50% {
    background-position-y: 0;
  }
  55% {
    background-position-y: 33.3%;
  }
  60% {
    background-position-y: 0;
  }
  70% {
    background-position-y: 33.3%;
  }
  75% {
    background-position-y: 0;
  }
  85% {
    background-position-y: 66.6%;
  }
  90% {
    background-position-y: 100%;
  }
  95% {
    background-position-y: 66.6%;
  }
  100% {
    background-position-y: 0;
  }
}
@keyframes kaeru_frame {
  0% {
    background-position-y: 0;
  }
  3% {
    background-position-y: 33.3%;
  }
  10% {
    background-position-y: 0;
  }
  15% {
    background-position-y: 33.3%;
  }
  25% {
    background-position-y: 0;
  }
  35% {
    background-position-y: 66.6%;
  }
  40% {
    background-position-y: 100%;
  }
  45% {
    background-position-y: 66.6%;
  }
  50% {
    background-position-y: 0;
  }
  55% {
    background-position-y: 33.3%;
  }
  60% {
    background-position-y: 0;
  }
  70% {
    background-position-y: 33.3%;
  }
  75% {
    background-position-y: 0;
  }
  85% {
    background-position-y: 66.6%;
  }
  90% {
    background-position-y: 100%;
  }
  95% {
    background-position-y: 66.6%;
  }
  100% {
    background-position-y: 0;
  }
}
body.summer .footer_img .footer_img_r {
  width: 150px;
  height: 180px;
  right: 100px;
  bottom: 20px;
  pointer-events: none;
}
@media only screen and (min-width: 960px) and (max-width: 1229px) {
  body.summer .footer_img .footer_img_r {
    width: 120px;
    height: 144px;
  }
}
@media only screen and (max-width: 959px) {
  body.summer .footer_img .footer_img_r {
    width: 100px;
    height: 120px;
  }
}
@media only screen and (max-width: 767px) {
  body.summer .footer_img .footer_img_r {
    right: 20px;
    width: 100px;
    height: 120px;
    bottom: 30px;
  }
}
body.summer .footer_img .footer_img_r::after {
  background: url(../img/common/footer_top_summer_r.webp) repeat-x;
  background-size: 100% 300%;
  background-position: 0 0;
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  -webkit-animation: sagi_frame 8s steps(1) infinite;
          animation: sagi_frame 8s steps(1) infinite;
}
@-webkit-keyframes sagi_frame {
  0% {
    background-position-y: 50%;
  }
  15% {
    background-position-y: 100%;
  }
  20% {
    background-position-y: 50%;
  }
  40% {
    background-position-y: 0%;
  }
  45% {
    background-position-y: 50%;
  }
  50% {
    background-position-y: 100%;
  }
  65% {
    background-position-y: 50%;
  }
  90% {
    background-position-y: 0%;
  }
  95% {
    background-position-y: 50%;
  }
  100% {
    background-position-y: 50%;
  }
}
@keyframes sagi_frame {
  0% {
    background-position-y: 50%;
  }
  15% {
    background-position-y: 100%;
  }
  20% {
    background-position-y: 50%;
  }
  40% {
    background-position-y: 0%;
  }
  45% {
    background-position-y: 50%;
  }
  50% {
    background-position-y: 100%;
  }
  65% {
    background-position-y: 50%;
  }
  90% {
    background-position-y: 0%;
  }
  95% {
    background-position-y: 50%;
  }
  100% {
    background-position-y: 50%;
  }
}
body.autumn .footer_img_inner {
  max-width: 1200px;
  margin: auto;
  position: relative;
  height: 100%;
}
body.autumn .footer_img {
  background-image: url(../img/common/footer_top_autumn.webp);
}
body.autumn .footer_img .footer_img_l {
  left: -160px;
  -webkit-animation: keitora_autumn_moveX_frame 8s cubic-bezier(0.445, 0.05, 0.55, 0.95) infinite;
          animation: keitora_autumn_moveX_frame 8s cubic-bezier(0.445, 0.05, 0.55, 0.95) infinite;
}
@media only screen and (max-width: 959px) {
  body.autumn .footer_img .footer_img_l {
    left: -10px;
  }
}
@-webkit-keyframes keitora_autumn_moveX_frame {
  0% {
    -webkit-animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
            animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
    -webkit-transform: translateX(-400px) scaleX(-1);
            transform: translateX(-400px) scaleX(-1);
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  30% {
    -webkit-transform: translateX(0) scaleX(-1);
            transform: translateX(0) scaleX(-1);
  }
  32% {
    -webkit-transform: translateX(0) scaleX(1);
            transform: translateX(0) scaleX(1);
  }
  60% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
  }
  80% {
    opacity: 1;
  }
  90% {
    -webkit-transform: translateX(-400px);
            transform: translateX(-400px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(-400px);
            transform: translateX(-400px);
    opacity: 0;
  }
}
@keyframes keitora_autumn_moveX_frame {
  0% {
    -webkit-animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
            animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
    -webkit-transform: translateX(-400px) scaleX(-1);
            transform: translateX(-400px) scaleX(-1);
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  30% {
    -webkit-transform: translateX(0) scaleX(-1);
            transform: translateX(0) scaleX(-1);
  }
  32% {
    -webkit-transform: translateX(0) scaleX(1);
            transform: translateX(0) scaleX(1);
  }
  60% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
  }
  80% {
    opacity: 1;
  }
  90% {
    -webkit-transform: translateX(-400px);
            transform: translateX(-400px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(-400px);
            transform: translateX(-400px);
    opacity: 0;
  }
}
body.autumn .footer_img .footer_img_l::after {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  background-image: url(../img/common/footer_top_autumn_l.webp);
  background-size: 100% auto;
  -webkit-animation: keitora_autumn_frame 8s steps(1) infinite;
          animation: keitora_autumn_frame 8s steps(1) infinite;
}
@-webkit-keyframes keitora_autumn_frame {
  0% {
    background-position-y: 0;
  }
  50% {
    background-position-y: 50%;
  }
  55% {
    background-position-y: 100%;
  }
  100% {
    background-position-y: 0;
  }
}
@keyframes keitora_autumn_frame {
  0% {
    background-position-y: 0;
  }
  50% {
    background-position-y: 50%;
  }
  55% {
    background-position-y: 100%;
  }
  100% {
    background-position-y: 0;
  }
}
body.autumn .footer_img .footer_img_r {
  right: -130px;
  background-image: url(../img/common/footer_top_autumn_r.webp);
  background-size: 100% auto;
}
@media only screen and (max-width: 959px) {
  body.autumn .footer_img .footer_img_r {
    right: -10px;
  }
}
body.winter .footer_img {
  background-image: url(../img/common/footer_top_winter.webp);
}
body.winter .footer_img .footer_img_l {
  background-image: url(../img/common/footer_top_winter_l.webp);
  -webkit-animation: yukidaruma_frame 8s steps(1) infinite;
          animation: yukidaruma_frame 8s steps(1) infinite;
}
@-webkit-keyframes yukidaruma_frame {
  0% {
    background-position-y: 0;
  }
  35% {
    background-position-y: 100%;
  }
  40% {
    background-position-y: 0;
  }
  95% {
    background-position-y: 100%;
  }
  97% {
    background-position-y: 0;
  }
  98% {
    background-position-y: 100%;
  }
  100% {
    background-position-y: 0;
  }
}
@keyframes yukidaruma_frame {
  0% {
    background-position-y: 0;
  }
  35% {
    background-position-y: 100%;
  }
  40% {
    background-position-y: 0;
  }
  95% {
    background-position-y: 100%;
  }
  97% {
    background-position-y: 0;
  }
  98% {
    background-position-y: 100%;
  }
  100% {
    background-position-y: 0;
  }
}
body.winter .footer_img .footer_img_r {
  background-image: url(../img/common/footer_top_winter_r.webp);
}

footer {
  letter-spacing: 0.1ex;
  background: url(../img/common/footer_bg.webp) 50% 50% repeat;
  padding: 0;
  margin-top: 120px;
  position: relative;
  z-index: 13;
}
@media only screen and (max-width: 767px) {
  footer {
    margin-top: 80px;
  }
}
footer p {
  margin: 0;
  padding: 0;
}
footer .footer_img {
  position: relative;
  background: url(../img/common/footer_top_summer.webp) 50% 50%/1600px auto repeat-x;
  height: 85px;
  top: -40px;
}
@media only screen and (max-width: 767px) {
  footer .footer_img {
    background-size: 800px auto;
    margin-bottom: -40px;
  }
}
footer .footer_img .footer_img_l,
footer .footer_img .footer_img_r {
  display: block;
  width: 256px;
  aspect-ratio: 2/1;
  position: absolute;
  bottom: 25px;
  background-size: 100% auto;
}
@media only screen and (max-width: 767px) {
  footer .footer_img .footer_img_l,
  footer .footer_img .footer_img_r {
    width: 128px;
  }
}
footer .footer_img .footer_img_l {
  left: 0;
}
footer .footer_img .footer_img_r {
  right: 0;
}
footer .footer_link a {
  text-decoration: none;
  color: #14274c;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
footer .footer_link a:hover, footer .footer_link a:active {
  background: #14274c;
  color: #ffffff;
}
footer .footer_link ul {
  color: #14274c;
  list-style-type: none;
  margin: 0 auto;
  padding: 1em 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  max-width: 1200px;
}
@media only screen and (max-width: 767px) {
  footer .footer_link ul {
    display: block;
    margin-top: 1em;
  }
}
footer .footer_link ul li {
  position: relative;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  text-align: center;
  padding: 0 1ex;
}
footer .footer_link ul li::before {
  content: "";
  display: block;
  width: 1px;
  height: 60%;
  position: absolute;
  background: #14274c;
  left: 0;
  top: 20%;
}
@media only screen and (max-width: 767px) {
  footer .footer_link ul li::before {
    width: 90%;
    height: 1px;
    background: transparent;
    border-bottom: 1px dotted #14274c;
    top: auto;
    bottom: 0;
    left: 5%;
  }
}
@media only screen and (max-width: 767px) {
  footer .footer_link ul li:last-child::before {
    content: none;
  }
}
footer .footer_link ul li:last-child::after {
  content: "";
  display: block;
  width: 1px;
  height: 60%;
  position: absolute;
  background: #14274c;
  right: 0;
  top: 20%;
}
@media only screen and (max-width: 767px) {
  footer .footer_link ul li:last-child::after {
    content: none;
  }
}
footer .footer_link ul li a {
  display: block;
}
@media only screen and (max-width: 767px) {
  footer .footer_link ul li a {
    padding: 1ex;
  }
}
footer .footer_column {
  color: #14274c;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  max-width: 1200px;
  margin: auto;
  padding: 0 15px 20px;
}
@media only screen and (max-width: 767px) {
  footer .footer_column {
    display: block;
  }
}
footer .footer_column a {
  text-decoration: none;
  color: #14274c;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
footer .footer_column a:hover, footer .footer_column a:active {
  background: #14274c;
  color: #ffffff;
}
@media only screen and (max-width: 767px) {
  footer .footer_column .footer_attr {
    text-align: center;
  }
}
footer .footer_column .footer_attr ._title {
  font-size: 27px;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 2;
}
footer .footer_column .footer_attr ._zip {
  line-height: 1.6;
}
footer .footer_column .footer_attr ._address {
  line-height: 1.6;
}
footer .footer_column .footer_attr ._tel_fax {
  list-style-type: none;
  margin: 0.7em 0;
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media only screen and (max-width: 767px) {
  footer .footer_column .footer_attr ._tel_fax {
    display: block;
    text-align: center;
  }
}
footer .footer_column .footer_attr ._tel_fax li {
  margin: 0;
  padding: 0 1.5em;
  position: relative;
}
@media only screen and (max-width: 767px) {
  footer .footer_column .footer_attr ._tel_fax li {
    padding: 0;
  }
}
footer .footer_column .footer_attr ._tel_fax li::before {
  content: "";
  display: block;
  width: 1px;
  height: 60%;
  position: absolute;
  background: #14274c;
  right: 0;
  top: 20%;
}
@media only screen and (max-width: 767px) {
  footer .footer_column .footer_attr ._tel_fax li::before {
    content: none;
  }
}
footer .footer_column .footer_attr ._tel_fax li:first-child {
  padding-left: 0;
}
footer .footer_column .footer_attr ._tel_fax li:last-child {
  padding-right: 0;
}
footer .footer_column .footer_attr ._tel_fax li:last-child::before {
  content: none;
}
footer .footer_column .fnav ul {
  margin: 1ex 0;
  padding: 0;
  list-style-type: none;
}
@media only screen and (max-width: 767px) {
  footer .footer_column .fnav ul {
    margin-top: 2em;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
footer .footer_column .fnav ul li {
  margin: 0;
  padding: 0;
}
footer .footer_column .fnav ul a {
  display: block;
  margin: 0;
  padding: 0.5ex 10px 0.5ex 20px;
  background-image: url(../img/common/fnav_arrow.webp);
  background-position: 5px 50%;
  background-size: 10px 10px;
  background-repeat: no-repeat;
}
footer .footer_column .fnav ul a:hover, footer .footer_column .fnav ul a:active {
  background-image: url(../img/common/fnav_arrow_white.webp);
}
footer .footer_copy {
  font-size: 14px;
  padding: 1ex;
  background: #1b2e51;
  color: #ffffff;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.1em;
}

@-webkit-keyframes totop_bounce {
  0% {
    -webkit-transform: translateY(0) scale(1, 1);
            transform: translateY(0) scale(1, 1);
    -webkit-animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
            animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
  }
  20% {
    -webkit-transform: translateY(0) scale(1.1, 0.9);
            transform: translateY(0) scale(1.1, 0.9);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
  }
  35% {
    -webkit-transform: translateY(-20px) scale(0.9, 1.1);
            transform: translateY(-20px) scale(0.9, 1.1);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
  }
  90% {
    -webkit-transform: translateY(0) scale(1, 1);
            transform: translateY(0) scale(1, 1);
    -webkit-animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
            animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
  }
  95% {
    -webkit-transform: translateY(-5px) scale(0.98, 1.02);
            transform: translateY(-5px) scale(0.98, 1.02);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
  }
  100% {
    -webkit-transform: translateY(0) scale(1, 1);
            transform: translateY(0) scale(1, 1);
  }
}

@keyframes totop_bounce {
  0% {
    -webkit-transform: translateY(0) scale(1, 1);
            transform: translateY(0) scale(1, 1);
    -webkit-animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
            animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
  }
  20% {
    -webkit-transform: translateY(0) scale(1.1, 0.9);
            transform: translateY(0) scale(1.1, 0.9);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
  }
  35% {
    -webkit-transform: translateY(-20px) scale(0.9, 1.1);
            transform: translateY(-20px) scale(0.9, 1.1);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
  }
  90% {
    -webkit-transform: translateY(0) scale(1, 1);
            transform: translateY(0) scale(1, 1);
    -webkit-animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
            animation-timing-function: cubic-bezier(0.39, 0.575, 0.565, 1);
  }
  95% {
    -webkit-transform: translateY(-5px) scale(0.98, 1.02);
            transform: translateY(-5px) scale(0.98, 1.02);
    -webkit-animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
            animation-timing-function: cubic-bezier(0.47, 0, 0.745, 0.715);
  }
  100% {
    -webkit-transform: translateY(0) scale(1, 1);
            transform: translateY(0) scale(1, 1);
  }
}
.totop {
  position: fixed;
  width: 100%;
  z-index: 100;
  bottom: 0;
  -webkit-transition: 0.3s bottom;
  transition: 0.3s bottom;
  pointer-events: none;
}
.totop.finished {
  position: absolute;
  bottom: auto;
}
.totop.finished > div a {
  -webkit-animation: totop_bounce 0.4s linear 1;
          animation: totop_bounce 0.4s linear 1;
}
.totop > div {
  margin: auto;
  position: relative;
}
.totop > div a {
  margin: -80px 10px 16px auto;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
  width: 110px;
  pointer-events: auto;
  display: block;
}
.totop > div a img {
  display: block;
  max-width: 100%;
}
@media only screen and (max-width: 767px) {
  .totop > div a {
    margin: -60px auto 16px;
    width: 80px;
  }
}
.totop > div a:hover, .totop > div a:active {
  -webkit-transform: translateY(3px);
          transform: translateY(3px);
  opacity: 0.7;
  background: transparent;
}

.topics_tab {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 0;
  padding: 0;
  list-style-type: none;
  font-size: 18px;
  letter-spacing: 0.1ex;
}
@media only screen and (max-width: 959px) {
  .topics_tab {
    font-size: 16px;
  }
}
@media only screen and (max-width: 767px) {
  .topics_tab {
    font-size: 16px;
  }
}
.topics_tab li {
  margin: 0;
  padding: 0;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
@media only screen and (max-width: 767px) {
  .topics_tab li {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    min-width: 50%;
  }
}
.topics_tab li a {
  display: block;
  text-decoration: none;
  color: #128062;
  text-align: center;
  padding: 0.5ex;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
  border-radius: 5px 5px 0 0;
}
@media only screen and (max-width: 767px) {
  .topics_tab li a {
    padding: 1ex;
  }
}
.topics_tab li a:hover, .topics_tab li a:active {
  text-decoration: none;
  background: #e5f7f1 !important;
}
.topics_tab li a::before {
  content: "";
  width: 10px;
  height: 0.8em;
  display: inline-block;
  background: url(../img/common/gnav_arrow.webp) 0 50%/10px 10px no-repeat;
  margin-right: 0.8ex;
}
.topics_tab li a.active {
  background: #f9f5f1;
}

.topics_content {
  list-style-type: none;
  margin: 0;
  padding: 0;
  background: #f9f5f1;
  border-radius: 0 5px 5px 5px;
}
.topics_content > li {
  display: none;
}

.topics_list {
  list-style-type: none;
  margin: 0 0 20px;
  padding: 0;
}
.topics_list li {
  margin: 0;
  padding: 0;
  position: relative;
}
.topics_list li::after {
  content: "";
  display: block;
  border-top: 1px dashed #d5d5a3;
  margin: 0 30px;
}
.topics_list li:last-child::after {
  content: none;
}
.topics_list li.sticky::before {
  content: "";
  display: block;
  position: absolute;
  right: -5px;
  top: -5px;
  width: 24px;
  height: 24px;
  background: url(../img/common/icon_pin.webp) 50% 50%/contain no-repeat;
}
.topics_list li.sticky ._date {
  display: none;
}
.topics_list li.sticky ._title {
  font-weight: 700;
}
.topics_list li a {
  text-decoration: none;
  padding: 20px 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
@media only screen and (max-width: 767px) {
  .topics_list li a {
    padding: 10px 15px;
  }
}
.topics_list li a:hover, .topics_list li a:active {
  text-decoration: none;
  background: #e5f7f1;
}
.topics_list li ._img {
  margin-right: 20px;
  position: relative;
}
@media only screen and (max-width: 767px) {
  .topics_list li ._img {
    margin-right: 15px;
  }
}
.topics_list li ._img > div {
  border-radius: 3px;
  width: 140px;
  aspect-ratio: 3/2;
  overflow: hidden;
  position: relative;
}
@media only screen and (max-width: 767px) {
  .topics_list li ._img > div {
    width: 100px;
  }
}
.topics_list li ._img > div > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
}
@media only screen and (max-width: 767px) {
  .topics_list li ._content {
    font-size: 14px;
  }
}
.topics_list li ._content ._attr {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.topics_list li ._content ._attr ._date {
  color: #14274c;
  font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin-top: 0.15em;
}
.topics_list li ._content ._attr ._category {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.topics_list li ._content ._attr ._category .label {
  background: #44ad89;
  border-radius: 1em;
  display: block;
  vertical-align: middle;
  color: #ffffff;
  font-weight: 500;
  line-height: 1.6;
  padding: 0 1.2ex;
  letter-spacing: 0.1em;
  margin-left: 0.7ex;
}
.topics_list li ._content ._title {
  color: #333333;
  padding-top: 0.5ex;
  letter-spacing: 0.1em;
  line-height: 1.8;
}
.topics_list li ._content ._title .ext::after {
  background: url(../img/common/icon_ext.webp) 50% 50%/contain no-repeat;
  content: "";
  display: inline-block;
  width: 18px;
  height: 18px;
  vertical-align: -5%;
  margin: 0 0 0 0.5ex;
}
.topics_list li ._content ._title .pdf::after {
  background: url(../img/common/icon_pdf.webp) 50% 50%/contain no-repeat;
  content: "";
  display: inline-block;
  width: 18px;
  height: 18px;
  vertical-align: -5%;
  margin: 0 0 0 0.5ex;
}
.topics_list._card li {
  margin-bottom: 10px;
}
.topics_list._card li::after {
  display: none;
}
.topics_list._card li a {
  padding: 20px;
  background: #f9f5f1;
  border-radius: 5px;
}
.topics_list._card li a:hover, .topics_list._card li a:active {
  background: #e5f7f1;
}

._orange .wp-block-button__link,
.wp-block-button__link._orange,
._orange .btn {
  background-color: #d14a1b;
}

:root a:where(.wp-element-button, .wp-block-button__link),
.btn {
  margin: 10px 5px;
  display: inline-block;
  border: 5px solid #d4e9fa;
  background: #ffffff;
  border-radius: 15px;
  color: #2e83c7;
  padding: 0.8em 2.4em 0.8em 2em;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  min-width: 200px;
  position: relative;
}
:root a:where(.wp-element-button, .wp-block-button__link).btn_l,
.btn.btn_l {
  font-size: 125%;
  display: table;
  margin: auto;
}
:root a:where(.wp-element-button, .wp-block-button__link)::after,
.btn::after {
  content: "";
  display: block;
  position: absolute;
  background: url(../img/common/btn_icon_arrow.webp) 50% 50%/contain no-repeat;
  width: 20px;
  height: 100%;
  right: 20px;
  top: 0;
}
:root a:where(.wp-element-button, .wp-block-button__link).ext::after,
.btn.ext::after {
  background-image: url(../img/common/btn_icon_ext.webp);
  width: 20px;
}
:root a:where(.wp-element-button, .wp-block-button__link).pdf::after,
.btn.pdf::after {
  background-image: url(../img/common/btn_icon_pdf.webp);
  width: 20px;
}
:root a:where(.wp-element-button, .wp-block-button__link):hover, :root a:where(.wp-element-button, .wp-block-button__link):active,
.btn:hover,
.btn:active {
  text-decoration: none;
  border-color: #3b96df;
}
._orange :root a:where(.wp-element-button, .wp-block-button__link), :root a:where(.wp-element-button, .wp-block-button__link)._orange,
._orange .btn,
.btn._orange {
  display: inline-block;
  background: #d14a1b url(../img/common/btn_bg.webp) repeat;
  color: #ffffff;
  padding: 1em 50px;
  text-align: center;
  min-width: 200px;
  text-decoration: none;
  border-radius: 2em;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin: 10px 5px;
  position: relative;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
  letter-spacing: 0.1ex;
  border: none;
}
@media only screen and (max-width: 959px) {
  ._orange :root a:where(.wp-element-button, .wp-block-button__link), :root a:where(.wp-element-button, .wp-block-button__link)._orange,
  ._orange .btn,
  .btn._orange {
    padding: 10px 40px;
  }
}
@media only screen and (max-width: 767px) {
  ._orange :root a:where(.wp-element-button, .wp-block-button__link), :root a:where(.wp-element-button, .wp-block-button__link)._orange,
  ._orange .btn,
  .btn._orange {
    padding: 10px 40px;
  }
}
._orange :root a:where(.wp-element-button, .wp-block-button__link):hover, ._orange :root a:where(.wp-element-button, .wp-block-button__link):active, :root a:where(.wp-element-button, .wp-block-button__link)._orange:hover, :root a:where(.wp-element-button, .wp-block-button__link)._orange:active,
._orange .btn:hover,
._orange .btn:active,
.btn._orange:hover,
.btn._orange:active {
  text-decoration: none;
  background-color: #eeeeee;
  color: #314061;
}
._orange :root a:where(.wp-element-button, .wp-block-button__link):hover::after, ._orange :root a:where(.wp-element-button, .wp-block-button__link):active::after, :root a:where(.wp-element-button, .wp-block-button__link)._orange:hover::after, :root a:where(.wp-element-button, .wp-block-button__link)._orange:active::after,
._orange .btn:hover::after,
._orange .btn:active::after,
.btn._orange:hover::after,
.btn._orange:active::after {
  background-image: url(../img/common/btn_arrow_hover.webp);
}
._orange :root a:where(.wp-element-button, .wp-block-button__link)::after, :root a:where(.wp-element-button, .wp-block-button__link)._orange::after,
._orange .btn::after,
.btn._orange::after {
  content: "";
  display: block;
  position: absolute;
  background: url(../img/common/btn_arrow.webp) 50% 50%/contain no-repeat;
  width: 11px;
  height: 100%;
  right: 20px;
  top: 0;
}
._orange :root a:where(.wp-element-button, .wp-block-button__link).ext::after, :root a:where(.wp-element-button, .wp-block-button__link)._orange.ext::after,
._orange .btn.ext::after,
.btn._orange.ext::after {
  background-image: url(../img/common/icon_ext_white.webp);
  width: 18px;
}
._orange :root a:where(.wp-element-button, .wp-block-button__link).pdf::after, :root a:where(.wp-element-button, .wp-block-button__link)._orange.pdf::after,
._orange .btn.pdf::after,
.btn._orange.pdf::after {
  background-image: url(../img/common/icon_pdf_white.webp);
  width: 18px;
}
._orange :root a:where(.wp-element-button, .wp-block-button__link):hover.ext::after, ._orange :root a:where(.wp-element-button, .wp-block-button__link):active.ext::after, :root a:where(.wp-element-button, .wp-block-button__link)._orange:hover.ext::after, :root a:where(.wp-element-button, .wp-block-button__link)._orange:active.ext::after,
._orange .btn:hover.ext::after,
._orange .btn:active.ext::after,
.btn._orange:hover.ext::after,
.btn._orange:active.ext::after {
  background-image: url(../img/common/icon_ext.webp);
}
._orange :root a:where(.wp-element-button, .wp-block-button__link):hover.pdf::after, ._orange :root a:where(.wp-element-button, .wp-block-button__link):active.pdf::after, :root a:where(.wp-element-button, .wp-block-button__link)._orange:hover.pdf::after, :root a:where(.wp-element-button, .wp-block-button__link)._orange:active.pdf::after,
._orange .btn:hover.pdf::after,
._orange .btn:active.pdf::after,
.btn._orange:hover.pdf::after,
.btn._orange:active.pdf::after {
  background-image: url(../img/common/icon_pdf.webp);
}

._orange a:hover span.btn, a:hover span.btn._orange,
._orange a:active span.btn,
a:active span.btn._orange {
  background-color: #eeeeee;
  color: #314061;
}
._orange a:hover span.btn::after, a:hover span.btn._orange::after,
._orange a:active span.btn::after,
a:active span.btn._orange::after {
  background-image: url(../img/common/btn_arrow_hover.webp);
}

.center {
  text-align: center;
}

.content_header {
  position: relative;
  z-index: 0;
  min-height: 300px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-bottom: 40px;
  margin-bottom: -40px;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
}
@media only screen and (min-width: 960px) and (max-width: 1229px) {
  .content_header {
    min-height: 200px;
    padding-bottom: 0;
    margin-bottom: 0;
  }
}
@media only screen and (max-width: 959px) {
  .content_header {
    min-height: 160px;
    padding-bottom: 0;
    margin-bottom: 0;
  }
}
@media only screen and (max-width: 767px) {
  .content_header {
    min-height: 120px;
    padding-bottom: 0;
    margin-bottom: 0;
  }
}
.content_header h1 {
  position: relative;
  z-index: 1;
  display: table;
  color: #ffffff;
  background: transparent;
  letter-spacing: 0.1ex;
  font-size: 36px;
  font-weight: 600;
  padding: 0 1.5em;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  line-height: 1.6;
  font-family: "Kosugi Maru", sans-serif;
}
.content_header h1 span {
  display: block;
  position: relative;
  z-index: 1;
  -webkit-transition: 0.3s all cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition: 0.3s all cubic-bezier(0.25, 0.46, 0.45, 0.94);
  -webkit-transition-delay: 0.5s;
          transition-delay: 0.5s;
  opacity: 1;
}
.content_header h1 span::before {
  position: absolute;
  content: "";
  display: block;
  width: 45px;
  height: 24px;
  top: -40px;
  left: 50%;
  -webkit-transform: translateX(-50%) translateY(0px);
          transform: translateX(-50%) translateY(0px);
  background: url(../img/common/h1_bg.webp) 50% 50%/contain no-repeat;
  -webkit-transition: 0.8s all cubic-bezier(0.175, 0.885, 0.32, 1.275);
  transition: 0.8s all cubic-bezier(0.175, 0.885, 0.32, 1.275);
  -webkit-transition-delay: 0.5s;
          transition-delay: 0.5s;
  opacity: 1;
}
@media only screen and (max-width: 959px) {
  .content_header h1 span::before {
    content: none;
  }
}
@media only screen and (max-width: 767px) {
  .content_header h1 span::before {
    content: none;
  }
}
@media only screen and (min-width: 960px) and (max-width: 1229px) {
  .content_header h1 {
    font-size: 30px;
  }
}
@media only screen and (max-width: 959px) {
  .content_header h1 {
    font-size: 27px;
  }
}
@media only screen and (max-width: 767px) {
  .content_header h1 {
    font-size: 24px;
  }
}
.content_header h1::before, .content_header h1::after {
  content: "";
  display: block;
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  -webkit-transform-origin: 0 0;
          transform-origin: 0 0;
  -webkit-transform: scaleX(1);
          transform: scaleX(1);
  opacity: 1;
  -webkit-transition: 0.3s all cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition: 0.3s all cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.content_header h1::before {
  background: #ffffff;
  -webkit-transition-delay: 0.2s;
          transition-delay: 0.2s;
}
.content_header h1::after {
  background: #233457;
  -webkit-transition-delay: 0.3s;
          transition-delay: 0.3s;
}
.content_header img {
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
  opacity: 1;
  -webkit-transition: 1.8s cubic-bezier(0.25, 0.46, 0.45, 0.94) all;
  transition: 1.8s cubic-bezier(0.25, 0.46, 0.45, 0.94) all;
  -webkit-filter: brightness(0.9) contrast(0.8);
          filter: brightness(0.9) contrast(0.8);
}
.content_header.ready img {
  -webkit-filter: blur(3px);
          filter: blur(3px);
  -webkit-transform: scaleX(1.1);
          transform: scaleX(1.1);
  opacity: 0.3;
}
.content_header.ready h1 span {
  opacity: 0;
}
.content_header.ready h1 span::before {
  -webkit-transform: translateX(-50%) translateY(50px) rotateY(360deg);
          transform: translateX(-50%) translateY(50px) rotateY(360deg);
  opacity: 0;
}
.content_header.ready h1::before, .content_header.ready h1::after {
  -webkit-transform: scaleX(0);
          transform: scaleX(0);
}

.anchor_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: start;
  list-style-type: none;
  padding: 0;
  margin: 1em 0 2em;
}
@media only screen and (max-width: 767px) {
  .anchor_link {
    margin-bottom: 2em;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: start;
  }
}
.anchor_link li {
  margin: 0;
  padding: 0;
}
@media only screen and (max-width: 767px) {
  .anchor_link li {
    margin-right: 1em;
  }
}
.anchor_link li a {
  display: inline-block;
  background: url(../img/common/arrow_anchor.webp) 0% 55%/10px 10px no-repeat;
  padding: 0 18px;
  margin: 0 15px;
  letter-spacing: 0.1ex;
}
@media only screen and (max-width: 767px) {
  .anchor_link li a {
    margin: 0;
  }
}

main {
  position: relative;
  margin: 0 auto 100px;
  background: #ffffff;
  min-height: 640px;
  max-width: 1400px;
  -webkit-box-shadow: 7px 7px 0 rgba(115, 116, 95, 0.06);
          box-shadow: 7px 7px 0 rgba(115, 116, 95, 0.06);
}
main .main_content {
  padding: 20px 100px;
}
@media only screen and (min-width: 960px) and (max-width: 1229px) {
  main .main_content {
    padding: 10px 15px;
  }
}
@media only screen and (max-width: 959px) {
  main .main_content {
    padding: 10px 15px;
  }
}
@media only screen and (max-width: 767px) {
  main .main_content {
    padding: 10px 15px;
  }
}
main .main_content hr {
  border: none;
  border-top: 3px dashed #9db9b1;
  margin: 2em;
}
main a {
  color: #128062;
  -webkit-transition: 0.3s all;
  transition: 0.3s all;
  text-decoration: none;
}
main a:hover, main a:active {
  color: #0096ff;
  text-decoration: underline;
}
main h2 {
  position: relative;
  color: #314061;
  font-size: 36px;
  padding-left: 0.8em;
  letter-spacing: 0.1em;
  line-height: 1.4;
  margin-top: 1.8em;
  margin-bottom: 0.8em;
  font-family: "Kosugi Maru", sans-serif;
}
main h2::before {
  content: "";
  position: absolute;
  display: block;
  background: #e8cd62;
  width: 8px;
  height: 85%;
  top: 10%;
  left: 0;
  border-radius: 4px 4px;
}
@media only screen and (max-width: 767px) {
  main h2 {
    font-size: 27px;
  }
}
main .anchor_link + h2,
main h2:first-child {
  margin-top: 1em;
}
main .wp-block-column > *:first-child {
  margin-top: 0;
}
main h3 {
  color: #233457;
  font-size: 28px;
  position: relative;
  border-bottom: 2px dashed #d5d5a3;
  display: table;
  line-height: 1.6;
  letter-spacing: 0.1em;
  margin-top: 2em;
  margin-bottom: 1ex;
  font-family: "Kosugi Maru", sans-serif;
}
main h3.has-text-align-center {
  margin-left: auto;
  margin-right: auto;
}
@media only screen and (max-width: 767px) {
  main h3 {
    font-size: 22px;
  }
}
main h2 + h3 {
  margin-top: 1.5ex;
}
main .wp-block-column > h3 {
  margin-top: 0;
}
main h4 {
  color: #233457;
  font-size: 24px;
  position: relative;
  line-height: 1.6;
  letter-spacing: 0.1em;
  margin-top: 1.5em;
  margin-bottom: 0.5ex;
}
main h4::before {
  content: "";
  display: inline-block;
  width: 1em;
  aspect-ratio: 1/1;
  background: url(../img/common/h4_marker.webp) 50% 50%/contain no-repeat;
  margin: 0 0.75ex -0.3ex 0;
}
@media only screen and (max-width: 767px) {
  main h4 {
    font-size: 20px;
  }
}
main h3 + h4 {
  margin-top: 1.5ex;
}
main .wp-block-column > h4 {
  margin-top: 0;
}
main h5 {
  color: #233457;
  font-size: 20px;
  position: relative;
  display: table;
  line-height: 1.6;
  letter-spacing: 0.1em;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, transparent), color-stop(50%, #f5eff1));
  background: linear-gradient(transparent 50%, #f5eff1 50%);
  margin-bottom: 0.5ex;
}
@media only screen and (max-width: 767px) {
  main h5 {
    font-size: 18px;
  }
}
main h4 + h5 {
  margin-top: 2ex;
}
main .wp-block-column > h5 {
  margin-top: 0;
}
main h6 {
  color: #233457;
  font-size: 18px;
}
@media only screen and (max-width: 767px) {
  main h6 {
    font-size: 17px;
  }
}
main h5 + h6 {
  margin-top: 2ex;
}
main .wp-block-column > h6 {
  margin-top: 0;
}

.entry-content > .wp-block-table {
  margin: 1em 0px;
}

.wp-block-table + .wp-block-table {
  margin-top: 1em;
}

.wp-block-table.fixed_table {
  position: relative;
}
.wp-block-table.fixed_table::after {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.6) url(../img/common/swipe.webp) 50% 50%/128px 128px no-repeat;
  cursor: pointer;
  -webkit-transition: 0.3s all cubic-bezier(0.455, 0.03, 0.515, 0.955);
  transition: 0.3s all cubic-bezier(0.455, 0.03, 0.515, 0.955);
}
.wp-block-table.fixed_table.touched::after {
  opacity: 0;
  pointer-events: none;
}
.wp-block-table.fixed_table > table {
  width: 100%;
}
@media only screen and (max-width: 959px) {
  .wp-block-table.fixed_table {
    overflow: auto;
  }
  .wp-block-table.fixed_table::after {
    content: "";
  }
  .wp-block-table.fixed_table > table {
    width: 1200px;
  }
}
@media only screen and (max-width: 767px) {
  .wp-block-table.fixed_table {
    overflow: auto;
  }
  .wp-block-table.fixed_table::after {
    content: "";
  }
  .wp-block-table.fixed_table > table {
    width: 1200px;
  }
}

.wp-admin .wp-block-table.fixed_table {
  position: relative;
}
.wp-admin .wp-block-table.fixed_table::after {
  display: none;
  content: none;
}

body#tinymce .wp-block-table.fixed_table::after {
  display: none;
}
body#tinymce .wp-block-table.fixed_table .bordered_table {
  width: 100%;
}

.wp-block-table {
  margin: 0;
  overflow: hidden;
}
.wp-block-table.th25 tbody tr th {
  width: 25%;
}
.wp-block-table.th33 tbody tr th {
  width: 33%;
}
.wp-block-table table {
  border-spacing: 0;
  border-collapse: collapse;
}
.wp-block-table table th,
.wp-block-table table td {
  border: none;
}
.wp-block-table table thead {
  border: none;
  background: #ac660c;
  border: 1px solid #ac660c;
}
.wp-block-table table thead th,
.wp-block-table table thead td {
  padding: 15px 15px;
  color: #ffffff;
  position: relative;
}
.wp-block-table table thead th::after,
.wp-block-table table thead td::after {
  content: "";
  display: block;
  position: absolute;
  right: -1px;
  top: 10px;
  height: calc(100% - 20px);
  width: 2px;
  background: #985805;
}
.wp-block-table table thead th:last-child::after,
.wp-block-table table thead td:last-child::after {
  content: none;
}
.wp-block-table table tbody {
  background-color: #faf8f6;
}
.wp-block-table table tbody th {
  border: 1px solid #daa617;
  background-color: #f8d77c;
  padding: 15px 15px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
}
.wp-block-table table tbody td {
  padding: 15px 25px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
  border: 1px solid #d0cbc5;
}
@media only screen and (max-width: 959px) {
  .wp-block-table table tbody td {
    padding: 15px 15px;
  }
}
@media only screen and (max-width: 767px) {
  .wp-block-table table tbody td {
    padding: 15px 15px;
  }
}

@media only screen and (max-width: 959px) {
  :where(.wp-block-columns.is-layout-flex) {
    gap: 0.5em;
  }
}
@media only screen and (max-width: 767px) {
  :where(.wp-block-columns.is-layout-flex) {
    gap: 0.5em;
  }
}

.breadcrumb {
  background: #fbf8f7;
  list-style-type: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin: 0;
  padding: 0;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: end;
  padding: 1em 2em;
}
@media only screen and (min-width: 960px) and (max-width: 1229px) {
  .breadcrumb {
    padding: 1ex 15px;
  }
}
@media only screen and (max-width: 959px) {
  .breadcrumb {
    padding: 0.75ex 15px;
  }
}
@media only screen and (max-width: 767px) {
  .breadcrumb {
    padding: 0.5ex 15px;
  }
}
.breadcrumb li {
  margin: 0;
  padding: 0 30px 0 0;
  position: relative;
  color: #808080;
}
.breadcrumb li::after {
  content: "";
  width: 1px;
  height: 60%;
  display: block;
  background: #808080;
  -webkit-transform: rotate(25deg);
          transform: rotate(25deg);
  position: absolute;
  right: 15px;
  top: 20%;
}
.breadcrumb li:last-child {
  padding-right: 0;
}
.breadcrumb li:last-child::after {
  content: none;
}

.columned {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 0 0px;
  padding: 0;
  list-style-type: none;
  list-style-image: none;
}
.columned.shrink {
  margin: 0 15px;
}
@media only screen and (max-width: 767px) {
  .columned.shrink {
    margin: 0;
  }
}
.columned.row_reverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
.columned.column_reverse {
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
}
.columned > * {
  margin: 0 0 1em;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding-left: 10px;
  padding-right: 10px;
  width: 100%;
  position: relative;
  list-style-image: none;
}
.columned > * > p {
  margin-left: 0;
  margin-right: 0;
}

.pc_column1,
.pc_column2,
.pc_column3,
.pc_column4,
.pc_column5,
.pc_column6 {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.pc_column2 > * {
  width: 50%;
}

.pc_column3 > * {
  width: 33.33%;
}

.pc_column4 > * {
  width: 25%;
}

.pc_column5 > * {
  width: 20%;
}

.pc_column6 > * {
  width: 16.66%;
}

@media only screen and (max-width: 959px) {
  .tab_column1,
  .tab_column2,
  .tab_column3 {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .tab_column1 > * {
    width: 100%;
  }
  .tab_column2 > * {
    width: 50%;
  }
  .tab_column3 > * {
    width: 33.33%;
  }
  .tab_column4 > * {
    width: 25%;
  }
  .tab_column5 > * {
    width: 20%;
  }
}
@media only screen and (max-width: 767px) {
  .sp_column1,
  .sp_column2,
  .sp_column3 {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .sp_column1 > * {
    width: 100%;
  }
  .sp_column2 > * {
    width: 50%;
  }
  .sp_column3 > * {
    width: 33.33%;
  }
  .sp_column4 > * {
    width: 25%;
  }
  .sp_column5 > * {
    width: 20%;
  }
}
.icon_new {
  font-family: "Montserrat", sans-serif;
  font-size: 75%;
  color: #ffffff;
  background: #ff3300;
  border-radius: 1em;
  padding: 0.2ex 1ex;
  display: inline-block;
  line-height: 1.4;
  font-weight: 500;
  vertical-align: 20%;
}

a:not(:has(img)):not(:has(div))::after {
  display: inline-block;
  height: 18px;
  width: 18px;
  vertical-align: -10%;
}
a:not(:has(img)):not(:has(div)).ext::after {
  content: "";
  background: url(../img/common/icon_ext.webp) 50% 50%/contain no-repeat;
}
a:not(:has(img)):not(:has(div)).pdf::after {
  content: "";
  background: url(../img/common/icon_pdf.webp) 50% 50%/contain no-repeat;
}

.img_max img,
img.img_max {
  width: 100%;
  max-width: 100%;
  display: block;
}

.boxed {
  border-radius: 10px;
  padding: 15px;
  border: 1px solid #dddddd;
}
.boxed._orange {
  background-color: #fbf6e9;
}

.yakkan_table tbody tr th {
  text-align: left;
  width: 50%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.yakkan_table tbody tr td {
  text-align: center;
  width: 25%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.fee_table thead tr th:first-child {
  width: 33.3%;
}
.fee_table thead tr th:last-child {
  width: 12%;
}

form button {
  border: none;
  cursor: pointer;
  font-size: 1rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
}

.clipping {
  overflow: auto;
  height: 320px;
}

.kinri_letter {
  font-size: 200%;
}

blockquote.wp-block-quote {
  background: #f8f8f8;
  border-radius: 5px;
  margin: 1.6rem 0;
  padding: 15px 2em 15px 2em;
  position: relative;
}
blockquote.wp-block-quote::before {
  content: "“";
  position: absolute;
  left: 0;
  top: -0.7em;
  font-size: 120px;
  color: #e8e8e8;
}

.bordered_img img {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border: 1px solid #dddddd;
}

.recipe_img figure {
  margin-bottom: 0;
}

.recipe_memo {
  background: #f8f4f1;
  border-radius: 10px 10px;
  position: relative;
  text-align: center;
  color: #552602;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding: 0 15px;
}
.recipe_memo::before {
  content: "";
  background: url(../img/common/recipe_memo_top.webp) 50% 0%/contain no-repeat;
  display: block;
  height: 80px;
  top: 0;
  width: 100%;
}
.recipe_memo::after {
  content: "";
  display: block;
  background: url(../img/common/recipe_memo_chara.webp) 50% 100%/contain no-repeat;
  height: 140px;
  top: 0;
  width: 100%;
  -webkit-transform: translateY(5.7%);
          transform: translateY(5.7%);
}
@media only screen and (max-width: 767px) {
  .recipe_memo::after {
    height: 100px;
  }
}

main .recipe_ingredient h3,
main .recipe_make h3 {
  color: #233457;
  font-size: 24px;
  position: relative;
  line-height: 1.6;
  letter-spacing: 0.1em;
  margin-top: 1.5em;
  margin-bottom: 0.5ex;
  border-bottom: none;
}
main .recipe_ingredient h3::before,
main .recipe_make h3::before {
  content: "";
  display: inline-block;
  width: 1em;
  aspect-ratio: 1/1;
  background: url(../img/common/h4_marker.webp) 50% 50%/contain no-repeat;
  margin: 0 0.75ex -0.3ex 0;
}
@media only screen and (max-width: 767px) {
  main .recipe_ingredient h3,
  main .recipe_make h3 {
    font-size: 20px;
  }
}
main .recipe_ingredient h4,
main .recipe_make h4 {
  color: #233457;
  font-size: 20px;
  position: relative;
  display: table;
  line-height: 1.6;
  letter-spacing: 0.1em;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, transparent), color-stop(50%, #f5eff1));
  background: linear-gradient(transparent 50%, #f5eff1 50%);
  margin-bottom: 0.5ex;
  padding-left: 1ex;
  padding-right: 1ex;
  margin-top: 1em;
}
main .recipe_ingredient h4::before,
main .recipe_make h4::before {
  content: none;
}
@media only screen and (max-width: 767px) {
  main .recipe_ingredient h4,
  main .recipe_make h4 {
    font-size: 18px;
  }
}
main .recipe_ingredient h3 + h4,
main .recipe_make h3 + h4 {
  margin-top: 0;
}
main .recipe_ingredient ol,
main .recipe_make ol {
  margin: 0;
  padding: 0;
  list-style: none;
  counter-reset: number;
}
main .recipe_ingredient ol li,
main .recipe_make ol li {
  position: relative;
  padding-left: 1.7em;
  border-bottom: 1px dashed #d5d5a3;
  padding: 1ex 1ex 1ex 2em;
}
main .recipe_ingredient ol li::before,
main .recipe_make ol li::before {
  counter-increment: number;
  content: counter(number);
  position: absolute;
  top: 1.8ex;
  left: 0;
  height: 1.8em;
  aspect-ratio: 1/1;
  border-radius: 50%;
  font-size: 10px;
  text-align: center;
  color: #ffffff;
  background: #7cc2b1;
  font-family: "Montserrat", sans-serif;
  font-size: 14px;
  line-height: 1.8;
}
main .recipe_ingredient ul,
main .recipe_make ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
main .recipe_ingredient ul li,
main .recipe_make ul li {
  position: relative;
  padding-left: 1.7em;
  border-bottom: 1px dashed #d5d5a3;
  padding: 1ex 1ex 1ex 1.5em;
}
main .recipe_ingredient ul li::before,
main .recipe_make ul li::before {
  content: "";
  position: absolute;
  top: 3.1ex;
  left: 1ex;
  height: 8px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  font-size: 10px;
  text-align: center;
  color: #ffffff;
  border: 2px solid #7cc2b1;
  font-size: 14px;
  line-height: 1;
}