@charset "UTF-8";
@font-face {
  font-family: "tsunagi";
  src: url("../font/TsunagiGothic.woff") format("woff"); }
/*****************************************/
body {
  background: url("../images/common/mv_bg1.svg") left top no-repeat;
  background-size: 548px 527px;
  padding: 150px 0 0 0; }

@media (max-width: 1024px) {
  body {
    background: url("../images/common/mv_bg1.svg") left top no-repeat;
    background-size: 377px 363px;
    padding: 100px 0 0 0; } }
/*max-width:1024px*/
@media (max-width: 480px) {
  body {
    background: url("../images/common/mv_bg1.svg") left top no-repeat;
    background-size: 231px 222px;
    padding: 100px 0 0 0; } }
/*max-width:480px*/
/*****************************************/
.loader {
  position: fixed;
  width: 100%;
  height: 100%;
  background-color: #fff;
  z-index: 555;
  top: 0;
  left: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 99999; }
  .loader .txt {
    display: none; }
    .loader .txt span {
      background: url("../images/load.svg") center center no-repeat;
      background-size: contain;
      display: block;
      width: 238px;
      height: 249px;
      overflow: hidden;
      text-indent: 100%;
      white-space: nowrap; }

/*****************************************/
header {
  z-index: 9999;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  transition: .3s; }
  header.fixed {
    background-color: rgba(255, 255, 255, 0.7); }
    header.fixed .header_box {
      height: 100px; }

/*max-width:1280px*/
/*max-width:1024px*/
/*max-width:768px*/
@media (max-width: 480px) {
  header.fixed {
    background-color: rgba(255, 255, 255, 0.7); }
    header.fixed .header_box {
      height: 80px; } }
/*max-width:480px*/
/*****************************************/
.header_box {
  transition: .3s;
  max-width: 1920px;
  margin: 0 auto;
  width: 100%;
  padding: 0 0 0 35px;
  height: 150px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  align-items: center; }
  .header_box h1 {
    width: fit-content;
    flex: 1; }
    .header_box h1 a {
      transition: .3s;
      width: fit-content;
      text-decoration: none;
      display: block; }
    .header_box h1 small {
      font: 1.3rem/1em " M PLUS Rounded 1c", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 700;
      color: #5F2607;
      margin: 0 0 10px;
      display: block; }
    .header_box h1 span {
      overflow: hidden;
      text-indent: 100%;
      white-space: nowrap;
      display: block;
      background: url("../images/logo01.svg") center center no-repeat;
      background-size: contain;
      aspect-ratio: 194/43;
      width: 236px;
      height: auto; }

@media (max-width: 1280px) {
  .header_box {
    max-width: 1920px;
    margin: 0 auto;
    width: 100%;
    padding: 0 0 0 20px; } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  .header_box {
    padding: 0 0 0 20px;
    height: 100px; }
    .header_box h1 small {
      font: 1rem/1em " M PLUS Rounded 1c", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 700; }
    .header_box h1 span {
      width: 200px; } }
/*max-width:1024px*/
@media (max-width: 480px) {
  .header_box {
    padding: 0 0 0 20px;
    height: 80px; }
    .header_box h1 span {
      width: 167px; } }
/*max-width:480px*/
@media (hover: hover) {
  .header_box h1 a:hover {
    opacity: 0.5; } }
/*****************************************/
.head_menu {
  transition: .3s;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  align-items: center;
  width: calc(100% - 310px);
  padding: 0 140px 0 30px;
  max-width: 1200px; }

