@charset "UTF-8";
.anchor {
  display: block;
  padding: 150px 0 0;
  margin: -150px 0 0;
  position: relative;
  z-index: -999;
  pointer-events: none; }

.anchor02 {
  display: block;
  margin: -100px 0 0;
  padding: 100px 0 0;
  position: relative;
  z-index: -999;
  pointer-events: none; }

/****************************************/
header {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 999;
  width: 100%;
  height: 100px;
  transition: .5s; }
  header.active {
    position: fixed;
    background-color: #fff; }
    header.active .header_box h1 {
      pointer-events: auto;
      opacity: 1; }

/*max-width:1280px*/
@media (max-width: 1024px) {
  header {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 999;
    width: 100%;
    height: 75px;
    transition: .5s; }
    header .header_box h1 {
      pointer-events: auto;
      opacity: 1; } }
/*max-width:1024px*/
/*max-width:768px*/
/*max-width:480px*/
/****************************************/
.header_box {
  max-width: 1920px;
  height: 100%;
  width: 100%;
  padding: 0 60px 0 30px;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center; }
  .header_box h1 {
    transition: .5s;
    letter-spacing: 0.01em;
    font: 2.2rem/1em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
    font-weight: 300; }
    .header_box h1 small {
      font: 1.4rem/1em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 300;
      display: block;
      letter-spacing: 0.06em;
      margin: 0 0 8px; }
    .header_box h1 span {
      color: #DF816E; }
    .header_box h1 a {
      color: #727171;
      width: 350px;
      padding: 0 0 0 125px;
      text-decoration: none;
      position: relative;
      display: block;
      height: fit-content; }
      .header_box h1 a:before {
        position: absolute;
        content: "";
        display: block;
        background: url("../images/h1.svg") center center no-repeat;
        background-size: contain;
        aspect-ratio: 113/41;
        width: 100%;
        max-width: 113px;
        height: auto;
        top: 50%;
        left: 0%;
        -webkit-transform: translate(0%, -50%);
        /* Safari用 */
        transform: translate(0%, -50%); }

nav {
  width: calc(100% - 400px);
  max-width: 980px;
  margin: 0 0 0 auto; }
  nav .gnav {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    width: 100%; }
    nav .gnav a {
      font: 1.6rem/1em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 700;
      color: #DF816E;
      text-decoration: none; }
    nav .gnav li.sp {
      display: none; }
  nav .sns,
  nav .dog {
    display: none; }

@media (max-width: 1280px) {
  .header_box {
    padding: 0 30px; }

  nav {
    width: calc(100% - 380px);
    max-width: 980px; } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  .header_box {
    padding: 0 20px 0 30px; }

  nav {
    width: 100%;
    max-width: 480px;
    position: fixed;
    margin: 0;
    left: auto;
    right: -100%;
    top: 0;
    background-color: #DF816E;
    height: 100vh;
    transition: .3s; }
    nav.active {
      right: 0; }
    nav .nav_box {
      height: 100%;
      overflow-y: scroll;
      scrollbar-color: #fff #DF816E;
      scrollbar-width: thin; }
    nav .gnav {
      padding: 150px 0 0;
      width: 100%;
      max-width: 310px;
      margin: 0 auto 10px; }
      nav .gnav a {
        color: #fff;
        font: 1.8rem/1em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
        font-weight: 700;
        text-decoration: none;
        padding: 10px 0; }
      nav .gnav li {
        padding: 0 0 40px 0;
        width: calc(100% / 2); }
        nav .gnav li:nth-of-type(2n) {
          padding-left: 35px; }
        nav .gnav li.sp {
          display: block; }
    nav .sns {
      display: flex;
      flex-direction: row;
      flex-wrap: wrap;
      justify-content: center;
      align-items: center;
      width: 230px;
      margin: 0 auto 100px; }
    nav .dog {
      display: block;
      text-align: center; }
      nav .dog a {
        display: block;
        border-radius: 50%;
        width: 75px;
        height: 75px;
        text-align: center;
        color: #DF816E;
        text-decoration: none;
        background-color: #fff;
        margin: 0 auto 25px;
        font: 2rem/80px "Poppins", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
        font-weight: 700; }
      nav .dog img {
        display: block;
        margin: 0 auto;
        width: 126px; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .header_box {
    padding: 0 15px; }
    .header_box h1 a {
      width: 230px;
      padding: 0; }
      .header_box h1 a:before {
        display: none; } }
/*max-width:768px*/
/*max-width:480px*/
/****************************************/
.toggle {
  display: none; }

@media (max-width: 1024px) {
  .toggle {
    display: block;
    position: relative;
    z-index: 9999;
    display: block;
    background-color: #DF816E;
    width: 55px;
    height: 55px;
    border-radius: 50%;
    transition: .3s; }
    .toggle span {
      display: block;
      width: 28px;
      height: 3px;
      position: absolute;
      background-color: #fff;
      left: 50%;
      transition: .3s; }
      .toggle span:nth-of-type(1) {
        top: 35%;
        transform: translate(-50%, -50%); }
      .toggle span:nth-of-type(2) {
        top: 50%;
        transform: translate(-50%, -50%); }
      .toggle span:nth-of-type(3) {
        top: 65%;
        transform: translate(-50%, -50%); }
    .toggle.active {
      background-color: #fff; }
      .toggle.active span {
        background-color: #DF816E;
        left: 50%; }
        .toggle.active span:nth-of-type(1) {
          top: 50%;
          transform: translate(-50%, -50%) rotate(45deg); }
        .toggle.active span:nth-of-type(2) {
          opacity: 0; }
        .toggle.active span:nth-of-type(3) {
          top: 50%;
          transform: translate(-50%, -50%) rotate(-45deg); } }
/*max-width:1024px*/
/****************************************/
.contact {
  width: calc(100% - 120px);
  max-width: 1800px;
  margin: 0 auto;
  background-color: #EFEFEF;
  text-align: center;
  padding: 65px 40px 140px; }
  .contact h1 {
    font: 4.3rem/1em "Poppins", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
    font-weight: 500;
    padding: 0 0 0 0.15em;
    letter-spacing: 0.15em;
    color: #DF816E;
    margin: 0 0 15px; }
  .contact > p {
    font: 2rem/1.8em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
    font-weight: 500;
    letter-spacing: 0.05em;
    margin: 0 0 40px; }
    .contact > p br {
      display: none; }
  .contact > div {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: stretch;
    max-width: 1000px;
    margin: 0 auto; }
  .contact a {
    transition: .3s;
    min-height: 110px;
    text-decoration: none;
    color: #fff;
    width: 50%;
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center; }
    .contact a.mail {
      background-color: #DF816E; }
      .contact a.mail span {
        letter-spacing: 0.05em;
        font: 2rem/1em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
        font-weight: 700;
        position: relative;
        padding: 0 0 0 50px; }
        .contact a.mail span:before {
          position: absolute;
          content: "";
          display: block;
          background: url("../images/contact_mail.svg") center left no-repeat;
          background-size: contain;
          width: 38px;
          height: 28px;
          top: 50%;
          left: 0%;
          -webkit-transform: translate(0%, -50%);
          /* Safari用 */
          transform: translate(0%, -50%); }
    .contact a.tel {
      font: 1.4rem/1em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 400;
      letter-spacing: 0.05em;
      background-color: #89655A; }
      .contact a.tel span {
        margin: 0 0 5px;
        font: 3.3rem/1em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
        font-weight: 700;
        letter-spacing: 0.11em;
        display: block;
        position: relative;
        padding: 0 0 0 35px; }
        .contact a.tel span:before {
          position: absolute;
          content: "";
          display: block;
          background: url("../images/contact_tel.svg") center left no-repeat;
          width: 22px;
          height: 24px;
          top: 50%;
          left: 0%;
          -webkit-transform: translate(0%, -50%);
          /* Safari用 */
          transform: translate(0%, -50%); }

@media (max-width: 1280px) {
  .contact {
    width: calc(100% - 80px); } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  .contact {
    padding: 65px 40px 85px; }
    .contact > div {
      display: block;
      max-width: 1000px;
      margin: 0 auto; }
    .contact a {
      transition: .3s;
      min-height: 110px;
      text-decoration: none;
      color: #fff;
      max-width: 640px;
      width: 100%;
      margin: 0 auto; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .contact {
    width: calc(100% - 40px);
    padding: 45px 40px 65px; }
    .contact > p {
      font: 2rem/1.8em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 500;
      letter-spacing: 0.05em;
      margin: 0 0 30px; }
      .contact > p br {
        display: block; }
    .contact > div {
      display: block;
      max-width: 1000px;
      margin: 0 auto; }
    .contact a {
      transition: .3s;
      min-height: 110px;
      text-decoration: none;
      color: #fff;
      max-width: 640px;
      width: 100%;
      margin: 0 auto; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .contact {
    margin: 0 auto;
    padding: 45px 15px 60px; }
    .contact a {
      transition: .3s;
      min-height: 100px; }
      .contact a.mail span {
        font: 1.8rem/1em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
        font-weight: 700;
        padding: 0 0 0 45px; }
        .contact a.mail span:before {
          width: 35px;
          height: 28px; }
      .contact a.tel span {
        font: 3rem/1em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
        font-weight: 700;
        padding: 0 0 0 30px; }
    .contact h1 {
      font: 3rem/1em "Poppins", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 500;
      padding: 0 0 0 0.15em;
      letter-spacing: 0.15em;
      color: #DF816E;
      margin: 0 0 15px; }
    .contact > p {
      font: 1.8rem/1.8em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 500;
      letter-spacing: 0.05em;
      margin: 0 0 20px; } }
/*max-width:480px*/
@media (hover: hover) {
  .contact a:hover {
    opacity: 0.5; } }
/****************************************/
aside {
  position: fixed;
  top: 111px;
  right: 15px;
  z-index: 888; }
  aside .side_line {
    display: block;
    width: 107px;
    height: 107px;
    border-radius: 50%;
    background: url("../images/line.svg") center center no-repeat #46A342;
    background-size: contain;
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
    transition: .3s;
    margin: 0 0 10px; }
  aside .side_contact {
    text-decoration: none;
    text-align: center;
    padding: 48px 0 0;
    display: block;
    width: 107px;
    height: 107px;
    border-radius: 50%;
    background: url("../images/mail.svg") center top 16px no-repeat #DF816E;
    background-size: 30px auto;
    transition: .3s;
    color: #fff;
    font: 1.6rem/1.3em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
    font-weight: 500; }

@media (max-width: 768px) {
  aside {
    top: auto;
    bottom: 20px; }
    aside .side_line {
      width: 55px;
      height: 55px;
      background: url("../images/line_w.svg") center center no-repeat #46A342;
      background-size: 30px auto; }
    aside .side_contact {
      width: 55px;
      height: 55px;
      border-radius: 50%;
      background: url("../images/mail.svg") center top 16px no-repeat #DF816E;
      background-size: 30px auto;
      transition: .3s;
      overflow: hidden;
      text-indent: 100%;
      white-space: nowrap; }
      aside .side_contact br {
        display: none; } }
/*max-width:480px*/
/*max-width:480px*/
@media (hover: hover) {
  aside a:hover {
    opacity: 0.5; } }
/****************************************/
footer {
  padding: 50px 0 0 0; }

.footer_box {
  max-width: 1800px;
  margin: 0 auto 50px;
  width: calc(100% - 120px);
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between; }

.f_left {
  max-width: 400px;
  width: 100%;
  padding: 0 0 0 135px;
  position: relative; }
  .f_left:before {
    position: absolute;
    content: "";
    display: block;
    background: url(../images/h1.svg) center center no-repeat;
    background-size: contain;
    aspect-ratio: 113 / 41;
    width: 100%;
    max-width: 113px;
    height: auto;
    top: 0%;
    left: 0%; }
  .f_left .namae {
    transition: .5s;
    letter-spacing: 0.01em;
    font: 2.2rem/1em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
    font-weight: 300;
    margin: 0 0 20px; }
    .f_left .namae small {
      font: 1.4rem/1em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 300;
      display: block;
      letter-spacing: 0.06em;
      margin: 0 0 8px; }
    .f_left .namae span {
      color: #DF816E; }
  .f_left .address {
    width: 100%;
    max-width: 270px;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start; }
  .f_left address {
    font: 1.6rem/2.2em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
    font-weight: 500;
    letter-spacing: 0.1em;
    margin: 0 0 20px; }
    .f_left address a {
      transition: .3s;
      text-decoration: none;
      width: fit-content; }
  .f_left ul {
    margin: 10px 0 0; }

.f_img {
  background: url("../images/footer_img.png") center center no-repeat;
  background-size: contain;
  aspect-ratio: 478/364;
  width: 480px;
  max-width: 100%;
  height: auto;
  display: block; }

.f_right {
  padding: 20px 0 0 0;
  max-width: 420px;
  width: 100%;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start; }
  .f_right li {
    position: relative;
    margin-bottom: 30px; }
    .f_right li a {
      transition: .3s;
      display: inline-block;
      position: relative;
      font: 1.6rem/1em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 400;
      text-decoration: none;
      padding: 0 0 0 15px; }
      .f_right li a:before {
        position: absolute;
        content: "";
        display: block;
        border-radius: 50px;
        width: 7px;
        height: 7px;
        background-color: #D76B5A;
        left: 0;
        top: 7px; }

@media (max-width: 1480px) {
  .f_left {
    max-width: 360px; }
    .f_left .address {
      width: 100%; }

  .f_img {
    width: 340px; }

  .f_right {
    max-width: 390px; } }
/*max-width:1480px*/
@media (max-width: 1280px) {
  .footer_box {
    max-width: 840px;
    margin: 0 auto 80px; }

  .f_left {
    order: 2;
    max-width: 400px;
    width: 50%; }

  .f_img {
    order: 3;
    max-width: 380px;
    width: 50%; }

  .f_right {
    margin: 0 auto 50px;
    order: 1;
    width: 100%;
    padding: 0;
    max-width: 590px; } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  .footer_box {
    max-width: 768px;
    width: calc(100% - 80px);
    margin: 0 auto 80px; }

  .f_left {
    order: 2;
    max-width: 400px;
    width: 50%;
    padding: 55px 0 0; }

  .f_img {
    order: 3;
    max-width: 380px;
    width: 50%; }

  .f_right {
    display: none; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .footer_box {
    display: block;
    max-width: 480px;
    width: 100%;
    margin: 0 auto 50px;
    position: relative;
    padding: 0; }

  .f_left {
    order: 2;
    max-width: 400px;
    width: 100%;
    padding: 0 0 0 135px;
    margin: 0 auto; }

  .f_img {
    order: 3;
    max-width: 380px;
    width: 100%;
    margin: 0 auto; } }
/*max-width:768px*/
@media (max-width: 480px) {
  .footer_box {
    display: block;
    max-width: 480px;
    width: 100%;
    margin: 0 auto 50px;
    position: relative;
    padding: 0 20px; }

  .f_left {
    order: 2;
    max-width: 270px;
    width: 100%;
    padding: 55px 0 0 0;
    margin: 0 auto; }

  .f_img {
    order: 3;
    max-width: 380px;
    width: 100%;
    margin: 0 auto; } }
/*max-width:480px*/
/****************************************/
.page_top {
  display: block;
  width: fit-content;
  margin: 0 auto;
  top: 0;
  position: relative;
  transition: .3s; }
  .page_top p {
    text-align: center;
    font: 1.4rem/1em "Poppins", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
    font-weight: 700;
    margin: 0 0 27px;
    position: relative;
    padding: 28px 0 0 0; }
    .page_top p:before {
      position: absolute;
      content: "";
      display: block;
      background: url("../images/pagetop.svg") center center no-repeat;
      background-size: contain;
      aspect-ratio: 30/17;
      width: 100%;
      max-width: 30px;
      height: auto;
      top: 0%;
      left: 50%;
      transform: translate(-50%, 0%); }

@media (hover: hover) {
  .page_top:hover {
    top: -10px;
    cursor: pointer; } }
/****************************************/
.page_mv {
  background-color: #FEFBF0;
  padding: 270px 0 50px 0;
  position: relative; }
  .page_mv:before {
    position: absolute;
    content: "";
    left: 0;
    top: 0;
    border-radius: 0 50px 50px 0;
    max-width: 800px;
    width: 100%;
    height: calc(95% - 50px);
    background-color: #FFE2C5; }

.page_mv_box {
  max-width: 1920px;
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: flex-start;
  padding: 0 60px;
  position: relative;
  height: fit-content; }

.page_mv_txt {
  position: relative;
  z-index: 10;
  width: 350px;
  padding: 30px 50px 0 0; }
  .page_mv_txt h1 {
    font: 4rem/1.4em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
    font-weight: 500;
    color: #89655A;
    margin: 0 0 30px; }
    .page_mv_txt h1 small {
      font: 2.4rem/1em "Poppins", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 300;
      display: block;
      margin: 10px 0 0; }

.page_mv_pic {
  position: relative;
  z-index: 5;
  max-width: 1300px;
  width: calc(100% - 350px);
  height: auto;
  aspect-ratio: 1300/600;
  margin: 0; }

@media (max-width: 1280px) {
  .page_mv {
    background-color: #FEFBF0;
    padding: 270px 0 50px 0;
    position: relative; }
    .page_mv:before {
      position: absolute;
      content: "";
      left: 0;
      top: 0;
      border-radius: 0 50px 50px 0;
      max-width: 800px;
      width: 100%;
      height: 100%;
      background-color: #FFE2C5; }

  .page_mv_box {
    padding: 0 0 0 60px; } }
/*max-width:1280px*/
@media (max-width: 1024px) {
  .page_mv {
    padding: 75px 0 0 0; }
    .page_mv:before {
      top: 75px;
      height: 80%; }

  .page_mv_box {
    display: block;
    padding: 0; }

  .page_mv_txt {
    padding: 100px 0;
    margin: 0 auto;
    max-width: auto;
    width: fit-content; }
    .page_mv_txt h1 {
      text-align: center; }
      .page_mv_txt h1 br {
        display: none; }
      .page_mv_txt h1 span {
        margin: 0 auto; }

  .page_mv_pic {
    width: calc(100% - 40px);
    margin: 0 0 0 auto; } }
/*max-width:1024px*/
@media (max-width: 768px) {
  .page_mv_txt {
    padding: 100px 0 15px;
    margin: 0 auto;
    max-width: auto;
    width: fit-content; }
    .page_mv_txt h1 {
      text-align: center; }
      .page_mv_txt h1 br {
        display: none; }

  .page_mv_pic {
    width: calc(100% - 20px); } }
/*max-width:768px*/
@media (max-width: 480px) {
  .page_mv {
    padding-bottom: 50px; }
    .page_mv:before {
      height: calc(100% - 75px); }

  .page_mv_txt {
    padding: 70px 0 20px; }
    .page_mv_txt h1 {
      font: 3.2rem/1em "Noto Sans JP", "Yu Gothic medium", "Hiragino Sans", Meiryo, "sans-serif";
      font-weight: 500; }

  .page_mv_pic {
    width: calc(100% - 20px);
    margin: 0 0 0 auto;
    height: auto;
    aspect-ratio: 1300/600;
    max-width: 100%; } }
/*max-width:480px*/
