@charset "UTF-8";
/* Scss Document */
:root {
  --ease-ui: cubic-bezier(.16, .32, .11, 1);
}

html.is-swup-transition {
  scroll-snap-type: none !important;
  scroll-behavior: auto !important;
}

html {
  scroll-snap-type: y mandatory;
  scroll-behavior: smooth;
  --vw: 100vw;
}
html.preload {
  font-size: 1px !important;
}
html.preload * {
  transition: none !important;
  visibility: hidden;
  max-width: 100%;
}
@media (max-width: 561.98px) {
  html {
    font-size: calc(var(--vw) / 375);
  }
}
@media (min-width: 562px) and (max-width: 767.98px) {
  html {
    font-size: 1.5px;
  }
}
@media (min-width: 768px) and (max-width: 1599.98px) {
  html {
    font-size: calc(var(--vw) / 1280);
  }
}
@media (min-width: 1600px) {
  html {
    font-size: 1.25px;
  }
}
@media print {
  html {
    font-size: 0.2mm;
  }
}

[id] {
  scroll-margin-top: 110px;
}
@media screen and (min-width: 768px), print {
  [id] {
    scroll-margin-top: 170px;
  }
}

* {
  box-sizing: border-box;
}

body {
  font-size: 12rem;
  font-weight: 400;
  color: #303030;
  background: #fff;
  line-height: 1.8;
  -webkit-text-size-adjust: 100%;
  word-break: break-word;
  min-width: 320rem;
  font-family: "Noto Serif JP", "游明朝体", "Yu Mincho", "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "Times New Roman", serif;
  margin: 0;
  padding: 0;
  letter-spacing: -0.1rem;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: justify;
  overflow-y: scroll;
}
@media screen and (min-width: 768px), print {
  body {
    font-size: 14rem;
  }
}

html,
body {
  height: 100%;
}
html.modal-on,
body.modal-on {
  overflow: hidden;
}

body {
  display: flex;
  flex-direction: column;
}

main {
  flex: 1;
}

.transition-fade {
  transition: opacity 0.4s ease, transform 0.4s ease;
}

html.is-animating .transition-fade {
  opacity: 0;
}

a {
  color: #303030;
  text-decoration: none;
  will-change: transform, opacity;
  transform: translateZ(0);
}

p a {
  text-decoration-line: underline;
  text-decoration-style: dashed;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.3em;
  transition: text-decoration-color 0.3s;
  text-decoration-color: currentColor;
}
@media screen and (min-width: 768px), print {
  p a:hover {
    text-decoration-color: transparent;
  }
}

button,
input,
textarea,
select {
  color: #303030;
  font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Arial, sans-serif;
  font-size: 12rem;
}
@media screen and (min-width: 768px), print {
  button,
  input,
  textarea,
  select {
    font-size: 16rem;
  }
}

.en,
[lang=en] {
  font-family: "Old Standard TT", sans-serif;
  font-weight: 400;
  text-align: left;
}

@media screen and (min-width: 768px), print {
  .inner {
    width: 1152rem;
    margin: 0 auto;
  }
  .spOnly {
    display: none !important;
  }
  .pcTal {
    text-align: left !important;
  }
  .pcTar {
    text-align: right !important;
  }
  .pcTac {
    text-align: center !important;
  }
}
@media screen and (max-width: 767.98px) {
  .spTal {
    text-align: left !important;
  }
  .spTar {
    text-align: right !important;
  }
  .spTac {
    text-align: center !important;
  }
  .inner {
    width: 100%;
    padding: 0 16rem;
    box-sizing: border-box;
  }
  .pcOnly {
    display: none !important;
  }
}
.touchdevice .clickdeviceOnly {
  display: none;
}

.clickdevice .touchdeviceOnly {
  display: none;
}

section,
nav,
header,
footer,
article,
figure {
  margin: 0;
  padding: 0;
}

p {
  margin: 20rem 0;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: top;
}

