@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Infant:ital,wght@0,300..700;1,300..700&family=Zen+Kaku+Gothic+New:wght@300;400;500;700;900&family=Zen+Old+Mincho:wght@400;500;600;700;900&display=swap');
/* footer */
/* footer */
.footer {
  position: relative;
  box-sizing: border-box;
  width: 100%;
  background: #fff;
}

.footer .footer_contact {
  display: flex;
  border-top: 1px solid #d7d3cf;
  border-bottom: 1px solid #d7d3cf;
}

.footer .footer_contact > div {
  flex: 1 1 0;
  box-sizing: border-box;
  padding: clamp(42px, 5vw, 58px) clamp(52px, 10vw, 150px);
}

.footer .footer_contact > div + div {
  border-left: 1px solid #d7d3cf;
}

.footer .footer_contact a {
  display: block;
  color: inherit;
  text-decoration: none;
}

.footer .footer_contact p {
  margin: 0 0 8px;
  color: #5f5953;
  font-family: "Noto Sans", "Zen Kaku Gothic New", sans-serif;
  font-size: 14px;
  line-height: 1.7;
  letter-spacing: .03em;
}

.footer .footer_contact .h2_box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin: 0;
  padding-bottom: 12px;
  border-bottom: 1px solid #cfcac5;
}

.footer .footer_contact .h2_box h2 {
  margin: 0;
  color: #333;
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(22px, 2vw, 27px);
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: .06em;
  white-space: nowrap;
}

.footer .footer_contact .h2_box i {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  box-sizing: border-box;
  width: 46px;
  height: 46px;
  border: 1px solid var(--ink);
  border-radius: 50%;
  color: #333;
  font-size: 13px;
  transition: ease 0.3s;
}

.footer .footer_contact > div:last-child .h2_box {
  justify-content: flex-start;
  margin-bottom: 6px;
  padding-bottom: 10px;
}

.footer .footer_contact > div:last-child .h2_box i {
  width: 25px;
  height: 25px;
  margin-right: 4px;
  border: 0;
  font-size: 18px;
}

.footer .footer_inner {
  box-sizing: border-box;
  width: 100%;
  padding-top: 48px;
  padding-bottom: 88px;
}

.footer .footer_inner > .width-1280-max {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: clamp(42px, 6vw, 78px);
  width: 100%;
}

.footer .footer_brand {
  flex: 0 0 280px;
}

.footer .footer_brand img {
  width: 190px;
  max-width: 100%;
  margin-bottom: 16px;
}

.footer .footer_brand p {
  margin: 0;
  color: #333;
  font-family: "Noto Sans", "Zen Kaku Gothic New", sans-serif;
  font-size: 14px;
  line-height: 1.9;
}

.footer .sns_links {
  gap: 14px;
}

.footer .sns_links a {
  color: #333;
  text-decoration: none;
}

.footer .footer_nav {
  display: flex;
  flex: 1 1 auto;
  flex-wrap: wrap;
  gap: 8px 44px;
  min-width: 320px;
  max-width: 360px;
}

.footer .footer_nav a {
  flex: 0 0 calc((100% - 88px) / 3);
  min-width: 82px;
  color: #333;
  font-family: "Noto Sans", "Zen Kaku Gothic New", sans-serif;
  font-size: 14px;
  line-height: 1.85;
  letter-spacing: .04em;
  text-decoration: none;
  white-space: nowrap;
}

.footer .footer_nav p,
.footer .footer_actions p {
  margin: 0;
}

.footer .footer_actions {
  display: flex;
  flex: 0 0 190px;
  flex-direction: column;
  gap: 8px;
  align-items: stretch;
}

.footer .footer_actions a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  box-sizing: border-box;
  width: 190px;
  min-height: 44px;
  padding: 0 16px;
  color: #fff !important;
  font-family: "Noto Sans", "Zen Kaku Gothic New", sans-serif;
  font-size: 14px;
  line-height: 1.3;
  letter-spacing: .06em;
  text-decoration: none;
  white-space: nowrap;
}

.footer .footer_actions a *,
.footer .footer_actions i,
.footer .footer_actions p {
  color: #fff !important;
}

.footer .footer_actions img {
  flex: 0 0 auto;
  width: 14px;
  height: 14px;
  filter: brightness(0) invert(1);
}

.footer .footer_actions a:first-child {
  background: var(--gold);
}

.footer .footer_actions a:last-child {
  background: var(--green);
}

.footer .copyright {
  position: absolute;
  right: 40px;
  bottom: 32px;
  margin: 0;
  color: #333;
  font-family: "Lato", "Noto Sans", sans-serif;
  font-size: 10px;
  line-height: 1;
  letter-spacing: .08em;
}

@media screen and (max-width: 1080px) {
  .footer .footer_inner > .width-1280-max {
    gap: 36px;
  }

  .footer .footer_brand {
    flex-basis: 250px;
  }

  .footer .footer_nav {
    gap: 8px 28px;
    min-width: 280px;
  }

  .footer .footer_nav a {
    flex-basis: calc((100% - 56px) / 3);
  }
}

@media screen and (max-width: 900px) {
    
    
  .footer .footer_contact {
    display: flex;
    flex-direction: column;
  }

  .footer .footer_contact > div {
    display: flex;
    justify-content: center;
    box-sizing: border-box;
    width: 100%;
    padding: 34px 20px 30px;
    text-align: left;
  }

  .footer .footer_contact > div + div {
    border-top: 1px solid #d7d3cf;
    border-left: 0;
  }

  .footer .footer_contact > div > a,
  .footer .footer_contact > div > div,
  .footer .footer_contact > div:last-child > a {
    width: min(100%, 248px);
  }

  .footer .footer_contact p {
    font-size: 11px;
    line-height: 1.7;
  }

  .footer .footer_contact .h2_box {
    justify-content: space-between;
    gap: 14px;
  }

  .footer .footer_contact .h2_box h2 {
    font-size: 19px;
    line-height: 1.6;
  }

  .footer .footer_contact .h2_box i {
    width: 30px;
    height: 30px;
    font-size: 11px;
  }

  .footer .footer_contact > div:last-child .h2_box {
    justify-content: flex-start;
    padding-bottom: 0;
    border-bottom: 0;
  }

  .footer .footer_contact > div:last-child .h2_box h2 {
    font-size: 24px;
  }

  .footer .footer_contact > div:last-child .h2_box i {
    width: 22px;
    height: 22px;
    margin-right: 0;
    font-size: 16px;
    }}
    @media screen and (max-width: 900px) {
  .footer .footer_inner {
    width: 100%;
    padding-top: 34px;
    padding-bottom: 64px;
  }

  .footer .footer_inner > .width-1280-max {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: 0;
    text-align: left;
  }

  .footer .footer_nav {
    order: 1;
    display: flex !important;
    flex-wrap: wrap;
    gap: 8px 34px;
    min-width: 0;
    max-width: none;
    width: 100%;
    padding-bottom: 36px;
    border-bottom: 1px solid #d7d3cf;
  }

  .footer .footer_nav a {
    flex: 0 0 calc((100% - 34px) / 2);
    min-width: 0;
    font-size: 13px;
    line-height: 1.7;
    white-space: nowrap;
  }

  .footer .footer_brand {
    order: 2;
    flex: none;
    width: 100%;
    padding-top: 36px;
  }

  .footer .footer_brand img {
    width: 180px;
    margin: 0 0 20px;
  }

  .footer .footer_brand p {
    font-size: 12px;
    line-height: 1.9;
  }

  .footer .sns_links {
    justify-content: flex-start;
    gap: 12px;
  }

  .footer .footer_actions {
    display: none !important;
  }

  .footer .copyright {
    right: auto;
    left: 20px;
    bottom: 32px;
    font-size: 9px;
  }
}
    
}

