@charset "UTF-8";
/* Scss Document */
html {
  --vw: 100vw;
  scroll-snap-type: y mandatory;
  scroll-behavior: smooth;
  overflow-y: scroll;
}
html.preload {
  font-size: 1px !important;
}
html.preload * {
  transition: none !important;
  visibility: hidden;
  max-width: 100%;
}
@media (max-width: 562.98px) {
  html {
    font-size: calc(var(--vw) / 375);
  }
}
@media (min-width: 563px) 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: 80rem;
}
@media screen and (min-width: 768px), print {
  [id] {
    scroll-margin-top: 150rem;
  }
}

* {
  box-sizing: border-box;
}

body {
  font-size: 14rem;
  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 Sans JP", "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Arial, sans-serif;
  margin: 0;
  padding: 0;
  letter-spacing: -0.1rem;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: justify;
}
@media screen and (min-width: 768px), print {
  body {
    font-size: 16rem;
    line-height: 2;
  }
}

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

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

a.disabled {
  pointer-events: none !important;
  opacity: 0.3 !important;
}

p a,
dd a {
  text-decoration: underline;
  text-underline-offset: 2rem;
  text-decoration-color: currentColor;
  transition: text-decoration-color 0.3s, color 0.3s;
}
@media screen and (min-width: 768px), print {
  p a:hover,
  dd a:hover {
    color: rgba(48, 48, 48, 0.4);
    text-decoration-color: transparent;
  }
}

button,
input,
textarea,
select {
  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;
  }
}

@media screen and (min-width: 768px), print {
  .inner {
    width: 1024rem;
    margin: 0 auto;
  }
  .spOnly {
    display: none !important;
  }
  .pcTal {
    text-align: left;
  }
}
@media screen and (max-width: 767.98px) {
  .inner {
    width: 100%;
    padding: 0 24rem;
    box-sizing: border-box;
  }
  .pcOnly {
    display: none !important;
  }
}
.touchdevice .clickdeviceOnly {
  display: none;
}

.clickdevice .touchdeviceOnly {
  display: none;
}

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

article,
section {
  margin: 72rem 0;
}
@media screen and (min-width: 768px), print {
  article,
  section {
    margin: 144rem 0;
  }
}

p {
  margin: 16rem 0;
}
@media screen and (min-width: 768px), print {
  p {
    margin: 24rem 0;
  }
}

[lang=en],
.en {
  font-family: "Marcellus", "游明朝体", "Yu Mincho", "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "Times New Roman", serif;
  text-align: left;
  letter-spacing: 0.01em;
}

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;
  text-decoration-skip-ink: none;
}

i:has(svg) {
  line-height: 1px;
  vertical-align: middle;
}
i:has(svg) svg {
  width: 100%;
  aspect-ratio: 1;
  transition: fill 0.3s, stroke 0.3s;
}
i:has(svg) svg:has([href="#svg-arrow"]) {
  width: 18rem;
  height: 10rem;
}
i:has(svg) svg:has([href="#svg-external"]) {
  width: 12rem;
  height: 12rem;
  translate: 0 -10%;
  margin-left: 3rem;
}

/*-----------------------------------------------------------------------------------*/
#header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 300;
  display: flex;
  justify-content: space-between;
  padding: 8rem 11rem;
  align-items: end;
  gap: 8rem;
}
@media screen and (min-width: 768px), print {
  #header {
    padding: 24rem;
  }
}
#header .logo {
  margin: 0;
  padding: 0;
  width: 82rem;
  font-size: 1px;
}
@media screen and (min-width: 768px), print {
  #header .logo {
    width: 104rem;
  }
}
#header .cart-btn {
  margin-left: auto;
  width: 40rem;
  aspect-ratio: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: opacity 0.3s;
}
@media screen and (min-width: 768px), print {
  #header .cart-btn:hover {
    opacity: 0.4;
  }
}
#header .menu-btn {
  width: 40rem;
  aspect-ratio: 1;
  text-align: center;
  background-color: #303030;
  border-radius: 100rem;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
}
#header .menu-btn svg {
  width: 100%;
  height: 100%;
}
#header .menu-btn path {
  transform-origin: center;
  transition: transform 0.3s, translate 0.3s, opacity 0.3s;
}
#header .menu-btn:hover:not(.is-active) path:nth-of-type(1), #header .menu-btn:hover:not(.is-active) path:nth-of-type(2), #header .menu-btn:hover:not(.is-active) path:nth-of-type(3) {
  translate: 0 0.5rem;
}
#header .menu-btn:hover:not(.is-active) path:nth-of-type(4), #header .menu-btn:hover:not(.is-active) path:nth-of-type(5), #header .menu-btn:hover:not(.is-active) path:nth-of-type(6) {
  translate: 0 -0.5rem;
}
#header .menu-btn.is-active path:nth-of-type(1), #header .menu-btn.is-active path:nth-of-type(4) {
  animation: burger1 0.3s linear;
  transform: rotate(45deg) translate(0%, 15%);
}
#header .menu-btn.is-active path:nth-of-type(2), #header .menu-btn.is-active path:nth-of-type(5) {
  opacity: 0;
}
#header .menu-btn.is-active path:nth-of-type(3), #header .menu-btn.is-active path:nth-of-type(6) {
  animation: burger2 0.3s linear;
  transform: rotate(-45deg) translate(0%, -15%);
}
#header .menu-btn.is-close path:nth-of-type(1), #header .menu-btn.is-close path:nth-of-type(4) {
  animation: burger1-rev 0.3s linear;
  transform: rotate(0) translate(0%, 0%);
}
#header .menu-btn.is-close path:nth-of-type(3), #header .menu-btn.is-close path:nth-of-type(6) {
  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%, 15%);
  }
  100% {
    transform: rotate(45deg) translate(0%, 15%);
  }
}
@keyframes burger2 {
  0% {
    transform: rotate(0) translate(0%, 0%);
  }
  50% {
    transform: rotate(0) translate(0%, -15%);
  }
  100% {
    transform: rotate(-45deg) translate(0%, -15%);
  }
}
@keyframes burger1-rev {
  0% {
    transform: rotate(45deg) translate(0%, 15%);
  }
  50% {
    transform: rotate(0) translate(0%, 15%);
  }
  100% {
    transform: rotate(0) translate(0%, 0%);
  }
}
@keyframes burger2-rev {
  0% {
    transform: rotate(-45deg) translate(0%, -15%);
  }
  50% {
    transform: rotate(0) translate(0%, -15%);
  }
  100% {
    transform: rotate(0) translate(0%, 0%);
  }
}
/*-----------------------------------------------------------------------------------*/
#gnavi {
  display: none;
  position: fixed;
  inset: 0;
  background-color: #fff;
  z-index: 200;
  overflow: auto;
}
#gnavi .gnavi-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}
#gnavi ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
#gnavi ul li {
  margin: 0;
  padding: 0;
}
#gnavi ul.main {
  display: flex;
  flex-wrap: wrap;
  justify-content: start;
  gap: 32rem;
  font-size: 24rem;
  line-height: 1;
  padding-top: 100rem;
}
@media screen and (min-width: 768px), print {
  #gnavi ul.main {
    justify-content: center;
    font-size: 40rem;
    text-align: center;
    gap: 80rem;
    padding: 0;
  }
}
#gnavi ul.main small {
  font-size: 12rem;
  display: block;
  margin-top: 6rem;
}
@media screen and (min-width: 768px), print {
  #gnavi ul.main small {
    font-size: 14rem;
    margin-top: 8rem;
  }
}
@media screen and (max-width: 767.98px) {
  #gnavi ul.main li:nth-of-type(2) {
    margin-right: 20rem;
  }
}
#gnavi ul.sns {
  display: flex;
  gap: 16rem;
}
@media screen and (min-width: 768px), print {
  #gnavi ul.sns {
    gap: 0;
  }
}
#gnavi ul.sns li {
  width: 56rem;
}
@media screen and (max-width: 767.98px) {
  #gnavi ul.sns li:nth-of-type(1), #gnavi ul.sns li:nth-of-type(2) {
    width: 24rem;
  }
}
#gnavi ul.sns li img {
  object-fit: cover;
  height: 56rem;
}
#gnavi ul.sub {
  display: grid;
  gap: 16rem;
  line-height: 1;
  margin-top: 24rem;
}
@media screen and (min-width: 768px), print {
  #gnavi ul.sub {
    display: flex;
    gap: 48rem;
    margin-top: 0;
    padding-right: 24rem;
  }
}
#gnavi .gnavi-bottom {
  border-top: 1px solid #303030;
  padding: 16rem 0 0;
  margin: 48rem 0;
}
@media screen and (min-width: 768px), print {
  #gnavi .gnavi-bottom {
    border-bottom: 1px solid #303030;
    margin: 99rem 0 0;
    padding: 14rem 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}

/*-----------------------------------------------------------------------------------*/
.scroll {
  position: absolute;
  right: 10rem;
  top: 570rem;
  width: 90rem;
  aspect-ratio: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: "Inter", "Noto Sans JP", "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Arial, sans-serif;
  font-size: 10rem;
  letter-spacing: 0.05em;
  overflow: hidden;
}
@media screen and (min-width: 768px), print {
  .scroll {
    font-size: 14rem;
    right: 64rem;
    top: 526rem;
    width: 154rem;
  }
  .home .scroll {
    top: 640rem;
  }
}
.scroll::before {
  content: "";
  background: url(../images/scroll.svg) no-repeat center center/contain;
  width: 100%;
  aspect-ratio: 1;
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  animation: scroll-icon 100s linear;
}
.scroll i {
  position: absolute;
  left: 50%;
  top: 50%;
  rotate: 90deg;
  translate: -50% 260%;
}
@media screen and (max-width: 767.98px) {
  .scroll i {
    scale: 0.5;
    translate: -50% 130%;
  }
}

