@charset "UTF-8";
*:where(:not(html, iframe, canvas, img, svg, video, audio):not(svg *, symbol *)) {
  all: unset;
  display: revert;
}

*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

ul, ul li, ol, ol li {
  list-style-type: none;
}

table {
  border-collapse: collapse;
}

em {
  font-style: normal;
}

@font-face {
  font-family: "HankenGrotesk-Regular";
  font-display: swap;
  font-weight: 400;
  font-style: normal;
  src: url("../fonts/HankenGrotesk-Regular.woff2") format("woff2"), url("../fonts/HankenGrotesk-Regular.woff") format("woff"), url("../fonts/HankenGrotesk-Regular.eot") format("eot"), url("../fonts/HankenGrotesk-Regular.ttf") format("truetype");
}
@font-face {
  font-family: "HankenGrotesk-Bold";
  font-display: swap;
  font-weight: 700;
  font-style: normal;
  src: url("../fonts/HankenGrotesk-Bold.woff2") format("woff2"), url("../fonts/HankenGrotesk-Bold.woff") format("woff"), url("../fonts/HankenGrotesk-Bold.eot") format("eot"), url("../fonts/HankenGrotesk-Bold.ttf") format("truetype");
}
@font-face {
  font-family: "ZenKakuGothicNew-Medium";
  font-display: swap;
  font-weight: 500;
  font-style: normal;
  src: url("../fonts/ZenKakuGothicNew-Medium.woff2") format("woff2"), url("../fonts/ZenKakuGothicNew-Medium.woff") format("woff"), url("../fonts/ZenKakuGothicNew-Medium.eot") format("eot"), url("../fonts/ZenKakuGothicNew-Medium.ttf") format("truetype");
}
@font-face {
  font-family: "ZenKakuGothicNew-Bold";
  font-display: swap;
  font-weight: 700;
  font-style: normal;
  src: url("../fonts/ZenKakuGothicNew-Bold.woff2") format("woff2"), url("../fonts/ZenKakuGothicNew-Bold.woff") format("woff"), url("../fonts/ZenKakuGothicNew-Bold.eot") format("eot"), url("../fonts/ZenKakuGothicNew-Bold.ttf") format("truetype");
}
* {
  min-height: 0vw;
}

html {
  overflow-x: hidden;
}
html.is-fixed {
  overflow: hidden;
}

body {
  font-family: "HankenGrotesk-Regular", "ZenKakuGothicNew-Medium", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 16px;
  line-height: 1.8;
  overflow-x: hidden;
  background: #F5F3ED;
  color: #333;
  -webkit-font-smoothing: antialiased;
}
@media screen and (max-width: 768px) {
  body {
    font-size: min(3.7333333333vw, 14px);
    line-height: 2;
  }
}
body.stop {
  overflow: hidden;
}