.head_nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  align-items: center;
  max-width: 860px;
  width: 80%; }
  .head_nav a, .head_nav span {
    transition: .3s;
    text-decoration: none;
    text-align: center;
    font: 1.6rem/1em "Zen Kaku Gothic New", "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
    font-weight: 700;
    letter-spacing: 0.02em;
    color: #4D2F1F; }
    .head_nav a small, .head_nav span small {
      display: block;
      font: 0.9rem/1em "Zen Kaku Gothic New", "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 700;
      color: #FFA200;
      letter-spacing: 0.04em;
      margin: 0 0 15px; }
  .head_nav > li {
    position: relative; }
    .head_nav > li.current:before {
      display: block;
      width: 100%;
      height: 2px;
      position: absolute;
      content: "";
      text-decoration: underline wavy;
      /* text-underline-offset: 3px; */
      background-color: #FFA200;
      left: 0;
      bottom: -5px; }

.head_sub {
  width: 160px;
  position: absolute;
  top: 35px;
  left: 50%;
  -webkit-transform: translate(-50%, 0%);
  /* Safari用 */
  transform: translate(-50%, 0%);
  padding: 20px 0 0;
  opacity: 0;
  z-index: -9999;
  pointer-events: none; }
  .head_sub.active {
    opacity: 1;
    z-index: 1000;
    pointer-events: all; }
  .head_sub ul {
    position: relative;
    border-radius: 20px;
    border: 3px solid #79503A;
    background-color: #fff;
    padding: 5px 20px 20px; }
    .head_sub ul:before {
      position: absolute;
      content: "";
      width: 0;
      height: 0;
      border-style: solid;
      border-right: 7px solid transparent;
      border-left: 7px solid transparent;
      border-bottom: 10px solid #79503A;
      border-top: 0;
      top: -10px;
      left: 50%;
      -webkit-transform: translate(-50%, 0%);
      /* Safari用 */
      transform: translate(-50%, 0%); }
  .head_sub li {
    text-align: center; }
  .head_sub a {
    display: block;
    padding: 10px;
    color: #79503A;
    border-bottom: dashed 1px #79503A; }

.head_sns {
  padding: 10px 0 0 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  align-items: center;
  width: 15%;
  max-width: 170px; }
  .head_sns .sns_icon {
    display: block;
    width: 27px;
    transition: .3s;
    height: 30px;
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
    position: relative; }
    .head_sns .sns_icon.instagram {
      background: url("../images/common/icon_instagram.svg") center center no-repeat; }
    .head_sns .sns_icon.youtube {
      background: url("../images/common/icon_youtube.svg") center center no-repeat;
      width: 30px; }
    .head_sns .sns_icon.facebook {
      background: url("../images/common/icon_facebook.svg") center center no-repeat; }

@media (hover: hover) {
  .head_nav a:hover,
  .head_nav span:hover {
    cursor: pointer;
    color: #FFA200; }

  .head_sns .sns_icon:hover {
    top: -5px;
    opacity: 0.8; } }
@media (max-width: 1366px) {
  .head_nav {
    margin: 0 0 0 auto;
    width: 95%; }

  .head_sns {
    display: none; } }
/*max-width:1280px*/
@media (max-width: 1280px) {
  .head_menu {
    width: calc(100% - 265px);
    padding: 0 110px 0 0;
    max-width: 850px; }

  .head_nav {
    width: 100%; }
    .head_nav a {
      text-decoration: none;
      text-align: center;
      font: 1.5rem/1em "Zen Kaku Gothic New", "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 700;
      letter-spacing: 0.02em;
      color: #4D2F1F; }
    .head_nav small {
      display: block;
      font: 0.9rem/1em "Zen Kaku Gothic New", "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 700;
      color: #FFA200;
      letter-spacing: 0.04em;
      margin: 0 0 15px; } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  .head_menu {
    display: none; } }
/*max-width:1024px*/
/*max-width:768px*/
/*max-width:480px*/
/*****************************************/
.toggle {
  display: block;
  position: fixed;
  width: 70px;
  height: 70px;
  background-color: #fff;
  border: 2px solid #FFA200;
  border-radius: 50%;
  z-index: 88888;
  top: 40px;
  right: 30px;
  transition: .3s; }
  .toggle.fixed {
    top: 13px; }
  .toggle p {
    color: #4D2F1F;
    font: 1.3rem/1em "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
    font-weight: 500;
    text-align: center;
    position: absolute;
    top: 65%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    /* Safari用 */
    transform: translate(-50%, -50%); }
  .toggle span {
    position: absolute;
    transition: .3s;
    display: block;
    width: 25px;
    height: 2px;
    background-color: #FFA200; }
    .toggle span:nth-of-type(1) {
      top: 35%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
      /* Safari用 */
      transform: translate(-50%, -50%); }
    .toggle span:nth-of-type(2) {
      top: 45%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
      /* Safari用 */
      transform: translate(-50%, -50%); }
  .toggle.active span {
    position: absolute;
    transition: .3s;
    display: block;
    width: 25px;
    height: 2px;
    background-color: #FFA200; }
    .toggle.active span:nth-of-type(1) {
      top: 40%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%) rotate(35deg);
      /* Safari用 */
      transform: translate(-50%, -50%) rotate(35deg); }
    .toggle.active span:nth-of-type(2) {
      top: 40%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%) rotate(-35deg);
      /* Safari用 */
      transform: translate(-50%, -50%) rotate(-35deg); }

@media (hover: hover) {
  .toggle:hover {
    cursor: pointer; }
    .toggle:hover span:nth-of-type(1) {
      top: 38%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%) rotate(20deg);
      /* Safari用 */
      transform: translate(-50%, -50%) rotate(20deg); }
    .toggle:hover span:nth-of-type(2) {
      top: 42%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%) rotate(-20deg);
      /* Safari用 */
      transform: translate(-50%, -50%) rotate(-20deg); }
    .toggle:hover.active:hover span:nth-of-type(1) {
      top: 40%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%) rotate(35deg);
      /* Safari用 */
      transform: translate(-50%, -50%) rotate(35deg); }
    .toggle:hover.active:hover span:nth-of-type(2) {
      top: 40%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%) rotate(-35deg);
      /* Safari用 */
      transform: translate(-50%, -50%) rotate(-35deg); } }