@keyframes scroll-icon {
  from {
    rotate: 0;
  }
  to {
    rotate: 360deg;
  }
}
/*-----------------------------------------------------------------------------------*/
#footer {
  background: #fff;
  padding: 32rem 24rem;
  border-top: 1px solid #E4E4E4;
}
@media screen and (min-width: 768px), print {
  #footer {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    padding: 48rem 64rem;
  }
}
#footer a {
  transition: color 0.3s;
}
@media screen and (min-width: 768px), print {
  #footer a:hover {
    color: color-mix(in srgb, currentColor 40%, transparent);
  }
}
#footer .logo {
  width: 114rem;
  margin-bottom: 40rem;
}
@media screen and (min-width: 768px), print {
  #footer .logo {
    width: 180rem;
    margin: 0;
  }
}
#footer ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
#footer ul li {
  margin: 0;
  padding: 0;
}
#footer nav ul {
  line-height: 1;
}
@media screen and (max-width: 767.98px) {
  #footer nav ul {
    column-gap: 32rem;
    columns: 2;
  }
}
@media screen and (min-width: 768px), print {
  #footer nav ul {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    align-content: flex-start;
    gap: 20rem 72rem;
    height: 99rem;
  }
}
#footer nav ul li {
  margin: 0 0 20rem;
}
@media screen and (min-width: 768px), print {
  #footer nav ul li {
    margin: 0;
  }
}
#footer nav a[target=_blank] span {
  width: 7.3em;
  display: inline-block;
}
#footer .footer-bottom {
  display: grid;
  margin-top: 20rem;
  gap: 16rem;
}
@media screen and (min-width: 768px), print {
  #footer .footer-bottom {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 80rem;
  }
}
#footer .footer-bottom ul.sub {
  display: grid;
  gap: 16rem;
  line-height: 1;
}
@media screen and (min-width: 768px), print {
  #footer .footer-bottom ul.sub {
    order: 2;
    display: flex;
    gap: 24rem;
  }
}
#footer .footer-bottom ul.sns {
  display: flex;
  gap: 16rem;
}
@media screen and (min-width: 768px), print {
  #footer .footer-bottom ul.sns {
    gap: 0;
  }
}
#footer .footer-bottom ul.sns li {
  width: 56rem;
}
@media screen and (max-width: 767.98px) {
  #footer .footer-bottom ul.sns li:nth-of-type(1), #footer .footer-bottom ul.sns li:nth-of-type(2) {
    width: 24rem;
  }
}
#footer .footer-bottom ul.sns li img {
  object-fit: cover;
  height: 56rem;
}

/*-----------------------------------------------------------------------------------*/
#contents {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0rem, rgb(255, 255, 255) 600rem, #fff 600rem);
}

/*-----------------------------------------------------------------------------------*/
h2.line {
  font-weight: 400;
  font-size: 1px;
  overflow: hidden;
  margin: 0 0 40rem;
}
@media screen and (min-width: 768px), print {
  h2.line {
    margin: 0 0 56rem;
  }
}
h2.line [lang=en] {
  font-size: 32rem;
  line-height: 0.95;
  width: fit-content;
  position: relative;
  display: block;
}
@media screen and (min-width: 768px), print {
  h2.line [lang=en] {
    font-size: 40rem;
  }
}
h2.line [lang=en]::after {
  content: "";
  display: block;
  width: 100vw;
  height: 1px;
  background: currentColor;
  position: absolute;
  right: -10rem;
  top: 50%;
  translate: 100% 0;
}
@media screen and (min-width: 768px), print {
  h2.line [lang=en]::after {
    right: -40rem;
  }
}
h2.line [lang=ja] {
  display: block;
  font-size: 14rem;
  line-height: 2;
}
@media screen and (min-width: 768px), print {
  h2.line [lang=ja] {
    font-size: 16rem;
  }
}

/*-----------------------------------------------------------------------------------*/
h2.line-s {
  line-height: 2;
  font-weight: 500;
  margin: 0 0 16rem;
  font-size: 18rem;
}
@media screen and (min-width: 768px), print {
  h2.line-s {
    font-size: 22rem;
    position: relative;
    margin-bottom: 40rem;
  }
}
h2.line-s::before {
  content: "";
  background-color: currentColor;
  height: 1px;
  width: 40rem;
  display: block;
  margin: 0 0 16rem -24rem;
}
@media screen and (min-width: 768px), print {
  h2.line-s::before {
    margin: 0;
    position: absolute;
    left: -64rem;
    top: 50%;
  }
}

/*-----------------------------------------------------------------------------------*/
h2.feature,
h3.feature {
  margin: 0 0 40rem;
  padding: 4rem 0;
  text-align: center;
  border-top: 1px solid #303030;
  border-bottom: 1px solid #303030;
  font-size: 16rem;
  font-weight: 500;
}
@media screen and (min-width: 768px), print {
  h2.feature,
  h3.feature {
    font-size: 22rem;
    margin-bottom: 72rem;
    padding: 8rem 0;
  }
}

/*-----------------------------------------------------------------------------------*/
.pager a,
a.more {
  font-family: "Marcellus", "游明朝体", "Yu Mincho", "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "Times New Roman", serif;
  text-decoration: none;
  display: flex;
  justify-content: center;
  align-items: center;
  width: fit-content;
  gap: 10rem;
  color: currentColor;
}
.pager a i,
a.more i {
  transition: translate 0.3s;
}
@media screen and (min-width: 768px), print {
  .pager a:hover i,
  a.more:hover i {
    translate: 10rem 0;
  }
}

a.btn {
  background: #303030;
  color: #fff;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: 500;
  line-height: 1;
  font-weight: 18rem;
  height: 52rem;
  border: 1px solid #303030;
}
@media screen and (min-width: 768px), print {
  a.btn {
    transition: background-color 0.3s, color 0.3s;
    width: 337rem;
    height: 52rem;
  }
  a.btn:hover {
    background: #fff;
    color: #303030;
  }
}
a.btn i {
  position: absolute;
  top: 50%;
  right: 20rem;
  translate: 0 -50%;
  transition: fill 0.3s;
}

/*-----------------------------------------------------------------------------------*/
.inview._fadein {
  translate: 0 50rem;
  opacity: 0;
  transition: opacity 1.5s, translate 1.5s;
}
@media screen and (min-width: 768px), print {
  .inview._fadein {
    translate: 0 80rem;
  }
}
.inview.is-show {
  opacity: 1;
  translate: 0 0;
}

/*-----------------------------------------------------------------------------------*/
#pagetitle {
  margin: 67rem 0 -50rem;
  position: relative;
  z-index: 195;
}
@media screen and (min-width: 768px), print {
  #pagetitle {
    margin: 114rem 0 -72rem;
  }
  #pagetitle:has(figure) {
    margin: 114rem 0 180rem;
  }
}
#pagetitle h1,
#pagetitle .title {
  text-align: center;
  margin: 0 0 14rem;
  padding: 0;
  font-weight: 400;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 768px), print {
  #pagetitle h1,
  #pagetitle .title {
    margin-bottom: -23rem;
  }
}
#pagetitle h1 .ja,
#pagetitle h1 [lang=ja],
#pagetitle .title .ja,
#pagetitle .title [lang=ja] {
  line-height: 1.2;
  font-size: 14rem;
  margin-bottom: 8rem;
  display: block;
}
@media screen and (min-width: 768px), print {
  #pagetitle h1 .ja,
  #pagetitle h1 [lang=ja],
  #pagetitle .title .ja,
  #pagetitle .title [lang=ja] {
    font-size: 16rem;
    margin-bottom: 9rem;
  }
}
#pagetitle h1 .en,
#pagetitle h1 [lang=en],
#pagetitle .title .en,
#pagetitle .title [lang=en] {
  line-height: 1;
  font-size: 34rem;
  display: block;
  text-align: center;
}
@media screen and (min-width: 768px), print {
  #pagetitle h1 .en,
  #pagetitle h1 [lang=en],
  #pagetitle .title .en,
  #pagetitle .title [lang=en] {
    font-size: 64rem;
  }
}
#pagetitle figure {
  display: grid;
  margin: 0 -24rem;
  grid-template-columns: 1fr 67rem;
  gap: 14rem;
}
@media screen and (min-width: 768px), print {
  #pagetitle figure {
    margin: 0 -64rem 0 -128rem;
    grid-template-columns: 843rem 273rem;
    justify-content: space-between;
  }
}
#pagetitle figure span {
  display: block;
  overflow: hidden;
}
#pagetitle figure img {
  opacity: 0;
  filter: brightness(1.5);
  scale: 110%;
  transition: opacity 2s, filter 2s, scale 2s;
}
.loaded #pagetitle figure img {
  opacity: 1;
  filter: brightness(1);
  scale: 100%;
}

/*-----------------------------------------------------------------------------------*/
@media screen and (max-width: 767.98px) {
  .anchor {
    margin: -100rem 0 32rem;
    padding-bottom: 16rem;
    padding-top: 64rem;
    position: sticky;
    top: 0;
    background: rgba(255, 255, 255, 0.9);
    z-index: 190;
  }
  .modal-on.is-anchor-sticky .anchor {
    position: fixed;
    top: 100rem;
    left: 24rem;
    right: 24rem;
  }
}
@media screen and (min-width: 768px), print {
  .anchor {
    margin-bottom: 96rem;
    padding-top: 16rem;
  }
}
.anchor ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16rem;
}
@media screen and (min-width: 768px), print {
  .anchor ul {
    display: flex;
  }
}
.anchor ul li {
  margin: 0;
  padding: 0;
  flex: 1 1 0;
}
.anchor a {
  display: block;
  text-align: center;
  border: 1px solid #303030;
  transition: background-color 0.3s, color 0.3s;
}
@media screen and (min-width: 768px), print {
  .anchor a:hover {
    background-color: #303030;
    color: #fff;
  }
}

