@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Abril+Fatface&family=Zen+Kaku+Gothic+New:wght@400;700&family=Zen+Old+Mincho:wght@400;700;900&display=swap");
@layer foundation, vendor, layout, component, project, page, utilities;
:root {
  --sans-serif: "Noto Sans JP", "ヒラギノ角ゴシック", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", sans-serif;
  --serif: "Zen Old Mincho", serif;
  --en-sans: sans-serif;
  --en-serif: "Abril Fatface", serif;
  --base: #f8e9c1;
  --main: #000;
  --accent: #ff0000;
  --sp-base-fs: calc(26/750*100vw);
  --sp-pad: calc(40/750*100%);
  --sp-pad-s: calc(30/750*100%);
}

@layer foundation {
  body,
  h1,
  h2,
  h3,
  h4,
  h5,
  h6,
  p,
  dl,
  dt,
  dd,
  ol,
  ul,
  figure {
    all: unset;
    display: revert;
  }
  body {
    line-height: 1;
  }
  ol,
  ul {
    list-style: none;
  }
  table {
    border-collapse: collapse;
    border-spacing: 0;
  }
  img {
    vertical-align: middle;
  }
}
@layer foundation {
  html {
    height: 100%;
    scroll-behavior: smooth;
    font-size: 1vw;
  }
  @media screen and (max-width: 767px) {
    html {
      font-size: var(--sp-base-fs);
    }
  }
  body {
    text-size-adjust: 100%;
    font-feature-settings: "palt" 1;
    font-family: var(--sans-serif);
    line-height: 1.6111111111;
    min-width: 320px;
    color: var(--main);
    background: var(--base);
    font-size: 1.125rem;
  }
  body.is-main-nav-expanded {
    overflow: hidden;
  }
  *,
  *::before,
  *::after {
    box-sizing: border-box;
  }
  :focus-visible {
    outline: 2px solid #000;
  }
  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    line-height: 1.5;
  }
  img,
  svg,
  iframe,
  video,
  picture {
    max-width: 100%;
  }
  img {
    letter-spacing: 0;
    font-size: 12px;
    height: auto;
  }
  a {
    text-decoration: none;
    word-break: break-all;
    color: currentColor;
  }
  @media screen and (min-width: 768px) {
    a[href^="tel:"] {
      display: inline-block;
      pointer-events: none;
    }
  }
  small {
    font-size: 80%;
  }
  button,
  input[type=button],
  input[type=submit] {
    cursor: pointer;
    font: inherit;
  }
  button,
  input,
  select,
  textarea {
    font: inherit;
    color: inherit;
  }
  label {
    cursor: pointer;
    display: inline-block;
  }
  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    line-height: 1.5;
  }
  summary::-webkit-details-marker {
    display: none;
  }
  summary {
    list-style: none;
    display: block;
    cursor: pointer;
    user-select: none;
  }
  .grecaptcha-badge {
    display: none;
  }
}
@layer layout {}
@layer layout {
  .l-footer {
    position: relative;
    z-index: 101;
    background: #000;
    color: #fff;
    padding-top: 6.25rem;
    padding-bottom: 5rem;
  }
  @media screen and (max-width: 767px) {
    .l-footer {
      padding-top: 20vw;
      padding-bottom: 12vw;
    }
  }
  .l-footer__logo {
    width: 18.75rem;
    margin: 0 auto;
    margin-top: 7.25rem;
  }
  @media screen and (max-width: 767px) {
    .l-footer__logo {
      margin-top: 18.6666666667vw;
      width: 40vw;
    }
  }
  .l-footer__copyright {
    display: block;
    margin-top: 5.25rem;
    text-align: center;
    font-size: 1rem;
  }
  @media screen and (max-width: 767px) {
    .l-footer__copyright {
      margin-top: 10.6666666667vw;
      font-size: 2.6666666667vw;
    }
  }
  .l-footer-sns {
    display: flex;
    justify-content: center;
    gap: 4.375rem;
  }
  @media screen and (max-width: 767px) {
    .l-footer-sns {
      gap: 10.6666666667vw;
    }
  }
  .p-icon-sns {
    fill: #fff;
  }
  .p-icon-sns.is-x {
    width: 2.0625rem;
    aspect-ratio: 33/34;
  }
  @media screen and (max-width: 767px) {
    .p-icon-sns.is-x {
      width: 7.2vw;
    }
  }
  .p-icon-sns.is-line {
    width: 2.6875rem;
    aspect-ratio: 43/41;
  }
  @media screen and (max-width: 767px) {
    .p-icon-sns.is-line {
      width: 9.4666666667vw;
    }
  }
  .p-icon-sns.is-insta {
    width: 2.25rem;
    aspect-ratio: 35/35;
  }
  @media screen and (max-width: 767px) {
    .p-icon-sns.is-insta {
      width: 7.7333333333vw;
    }
  }
  .p-icon-sns img {
    width: 100%;
  }
  .l-footer-nav {
    max-width: 58.125rem;
    margin-top: 6.25rem;
    margin-left: auto;
    margin-right: auto;
    line-height: 1.4;
  }
  @media screen and (max-width: 767px) {
    .l-footer-nav {
      display: none;
    }
  }
  .l-footer-nav a {
    color: #fff;
  }
  .l-footer-nav__lists {
    display: flex;
    justify-content: space-between;
    margin-top: 1rem;
  }
  @media screen and (min-width: 768px) {
    .l-footer-nav__lists {
      gap: 6.25rem;
    }
  }
  .l-footer-nav__list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }
  .l-footer-nav a {
    display: inline-block;
    position: relative;
  }
  .l-footer-nav a::before {
    position: absolute;
    left: 0;
    top: 0;
    transform: translate(-100%, 4%) rotate(-15deg);
    content: "";
    display: block;
    aspect-ratio: 55/39;
    background: url("../img/icon/ramen.webp") 0 0/contain no-repeat;
    width: 1.75rem;
    pointer-events: none;
    opacity: 0;
    transition-property: opacity, transform;
    transition-duration: 0.2s;
  }
  @media (hover: hover) {
    .l-footer-nav a:hover::before {
      transform: translate(-120%, -2%) rotate(-15deg);
      opacity: 1;
    }
  }
  .l-footer-nav__children {
    margin-top: 1rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-left: 0.25rem;
  }
  .l-footer-nav__children > li::before {
    content: "・";
  }
  @media (hover: hover) {
    .l-footer-nav__children a:hover::before {
      transform: translate(-150%, -2%) rotate(-15deg);
    }
  }
}
@layer layout {
  @media screen and (min-width: 768px) {
    .home .l-header__logo {
      position: relative;
      z-index: 3;
      width: 12.625rem;
    }
  }
  @media screen and (min-width: 768px) {
    .l-header {
      padding: 2.5rem 2.5rem 2.5rem 3.5rem;
    }
  }
  @media screen and (min-width: 768px) {
    .l-header__inner {
      display: flex;
      flex-direction: row;
      flex-wrap: wrap;
      justify-content: space-between;
    }
  }
  .l-header__logo {
    width: 10rem;
  }
  @media screen and (max-width: 767px) {
    .l-header__logo {
      width: 28.8vw;
      margin-top: 4vw;
      margin-left: 4vw;
      padding-bottom: 6.6666666667vw;
    }
  }
  .l-header__logo a {
    display: inline-block;
  }
}
@layer layout {}
@layer layout {
  @media screen and (min-width: 768px) {
    .l-nav {
      display: flex;
      align-items: flex-start;
      gap: 2.875rem;
      padding-right: 5.625rem;
    }
  }
  .l-nav__btn {
    position: fixed;
    right: 0;
    top: 0;
    z-index: 10001;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    padding: 0;
    border: 0;
    transition: 0.25s background;
  }
  @media screen and (min-width: 768px) {
    .l-nav__btn {
      top: 2.5rem;
      right: 2.5rem;
    }
  }
  @media screen and (max-width: 767px) {
    .l-nav__btn {
      width: 15.2vw;
      height: 15.2vw;
    }
  }
  .l-nav__btn[aria-expanded=true] .l-nav__line.is-1 {
    opacity: 0;
  }
  .l-nav__btn[aria-expanded=true] .l-nav__line.is-2 {
    rotate: 45deg;
  }
  .l-nav__btn[aria-expanded=true] .l-nav__line.is-3 {
    opacity: 0;
  }
  .l-nav__btn[aria-expanded=true] .l-nav__line.is-4 {
    opacity: 1;
    rotate: -45deg;
  }
  .l-nav__btn[aria-expanded=true] line {
    stroke: #fff;
  }
  .l-nav__btn svg {
    width: 3.125rem;
    height: 3.375rem;
  }
  @media screen and (max-width: 767px) {
    .l-nav__btn svg {
      width: 6.6666666667vw;
      height: 7.2vw;
    }
  }
  .l-nav__line {
    transform-origin: center center;
    transition-property: opacity, rotate stroke;
    stroke: #000;
    stroke-width: 2px;
  }
  .l-nav__line.is-4 {
    opacity: 0;
  }
  @media screen and (max-width: 767px) {
    .l-nav__line {
      stroke-width: 3px;
    }
  }
  .l-nav__list {
    font-family: var(--serif);
    font-weight: 600;
  }
  @media screen and (min-width: 768px) {
    .l-nav__list {
      font-size: 1.375rem;
      display: flex;
      align-items: center;
      gap: 2.875rem;
    }
  }
  .l-nav__item-a {
    position: relative;
  }
  @media screen and (max-width: 767px) {
    .l-nav__item-a {
      position: absolute;
      top: 3.4666666667vw;
      right: 16vw;
    }
  }
  .l-nav__item-a:hover .l-nav__lang-children {
    opacity: 1;
    pointer-events: fill;
  }
  .l-nav__ilink-btn {
    display: inline-block;
    position: relative;
    font-size: 0.875rem;
    border: 1px solid #000;
    border-radius: 6.25rem;
    font-family: var(--sans-serif);
    padding: 0.625rem 1.5rem;
    background-color: transparent;
    transition-property: color, background;
    transition-duration: 0.25s;
  }
  @media screen and (max-width: 767px) {
    .l-nav__ilink-btn {
      font-size: 1.8666666667vw;
      padding: 1.3333333333vw 2.6666666667vw;
    }
  }
  .l-nav__ilink-btn:focus, .l-nav__ilink-btn:hover {
    background: #000;
    color: #fff;
  }
  .l-nav__ilink-btn:focus + .l-nav__lang-children, .l-nav__ilink-btn:hover + .l-nav__lang-children {
    opacity: 1;
    pointer-events: fill;
  }
  .l-nav__link {
    display: inline-block;
    position: relative;
  }
  .l-nav__link::before {
    position: absolute;
    left: 0;
    top: 0;
    transform: translate(-100%, 4%) rotate(-15deg);
    content: "";
    display: block;
    aspect-ratio: 55/39;
    background: url("../img/icon/ramen_black.webp") 0 0/contain no-repeat;
    width: 1.75rem;
    pointer-events: none;
    opacity: 0;
    transition-property: opacity, transform;
    transition-duration: 0.2s;
  }
  @media (hover: hover) {
    .l-nav__link:hover::before {
      transform: translate(-110%, 0%) rotate(-15deg);
      opacity: 1;
    }
  }
  .l-nav__lang-children {
    opacity: 0;
    pointer-events: none;
    font-family: var(--sans-serif);
    position: absolute;
    left: 0;
    top: 2.75rem;
    z-index: 10;
    width: 100%;
    font-size: 1.125rem;
    font-weight: normal;
    text-align: center;
    line-height: 1.3;
    padding-top: 0.625rem;
    transition: 0.4s opacity;
  }
  @media screen and (max-width: 767px) {
    .l-nav__lang-children {
      top: 6.6666666667vw;
      font-size: 2.4vw;
    }
  }
  .l-nav__lang-children::after {
    content: "";
    width: 0;
    height: 0;
    position: absolute;
    left: 50%;
    top: 1px;
    transform: translate(-50%, 0%);
    border-style: solid;
    border-width: 0 0.3125rem 0.625rem 0.625rem;
    border-color: transparent transparent rgba(0, 0, 0, 0.8) transparent;
  }
  .l-nav__lang-children li {
    background: rgba(0, 0, 0, 0.8);
    padding: 0 0.625rem;
  }
  .l-nav__lang-children li:not(:last-child) {
    border-bottom: 1px solid rgba(255, 255, 255, 0.3);
  }
  .l-nav__lang-children a {
    color: #fff;
    padding: 1rem;
  }
  .l-nav-modal {
    position: fixed;
    background: #000;
    width: 100%;
    top: -62.5rem;
    left: 0;
    z-index: 1000;
    transition: 0.4s;
    visibility: hidden;
  }
  .l-nav-modal.is-expanded {
    top: 0;
    visibility: visible;
  }
  .l-nav-modal a {
    color: #fff;
  }
  @media screen and (min-width: 768px) {
    .l-nav-modal__inner {
      display: grid;
      grid-template-columns: 10rem 1fr;
      justify-content: space-between;
      padding: 1.875rem 5rem 4.375rem 2.5rem;
    }
  }
  @media screen and (max-width: 767px) {
    .l-nav-modal__inner {
      padding: 4vw 5.3333333333vw;
      height: 100vh;
      overflow: auto;
      overscroll-behavior-y: contain;
    }
  }
  @media screen and (max-width: 767px) {
    .l-nav-modal__logo {
      width: 21.3333333333vw;
    }
  }
  .l-nav-modal__logo img {
    width: 100%;
  }
  .l-nav-modal__body {
    font-family: var(--serif);
  }
  @media screen and (min-width: 768px) {
    .l-nav-modal__body {
      display: flex;
      justify-content: flex-end;
      font-size: 1.25rem;
      padding-top: 0.625rem;
    }
  }
  @media screen and (max-width: 767px) {
    .l-nav-modal__body {
      margin-top: 5.3333333333vw;
      font-size: 4vw;
    }
  }
  .l-nav-modal__wilink-btn {
    display: flex;
    justify-content: flex-end;
  }
  @media screen and (min-width: 768px) {
    .l-nav-modal__wilink-btn {
      margin-bottom: 3.125rem;
      padding-right: 3.125rem;
    }
  }
  .l-nav-modal__ilink-btn {
    display: inline-block;
    position: relative;
    font-size: 0.875rem;
    border: 1px solid #fff;
    border-radius: 6.25rem;
    font-family: var(--sans-serif);
    padding: 0.625rem 1.5rem;
    background-color: transparent;
    transition-property: color, background;
    transition-duration: 0.25s;
  }
  @media screen and (max-width: 767px) {
    .l-nav-modal__ilink-btn {
      position: absolute;
      top: 4vw;
      right: 16vw;
      font-size: 1.8666666667vw;
      padding: 1.3333333333vw 2.6666666667vw;
    }
  }
  @media (hover: hover) {
    .l-nav-modal__ilink-btn:hover {
      background: #000;
      color: #fff;
    }
  }
  @media screen and (min-width: 768px) {
    .l-nav-modal__lists {
      display: flex;
      justify-content: space-between;
      margin-top: 1.25rem;
      gap: 4.375rem;
    }
  }
  @media screen and (max-width: 767px) {
    .l-nav-modal__lists {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 9.3333333333vw;
      margin-top: 5.3333333333vw;
    }
  }
  .l-nav-modal__list {
    display: flex;
    flex-direction: column;
    gap: 1rem;
  }
  @media screen and (max-width: 767px) {
    .l-nav-modal__list {
      gap: 6.6666666667vw;
    }
  }
  .l-nav-modal__list a {
    display: inline-block;
    position: relative;
  }
  .l-nav-modal__list a::before {
    position: absolute;
    left: 0;
    top: 0;
    transform: translate(-100%, 4%) rotate(-15deg);
    content: "";
    display: block;
    aspect-ratio: 55/39;
    background: url("../img/icon/ramen.webp") 0 0/contain no-repeat;
    width: 1.75rem;
    pointer-events: none;
    opacity: 0;
    transition-property: opacity, transform;
    transition-duration: 0.2s;
  }
  @media (hover: hover) {
    .l-nav-modal__list a:hover::before {
      transform: translate(-120%, -2%) rotate(-15deg);
      opacity: 1;
    }
  }
  .l-nav-modal__children {
    margin-top: 1rem;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-left: 0.25rem;
  }
  @media screen and (max-width: 767px) {
    .l-nav-modal__children {
      margin-top: 6.6666666667vw;
      gap: 6.6666666667vw;
    }
  }
  .l-nav-modal__children > li::before {
    content: "・";
  }
  @media (hover: hover) {
    .l-nav-modal__children a:hover::before {
      transform: translate(-150%, -2%) rotate(-15deg);
    }
  }
  .l-nav-modal__sns {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 2.5rem;
    gap: 1.875rem;
  }
  @media screen and (max-width: 767px) {
    .l-nav-modal__sns {
      margin: 20vw 0 0 0;
    }
  }
  .l-nav-modal .p-icon-sns {
    fill: #fff;
  }
  .l-nav-modal .p-icon-sns.is-x {
    width: 1.5rem;
    aspect-ratio: 33/34;
  }
  @media screen and (max-width: 767px) {
    .l-nav-modal .p-icon-sns.is-x {
      width: 7.2vw;
    }
  }
  .l-nav-modal .p-icon-sns.is-line {
    width: 2rem;
    aspect-ratio: 43/41;
  }
  @media screen and (max-width: 767px) {
    .l-nav-modal .p-icon-sns.is-line {
      width: 9.4666666667vw;
    }
  }
  .l-nav-modal .p-icon-sns.is-insta {
    width: 1.625rem;
    aspect-ratio: 35/35;
  }
  @media screen and (max-width: 767px) {
    .l-nav-modal .p-icon-sns.is-insta {
      width: 7.7333333333vw;
    }
  }
  .l-nav-modal .p-icon-sns img {
    width: 100%;
  }
}
@layer layout {
  .l-page__body {
    position: relative;
  }
}
@layer component {
  .c-btn {
    cursor: pointer;
    position: relative;
    display: inline-block;
    line-height: 1.1;
    text-decoration: none;
    user-select: none;
  }
  .c-btn:hover {
    text-decoration: none;
  }
}
@layer component {
  .c-container-w {
    width: 82.5rem;
    max-width: 100%;
    margin-right: auto;
    margin-left: auto;
  }
  .c-container {
    width: 80rem;
    max-width: 100%;
    margin-right: auto;
    margin-left: auto;
  }
  .c-container-s {
    width: 61.25rem;
    max-width: 100%;
    margin-right: auto;
    margin-left: auto;
  }
}
@layer component {
  .c-icon {
    position: relative;
    display: inline-block;
    background: 50% 50% no-repeat;
    background-size: contain;
    vertical-align: top;
    line-height: 1;
    font-style: normal;
  }
}
@layer project {
  .p-btn-a {
    display: inline-flex;
    align-items: center;
    font-size: 1.5rem;
    gap: 1.875rem;
  }
  @media screen and (max-width: 767px) {
    .p-btn-a {
      font-size: 3.7333333333vw;
      background: #000;
      padding: 2.9333333333vw 5.3333333333vw 2.9333333333vw 8vw;
      gap: 5.3333333333vw;
      color: #fff;
      border-radius: 13.3333333333vw;
    }
  }
  @media screen and (min-width: 768px) {
    .p-btn-a.is-white {
      color: #fff;
    }
  }
  .p-btn-a__label {
    border-bottom: 2px solid transparent;
    transition-property: border;
    transition-duration: 0.25s;
  }
  @media screen and (min-width: 768px) {
    .p-btn-a__icon {
      background: #fff;
      width: 3.75rem;
      height: 3.75rem;
      box-shadow: 0 0 10px rgba(0, 0, 0, 0.05);
      border-radius: 6.25rem;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }
  }
  .p-btn-a__icon svg {
    transition-property: transform;
    transition-duration: 0.25s;
  }
  .p-btn-a__arrow {
    width: 1.875rem;
    aspect-ratio: 30/23;
  }
  .p-btn-a__arrow.is-prev {
    rotate: 180deg;
  }
  @media screen and (max-width: 767px) {
    .p-btn-a__arrow {
      fill: #fff;
      width: 4.2666666667vw;
    }
  }
  @media (hover: hover) {
    .p-btn-a:hover .p-btn-a__label {
      border-bottom-color: var(--main);
    }
    .p-btn-a:hover .p-btn-a__icon svg {
      transform: translateX(2px);
    }
    .p-btn-a:hover.is-white .p-btn-a__label {
      border-bottom-color: #fff;
    }
  }
  .p-btn-more {
    display: inline-flex;
  }
  .p-btn-more__label {
    font-size: 1.5rem;
  }
  .p-btn-shop-wrap {
    position: fixed;
    z-index: 100;
    transition: 0.5s transform;
  }
  @media screen and (min-width: 768px) {
    .p-btn-shop-wrap {
      right: 0;
      top: 50%;
      transform: translate(110%, 0);
    }
  }
  @media screen and (max-width: 767px) {
    .p-btn-shop-wrap {
      text-align: center;
      margin-top: 10.6666666667vw;
      bottom: 2.6666666667vw;
      left: 0;
      width: 100%;
      transform: translate(0, 140%);
    }
  }
  .p-btn-shop-wrap.is-show {
    transform: translate(0, 0%);
  }
  .p-btn-shop {
    color: #fff;
    background: #000;
    font-family: var(--serif);
  }
  @media screen and (min-width: 768px) {
    .p-btn-shop {
      overflow: hidden;
      width: 4.375rem;
      border-radius: 0.625rem 0 0 0.625rem;
      writing-mode: vertical-rl;
      padding: 1.875rem 1.125rem 1.875rem 1.5rem;
    }
  }
  @media screen and (max-width: 767px) {
    .p-btn-shop {
      font-size: 4vw;
      display: inline-flex;
      flex-direction: row;
      flex-wrap: wrap;
      align-items: center;
      justify-content: center;
      gap: 2.6666666667vw;
      width: 50.6666666667vw;
      height: 13.3333333333vw;
      letter-spacing: -0.12em;
      border-radius: 1.3333333333vw;
    }
  }
  .p-btn-shop__icon {
    display: inline-block;
    position: relative;
  }
  @media screen and (max-width: 767px) {
    .p-btn-shop__icon {
      width: 4vw;
      height: 4vw;
    }
  }
  .p-btn-shop__ramen {
    background-image: url("../img/icon/ramen.webp");
    width: 1.75rem;
    height: 1.75rem;
    position: absolute;
    top: 0;
    left: 0;
    transform: translateX(-250%);
    transition: 0.4s transform;
  }
  .p-btn-shop__cart {
    background-image: url("../img/icon/cart.webp");
  }
  @media screen and (min-width: 768px) {
    .p-btn-shop__cart {
      width: 1.5rem;
      height: 1.5rem;
      margin-bottom: 0.625rem;
      transform: translateX(-30%);
      transition: 0.4s transform;
    }
  }
  @media screen and (max-width: 767px) {
    .p-btn-shop__cart {
      width: 100%;
      height: 100%;
    }
  }
  @media (hover: hover) {
    .p-btn-shop:hover .p-btn-shop__cart {
      transform: translateX(200%);
    }
    .p-btn-shop:hover .p-btn-shop__ramen {
      transform: translateX(-16%);
    }
  }
}
@layer project {
  .p-icon-toggle {
    display: inline-block;
    position: relative;
    width: 1em;
    height: 1em;
    margin-right: 0.5em;
  }
  .p-icon-toggle::before, .p-icon-toggle::after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    height: 2px;
    background: #333;
    transform: translateY(50%);
    border-radius: 10px;
  }
  .p-icon-toggle::before {
    transition: 0.25s transform;
    transform: rotate(90deg);
  }
  .p-icon-toggle::after {
    transform: rotate(0);
  }
  details[open] .p-icon-toggle::before {
    transform: rotate(0);
  }
}
@media screen and (min-width: 768px) {
  .p-article__body figure.wp-block-image.size-large {
    margin-top: 3.75rem;
    margin-bottom: 3.75rem;
    margin-left: -1.25rem;
    margin-right: -1.25rem;
  }
}
@media screen and (max-width: 767px) {
  .p-article__body figure.wp-block-image.size-large {
    margin-top: 6.6666666667vw;
    margin-bottom: 6.6666666667vw;
  }
}