mark {
  text-decoration-color: #f8ffa2;
  text-decoration: underline;
  text-decoration-thickness: 0.6em;
  text-underline-offset: -0.2em;
  -webkit-text-decoration-skip-ink: none;
          text-decoration-skip-ink: none;
}

i:has(svg) {
  line-height: 1px;
  display: inline-block;
}
i:has(svg) svg {
  width: 100%;
  aspect-ratio: 1;
  transition: translate 0.5s var(--ease-ui);
}

@media screen and (min-width: 768px), print {
  a:has([data-label]) {
    overflow: hidden;
    display: inline-block;
  }
  a:has([data-label]) > span {
    position: relative;
    display: block;
    transition: translate 0.5s var(--ease-ui);
  }
  a:has([data-label]) > span::after {
    content: attr(data-label);
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    translate: 0 100%;
  }
  a:has([data-label]):hover > span {
    translate: 0 -100%;
  }
}

.splide__arrow,
a:has(> i) {
  display: grid !important;
  grid-template-columns: 1fr 16rem;
  align-items: center;
  gap: 8rem;
  overflow: hidden;
}
.splide__arrow i,
a:has(> i) i {
  position: relative;
  aspect-ratio: 1;
  overflow: hidden;
  display: block;
}
.splide__arrow i svg,
a:has(> i) i svg {
  width: 100%;
  height: auto;
  fill: currentColor;
}
.splide__arrow i svg:nth-of-type(2),
a:has(> i) i svg:nth-of-type(2) {
  position: absolute;
  top: 0;
  left: 0;
  translate: -200% 0;
}
.splide__arrow .en,
a:has(> i) .en {
  translate: 0 0.2em;
}
.splide__arrow.back, .splide__arrow.splide__arrow--prev,
a:has(> i).back,
a:has(> i).splide__arrow--prev {
  grid-template-columns: 16rem 1fr;
}
.splide__arrow.back span, .splide__arrow.splide__arrow--prev span,
a:has(> i).back span,
a:has(> i).splide__arrow--prev span {
  order: 2;
}
.splide__arrow.back i, .splide__arrow.splide__arrow--prev i,
a:has(> i).back i,
a:has(> i).splide__arrow--prev i {
  transform: scaleX(-1);
}
.splide__arrow.back i svg, .splide__arrow.splide__arrow--prev i svg,
a:has(> i).back i svg,
a:has(> i).splide__arrow--prev i svg {
  transform: none;
}
@media screen and (min-width: 768px), print {
  .splide__arrow:hover i svg:nth-of-type(1),
  a:has(> i):hover i svg:nth-of-type(1) {
    translate: 200% 0;
  }
  .splide__arrow:hover i svg:nth-of-type(2),
  a:has(> i):hover i svg:nth-of-type(2) {
    translate: 0 0;
  }
}

a[target=_blank]:has(i) {
  grid-template-columns: 1fr 14rem;
  gap: 6rem;
}
a[target=_blank]:has(i) i {
  rotate: -45deg;
}

/*-----------------------------------------------------------------------------------*/
#header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 72rem;
  z-index: 300;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 16rem;
}
@media screen and (min-width: 768px), print {
  #header {
    height: 120rem;
    padding: 0 64rem;
    transition: height 0.8s;
  }
  .is-scrolled #header {
    height: 80rem;
  }
}
#header .logo {
  width: 108rem;
  margin: 0;
  font-size: 1px;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 768px), print {
  #header .logo {
    width: 168rem;
    transition: width 0.8s;
  }
  .is-scrolled #header .logo {
    width: 84rem;
  }
}