/*-----------------------------------------------------------------------------------*/
#modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  transition: opacity 0.5s;
  z-index: 2500;
  opacity: 0;
  pointer-events: none;
}
#modal.active {
  pointer-events: all;
  opacity: 1;
}
#modal .modal-bg {
  background: rgba(0, 0, 0, 0.4);
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  width: 100%;
}
#modal .modal-close {
  position: absolute;
  top: 0;
  right: 0;
  cursor: pointer;
  line-height: 1;
  z-index: 100;
  width: 62rem;
  border: none;
  appearance: none;
  outline: none;
  background: none;
  padding: 0;
}
@media screen and (min-width: 768px), print {
  #modal .modal-close {
    width: 69rem;
    transition: opacity 0.3s;
  }
  #modal .modal-close:hover {
    opacity: 0.8;
  }
}
#modal .modal-close img {
  width: 100%;
}
#modal .modal-frame {
  width: calc(100% - 48rem);
  max-width: 1080rem;
  max-height: calc(100dvh - 48rem);
  position: relative;
  box-sizing: border-box;
  margin: 0 auto;
  background: #fff;
  display: none;
  pointer-events: none;
  overflow: auto;
  border: 1px solid #303030;
}
#modal .modal-frame.active {
  display: block;
  pointer-events: all;
}

/*-----------------------------------------------------------------------------------*/
.splide .my-arrows {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16rem;
  margin: 16rem 0 0;
}
@media screen and (min-width: 768px), print {
  .splide .my-arrows {
    justify-content: end;
  }
}
.splide .my-arrows .splide__arrow {
  border: none;
  background: none;
  outline: none;
  appearance: none;
  opacity: 1;
  position: static;
  transform: none;
  height: auto;
  width: auto;
}
.splide .my-arrows .splide__arrow i {
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 100rem;
  width: 43rem;
  aspect-ratio: 1;
  background: transparent;
  color: #303030;
  border: 1px solid #303030;
  transition: color 0.3s, background-color 0.3s;
}
@media screen and (min-width: 768px), print {
  .splide .my-arrows .splide__arrow i {
    width: 43rem;
    bottom: 5rem;
  }
}
@media screen and (min-width: 768px), print {
  .splide .my-arrows .splide__arrow:hover i {
    background: #303030;
    color: #fff;
  }
}

/*-----------------------------------------------------------------------------------*/
#kv #kvimage {
  position: fixed;
  top: 0;
  left: -33rem;
  right: -33rem;
  z-index: -1;
  text-align: center;
}
@media screen and (min-width: 768px), print {
  #kv #kvimage {
    left: 0;
    right: 0;
  }
}
#kv #kvimage > picture {
  position: absolute;
  inset: 0;
  display: block;
  opacity: 0;
  visibility: hidden;
  transition: opacity 500ms ease;
}
#kv #kvimage > picture.is-active {
  opacity: 1;
  visibility: visible;
}
#kv #kvimage > picture.is-in {
  opacity: 1;
  visibility: visible;
}
#kv #kvimage img {
  width: 408rem;
  max-width: none;
}
@media screen and (min-width: 768px), print {
  #kv #kvimage img {
    width: 618rem;
  }
}
#kv .catchcopy {
  font-family: "Marcellus", "游明朝体", "Yu Mincho", "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "Times New Roman", serif;
  font-size: 70rem;
  line-height: 0.75;
  width: fit-content;
  margin: 300rem auto 160rem;
  display: grid;
  gap: 0.25em;
}
@media screen and (min-width: 768px), print {
  #kv .catchcopy {
    font-size: 120rem;
    margin: 322rem 55rem 190rem;
  }
}
#kv .catchcopy span {
  display: block;
}
#kv .catchcopy span.mask {
  overflow: hidden;
}
#kv .catchcopy span.mask span {
  translate: 0 100%;
  transition: translate 1s;
}
.loaded #kv .catchcopy span.mask span {
  translate: 0;
}
#kv .catchcopy span.mask:nth-of-type(2) span {
  transition-delay: 0.3s;
}
#kv nav {
  position: absolute;
  right: 64rem;
  top: 330rem;
  font-family: "Inter", "Noto Sans JP", "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Arial, sans-serif;
}
#kv nav ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
}
#kv nav ul li {
  margin: 0;
  padding: 0;
}
#kv nav a {
  text-decoration: underline;
  text-underline-offset: 8rem;
  text-decoration-color: transparent;
  transition: text-decoration-color 0.3s, color 0.3s;
}
#kv nav a:hover {
  color: rgba(48, 48, 48, 0.4);
  text-decoration-color: #303030;
}
#kv #headline {
  padding: 0 24rem;
}
@media screen and (min-width: 768px), print {
  #kv #headline {
    padding: 0;
    margin: 0 64rem;
    line-height: 1.8;
  }
}
#kv #headline .label {
  font-family: "Inter", "Noto Sans JP", "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Arial, sans-serif;
  font-size: 16rem;
  font-weight: 500;
}
@media screen and (min-width: 768px), print {
  #kv #headline a {
    display: flex;
    gap: 1em;
  }
}
#kv #headline a time {
  display: block;
  white-space: nowrap;
}
#kv #headline a .title {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  margin-right: 90rem;
}
@media screen and (min-width: 768px), print {
  #kv #headline a .title {
    padding-right: 200rem;
  }
}

/*-----------------------------------------------------------------------------------*/
#top-about {
  position: relative;
  padding: 300rem 0;
}
@media screen and (min-width: 768px), print {
  #top-about {
    padding: 580rem 0 300rem;
  }
  #top-about .inner {
    position: relative;
  }
}
#top-about h2 {
  font-family: "Marcellus", "游明朝体", "Yu Mincho", "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "Times New Roman", serif;
  font-size: 40rem;
  font-weight: 400;
  line-height: 1;
  text-align: center;
  margin: 0;
}
@media screen and (min-width: 768px), print {
  #top-about h2 {
    font-size: 64rem;
  }
}
#top-about p {
  margin: 24rem 0;
}
@media screen and (min-width: 768px), print {
  #top-about p {
    text-align: center;
    font-size: 18rem;
  }
}
#top-about .more {
  margin: 0 auto;
}
@media screen and (min-width: 768px), print {
  #top-about .more {
    margin-top: 32rem;
  }
}
#top-about .js-parallax {
  overflow: hidden;
  position: absolute;
  aspect-ratio: 1;
  width: 137rem;
}
@media screen and (max-width: 767.98px) {
  #top-about .js-parallax:nth-of-type(1) {
    top: 100rem;
    right: 0;
  }
}
@media screen and (min-width: 768px), print {
  #top-about .js-parallax:nth-of-type(1) {
    width: 280rem;
    top: -210rem;
    right: -128rem;
  }
}
@media screen and (max-width: 767.98px) {
  #top-about .js-parallax:nth-of-type(2) {
    left: 0;
    bottom: 94rem;
  }
}
@media screen and (min-width: 768px), print {
  #top-about .js-parallax:nth-of-type(2) {
    top: 120rem;
    left: -128rem;
    width: 262rem;
  }
}
@media screen and (max-width: 767.98px) {
  #top-about .js-parallax:nth-of-type(3) {
    bottom: 0;
    right: 0;
  }
}
@media screen and (min-width: 768px), print {
  #top-about .js-parallax:nth-of-type(3) {
    bottom: -370rem;
    right: 0;
    width: 320rem;
  }
}
#top-about .js-parallax img {
  position: absolute;
  left: 0;
  top: 50%;
  width: 100%;
  height: 150%;
  object-fit: cover;
  transform: translate3d(0, 0, 0);
  translate: 0 -50%;
  will-change: transform;
}

/*-----------------------------------------------------------------------------------*/
#top-lineup ul {
  margin: -16rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 32rem;
}
@media screen and (min-width: 768px), print {
  #top-lineup ul {
    gap: 0;
  }
}
#top-lineup ul li {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 16rem;
}
@media screen and (min-width: 768px), print {
  #top-lineup ul li {
    gap: 0;
    grid-template-columns: repeat(2, 1fr);
  }
  #top-lineup ul li:nth-of-type(2n+1) figure {
    order: 1;
  }
  #top-lineup ul li:nth-of-type(2n+1) .text {
    order: 2;
    padding: 0 32rem 0 72rem;
  }
  #top-lineup ul li:nth-of-type(2n) .text {
    padding: 0 72rem 0 32rem;
  }
}
@media screen and (max-width: 767.98px) {
  #top-lineup figure {
    order: 1;
  }
}
@media screen and (max-width: 767.98px) {
  #top-lineup .text {
    order: 2;
  }
}
@media screen and (min-width: 768px), print {
  #top-lineup .text {
    display: flex;
    align-items: center;
  }
}
#top-lineup h3 {
  line-height: 1;
  margin: 0;
}
#top-lineup h3 [lang=en] {
  font-size: 24rem;
  display: block;
  font-weight: 400;
}
@media screen and (min-width: 768px), print {
  #top-lineup h3 [lang=en] {
    font-size: 48rem;
  }
}
#top-lineup h3 [lang=ja] {
  font-size: 14rem;
  display: block;
  margin-top: 8rem;
  font-weight: 500;
}
@media screen and (min-width: 768px), print {
  #top-lineup h3 [lang=ja] {
    font-size: 16rem;
  }
}
#top-lineup .more {
  margin: 24rem 0 0 auto;
}
@media screen and (min-width: 768px), print {
  #top-lineup .more {
    margin-top: 32rem;
  }
}

/*-----------------------------------------------------------------------------------*/
#top-shop dl {
  margin: 0;
  padding: 0;
  border-bottom: 1px dashed #303030;
}
@media screen and (min-width: 768px), print {
  #top-shop dl {
    margin-top: -24rem;
    border: none;
  }
}
#top-shop dl > div {
  display: grid;
  gap: 4rem;
  padding: 20rem 0;
  border-top: 1px dashed #303030;
}
@media screen and (min-width: 768px), print {
  #top-shop dl > div {
    grid-template-columns: 230rem 1fr;
    gap: 64rem;
    align-items: center;
  }
}
#top-shop dl dt {
  margin: 0;
  padding: 0;
  font-family: "Inter", "Noto Sans JP", "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Arial, sans-serif;
  font-size: 18rem;
  line-height: 1.2;
  font-weight: 500;
}
@media screen and (min-width: 768px), print {
  #top-shop dl dt {
    font-size: 22rem;
  }
}
#top-shop dl dd {
  margin: 0;
  padding: 0;
  line-height: 1.4;
}
#top-shop .more {
  margin: 24rem auto 0;
}
@media screen and (min-width: 768px), print {
  #top-shop .more {
    margin: 24rem 0 0 auto;
  }
}