@media screen and (max-width: 768px) {
  .footer {
    padding-bottom: 0;
  }

  .footer .footer_inner {
    width: 100%;
    padding-top: 34px;
    padding-bottom: 64px;
  }

  .footer .footer_inner > .width-1280-max {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: 0;
    text-align: left;
  }

  .footer .footer_nav {
    order: 1;
    display: flex !important;
    flex-wrap: wrap;
    gap: 8px 34px;
    min-width: 0;
    max-width: none;
    width: 100%;
    padding-bottom: 36px;
    border-bottom: 1px solid #d7d3cf;
  }

  .footer .footer_nav a {
    flex: 0 0 calc((100% - 34px) / 2);
    min-width: 0;
    font-size: 13px;
    line-height: 1.7;
    white-space: nowrap;
  }

  .footer .footer_brand {
    order: 2;
    flex: none;
    width: 100%;
    padding-top: 36px;
  }

  .footer .footer_brand img {
    width: 180px;
    margin: 0 0 20px;
  }

  .footer .footer_brand p {
    font-size: 12px;
    line-height: 1.9;
  }

  .footer .sns_links {
    justify-content: flex-start;
    gap: 12px;
  }

  .footer .footer_actions {
    display: none !important;
  }

  .footer .copyright {
    right: auto;
    left: 20px;
    bottom: 32px;
    font-size: 9px;
  }
}