@media (max-width: 1280px) {
  .toggle {
    right: 20px; } }
/*max-width:480px*/
@media (max-width: 1024px) {
  .toggle {
    top: 13px; } }
/*max-width:480px*/
/*max-width:480px*/
@media (max-width: 480px) {
  .toggle {
    top: 5px;
    right: 15px;
    transform: scale(0.85);
    transform-origin: center right; }
    .toggle.fixed {
      top: 5px; } }
/*max-width:480px*/
/*****************************************/
nav {
  transition: .3s;
  opacity: 0;
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: -1;
  background-color: inherit;
  pointer-events: none;
  opacity: 0; }
  nav.active {
    opacity: 1;
    background-color: rgba(255, 255, 255, 0.95);
    pointer-events: all;
    z-index: 77777; }

.gnav {
  padding: 65px 0 100%; }
  .gnav .jii {
    background: url("../images/mv_chara.svg") center center no-repeat;
    background-size: contain;
    display: block;
    margin: 0 auto 65px;
    aspect-ratio: 121/154;
    width: 100%;
    max-width: 121px;
    height: auto; }

.nav_box {
  width: calc(100% - 100px);
  margin: 0 auto;
  max-width: 630px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  align-items: flex-start; }
  .nav_box a, .nav_box span {
    padding: 0 0 0 16px;
    display: block;
    position: relative;
    font: 1.5rem/1em "Zen Kaku Gothic New", "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
    font-weight: 500;
    margin: 0 0 18px;
    text-decoration: none;
    color: #79503A; }
    .nav_box a:before, .nav_box span:before {
      position: absolute;
      content: "";
      display: block;
      border-radius: 50%;
      background-color: #79503A;
      width: 7px;
      height: 7px;
      left: 3px;
      top: 5px; }
  .nav_box li {
    margin: 0 0 30px;
    position: relative;
    padding: 0 0 0 20px; }
    .nav_box li a.no,
    .nav_box li span {
      font: 1.6rem/1em "Zen Kaku Gothic New", "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 700;
      padding: 0; }
      .nav_box li a.no:before,
      .nav_box li span:before {
        display: none; }
    .nav_box li:before {
      position: absolute;
      content: "";
      display: block;
      border-radius: 50%;
      background-color: #FFA200;
      width: 10px;
      height: 10px;
      left: 0;
      top: 5px; }

/*max-width:1280px*/
/*max-width:1024px*/
@media (max-width: 768px) {
  .gnav {
    height: 100%;
    overflow-y: scroll;
    height: 100vh;
    padding: 30px 40px 50%; }
    .gnav .jii {
      margin: 0 auto 20px;
      max-width: 80px; }

  .nav_box {
    width: 100%;
    margin: 0 auto;
    max-width: 480px;
    display: block; }
    .nav_box a {
      margin: 0;
      padding: 10px 0 10px 16px;
      display: block;
      position: relative;
      font: 1.5rem/1em "Zen Kaku Gothic New", "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 500;
      text-decoration: none; }
      .nav_box a:before {
        display: none; }
    .nav_box li {
      margin: 0;
      position: relative;
      padding: 10px 0 10px;
      border-bottom: 1px solid #ccc; }
      .nav_box li a.no,
      .nav_box li span {
        font: 1.6rem/1em "Zen Kaku Gothic New", "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
        font-weight: 700;
        padding: 10px 0 10px 20px;
        margin: 0; }
      .nav_box li:before {
        position: absolute;
        content: "";
        display: block;
        border-radius: 50%;
        background-color: #FFA200;
        width: 10px;
        height: 10px;
        left: 0;
        top: 23px; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .gnav {
    height: 100%;
    overflow-y: scroll;
    height: 100vh;
    padding: 30px 20px 50%; }
    .gnav .jii {
      margin: 0 auto 20px;
      max-width: 80px; } }
/*max-width:480px*/
/*****************************************/
aside {
  position: fixed;
  top: 20%;
  right: 0;
  z-index: 9998;
  height: calc(100% - 20%);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center; }
  aside .aside_menu {
    max-height: 520px;
    height: calc(100% - 80px); }
  aside a {
    text-decoration: none;
    max-height: 250px;
    height: calc((100% - 20px)/2);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    width: 80px;
    border-radius: 15px 0 0 15px;
    transition: .3s; }
    aside a p {
      transition: .3s;
      writing-mode: vertical-rl;
      text-align: center;
      width: 100%;
      flex: 1;
      display: flex;
      justify-content: center;
      align-items: center;
      color: #fff;
      font: 1.8rem/1em "Zen Kaku Gothic New", "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 700;
      letter-spacing: 0.05em;
      padding: 0 0 30px;
      position: relative; }
      aside a p:before {
        transition: .3s;
        position: absolute;
        content: "";
        display: block; }
    aside a span {
      transition: .3s;
      writing-mode: horizontal-tb;
      font: 1.6rem/1.3em "Zen Kaku Gothic New", "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 700;
      padding: 10px 0 0 2px;
      letter-spacing: 0.04em;
      border-radius: 0 0 0 12px;
      height: 65px;
      width: 100%;
      display: block;
      background-color: #fff;
      text-align: center; }
  aside .side_about {
    margin: 0 0 20px;
    background-color: #FFA200;
    border: 3px solid #FFA200; }
    aside .side_about span {
      color: #FFA200; }
    aside .side_about p:before {
      background: url("../images/common/side_about.svg") center bottom no-repeat;
      background-size: contain;
      aspect-ratio: 35/27;
      width: 100%;
      max-width: 35px;
      height: auto;
      top: auto;
      bottom: 10px;
      left: 56%;
      -webkit-transform: translate(-50%, 0%);
      /* Safari用 */
      transform: translate(-50%, 0%); }
  aside .side_contact {
    background-color: #FF6600;
    border: 3px solid #FF6600; }
    aside .side_contact span {
      color: #FF6600; }
    aside .side_contact p {
      padding-bottom: 35px; }
      aside .side_contact p:before {
        background: url("../images/common/side_contact.svg") center bottom no-repeat;
        background-size: contain;
        aspect-ratio: 27/36;
        width: 100%;
        max-width: 27px;
        height: auto;
        top: auto;
        bottom: 10px;
        left: 56%;
        -webkit-transform: translate(-50%, 0%);
        /* Safari用 */
        transform: translate(-50%, 0%); }

@media (hover: hover) {
  aside .side_about:hover {
    background-color: #fff;
    color: #FFA200; }
    aside .side_about:hover span {
      background-color: #FFA200;
      color: #fff; }
    aside .side_about:hover p {
      color: #FFA200; }
      aside .side_about:hover p:before {
        background: url("../images/common/side_about_hover.svg") center bottom no-repeat;
        background-size: contain; }
  aside .side_contact:hover {
    background-color: #ffffff;
    color: #FF6600; }
    aside .side_contact:hover span {
      background-color: #FF6600;
      color: #ffffff; }
    aside .side_contact:hover p {
      color: #FF6600; }
      aside .side_contact:hover p:before {
        background: url("../images/common/side_contact_hover.svg") center bottom no-repeat;
        background-size: contain; } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  aside {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    height: auto;
    position: fixed;
    top: auto;
    right: auto;
    left: 0;
    bottom: -100px;
    z-index: 9998;
    width: 100%;
    padding: 0 15px;
    transition: .3s; }
    aside .aside_menu {
      max-height: auto;
      height: auto;
      display: flex;
      flex-direction: row;
      justify-content: space-between;
      align-items: center;
      width: calc(100% - 90px); }
    aside.active {
      bottom: 20px; }
    aside a {
      text-decoration: none;
      height: 70px;
      width: calc(100% / 2);
      max-width: 480px;
      border-radius: 50px;
      transition: .3s;
      padding: 0 0 2px; }
      aside a p {
        transition: .3s;
        width: fit-content;
        writing-mode: horizontal-tb;
        text-align: center;
        flex: 1;
        display: flex;
        justify-content: center;
        align-items: center; }
      aside a span {
        display: none; }
    aside .side_about {
      margin: 0 20px 0 0; }
      aside .side_about p {
        padding: 0 45px 0 0; }
        aside .side_about p:before {
          top: 50%;
          bottom: auto;
          left: auto;
          right: 0;
          -webkit-transform: translate(0%, -50%);
          /* Safari用 */
          transform: translate(0, -50%); }
    aside .side_contact p {
      padding: 0 40px 0 0; }
      aside .side_contact p:before {
        top: 45%;
        bottom: auto;
        left: auto;
        right: 0;
        -webkit-transform: translate(0%, -50%);
        /* Safari用 */
        transform: translate(0, -50%); } }
/*max-width:1024px*/
@media (max-width: 768px) {
  aside .aside_menu {
    width: calc(100% - 80px); }
  aside.active {
    bottom: 20px; }
  aside a {
    width: calc((100% - 10px) / 2); }
    aside a p {
      font-size: 1.7rem; }
    aside a span {
      display: none; }
  aside .side_about {
    margin: 0 0 0 0; }
    aside .side_about p {
      padding: 0 40px 0 0; }
      aside .side_about p:before {
        top: 50%;
        bottom: auto;
        left: auto;
        right: 0;
        -webkit-transform: translate(0%, -50%);
        /* Safari用 */
        transform: translate(0, -50%); }
  aside .side_contact p {
    padding: 0 35px 0 0; }
    aside .side_contact p:before {
      top: 45%;
      bottom: auto;
      left: auto;
      right: 0;
      -webkit-transform: translate(0%, -50%);
      /* Safari用 */
      transform: translate(0, -50%); } }
/*max-width:768px*/
@media (max-width: 480px) {
  aside .aside_menu {
    width: calc(100% - 60px); }
  aside.active {
    bottom: 10px; }
  aside a {
    height: 50px; }
    aside a p {
      font-size: 1.5rem; }
    aside a span {
      display: none; }
  aside .side_about,
  aside .side_contact {
    margin: 0 0 0 0; }
    aside .side_about p,
    aside .side_contact p {
      padding: 0; }
      aside .side_about p:before,
      aside .side_contact p:before {
        display: none; } }
/*max-width:480px*/
/*****************************************/
.page_top {
  width: 80px;
  height: 80px;
  display: block;
  margin: 0 0 10px;
  background-color: #ffffff;
  border: 3px solid #EA7A60;
  border-radius: 15px 0 0 15px;
  z-index: 7777;
  transition: .3s;
  position: relative;
  opacity: 0;
  pointer-events: none; }
  .page_top.active {
    opacity: 1;
    pointer-events: all; }
  .page_top p {
    text-align: center;
    color: #EA7A60;
    font: 1.8rem/95px "Zen Kaku Gothic New", "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
    font-weight: 700;
    position: relative; }
    .page_top p:before {
      transition: .3s;
      position: absolute;
      content: "";
      width: 12px;
      height: 12px;
      border-top: 4px solid #EA7A60;
      border-right: 4px solid #EA7A60;
      top: 30%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%) rotate(-45deg);
      transform: translate(-50%, -50%) rotate(-45deg); }

@media (max-width: 1024px) {
  .page_top {
    width: 70px;
    height: 70px;
    display: block;
    margin: 0;
    border-radius: 50%;
    opacity: 1;
    pointer-events: all; }
    .page_top p {
      font: 1.6rem/85px "Zen Kaku Gothic New", "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 700; } }
/*max-width:1024px*/
/*max-width:768px*/
@media (max-width: 480px) {
  .page_top {
    width: 50px;
    height: 50px;
    border: 2px solid #EA7A60; }
    .page_top p {
      font: 1.4rem/55px "Zen Kaku Gothic New", "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 700; }
      .page_top p:before {
        width: 8px;
        height: 8px;
        border-top: 2px solid #EA7A60;
        border-right: 2px solid #EA7A60;
        top: 30%;
        left: 50%; } }
/*max-width:480px*/
@media (hover: hover) {
  .page_top:hover {
    cursor: pointer; }
    .page_top:hover p:before {
      top: 25%; } }
/*****************************************/
footer {
  background-color: #79503A;
  padding: 95px 0 0; }

.footer_box {
  max-width: 1280px;
  width: calc(100% - 200px);
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  align-items: flex-start;
  color: #fff; }
  .footer_box a {
    color: #fff;
    text-decoration: none; }

.footer_left {
  width: 260px;
  padding: 0 0 235px;
  position: relative; }
  .footer_left .footer_yumeji {
    position: absolute;
    display: block;
    aspect-ratio: 145/177;
    width: 100%;
    max-width: 145px;
    height: auto;
    left: 30px;
    bottom: 0; }
  .footer_left .logo {
    display: block;
    margin: 0 0 20px;
    width: fit-content; }
    .footer_left .logo small {
      text-align: center;
      padding: 0 0 10px 30px;
      font: 1.3rem/1em " M PLUS Rounded 1c", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 700;
      display: block; }
    .footer_left .logo span {
      overflow: hidden;
      text-indent: 100%;
      white-space: nowrap;
      display: block;
      background: url("../images/logo02.svg") center center no-repeat;
      width: 194px;
      height: 42px; }
  .footer_left .tel {
    letter-spacing: 0.03em;
    font: 2.2rem/1em "Urbanist", Arial, Helvetica, "sans-serif";
    font-weight: 500; }
  .footer_left .add {
    font: 1.5rem/1.8em "Zen Kaku Gothic New", "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
    font-weight: 400;
    margin: 0 0 10px; }
  .footer_left .gmap {
    height: 20px;
    font: 1.6rem/16px "Urbanist", Arial, Helvetica, "sans-serif";
    font-weight: 500;
    position: relative;
    padding: 0 25px 0 0;
    display: block;
    width: fit-content;
    letter-spacing: 0.03em;
    background: url("../images/index/icon.svg") top 3px right no-repeat;
    background-size: 16px; }

.footer_right {
  width: calc(100% - 300px);
  max-width: 630px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  align-items: flex-start; }
  .footer_right a, .footer_right span {
    display: block;
    position: relative;
    font: 1.5rem/1em "Zen Kaku Gothic New", "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
    font-weight: 500;
    margin: 0 0 18px; }
  .footer_right li {
    margin: 0 0 30px;
    position: relative;
    padding: 0 0 0 20px; }
    .footer_right li:after {
      position: absolute;
      content: "";
      display: block;
      border-radius: 50%;
      background-color: #FFA200;
      width: 10px;
      height: 10px;
      left: 0;
      top: 5px; }
    .footer_right li a.dot {
      position: relative;
      padding: 0 0 0 16px; }
      .footer_right li a.dot:before {
        position: absolute;
        content: "";
        display: block;
        border-radius: 50%;
        background-color: #fff;
        width: 7px;
        height: 7px;
        left: 3px;
        top: 5px; }

@media (max-width: 1024px) {
  .footer_box {
    max-width: 1280px;
    width: calc(100% - 80px);
    flex-direction: column;
    padding: 0 0 20px; }

  .footer_left {
    order: 2;
    width: 450px;
    padding: 0 175px 100px 0;
    margin: 0 auto;
    position: relative; }
    .footer_left .footer_yumeji {
      left: auto;
      right: 0;
      bottom: 100px; }

  .footer_right {
    order: 1;
    width: 100%;
    margin: 0 auto 50px;
    max-width: 630px; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .footer_box {
    max-width: 1280px;
    width: calc(100% - 80px);
    flex-direction: column; }

  .footer_left {
    order: 2;
    width: 100%;
    max-width: 480px;
    padding: 0 0 100px 0;
    margin: 0 auto;
    position: relative; }
    .footer_left .footer_yumeji {
      max-width: 125px;
      left: auto;
      right: 0;
      bottom: 100px; }

  .footer_right {
    display: none; } }
/*max-width:768px*/
@media (max-width: 480px) {
  footer {
    padding: 50px 0 0 0; }

  .footer_box {
    max-width: 1280px;
    width: calc(100% - 50px);
    flex-direction: column;
    padding: 0; }

  .footer_left {
    width: fit-content;
    margin: 0 auto;
    padding: 150px 0 100px; }
    .footer_left .logo {
      display: block;
      margin: 0 auto 20px;
      width: fit-content;
      padding: 0 20px 0 0; }
    .footer_left .footer_yumeji {
      max-width: 105px;
      top: 0%;
      left: 50%;
      -webkit-transform: translate(-50%, 0%);
      /* Safari用 */
      transform: translate(-50%, 0%);
      right: auto;
      bottom: auto; } }
/*max-width:480px*/
@media (hover: hover) {
  .footer_left .gmap:hover {
    text-decoration: underline wavy;
    text-underline-offset: 3px; }

  .footer_right a:hover {
    text-decoration: underline wavy;
    text-underline-offset: 3px; } }
/*****************************************/
.main_content {
  width: calc(100% - 200px);
  margin: 0 auto;
  max-width: 1280px;
  padding: 150px 0 230px; }
  .main_content h2 {
    color: #79503A;
    font: 4rem/1em "tsunagi", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
    letter-spacing: 0.06em;
    margin: 0 auto 180px;
    position: relative; }
    .main_content h2 small {
      font: 1.5rem/1em "Zen Kaku Gothic New", "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 700;
      position: absolute;
      top: -30px;
      left: 8px; }
    .main_content h2 > span {
      margin: 0;
      position: relative;
      width: fit-content;
      display: -webkit-box;
      display: -ms-flexbox;
      display: -webkit-flex;
      display: flex;
      flex-direction: row;
      flex-wrap: wrap;
      -webkit-box-pack: justify;
      -ms-flex-pack: justify;
      -webkit-justify-content: flex-start;
      justify-content: flex-start;
      align-items: center; }
      .main_content h2 > span:before {
        position: absolute;
        content: "";
        display: block;
        background: url("../images/common/dot.svg") center center no-repeat;
        background-size: contain;
        aspect-ratio: 85/10;
        width: 100%;
        max-width: 85px;
        height: auto;
        top: 55%;
        left: auto;
        right: -120px;
        -webkit-transform: translate(0%, -50%);
        /* Safari用 */
        transform: translate(0%, -50%); }
      .main_content h2 > span span {
        padding: 0 15px 0 0;
        font: 2.6rem/1em "tsunagi", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
        letter-spacing: 0.06em; }

/*max-width:1280px*/
@media (max-width: 1024px) {
  .main_content {
    width: calc(100% - 80px); } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .main_content {
    padding: 100px 0 150px; }
    .main_content h2 {
      margin: 0 auto 65px; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .main_content {
    padding: 100px 0 150px;
    width: calc(100% - 40px); }
    .main_content h2 {
      color: #79503A;
      font: 3rem/1em "tsunagi", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      letter-spacing: 0.06em;
      margin: 0 auto 55px; }
      .main_content h2 small {
        font: 1.4rem/1em "Zen Kaku Gothic New", "Noto Sans JP", YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
        font-weight: 700;
        top: -30px;
        left: 2px; }
      .main_content h2 > span:before {
        max-width: 65px;
        top: 55%;
        right: -85px; } }
/*max-width:480px*/