/*-----------------------------------------------------------------------------------*/
#top-service {
  margin: -32rem 0;
  background: #F8F6F6;
  padding: 40rem 0;
}
@media screen and (min-width: 768px), print {
  #top-service {
    margin: -88rem 0;
    padding: 72rem 0;
  }
}
#top-service h3 {
  margin: 0 0 32rem;
  font-weight: 400;
  line-height: 1.2;
}
@media screen and (min-width: 768px), print {
  #top-service h3 {
    margin: 0 0 48rem;
  }
}
#top-service h3 small {
  display: inline-block;
  font-size: 14rem;
  padding: 8rem 16rem;
  border: 1px solid #303030;
}
@media screen and (min-width: 768px), print {
  #top-service h3 small {
    font-size: 16rem;
    padding: 12rem 24rem;
  }
}
#top-service h3 span {
  margin-top: 12rem;
  display: block;
  font-size: 20rem;
}
@media screen and (min-width: 768px), print {
  #top-service h3 span {
    margin-top: 24rem;
    font-size: 24rem;
  }
}
#top-service h4 {
  font-size: 18rem;
  font-weight: 400;
  margin: 0;
  line-height: 1.2;
}
#top-service ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 32rem;
}
@media screen and (min-width: 768px), print {
  #top-service ul {
    gap: 40rem;
  }
}
#top-service ul li {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 24rem;
}
@media screen and (min-width: 768px), print {
  #top-service ul li {
    grid-template-columns: 440rem 1fr;
    gap: 118rem;
    align-items: center;
  }
}
#top-service .more {
  margin: 24rem 0 0 auto;
}
#top-service hr {
  margin: 32rem 0;
  border: none;
  height: 1px;
  background: #303030;
}
@media screen and (min-width: 768px), print {
  #top-service hr {
    margin: 56rem 0;
  }
}

/*-----------------------------------------------------------------------------------*/
#top-news ul.news-list {
  margin-top: -16rem;
}
@media screen and (min-width: 768px), print {
  #top-news ul.news-list {
    margin-top: -24rem;
    grid-template-columns: repeat(4, 1fr);
    gap: 24rem;
    border-bottom: 1px dashed #303030;
    padding-bottom: 24rem;
  }
}
#top-news .more {
  margin: 40rem auto 0;
}
@media screen and (min-width: 768px), print {
  #top-news .more {
    margin-right: 0;
  }
}

/*-----------------------------------------------------------------------------------*/
#top-recruit,
#entry {
  margin: -32rem 0 0;
  background: #717070;
  padding: 32rem 0 32rem;
  color: #fff;
}
@media screen and (min-width: 768px), print {
  #top-recruit,
  #entry {
    margin: -88rem 0 0;
    padding: 72rem 0;
  }
}
#top-recruit .grid,
#entry .grid {
  display: grid;
  margin-top: -16rem;
}
@media screen and (min-width: 768px), print {
  #top-recruit .grid,
  #entry .grid {
    grid-template-columns: 1fr 502rem;
    align-items: center;
    gap: 64rem;
  }
  #top-recruit .grid figure,
  #entry .grid figure {
    order: 2;
  }
  #top-recruit .grid p,
  #entry .grid p {
    margin: 0 0 50rem;
  }
}
#top-recruit .more,
#entry .more {
  margin-left: auto;
}
#top-recruit .btn,
#entry .btn {
  background: #fff;
  color: #303030;
}
@media screen and (min-width: 768px), print {
  #top-recruit .btn:hover,
  #entry .btn:hover {
    background: #303030;
    color: #fff;
  }
}

/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
ul.news-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16rem;
  line-height: 1.6;
}
@media screen and (min-width: 768px), print {
  ul.news-list {
    grid-template-columns: repeat(3, 1fr);
    gap: 56rem 72rem;
  }
}
ul.news-list li {
  margin: 0;
  padding: 0;
}
ul.news-list figure {
  overflow: hidden;
}
ul.news-list img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  transition: scale 0.3s;
}
@media screen and (min-width: 768px), print {
  ul.news-list a:hover img {
    scale: 105%;
  }
}
ul.news-list h2,
ul.news-list h3 {
  font-weight: 400;
  font-size: 14rem;
  margin: 6rem 0 3rem;
  line-height: 1.6;
}
@media screen and (min-width: 768px), print {
  ul.news-list h2,
  ul.news-list h3 {
    margin: 8rem 0 4rem;
    font-size: 16rem;
  }
}
ul.news-list time {
  display: block;
}
@media screen and (min-width: 768px), print {
  ul.news-list time {
    font-size: 14rem;
  }
}

/*-----------------------------------------------------------------------------------*/
#news .news-list {
  border-top: 1px dashed #303030;
  padding: 32rem 0;
}
@media screen and (min-width: 768px), print {
  #news .news-list {
    padding: 64rem 0;
  }
}
#news .pager {
  border-top: 1px dashed #303030;
  padding-top: 56rem;
  margin-bottom: -16rem;
}
@media screen and (min-width: 768px), print {
  #news .pager {
    padding-top: 72rem;
    margin-bottom: -64rem;
  }
}
#news .pager a {
  margin: 0 auto;
}

/*-----------------------------------------------------------------------------------*/
@media screen and (max-width: 767.98px) {
  #news-detail {
    margin-bottom: 32rem;
  }
}
#news-detail header {
  border-top: 1px dashed #303030;
  border-bottom: 1px dashed #303030;
  padding: 24rem 0;
  margin: 0 0 40rem;
}
#news-detail header h1 {
  font-size: 18rem;
  font-weight: 500;
  margin: 0;
}
@media screen and (min-width: 768px), print {
  #news-detail .entry-body {
    display: grid;
    gap: 102rem;
    grid-template-columns: 393rem 1fr;
    align-items: start;
    margin: 88rem 0;
  }
}
#news-detail .entry-body > figure {
  text-align: center;
  margin: 40rem 0;
}
@media screen and (min-width: 768px), print {
  #news-detail .entry-body > figure {
    position: sticky;
    top: 0;
    left: 0;
    margin: 0;
  }
}
#news-detail .entry-body > figure img {
  width: 213rem;
}
@media screen and (min-width: 768px), print {
  #news-detail .entry-body > figure img {
    width: 100%;
  }
}
#news-detail .entry-body > .text *:first-child {
  margin-top: 0;
}
#news-detail .entry-body > .text *:last-child {
  margin-bottom: 0;
}
#news-detail nav {
  border-top: 1px dashed #303030;
  margin: 40rem 0 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 32rem 0 0;
}
@media screen and (min-width: 768px), print {
  #news-detail nav {
    padding: 40rem 0 0;
    justify-content: end;
    gap: 72rem;
  }
}
@media screen and (min-width: 768px), print {
  #news-detail nav > div:not(:has(a)) {
    display: none;
  }
}
#news-detail nav a {
  display: grid;
  align-items: center;
  gap: 16rem;
}
@media screen and (min-width: 768px), print {
  #news-detail nav a {
    gap: 24rem;
  }
}
@media screen and (min-width: 768px), print {
  #news-detail nav a:hover i {
    background: #303030;
    color: #fff;
  }
}
#news-detail nav i {
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 100rem;
  width: 43rem;
  aspect-ratio: 1;
  background: #fff;
  color: #303030;
  border: 1px solid #303030;
  transition: color 0.3s, background-color 0.3s;
}
@media screen and (min-width: 768px), print {
  #news-detail nav i {
    width: 43rem;
  }
}
#news-detail nav .prev a {
  grid-template-columns: 43rem 1fr;
}
#news-detail nav .prev i {
  transform: scaleX(-1);
}
#news-detail nav .next a {
  grid-template-columns: 1fr 43rem;
}

/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
@media screen and (min-width: 768px), print {
  #about {
    margin-top: -72rem;
  }
}
#about .lead {
  margin-bottom: 56rem;
}
@media screen and (min-width: 768px), print {
  #about .lead {
    text-align: center;
    margin-bottom: 93rem;
  }
}
#about h2 {
  font-family: "Inter", "Noto Sans JP", "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Arial, sans-serif;
  font-size: 14rem;
  font-weight: 600;
}
#about .mission {
  border-top: 1px solid #303030;
  border-bottom: 1px solid #303030;
  padding: 32rem 0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 24rem;
  margin: 0 0 40rem;
}
@media screen and (min-width: 768px), print {
  #about .mission {
    padding: 40rem 0;
    margin-bottom: 110rem;
  }
}
#about .mission strong {
  font-weight: 400;
}
#about .mission .en {
  font-size: 36rem;
  line-height: 1;
  margin-bottom: 12rem;
}
@media screen and (min-width: 768px), print {
  #about .mission .en {
    font-size: 48rem;
  }
}
#about .mission .ja {
  font-size: 16rem;
  font-weight: 500;
}
@media screen and (min-width: 768px), print {
  #about .mission .ja {
    font-size: 14rem;
  }
}
#about .mission p {
  margin: 0;
}
@media screen and (min-width: 768px), print {
  #about .mission p {
    padding: 0 40rem;
    border-left: 1px solid #303030;
  }
}
#about h3 {
  font-weight: 400;
  margin: 0 0 24rem;
  line-height: 1;
}
#about h3 [lang=en] {
  font-size: 26rem;
  display: block;
  margin-bottom: 8rem;
}
#about h3 [lang=ja] {
  font-size: 14rem;
  font-weight: 500;
  display: block;
}
#about ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 40rem;
}
@media screen and (min-width: 768px), print {
  #about ul {
    gap: 56rem;
  }
}
#about ul li {
  margin: 0;
  padding: 0;
}
@media screen and (min-width: 768px), print {
  #about ul li {
    display: grid;
    grid-template-columns: 326rem 546rem;
    justify-content: space-between;
  }
}