/*-----------------------------------------------------------------------------------*/
#gnavi {
  font-family: "Old Standard TT", sans-serif;
}
@media screen and (max-width: 767.98px) {
  #gnavi {
    display: flex;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.5s, color 0.4s;
    position: fixed;
    inset: 0;
    background: #fff;
    justify-content: center;
    align-items: start;
    flex-direction: column;
    box-sizing: border-box;
    padding: 16rem;
  }
  #gnavi.is-open {
    opacity: 1;
    pointer-events: all;
  }
  #gnavi.is-move {
    opacity: 1;
  }
  #gnavi a {
    color: currentColor;
  }
  #gnavi ul {
    margin: 0;
    padding: 0;
    list-style: none;
  }
  #gnavi ul.primary {
    font-size: 32rem;
  }
  #gnavi ul.secondary {
    font-size: 16rem;
    display: flex;
    gap: 24rem;
    margin-top: 32rem;
  }
  #gnavi ul li {
    margin: 0;
    padding: 0;
  }
}
@media screen and (min-width: 768px), print {
  #gnavi {
    display: flex;
    gap: 48rem;
    font-size: 16rem;
    line-height: 1.4;
  }
  #gnavi a {
    transition: color 0.8s;
  }
  .is-slide #gnavi a {
    color: #fff;
  }
  #gnavi ul {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    gap: 30rem;
  }
  #gnavi ul li {
    margin: 0;
    padding: 0;
  }
}

/*-----------------------------------------------------------------------------------*/
#footer {
  display: flex;
  justify-content: space-between;
  align-items: end;
  padding: 24rem 16rem;
  font-size: 11rem;
  z-index: 290;
  margin-top: 24rem;
}
@media screen and (min-width: 768px), print {
  #footer {
    font-size: 12rem;
    padding: 32rem 64rem;
  }
}
#footer ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
@media screen and (min-width: 768px), print {
  #footer ul {
    display: flex;
    gap: 24rem;
  }
}
#footer ul li {
  margin: 0;
  padding: 0;
}
#footer .copyright {
  font-family: "Old Standard TT", sans-serif;
  margin: 0;
}

@media screen and (max-width: 767.98px) {
  #contents {
    padding: 72rem 0 0;
  }
}

/*-----------------------------------------------------------------------------------*/
.menu-btn {
  width: 48rem;
  aspect-ratio: 1;
  text-align: center;
  border-radius: 100rem;
  display: flex;
  justify-content: center;
  align-items: center;
  border: none;
  background: none;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  outline: none;
  cursor: pointer;
  position: relative;
  z-index: 2;
  color: #303030;
  -webkit-tap-highlight-color: transparent;
}
.menu-btn svg {
  width: 100%;
  height: auto;
  aspect-ratio: 1;
}
.menu-btn path {
  transform-origin: center;
  transition: transform 0.3s, opacity 0.3s;
}
.menu-btn.is-active path:nth-of-type(1) {
  animation: burger1 0.3s linear;
  transform: rotate(15deg) translate(0%, 7.5%);
}
.menu-btn.is-active path:nth-of-type(2) {
  animation: burger2 0.3s linear;
  transform: rotate(-15deg) translate(0%, -7.5%);
}
.menu-btn.is-close path:nth-of-type(1) {
  animation: burger1-rev 0.3s linear;
  transform: rotate(0) translate(0%, 0%);
}
.menu-btn.is-close path:nth-of-type(2) {
  animation: burger2-rev 0.3s linear;
  transform: rotate(0) translate(0%, 0%);
}

@keyframes burger1 {
  0% {
    transform: rotate(0) translate(0%, 0%);
  }
  50% {
    transform: rotate(0) translate(0%, 7.5%);
  }
  100% {
    transform: rotate(15deg) translate(0%, 7.5%);
  }
}
@keyframes burger2 {
  0% {
    transform: rotate(0) translate(0%, 0%);
  }
  50% {
    transform: rotate(0) translate(0%, -7.5%);
  }
  100% {
    transform: rotate(-15deg) translate(0%, -7.5%);
  }
}
@keyframes burger1-rev {
  0% {
    transform: rotate(15deg) translate(0%, 7.5%);
  }
  50% {
    transform: rotate(0) translate(0%, 7.5%);
  }
  100% {
    transform: rotate(0) translate(0%, 0%);
  }
}
@keyframes burger2-rev {
  0% {
    transform: rotate(-15deg) translate(0%, -7.5%);
  }
  50% {
    transform: rotate(0) translate(0%, -7.5%);
  }
  100% {
    transform: rotate(0) translate(0%, 0%);
  }
}
/*-----------------------------------------------------------------------------------*/
.js-parallax {
  overflow: hidden;
  width: -moz-fit-content;
  width: fit-content;
}
.js-parallax img {
  width: 100%;
  height: auto;
}