@media screen and (min-width: 769px) {
  .pc {
    display: block;
  }
  .middle {
    display: none;
  }
  .sp {
    display: none;
  }
}
@media screen and (max-width: 1280px) {
  .middle {
    display: block;
  }
}
@media screen and (max-width: 768px) {
  .pc {
    display: none;
  }
  .sp {
    display: block;
  }
  svg {
    width: 100%;
  }
}
a {
  color: #333;
  text-decoration: none;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
a:hover {
  cursor: pointer;
}

img {
  width: 100%;
  vertical-align: bottom;
}

main {
  padding-top: min(9.0909090909vw, 120px);
}

@media screen and (min-width: 1441px) {
  .inner {
    width: 1440px;
    padding: 0 80px;
  }
}
.inner {
  width: min(100%, 1540px);
  margin: 0 auto;
  padding: 0 min(3.2467532468%, 50px);
}
@media screen and (max-width: 1280px) {
  .inner {
    width: min(100%, 1280px);
    margin: 0 auto;
    padding: 0 min(5%, 60px);
  }
}
@media screen and (max-width: 768px) {
  .inner {
    padding: 0 5.4%;
  }
}

.box_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.flex_wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

body.stop header {
  padding: 0;
}
body.stop .wrap {
  z-index: -1;
  position: relative;
}

@media screen and (max-width: 768px) {
  header {
    padding: 0;
  }
}
header .header_inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 88px;
  padding: 0 60px 0 40px;
}
@media screen and (max-width: 1280px) {
  header .header_inner {
    height: min(5.5vw, 88px);
    padding: 0 min(3.75vw, 60px) 0 min(2.5vw, 40px);
  }
}
@media screen and (max-width: 768px) {
  header .header_inner {
    height: min(17.6vw, 66px);
    padding: 0;
  }
}
header .logo {
  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;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  z-index: 10000;
}
header .logo a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -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-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: min(1.625vw, 26px);
}
header .logo img {
  width: 212px;
  position: relative;
}
@media screen and (max-width: 1280px) {
  header .logo img {
    width: min(13.25vw, 212px);
  }
}
header .logo .name {
  width: 221px;
}
@media screen and (max-width: 1280px) {
  header .logo .name {
    width: min(13.8125vw, 221px);
  }
}
@media screen and (max-width: 768px) {
  header .logo {
    margin-left: min(5.3333333333vw, 20px);
  }
  header .logo img {
    width: min(36.8vw, 138px);
  }
  header .logo .name {
    width: min(35.7333333333vw, 134px);
  }
}
header .box_menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  align-items: center;
  gap: min(0.75vw, 12px);
}
header .box_menu .box_btn {
  width: 204px;
  height: 52px;
}
header .box_menu .box_btn a {
  font-size: 18px;
}
@media screen and (max-width: 1280px) {
  header .box_menu .box_btn {
    width: min(12.75vw, 204px);
    height: min(3.25vw, 52px);
  }
  header .box_menu .box_btn a {
    font-size: min(1.125vw, 18px);
  }
}
@media screen and (max-width: 768px) {
  header .box_menu {
    display: block;
  }
  header .box_menu .box_btn {
    display: none;
  }
}
header .box_menu .menu_trigger {
  width: 95px;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
  position: relative;
  z-index: 1000;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  align-items: center;
  margin-left: min(0.9375vw, 15px);
}
@media screen and (max-width: 1280px) {
  header .box_menu .menu_trigger {
    width: min(5.9375vw, 95px);
  }
}
header .box_menu .menu_trigger:hover {
  cursor: pointer;
}
header .box_menu .menu_trigger:hover::after {
  color: #3F9276;
}
header .box_menu .menu_trigger:hover .box span {
  background: #3F9276;
}
header .box_menu .menu_trigger::after {
  content: "MENU";
  color: #333;
  font-family: "HankenGrotesk-Regular", sans-serif;
  letter-spacing: 0.025em;
  font-weight: 700;
  font-size: 18px;
  line-height: 1;
  text-align: center;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
@media screen and (max-width: 1280px) {
  header .box_menu .menu_trigger::after {
    font-size: min(1.125vw, 18px);
  }
}
@media screen and (max-width: 768px) {
  header .box_menu .menu_trigger {
    width: min(14.9333333333vw, 56px);
    height: min(14.9333333333vw, 56px);
    -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;
    gap: min(1.3333333333vw, 5px);
    margin-left: 0;
    background: #fff;
    border-radius: 0 0 0 8px;
    position: fixed;
    top: 0;
    right: 0;
  }
  header .box_menu .menu_trigger::after {
    font-size: min(2.6666666667vw, 10px);
  }
}
header .box_menu .menu_trigger .box {
  display: block;
  width: 32px;
  height: 18px;
  position: relative;
}
@media screen and (max-width: 1280px) {
  header .box_menu .menu_trigger .box {
    width: min(2vw, 32px);
    height: min(1.125vw, 18px);
  }
}
@media screen and (max-width: 768px) {
  header .box_menu .menu_trigger .box {
    width: min(8.5333333333vw, 32px);
    height: min(4.8vw, 18px);
  }
}
header .box_menu .menu_trigger .box span {
  display: block;
  width: 100%;
  height: 2px;
  background: #333;
  position: absolute;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
header .box_menu .menu_trigger .box span:nth-of-type(1) {
  top: 0;
}
header .box_menu .menu_trigger .box span:nth-child(2) {
  top: 8px;
}
header .box_menu .menu_trigger .box span:nth-child(3) {
  top: 16px;
}
@media screen and (max-width: 1280px) {
  header .box_menu .menu_trigger .box span:nth-child(2) {
    top: min(0.5vw, 8px);
  }
  header .box_menu .menu_trigger .box span:nth-child(3) {
    top: min(1vw, 16px);
  }
}
@media screen and (max-width: 768px) {
  header .box_menu .menu_trigger .box span:nth-child(2) {
    top: min(2.1333333333vw, 8px);
  }
  header .box_menu .menu_trigger .box span:nth-child(3) {
    top: min(4.2666666667vw, 16px);
  }
}
header .box_menu .menu_trigger.open {
  position: absolute;
  right: 0;
  top: 0;
  -webkit-transform: translateY(0%);
          transform: translateY(0%);
  width: min(5.5vw, 88px);
  height: min(5.5vw, 88px);
  background: #EFEBE0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  border-radius: 0 0 0 8px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
header .box_menu .menu_trigger.open::after {
  content: "CLOSE";
  color: #7E634B;
  position: absolute;
  bottom: min(1.25vw, 20px);
}
header .box_menu .menu_trigger.open .box {
  height: min(4.375vw, 70px);
  position: absolute;
}
header .box_menu .menu_trigger.open .box span {
  background: #7E634B;
}
header .box_menu .menu_trigger.open .box span:nth-of-type(1) {
  -webkit-transform: translateY(16px) rotate(-30deg);
          transform: translateY(16px) rotate(-30deg);
}
header .box_menu .menu_trigger.open .box span:nth-of-type(2) {
  opacity: 0;
}
header .box_menu .menu_trigger.open .box span:nth-of-type(3) {
  -webkit-transform: translateY(0) rotate(30deg);
          transform: translateY(0) rotate(30deg);
}
@media screen and (max-width: 1280px) {
  header .box_menu .menu_trigger.open .box span:nth-of-type(1) {
    -webkit-transform: translateY(min(1vw, 16px)) rotate(-30deg);
            transform: translateY(min(1vw, 16px)) rotate(-30deg);
  }
}
@media screen and (max-width: 768px) {
  header .box_menu .menu_trigger.open .box span:nth-of-type(1) {
    -webkit-transform: translateY(min(4.2666666667vw, 16px)) rotate(-30deg);
            transform: translateY(min(4.2666666667vw, 16px)) rotate(-30deg);
  }
}
header .box_menu .menu_trigger.open:hover {
  color: #3F9276;
}
header .box_menu .menu_trigger.open:hover::after {
  color: #3F9276;
}
header .box_menu .menu_trigger.open:hover .box span {
  background: #3F9276;
}
@media screen and (max-width: 768px) {
  header .box_menu .menu_trigger.open {
    position: fixed;
    width: min(14.9333333333vw, 56px);
    height: min(14.9333333333vw, 56px);
  }
  header .box_menu .menu_trigger.open::after {
    bottom: min(2.6666666667vw, 10px);
  }
  header .box_menu .menu_trigger.open .box {
    height: min(13.3333333333vw, 50px);
  }
}

header .dl_tel {
  width: min(23.25vw, 372px);
  margin: min(2.5vw, 40px) auto 0;
  text-align: center;
  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;
}
header .dl_tel dt {
  font-size: min(1.125vw, 18px);
}
header .dl_tel dd .tel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  align-items: center;
}
header .dl_tel dd .tel .tag {
  font-family: "HankenGrotesk-Regular", "ZenKakuGothicNew-Medium", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 400;
  font-size: min(1vw, 16px);
  border: solid 1px #333;
  padding: min(0.1875vw, 3px) min(0.5vw, 8px);
  margin-right: min(0.625vw, 10px);
}
header .dl_tel dd .tel a {
  font-family: "HankenGrotesk-Regular", sans-serif;
  letter-spacing: 0.025em;
  font-weight: 700;
  font-size: min(2.5vw, 40px);
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  header .dl_tel dd .tel a {
    pointer-events: none;
  }
}
@media screen and (max-width: 768px) {
  header .dl_tel dd .tel .tag {
    font-size: min(3.2vw, 12px);
    padding: min(0.5333333333vw, 2px) min(1.3333333333vw, 5px);
    margin-right: min(2.1333333333vw, 8px);
  }
  header .dl_tel dd .tel a {
    font-size: min(7.4666666667vw, 28px);
    text-decoration: underline;
  }
}
header .dl_tel dd small {
  font-size: min(1.125vw, 18px);
  color: #8F8F8F;
}
@media screen and (max-width: 768px) {
  header .dl_tel {
    width: 100%;
    margin: min(6.6666666667vw, 25px) auto 0;
  }
  header .dl_tel dt {
    font-size: min(3.7333333333vw, 14px);
  }
  header .dl_tel dd small {
    font-size: min(3.7333333333vw, 14px);
  }
}
header #navigation {
  width: min(38.25vw, 612px);
  padding-bottom: 60px;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 999;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
  -webkit-transition: 0.3s;
  transition: 0.3s;
  visibility: hidden;
}
@media screen and (max-width: 768px) {
  header #navigation {
    width: 100%;
    border-radius: 0;
  }
}
header #navigation.open {
  height: 100vh;
  overflow-y: auto;
  -webkit-transform: translateX(0);
          transform: translateX(0);
  -webkit-transition: 0.3s;
  transition: 0.3s;
  background: #fff;
  visibility: visible;
  border-radius: 28px 0 0 28px;
}
header #navigation.open .contact {
  width: min(23.25vw, 372px);
  height: min(4.25vw, 68px);
  margin: min(11vw, 17px) auto 0;
}
@media screen and (max-width: 768px) {
  header #navigation.open .contact {
    width: min(80vw, 300px);
    height: min(12.8vw, 48px);
    margin: min(2.6666666667vw, 10px) auto 0;
  }
  header #navigation.open .contact.mail {
    margin-top: min(2.6666666667vw, 10px);
  }
}
@media screen and (max-width: 768px) {
  header #navigation.open {
    border-radius: 0;
  }
  header #navigation.open .contact {
    width: min(80vw, 300px);
    height: min(12.8vw, 48px);
    margin: min(2.6666666667vw, 10px) auto 0;
  }
  header #navigation.open .contact.mail {
    margin-top: min(2.6666666667vw, 10px);
  }
}
header #navigation .ul_nav {
  width: min(23.25vw, 372px);
  margin: min(5vw, 80px) auto 0;
}
@media screen and (max-width: 768px) {
  header #navigation .ul_nav {
    width: 88%;
    margin: min(21.3333333333vw, 80px) auto 0;
  }
}
header #navigation .ul_nav a:focus {
  outline: #3F9276;
}
header #navigation .ul_nav > li {
  padding-bottom: 0;
}
header #navigation .ul_nav > li a {
  padding: min(3vw, 13px) 0;
  display: block;
  font-size: min(1.5vw, 24px);
  text-align: center;
}
@media screen and (max-width: 768px) {
  header #navigation .ul_nav > li a {
    padding: 2vw 0;
    display: block;
    font-size: min(4.2666666667vw, 16px);
  }
}
header #navigation .ul_nav > li a:hover {
  color: #3F9276;
}
header .overlay {
  content: "";
  display: block;
  width: 0;
  height: 0;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 2;
  opacity: 0;
  -webkit-transition: opacity 0.5s;
  transition: opacity 0.5s;
  background: rgba(0, 0, 0, 0.5);
}
header .overlay.open {
  width: 100%;
  height: 100vh;
  opacity: 1;
}