/*-----------------------------------------------------------------------------------*/
#initiative {
  margin: -32rem 0;
  background: #F8F6F6;
  padding: 40rem 0;
}
@media screen and (min-width: 768px), print {
  #initiative {
    margin: -72rem 0;
    padding: 72rem 0;
  }
}
@media screen and (min-width: 768px), print {
  #initiative h2.line-s {
    margin-bottom: -16rem;
  }
}
#initiative ul {
  margin: 32rem 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 32rem;
}
@media screen and (min-width: 768px), print {
  #initiative ul {
    grid-template-columns: repeat(3, 1fr);
    gap: 64rem;
    align-items: start;
  }
}
#initiative ul li {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8rem;
}
@media screen and (min-width: 768px), print {
  #initiative ul li {
    gap: 16rem;
  }
}
#initiative ul p {
  margin: 0;
}
#initiative h3 {
  font-size: 16rem;
  font-weight: 500;
  margin: 0 0 8rem;
}
@media screen and (min-width: 768px), print {
  #initiative h3 {
    font-size: 20rem;
  }
}

/*-----------------------------------------------------------------------------------*/
#experience {
  margin-bottom: 32rem;
}
@media screen and (min-width: 768px), print {
  #experience {
    margin-bottom: 72rem;
    padding: 24rem 0;
  }
}
#experience h2 {
  margin: 0 0 16rem;
  font-size: 16rem;
  line-height: 1.6;
  font-weight: 400;
  text-align: center;
}
@media screen and (min-width: 768px), print {
  #experience h2 {
    text-align: left;
    font-size: 18rem;
  }
}
@media screen and (min-width: 768px), print {
  #experience .grid {
    display: grid;
    grid-template-columns: 1fr 478rem;
    gap: 0 88rem;
  }
  #experience .grid figure {
    grid-column: 2/3;
    grid-row: 1/3;
  }
}
#experience ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
@media screen and (min-width: 768px), print {
  #experience ul {
    align-self: end;
  }
}
#experience ul li {
  margin: 0;
  padding: 0;
  border-bottom: 1px solid #303030;
}
#experience ul li.blank {
  border: none;
  padding: 16rem 0;
}
#experience ul a {
  display: grid;
  grid-template-columns: 1fr 19rem;
  gap: 8rem;
  align-items: center;
  padding: 16rem 0;
}
@media screen and (min-width: 768px), print {
  #experience ul a {
    font-size: 20rem;
  }
}
#experience ul a i {
  translate: 0 15%;
}
#experience ul a i svg {
  width: 19rem;
  height: 19rem;
  margin: 0;
}

/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
@media screen and (max-width: 767.98px) {
  .modal-on.is-anchor-sticky #lineup {
    padding-top: 174rem;
  }
  #lineup [id] {
    scroll-margin-top: 210rem;
  }
}
#lineup h2.line {
  margin-bottom: 16rem;
}
@media screen and (min-width: 768px), print {
  #lineup h2.line {
    margin-bottom: 32rem;
  }
}
#lineup h2.line [lang=en] {
  font-family: "Inter", "Noto Sans JP", "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Arial, sans-serif;
  font-size: 24rem;
}
@media screen and (min-width: 768px), print {
  #lineup h2.line [lang=en] {
    font-size: 36rem;
  }
}
#lineup .category + .category {
  margin-top: 72rem;
}
@media screen and (min-width: 768px), print {
  #lineup .category + .category {
    margin-top: 144rem;
  }
}
#lineup .category ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 24rem;
}
@media screen and (min-width: 768px), print {
  #lineup .category ul {
    grid-template-columns: repeat(3, 1fr);
    gap: 62rem;
    margin-top: 40rem;
  }
}
#lineup .category ul li {
  margin: 0;
  padding: 0;
}
#lineup .category button {
  border: none;
  outline: none;
  background: none;
  appearance: none;
  padding: 0;
  cursor: pointer;
  vertical-align: top;
  color: #000;
}
#lineup .category button figure {
  display: grid;
  grid-template-columns: 157rem 1fr;
  gap: 32rem;
  position: relative;
  align-items: center;
}
@media screen and (min-width: 768px), print {
  #lineup .category button figure {
    grid-template-columns: 1fr;
    gap: 16rem;
  }
}
#lineup .category button figure > span {
  display: block;
  overflow: hidden;
}
#lineup .category button img {
  transition: scale 0.3s;
  transform: translate3d(0, 0, 0);
  will-change: scale;
}
@media screen and (min-width: 768px), print {
  #lineup .category button:hover img {
    scale: 105%;
  }
}
#lineup .category button figcaption {
  text-align: left;
  padding-bottom: 36rem;
}
@media screen and (min-width: 768px), print {
  #lineup .category button figcaption {
    padding: 0 62rem 0 0;
  }
}
#lineup .category button .label [lang=en] {
  font-size: 16rem;
  font-family: "Inter", "Noto Sans JP", "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Arial, sans-serif;
  display: block;
  line-height: 1.3;
  margin-bottom: 6rem;
}
@media screen and (min-width: 768px), print {
  #lineup .category button .label [lang=en] {
    font-size: 22rem;
  }
}
#lineup .category button .label [lang=ja] {
  font-size: 13rem;
  display: block;
  line-height: 1.2;
}
@media screen and (min-width: 768px), print {
  #lineup .category button .label [lang=ja] {
    font-size: 16rem;
  }
}
#lineup .category button i {
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 100rem;
  width: 36rem;
  aspect-ratio: 1;
  background: #fff;
  color: #303030;
  border: 1px solid #303030;
  transition: color 0.3s, background-color 0.3s;
  position: absolute;
  bottom: 0;
  right: 0;
}
@media screen and (min-width: 768px), print {
  #lineup .category button i {
    width: 43rem;
    bottom: 5rem;
  }
}
@media screen and (min-width: 768px), print {
  #lineup .category button:hover i {
    background: #303030;
    color: #fff;
  }
}

/*-----------------------------------------------------------------------------------*/
.radar {
  width: 75%;
  color: #333;
  margin: 0 auto;
}
@media screen and (min-width: 768px), print {
  .radar {
    width: 80%;
  }
}

.radar svg {
  width: 100%;
  height: auto;
  display: block;
  overflow: visible;
}

/* 内側グリッド（同心） */
.radar g[data-layer=grid] polygon {
  fill: none;
  stroke: #e6e6e6;
  stroke-width: 1;
  stroke-opacity: 1;
}

/* 放射線 */
.radar g[data-layer=grid] line {
  stroke: #e6e6e6;
  stroke-width: 1;
  stroke-opacity: 1;
}

/* 外枠（最前面） */
.radar g[data-layer=outer] polygon {
  fill: none;
  stroke: #1a1a1a;
  stroke-width: 1;
  stroke-opacity: 1;
}

/* データ面（薄いグレーの面） */
.radar g[data-layer=data] polygon {
  fill: #e6e6e6;
  stroke: none;
  mix-blend-mode: multiply;
}

/* ラベル */
.radar g[data-layer=labels] text {
  fill: #1a1a1a;
  fill-opacity: 1;
  font-size: 10rem;
}