/*-----------------------------------------------------------------------------------*/
.pagetitle {
  font-size: 20rem;
  margin: 0 0 8rem;
  line-height: 1.2;
}
@media screen and (min-width: 768px), print {
  .pagetitle {
    font-size: 40rem;
    margin: 0;
  }
}

/*-----------------------------------------------------------------------------------*/
@media screen and (min-width: 768px), print {
  .left-fix {
    display: grid;
    grid-template-columns: 1fr 570rem;
  }
}
@media screen and (min-width: 768px), print {
  .left-fix .fix-left__inner {
    position: sticky;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    box-sizing: border-box;
    height: var(--fix-h);
    padding: 120rem 0;
  }
}
@media screen and (min-width: 768px), print {
  .left-fix .fix-base {
    padding-top: 120rem;
  }
}

/*-----------------------------------------------------------------------------------*/
.splide__arrows {
  display: flex;
  justify-content: space-between;
  margin-top: 10rem;
}
@media screen and (min-width: 768px), print {
  .splide__arrows {
    display: none;
  }
}
.splide__arrow {
  background: none;
  position: static;
  width: auto;
  border-radius: 0;
  height: auto;
  opacity: 1;
  transform: none;
  font-size: 13rem;
}
.splide__arrow .en {
  translate: 0 0.15em;
}
.splide__pagination {
  bottom: 1rem;
  padding: 0;
  gap: 12rem;
}
@media screen and (min-width: 768px), print {
  .splide__pagination {
    justify-content: end;
    gap: 16rem;
    bottom: -24rem;
  }
}
.splide__pagination__page {
  background-color: #f3f3f3;
  width: 8rem;
  height: auto;
  aspect-ratio: 1;
  margin: 0;
  opacity: 1;
}
@media screen and (min-width: 768px), print {
  .splide__pagination__page {
    width: 6rem;
  }
}
.splide__pagination__page.is-active {
  background-color: #d9d9d9;
  transform: none;
}

/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
@media screen and (min-width: 768px), print {
  #top-kv {
    margin: 120rem 0 240rem;
  }
}
#top-kv .inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: end;
}
#top-kv figure:nth-of-type(1) {
  aspect-ratio: 343/257;
  width: 100%;
  margin-bottom: 8rem;
}
@media screen and (min-width: 768px), print {
  #top-kv figure:nth-of-type(1) {
    width: 860rem;
    margin-bottom: 16rem;
  }
}
#top-kv figure:nth-of-type(2) {
  aspect-ratio: 218/282;
  width: 218rem;
}
@media screen and (min-width: 768px), print {
  #top-kv figure:nth-of-type(2) {
    width: 568rem;
    order: 4;
  }
}
#top-kv figure:nth-of-type(3) {
  aspect-ratio: 117/218;
  width: 117rem;
}
@media screen and (min-width: 768px), print {
  #top-kv figure:nth-of-type(3) {
    width: 276rem;
    order: 2;
    align-self: start;
  }
}
#top-kv .text {
  margin: 48rem 0;
  width: 100%;
}
@media screen and (min-width: 768px), print {
  #top-kv .text {
    order: 3;
    width: 353rem;
    margin: 0 0 0 64rem;
  }
}
#top-kv .text h2 {
  margin: 0;
  line-height: 1.3;
  font-size: 34rem;
}
@media screen and (min-width: 768px), print {
  #top-kv .text h2 {
    font-size: 56rem;
    line-height: 1.1;
  }
}
#top-kv .text p {
  margin: 8rem 0 0;
  font-size: 13rem;
}
@media screen and (min-width: 768px), print {
  #top-kv .text p {
    margin: 24rem 0 0;
  }
}