header.black {
  position: fixed;
  top: 0;
  width: 100%;
  background: #fff;
  -webkit-box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.15);
          box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.15);
  z-index: 999;
}
header.black .header_inner {
  background: #fff;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
header.black .header_inner .logo {
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
@media screen and (max-width: 768px) {
  header.black .header_inner {
    height: auto;
  }
  header.black .logo {
    display: none;
  }
  header.black .box_menu {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 9999;
  }
}

@media screen and (min-width: 769px) {
  header.black {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    -webkit-transition: -webkit-transform 0.4s ease;
    transition: -webkit-transform 0.4s ease;
    transition: transform 0.4s ease;
    transition: transform 0.4s ease, -webkit-transform 0.4s ease;
    -webkit-animation: headerFade 0.5s ease;
            animation: headerFade 0.5s ease;
  }
}
@-webkit-keyframes headerFade {
  0% {
    -webkit-transform: translateY(-10px);
            transform: translateY(-10px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 1;
  }
}
@keyframes headerFade {
  0% {
    -webkit-transform: translateY(-10px);
            transform: translateY(-10px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 1;
  }
}
#pagetop {
  width: min(10vw, 160px);
  height: min(3vw, 48px);
  padding-right: min(1.125vw, 18px);
  background: url(../images/noise.svg) #EFEBE0 repeat top center;
  position: absolute;
  bottom: 0;
  right: min(3.75vw, 60px);
  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;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: 4px 4px 0 0;
  z-index: 9999;
}
#pagetop, #pagetop span, #pagetop span::after {
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
#pagetop span {
  display: inline-block;
  position: relative;
  font-family: "HankenGrotesk-Regular", sans-serif;
  letter-spacing: 0.025em;
  font-size: min(1vw, 16px);
  letter-spacing: 0.05em;
}
#pagetop span::after {
  content: "";
  display: block;
  position: absolute;
  display: inline-block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0px min(0.3125vw, 5px) min(0.375vw, 6px) min(0.3125vw, 5px);
  border-color: transparent transparent #7E634B transparent;
  position: absolute;
  top: 0;
  bottom: 0;
  right: -1em;
  margin: auto;
}
#pagetop:hover {
  cursor: pointer;
  color: #3F9276;
}
#pagetop:hover span {
  color: #3F9276;
}
#pagetop:hover span::after {
  border-color: transparent transparent #3F9276 transparent;
}
@media screen and (max-width: 1280px) {
  #pagetop {
    right: 6%;
  }
}
@media screen and (max-width: 768px) {
  #pagetop {
    width: min(32vw, 120px);
    height: min(8.5333333333vw, 32px);
    border-radius: 4px 0 0 0;
    right: 0;
  }
  #pagetop span {
    font-size: min(3.2vw, 12px);
  }
  #pagetop span::after {
    border-width: 0px 4px 5px 4px;
  }
}

