@charset "UTF-8";
@font-face {
  font-family: "icomoon";
  src: url("../fonts/icomoon/fonts/icomoon.eot?366h7e");
  src: url("../fonts/icomoon/fonts/icomoon.eot?366h7e#iefix") format("embedded-opentype"), url("../fonts/icomoon/fonts/icomoon.ttf?366h7e") format("truetype"), url("../fonts/icomoon/fonts/icomoon.woff?366h7e") format("woff"), url("../fonts/icomoon/fonts/icomoon.svg?366h7e#icomoon") format("svg");
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
html {
  --font-base: "游ゴシック体",YuGothic,"游ゴシック Medium","Yu Gothic Medium","游ゴシック","Yu Gothic","ヒラギノ角ゴ ProN","Hiragino Kaku Gothic ProN",Verdana,"メイリオ",Meiryo,sans-serif;
  --font-min: "Yu Mincho Light","YuMincho","Yu Mincho","游明朝体","ヒラギノ明朝 ProN","Hiragino Mincho ProN",serif;
  --font-en: "Lato", sans-serif;
  --font-icon: "icomoon";
  --clr-Black: #000;
  --clr-Red: #CC382D;
  --clr-Gray: #D5D5D5;
  --bg-Gray: #f5f5f5;
}
@-webkit-keyframes anime_articleItem_title {
  0% {
    background-position: left 0 bottom;
  }
  50% {
    background-position: left -100% bottom;
  }
  100% {
    background-position: left -200% bottom;
  }
}
@keyframes anime_articleItem_title {
  0% {
    background-position: left 0 bottom;
  }
  50% {
    background-position: left -100% bottom;
  }
  100% {
    background-position: left -200% bottom;
  }
}
@-webkit-keyframes boundIn {
  0% {
    -webkit-transform: scale(0.3);
            transform: scale(0.3);
  }
  30% {
    -webkit-transform: scale(1.3);
            transform: scale(1.3);
  }
  60% {
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
  }
  80% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  0% {
    opacity: 0;
  }
  80% {
    opacity: 1;
  }
  100% {
    opacity: 1;
  }
}

.hero {
  color: white;
  position: relative;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (min-width: 750px) {
  .hero {
    background-position: right top;
  }
}
.hero.-bgNone {
  color: var(--clr-Black);
}
.hero.-bgNone .hero__inr {
  position: static;
}
@media screen and (min-width: 750px) {
  .hero.-bgNone .hero__inr {
    padding: 260px 0 140px;
  }
}
@media screen and (max-width: 749px) {
  .hero.-bgNone .hero__inr {
    padding: 2rem 0rem 0;
    height: 85.3333333333vw;
  }
}
.hero.-bgNone .hero__heading .sm {
  vertical-align: middle;
  -webkit-transform: translate(0, 115%);
          transform: translate(0, 115%);
}
.hero.-bgNone .hero__en {
  color: var(--clr-Red);
  opacity: 1;
  padding-left: 0;
}
.hero.-bgNone .hero__en::before {
  content: none;
}

.hero__inr {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-right: calc((100vw - 100%) / 2 * -1);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.02em;
  position: absolute;
}
@media screen and (max-width: 749px) {
  .hero__inr {
    height: 100%;
    border-radius: 2rem 0 0 2rem;
  }
}

.hero__heading {
  overflow: hidden;
}
@media screen and (min-width: 750px) {
  .hero__heading {
    font-size: 4.8rem;
  }
}
@media screen and (min-width: 750px) and (max-width: 1023px) {
  .hero__heading {
    font-size: 3.6rem;
  }
}
@media screen and (max-width: 749px) {
  .hero__heading {
    font-size: 3rem;
  }
}
.hero__heading > span {
  display: inline-block;
  -webkit-transform: translate(0, 105%);
          transform: translate(0, 105%);
  -webkit-transition: -webkit-transform cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
  transition: -webkit-transform cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
  transition: transform cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
  transition: transform cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s, -webkit-transform cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
  line-height: 1.2;
}
@media screen and (min-width: 750px) {
  .hero__heading .sm {
    font-size: 2.6rem;
  }
}
@media screen and (max-width: 749px) {
  .hero__heading .sm {
    font-size: 1.6rem;
  }
}

.hero__en {
  padding-left: 0.2em;
  font-family: var(--font-en);
  font-family: "Cormorant Garamond", serif;
  line-height: 1.2;
  position: relative;
}
.hero__en::before {
  content: "";
  background-color: #fff;
  display: block;
  position: absolute;
  left: 0;
  top: calc(50% - 0.5px);
  height: 1px;
}
@media screen and (min-width: 750px) {
  .hero__en {
    margin-top: 2.4rem;
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 749px) {
  .hero__en {
    font-size: 1.8rem;
    margin-top: 1.2rem;
    font-size: 1.5rem;
    padding-left: 10.6666666667vw;
  }
  .hero__en::before {
    width: 30px;
  }
}
.-bgNone .hero__en {
  font-family: var(--font-en);
}








.heading-a {
  position: relative;
  z-index: 1;
  font-weight: bold;
}
@media screen and (min-width: 750px) {
  .heading-a {
    padding: 0 0 0 2.4rem;
    font-size: 3rem;
  }
}
@media screen and (max-width: 749px) {
  .heading-a {
    padding: 0 0 0 1.6rem;
    font-size: 2rem;
  }
}
.heading-a::before {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  left: 0;
  border-radius: 50%;
  background: var(--clr-Red);
}
@media screen and (min-width: 750px) {
  .heading-a::before {
    top: 0.73em;
    width: 1rem;
    height: 1rem;
  }
}
@media screen and (max-width: 749px) {
  .heading-a::before {
    top: 0.68em;
    width: 0.8rem;
    height: 0.8rem;
  }
}

.breadcrumb {
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 750px) {
  .breadcrumb {
    margin-top: 2.4rem;
  }
}
@media screen and (max-width: 749px) {
  .breadcrumb {
    margin-top: 1.2rem;
  }
}

.breadcrumb__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow-x: auto;
  scrollbar-width: none;
  scrollbar-color: rgba(255, 255, 255, 0.2) transparent;
  scrollbar-width: thin;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
.breadcrumb__list::-webkit-scrollbar {
  height: 8px;
}
.breadcrumb__list::-webkit-scrollbar-track {
  background: transparent;
}
.breadcrumb__list::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.2);
  border-radius: 4px;
}
.breadcrumb__list::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.2);
}
.breadcrumb__list::-webkit-scrollbar {
  display: none;
}