#top-main {
  margin: 0 0 120rem;
}
@media screen and (min-width: 768px), print {
  #top-main {
    margin-bottom: 240rem;
  }
}
#top-main .inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: end;
}
#top-main figure:nth-of-type(1) {
  aspect-ratio: 343/393;
  width: 100%;
}
@media screen and (min-width: 768px), print {
  #top-main figure:nth-of-type(1) {
    width: 50%;
    order: 1;
  }
}
#top-main figure:nth-of-type(2) {
  aspect-ratio: 343/393;
  width: 100%;
}
@media screen and (min-width: 768px), print {
  #top-main figure:nth-of-type(2) {
    width: 50%;
    order: 2;
  }
}
#top-main figure:nth-of-type(3) {
  aspect-ratio: 176/278;
  width: 176rem;
}
@media screen and (min-width: 768px), print {
  #top-main figure:nth-of-type(3) {
    width: 276rem;
    margin-top: 16rem;
    align-self: start;
    order: 3;
  }
}
#top-main figure:nth-of-type(4) {
  aspect-ratio: 117/140;
  width: 117rem;
  margin: -100rem 0 0 auto;
}
@media screen and (min-width: 768px), print {
  #top-main figure:nth-of-type(4) {
    width: 276rem;
    padding-left: 500rem;
    margin-bottom: 16rem;
    box-sizing: content-box;
    margin: 200rem 0 16rem auto;
    align-self: start;
    order: 4;
  }
}
#top-main figure:nth-of-type(5) {
  aspect-ratio: 117/140;
  width: 117rem;
  margin: 0 0 0 auto;
}
@media screen and (min-width: 768px), print {
  #top-main figure:nth-of-type(5) {
    width: 276rem;
    order: 5;
  }
}
#top-main figure:nth-of-type(6) {
  aspect-ratio: 344/352;
}
@media screen and (max-width: 767.98px) {
  #top-main figure:nth-of-type(6) {
    width: 100%;
    margin: 0 0 8rem;
  }
}
@media screen and (min-width: 768px), print {
  #top-main figure:nth-of-type(6) {
    width: 860rem;
    margin-bottom: 56rem;
    order: 7;
  }
}
#top-main figure:nth-of-type(7) {
  aspect-ratio: 341/279;
}
@media screen and (max-width: 767.98px) {
  #top-main figure:nth-of-type(7) {
    width: 100%;
    margin: 0 0 8rem;
  }
}
@media screen and (min-width: 768px), print {
  #top-main figure:nth-of-type(7) {
    width: 860rem;
    order: 10;
  }
}
#top-main figure:nth-of-type(8) {
  aspect-ratio: 115/156;
}
@media screen and (max-width: 767.98px) {
  #top-main figure:nth-of-type(8) {
    width: 115rem;
    align-self: start;
    margin: 0 0 8rem;
  }
}
@media screen and (min-width: 768px), print {
  #top-main figure:nth-of-type(8) {
    width: 276rem;
    order: 8;
    margin-bottom: 56rem;
  }
}
#top-main figure:nth-of-type(9) {
  aspect-ratio: 218/266;
  width: 218rem;
}
@media screen and (min-width: 768px), print {
  #top-main figure:nth-of-type(9) {
    width: 276rem;
    order: 9;
    translate: 0 -96rem;
  }
}
#top-main figure:nth-of-type(10) {
  aspect-ratio: 115/102;
  width: 115rem;
  margin-top: -102rem;
}
@media screen and (min-width: 768px), print {
  #top-main figure:nth-of-type(10) {
    width: 276rem;
    order: 11;
    margin-top: -80rem;
  }
}
#top-main .text {
  margin: 48rem 0;
  width: 100%;
}
@media screen and (min-width: 768px), print {
  #top-main .text {
    margin: 200rem 0 80rem 0;
    display: flex;
    justify-content: end;
    order: 6;
  }
}
#top-main .text h2 {
  margin: 0;
  line-height: 1.3;
  font-size: 34rem;
}
@media screen and (min-width: 768px), print {
  #top-main .text h2 {
    font-size: 56rem;
  }
}
#top-main .text p {
  margin: 8rem 0 0;
  font-size: 13rem;
}