.pagetitle {
  position: relative;
  height: clamp(260px, 40vw, 500px);
  overflow: hidden;
  align-items: center;
  justify-content: flex-start;
  padding-top: clamp(70px, 7vw, 100px);
  padding-bottom: clamp(40px, 5vw, 65px);
  background-color: #141318;
}
body.on .pagetitle::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  background: linear-gradient(90deg, rgba(0, 0, 0, .36) 0%, rgba(0, 0, 0, .18) 34%, rgba(0, 0, 0, .04) 70%, rgba(0, 0, 0, .02) 100%);
  pointer-events: none;
}
body.on .pagetitle::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 3;
  background: linear-gradient(180deg, rgba(20, 19, 24, .04) 0%, rgba(20, 19, 24, 0) 48%, rgba(20, 19, 24, .08) 100%);
  pointer-events: none;
}
.pagetitle > img {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.pagetitle .txtbox {
  position: relative;
  z-index: 4;
}
.pagetitle h1 {
  margin-bottom: clamp(8px, 1.2vw, 14px);
  color: #fff;
  line-height: 1;
  letter-spacing: .08em;
  font-weight: 400;
}
.pagetitle p {
  color: #fff;
  letter-spacing: .08em;
}
@media screen and (max-width: 768px) {
  .pagetitle {
    height: clamp(230px, 42vw, 300px);
  }
  .pagetitle > img {
    object-position: center center;
  }
}
@media screen and (max-width: 576px) {
  .pagetitle {
    height: 220px;
    padding-top: 70px;
    padding-bottom: 35px;
  }
}
.pagetitle {
  align-items: flex-end;
}
.pagetitle .txtbox {
  position: absolute;
  left: clamp(20px, 6vw, 80px);
  bottom: clamp(28px, 5vw, 58px);
  z-index: 4;
}
:root {
  --ink: #3b3630;
  --ink-soft: #4c4844;
  --rose: #80625e;
  --rose-light: #c1a893;
  --sand: #e5d4ca;
  --paper: #f7f3f1;
  --gray: #edece8;
  --gold: #deac4e;
  --green: #32c36a;
}
html {
  scroll-behavior: smooth;
}
body {
  margin: 0;
  overflow-x: hidden;
  background: #fff;
  color: var(--ink);
  font-family: "Zen Kaku Gothic New", "Noto Sans JP", "Yu Gothic", sans-serif;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  background-image: url("https://immune-plus.net/system_panel/uploads/images/body_bg.png");
  background-position: top left;
  background-size: 100% auto;
  background-repeat: repeat-y;
}
body.menu-open {
  overflow: hidden;
}
body .bg_img_wrap, body .bg_img_wrap2 {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
body.on .bg_img_wrap .bg_img, body.on .bg_img_wrap2 > img {
  display: none;
}
a {
  color: var(--ink);
  text-decoration: none;
  transition: opacity .25s ease;
}
a:hover {
  color: var(--ink);
  opacity: .6;
}
img {
  display: block;
  width: 100%;
  max-width: 100%;
}
p.meta_text {
  margin: 0;
}
.width-1200-max {
  width: min(1140px, calc(100% - 80px));
  margin-right: auto;
  margin-left: auto;
}
.width-1080-max {
  width: min(1080px, calc(100% - 80px));
  margin-right: auto;
  margin-left: auto;
}
.main-wrap {
  overflow: hidden;
}
.pc_br {
  display: block;
}
.section_title > p {
  margin: 0;
  color: var(--rose);
  font-family: "Cormorant Infant", serif;
  font-size: 54px;
  font-weight: 500;
  line-height: 44px;
  letter-spacing: .02em;
}
.section_title > h2 {
  margin: 15px 0 0 0px;
  position: relative;
  font-family: "Zen Old Mincho", serif;
  font-size: 20px;
  font-weight: 400;
  line-height: 39.4px;
  letter-spacing: .02em;
}
/*
.section_title > h2::after{
	content: "";
	position: absolute;
	top: 50%;
	left: -15px;
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background-color: #3B3630;
	transform: translateY(-50%);
}
*/
.more_bt {
  position: relative;
  box-sizing: border-box;
  border-radius: 200px;
  border: 1px solid #80625E;
  overflow: hidden;
  display: inline-block;
}
.more_bt::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(-100%, -50%);
  width: 100%;
  height: 100%;
  background-color: #80625E;
  transition: ease 0.4s;
  opacity: 0;
}
.more_bt:hover::after {
  transform: translate(0, -50%);
  opacity: 1;
}
.more_bt > a {
  position: relative;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  width: 100%;
  height: auto;
  color: var(--rose);
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: .08em;
  padding: 6px 30px 4px;
}
.more_bt p {
  margin: 0;
  transition: ease 0.4s;
  color: #80625e;
  font-family: "Cormorant Infant", "Zen Kaku Gothic New", serif;
}
.more_bt:hover p {
  color: #FFFFFF;
  transition-delay: 0.1s;
}
.more_bt > a:hover {
  color: var(--rose);
}
.more_bt_line {
  border: 1px solid var(--rose);
  background: transparent;
  color: var(--rose);
}
.more_bt_line > a {
  color: var(--rose);
}
.pill_bt {
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  height: 36px;
  padding: 0 24px;
  border: 1px solid rgba(128, 98, 94, .35);
  border-radius: 40px;
  background: #fff;
  font-size: 13px;
}
.leaf_shadow {
  position: absolute;
  background: url("https://immune-plus.net/system_panel/uploads/images/leaf-shadow.png") center/contain no-repeat;
  pointer-events: none;
}
.more_bt2 {
  display: flex;
  justify-content: flex-end;
}
.more_bt2 a {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}
.more_bt2 a .icon {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 1px solid #B9B4AE;
  position: relative;
}
.more_bt2 a .icon img {
  position: absolute;
  top: 50%;
  left: 0;
  width: 80%;
  transform: translate(-50%, -50%);
  transition: ease 0.3s;
}
.more_bt2 a:hover .icon img {
  transform: translate(-20%, -50%);
}
.more_bt2 a p {
  line-height: 1;
}
@media screen and (max-width:767px) {
  .more_bt2 a {
    gap: 8px;
  }
  .more_bt2 a .icon {
    width: 14px;
    height: 14px;
  }
}
/* header */
.header {
  position: fixed;
  z-index: 1000;
  top: 0;
  left: 0;
  width: 100%;
  height: 70px;
  border-bottom: 1px solid rgba(128, 98, 94, .35);
  background: #fff;
}
.header_inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  box-sizing: border-box;
  width: 100%;
  height: 70px;
  padding-left: 42px;
}
.header_logo {
  width: 130px;
}
.header_right {
  display: flex;
  align-items: center;
  height: 70px;
  margin-left: auto;
}
.header_open {
  display: flex;
  align-items: center;
  gap: 8px;
  box-sizing: border-box;
  height: 70px;
  margin: 0;
  padding: 0 27px;
  border-right: 1px solid #d8d4d0;
  font-family: "DM Sans", "Noto Sans", sans-serif;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: .08em;
}
.header_open > p {
  margin: 0;
}
.header_open > p:first-child {
  display: flex;
  align-items: center;
  gap: 8px;
}
.header_open > p:first-child::before {
  display: block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--rose);
  content: "";
}
.header_lang {
  position: relative;
  box-sizing: border-box;
  width: 58px;
  height: 70px;
  border-right: 1px solid #d8d4d0;
}
.header_lang_current {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  cursor: pointer;
}
.header_lang_current > i {
  display: block;
  font-size: 18px;
  line-height: 1;
}
.header_lang_list {
  position: absolute;
  top: 100%;
  right: -1px;
  z-index: 40;
  display: flex;
  flex-direction: column;
  min-width: 118px;
  padding: 12px 0;
  border: 1px solid #d8d4d0;
  background: rgba(247, 243, 241, .98);
  box-shadow: 0 14px 28px rgba(51, 42, 37, .08);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity .22s ease, visibility .22s ease, transform .22s ease;
  pointer-events: none;
}
.header_lang:hover .header_lang_list, .header_lang:focus-within .header_lang_list {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}
.header_lang_list > a {
  display: flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  min-height: 36px;
  padding: 0 16px;
  text-decoration: none;
}
.header_lang_list > a > p {
  margin: 0;
  color: var(--ink);
  font-family: "DM Sans", "Noto Sans JP", sans-serif;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: .08em;
  white-space: nowrap;
}
.header_lang_list > a:hover {
  background: rgba(196, 153, 132, .10);
}
.menu-bt {
  position: relative;
  display: block;
  width: 58px;
  height: 70px;
  cursor: pointer;
}
.menu-bt > p {
  position: absolute;
  left: 19px;
  display: block !important;
  width: 20px;
  height: 1px;
  margin: 0;
  background: var(--ink);
  transition: transform .25s ease, top .25s ease;
}
.menu-bt > p:first-of-type {
  top: 29px;
}
.menu-bt > p:last-of-type {
  top: 40px;
}
.menu-bt.active > p:first-of-type {
  top: 35px;
  transform: rotate(35deg);
}
.menu-bt.active > p:last-of-type {
  top: 35px;
  transform: rotate(-35deg);
}
/* menu overlay */
.menu-wrap {
  position: fixed;
  z-index: 950;
  inset: 0;
  display: none;
  overflow: auto;
  box-sizing: border-box;
  padding: 115px 8vw 70px;
  background: rgba(247, 243, 241, .985);
}
.menu_inner {
  width: min(1080px, 100%);
  margin: auto;
}
.menu_head img {
  width: 180px;
}
.menu_nav {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0 55px;
  margin-top: 65px;
  border-top: 1px solid #d6cec9;
}
.menu_nav > a {
  display: grid;
  grid-template-columns: 42px 1fr;
  align-items: center;
  min-height: 105px;
  border-bottom: 1px solid #d6cec9;
}
.menu_nav p {
  margin: 0;
}
.menu_nav .menu_no {
  font-family: "Cormorant Infant", serif;
  font-size: 15px;
}
.menu_nav .menu_label > p:first-child {
  font-family: "Zen Old Mincho", serif;
  font-size: 18px;
}
.menu_nav .menu_en {
  margin-top: 5px;
  color: var(--rose);
  font-family: "Cormorant Infant", serif;
  font-size: 13px;
}
.menu_contact {
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  margin-top: 45px;
}
.menu_contact a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 200px;
  height: 48px;
  color: #fff;
  font-size: 14px;
}
.menu_contact p, .lower_link_banner a p, .lower_cta .salon_guide > a p {
  margin: 0;
  color: inherit;
}
.menu_contact a:first-child {
  background: var(--gold);
}
.menu_contact a:last-child {
  background: var(--green);
}
/* fixed reservation/store */
.fixed_links {
  position: fixed;
  z-index: 900;
  top: 245px;
  right: 0;
  display: block;
  width: 58px;
}
.fixed_links a {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  box-sizing: border-box;
  width: 58px;
  min-height: 160px;
  padding: 20px 0 14px;
  color: #fff;
}
.fixed_links p {
  margin: 10px 0 0;
  color: #fff;
  font-size: 14px;
  line-height: 14.6px;
  letter-spacing: .04em;
  writing-mode: vertical-rl;
  font-weight: 500;
}
.fixed_links i {
  display: block;
  color: #fff;
  margin-bottom: 3px;
  font-size: 17px;
  line-height: 17px;
  text-align: center;
  writing-mode: horizontal-tb;
}
.fixed_reserve {
  background: #DEAC4E;
  background: linear-gradient(135deg, rgba(222, 172, 78, 1) 0%, rgba(206, 155, 59, 1) 100%);
}
.fixed_store {
  background: #32C3A1;
  background: linear-gradient(135deg, rgba(50, 195, 161, 1) 0%, rgba(50, 195, 106, 1) 100%);
}
/* shared lower-page title */
.lower_main, .about_main, .setmenu_main, .fullmenu_main, .salon_page, .contact_page {
  padding-top: 70px;
}
.about_page_hero, .setmenu_hero, .fullmenu_hero, .salon_hero, .post_hero, .news_hero, .detail_hero, .contact_hero {
  position: relative;
  box-sizing: border-box;
  height: 366px;
}
.about_page_hero::after, .setmenu_hero::after, .fullmenu_hero::after, .salon_hero::after, .post_hero::after, .news_hero::after, .detail_hero::after, .contact_hero::after {
  position: absolute;
  inset: 0;
  background: rgba(59, 54, 48, .08);
  content: "";
}
.about_page_hero > div, .setmenu_hero > div, .fullmenu_hero > div, .salon_hero > div, .post_hero > div, .news_hero > div, .detail_hero > div, .contact_hero > div {
  position: absolute;
  z-index: 2;
  top: 50%;
  left: 150px;
  transform: translateY(-50%);
}
.about_page_hero p, .setmenu_hero p, .fullmenu_hero p, .salon_hero p, .post_hero p, .news_hero p, .detail_hero p, .contact_hero p {
  margin: 0;
  color: #fff;
  font-family: "Cormorant Infant", serif;
  font-size: 42px;
  font-weight: 600;
  line-height: 46.6px;
}
.about_page_hero h1, .setmenu_hero h1, .fullmenu_hero h1, .salon_hero h1, .post_hero h1, .news_hero h1, .detail_hero h1, .contact_hero h1 {
  margin: 8px 0 0 15px;
  color: #fff;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 46.6px;
}
/* Salon information block */
.lower_cta {
  position: relative;
  display: grid;
  grid-template-columns: minmax(120px, 230px) minmax(0, 710px) minmax(340px, 500px);
  box-sizing: border-box;
  width: 100%;
  height: 710px;
  overflow: hidden;
  background: #e5d4ca;
}
.lower_cta .salon_panel {
  position: relative;
  overflow: hidden;
  height: 710px;
}
.lower_cta .salon_panel img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.lower_cta .salon_panel_sub img {
  opacity: .7;
}
.lower_cta .salon_guide {
  box-sizing: border-box;
  padding: 122px clamp(36px, 5vw, 100px) 70px;
  background: #f3e9e4;
}
.lower_cta .salon_guide h2 {
  margin: 0 0 58px;
  font-family: "Zen Old Mincho", serif;
  font-size: 25px;
  font-weight: 400;
  letter-spacing: .08em;
}
.lower_cta .salon_detail {
  margin: 0 0 22px;
}
.lower_cta .salon_detail h3 {
  margin: 0 0 2px;
  font-family: "Cormorant Infant", serif;
  font-size: 20px;
  font-weight: 400;
  letter-spacing: .06em;
}
.lower_cta .salon_detail p {
  margin: 0;
  font-family: "Noto Sans", "Zen Kaku Gothic New", sans-serif;
  font-size: 15px;
  line-height: 27px;
}
.lower_cta .salon_guide > a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 220px;
  height: 43px;
  margin-top: 30px;
  border-radius: 50px;
  background: var(--rose);
  color: #fff;
  font-family: "Cormorant Infant", serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .08em;
}
.lower_cta .salon_panel_main p {
  position: absolute;
  left: clamp(-90px, -6vw, -42px);
  bottom: 77px;
  margin: 0;
  color: #fff;
  font-family: "Cormorant Infant", serif;
  font-size: clamp(58px, 6.3vw, 90px);
  font-weight: 700;
  line-height: clamp(54px, 5.9vw, 84px);
  letter-spacing: .04em;
  white-space: nowrap;
}
/* Product block used on set-menu */
.lower_products {
  position: relative;
  box-sizing: border-box;
  height: 1235px;
  padding: 0 0 105px;
  overflow: hidden;
  background: #f3e9e4;
}
.lower_products_head {
  width: 1140px;
  margin: 0 auto;
  padding-top: 72px;
}
.lower_products_head p {
  margin: 0;
  color: var(--rose);
  font-family: "Cormorant Infant", serif;
  font-size: 54px;
  line-height: 44px;
}
.lower_products_head h2 {
  margin: 11px 0 0 15px;
  font-family: "Zen Old Mincho", serif;
  font-size: 20px;
  font-weight: 400;
}
.lower_products_list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 270px));
  gap: 38px 20px;
  justify-content: center;
  width: min(1140px, calc(100% - 60px));
  margin: 85px auto 0;
}
.lower_products_list a {
  display: block;
  width: 270px;
  margin-right: 0;
}
.lower_products_list img {
  width: 270px;
  height: 270px;
  object-fit: cover;
  background: #fff;
}
.lower_products_list h3 {
  margin: 18px 0 7px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 18px;
  font-weight: 400;
  line-height: 24px;
}
.lower_products_list p {
  margin: 0;
  font-size: 14px;
  line-height: 24px;
}
.lower_link_banner {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  box-sizing: border-box;
  height: 359px;
  background: #fff;
}
.lower_link_banner p {
  margin: 0 0 42px;
  font-family: "Zen Old Mincho", serif;
  font-size: 28px;
  letter-spacing: .04em;
}
.lower_link_banner a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 220px;
  height: 43px;
  border-radius: 50px;
  background: var(--rose);
  color: #fff;
  font-size: 13px;
}