.breadcrumb__item {
  line-height: 1;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
@media screen and (min-width: 750px) {
  .breadcrumb__item {
    font-size: 1.3rem;
  }
}
@media screen and (max-width: 749px) {
  .breadcrumb__item {
    font-size: 1.1rem;
  }
}
.breadcrumb__item + .breadcrumb__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.breadcrumb__item + .breadcrumb__item:before {
  content: "";
  display: inline-block;
  width: 1px;
  height: 90%;
  margin: 0 1.2rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  background: var(--clr-Black);
  -webkit-transform: rotate(30deg);
          transform: rotate(30deg);
}

.breadcrumb__anc {
  color: var(--clr-Red);
}
@media screen and (min-width: 750px) {
  .breadcrumb__anc:hover {
    text-decoration: underline;
  }
}


@media screen and (min-width: 750px) {
  .privacy_wrap {
    padding: 8rem 0 16rem;
  }
}
@media screen and (max-width: 749px) {
  .privacy_wrap {
    padding: 6rem 0 13rem;
  }
}


.privacy_nav li a {
  position: relative;
  font-weight: 700;
  line-height: 1;
  display: block;
  border-bottom: 1px solid #D5D5D5;
  padding: 1.5rem  2rem 1.5rem 0;
}
.privacy_nav li a i.arrow-down {
  padding-left: 1rem;
  position: absolute;
  right: 0;
  top: calc(50% - 1.5vw);
}
.privacy_nav li a i.arrow-down::after {
  content: "\e900";
  font-size: 1.1rem;
  font-family: var(--font-icon);
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
  color: var(--clr-Red);
  display: inline-block;
}

@media screen and (min-width: 750px) {
  .privacy_nav {
    display: flex;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 3rem;
  }
  .privacy_nav li a::after {
    content: "";
    width: 0;
    height: 1px;
    background-color: var(--clr-Red);
    display: block;
    position: absolute;
    left: 0;
    bottom: -1px;
    -webkit-transition: width 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: width 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  .privacy_nav li a i.arrow-down {
    top: calc(50% - 9px);
    -webkit-transform: translateY(0);
    transform: translateY(0);
    -webkit-transition: -webkit-transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: -webkit-transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1), -webkit-transform 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  .privacy_nav li a:hover {
    color: var(--clr-Red);
  }
  .privacy_nav li a:hover::after {
    width: 100%;
  }
  .privacy_nav li a:hover i.arrow-down {
    -webkit-transform: translateY(3px);
    transform: translateY(3px);
  }
}


.l-inner-lg {
  max-width: 1000px;
}
.privacy {
  margin-top: 9rem;
}
.privacy__lead {
    margin-top: 3rem;
}
.privacy__lead.txt_r {
  text-align: right;
}
.privacy__item {
  margin-top: 2.4rem;
}

.privacy__item span {
  font-size: 1.8rem;
  font-weight: 700;
  color: var(--clr-Red);
}
.privacy__item dt {
  font-weight: 700;
}
.privacy__item > dd > ol {
  margin-top: 2rem;
}
.privacy__item .sub__item {
  padding-left: 4rem;
  margin-top: 3rem;
}
.privacy__item  .sub__item .case ol {
  margin-left: 5rem;
}
.privacy__item  .sub__item .case ol li {
  margin-left: 1.5rem;
  text-indent: -1.5rem;
}
.privacy__item  .sub__item .case p {
    margin-left: 5rem;
    text-indent: -5rem;
}
ul.privacy__item > li {
  margin-top: 2rem;
  margin-left: 2.3rem;
  text-indent: -2.3rem;
}
@media screen and (min-width: 750px) {
  .privacy__item a[href*="tel:"]  {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
  }
}
@media screen and (max-width: 749px) {
  .privacy__item a[href*="tel:"]  {
    text-decoration: underline;
  }
  #announcement .privacy__content,
  #policy .privacy__content {
    margin-top: 3.5rem;
  }
  .privacy__item {
    margin-top: 0;
  }
  .privacy__item + .privacy__item {
    margin-top: 2rem;
  }
  .privacy__item dt {
    font-size: 1.6rem;
    margin-left: 2rem;
    text-indent: -2rem;
  }
  .privacy__item span {
    font-size: 1.6rem;
  }
  .privacy__item > dd > ol {
    margin-left: 1.5rem;
    text-indent: -1.5rem;
    margin-top: 2rem;
  }
  .privacy__item .sub__item {
    padding-left: 3rem;
  }
  .privacy__item .sub__item dt {
    font-size: 1.4rem;
    margin-left: 3rem;
    text-indent: -3rem;
  }
  .privacy__item .sub__item ol li {
    margin-left: 2rem;
    text-indent: -2rem;
  }
  .privacy__item  .sub__item .case {
    margin-top: 0.5rem;
  }
  .privacy__item  .sub__item .case ol {
    margin-left: 0rem;
    margin-top: 1rem;
  }
  .privacy__item  .sub__item .case ol.mar_l {
    margin-left: 4.5rem;
    margin-top: 0;
  }
  .privacy__item  .sub__item .case ol + p {
    margin-top: 1rem;
  }
  .privacy__item  .sub__item .case > ol:not(.mar_l) > li {
    margin-top: 0.5rem;
  }
  .privacy__item  .sub__item .case ul {
    margin-top: 1rem;
  }
  .privacy__item  .sub__item .case p {
    margin-left: 4.5rem;
    text-indent: -4.5rem;
  }
  ul.privacy__item > li {
    margin-top: 3.5rem;
    margin-left: 2rem;
    text-indent: -2rem;
  }
}