/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
.lineup-modal .photo {
  width: 315rem;
  aspect-ratio: 1;
  border-right: 1px solid #303030;
  position: absolute;
  top: 0;
  height: 0;
}
.lineup-modal .text {
  padding: 24rem 16rem 16rem;
}
@media screen and (min-width: 768px), print {
  .lineup-modal .text {
    height: 315rem;
    padding: 16rem 359rem 16rem 369rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
}
.lineup-modal .text h3 {
  line-height: 1;
  margin: 0 60rem 0 0;
}
@media screen and (min-width: 768px), print {
  .lineup-modal .text h3 {
    margin: 0;
  }
}
.lineup-modal .text h3 [lang=en] {
  font-size: 20rem;
  font-weight: 500;
  font-family: "Inter", "Noto Sans JP", "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Arial, sans-serif;
  display: block;
  margin-bottom: 8rem;
}
@media screen and (min-width: 768px), print {
  .lineup-modal .text h3 [lang=en] {
    font-size: 24rem;
  }
}
.lineup-modal .text h3 [lang=ja] {
  font-size: 14rem;
  font-weight: 400;
  display: block;
}
@media screen and (min-width: 768px), print {
  .lineup-modal .text h3 [lang=ja] {
    font-size: 16rem;
  }
}
.lineup-modal .text p {
  margin-bottom: 0;
}
@media screen and (min-width: 768px), print {
  .lineup-modal .chart {
    position: absolute;
    top: 48rem;
    right: 16rem;
    width: 315rem;
  }
}
@media screen and (min-width: 768px), print {
  .lineup-modal .sub {
    display: grid;
  }
  .lineup-modal .sub:has(.recommend) {
    grid-template-columns: 1fr 1fr;
  }
}
.lineup-modal .sub h4 {
  margin: 0;
  font-size: 16rem;
  font-weight: 400;
}
@media screen and (min-width: 768px), print {
  .lineup-modal .sub h4 {
    margin-bottom: 8rem;
  }
}
.lineup-modal .ingredients {
  border-top: 1px solid #303030;
  padding: 16rem;
}
@media screen and (min-width: 768px), print {
  .lineup-modal .ingredients {
    padding: 24rem 32rem;
  }
}
.lineup-modal .ingredients p {
  margin: 0;
}
.lineup-modal .recommend {
  border-top: 1px solid #303030;
  padding: 16rem;
}
@media screen and (min-width: 768px), print {
  .lineup-modal .recommend {
    border-left: 1px solid #303030;
    padding: 24rem 32rem;
  }
}
.lineup-modal .recommend ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
.lineup-modal .recommend ul li {
  margin: 0;
  padding: 0 0 0 1.3em;
  text-indent: -1.3em;
}
.lineup-modal .recommend ul li::before {
  content: "●";
  color: #d9d9d9;
  display: inline-block;
  text-indent: 0;
  width: 1.3em;
}

/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
@media screen and (max-width: 767.98px) {
  #shop [id] {
    scroll-margin-top: 120rem;
  }
}
#shop .shop {
  display: grid;
  gap: 24rem;
  font-style: normal;
  border-bottom: 1px solid #303030;
  margin: 0 0 32rem;
  padding: 0 0 32rem;
}
@media screen and (min-width: 768px), print {
  #shop .shop {
    width: 800rem;
    margin: 0 auto 72rem;
    padding: 0 0 72rem;
    grid-template-columns: 345rem 1fr;
    gap: 102rem;
  }
}
#shop .shop:last-child {
  border: none;
  margin-bottom: 0;
  padding-bottom: 0;
}
#shop .shop h2 {
  font-size: 20rem;
  font-weight: 500;
  margin: 0 0 16rem;
  line-height: 1.2;
}
@media screen and (min-width: 768px), print {
  #shop .shop h2 {
    font-size: 24rem;
    margin-bottom: 20rem;
  }
}
#shop .shop p {
  margin: 0 0 8rem;
  line-height: 1.4;
}
#shop .shop a.map {
  display: grid;
  width: fit-content;
  grid-template-columns: 14rem 1fr;
  gap: 8rem;
  align-items: center;
  line-height: 1.2;
}
#shop .shop a.map::before {
  content: "";
  background: url(../images/shop/pin.svg) no-repeat center center/contain;
  display: block;
  aspect-ratio: 14/17;
}
#shop .shop dl {
  margin: 16rem 0 0;
  padding: 0;
  line-height: 1.2;
  display: grid;
  gap: 8rem;
}
#shop .shop dl > div {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: flex-start;
  gap: 0.75em;
}
#shop .shop dl > div::after {
  content: "";
  border-bottom: 1px dashed currentColor;
  transform: translateY(0.65em);
  order: 2;
}
#shop .shop dl dt {
  white-space: nowrap;
  order: 1;
}
#shop .shop dl dd {
  margin: 0;
  white-space: nowrap;
  order: 3;
}
#shop .shop small {
  display: block;
  font-size: 12rem;
  margin-top: 4rem;
}
@media screen and (min-width: 768px), print {
  #shop .shop small {
    margin-top: 6rem;
  }
}
#shop + #experience {
  margin: -32rem 0 0;
  background: #F8F6F6;
  padding: 40rem 0;
}
@media screen and (min-width: 768px), print {
  #shop + #experience {
    margin: -72rem 0 0;
    padding: 72rem 0;
  }
}

/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
#drinkcatering h2 {
  margin: 0 0 24rem;
  line-height: 1.5;
  font-size: 22rem;
  font-weight: 400;
}
@media screen and (min-width: 768px), print {
  #drinkcatering h2 {
    font-size: 40rem;
    margin-bottom: 48rem;
  }
}
#drinkcatering h2 small {
  display: block;
  font-size: 14rem;
  line-height: 1;
  margin-top: 10rem;
}
@media screen and (min-width: 768px), print {
  #drinkcatering h2 small {
    font-size: 18rem;
    margin-top: 16rem;
  }
}
@media screen and (min-width: 768px), print {
  #drinkcatering .lead {
    width: 546rem;
  }
}
#drinkcatering .photos {
  margin: 24rem 0 56rem;
  display: grid;
  gap: 2rem;
}
@media screen and (min-width: 768px), print {
  #drinkcatering .photos {
    margin: 0 0 96rem;
    grid-template-columns: repeat(3, 1fr);
  }
}
#drinkcatering .photos figure {
  position: relative;
}
#drinkcatering .photos figure img {
  width: 100%;
  object-fit: cover;
}
@media screen and (max-width: 767.98px) {
  #drinkcatering .photos figure img {
    aspect-ratio: 327/190;
  }
}
@media screen and (min-width: 768px), print {
  #drinkcatering .photos figure img {
    height: 274rem;
  }
}
#drinkcatering .photos figcaption {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  text-align: center;
  translate: 0 -50%;
  color: #fff;
  font-size: 500;
  font-size: 18rem;
  line-height: 1.6;
}
@media screen and (min-width: 768px), print {
  #drinkcatering .photos figcaption {
    font-size: 20rem;
  }
}
#drinkcatering h3 {
  margin: 0 0 16rem;
  font-weight: 400;
}
@media screen and (min-width: 768px), print {
  #drinkcatering h3 {
    margin-bottom: 40rem;
  }
}
#drinkcatering h3 [lang=en] {
  font-family: "Inter", "Noto Sans JP", "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Arial, sans-serif;
  font-size: 24rem;
  display: block;
  line-height: 1;
}
@media screen and (min-width: 768px), print {
  #drinkcatering h3 [lang=en] {
    font-size: 32rem;
  }
}
#drinkcatering h3 [lang=ja] {
  display: block;
  font-size: 14rem;
  line-height: 2;
}
@media screen and (min-width: 768px), print {
  #drinkcatering h3 [lang=ja] {
    font-size: 16rem;
  }
}
#drinkcatering ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 40rem;
}
#drinkcatering ul li {
  margin: 0;
  padding: 0;
  display: grid;
  gap: 16rem;
}
@media screen and (min-width: 768px), print {
  #drinkcatering ul li {
    grid-template-columns: 1fr 445rem;
    gap: 144rem;
  }
}
#drinkcatering ul .text {
  border-left: 1px solid #303030;
  padding: 0 0 0 24rem;
}
@media screen and (min-width: 768px), print {
  #drinkcatering ul .text {
    padding-left: 64rem;
  }
}
#drinkcatering ul .text small {
  font-size: 10rem;
  display: block;
  line-height: 1.5;
  margin-top: 8rem;
}
@media screen and (min-width: 768px), print {
  #drinkcatering ul .text small {
    font-size: 12rem;
    line-height: 1.6;
  }
}
@media screen and (min-width: 768px), print {
  #drinkcatering ul .area {
    display: flex;
    gap: 16rem;
    margin-top: 8rem;
    align-items: start;
  }
}
#drinkcatering ul .area p {
  font-size: 12rem;
}
@media screen and (min-width: 768px), print {
  #drinkcatering ul .area p {
    font-size: 14rem;
    line-height: 1.5;
    padding-top: 4rem;
  }
}
#drinkcatering ul .area p .hour {
  display: inline-block;
  width: 2.2em;
}
#drinkcatering ul h4 {
  font-size: 18rem;
  font-weight: 500;
  margin: 0 0 16rem;
  line-height: 1;
}
@media screen and (min-width: 768px), print {
  #drinkcatering ul h4 {
    font-size: 22rem;
    margin-bottom: 32rem;
  }
}
#drinkcatering ul h5 {
  font-size: 13rem;
  line-height: 2;
  border: 1px solid #303030;
  padding: 0 16rem;
  margin: 16rem 0 8rem;
  width: fit-content;
  font-weight: 400;
}
@media screen and (min-width: 768px), print {
  #drinkcatering ul h5 {
    white-space: nowrap;
    flex: 0 0 auto;
    margin: 0;
    font-size: 14rem;
    translate: 0 5rem;
  }
}
#drinkcatering ul p {
  margin: 0;
}

/*-----------------------------------------------------------------------------------*/
#casestudy {
  margin: -32rem 0;
  background: #F8F6F6;
  padding: 40rem 0;
}
@media screen and (min-width: 768px), print {
  #casestudy {
    margin: -72rem 0;
    padding: 72rem 0;
  }
}
#casestudy figure {
  padding: 0 24rem;
}
@media screen and (min-width: 768px), print {
  #casestudy figure {
    padding: 0;
  }
}
#casestudy figure img {
  width: 210rem;
  aspect-ratio: 1;
  object-fit: cover;
  margin: 0 auto;
  display: block;
}
@media screen and (min-width: 768px), print {
  #casestudy figure img {
    width: 100%;
  }
}
#casestudy h2.line-s::before {
  display: none;
}
#casestudy h3 {
  font-size: 16rem;
  font-weight: 500;
  margin: 16rem 0 12rem;
  line-height: 1.5;
}
@media screen and (min-width: 768px), print {
  #casestudy h3 {
    font-size: 16rem;
    margin-top: 24rem;
  }
}
#casestudy p {
  margin: 0;
}
#casestudy p small {
  font-size: 12rem;
  display: block;
  margin-top: 3rem;
}
#casestudy .splide {
  margin: 0 -24rem 0;
}
@media screen and (min-width: 768px), print {
  #casestudy .splide {
    margin: 0;
  }
}

/*-----------------------------------------------------------------------------------*/
#cta {
  margin-bottom: 48rem;
}
@media screen and (min-width: 768px), print {
  #cta {
    margin-bottom: 72rem;
  }
}
@media screen and (min-width: 768px), print {
  #cta .grid {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}
#cta p {
  margin: 0 0 32rem;
}
@media screen and (min-width: 768px), print {
  #cta p {
    margin: 0;
  }
}
#cta a.btn {
  height: 65rem;
}
@media screen and (min-width: 768px), print {
  #cta a.btn {
    height: 60rem;
  }
}

