html {
  width: 100%;
  height: 100%;
  color: #4b4b4b;
  box-sizing: border-box;
  background-color: #f8f8f5;
  -webkit-overflow-scrolling: touch;
  overflow-scrolling: touch;
  letter-spacing: 0.125rem;
  font-size: 62.5%;
  font-family: "dnp-shuei-gothic-kin-std", sans-serif;
  font-weight: 500;
  font-style: normal;
  font-feature-settings: "palt"; }
  html a {
    text-decoration: none;
    color: #4b4b4b; }
  html ol, html ul, html li {
    list-style: none; }
  html h1, html h2, html h3, html h4, html h5, html h6 {
    font-family: "dnp-shuei-mgothic-std", sans-serif;
    font-weight: 600;
    font-style: normal;
    font-feature-settings: "palt"; }

body {
  width: 100%;
  height: 100%; }

.none {
  display: none; }

header {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 75px;
  z-index: 1000; }
  header #header__wrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 1050px;
    height: 100%;
    padding: 0 60px;
    margin: 0 auto; }
    header #header__wrap .header__title {
      display: flex;
      align-items: center;
      z-index: 1003; }
      header #header__wrap .header__title img {
        width: auto;
        height: 36px;
        margin-right: 18px; }
      header #header__wrap .header__title p {
        letter-spacing: 0.025rem;
        font-size: 1.1rem;
        font-family: "dnp-shuei-mgothic-std", sans-serif;
        font-weight: 600;
        font-style: normal;
        font-feature-settings: "palt"; }
      @media (max-width: 767px) {
        header #header__wrap .header__title img {
          height: 24px;
          margin-right: 12px; } }
    header #header__wrap #hg-open {
      display: none;
      position: relative;
      width: 30px;
      height: 30px;
      justify-content: center;
      align-items: center;
      cursor: pointer; }
      header #header__wrap #hg-open span, header #header__wrap #hg-open span::before, header #header__wrap #hg-open span::after {
        display: block;
        position: absolute;
        width: 30px;
        height: 3px;
        background-color: #4b4b4b;
        content: "";
        transition: 0.2s; }
      header #header__wrap #hg-open span::before {
        bottom: 8px; }
      header #header__wrap #hg-open span::after {
        top: 8px; }
    header #header__wrap .header__nav ul {
      display: flex; }
      header #header__wrap .header__nav ul li a {
        display: block;
        width: auto;
        color: #aeaeae;
        margin-left: 30px;
        transition: all .3s ease;
        -webkit-transition: all .3s ease;
        letter-spacing: 0.05rem;
        font-size: 1.5rem;
        font-family: "dnp-shuei-mgothic-std", sans-serif;
        font-weight: 600;
        font-style: normal;
        font-feature-settings: "palt"; }
      header #header__wrap .header__nav ul li a::after {
        border-bottom: solid 2px #fa7d00;
        padding-top: 9px;
        content: "";
        display: block;
        transition: all .3s ease;
        -webkit-transition: all .3s ease;
        width: 0; }
      header #header__wrap .header__nav ul li a:hover {
        color: #4b4b4b; }
        header #header__wrap .header__nav ul li a:hover:after {
          width: 100%; }
      header #header__wrap .header__nav ul li:first-child > a {
        margin-left: 0; }
  @media (max-width: 767px) {
    header #header__wrap {
      padding: 0 min(7.5%, 60px); }
      header #header__wrap #hg-open {
        display: flex; }
      header #header__wrap .header__nav {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 0;
        opacity: 0;
        transition: 0.2s;
        overflow: hidden;
        background-color: rgba(248, 248, 245, 0.9); }
        header #header__wrap .header__nav ul {
          display: none;
          text-align: center;
          flex-direction: column;
          align-items: center;
          margin-top: 75px; }
          header #header__wrap .header__nav ul li {
            padding: 15px; }
            header #header__wrap .header__nav ul li a {
              margin-left: 0;
              color: #4b4b4b;
              font-size: 1.8rem;
              padding: 9px; }
              header #header__wrap .header__nav ul li a::after {
                padding: 0; }
      header #header__wrap #hg-btn:checked ~ #hg-open {
        z-index: 1002; }
        header #header__wrap #hg-btn:checked ~ #hg-open span {
          background-color: rgba(255, 255, 255, 0); }
        header #header__wrap #hg-btn:checked ~ #hg-open span::before {
          transform: rotate(45deg);
          bottom: 0px; }
        header #header__wrap #hg-btn:checked ~ #hg-open span::after {
          transform: rotate(-45deg);
          top: 0px; }
      header #header__wrap #hg-btn:checked ~ #hg-close .header__nav {
        height: 100%;
        opacity: 1;
        z-index: 1001; }
        header #header__wrap #hg-btn:checked ~ #hg-close .header__nav ul {
          display: flex; } }