/*-----------------------------------------------------------------------------------*/
#top-look {
  margin-bottom: 150rem;
}
@media screen and (min-width: 768px), print {
  #top-look {
    margin-bottom: 240rem;
  }
}
#top-look h2 {
  font-size: 18rem;
  margin: 0 0 16rem;
}
@media screen and (min-width: 768px), print {
  #top-look h2 {
    font-size: 24rem;
    margin: 0 0 24rem;
  }
}
#top-look h2 a {
  margin: 0 auto;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (min-width: 768px), print {
  #top-look h2 a {
    margin: 0;
  }
}
@media screen and (max-width: 767.98px) {
  #top-look .splide {
    width: 225rem;
    margin: 0 auto;
  }
}
@media screen and (min-width: 768px), print {
  #top-look .splide {
    visibility: visible;
  }
  #top-look .splide__list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16rem;
  }
}
#top-look .splide__pagination {
  bottom: -32rem;
}

/*-----------------------------------------------------------------------------------*/
#top-news h2 {
  font-size: 32rem;
  margin: 0;
}
@media screen and (min-width: 768px), print {
  #top-news h2 {
    font-size: 40rem;
  }
}
#top-news .inner {
  position: relative;
}
@media screen and (min-width: 768px), print {
  #top-news .inner {
    min-height: 338rem;
  }
}
#top-news figure {
  aspect-ratio: 117/143;
  width: 117rem;
  margin-top: 24rem;
}
@media screen and (min-width: 768px), print {
  #top-news figure {
    width: 276rem;
    position: absolute;
    top: 0;
    right: 0;
    margin: 0;
  }
}
#top-news ul.news-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8rem;
}
@media screen and (min-width: 768px), print {
  #top-news ul.news-list {
    margin-right: 400rem;
  }
}
#top-news ul.news-list li {
  margin: 0;
  padding: 0;
}
#top-news ul.news-list a,
#top-news ul.news-list .nolink {
  font-size: 13rem;
  display: inline-grid;
  grid-template-columns: 6em 1fr;
}
@media screen and (min-width: 768px), print {
  #top-news ul.news-list a:hover i svg:nth-of-type(1),
  #top-news ul.news-list .nolink:hover i svg:nth-of-type(1) {
    translate: 200% 0;
  }
  #top-news ul.news-list a:hover i svg:nth-of-type(2),
  #top-news ul.news-list .nolink:hover i svg:nth-of-type(2) {
    translate: 0 0;
  }
}
#top-news ul.news-list h3:has(> i) {
  font-size: 13rem;
  margin: 0;
  display: inline-grid;
  grid-template-columns: 1fr 16rem;
  align-items: center;
  gap: 8rem;
  overflow: hidden;
  font-weight: 400;
}
#top-news ul.news-list h3:has(> i) i {
  position: relative;
  aspect-ratio: 1;
  overflow: hidden;
  display: block;
}
#top-news ul.news-list h3:has(> i) i svg {
  width: 100%;
  height: auto;
  fill: currentColor;
}
#top-news ul.news-list h3:has(> i) i svg:nth-of-type(2) {
  position: absolute;
  top: 0;
  left: 0;
  translate: -200% 0;
}
#top-news ul.news-list h3:has(> i) .en {
  translate: 0 0.2em;
}
#top-news ul.news-list h3:has(> i).back, #top-news ul.news-list h3:has(> i).splide__arrow--prev {
  grid-template-columns: 16rem 1fr;
}
#top-news ul.news-list h3:has(> i).back span, #top-news ul.news-list h3:has(> i).splide__arrow--prev span {
  order: 2;
}
#top-news ul.news-list h3:has(> i).back i, #top-news ul.news-list h3:has(> i).splide__arrow--prev i {
  transform: scaleX(-1);
}
#top-news ul.news-list h3:has(> i).back i svg, #top-news ul.news-list h3:has(> i).splide__arrow--prev i svg {
  transform: none;
}