/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
#recruit .lead {
  margin: 0 0 72rem;
}
@media screen and (min-width: 768px), print {
  #recruit .lead {
    margin-bottom: 112rem;
  }
}
@media screen and (max-width: 767.98px) {
  #recruit .lead p {
    margin: 0;
  }
}
#recruit h2.small {
  font-size: 14rem;
  margin: 0 0 24rem;
  padding: 0;
  line-height: 1;
  font-weight: 600;
}
@media screen and (min-width: 768px), print {
  #recruit .grid {
    display: grid;
    grid-template-columns: 320rem 1fr;
  }
}
#recruit .mission {
  margin: 0 0 64rem;
}
@media screen and (min-width: 768px), print {
  #recruit .mission {
    margin-bottom: 112rem;
  }
}
#recruit .mission .en {
  font-family: "Marcellus", "游明朝体", "Yu Mincho", "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "Times New Roman", serif;
  font-size: 36rem;
  font-weight: 400;
  line-height: 1;
  display: block;
}
@media screen and (min-width: 768px), print {
  #recruit .mission .en {
    font-size: 48rem;
  }
}
#recruit .mission .ja {
  font-size: 16rem;
  display: block;
  margin-top: 12rem;
}
@media screen and (min-width: 768px), print {
  #recruit .mission .ja {
    font-size: 14rem;
  }
}
#recruit dl {
  margin: 0 0 72rem;
  padding: 0;
  display: grid;
  gap: 24rem;
}
@media screen and (min-width: 768px), print {
  #recruit dl {
    margin-bottom: 144rem;
    gap: 64rem;
  }
}
#recruit dl > div {
  display: grid;
}
@media screen and (min-width: 768px), print {
  #recruit dl > div {
    grid-template-columns: 150rem 1fr;
    align-items: center;
  }
}
#recruit dl dt {
  font-family: "Marcellus", "游明朝体", "Yu Mincho", "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "Times New Roman", serif;
  font-size: 32rem;
  font-weight: 400;
  line-height: 1;
  display: block;
  margin: 0;
  padding: 0;
}
@media screen and (min-width: 768px), print {
  #recruit dl dt {
    font-size: 40rem;
  }
}
#recruit dl dd {
  margin: 0;
  padding: 0;
}
@media screen and (min-width: 768px), print {
  #recruit dl dd {
    font-size: 18rem;
  }
}
#recruit ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 32rem;
}
@media screen and (min-width: 768px), print {
  #recruit ul {
    grid-template-columns: 1fr 1fr;
    gap: 40rem 210rem;
    padding: 0 40rem;
  }
}
#recruit ul li {
  margin: 0;
  padding: 0;
}
#recruit ul h4 {
  font-size: 16rem;
  font-weight: 500;
  margin: 0 0 8rem;
}
@media screen and (min-width: 768px), print {
  #recruit ul h4 {
    font-size: 20rem;
    margin-bottom: 16rem;
  }
}
#recruit ul p {
  margin: 0;
}

/*-----------------------------------------------------------------------------------*/
#works {
  margin: -32rem 0;
  background: #F8F6F6;
  padding: 40rem 0;
}
@media screen and (min-width: 768px), print {
  #works {
    margin: -72rem 0;
    padding: 72rem 0;
  }
}
#works h2 {
  margin: 0 0 24rem;
  font-size: 24rem;
  font-weight: 400;
  line-height: 1;
}
@media screen and (min-width: 768px), print {
  #works h2 {
    font-size: 40rem;
    margin-bottom: 40rem;
  }
}
#works .lead {
  margin: 0 0 56rem;
}
@media screen and (min-width: 768px), print {
  #works .lead {
    margin-bottom: 102rem;
    display: grid;
    grid-template-columns: 613rem 1fr;
    gap: 48rem;
    align-items: end;
  }
}
@media screen and (min-width: 768px), print {
  #works .lead p {
    margin: 0;
  }
}
#works ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 40rem;
}
@media screen and (min-width: 768px), print {
  #works ul {
    gap: 56rem 48rem;
    grid-template-columns: repeat(2, 1fr);
    align-items: start;
  }
}
#works ul li {
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 172rem 1fr;
  gap: 16rem;
  align-items: center;
}
@media screen and (min-width: 768px), print {
  #works ul li {
    grid-template-columns: 1fr;
    gap: 24rem;
  }
}
#works ul h4 {
  font-size: 15rem;
  font-weight: 500;
  margin: 0;
}
@media screen and (min-width: 768px), print {
  #works ul h4 {
    font-size: 20rem;
    margin-bottom: -16rem;
  }
}
#works ul p {
  margin: 0;
  grid-column: 1/3;
}
@media screen and (min-width: 768px), print {
  #works ul p {
    grid-column: 1/2;
    padding-right: 96rem;
  }
}
#works .frame {
  border: 1px solid #303030;
  background: #fff;
  padding: 16rem;
  margin: 32rem 0 0;
}
@media screen and (min-width: 768px), print {
  #works .frame {
    margin-top: 40rem;
    display: flex;
    padding: 40rem 72rem;
    align-items: center;
    gap: 60rem;
  }
}
#works .frame h3 {
  font-size: 16rem;
  font-weight: 500;
  margin: 0 0 8rem;
}
@media screen and (min-width: 768px), print {
  #works .frame h3 {
    flex: 0 0 1;
    white-space: nowrap;
  }
}
#works .frame p {
  margin: 0;
}

/*-----------------------------------------------------------------------------------*/
#staff h2 {
  font-size: 18rem;
  text-align: center;
  font-weight: 500;
  margin: 0 0 24rem;
}
@media screen and (min-width: 768px), print {
  #staff h2 {
    font-size: 22rem;
    margin-bottom: 56rem;
  }
}
#staff ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: 251rem;
  justify-content: center;
  gap: 48rem;
}
@media screen and (min-width: 768px), print {
  #staff ul {
    grid-template-columns: repeat(4, 1fr);
  }
}
#staff ul button {
  border: none;
  background: none;
  appearance: none;
  outline: none;
  padding: 0;
  margin: 0 auto;
  display: block;
  cursor: pointer;
  color: #000;
}
#staff ul button i {
  transition: translate 0.3s;
}
@media screen and (min-width: 768px), print {
  #staff ul button:hover i {
    translate: 10rem 0;
  }
}
#staff figure {
  margin: 0 auto;
  aspect-ratio: 251/323;
}
#staff figure img {
  width: 100%;
  aspect-ratio: 251/323;
  -webkit-mask-image: url("../images/recruit/mask.svg");
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
  mask-image: url("../images/recruit/mask.svg");
  mask-repeat: no-repeat;
  mask-size: 100% 100%;
}
#staff figcaption {
  text-align: left;
  margin: -48rem 8rem 0 64rem;
}
#staff figcaption .name {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10rem;
}
#staff figcaption .name .en {
  flex: 0 0 auto;
  font-size: 20rem;
}
#staff figcaption .name .position {
  flex: 1;
  font-weight: 500;
  font-size: 18rem;
}
#staff figcaption .name i {
  flex: 0 0 auto;
}
#staff figcaption .shop {
  font-size: 13rem;
}

/*-----------------------------------------------------------------------------------*/
@media screen and (min-width: 768px), print {
  #merit {
    padding-bottom: 72rem;
    margin-top: -72rem;
  }
}
#merit h2 {
  font-size: 18rem;
  text-align: center;
  font-weight: 500;
  margin: 0 0 24rem;
}
@media screen and (min-width: 768px), print {
  #merit h2 {
    font-size: 22rem;
    margin-bottom: 56rem;
  }
}
#merit ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
@media screen and (max-width: 767.98px) {
  #merit ul {
    columns: 2;
    column-gap: 16rem;
  }
}
@media screen and (min-width: 768px), print {
  #merit ul {
    display: flex;
    gap: 24rem;
    flex-wrap: wrap;
    justify-content: center;
  }
}
#merit ul li {
  margin: 0 0 16rem;
  padding: 16rem 24rem;
  background: #F8F6F6;
  font-size: 13rem;
  line-height: 2;
  border-radius: 16rem;
  font-weight: 500;
}
@media screen and (min-width: 768px), print {
  #merit ul li {
    font-size: 18rem;
    margin: 0;
    padding: 24rem 40rem;
  }
}

/*-----------------------------------------------------------------------------------*/
#modal.staff-modal .modal-bg {
  background: rgba(248, 246, 246, 0.95);
  display: block;
}
#modal.staff-modal .modal-frame {
  background: none;
  border: none;
  width: 100%;
  height: 100dvh;
  max-height: 100dvh;
  padding: 40rem 16rem;
}
@media screen and (min-width: 768px), print {
  #modal.staff-modal .modal-frame {
    max-width: 100%;
    padding: 0;
  }
}
#modal.staff-modal .modal-close {
  position: fixed;
  top: 0;
  right: 0;
}
@media screen and (min-width: 768px), print {
  #modal.staff-modal .modal-close {
    top: 32rem;
    right: 32rem;
  }
}
@media screen and (min-width: 768px), print {
  #modal.staff-modal .staff-inner {
    width: 1012rem;
    padding: 124rem 0 124rem 222rem;
    margin: 0 auto;
  }
}
#modal.staff-modal figure {
  text-align: center;
}
@media screen and (min-width: 768px), print {
  #modal.staff-modal figure {
    position: fixed;
    top: 124rem;
    right: calc(50% + 355rem);
    width: 150rem;
    text-align: left;
  }
}
#modal.staff-modal figure > span {
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: 100rem;
  width: 150rem;
  overflow: hidden;
  display: block;
  margin: 0 auto;
}
#modal.staff-modal figure > span img {
  width: 100%;
  object-fit: cover;
  transform-origin: center top;
}
#modal.staff-modal .name {
  display: flex;
  justify-content: center;
  line-height: 1;
  gap: 10rem;
  margin: 16rem 0 12rem;
}
@media screen and (min-width: 768px), print {
  #modal.staff-modal .name {
    justify-content: start;
  }
}
#modal.staff-modal .name .en {
  flex: 0 0 auto;
  font-size: 24rem;
  display: block;
  translate: 0 2rem;
}
#modal.staff-modal .name .position {
  font-weight: 500;
  font-size: 22rem;
  display: block;
}
#modal.staff-modal .shop {
  line-height: 1.5;
  font-size: 14rem;
}
#modal.staff-modal .text h3 {
  margin: 40rem 0 16rem;
  display: grid;
  grid-template-columns: 40rem 1fr;
  font-weight: 400;
  text-align: left;
}
@media screen and (min-width: 768px), print {
  #modal.staff-modal .text h3 {
    margin: 72rem 0 27rem;
  }
  #modal.staff-modal .text h3:first-child {
    margin-top: 0;
  }
}
#modal.staff-modal .text h3 small {
  font-size: 20rem;
  line-height: 1;
  translate: 0 5rem;
}
@media screen and (min-width: 768px), print {
  #modal.staff-modal .text h3 small {
    font-size: 24rem;
  }
}
#modal.staff-modal .text h3 span {
  font-size: 18rem;
  line-height: 1.6;
  font-weight: 500;
}
@media screen and (min-width: 768px), print {
  #modal.staff-modal .text h3 span {
    font-size: 22rem;
  }
}
#modal.staff-modal .text .frame {
  border-radius: 16rem;
  padding: 24rem;
  border: 1px solid #303030;
  background-color: #fff;
}
@media screen and (min-width: 768px), print {
  #modal.staff-modal .text .frame {
    padding: 40rem 56rem;
  }
}
#modal.staff-modal .text .frame p:first-child {
  margin-top: 0;
}
#modal.staff-modal .text .frame p:last-child {
  margin-bottom: 0;
}