header::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 15px;
  height: inherit;
  background-color: #fa7d00;
  z-index: 1000; }

header::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 15px;
  height: inherit;
  background-color: #fa7d00;
  z-index: 1000; }

main {
  display: block;
  position: relative;
  width: 100%;
  overflow: hidden;
  top: 75px; }

main::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 15px;
  height: calc(100% - 75px);
  background-color: #f8c719;
  z-index: 900; }

main::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 15px;
  height: calc(100% - 75px);
  background-color: #f8c719;
  z-index: 900; }

.btn, .more-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 210px;
  height: 54px;
  background-color: #f8f8f5;
  border: solid 3px #fa7d00;
  border-radius: 210px;
  color: #4b4b4b;
  line-height: 1.6rem;
  letter-spacing: 0.25rem;
  margin-bottom: 0;
  font-family: "dnp-shuei-mgothic-std", sans-serif;
  font-size: 1.6rem;
  font-weight: 600;
  font-style: normal;
  font-feature-settings: "palt"; }
  .btn span, .more-btn span {
    color: #fa7d00; }

.btn:hover, .more-btn:hover {
  transition: all .3s ease;
  -webkit-transition: all .3s ease;
  background-color: #fa7d00; }
  .btn:hover > p, .more-btn:hover > p {
    color: #f8f8f5; }
    .btn:hover > p > span, .more-btn:hover > p > span {
      color: #f8f8f5; }

.wave-deco {
  position: absolute;
  width: 100%;
  min-width: 2560px;
  left: 50%;
  transform: translateX(-50%); }

footer {
  display: block;
  width: 100%;
  background-color: #e1edd4;
  font-size: 1.2rem;
  text-align: center;
  padding-bottom: 45px;
  margin: 0 auto; }
  footer #footer__contents {
    position: relative;
    display: flex;
    justify-content: space-between;
    margin: 0 auto;
    padding: 45px 60px 90px;
    max-width: 1050px; }
    footer #footer__contents .footer__deco {
      position: absolute;
      right: 30px;
      top: -60px; }
      footer #footer__contents .footer__deco img {
        height: 60px;
        width: auto; }
    footer #footer__contents .footer__logo img {
      height: 30px;
      width: auto; }
    footer #footer__contents .footer__nav ul {
      display: flex;
      justify-content: center; }
      footer #footer__contents .footer__nav ul li a {
        display: block;
        width: auto;
        color: #4b4b4b;
        margin-left: 24px;
        transition: all .3s ease;
        -webkit-transition: all .3s ease;
        letter-spacing: 0.05rem;
        font-size: 1.2rem;
        font-family: "dnp-shuei-mgothic-std", sans-serif;
        font-weight: 600;
        font-style: normal;
        font-feature-settings: "palt"; }
      footer #footer__contents .footer__nav ul li a::after {
        border-bottom: solid 2px #4b4b4b;
        padding-top: 9px;
        content: "";
        display: block;
        transition: all .3s ease;
        -webkit-transition: all .3s ease;
        width: 100%; }
      footer #footer__contents .footer__nav ul li a:hover {
        color: #aeaeae; }
        footer #footer__contents .footer__nav ul li a:hover:after {
          width: 100%;
          border-bottom: solid 2px #aeaeae; }
      footer #footer__contents .footer__nav ul li:first-child a {
        margin-left: 0; }
    @media (max-width: 767px) {
      footer #footer__contents {
        flex-direction: column;
        justify-content: center; }
        footer #footer__contents .footer__deco {
          top: -45px; }
          footer #footer__contents .footer__deco img {
            height: 45px; }
        footer #footer__contents .footer__logo {
          margin-bottom: 30px; }
        footer #footer__contents .footer__nav ul li a {
          margin-left: 18px; } }
  footer .copyright {
    font-size: 1.2rem;
    letter-spacing: normal; }

.sp-only {
  display: none; }
  @media (max-width: 767px) {
    .sp-only {
      display: block; } }

.pc-only {
  display: block; }
  @media (max-width: 767px) {
    .pc-only {
      display: none !important; } }