@layer project {
  .p-article__hdr {
    background: url("../img/content/nami.svg") 0 100%/auto 0.5625rem repeat-x;
    padding: 1.25rem;
    padding-bottom: 2.875rem;
  }
  @media screen and (max-width: 767px) {
    .p-article__hdr {
      background-size: auto 1.2vw;
      padding: 1.3333333333vw 1.3333333333vw 6.1333333333vw 1.3333333333vw;
    }
  }
  .p-article__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 1.25rem;
    margin-bottom: 1.25rem;
  }
  @media screen and (max-width: 767px) {
    .p-article__meta {
      margin-bottom: 2.6666666667vw;
    }
  }
  .p-article__tax {
    display: flex;
    gap: 0.625rem;
  }
  @media screen and (max-width: 767px) {
    .p-article__tax {
      font-size: 2.6666666667vw;
    }
  }
  .p-article__tax > li {
    background: #000;
    color: #fff;
    line-height: 1.1;
    border-radius: 6.25rem;
    padding: 1.0666666667vw 3.4666666667vw;
    letter-spacing: 0.2em;
  }
  @media screen and (min-width: 768px) {
    .p-article__tax > li {
      padding: 0.5rem 1.625rem 0.5rem 1.8125rem;
      font-size: 1rem;
    }
  }
  .p-article__ttl {
    font-size: 2.25rem;
    font-weight: 600;
    font-family: var(--serif);
  }
  @media screen and (max-width: 767px) {
    .p-article__ttl {
      font-size: 5.3333333333vw;
    }
  }
  .p-article__body {
    line-height: 2;
    letter-spacing: 0.04em;
    margin-top: 6.6666666667vw;
  }
  @media screen and (min-width: 768px) {
    .p-article__body {
      margin-top: 3.75rem;
      padding: 0 1.25rem;
    }
  }
  .p-article__body ul {
    list-style: none;
  }
  .p-article__body ul li {
    position: relative;
    padding-left: 2.875rem;
  }
  @media screen and (max-width: 767px) {
    .p-article__body ul li {
      padding-left: 6.6666666667vw;
    }
    .p-article__body ul li + li {
      margin-top: 0.8em;
    }
  }
  .p-article__body ul li::before {
    position: absolute;
    left: 0;
    top: 1em;
    content: "";
    height: 0.3125rem;
    width: 1.875rem;
    border-top: 1px solid #000;
    border-bottom: 1px solid #000;
  }
  @media screen and (max-width: 767px) {
    .p-article__body ul li::before {
      top: 2.5333333333vw;
      width: 4vw;
    }
  }
  .p-article__body ul li ul {
    margin: 0;
  }
  @media screen and (max-width: 767px) {
    .p-article__body ul li ul {
      margin-top: 0.8em;
    }
  }
  .p-article__body ul li ul li::before {
    border-top-color: #999999;
    border-bottom-color: #999999;
  }
  .p-article__body ol {
    all: revert;
    margin: 0 0 0 16px;
    padding: 0;
  }
  .p-article__body ol li::marker {
    color: #B3AFAA;
  }
  .p-article__body ol li ol {
    list-style-type: upper-roman;
    margin: 0;
    margin-left: 1.25rem;
  }
  .p-article__body ol li ol ol {
    list-style-type: lower-latin;
  }
  .p-article__body h2, .p-article__body figure, .p-article__body table, .p-article__body dl, .p-article__body > div {
    margin-top: 3.75rem;
    margin-bottom: 3.75rem;
  }
  @media screen and (max-width: 767px) {
    .p-article__body h2, .p-article__body figure, .p-article__body table, .p-article__body dl, .p-article__body > div {
      margin-top: 6.6666666667vw;
      margin-bottom: 6.6666666667vw;
    }
  }
  .p-article__body ul, .p-article__body ol, .p-article__body blockquote {
    margin-top: 2.5rem;
    margin-bottom: 2.5rem;
  }
  @media screen and (max-width: 767px) {
    .p-article__body ul, .p-article__body ol, .p-article__body blockquote {
      margin-top: 6.6666666667vw;
      margin-bottom: 6.6666666667vw;
    }
  }
  .p-article__body p {
    margin-top: 1.25rem;
    margin-bottom: 1.25rem;
  }
  @media screen and (max-width: 767px) {
    .p-article__body p {
      margin-top: 2.6666666667vw;
      margin-bottom: 2.6666666667vw;
    }
  }
  .p-article__body figcaption {
    margin-top: 1.5rem;
    font-size: 0.875rem;
    line-height: 1.7857142857;
  }
  @media screen and (max-width: 767px) {
    .p-article__body figcaption {
      margin-top: 2.4vw;
      font-size: 2.6666666667vw;
      line-height: 2;
    }
  }
  .p-article__body blockquote {
    margin-left: 0;
    margin-right: 0;
    padding-left: 1.875rem;
    border-left: 10px solid #ccc;
  }
  .p-article__body > *:last-child {
    margin-bottom: 0;
  }
  .p-article__body figure,
  .p-article__body .p-heading--lv2,
  .p-article__body h2,
  .p-article__body .p-heading--lv3,
  .p-article__body h3,
  .p-article__body .p-heading--lv4,
  .p-article__body h4,
  .p-article__body .p-heading--lv5,
  .p-article__body h5,
  .p-article__body .p-heading--lv6,
  .p-article__body h6 {
    font-weight: 600;
    line-height: 2;
  }
  @media screen and (min-width: 768px) {
    .p-article__body figure,
    .p-article__body .p-heading--lv2,
    .p-article__body h2,
    .p-article__body .p-heading--lv3,
    .p-article__body h3,
    .p-article__body .p-heading--lv4,
    .p-article__body h4,
    .p-article__body .p-heading--lv5,
    .p-article__body h5,
    .p-article__body .p-heading--lv6,
    .p-article__body h6 {
      margin-top: 3.75rem;
      margin-bottom: 2.5rem;
      margin-left: -1.25rem;
      margin-right: -1.25rem;
    }
  }
  @media screen and (max-width: 767px) {
    .p-article__body figure,
    .p-article__body .p-heading--lv2,
    .p-article__body h2,
    .p-article__body .p-heading--lv3,
    .p-article__body h3,
    .p-article__body .p-heading--lv4,
    .p-article__body h4,
    .p-article__body .p-heading--lv5,
    .p-article__body h5,
    .p-article__body .p-heading--lv6,
    .p-article__body h6 {
      line-height: 1.4375;
      margin-top: 6.6666666667vw;
      margin-bottom: 6.6666666667vw;
    }
  }
  .p-article__body .p-heading--lv2,
  .p-article__body h2 {
    border: 3px double #000;
    padding: 1.5rem 1.875rem;
    font-size: 1.5rem;
  }
  @media screen and (max-width: 767px) {
    .p-article__body .p-heading--lv2,
    .p-article__body h2 {
      padding: 2.1333333333vw 2.6666666667vw;
      font-size: 4.2666666667vw;
    }
  }
  .p-article__body .p-heading--lv3,
  .p-article__body h3 {
    border-bottom: 3px double #000;
    font-size: 1.375rem;
  }
  @media screen and (min-width: 768px) {
    .p-article__body .p-heading--lv3,
    .p-article__body h3 {
      padding: 0 1.25rem 1.25rem 1.25rem;
    }
  }
  @media screen and (max-width: 767px) {
    .p-article__body .p-heading--lv3,
    .p-article__body h3 {
      padding-bottom: 2.6666666667vw;
      font-size: 4.2666666667vw;
    }
  }
  .p-article__body .p-heading--lv4,
  .p-article__body h4 {
    padding: 1.25rem;
    border: 1px dotted #000;
  }
  @media screen and (min-width: 768px) {
    .p-article__body .p-heading--lv4,
    .p-article__body h4 {
      padding: 1.25rem;
    }
  }
  @media screen and (max-width: 767px) {
    .p-article__body .p-heading--lv4,
    .p-article__body h4 {
      font-size: 3.7333333333vw;
      padding: 2.4vw 3.4666666667vw;
    }
  }
  .p-article__body .p-heading--lv5,
  .p-article__body h5 {
    border-bottom: 1px dotted #000;
  }
  @media screen and (min-width: 768px) {
    .p-article__body .p-heading--lv5,
    .p-article__body h5 {
      padding: 0 1.25rem 1.25rem 1.25rem;
    }
  }
  @media screen and (max-width: 767px) {
    .p-article__body .p-heading--lv5,
    .p-article__body h5 {
      padding-bottom: 2.6666666667vw;
      font-size: 3.7333333333vw;
      line-height: 2;
    }
  }
  .p-article__body .p-heading--lv6,
  .p-article__body h6 {
    display: list-item;
    list-style: disc;
    margin-left: 1.25rem;
  }
  .p-article__body table {
    width: 100%;
    table-layout: fixed;
    text-align: center;
  }
  .p-article__body table th, .p-article__body table td {
    border: 1px solid #D2CFCB;
    padding: 1em;
  }
  .p-article__body table thead th {
    background: #DBD8D5;
  }
  .p-article__body table thead td {
    background: #F5F3F0;
  }
  .p-article__body table tbody th {
    background: #F5F3F0;
  }
  .p-article__body a:not(.c-btn) {
    color: var(--accent);
    text-decoration: underline;
  }
  @media (hover: hover) {
    .p-article__body a:not(.c-btn):hover {
      text-decoration: none;
    }
  }
  .p-article__body a:not(.c-btn)[target=_blank]::after {
    content: "";
    width: 0.875rem;
    height: 0.875rem;
    display: inline-block;
    background: url("../img/icon/icon_blank.svg");
    margin: 0 0.1875rem 0 0.375rem;
  }
  @media screen and (max-width: 767px) {
    .p-article__body a:not(.c-btn)[target=_blank]::after {
      width: 3.7333333333vw;
      height: 3.7333333333vw;
    }
  }
  .p-article__body a[href^="tel:"] {
    text-decoration: none;
    color: currentColor;
  }
  .p-article__share {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.875rem;
    background: url("../img/content/nami.svg") 0 0/auto 0.5625rem repeat-x, url("../img/content/nami.svg") 0 100%/auto 0.5625rem repeat-x;
    margin-top: 3.75rem;
    padding: 2.5rem;
  }
  @media screen and (max-width: 767px) {
    .p-article__share {
      background-size: auto 1.2vw, auto 1.2vw;
      margin-top: 10.6666666667vw;
      padding: 5.3333333333vw;
      gap: 5.3333333333vw;
    }
  }
  .p-article__share dt {
    font-weight: 600;
  }
  .p-article__share dd {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.25rem;
  }
  @media screen and (max-width: 767px) {
    .p-article__share dd {
      gap: 2.6666666667vw;
    }
  }
  .p-article__share a {
    width: 4.375rem;
    height: 4.375rem;
    background: #000;
    border-radius: 6.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  @media screen and (max-width: 767px) {
    .p-article__share a {
      width: 10.6666666667vw;
      height: 10.6666666667vw;
    }
  }
  .p-article__share svg {
    fill: white;
  }
  .p-article__share svg.is-x {
    width: 2.0625rem;
    aspect-ratio: 33/34;
  }
  @media screen and (max-width: 767px) {
    .p-article__share svg.is-x {
      width: 5.0666666667vw;
    }
  }
  .p-article__share svg.is-line {
    width: 2.6875rem;
    aspect-ratio: 43/41;
  }
  @media screen and (max-width: 767px) {
    .p-article__share svg.is-line {
      width: 6.6666666667vw;
    }
  }
}
@layer project {
  .p-breadcrumbs {
    pointer-events: none;
    position: sticky;
    padding-left: 1.5625rem;
    top: 3.125rem;
    z-index: 10;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    letter-spacing: 0.1em;
    height: 0;
    white-space: nowrap;
    font-size: 0.875rem;
  }
  @media screen and (max-width: 767px) {
    .p-breadcrumbs {
      display: none;
    }
  }
  .p-breadcrumbs span[property=itemListElement] {
    display: inline-block;
    writing-mode: sideways-rl;
  }
  .p-breadcrumbs [property=name] {
    display: inline-block;
  }
  .p-breadcrumbs a {
    pointer-events: fill;
    position: relative;
    display: inline-block;
    margin-bottom: 0.625rem;
    padding-bottom: 2.4375rem;
  }
  .p-breadcrumbs a::after {
    content: "";
    display: block;
    width: 2px;
    height: 1.875rem;
    background: #000;
    position: absolute;
    bottom: 0;
    left: 40%;
  }
}
@layer project {
  .p-cloud {
    overflow: hidden;
    position: absolute;
    z-index: 1;
    aspect-ratio: 1056/414;
    width: 33rem;
  }
  .p-cloud::before {
    background: url("../img/content/cloud_1.png") 0 0/contain no-repeat;
    content: "";
    display: block;
    width: 100%;
    height: 100%;
  }
  @media screen and (max-width: 767px) {
    .p-cloud {
      width: 49.0666666667vw;
      aspect-ratio: 435/181;
    }
    .p-cloud::before {
      background-image: url("../img/content/cloud_1_sp.png");
    }
  }
  .p-cloud.is-a {
    aspect-ratio: 560/230;
    width: 35rem;
  }
  .p-cloud.is-a::before {
    background-image: url("../img/content/cloud_2.png");
  }
  @media screen and (min-width: 768px) {
    .p-cloud.is-a::before {
      background-size: auto 100%;
    }
  }
  @media screen and (max-width: 767px) {
    .p-cloud.is-a {
      width: 48vw;
    }
  }
  .p-cloud.is-c {
    aspect-ratio: 720/256;
    width: 22.5rem;
  }
  .p-cloud.is-c::before {
    background-image: url("../img/content/cloud_3.png");
  }
  @media screen and (max-width: 767px) {
    .p-cloud.is-c {
      width: 34.6666666667vw;
      height: 17.0666666667vw;
    }
    .p-cloud.is-c::before {
      background-size: auto 100%;
      background-position: 100% 0;
    }
  }
  .p-cloud.is-d {
    aspect-ratio: 794/254;
    width: 24.8125rem;
  }
  .p-cloud.is-d::before {
    background-image: url("../img/content/cloud_4.png");
  }
  @media screen and (max-width: 767px) {
    .p-cloud.is-d {
      width: 34.6666666667vw;
      height: 17.3333333333vw;
    }
    .p-cloud.is-d::before {
      background-size: auto 100%;
    }
  }
  .p-cloud.is-e {
    aspect-ratio: 1000/364;
    width: 31.25rem;
  }
  .p-cloud.is-e::before {
    background-image: url("../img/content/cloud_5.png");
  }
  @media screen and (max-width: 767px) {
    .p-cloud.is-e {
      width: 42vw;
    }
  }
}
@layer project {
  .p-doc {
    position: relative;
    z-index: 2;
    background: #fff;
    padding: 4.375rem;
  }
  @media screen and (max-width: 767px) {
    .p-doc {
      margin: 0 var(--sp-pad-s);
      padding: 5.3333333333vw var(--sp-pad-s) 8vw var(--sp-pad-s);
    }
  }
  .p-doc__sec + .p-doc__sec {
    margin-top: 4.25rem;
  }
  @media screen and (max-width: 767px) {
    .p-doc__sec + .p-doc__sec {
      margin-top: 6.6666666667vw;
    }
  }
  .p-doc__ttl {
    border-bottom: 3px double #000;
    font-size: 1.875rem;
    margin-bottom: 2.5rem;
    padding: 0 1.25rem 0.5rem 1.25rem;
    font-weight: 600;
    font-family: var(--serif);
  }
  @media screen and (max-width: 767px) {
    .p-doc__ttl {
      margin-bottom: 4vw;
      padding: 0 1.3333333333vw 1.3333333333vw 1.3333333333vw;
      font-size: 5.3333333333vw;
    }
  }
  .p-doc__mt {
    margin-top: 1em;
  }
  .p-doc__mt2 {
    margin-top: 2em;
  }
  .p-doc__text {
    padding: 0 1.25rem;
    line-height: 2;
  }
  @media screen and (max-width: 767px) {
    .p-doc__text {
      padding: 0 1.3333333333vw;
      line-height: 1.6923076923;
    }
  }
  .p-doc__list {
    list-style: none;
  }
  .p-doc__list li {
    position: relative;
    padding-left: 2.875rem;
  }
  @media screen and (max-width: 767px) {
    .p-doc__list li {
      padding-left: 6.6666666667vw;
    }
    .p-doc__list li + li {
      margin-top: 0.8em;
    }
  }
  .p-doc__list li::before {
    position: absolute;
    left: 0;
    top: 1em;
    content: "";
    height: 0.3125rem;
    width: 1.875rem;
    border-top: 1px solid #000;
    border-bottom: 1px solid #000;
  }
  @media screen and (max-width: 767px) {
    .p-doc__list li::before {
      top: 2.5333333333vw;
      width: 4vw;
    }
  }
  .p-doc-box {
    background: #F2F2F2;
    padding: 1.875rem;
    line-height: 2;
  }
  @media screen and (max-width: 767px) {
    .p-doc-box {
      padding: var(--sp-pad);
      line-height: 1.6153846154;
    }
  }
}
@layer project {
  .p-hdr-page {
    position: relative;
    text-align: center;
    margin-top: 3.75rem;
    padding-bottom: 4.375rem;
  }
  @media screen and (max-width: 767px) {
    .p-hdr-page {
      margin-top: 2.6666666667vw;
      padding-bottom: 16vw;
    }
  }
  .p-hdr-page::before, .p-hdr-page::after {
    content: "";
    display: block;
    z-index: 1;
    width: 100%;
    pointer-events: none;
    position: absolute;
    top: -10.625rem;
  }
  .p-hdr-page::after {
    left: 0;
    height: 17.5rem;
    background: url("../img/content/ttl_cloud.svg") 50% 0/153.3333333333vw auto no-repeat;
  }
  @media screen and (max-width: 767px) {
    .p-hdr-page::after {
      top: -18.6666666667vw;
      background: url("../img/content/ttl_cloud_sp.svg") 50% 0/196vw auto no-repeat;
    }
  }
  .p-hdr-page__ttl {
    position: relative;
    z-index: 2;
  }
  .p-hdr-page__ttl.is-plain {
    font-size: 6.25rem;
    text-align: center;
    font-family: var(--serif);
    font-weight: bold;
  }
  @media screen and (max-width: 767px) {
    .p-hdr-page__ttl.is-plain {
      font-size: 10.6666666667vw;
    }
  }
  .p-hdr-page__ttl-img {
    width: calc(var(--my-width) / 16 * 1rem);
  }
  @media screen and (max-width: 767px) {
    .p-hdr-page__ttl-img {
      width: calc(var(--my-width) / 750 * 100vw);
    }
  }
  .p-hdr-page.is-blog::before {
    right: 1.875rem;
    transform: translateY(0.375rem);
    width: 18.125rem;
    height: 18rem;
    z-index: 2;
    background: url("../img/page/blog/illust.webp") 0 0/contain no-repeat;
  }
  @media screen and (max-width: 767px) {
    .p-hdr-page.is-blog::before {
      top: -10.6666666667vw;
      right: 0.2666666667vw;
      height: 38.2666666667vw;
      width: 38.6666666667vw;
    }
  }
  .p-hdr-page.is-privacy::before {
    top: -7.5rem;
    right: 0;
    transform: translateY(0.375rem);
    width: 21.25rem;
    height: 15rem;
    z-index: 2;
    background: url("../img/page/privacy/illust.webp") 0 0/contain no-repeat;
  }
  @media screen and (max-width: 767px) {
    .p-hdr-page.is-privacy::before {
      top: 6.1333333333vw;
      right: 0.2666666667vw;
      height: 31.4666666667vw;
      width: 25.0666666667vw;
      background-position: 2.1333333333vw 0;
    }
  }
  @media screen and (max-width: 767px) {
    .p-hdr-page.is-blog-single {
      padding-bottom: 9.3333333333vw;
    }
  }
  .p-hdr-page.is-access::before {
    top: -5.625rem;
    right: 0;
    transform: translateY(0.375rem);
    width: 26.875rem;
    height: 27.5rem;
    z-index: 2;
    background: url("../img/page/access/illust.webp") 4.5rem 0/contain no-repeat;
  }
  @media screen and (max-width: 767px) {
    .p-hdr-page.is-access::before {
      top: -4.8vw;
      height: 33.3333333333vw;
      width: 32vw;
      background-position: 5.3333333333vw 0;
    }
  }
  .p-hdr-a {
    margin-bottom: 2em;
  }
  .p-hdr-a__ttl {
    font-family: var(--serif);
    font-size: 1.875rem;
  }
}
@layer project {
  .p-img-foot {
    position: relative;
    z-index: 1;
    margin-top: -6.25rem;
  }
  @media screen and (max-width: 767px) {
    .p-img-foot {
      margin-top: -12vw;
    }
  }
  .p-img-foot img {
    width: 100%;
  }
}
@layer project {
  .p-menu-unit + .p-menu-unit {
    margin-top: 3.75rem;
  }
  .p-menu-unit__hdr {
    margin-top: 5rem;
  }
  @media screen and (max-width: 767px) {
    .p-menu-unit__hdr {
      margin-top: 10.6666666667vw;
    }
  }
  @media screen and (min-width: 768px) {
    .p-menu-unit__hdr.is-menu {
      margin-bottom: -3.75rem;
    }
  }
  .p-menu-unit__ttl {
    position: relative;
    z-index: 2;
    text-align: center;
    font-family: var(--serif);
    font-weight: 600;
    font-size: 5rem;
    margin-bottom: 0.625rem;
  }
  @media screen and (max-width: 767px) {
    .p-menu-unit__ttl {
      font-size: 10.6666666667vw;
    }
  }
  .p-menu-unit__lead {
    margin-bottom: 3.75rem;
  }
  @media screen and (min-width: 768px) {
    .p-menu-unit__lead {
      text-align: center;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-unit__lead {
      margin-bottom: 6.6666666667vw;
    }
  }
  .p-menu-unit__lead-a {
    margin-bottom: 3.75rem;
  }
  @media screen and (min-width: 768px) {
    .p-menu-unit__lead-a {
      font-size: 1.25rem;
      text-align: center;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-unit__lead-a {
      margin-bottom: 6.6666666667vw;
      text-align: center;
    }
  }
  @media screen and (min-width: 768px) {
    .p-menu-item {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 2.8125rem;
      background: url("../img/page/menu/cloud_1.svg") -33% 50%/64.375rem auto no-repeat;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-item {
      display: flex;
      flex-direction: column-reverse;
      gap: 2.6666666667vw;
      background: url("../img/page/menu/cloud_1_sp.svg") -32.6666666667vw 54.4vw/137.3333333333vw auto no-repeat;
      padding-bottom: 1.3333333333vw;
    }
  }
  @media screen and (min-width: 768px) {
    .p-menu-item.is-rev {
      background: url("../img/page/menu/cloud_0.svg") 108% 50%/57.375rem auto no-repeat;
      flex-direction: row-reverse;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-item.is-rev {
      background: url("../img/page/menu/cloud_0_sp.svg") 13.3333333333vw 61.3333333333vw/122.4vw auto no-repeat;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-item.is-mukashi-chashu {
      background: url("../img/page/menu/cloud_2_sp.svg") -13.3333333333vw 58.6666666667vw/122.4vw auto no-repeat;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-item.is-kataloin {
      background: url("../img/page/menu/cloud_1_sp.svg") -21.3333333333vw 57.0666666667vw/137.3333333333vw auto no-repeat;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-item.is-moyashi {
      background: url("../img/page/menu/cloud_1_sp.svg") -13.3333333333vw 65.0666666667vw/122.4vw auto no-repeat;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-item.is-butasoboro {
      background: url("../img/page/menu/cloud_0_sp.svg") 1.3333333333vw 61.0666666667vw/137.3333333333vw auto no-repeat;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-item.is-sirogoma {
      background: url("../img/page/menu/cloud_1_sp.svg") -28vw 49.6vw/137.3333333333vw auto no-repeat;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-item.is-chibitama {
      background: url("../img/page/menu/cloud_0_sp.svg") -13.8666666667vw 56vw/137.3333333333vw auto no-repeat;
    }
  }
  @media screen and (min-width: 768px) {
    .p-menu-item.is-1 {
      margin-left: -2.5rem;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-item + .p-menu-item {
      margin-top: 9.3333333333vw;
    }
  }
  .p-menu-item__wtext {
    position: relative;
    z-index: 3;
  }
  @media screen and (min-width: 768px) {
    .p-menu-item__wtext {
      width: 25.625rem;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-item__wtext {
      padding-left: var(--sp-pad);
      padding-right: var(--sp-pad);
    }
  }
  .p-menu-item__name {
    font-size: 1.75rem;
    font-family: var(--serif);
    margin-bottom: 0.625rem;
    line-height: 1.2142857143;
  }
  @media screen and (max-width: 767px) {
    .p-menu-item__name {
      font-size: 6.4vw;
      text-align: center;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-item__box {
      transition: background 0.25s;
      padding-bottom: 4.5333333333vw;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-item__box.is-open {
      border-radius: 1.3333333333vw;
      background: rgba(255, 255, 255, 0.48);
    }
  }
  .p-menu-item__text {
    font-size: 1rem;
    line-height: 1.875;
  }
  @media screen and (max-width: 767px) {
    .p-menu-item__text {
      font-size: 3.3333333333vw;
      display: none;
    }
    .p-menu-item__text.is-show {
      margin-top: -6.6666666667vw;
      padding-top: 6.6666666667vw;
      display: block;
    }
    .p-menu-item__text.is-show .p-menu-item__pad {
      padding-top: 0;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-item__pad {
      padding: 4.5333333333vw 4.5333333333vw 2.6666666667vw 4.5333333333vw;
    }
  }
  .p-menu-item__meta {
    margin-bottom: 0.625rem;
  }
  @media screen and (max-width: 767px) {
    .p-menu-item__meta {
      text-align: center;
    }
  }
  .p-menu-item__icon {
    background: #000;
    color: #fff;
    font-size: 0.875rem;
    display: inline-block;
    border-radius: 6.25rem;
    padding: 0.375rem 1.125rem;
    line-height: 1.1;
  }
  .p-menu-item__check {
    width: 0.875rem;
    height: 0.625rem;
    fill: #E60012;
  }
  .p-menu-item__note {
    margin-top: 0.6em;
    font-size: 0.875rem;
  }
  @media screen and (max-width: 767px) {
    .p-menu-item__note {
      font-size: 2.6666666667vw;
    }
  }
  .p-menu-item__note li + Li {
    margin-top: 0.4em;
  }
  .p-menu-item__note li {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 0.375rem;
  }
  .p-menu-item__attention {
    border: 1px solid #E60012;
    color: #E60012;
    font-size: 0.875rem;
    text-align: center;
    margin: 0.5rem 0;
    padding: 0.375rem;
    border-radius: 0.625rem;
  }
  @media screen and (max-width: 767px) {
    .p-menu-item__attention {
      border-radius: 1.3333333333vw;
      font-size: 2.6666666667vw;
    }
  }
  .p-menu-item__img {
    position: relative;
    z-index: 2;
  }
  .p-menu-item__img img {
    width: calc(var(--my-width) / 16 * 1rem);
  }
  .p-menu-item__steam {
    pointer-events: none;
    position: absolute;
    z-index: 3;
    width: 60%;
  }
  .p-menu-item__steam img {
    width: 100%;
  }
  .p-menu-item__steam.is-1 {
    right: 0;
    animation: steam 10s infinite linear;
    opacity: 0;
  }
  .p-menu-item__steam.is-2 {
    left: 0;
    animation: steam 14s infinite linear;
    opacity: 0;
  }
  .p-menu-item__steam.is-3 {
    left: 30%;
    animation: steam2 12s infinite linear;
    opacity: 0;
  }
  .p-menu-item__wtoggle-btn {
    text-align: center;
    margin-top: 2.6666666667vw;
  }
  .p-menu-item__toggle-btn {
    border: 1px solid #000;
    border-top: 0;
    border-radius: 0 0 2.6666666667vw 2.6666666667vw;
    font-size: 3.2vw;
    text-align: center;
    width: 58.6666666667vw;
    background: transparent;
    padding: 0 0.5333333333vw 0.5333333333vw 0.5333333333vw;
    transition: all 0.25s;
  }
  .p-menu-item__toggle-btn span {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 1.8666666667vw;
  }
  .p-menu-item__toggle-btn span::before {
    content: "＞";
    font-family: Helvetica, sans-serif;
    display: inline-block;
    rotate: 90deg;
    transform: scale(1, 1.2);
    font-size: 1.6vw;
    transition: all 0.25s;
  }
  .p-menu-item__toggle-btn.is-open {
    border-top: 1px solid #000;
    border-radius: 2.6666666667vw;
    padding: 0.5333333333vw;
  }
  .p-menu-item__toggle-btn.is-open span::before {
    rotate: -90deg;
  }
  .p-menu-sttl {
    text-align: center;
    margin-bottom: 3.125rem;
  }
  @media screen and (max-width: 767px) {
    .p-menu-sttl {
      margin-bottom: 6.6666666667vw;
    }
  }
  .p-menu-sttl img {
    width: calc(var(--my-width) / 16 * 1rem);
  }
  @media screen and (max-width: 767px) {
    .p-menu-sttl img {
      width: calc(var(--my-width) / 750 * 100vw);
    }
  }
  .p-menu-list {
    display: flex;
    flex-wrap: wrap;
    gap: 1.875rem 7.5rem;
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
  }
  @media screen and (min-width: 768px) {
    .p-menu-list {
      width: 59.375rem;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-list {
      flex-direction: column;
      gap: 6.6666666667vw 5.3333333333vw;
      padding-left: var(--sp-pad);
      padding-right: var(--sp-pad);
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-list.is-miyage {
      padding-left: 0;
      padding-right: 0;
      display: grid;
      grid-template-columns: repeat(2, 1fr);
    }
    .p-menu-list.is-miyage .p-menu-list__img {
      height: calc(var(--my-height) / 750 * 100vw);
    }
    .p-menu-list.is-miyage .p-menu-list__img img {
      width: calc(var(--my-width) / 750 * 100vw);
    }
  }
  @media screen and (min-width: 768px) {
    .p-menu-list__item {
      width: 25.625rem;
    }
  }
  .p-menu-list__img {
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 0;
    align-items: center;
    justify-content: center;
  }
  @media screen and (min-width: 768px) {
    .p-menu-list__img {
      height: calc(var(--my-height) / 16 * 1rem);
    }
  }
  .p-menu-list__img.is-start {
    justify-content: flex-start;
  }
  .p-menu-list__img img {
    width: calc(var(--my-width) / 16 * 1rem);
  }
  @media screen and (max-width: 767px) {
    .p-menu-list__img img {
      width: calc(var(--my-width) / 450 * 100vw);
    }
  }
  .p-menu-list__meta {
    margin-top: 0.125rem;
  }
  @media screen and (max-width: 767px) {
    .p-menu-list__meta {
      margin-bottom: 1.3333333333vw;
      margin-top: -4vw;
    }
  }
  .p-menu-list__icon {
    font-family: var(--sans-serif);
    background: #000;
    color: #fff;
    font-size: 0.875rem;
    display: inline-block;
    border-radius: 6.25rem;
    padding: 0.375rem 1.125rem;
    line-height: 1.1;
  }
  @media screen and (max-width: 767px) {
    .p-menu-list__icon {
      padding: 1.3333333333vw 2.4vw;
      font-size: 2.6666666667vw;
    }
  }
  .p-menu-list__sttl {
    text-align: center;
    font-family: var(--serif);
    font-size: 1.5rem;
    margin-top: 0.625rem;
    line-height: 1.2;
    font-weight: 600;
  }
  @media screen and (max-width: 767px) {
    .p-menu-list__sttl {
      font-size: 2.9333333333vw;
    }
  }
  .p-menu-list__name {
    font-weight: 600;
    font-family: var(--serif);
    font-size: 1.75rem;
    text-align: center;
    margin-top: 0.375rem;
    margin-bottom: 1rem;
    line-height: 1.4;
  }
  @media screen and (max-width: 767px) {
    .p-menu-list__name {
      margin-bottom: 0.5333333333vw;
      font-size: 4vw;
    }
  }
  @media screen and (min-width: 768px) {
    .p-menu-list__name.is-mt {
      margin-top: 1.875rem;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-list__name.is-SP-large {
      font-size: 6.4vw;
      margin-top: 0;
      margin-bottom: 2.6666666667vw;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-list__box {
      transition: background 0.25s;
      padding-bottom: 4.5333333333vw;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-list__box.is-open {
      border-radius: 1.3333333333vw;
      background: rgba(255, 255, 255, 0.48);
    }
  }
  .p-menu-list__text {
    font-size: 1rem;
  }
  @media screen and (max-width: 767px) {
    .p-menu-list__text {
      font-size: 3.4666666667vw;
      display: none;
    }
  }
  @media screen and (max-width: 767px) {
    .p-menu-list__pad {
      padding: 4.5333333333vw 4.5333333333vw 2.6666666667vw 4.5333333333vw;
    }
  }
  .p-menu-list__wtoggle-btn {
    text-align: center;
    margin-top: 2.6666666667vw;
  }
  .p-menu-list__toggle-btn {
    border: 1px solid #000;
    border-top: 0;
    border-radius: 0 0 2.6666666667vw 2.6666666667vw;
    font-size: 3.2vw;
    text-align: center;
    width: 58.6666666667vw;
    background: transparent;
    padding: 0 0.5333333333vw 0.5333333333vw 0.5333333333vw;
    transition: all 0.25s;
  }
  .p-menu-list__toggle-btn span {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 1.8666666667vw;
  }
  .p-menu-list__toggle-btn span::before {
    content: "＞";
    font-family: Helvetica, sans-serif;
    display: inline-block;
    rotate: 90deg;
    transform: scale(1, 1.2);
    font-size: 1.6vw;
    transition: all 0.25s;
  }
  .p-menu-list__toggle-btn.is-open {
    border-top: 1px solid #000;
    border-radius: 2.6666666667vw;
    padding: 0.5333333333vw;
  }
  .p-menu-list__toggle-btn.is-open span::before {
    rotate: -90deg;
  }
}
@keyframes fuwafuwa {
  0% {
    transform: translateY(-2%);
  }
  100% {
    transform: translateY(4%);
  }
}
@layer project {
  @media screen and (min-width: 768px) {
    .p-news-list {
      display: grid;
      grid-template-columns: repeat(2, 1fr);
      gap: 1.875rem 2.875rem;
    }
  }
  .p-news-list__item {
    border-bottom: 1px solid #000;
  }
  .p-news-list__cont {
    position: relative;
    display: block;
    padding: 1.875rem 0;
  }
  @media screen and (max-width: 767px) {
    .p-news-list__cont {
      padding: 5.3333333333vw 0;
    }
  }
  @media (hover: hover) {
    .p-news-list__cont:hover .p-news-list__ttl span {
      border-bottom-color: var(--main);
    }
    .p-news-list__cont:hover .p-news-list__yuge::before {
      transform: translate(-30%, -90%) rotate(-15deg);
      opacity: 1;
      scale: 1;
      filter: blur(0);
    }
  }
  .p-news-list__yuge {
    position: absolute;
    left: 0;
    top: 0;
    aspect-ratio: 55/39;
    width: 18.75rem;
    pointer-events: none;
    animation: fuwafuwa 1.8s ease-in-out infinite alternate-reverse;
  }
  .p-news-list__yuge::before {
    transform: translate(-100%, 4%) rotate(-15deg);
    content: "";
    display: block;
    background: url("../img/content/yuge.webp") 0 0/contain no-repeat;
    width: 100%;
    height: 100%;
    opacity: 0;
    filter: blur(1px);
    transition-property: opacity, transform, scale, filter;
    transition-duration: 2.2s;
    scale: 0.5;
  }
  .p-news-list__meta {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 1.125rem;
  }
  @media screen and (max-width: 767px) {
    .p-news-list__meta {
      font-size: 2.9333333333vw;
    }
  }
  .p-news-list__date {
    letter-spacing: 0.05em;
  }
  .p-news-list__tax {
    display: flex;
    gap: 0.625rem;
  }
  .p-news-list__tax > li {
    background: #000;
    color: #fff;
    border-radius: 6.25rem;
    line-height: 1.1;
    padding: 1.0666666667vw 3.4666666667vw;
  }
  @media screen and (min-width: 768px) {
    .p-news-list__tax > li {
      padding: 0.5rem 1.625rem;
      font-size: 1rem;
    }
  }
  .p-news-list__ttl {
    margin-top: 1.25rem;
    line-height: 1.3846153846;
    font-size: 1.625rem;
    font-family: var(--serif);
    font-weight: 600;
  }
  @media screen and (max-width: 767px) {
    .p-news-list__ttl {
      margin-top: 2.4vw;
      font-size: 5.3333333333vw;
      line-height: 1.5333333333;
    }
  }
  .p-news-list__ttl span {
    transition: 0.25s border;
    border-bottom: 2px solid transparent;
  }
  .p-news-list__text {
    margin-top: 0.625rem;
    color: #797979;
    line-height: 1.6111111111;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
    overflow: hidden;
  }
  @media screen and (max-width: 767px) {
    .p-news-list__text {
      margin-top: 2.6666666667vw;
    }
  }
}
@layer project {
  .p-recruit__inner {
    position: relative;
    color: #fff;
    display: flex;
    justify-content: flex-end;
    padding: 1.875rem 1.25rem;
    transition: 0.4s filter;
  }
  @media screen and (max-width: 767px) {
    .p-recruit__inner {
      padding: 9.3333333333vw 2.6666666667vw 53.3333333333vw 2.6666666667vw;
      justify-content: center;
      align-items: center;
      flex-direction: column;
    }
  }
  @media (hover: hover) {
    .p-recruit__inner:hover {
      filter: brightness(120%);
    }
  }
  .p-recruit__wtext {
    z-index: 2;
    display: flex;
    flex-direction: row-reverse;
    gap: 1.25rem;
  }
  @media screen and (min-width: 768px) {
    .p-recruit__wtext {
      position: relative;
    }
  }
  @media screen and (max-width: 767px) {
    .p-recruit__wtext {
      gap: 2.6666666667vw;
    }
  }
  .p-recruit__ttl {
    writing-mode: vertical-rl;
    font-size: 5.5rem;
    font-family: var(--serif);
    line-height: 1.1;
    font-weight: 900;
    white-space: nowrap;
  }
  @media screen and (max-width: 767px) {
    .p-recruit__ttl {
      line-height: 1.14;
      font-size: 11.7333333333vw;
    }
  }
  .p-recruit__ttl span {
    letter-spacing: -0.1em;
  }
  .p-recruit__sub {
    writing-mode: vertical-rl;
  }
  @media screen and (max-width: 767px) {
    .p-recruit__sub {
      font-size: 3.7333333333vw;
    }
  }
  .p-recruit__label {
    position: absolute;
    white-space: nowrap;
  }
  @media screen and (min-width: 768px) {
    .p-recruit__label {
      bottom: 1.25rem;
      right: 15rem;
    }
  }
  @media screen and (max-width: 767px) {
    .p-recruit__label {
      bottom: 5.7333333333vw;
    }
  }
  .p-recruit__img {
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
    width: 100%;
    height: 100%;
  }
  .p-recruit__img img {
    object-fit: cover;
    width: 100%;
    height: 100%;
  }
}
@layer project {
  .p-pagination {
    position: relative;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 0 0.5rem;
    font-size: 1.5rem;
    margin-top: 5.9375rem;
    line-height: 1.1;
  }
  @media screen and (max-width: 767px) {
    .p-pagination {
      font-size: 3.7333333333vw;
      margin-top: 14.6666666667vw;
      padding: 0 10.6666666667vw;
      height: 8.5333333333vw;
    }
  }
  .p-pagination > * {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: currentColor;
  }
  .p-pagination a {
    text-decoration: underline;
  }
  @media (hover: hover) {
    .p-pagination a:hover {
      text-decoration: none;
    }
  }
  .p-pagination a,
  .p-pagination .current {
    width: 2.5rem;
    height: 2.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  @media screen and (max-width: 767px) {
    .p-pagination a,
    .p-pagination .current {
      width: 5.3333333333vw;
      height: 5.3333333333vw;
    }
  }
  .p-pagination .prev, .p-pagination .next {
    transition: 0.25s background;
    background: #fff;
    width: 3.75rem;
    height: 3.75rem;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.05);
    border-radius: 6.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
  }
  @media screen and (min-width: 768px) {
    .p-pagination .prev, .p-pagination .next {
      margin: 0 0.625rem;
    }
  }
  @media screen and (max-width: 767px) {
    .p-pagination .prev, .p-pagination .next {
      position: absolute;
      top: 0;
      width: 8.5333333333vw;
      height: 8.5333333333vw;
    }
  }
  .p-pagination .prev svg, .p-pagination .next svg {
    transition-property: fill;
    transition-duration: 0.25s;
    width: 1.875rem;
    aspect-ratio: 30/23;
  }
  @media screen and (max-width: 767px) {
    .p-pagination .prev svg, .p-pagination .next svg {
      width: 4.5333333333vw;
    }
  }
  @media (hover: hover) {
    .p-pagination .prev:hover, .p-pagination .next:hover {
      background: #000;
    }
    .p-pagination .prev:hover svg, .p-pagination .next:hover svg {
      fill: #fff;
    }
  }
  @media screen and (max-width: 767px) {
    .p-pagination .prev {
      left: 0;
    }
  }
  .p-pagination .prev svg {
    rotate: 180deg;
  }
  @media screen and (max-width: 767px) {
    .p-pagination .next {
      right: 0;
    }
  }
  .p-pagination .dots {
    width: auto;
    border: 0;
  }
}
@layer utilities {
  @media screen and (max-width: 767px) {
    .u-hidden-ltSP {
      display: none;
    }
  }
  @media screen and (max-width: 991px) {
    .u-hidden-ltTAB {
      display: none;
    }
  }
  @media screen and (min-width: 768px) {
    .u-hidden-gtTAB {
      display: none;
    }
  }
  @media screen and (min-width: 992px) {
    .u-hidden-gtPC {
      display: none;
    }
  }
}
@layer utilities {
  .u-hide {
    display: none;
  }
}
@layer utilities {
  @media screen and (max-width: 1200px) and (min-width: 767px) {
    .u-PC-pad {
      padding-right: 4%;
      padding-left: 4%;
    }
  }
  @media screen and (max-width: 767px) {
    .u-SP-pad {
      padding-right: var(--sp-pad);
      padding-left: var(--sp-pad);
    }
  }
}
@layer utilities {
  .screen-reader-text,
  .u-screen-reader {
    clip: rect(1px, 1px, 1px, 1px);
    height: 1px;
    overflow: hidden;
    position: absolute;
    width: 1px;
    word-wrap: normal;
  }
}
@layer utilities {
  .u-ta-left {
    text-align: left;
  }
  .u-ta-center {
    text-align: center;
  }
  .u-ta-right {
    text-align: right;
  }
  @media screen and (max-width: 767px) {
    .u-SP-ta-left {
      text-align: left;
    }
    .u-SP-ta-center {
      text-align: center;
    }
    .u-SP-ta-right {
      text-align: right;
    }
  }
}