/*-----------------------------------------------------------------------------------*/
#concept .concept-images {
  position: fixed;
  overflow: hidden;
  pointer-events: none;
  transition: inset 0.8s;
  inset: 120rem 50rem 50rem 50%;
  background: #babbb8;
}
.is-slide #concept .concept-images {
  inset: 0 0 0 50%;
}
#concept .concept-images figure {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1s ease;
}
#concept .concept-images figure.is-show {
  opacity: 1;
}
#concept .concept-images figure img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 767.98px) {
  #concept figure {
    margin: 0 auto 40rem;
  }
  #concept figure:nth-of-type(n+2) {
    width: 175rem;
    margin: 40rem auto;
  }
  #concept figure:last-child {
    margin-bottom: 24rem;
  }
}
@media screen and (min-width: 768px), print {
  #concept .section {
    height: 100vh;
    display: flex;
    align-items: center;
  }
  #concept .section:last-child {
    height: calc(100vh - 88rem);
  }
  #concept .section .section-inner {
    width: calc(50% - 170rem);
  }
}
#concept [lang=ja] {
  line-height: 2;
  margin: 2em 0;
}
@media screen and (max-width: 767.98px) {
  #concept [lang=ja] {
    font-size: 13rem;
    line-height: 1.8;
    margin: 1em 0;
  }
}
#concept [lang=en] {
  line-height: 1.5;
  font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Arial, sans-serif;
  margin: 2em 0;
}
@media screen and (max-width: 767.98px) {
  #concept [lang=en] {
    font-size: 12rem;
    margin: 1em 0;
  }
}

/*-----------------------------------------------------------------------------------*/
@media screen and (min-width: 768px), print {
  #contact-page .fix-base {
    min-height: 875rem;
  }
  body.iframe-thanks #contact-page .fix-base {
    min-height: 0;
  }
}

@media screen and (min-width: 768px), print {
  .form-wrap {
    min-height: calc(100% - 120rem);
    display: flex;
    align-items: center;
  }
}

/*-----------------------------------------------------------------------------------*/
@media screen and (min-width: 768px), print {
  #look {
    margin-bottom: 24rem;
  }
}
#look .collection-title {
  font-weight: 400;
  text-align: left;
}
@media screen and (max-width: 767.98px) {
  #look .collection-title {
    order: 3;
    font-size: 16rem;
    margin: 24rem 0;
  }
}
@media screen and (min-width: 768px), print {
  #look .collection-title {
    position: absolute;
    bottom: 32rem;
    left: 0;
    margin: 0 80rem 0 0;
  }
}
@media screen and (min-width: 768px), print {
  #look .fix-base {
    padding-bottom: 32rem;
  }
}
@media screen and (max-width: 767.98px) {
  #look .splide {
    order: 2;
  }
}
@media screen and (min-width: 768px), print {
  #look .splide {
    margin-left: auto;
  }
}

/*-----------------------------------------------------------------------------------*/
@media screen and (min-width: 768px), print {
  #news .left-fix {
    grid-template-columns: 1fr 840rem;
  }
}
#news ul.news-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16rem 8rem;
}
@media screen and (min-width: 768px), print {
  #news ul.news-list {
    margin-left: auto;
    grid-template-columns: repeat(3, 1fr);
    min-height: 548rem;
    gap: 40rem 16rem;
  }
}
#news ul.news-list li {
  margin: 0;
  padding: 0;
}
#news ul.news-list a {
  display: block;
}
@media screen and (min-width: 768px), print {
  #news ul.news-list a:hover img {
    scale: 105%;
  }
}
#news ul.news-list figure {
  overflow: hidden;
  margin-bottom: 4rem;
}
#news ul.news-list figure img {
  transition: scale 0.3s;
  aspect-ratio: 168/124;
  -o-object-fit: cover;
     object-fit: cover;
}
#news ul.news-list time {
  display: block;
}
#news ul.news-list h2 {
  font-size: 13rem;
  font-weight: 400;
  text-align: left;
  margin: 0;
}
#news nav {
  margin-top: 32rem;
}
@media screen and (min-width: 768px), print {
  #news nav {
    margin-top: 64rem;
  }
}
#news nav ul {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0;
  padding: 0;
  list-style: none;
  gap: 8rem;
}
#news nav ul li {
  margin: 0;
  padding: 0;
}
#news nav .page-numbers {
  opacity: 0.7;
}
#news nav .page-numbers.current {
  opacity: 1;
}

