/* CSS Document */
#page-nav ul {
  width: 70%;
  margin: 0 auto; }

.site-header {
  background-color: #fff !important; }

#header {
  background: #efcd99 url("../img/header-guide.jpg") center/cover; }

#wrapper {
  overflow: hidden; }

#to-use {
  position: relative;
  padding-bottom: 12rem;
  background: #f8f9e0; }
  @media screen and (max-width: 991px) {
    #to-use {
      padding-bottom: 10rem; } }
  @media screen and (max-width: 767px) {
    #to-use {
      padding-bottom: 7rem; } }
  @media screen and (max-width: 575px) {
    #to-use {
      padding-bottom: 5rem; } }
  #to-use::after {
    content: "";
    position: absolute;
    bottom: -2px;
    width: 100%;
    height: 5.7vw;
    background-image: url("../../img/wave-white-top.svg");
    background-size: contain;
    background-repeat: no-repeat;
    left: 50%;
    transform: translateX(-50%); }
  #to-use dl {
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
    padding: 2.5rem 3rem;
    margin-bottom: 40px;
    position: relative; }
    @media screen and (max-width: 767px) {
      #to-use dl {
        margin-bottom: 30px; } }
    #to-use dl:not(:last-of-type)::after {
      content: "";
      position: absolute;
      bottom: 0;
      left: 50%;
      border-style: solid;
      border-width: 26px 26px 0 26px;
      border-color: #80cea0 transparent transparent;
      translate: -50% 100%; }
      @media screen and (max-width: 767px) {
        #to-use dl:not(:last-of-type)::after {
          border-width: 18px 18px 0 18px; } }
    #to-use dl dt {
      font-size: 25px;
      font-size: 2.5rem;
      font-weight: 700;
      color: #009d42;
      line-height: 1.5em; }
    #to-use dl dd {
      margin-bottom: 0;
      line-height: 1.5em; }

#price {
  position: relative;
  padding-top: 2rem;
  padding-bottom: 13rem; }
  @media screen and (max-width: 991px) {
    #price {
      padding-bottom: 10rem; } }
  @media screen and (max-width: 575px) {
    #price {
      padding-bottom: 5rem; } }
  #price::after {
    content: "";
    position: absolute;
    bottom: -2px;
    width: 100%;
    height: 5.7vw;
    background-image: url("../../img/wave-yellow-top.svg");
    background-size: contain;
    background-repeat: no-repeat;
    left: 50%;
    transform: translateX(-50%); }
  #price .price-list {
    margin-bottom: 3rem; }
    #price .price-list h4 {
      font-size: 25px;
      font-size: 2.5rem;
      font-weight: 700;
      color: #009d42;
      margin-bottom: 1rem; }
      #price .price-list h4 span {
        font-size: 16px;
        font-size: 1.6rem;
        font-weight: 400;
        color: #513619; }
    #price .price-list .table-wrap {
      margin-bottom: 2rem;
      overflow-x: auto; }
      #price .price-list .table-wrap table {
        width: 100%;
        border: 2px solid #009d42; }
        @media screen and (max-width: 767px) {
          #price .price-list .table-wrap table {
            min-width: 680px; } }
        #price .price-list .table-wrap table .sub-th {
          width: 23%; }
          @media screen and (max-width: 991px) {
            #price .price-list .table-wrap table .sub-th {
              width: 20%; } }
        #price .price-list .table-wrap table th, #price .price-list .table-wrap table td {
          border: 1px solid #009d42;
          padding: 0.75rem 2rem;
          line-height: 1.35em;
          white-space: nowrap; }
          @media screen and (max-width: 767px) {
            #price .price-list .table-wrap table th, #price .price-list .table-wrap table td {
              padding: 0.75rem 1rem; } }
        #price .price-list .table-wrap table th {
          font-weight: 400;
          background: #cedf9f; }
      #price .price-list .table-wrap .scroll-hint-icon-wrap .scroll-hint-icon {
        top: 0;
        bottom: 0;
        right: 0;
        left: 0;
        margin: auto;
        height: 100px; }
  #price .price-other h5 {
    font-size: 20px;
    font-size: 2rem;
    font-weight: 700;
    color: #009d42;
    margin-bottom: 1rem; }
  #price .price-other ul {
    list-style: none;
    padding: 0; }
    #price .price-other ul li {
      line-height: 1.75em; }
      #price .price-other ul li::before {
        content: "";
        display: inline-block;
        width: 13px;
        height: 13px;
        background-color: #a1d6b2;
        border-radius: 50%;
        margin-right: 0.5rem; }
  #price .price-other p {
    font-size: 12px;
    font-size: 1.2rem;
    line-height: 1.75em; }

#contact-banner {
  padding: 7rem 0 10rem;
  background: #f8f9e0; }
  @media screen and (max-width: 991px) {
    #contact-banner {
      padding: 5rem 0 5rem; } }
  @media screen and (max-width: 575px) {
    #contact-banner {
      padding: 3rem 0 3rem; } }
  #contact-banner .banner-content {
    display: flex;
    gap: 2rem;
    align-items: center;
    background: #009d42;
    border-radius: 10px;
    margin-bottom: 3rem;
    padding: 2rem;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
    transition: 0.2s ease-in-out; }
    @media screen and (max-width: 767px) {
      #contact-banner .banner-content {
        padding: 1.5rem; } }
    #contact-banner .banner-content:hover {
      background: #4cba7b; }
    #contact-banner .banner-content .text, #contact-banner .banner-content .image {
      flex: 1; }
    @media screen and (max-width: 575px) {
      #contact-banner .banner-content .text {
        text-align: center; } }
    #contact-banner .banner-content .text p {
      font-size: 35px;
      font-size: 3.5rem;
      line-height: 1.35em;
      color: #fff;
      border-bottom: dotted 3px #fff;
      display: inline-block;
      font-weight: 700; }
      @media screen and (max-width: 767px) {
        #contact-banner .banner-content .text p {
          font-size: 30px;
          font-size: 3rem; } }
      @media screen and (max-width: 575px) {
        #contact-banner .banner-content .text p {
          font-size: 28px;
          font-size: 2.8rem; } }
    #contact-banner .banner-content .image {
      height: 170px;
      overflow: hidden; }
      @media screen and (max-width: 991px) {
        #contact-banner .banner-content .image {
          height: 120px; } }
      @media screen and (max-width: 767px) {
        #contact-banner .banner-content .image {
          height: 120px; } }
      @media screen and (max-width: 575px) {
        #contact-banner .banner-content .image {
          display: none; } }
      #contact-banner .banner-content .image img {
        border-radius: 10px;
        width: 100%;
        height: 100%;
        object-fit: cover;
        mask-image: linear-gradient(to right, black 0%, black 70%, transparent 100%);
        -webkit-mask-image: linear-gradient(to right, black 0%, black 70%, transparent 100%); }