.concerns_section {
  position: relative;
  z-index: 2;
  box-sizing: border-box;
  overflow: hidden;
  background: #fff;
}
.concerns_inner {
  position: relative;
  height: 100%;
  background-image: url("https://immune-plus.net/system_panel/uploads/images/concern_bg.png");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
}
.concerns_title {}
.concerns_title h2 {
  margin: 0;
  font-family: "Zen Old Mincho", serif;
  font-size: 32px;
  font-weight: 400;
  line-height: 39.4px;
}
.concerns_title p {
  margin: 8px 0 0;
  font-size: 16px;
  line-height: 29px;
}
.concerns_map {
  text-align: center;
}
.concerns_map > img {
  width: 80%;
  margin: 0 auto;
}
.concern {
  position: absolute;
  box-shadow: 0 4px 14px rgba(59, 54, 48, .08);
  font-size: 13px;
  border-radius: 200px;
}
.concern::after {
  content: "";
  position: absolute;
  top: 70%;
  width: 40px;
  aspect-ratio: 1 / 1;
  background-position: top center;
  background-repeat: no-repeat;
  background-size: 100% auto;
  transition: ease 0.3s;
}
.concern:hover::after {}
.concern01::after, .concern02::after, .concern03::after {
  background-image: url("https://immune-plus.net/system_panel/uploads/images/concern_item1.svg");
  right: 5%;
}
.concern04::after, .concern05::after, .concern06::after {
  background-image: url("https://immune-plus.net/system_panel/uploads/images/concern_item2.svg");
  left: 5%;
}
.concern a {
  box-sizing: border-box;
  min-width: 120px;
  height: 60px;
  padding: 15px 30px;
  border-radius: 200px;
  background: #fff;
  position: relative;
  z-index: 2;
}
.concern01 {
  top: 110px;
  left: 0
}
.concern02 {
  top: 220px;
  left: -40px
}
.concern03 {
  top: 330px;
  left: 10px
}
.concern04 {
  top: 90px;
  right: 5px
}
.concern05 {
  top: 200px;
  right: -35px
}
.concern06 {
  right: 25px;
  top: 310px;
}
.concerns_buttons {
  display: flex;
  gap: 10px;
}
@media screen and (max-width: 1080px) {
  .concerns_map > img {
    width: 80%;
    margin: 0 auto;
    padding: 10% 0;
  }
  .concern01 {
    top: 70px;
    left: 0
  }
  .concern02 {
    top: 180px;
    left: -40px
  }
  .concern03 {
    top: 290px;
    left: 10px
  }
  .concern04 {
    top: 50px;
    right: 5px
  }
  .concern05 {
    top: 160px;
    right: -35px
  }
  .concern06 {
    right: 25px;
    top: 270px;
  }
}
@media screen and (max-width:767px) {
  .concerns_section {}
  .concerns_inner {}
  .concerns_title {}
  .concerns_title h2 {
    font-size: 28px;
  }
  .concerns_map {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 10px;
  }
  .concerns_map > img {
    width: 100%;
  }
  .concerns_map .more_bt2 {
    width: calc(50% - 10px / 2)
  }
  .concerns_map .more_bt2 a {
    width: 100%;
    padding: 8px 10px;
    height: 40px;
  }
  .concern {}
  .concern01 {
    top: 15px;
    left: 20px
  }
  .concern02 {
    top: 90px;
    left: 0
  }
  .concern03 {
    top: 350px;
    left: 20px
  }
  .concern04 {
    top: 15px;
    right: 12px
  }
  .concern05 {
    top: 105px;
    right: 0
  }
  .concern06 {
    right: 20px;
    bottom: 30px
  }
  .concerns_buttons {
    padding-top: 50px;
    display: grid;
  }
  .concerns_buttons .pill_bt:last-child {
    grid-column: 1/3;
  }
  .concerns_map > img {
    width: 100%;
    margin: 0 auto;
    padding: 0;
  }
  .concern01 {
    top: 70px;
    left: 0
  }
  .concern02 {
    top: 180px;
    left: -40px
  }
  .concern03 {
    top: 290px;
    left: 10px
  }
  .concern04 {
    top: 50px;
    right: 5px
  }
  .concern05 {
    top: 160px;
    right: -35px
  }
  .concern06 {
    right: 25px;
    top: 270px;
  }
  .concern {
    position: static;
  }
  .concern::after {
    display: none;
  }
  .concerns_buttons {}
}
.product_section {
  position: relative;
  box-sizing: border-box;
  overflow: hidden;
  background: #F4EFED;
}
.product_head {
  box-sizing: border-box;
  padding-top: 0;
}
.product_head .section_title {
  padding-top: 0;
}
.product_scroll {
  /*
  width: max-content;
  */
  width: 100%;
}
.product_scroll .slick-track {
  display: flex;
}
.product_item {
  box-sizing: border-box;
  width: 270px;
  margin-right: 20px;
}
.product_item > div {
width: 100%;
    aspect-ratio: 1 / 1;
    height: auto;
    background: transparent;
}