footer {
  padding: min(2.5vw, 40px) 0 min(3.75vw, 60px);
  background: url(../images/noise.svg) #EFEBE0 repeat top center;
}
footer .inner {
  position: relative;
  width: min(100%, 1300px);
}
footer .box_status .logo a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -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-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: min(1vw, 16px);
}
footer .box_status .logo a .osmo_logo {
  width: 275px;
}
footer .box_status .logo a .name {
  width: 221px;
}
@media screen and (max-width: 1280px) {
  footer .box_status .logo a .osmo_logo {
    width: min(17.1875vw, 275px);
  }
  footer .box_status .logo a .name {
    width: min(13.8125vw, 221px);
  }
}
footer .box_status .ul_sns {
  margin-top: min(1.5vw, 24px);
  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;
  gap: 0 12px;
}
footer .box_status .ul_sns li {
  width: min(1.5vw, 24px);
}
footer .box_status .ul_sns li a {
  display: block;
}
footer .box_status a:hover .logo, footer .box_status a:hover .ul_sns {
  opacity: 0.7;
}
@media screen and (max-width: 768px) {
  footer {
    padding: 2.8em 0 4em;
  }
  footer .inner {
    position: relative;
    width: 100%;
  }
  footer .box_wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  footer .box_status .logo a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -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;
    align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: min(4.2666666667vw, 16px);
  }
  footer .box_status .logo a .osmo_logo {
    width: min(57.6vw, 216px);
  }
  footer .box_status .logo a .name {
    width: min(57.6vw, 216px);
  }
  footer .box_status .ul_sns {
    margin-top: min(5.3333333333vw, 20px);
    gap: 0 1.1em;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  footer .box_status .ul_sns li {
    width: min(5.3333333333vw, 20px);
  }
}
footer .area_copyright {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  position: relative;
  top: 5px;
}
footer .area_copyright .ul_nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0 min(1.25vw, 20px);
}
footer .area_copyright .ul_nav li a::before {
  content: "";
  display: block;
  position: absolute;
  width: 0%;
  height: 1px;
  background: #3F9276;
  position: absolute;
  left: 0;
  bottom: -1px;
  -webkit-transition: all 0.3s ease-out;
  transition: all 0.3s ease-out;
}
footer .area_copyright .ul_nav li a:hover {
  color: #3F9276;
}
footer .area_copyright .ul_nav li a:hover::before {
  width: 100%;
}
footer .area_copyright .ul_nav li a {
  position: relative;
  font-size: 14px;
}
@media screen and (max-width: 1280px) {
  footer .area_copyright .ul_nav li a {
    font-size: min(0.875vw, 14px);
  }
}
footer .area_copyright .ul_nav li a[target=_blank] span::after {
  content: "";
  display: inline-block;
  width: min(0.75vw, 12px);
  height: min(0.75vw, 12px);
  -webkit-mask: url("../images/icon_arrow_diag.svg");
          mask: url("../images/icon_arrow_diag.svg");
  background-color: #000;
  -webkit-mask-size: 100%;
          mask-size: 100%;
  vertical-align: middle;
  position: absolute;
  right: 0;
  background-color: #9E9E9E;
  -webkit-transform: rotate(0);
          transform: rotate(0);
  top: 2px;
  right: 0;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
@media (hover: hover) {
  footer .area_copyright .ul_nav li a:hover[target=_blank] span::after {
    background-color: #3F9276;
  }
}
footer .area_copyright .ul_nav li a span {
  padding-right: min(1.25vw, 20px);
}
footer .area_copyright .copyright {
  text-align: right;
}
footer .area_copyright .copyright small {
  font-size: 12px;
}
@media screen and (max-width: 1280px) {
  footer .area_copyright .copyright small {
    font-size: min(0.75vw, 12px);
  }
}
footer .area_copyright .copyright small {
  font-family: "HankenGrotesk-Regular", sans-serif;
  letter-spacing: 0.025em;
  color: #AFB1AB;
}
@media screen and (max-width: 768px) {
  footer .area_copyright {
    margin-top: min(5.3333333333vw, 20px);
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  footer .area_copyright .ul_nav {
    gap: 0 min(5.3333333333vw, 20px);
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  footer .area_copyright .ul_nav li a {
    font-size: min(3.2vw, 12px);
  }
  footer .area_copyright .ul_nav li a[target=_blank] span::after {
    width: min(3.2vw, 12px);
    height: min(3.2vw, 12px);
  }
  footer .area_copyright .ul_nav li a span {
    padding-right: min(4vw, 15px);
  }
  footer .area_copyright .copyright {
    margin-top: min(5.3333333333vw, 20px);
    font-size: min(2.6666666667vw, 10px);
    -webkit-transform: scale(0.85);
            transform: scale(0.85);
  }
}

section {
  margin-top: min(6.25vw, 100px);
  font-family: "HankenGrotesk-Bold", "ZenKakuGothicNew-Bold", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  section {
    margin-top: min(13.3333333333vw, 50px);
  }
}

.fadeUp {
  opacity: 0;
  -webkit-transform: translateY(40px);
          transform: translateY(40px);
  -webkit-transition: opacity 0.8s ease, -webkit-transform 0.8s ease;
  transition: opacity 0.8s ease, -webkit-transform 0.8s ease;
  transition: opacity 0.8s ease, transform 0.8s ease;
  transition: opacity 0.8s ease, transform 0.8s ease, -webkit-transform 0.8s ease;
}
.fadeUp.show {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

/*----------------------------------------*/
/* $ タイトル
/*----------------------------------------*/
.tit_content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.tit_content .tag {
  font-size: min(1.25vw, 20px);
  color: #7E634B;
}
.tit_content em {
  font-size: min(2.25vw, 36px);
  line-height: 1.6;
  margin-top: 10px;
}
.tit_content .line {
  position: relative;
  color: #3F9276;
  padding: 0 0 min(0.875vw, 14px);
}
.tit_content .line span {
  color: #333;
}
.tit_content + p {
  font-family: "HankenGrotesk-Regular", "ZenKakuGothicNew-Medium", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 400;
  font-size: min(1.25vw, 20px);
  line-height: 2.2;
  margin-top: min(1.875vw, 30px);
}
.tit_content + p span {
  color: #3F9276;
  font-family: "HankenGrotesk-Bold", "ZenKakuGothicNew-Bold", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  .tit_content {
    text-align: center;
  }
  .tit_content .tag {
    font-size: min(4.2666666667vw, 16px);
  }
  .tit_content em {
    font-size: min(6.9333333333vw, 26px);
    line-height: 1.84;
    margin-top: min(1.3333333333vw, 5px);
  }
  .tit_content .line {
    padding: 0 0 min(2.6666666667vw, 10px);
  }
  .tit_content + p {
    font-size: min(4.2666666667vw, 16px);
    line-height: 2;
    margin-top: min(5.3333333333vw, 20px);
  }
}

.marker {
  color: #3F9276;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(70%, transparent), color-stop(70%, #FEEF6B));
  background: linear-gradient(transparent 70%, #FEEF6B 70%);
}

.image_box figcaption {
  font-size: min(1.25vw, 20px);
  line-height: 1.45;
  text-align: center;
  margin-top: min(0.875vw, 14px);
}
@media screen and (max-width: 768px) {
  .image_box figcaption {
    font-size: min(4.2666666667vw, 16px);
    margin-top: min(2.6666666667vw, 10px);
  }
}

/*----------------------------------------*/
/* $ ボタン
/*----------------------------------------*/
.contact {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.contact a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.box_btn {
  position: relative;
}
.box_btn a {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -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-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  align-items: center;
  font-size: min(1.125vw, 18px);
  color: #fff;
  line-height: 1;
  border-radius: 8px;
  -webkit-box-shadow: 3px 3px 0 #CDCCC7;
          box-shadow: 3px 3px 0 #CDCCC7;
  background: #F37D36;
  padding: min(0.625vw, 10px) min(0.9375vw, 15px);
}
.box_btn a span {
  position: relative;
  padding-left: min(2.5vw, 40px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.box_btn a span::before, .box_btn a span::after {
  content: "";
  display: block;
  position: absolute;
}
.box_btn a span::before {
  left: min(0.4375vw, 7px);
  width: min(1.125vw, 18px);
  height: min(1.125vw, 18px);
  background-color: #F37D36;
  -webkit-mask: url("../images/contact_icon01.svg");
          mask: url("../images/contact_icon01.svg");
  -webkit-mask-size: min(1.125vw, 18px);
          mask-size: min(1.125vw, 18px);
  z-index: 2;
}
.box_btn a span::after {
  left: 0;
  width: min(2vw, 32px);
  height: min(2vw, 32px);
  background-color: #fff;
  border-radius: 50%;
}
@media screen and (max-width: 768px) {
  .box_btn a {
    font-size: min(4.2666666667vw, 16px);
    border-radius: 4px;
    padding: min(2.6666666667vw, 10px) min(5.3333333333vw, 20px);
  }
  .box_btn a span {
    padding-left: min(10.6666666667vw, 40px);
  }
  .box_btn a span::before {
    left: min(1.8666666667vw, 7px);
    width: min(4.8vw, 18px);
    height: min(4.8vw, 18px);
    -webkit-mask-size: min(4.8vw, 18px);
            mask-size: min(4.8vw, 18px);
  }
  .box_btn a span::after {
    width: min(8.5333333333vw, 32px);
    height: min(8.5333333333vw, 32px);
  }
}
.box_btn a:hover {
  -webkit-box-shadow: none;
          box-shadow: none;
  -webkit-transform: translateY(3px);
          transform: translateY(3px);
}

.boxs {
  position: relative;
  background: #fff;
}
.boxs.shadow {
  border-radius: 20px;
  -webkit-box-shadow: 3px 3px 0 #D5CEB9;
          box-shadow: 3px 3px 0 #D5CEB9;
}
.boxs.line {
  border-radius: 0px 8px 8px 0px;
  -webkit-box-shadow: 3px 3px 0 #D5CEB9;
          box-shadow: 3px 3px 0 #D5CEB9;
  border-left: solid 4px #3F9276;
  min-height: 84px;
}
.boxs.dashed {
  position: relative;
  border: dashed 0.1em #A7927C;
  padding: 10px 15px;
  color: #454545;
  width: 100%;
}
.boxs span {
  color: #3F9276;
}

.dl_tel {
  text-align: center;
  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;
  width: min(23.25vw, 372px);
  margin: 0 min(3.125vw, 50px) 0 min(2.1875vw, 35px);
}
.dl_tel dt {
  font-size: min(1.125vw, 18px);
}
.dl_tel dd .tel {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  align-items: center;
}
.dl_tel dd .tel .tag {
  font-family: "HankenGrotesk-Regular", "ZenKakuGothicNew-Medium", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 400;
  font-size: min(1vw, 16px);
  border: solid 1px #333;
  padding: min(0.1875vw, 3px) min(0.5vw, 8px);
  margin-right: min(0.625vw, 10px);
}
.dl_tel dd .tel a {
  font-family: "HankenGrotesk-Regular", sans-serif;
  letter-spacing: 0.025em;
  font-weight: 700;
  font-size: min(2.5vw, 40px);
  line-height: 1.5;
}
@media screen and (min-width: 769px) {
  .dl_tel dd .tel a {
    pointer-events: none;
  }
}
@media screen and (max-width: 768px) {
  .dl_tel dd .tel .tag {
    font-size: min(3.2vw, 12px);
    padding: min(0.5333333333vw, 2px) min(1.3333333333vw, 5px);
    margin-right: min(2.1333333333vw, 8px);
  }
  .dl_tel dd .tel a {
    font-size: min(7.4666666667vw, 28px);
    text-decoration: underline;
  }
}
.dl_tel dd small {
  font-size: min(1.125vw, 18px);
  color: #8F8F8F;
}
@media screen and (max-width: 768px) {
  .dl_tel {
    width: 100%;
  }
  .dl_tel dt {
    font-size: min(3.7333333333vw, 14px);
  }
  .dl_tel dd small {
    font-size: min(3.7333333333vw, 14px);
  }
}
/*# sourceMappingURL=common.css.map */