/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
#company .lead {
  padding-top: 16rem;
}
@media screen and (min-width: 768px), print {
  #company .lead {
    text-align: center;
    padding-top: 0;
  }
}
#company .lead p {
  margin: 0;
}
#company dl {
  border-top: 1px solid #303030;
  margin: 48rem 0 0;
}
@media screen and (min-width: 768px), print {
  #company dl {
    margin: 56rem auto 0;
    width: 800rem;
  }
}
#company dl > div {
  border-bottom: 1px solid #303030;
  padding: 8rem 0;
  display: grid;
  grid-template-columns: 90rem 1fr;
}
@media screen and (min-width: 768px), print {
  #company dl > div {
    padding: 16rem 0;
    grid-template-columns: 280rem 1fr;
  }
}
#company dl dt {
  padding: 0 16rem 0 0;
}
#company dl dd {
  border-left: 1px solid #303030;
  padding: 0 0 0 24rem;
  margin: 0;
}

/*-----------------------------------------------------------------------------------*/
@media screen and (min-width: 768px), print {
  #privaypolicy .inner {
    width: 800rem;
  }
}
#privaypolicy h2 {
  font-size: 16rem;
  font-weight: 700;
  margin: 24rem 0 0;
}
@media screen and (min-width: 768px), print {
  #privaypolicy h2 {
    font-size: 20rem;
    margin: 32rem 0 8rem;
  }
}
#privaypolicy p {
  margin: 0;
}
#privaypolicy p:first-child {
  padding-top: 16rem;
}
@media screen and (min-width: 768px), print {
  #privaypolicy p:first-child {
    padding-top: 0;
  }
}

/*-----------------------------------------------------------------------------------*/
@media screen and (min-width: 768px), print {
  #contact .inner {
    width: 800rem;
  }
}
#contact .lead {
  padding-top: 16rem;
}
@media screen and (min-width: 768px), print {
  #contact .lead {
    text-align: center;
    padding-top: 0;
  }
}
#contact .lead p {
  margin: 0;
}
@media screen and (min-width: 768px), print {
  #contact.confirm dl dt {
    padding-top: 5rem;
  }
}
#contact.confirm .subject {
  margin-bottom: 1em;
}
#contact.complete .more {
  margin: 32rem auto 0;
  font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Arial, sans-serif;
}
@media screen and (min-width: 768px), print {
  #contact.complete .more {
    margin-top: 64rem;
  }
}
#contact form {
  margin: 0;
  padding: 0;
}
#contact input[type=text],
#contact input[type=email],
#contact input[type=tel] {
  font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Arial, sans-serif;
  background: #F8F6F6;
  border: none;
  font-size: 16rem;
  height: 48rem;
  width: 100%;
  box-sizing: border-box;
  padding: 0 16rem;
}
@media screen and (min-width: 768px), print {
  #contact input[type=text],
  #contact input[type=email],
  #contact input[type=tel] {
    font-size: 18rem;
    padding: 0 32rem;
  }
}
#contact .selectwrap {
  position: relative;
}
#contact .selectwrap::after {
  content: "▼";
  position: absolute;
  top: 50%;
  right: 16rem;
  translate: 0 -50%;
}
#contact select {
  font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Arial, sans-serif;
  background: #F8F6F6;
  border: none;
  appearance: none;
  font-size: 16rem;
  height: 48rem;
  width: 100%;
  box-sizing: border-box;
  padding: 0 48rem 0 16rem;
}
@media screen and (min-width: 768px), print {
  #contact select {
    font-size: 18rem;
    padding: 0 64rem 0 32rem;
  }
}
#contact textarea {
  font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Arial, sans-serif;
  background: #F8F6F6;
  border: none;
  height: 200rem;
  width: 100%;
  font-size: 16rem;
  box-sizing: border-box;
  padding: 16rem;
  line-height: 1.8;
}
@media screen and (min-width: 768px), print {
  #contact textarea {
    font-size: 18rem;
    padding: 24rem 32rem;
  }
}
#contact dl {
  border-top: 1px dashed #303030;
  margin: 24rem 0;
}
#contact dl > div {
  border-bottom: 1px dashed #303030;
  display: grid;
  padding: 16rem 0;
  gap: 8rem;
}
@media screen and (min-width: 768px), print {
  #contact dl > div {
    grid-template-columns: 1fr 516rem;
    align-items: center;
    padding: 32rem 0;
  }
}
#contact dl dt {
  line-height: 1;
  font-size: 16rem;
  margin: 0;
  padding: 0;
}
@media screen and (min-width: 768px), print {
  #contact dl dt {
    font-size: 18rem;
    align-self: start;
    padding-top: 14rem;
  }
}
#contact dl dt sup {
  color: #FF3232;
  font-size: 10rem;
}
@media screen and (min-width: 768px), print {
  #contact dl dt sup {
    font-size: 11rem;
  }
}
#contact dl dd {
  margin: 0;
  padding: 0;
}
#contact dl dd p {
  margin: 24rem 0 16rem;
  padding: 0;
  font-size: 16rem;
}
@media screen and (min-width: 768px), print {
  #contact dl dd p {
    font-size: 18rem;
    margin: 48rem 0 16rem;
  }
}
#contact .privacy {
  margin: 24rem 0;
}
@media screen and (min-width: 768px), print {
  #contact .privacy {
    margin: 32rem 0 48rem;
  }
}
@media screen and (min-width: 768px), print {
  #contact .input-check {
    font-size: 18rem;
  }
}
#contact .input-check label {
  display: grid;
  grid-template-columns: 30rem 1fr;
  line-height: 1.2;
  gap: 8rem;
}
@media screen and (min-width: 768px), print {
  #contact .input-check label {
    margin: 0 auto;
    width: fit-content;
  }
  #contact .input-check label input {
    scale: 150%;
  }
}
#contact .btns {
  margin-top: 24rem;
  display: grid;
  gap: 16rem;
}
@media screen and (min-width: 768px), print {
  #contact .btns {
    margin: 56rem 0 0;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 32rem;
  }
}
#contact .btns input.back {
  background: #aaa;
  color: #fff;
  text-align: center;
  display: flex;
  justify-content: center;
  cursor: pointer;
  border: none;
  align-items: center;
  font-weight: 500;
  line-height: 1;
  font-weight: 18rem;
  height: 52rem;
  width: 100%;
  appearance: none;
  font-size: 16rem;
}
@media screen and (max-width: 767.98px) {
  #contact .btns input.back {
    order: 2;
  }
}
@media screen and (min-width: 768px), print {
  #contact .btns input.back {
    transition: background-color 0.3s, color 0.3s;
    width: 200rem;
    height: 74rem;
    font-size: 18rem;
  }
  #contact .btns input.back:hover {
    background: #bbb;
  }
}
#contact .btns .formbtn {
  position: relative;
  display: block;
}
@media screen and (min-width: 768px), print {
  #contact .btns .formbtn {
    width: 470rem;
  }
}
#contact .btns .formbtn:hover input[type=submit] {
  background: #fff;
  color: #303030;
}
#contact .btns .formbtn:hover i {
  color: #303030;
}
#contact .btns .formbtn i {
  position: absolute;
  top: 50%;
  color: #fff;
  right: 24rem;
  translate: 0 -50%;
}
@media screen and (min-width: 768px), print {
  #contact .btns .formbtn i {
    right: 48rem;
  }
}
#contact .btns .formbtn input[type=submit] {
  background: #303030;
  border: 1px solid #303030;
  color: #fff;
  text-align: center;
  display: flex;
  justify-content: center;
  cursor: pointer;
  align-items: center;
  font-weight: 500;
  line-height: 1;
  font-weight: 18rem;
  height: 52rem;
  width: 100%;
  appearance: none;
  font-size: 18rem;
}
@media screen and (min-width: 768px), print {
  #contact .btns .formbtn input[type=submit] {
    transition: background-color 0.3s, color 0.3s;
    width: 470rem;
    height: 74rem;
    font-size: 22rem;
  }
}
#contact .wpcf7-spinner {
  position: absolute;
  left: 20rem;
  top: 50%;
  translate: 0 -48%;
  margin: 0;
}

::placeholder {
  color: #e1e1e1;
}

/*-----------------------------------------------------------------------------------*/
#notfound {
  text-align: center;
}
#notfound p {
  margin: 0;
  padding-top: 16rem;
}
@media screen and (min-width: 768px), print {
  #notfound p {
    padding-top: 0;
  }
}
#notfound .btns {
  margin: 32rem 0 -32rem;
}
@media screen and (min-width: 768px), print {
  #notfound .btns {
    margin: 56rem 0 0;
  }
}
#notfound .btns .more {
  margin: 0 auto;
  font-family: "Noto Sans JP", "游ゴシック体", "Yu Gothic", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", Arial, sans-serif;
}

/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/
/*-----------------------------------------------------------------------------------*/