.product_item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.product_item h3 {
  margin: 17px 0 7px;
  font-size: 20px;
  font-weight: 400;
  line-height: 24px;
}
.product_item p {
  margin: 10px 0;
  font-size: 16px;
  line-height: 24px;
}
.product_item .product_price {
  font-family: "Lato", sans-serif;
  font-size: 18px;
  line-height: 29px;
}
.product_banners {
  gap: 20px 40px;
  max-width: 1140px;
  margin-left: auto;
  margin-right: auto;
}
.product_banners a {
  width: calc(50% - 40px / 2)
}
.product_banners img {
  margin-bottom: 10px;
}
.product_banners p {
  font-weight: 500;
  font-size: 20px;
}
.product_more {
  position: absolute;
  top: 86px;
  right: 120px;
}
.product_more .more_bt {
  width: 162px;
  height: 32px;
  padding: 0;
  border-radius: 50px;
  background: #80625e;
  color: #fff;
  font-size: 11px;
  white-space: nowrap;
}
.product_more .more_bt > a, .salon_info .more_bt > a {
  color: #fff;
}
.product_more .more_bt p {
  margin: 0;
}
@media screen and (max-width:767px) {
  .product_section {
    ;
  }
  .product_head {
    padding: 0;
    margin: 0 auto;
  }
  .product_scroll {
    margin: 50px 0 0 30px;
  }
  .product_item {
    width: 270px;
    margin-right: 20px;
  }
  .product_more {}
  .product_banners {
    gap: 20px 20px;
    max-width: 550px;
  }
  .product_banners a {
    width: 100%
  }
  .product_banners p {
    font-weight: 500;
    font-size: 16px;
  }
}
.voice_section {
  background-color: #F4EFED;
}
.voice_section .webgene-blog .webgene-item {}
.voice_section .webgene-blog .webgene-item a {
  width: 80vw;
  padding: 0 5%;
  box-sizing: border-box;
  gap: 40px;
  align-items: flex-start;
}
.voice_section .webgene-blog .webgene-item a .imgbox {
  width: 100px;
  border: 1px solid #C7965D;
  border-radius: 50%;
  padding: 6px;
  box-sizing: border-box;
}
.voice_section .webgene-blog .webgene-item a .txtbox {
  position: relative;
  width: calc(100% - 100px - 40px);
  background-color: #fff;
  border-radius: 10px;
  padding: 30px;
  box-sizing: border-box;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
}
.voice_section .webgene-blog .webgene-item a .txtbox h3 {
  color: #C7965D;
  font-family: "Zen Old Mincho", serif;
}
.voice_section .webgene-blog .webgene-item a .txtbox::after {
  content: "";
  position: absolute;
  top: 25px;
  left: 0;
  transform: translateX(-100%);
  width: 0;
  height: 0;
  border-style: solid;
  border-top: 11px solid transparent;
  border-bottom: 11px solid transparent;
  border-right: 20px solid #ffffff;
  border-left: 0;
}
.voice_section .webgene-blog .webgene-item a .txtbox .more_txt {
  gap: 10px;
}
.voice_section .webgene-blog .webgene-item a .txtbox .more_txt .icon {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 1px solid #707070;
  transition: ease 0.3s;
}
.voice_section .webgene-blog .webgene-item a:hover .txtbox .more_txt .icon {
  transform: translateX(3px);
}
.voice_section .slick-list {
  overflow: inherit !important;
}
.voice_section .webgene-blog .webgene-item a .imgbox img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 50%;
}
@media screen and (max-width:767px) {
  .voice_section .webgene-blog .webgene-item a {
    width: calc(100vw - 40px);
    padding: 0 5%;
    gap: 20px;
  }
  .voice_section .webgene-blog .webgene-item a .imgbox {
    width: 70px;
    border: 1px solid #C7965D;
    border-radius: 50%;
    padding: 6px;
    box-sizing: border-box;
  }
  .voice_section .webgene-blog .webgene-item a .txtbox {
    position: relative;
    width: calc(100% - 70px - 20px);
    background-color: #fff;
    border-radius: 10px;
    padding: 15px;
    box-sizing: border-box;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.1);
  }
  .voice_section .webgene-blog .webgene-item a .txtbox::after {
    content: "";
    position: absolute;
    top: 25px;
    left: 0;
    transform: translateX(-100%);
    width: 0;
    height: 0;
    border-style: solid;
    border-top: 5px solid transparent;
    border-bottom: 5px solid transparent;
    border-right: 10px solid #ffffff;
    border-left: 0;
  }
}
@media screen and (max-width:1366px) {
  .lower_cta {
    grid-template-columns: minmax(80px, 180px) minmax(0, 1fr) minmax(320px, 420px);
  }
  .lower_cta .salon_panel_main p {
    bottom: 58px;
  }

}
.salon_section {
  box-sizing: border-box;
  overflow: hidden;
  background: #E5D4CA;
  position: relative;
  padding-left: 18%;
}
.salon_main {
  width: 45%;
  position: relative;
}
.salon_sub {
  position: absolute;
  top: 0;
  left: 0;
  width: 18%;
  height: 100%;
}
.salon_sub img {
  opacity: .7;
}
.salon_info {
  box-sizing: border-box;
  color: var(--ink);
  width: 55%;
  padding: 0 5%;
}
.salon_main p {
  position: absolute;
  left: -15%;
  bottom: -70px;
  margin: 0;
  color: #fff;
  font-family: "Cormorant Infant", serif;
  font-size: 90px;
  font-weight: 700;
  line-height: 84px;
  white-space: nowrap;
}
.salon_title h2 {
  margin: 0 0 52px;
  font-family: "Zen Old Mincho", serif;
  font-size: 25px;
  font-weight: 400;
}
.salon_data > div {
  margin-bottom: 20px;
}
.salon_data p {
  margin: 0;
  font-size: 15px;
  line-height: 27px;
}
.salon_data p:first-child {
  font-family: "Cormorant Infant", serif;
  font-size: 20px;
}
.reserve_section {
  display: none;
}
@media screen and (max-width:767px) {
  .salon_section {
    padding-left: 0px;
    justify-content: center;
  }
  .salon_visual {
    position: absolute;
    right: 0;
    width: 300px;
    height: 405px;
    grid-template-columns: 1fr;
  }
  .salon_sub {
    display: none;
  }
  .salon_main {
    width: 80%;
    margin-left: 20%;
  }
  .salon_info {
    width: 95%;
    max-width: 95%;
  }
  .salon_main p {
    font-size: clamp(42px, 5vw, 60px);
    line-height: 54px;
    bottom: 0;
  }
  .salon_title h2 {
    margin-bottom: 20px;
    font-size: 20px;
    margin-top: 20px;
  }
  .salon_data p {
    font-size: 13px;
    line-height: 22px;
  }
  .salon_data p:first-child {
    font-size: 18px;
  }
  .salon_info .more_bt {
    margin: 35px auto 0;
  }
}
@media screen and (min-width:768px) and (max-width:1366px) {
  .salon_section {
    grid-template-columns: minmax(0, 1fr) minmax(360px, 420px);
  }
  .salon_visual {
    grid-template-columns: minmax(150px, 210px) minmax(0, 1fr);
  }
  .salon_main p {
    font-size: clamp(68px, 6vw, 90px);
    line-height: clamp(62px, 5.7vw, 84px);
  }
}
/* slider primitives */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  user-select: none;
  touch-action: pan-y;
}
.slick-list {
  position: relative;
  display: block;
  margin: 0;
  padding: 0;
}
.slick-track {
  position: relative;
  top: 0;
  left: 0;
  display: block;
  margin-right: auto;
  margin-left: auto;
}
.slick-track::before, .slick-track::after {
  display: table;
  content: "";
}
.slick-track::after {
  clear: both;
}
.slick-slide {
  display: none;
  float: left;
  height: 100%;
  min-height: 1px;
}
.slick-initialized .slick-slide {
  display: block;
}
.sc-anime {
  opacity: 1;
  transform: none;
}
@media screen and (max-width:767px) {
  /*
	.width-1200-max,.width-1080-max{width:330px;}
	*/
  .pc_br {
    display: none;
  }
  .section_title > p {
    font-size: 48px;
    line-height: 44px;
  }
  .section_title > h2 {
    font-size: 18px;
    line-height: 32px;
  }
  .header {
    height: 60px;
  }
  .header_inner {
    height: 60px;
    padding-left: 20px;
  }
  .header_logo {
    width: 110px;
  }
  .header_right {
    height: 60px;
  }
  .header_open {
    display: none;
  }
  .header_lang {
    width: 44px;
    height: 60px;
    border-right: 0;
  }
  .header_lang_list {
    right: 0;
    min-width: 104px;
    padding: 10px 0;
  }
  .header_lang_list > a {
    min-height: 34px;
    padding: 0 14px;
  }
  .header_lang_list > a > p {
    font-size: 11px;
  }
  .menu-bt {
    width: 48px;
    height: 60px;
  }
  .more_bt > a {
    padding: 6px 20px 5px;
  }
  .menu-bt > p {
    left: 14px;
  }
  .menu-bt > p:first-of-type {
    top: 24px;
  }
  .menu-bt > p:last-of-type {
    top: 35px;
  }
  .menu-bt.active > p:first-of-type, .menu-bt.active > p:last-of-type {
    top: 30px;
  }
  .menu-wrap {
    padding: 85px 30px 75px;
  }
  .menu_head img {
    width: 145px;
  }
  .menu_nav {
    grid-template-columns: 1fr;
    margin-top: 35px;
  }
  .menu_nav > a {
    min-height: 72px;
  }
  .menu_nav p {
    font-size: 16px;
  }
  .menu_contact {
    display: grid;
    grid-template-columns: 1fr 1fr;
    margin-top: 30px;
  }
  .menu_contact a {
    width: auto;
    height: 44px;
    font-size: 12px;
  }
  .fixed_links {
    top: auto;
    right: 0;
    bottom: 0;
    z-index: 1100;
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: 100%;
    height: 52px;
  }
  .fixed_links a {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: row;
    width: auto;
    height: 52px;
    padding: 0;
    color: #fff;
    writing-mode: horizontal-tb;
    min-height: auto;
  }
  .fixed_links p {
    margin: 0 0 0 9px;
    font-size: 15px;
    writing-mode: horizontal-tb;
  }
  .fixed_links i {
    margin: 0;
  }
  .lower_main, .about_main, .setmenu_main, .fullmenu_main, .salon_page, .contact_page {
    padding-top: 60px;
  }
  .about_page_hero, .setmenu_hero, .fullmenu_hero, .salon_hero, .post_hero, .news_hero, .detail_hero, .contact_hero {
    height: 376px;
  }
  .about_page_hero > div, .setmenu_hero > div, .fullmenu_hero > div, .salon_hero > div, .post_hero > div, .news_hero > div, .detail_hero > div, .contact_hero > div {
    top: auto;
    bottom: 36px;
    left: 30px;
    transform: none;
  }
  .about_page_hero p, .setmenu_hero p, .fullmenu_hero p, .salon_hero p, .post_hero p, .news_hero p, .detail_hero p, .contact_hero p {
    font-size: 38px;
    line-height: 44px;
  }
  .about_page_hero h1, .setmenu_hero h1, .fullmenu_hero h1, .salon_hero h1, .post_hero h1, .news_hero h1, .detail_hero h1, .contact_hero h1 {
    margin-top: 0;
    font-size: 15px;
    line-height: 32px;
  }
  .lower_cta {
    display: block;
    height: 993.58px;
    background: #f3e9e4;
  }
  .lower_cta .salon_panel_sub {
    display: none;
  }
  .lower_cta .salon_panel_main {
    position: absolute;
    top: 0;
    right: 0;
    width: 300px;
    height: 405px;
  }
  .lower_cta .salon_panel_main p {
    left: -60px;
    bottom: 0;
    font-size: 57px;
    line-height: 54px;
  }
  .lower_cta .salon_guide {
    height: 993.58px;
    padding: 438px 30px 40px;
  }
  .lower_cta .salon_guide h2 {
    margin-bottom: 34px;
    font-size: 20px;
  }
  .lower_cta .salon_guide p {
    margin-bottom: 20px;
    font-size: 13px;
    line-height: 22px;
  }
  .lower_cta .salon_detail h3 {
    font-size: 18px;
  }
  .lower_cta .salon_guide > a {
    margin: 35px auto 0;
  }
  .lower_products {
    height: 1362px;
    padding-bottom: 75px;
  }
  .lower_products_head {
    width: 330px;
    padding-top: 72px;
  }
  .lower_products_head p {
    font-size: 48px;
  }
  .lower_products_list {
    display: flex;
    margin: 65px 0 0 30px;
  }
  .lower_products_list a {
    width: 210px;
    margin-right: 20px;
  }
  .lower_products_list img {
    width: 210px;
    height: 210px;
  }
  .lower_products_list h3 {
    font-size: 15px;
  }
  .lower_products_list p {
    font-size: 12px;
  }
  .lower_link_banner {
    height: 525px;
    padding: 0 30px;
    text-align: center;
  }
  .lower_link_banner p {
    margin-bottom: 38px;
    font-size: 23px;
    line-height: 42px;
  }

}
.bg3 {
  background: #F3EFE4;
}
.txtwhite {
  color: #fff;
}
.color1 {
  color: #80625E;
}
.color2 {
  color: #C39720;
}
.color3 {}
.main-wrap {
  overflow: hidden;
}
.nowhite {
  white-space: nowrap;
}
.font400 {
  font-weight: 400;
}
.font500 {
  font-weight: 500;
}
.lineheight22 {
  line-height: 2.2;
  letter-spacing: 0.08em;
  font-weight: 400;
}
.mincho {
  font-family: "Zen Old Mincho", "游明朝", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Sawarabi Mincho", "serif";
}
.zenkaku {
  font-family: "Zen Kaku Gothic New", "Noto Sans", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important;
}
.fontco {
  font-family: "Cormorant Infant", "Zen Old Mincho", "游明朝", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Sawarabi Mincho", "serif";
}
.entitle0 {
  font-family: "Cormorant Infant", "Zen Kaku Gothic New", "Noto Sans", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: clamp(56px, 6vw, 72px);
  letter-spacing: 0.2em;
}
.footer_actions {
  grid-template-columns: 1fr 1fr;
  margin-top: 50px;
}
.entitle1 {
  font-family: "Cormorant Infant", "Zen Kaku Gothic New", "Noto Sans", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: clamp(40px, 4vw, 57px);
  letter-spacing: 0.2rem;
}
.entitle2 {
  font-family: "Cormorant Infant", "Zen Kaku Gothic New", "Noto Sans", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: clamp(34px, 5vw, 46px);
  letter-spacing: 0.1rem;
}
.entitle3 {
  font-family: "Cormorant Infant", "Zen Kaku Gothic New", "Noto Sans", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: clamp(22px, 3vw, 28px);
  letter-spacing: 0.1rem;
}
.entitle4 {
  font-family: "Cormorant Infant", "Zen Kaku Gothic New", "Noto Sans", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: clamp(18px, 3vw, 22px);
  letter-spacing: 0.1rem;
}
.default_title0 {
  font-size: clamp(48px, 5.6vw, 80px);
}
.default_title1 {
  font-size: clamp(28px, 3.2vw, 44px);
}
.default_title2 {
  font-size: clamp(26px, 3.0vw, 32px);
}
.default_title3 {
  font-size: clamp(18px, 2.8vw, 28px);
}
.default_title4 {
  font-size: clamp(18px, 1.8vw, 22px);
}
.default_txt1 {
  font-size: clamp(15px, 1.4vw, 18px);
}
.default_txt2 {
  font-size: clamp(12px, 1.2vw, 14px);
}
.default_txt3 {
  font-size: clamp(12px, 1.2vw, 14px);
}
.mg_b_1 {
  margin-bottom: 150px;
}
.mg_b_2 {
  margin-bottom: 100px;
}
.mg_b_3 {
  margin-bottom: 80px;
}
.mg_b_4 {
  margin-bottom: 50px;
}
.mg_b_5 {
  margin-bottom: 30px;
}
@media screen and (max-width: 1080px) {
  .mg_b_1 {
    margin-bottom: 100px;
  }
  .mg_b_2 {
    margin-bottom: 80px;
  }
  .mg_b_3 {
    margin-bottom: 60px;
  }
  .mg_b_4 {
    margin-bottom: 40px;
  }
  .mg_b_5 {
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 576px) {
  .mg_b_1 {
    margin-bottom: 80px;
  }
  .mg_b_2 {
    margin-bottom: 60px;
  }
  .mg_b_3 {
    margin-bottom: 50px;
  }
  .mg_b_4 {
    margin-bottom: 30px;
  }
  .mg_b_5 {
    margin-bottom: 20px;
  }
}
.mg_t_1 {
  margin-top: 150px;
}
.footer_actions a {
  font-size: 12px;
}
.mg_t_2 {
  margin-top: 100px;
}
.mg_t_3 {
  margin-top: 80px;
}
.mg_t_4 {
  margin-top: 50px;
}
.mg_t_5 {
  margin-top: 30px;
}
@media screen and (max-width: 1080px) {
  .mg_t_1 {
    margin-top: 100px;
  }
  .mg_t_2 {
    margin-top: 80px;
  }
  .copyright {
    bottom: 62px;
    font-size: 12px;
  }
  .mg_t_3 {
    margin-top: 60px;
  }
  .mg_t_4 {
    margin-top: 40px;
  }
  .mg_t_5 {
    margin-top: 30px;
  }
}
@media screen and (max-width: 576px) {
  .mg_t_1 {
    margin-top: 80px;
  }
  .mg_t_2 {
    margin-top: 60px;
  }
  .mg_t_3 {
    margin-top: 50px;
  }
  .mg_t_4 {
    margin-top: 30px;
  }
  .mg_t_5 {
    margin-top: 20px;
  }
}
.pd_wrap {
  padding: 150px 80px 0;
}
.pd_wrap_all {
  padding: 150px 80px 150px;
}
.pd_wrap_side {
  padding-left: 80px;
  padding-right: 80px;
}
.pd_wrap_t {
  padding-top: 150px;
}
.pd_wrap_b {
  padding-bottom: 150px;
}
.pd_wrap_tb {
  padding-top: 150px;
  padding-bottom: 150px;
}
@media screen and (max-width: 1280px) {
  .pd_wrap {
    padding: 150px 60px 0;
  }
  .pd_wrap_all {
    padding: 150px 60px 150px;
  }
  .pd_wrap_side {
    padding-left: 60px;
    padding-right: 60px;
  }
}
@media screen and (max-width: 768px) {
  .pd_wrap {
    padding: 100px 50px 0;
  }
  .pd_wrap_all {
    padding: 100px 50px 100px;
  }
  .pd_wrap_side {
    padding-left: 50px;
    padding-right: 50px;
  }
  .pd_wrap_t {
    padding-top: 100px;
  }
  .pd_wrap_b {
    padding-bottom: 100px;
  }
  .pd_wrap_tb {
    padding-top: 100px;
    padding-bottom: 100px;
  }
}
@media screen and (max-width: 576px) {
  .pd_wrap {
    padding: 80px 20px 0;
  }
  .pd_wrap_all {
    padding: 80px 20px 80px;
  }
  .pd_wrap_side {
    padding-left: 20px;
    padding-right: 20px;
  }
  .pd_wrap_t {
    padding-top: 80px;
  }
  .pd_wrap_b {
    padding-bottom: 80px;
  }
  .pd_wrap_tb {
    padding-top: 80px;
    padding-bottom: 80px;
  }
}
html {}
body {
  font-family: "Zen Kaku Gothic New", "Noto Sans JP", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  color: #3B3630;
}
body .bg_img_wrap {
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
body.on .bg_img_wrap .bg_img {
  display: none;
}
body .bg_img_wrap2 {
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
body.on .bg_img_wrap2 > img {
  display: none;
}
a {
  display: inline-block;
  transition: ease 0.3s;
}
a:hover {
  opacity: 0.5;
}
.font-medium {
  font-weight: 500;
}
.font-semibold {
  font-weight: 600;
}
.font-black {
  font-weight: 900;
}
.cate_wrap > .cate {
  padding-top: 150px;
}
/* ---------- common ---------- */
/* ---------- header ---------- */
.header {}
/* ---------- footer ---------- */
/* ANIME */
.sc-anime.topin.on {
  opacity: 0;
  transform: translateY(-50px);
}
.sc-anime.topin.on.active {
  animation-name: topin;
  animation-duration: 1.2s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
}
.sc-anime.bottomin.on {
  opacity: 0;
  transform: translateY(50px);
}
.sc-anime.bottomin.on.active {
  animation-name: bottomin;
  animation-duration: 1.2s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
}
.sc-anime.leftin.on {
  opacity: 0;
  transform: translateX(-50px);
}
.sc-anime.leftin.on.active {
  animation-name: leftin;
  animation-duration: 1.2s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
}
.sc-anime.rightin.on {
  opacity: 0;
  transform: translateX(50px);
}
.sc-anime.rightin.on.active {
  animation-name: rightin;
  animation-duration: 1.2s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
}
.sc-anime.fadein.on {
  opacity: 0;
}
.sc-anime.fadein.on.active {
  animation-name: fadein;
  animation-duration: 1.2s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
}
.sc-anime.blurin.on {
  opacity: 0;
  -ms-filter: blur(6px);
  filter: blur(6px);
}
.sc-anime.blurin.on.active {
  animation-name: blurin;
  animation-duration: 1.2s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
}
.sc-anime.blurin2.on {
  opacity: 0;
  transform: translateY(50px);
  -ms-filter: blur(6px);
  filter: blur(6px);
}
.sc-anime.blurin2.on.active {
  animation-name: blurin2;
  animation-duration: 1.2s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
}
@keyframes topin {
  0% {
    opacity: 0;
    transform: translateY(-50px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
@keyframes bottomin {
  0% {
    opacity: 0;
    transform: translateY(50px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
}
@keyframes leftin {
  0% {
    opacity: 0;
    transform: translateX(-50px);
  }
  100% {
    opacity: 1;
    transform: translateX(0px);
  }
}
@keyframes rightin {
  0% {
    opacity: 0;
    transform: translateX(50px);
  }
  100% {
    opacity: 1;
    transform: translateX(0px);
  }
}
@keyframes upin {
  0% {
    transform: translateY(100%);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeout {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes blurin {
  0% {
    opacity: 0;
    -ms-filter: blur(6px);
    filter: blur(6px);
  }
  100% {
    opacity: 1;
    -ms-filter: blur(0px);
    filter: blur(0px);
  }
}
@keyframes blurin2 {
  0% {
    opacity: 0;
    transform: translateY(50px);
    -ms-filter: blur(6px);
    filter: blur(6px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
    -ms-filter: blur(0px);
    filter: blur(0px);
  }
}
/* color */
.txt-color-normal {
  color: #000000;
}
.txt-white {
  color: #ffffff;
}
.txt-red {
  color: red;
}
.txt-color1 {
  color: #FFE93C
}
.txt-color2 {
  color: #F1F1E9
}
.txt-color3 {
  color: #021745
}
.txt-color4 {
  color: #EBF5E5
}
.bg-white {
  background-color: #ffffff;
}
.bg-black {
  background-color: black
}
.bg-color1 {
  background-color: #FFE93C
}
.bg-color2 {
  background-color: #F1F1E9
}
.bg-color3 {
  background-color: #021745
}
.bg-color4 {
  background-color: #EBF5E5
}
.border-color1 {
  border-color: #FFE93C
}
.border-color2 {
  border-color: #F1F1E9
}
.border-color3 {
  border-color: #021745
}
.border-color4 {
  border-color: #EBF5E5
}
.hvr-txt-color-normal:hover {
  color: #000000;
}
.hvr-txt-white:hover {
  color: #ffffff;
}
.hvr-txt-red:hover {
  color: red;
}
.hvr-txt-color1:hover {
  color: #FFE93C
}
.hvr-txt-color2:hover {
  color: #F1F1E9
}
.hvr-txt-color3:hover {
  color: #021745
}
.hvr-txt-color4:hover {
  color: #EBF5E5
}
.hvr-bg-white:hover {
  background-color: #ffffff;
}
.hvr-bg-black:hover {
  background-color: black
}
.hvr-bg-color1:hover {
  background-color: #FFE93C
}
.hvr-bg-color2:hover {
  background-color: #F1F1E9
}
.hvr-bg-color3:hover {
  background-color: #021745
}
.hvr-bg-color4:hover {
  background-color: #EBF5E5
}
.hvr-border-color1:hover {
  border-color: #FFE93C
}
.hvr-border-color2:hover {
  border-color: #F1F1E9
}
.hvr-border-color3:hover {
  border-color: #021745
}
.hvr-border-color4:hover {
  border-color: #EBF5E5
}
/* ---------- IEのみ ---------- */
@media all and (-ms-high-contrast: none) {}
/* ---------- 1280px ~ ---------- */
@media screen and (max-width: 1280px) {
  .pd_wrap {
    padding: 150px 60px 0;
  }
  .pd_wrap_all {
    padding: 150px 60px 150px;
  }
  .pd_wrap_side {
    padding-left: 60px;
    padding-right: 60px;
  }
  /* ---------- common ---------- */
  /* ---------- header ---------- */
  /* ---------- footer ---------- */
}
/* ---------- 1080px ~ ---------- */
@media screen and (max-width: 1080px) {
  /* ---------- common ---------- */
  /* ---------- header ---------- */
  /* ---------- footer ---------- */
}
/* ---------- 768px ~ ---------- */
@media screen and (max-width: 768px) {
  .pd_wrap {
    padding: 100px 50px 0;
  }
  .pd_wrap_all {
    padding: 100px 50px 100px;
  }
  .pd_wrap_side {
    padding-left: 50px;
    padding-right: 50px;
  }
  .cate_wrap > .cate {
    padding-top: 100px;
  }
  /* ---------- common ---------- */
  /* ---------- header ---------- */
  /* ---------- footer ---------- */
}
/* ---------- スマートフォン ---------- */
/* ---------- 576px ~ ---------- */
@media screen and (max-width: 576px) {
  .pd_wrap {
    padding: 80px 20px 0;
  }
  .pd_wrap_all {
    padding: 80px 20px 80px;
  }
  .pd_wrap_side {
    padding-left: 20px;
    padding-right: 20px;
  }
  .cate_wrap > .cate {
    padding-top: 80px;
  }
  /* ---------- common ---------- */
  /* ---------- header ---------- */
  /* ---------- footer ---------- */
}
/* ---------- 350px ~ ---------- */
@media screen and (max-width: 350px) {}