/*-----------------------------------------------------------------------------------*/
#news-detail time {
  font-size: 14rem;
  margin-top: 16rem;
}
#news-detail h1 {
  font-size: 16rem;
  font-weight: 400;
  margin: 0 0 24rem;
  text-align: left;
}
@media screen and (min-width: 768px), print {
  #news-detail h1 {
    margin: 0 80rem 0 0;
  }
}
#news-detail .eyecatch {
  padding: 0 32rem;
  margin: 8rem 0 16rem 0;
}
@media screen and (min-width: 768px), print {
  #news-detail .eyecatch {
    padding: 0;
    margin: 0 0 32rem;
  }
}
#news-detail .eyecatch img {
  aspect-ratio: 168/124;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (min-width: 768px), print {
  #news-detail .entry-meta {
    position: absolute;
    bottom: 32rem;
    left: 0;
  }
}
@media screen and (min-width: 768px), print {
  #news-detail .entry-body {
    padding-bottom: 32rem;
  }
}
#news-detail .entry-body > :first-child {
  margin-top: 0 !important;
}
#news-detail .entry-body > :last-child {
  margin-bottom: 0 !important;
}
#news-detail .entry-body h2 {
  font-weight: 400;
  font-size: 128%;
  margin: 32rem 0 24rem;
}

.entry-move {
  display: flex;
  justify-content: space-between;
  border-top: 1px solid #303030;
  padding-top: 16rem;
  margin-top: 32rem;
}
@media screen and (min-width: 768px), print {
  .entry-move {
    gap: 100rem;
    justify-content: end;
  }
}
@media screen and (min-width: 768px), print {
  .entry-move > div {
    display: none;
  }
  .entry-move > div:has(a) {
    display: block;
  }
}

/*-----------------------------------------------------------------------------------*/
@media screen and (min-width: 768px), print {
  #company {
    margin-bottom: -120rem;
  }
}
#company dl {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  font-size: 13rem;
  gap: 16rem;
}
@media screen and (min-width: 768px), print {
  #company dl {
    padding: 0 0 120rem;
    min-height: calc(100vh - 120rem);
  }
}
#company dl > div {
  display: grid;
  grid-template-columns: 110rem 1fr;
}
@media screen and (min-width: 768px), print {
  #company dl > div {
    grid-template-columns: 1fr 1fr;
  }
}
#company dl dt {
  margin: 0;
  padding: 0;
}
#company dl dd {
  margin: 0;
  padding: 0;
}

/*-----------------------------------------------------------------------------------*/
@media screen and (min-width: 768px), print {
  #privacypolicy .left-fix {
    grid-template-columns: 1fr 860rem;
  }
}
#privacypolicy h1 {
  font-size: 16rem;
  font-weight: 400;
  margin: 0 0 24rem;
}
@media screen and (min-width: 768px), print {
  #privacypolicy h1 {
    font-size: 18rem;
    margin: 0 0 64rem;
  }
}
#privacypolicy h2 {
  font-size: 13rem;
  font-weight: 400;
  margin: 32rem 0 0;
}
@media screen and (min-width: 768px), print {
  #privacypolicy h2 {
    font-size: 16rem;
    margin: 48rem 0 0;
  }
}

/*-----------------------------------------------------------------------------------*/
@media screen and (min-width: 768px), print {
  #notfound {
    margin-bottom: -120rem;
  }
}
@media screen and (min-width: 768px), print {
  #notfound .left-fix {
    grid-template-columns: 1fr 1000rem;
  }
}
@media screen and (min-width: 768px), print {
  #notfound .message {
    padding: 0 0 120rem;
    min-height: calc(100vh - 120rem);
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
}

/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*//*# sourceMappingURL=common.css.map */