@charset "UTF-8";
/* ==========================================================================
   setting.scss
   ========================================================================== */
/*
Zen Maru Gothic
font-family: "Zen Maru Gothic", sans-serif;
font-weight: 500;
font-weight: 700;
*/
/*
Manrope
font-family: "Manrope", sans-serif;
font-weight: 200-800;
*/
:root {
  --min-viewport-width: 750;
  --max-viewport-width: 1600;
  --min-fluid-ratio: calc(1 / var(--min-viewport-width) * 100 * 1vw);
  --max-fluid-ratio: calc(1 / var(--max-viewport-width) * 100 * 1vw);
  --rem: 1rem / 16;
  --font-serif: "YakuHanMPs", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif;
  --font-serif-en: "YakuHanJPs", "游明朝", "Yu Mincho", "游明朝体", "YuMincho", serif;
  --font-sans-serif: "YakuHanJPs", "Zen Maru Gothic", "游ゴシック", "Yu Gothic", yugothic, "Hiragino Sans", "Noto Sans JP", "San Francisco", meiryo, "Hiragino Kaku Gothic ProN", sans-serif;
  --font-sans-serif-en: "YakuHanJPs", "Manrope", "游ゴシック", "Yu Gothic", yugothic, sans-serif;
  --font-family-ja: var(--font-sans-serif);
  --font-family-en: var(--font-sans-serif-en);
  --leading-trim: calc((1em - 1lh) / 2);
  --font-xlarge: 34px;
  --font-large: 26px;
  --font-medium-large: 24px;
  --font-medium: 16px;
  --font-small: 13px;
  --font-xsmall: 11px;
  --max-content-width: 3000px;
  --content-width-xl: 1280px;
  --content-width-lg: 1100px;
  --content-width-md: 894px;
  --content-width-sm: 774px;
  --content-width-xsm: 620px;
  --header-height: 136px;
  --scrollbar-width: 0.1px;
  --side-spacing: min(100px, 5.5vw);
  --main-spacing-bottom: 150px;
  --color-white: #fff;
  --color-black: #000;
  --color-boston-university-red: #cb0000;
  --color-alto: #d9d9d9;
  --color-tapa: #747474;
  --color-gray-chateau: #a0a6b4;
  --color-nevada: #616d82;
  --color-highlight-grain: #f9d94a;
  --color-deep-mustard: #c6891a;
  --color-spicy-grain: #a05e0f;
  --color-strong-grain: #8c4411;
  --color-bitter-grain: #734010;
  --color-olive-grain: #bbaf32;
  --color-creamy-grain: #ffd78c;
  --color-pearl-bush: #eadece;
  --color-eclipse: #341a1c;
  --color-contessa: #c66876;
  --background-color: var(--color-pearl-bush);
  --light-grey: var(--color-alto);
  --medium-grey: var(--color-tapa);
  --dark-grey: #454545;
  --line-color: var(--base-text-color);
  --base-text-color: var(--color-eclipse);
  --link-color: var(--base-text-color);
  --link-color-visited: var(--link-color);
  --link-color-hover: var(--link-color);
  --link-color-active: var(--link-color);
  --header-zindex: 30;
  --navigation-zindex: 40;
  --navigation-open-close-button-zindex: 50;
  --overlay-zindex: 60;
  /* Sine（最も弱い） */
  --ease-in-sine: cubic-bezier(0.47, 0, 0.745, 0.715); /* easeInSine */
  --ease-out-sine: cubic-bezier(0.39, 0.575, 0.565, 1); /* easeOutSine */
  --ease-in-out-sine: cubic-bezier(0.445, 0.05, 0.55, 0.95); /* easeInOutSine */
  /* Quad（弱め。Sineより強く、Cubicより弱い） */
  --ease-in-quad: cubic-bezier(0.55, 0.085, 0.68, 0.53); /* easeInQuad */
  --ease-out-quad: cubic-bezier(0.25, 0.46, 0.45, 0.94); /* easeOutQuad */
  --ease-in-out-quad: cubic-bezier(0.455, 0.03, 0.515, 0.955); /* easeInOutQuad */
  /* Cubic（Quadより強く、Quartより弱い） */
  --ease-in-cubic: cubic-bezier(0.55, 0.055, 0.675, 0.19); /* easeInCubic */
  --ease-out-cubic: cubic-bezier(0.215, 0.61, 0.355, 1); /* easeOutCubic */
  --easein-out-cubic: cubic-bezier(0.645, 0.045, 0.355, 1); /* easeInOutCubic */
  /* Quart（Cubicより強く、Quintより弱い） */
  --ease-in-quart: cubic-bezier(0.895, 0.03, 0.685, 0.22); /* easeInQuart */
  --ease-out-quart: cubic-bezier(0.165, 0.84, 0.44, 1); /* easeOutQuart */
  --ease-in-out-quart: cubic-bezier(0.77, 0, 0.175, 1); /* easeInOutQuart */
  /* Quint（Quartより強く、Expoより弱い） */
  --ease-in-quint: cubic-bezier(0.755, 0.05, 0.855, 0.06); /* easeInQuint */
  --ease-out-quint: cubic-bezier(0.23, 1, 0.32, 1); /* ★easeOutQuint */
  --ease-in-out-quint: cubic-bezier(0.86, 0, 0.07, 1); /* easeInOutQuint */
  /* Expo（最も強い） */
  --ease-in-expo: cubic-bezier(0.95, 0.05, 0.795, 0.035); /* easeInExpo */
  --ease-out-expo: cubic-bezier(0.19, 1, 0.22, 1); /* easeOutExpo */
  --ease-in-out-expo: cubic-bezier(1, 0, 0, 1); /* easeInOutExpo */
  /* Circ（Expoのような強さを持つが、加速や減速の時間がよりゆるやか。） */
  --ease-in-circ: cubic-bezier(0.6, 0.04, 0.98, 0.335); /* easeInCirc */
  --ease-out-circ: cubic-bezier(0.075, 0.82, 0.165, 1); /* easeOutCirc */
  --ease-in-out-circ: cubic-bezier(0.785, 0.135, 0.15, 0.86); /* easeInOutCirc */
  /* Back（少し行き過ぎてから戻ってくるような動き） */
  --ease-in-back: cubic-bezier(0.6, -0.28, 0.735, 0.045); /* easeInBack */
  --ease-out-back: cubic-bezier(0.175, 0.885, 0.32, 1.275); /* easeOutBack */
  --ease-in-out-back: cubic-bezier(0.68, -0.55, 0.265, 1.55); /* easeInOutBack */
  --ease-bounce: cubic-bezier(0.61, 0.06, 0.22, 1.76); /* easeBounce */
}
@media screen and (width > 1600px) {
  :root {
    --header-height: calc(136 * var(--max-fluid-ratio));
    --side-spacing: calc(80 * var(--max-fluid-ratio));
    --main-spacing-bottom: calc(150 * var(--max-fluid-ratio));
    --font-xlarge: calc(34 * var(--max-fluid-ratio));
    --font-large: calc(26 * var(--max-fluid-ratio));
    --font-medium-large: calc(24 * var(--max-fluid-ratio));
    --font-medium: calc(16 * var(--max-fluid-ratio));
    --font-small: calc(13 * var(--max-fluid-ratio));
    --font-xsmall: calc(10 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 770px) {
  :root {
    --side-spacing: 8vw;
  }
}
@media screen and (width <= 576px) {
  :root {
    --header-height: calc(112 * var(--min-fluid-ratio));
    --side-spacing: calc(50 * var(--min-fluid-ratio));
    --main-spacing-bottom: calc(200 * var(--min-fluid-ratio));
    --font-xlarge: calc(48 * var(--min-fluid-ratio));
    --font-large: calc(35 * var(--min-fluid-ratio));
    --font-medium-large: calc(30 * var(--min-fluid-ratio));
    --font-medium: calc(26 * var(--min-fluid-ratio));
    --font-small: calc(22 * var(--min-fluid-ratio));
    --font-xsmall: calc(17 * var(--min-fluid-ratio));
  }
}

@supports not (top: 1lh) {
  :root {
    --leading-trim: 0px; /* `px`などの単位が必要 */
  }
}
/* ==========================================================================
   reset.scss
   ========================================================================== */
* {
  min-inline-size: 0;
}

html {
  text-size-adjust: 100%;
}

/* HTML5 display definitions
     ========================================================================== */
article,
aside,
details,
figcaption,
figure,
picture,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
  display: block;
}

html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
dialog,
figure,
main,
footer,
header,
hgroup,
menu,
nav,
section,
time,
mark,
audio,
video {
  padding: 0;
  margin: 0;
  outline: 0;
  border: 0;
}

audio,
canvas,
progress,
video {
  display: inline-block;
  vertical-align: baseline;
}

audio:not([controls]) {
  display: none;
  block-size: 0;
}

object,
embed {
  vertical-align: bottom;
  outline: none;
  border: 0;
}

[hidden],
template {
  display: none;
}

/* Links
     ========================================================================== */
a {
  padding: 0;
  margin: 0;
  touch-action: manipulation;
  background: transparent;
  border: 0;
}
a:hover, a:active, a:focus {
  -webkit-tap-highlight-color: transparent;
}

a:active,
a:hover {
  outline: 0;
}

a img {
  text-decoration: none;
  outline: 0;
  border: none;
}

/* Text-level semantics
     ========================================================================== */
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 100%;
  font-weight: normal;
}

ul li {
  list-style: none;
}

ul,
ol {
  list-style-position: inside;
}

blockquote,
q {
  quotes: none;
}

blockquote::before,
blockquote::after,
q::before,
q::after {
  content: "";
  content: none;
}

abbr[title] {
  border-block-end: 1px dotted;
}

b,
strong {
  font-weight: bold;
}

dfn {
  font-style: italic;
}

small {
  font-size: 80%;
}

sub,
sup {
  position: relative;
  font-size: 75%;
  line-height: 0;
  vertical-align: baseline;
}

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

/* Tables
     ========================================================================== */
table {
  border-spacing: 0;
  border-collapse: collapse;
}

td,
th {
  padding: 0;
}

caption,
th {
  text-align: left;
}

/* Embedded content
     ========================================================================== */
img {
  max-inline-size: 100%;
  block-size: auto;
  font-style: italic;
  vertical-align: middle;
  background-repeat: no-repeat;
  background-size: cover;
  shape-margin: 0.75rem;
}

svg:not(:root) {
  overflow: hidden;
}

/* Grouping content
     ========================================================================== */
hr {
  display: block;
  block-size: 1px;
  padding: 0;
  margin: 1em 0;
  border: 0;
  border-block-start: 1px solid #ccc;
}

pre {
  overflow: auto;
}

code,
kbd,
pre,
samp {
  font-family: monospace, sans-serif;
  font-size: 1em;
}

/* Forms
     ========================================================================== */
button,
input,
optgroup,
select,
textarea {
  margin: 0;
  font: inherit;
  color: inherit;
  touch-action: manipulation;
}

input,
textarea,
select {
  font-size: max(100%, 1rem);
  vertical-align: middle;
}

button {
  padding: 0;
  overflow: visible;
  appearance: none;
  cursor: pointer;
  background: none;
  border: none;
  border-radius: 0;
}
button:hover, button:active, button:focus {
  -webkit-tap-highlight-color: transparent;
}

button,
select {
  text-transform: none;
}

button,
html input[type=button],
input[type=reset],
input[type=submit] {
  appearance: auto;
  cursor: pointer;
}

button[disabled],
html input[disabled] {
  cursor: default;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
  padding: 0;
  border: 0;
}

label {
  cursor: pointer;
}

input {
  line-height: normal;
}

input[type=checkbox],
input[type=radio] {
  box-sizing: border-box;
  padding: 0;
}

input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  block-size: auto;
}

input[type=search] {
  box-sizing: content-box;
  appearance: textfield;
}

input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration {
  appearance: none;
}

fieldset {
  padding: 0.35em 0.625em 0.75em;
  margin: 0 2px;
  border: 1px solid #c0c0c0;
}

legend {
  padding: 0;
  border: 0;
}

textarea {
  overflow: auto;
}

optgroup {
  font-weight: bold;
}

@font-face {
  font-family: icomoon;
  font-style: normal;
  font-weight: normal;
  src: url("../fonts/icon/icomoon.eot?1gi6ot");
  src: url("../fonts/icon/icomoon.eot?1gi6ot#iefix") format("embedded-opentype"), url("../fonts/icon/icomoon.ttf?1gi6ot") format("truetype"), url("../fonts/icon/icomoon.woff?1gi6ot") format("woff"), url("../fonts/icon/icomoon.svg?1gi6ot#icomoon") format("svg");
  font-display: block;
}
.icon:before,
[class^=icon-]:before,
[class*=" icon-"]:before {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: icomoon !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-pin:before {
  content: "\e903";
}

.icon-arrow-right:before {
  content: "\e900";
}

.icon-cart:before {
  content: "\e901";
}

.icon-open-close:before {
  content: "\e902";
}

.icon-instagram:before {
  content: "\ea92";
}

/*! Yaku Han JP v4.1.1 (OFL-1.1 AND MIT) by Qrac | Type: YakuHanJPs - Based on Noto Sans JP */
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 100;
  src: url("../fonts/YakuHanJPs/YakuHanJPs-Thin.woff2") format("woff2");
  font-display: swap;
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f, U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b, U+ff5d;
}
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 200;
  src: url("../fonts/YakuHanJPs/YakuHanJPs-ExtraLight.woff2") format("woff2");
  font-display: swap;
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f, U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b, U+ff5d;
}
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 300;
  src: url("../fonts/YakuHanJPs/YakuHanJPs-Light.woff2") format("woff2");
  font-display: swap;
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f, U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b, U+ff5d;
}
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/YakuHanJPs/YakuHanJPs-Light.woff2") format("woff2");
  font-display: swap;
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f, U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b, U+ff5d;
}
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 500;
  src: url("../fonts/YakuHanJPs/YakuHanJPs-Medium.woff2") format("woff2");
  font-display: swap;
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f, U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b, U+ff5d;
}
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 600;
  src: url("../fonts/YakuHanJPs/YakuHanJPs-SemiBold.woff2") format("woff2");
  font-display: swap;
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f, U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b, U+ff5d;
}
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/YakuHanJPs/YakuHanJPs-Bold.woff2") format("woff2");
  font-display: swap;
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f, U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b, U+ff5d;
}
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 800;
  src: url("../fonts/YakuHanJPs/YakuHanJPs-ExtraBold.woff2") format("woff2");
  font-display: swap;
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f, U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b, U+ff5d;
}
@font-face {
  font-family: YakuHanJPs;
  font-style: normal;
  font-weight: 900;
  src: url("../fonts/YakuHanJPs/YakuHanJPs-Black.woff2") format("woff2");
  font-display: swap;
  unicode-range: U+3008, U+3009, U+300a, U+300b, U+300c, U+300d, U+300e, U+300f, U+3010, U+3011, U+3014, U+3015, U+ff08, U+ff09, U+ff3b, U+ff3d, U+ff5b, U+ff5d;
}
/**
 * Swiper 12.0.2
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * https://swiperjs.com
 *
 * Copyright 2014-2025 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: September 18, 2025
 */
:root {
  --swiper-theme-color: #007aff;
  /*
  --swiper-preloader-color: var(--swiper-theme-color);
  --swiper-wrapper-transition-timing-function: initial;
  */
}

:host {
  position: relative;
  display: block;
  margin-left: auto;
  margin-right: auto;
  z-index: 1;
}

.swiper {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  /* Fix of Webkit flickering */
  z-index: 1;
  display: block;
}

.swiper-vertical > .swiper-wrapper {
  flex-direction: column;
}

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
  box-sizing: content-box;
}

.swiper-android .swiper-slide,
.swiper-ios .swiper-slide,
.swiper-wrapper {
  transform: translate3d(0px, 0, 0);
}

.swiper-horizontal {
  touch-action: pan-y;
}

.swiper-vertical {
  touch-action: pan-x;
}

.swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
  display: block;
}

.swiper-slide-invisible-blank {
  visibility: hidden;
}

/* Auto Height */
.swiper-autoheight,
.swiper-autoheight .swiper-slide {
  height: auto;
}

.swiper-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height;
}

.swiper-backface-hidden .swiper-slide {
  transform: translateZ(0);
  backface-visibility: hidden;
}

/* 3D Effects */
.swiper-3d.swiper-css-mode .swiper-wrapper {
  perspective: 1200px;
}

.swiper-3d .swiper-wrapper {
  transform-style: preserve-3d;
}

.swiper-3d {
  perspective: 1200px;
  .swiper-slide,
  .swiper-cube-shadow {
    transform-style: preserve-3d;
  }
}

/* CSS Mode */
.swiper-css-mode {
  > .swiper-wrapper {
    overflow: auto;
    scrollbar-width: none; /* For Firefox */
    -ms-overflow-style: none; /* For Internet Explorer and Edge */
    &::-webkit-scrollbar {
      display: none;
    }
  }
  > .swiper-wrapper > .swiper-slide {
    scroll-snap-align: start start;
  }
  &.swiper-horizontal {
    > .swiper-wrapper {
      scroll-snap-type: x mandatory;
    }
  }
  &.swiper-vertical {
    > .swiper-wrapper {
      scroll-snap-type: y mandatory;
    }
  }
  &.swiper-free-mode {
    > .swiper-wrapper {
      scroll-snap-type: none;
    }
    > .swiper-wrapper > .swiper-slide {
      scroll-snap-align: none;
    }
  }
  &.swiper-centered {
    > .swiper-wrapper::before {
      content: "";
      flex-shrink: 0;
      order: 9999;
    }
    > .swiper-wrapper > .swiper-slide {
      scroll-snap-align: center center;
      scroll-snap-stop: always;
    }
  }
  &.swiper-centered.swiper-horizontal {
    > .swiper-wrapper > .swiper-slide:first-child {
      margin-inline-start: var(--swiper-centered-offset-before);
    }
    > .swiper-wrapper::before {
      height: 100%;
      min-height: 1px;
      width: var(--swiper-centered-offset-after);
    }
  }
  &.swiper-centered.swiper-vertical {
    > .swiper-wrapper > .swiper-slide:first-child {
      margin-block-start: var(--swiper-centered-offset-before);
    }
    > .swiper-wrapper::before {
      width: 100%;
      min-width: 1px;
      height: var(--swiper-centered-offset-after);
    }
  }
}

/* Slide styles start */
/* 3D Shadows */
.swiper-3d {
  .swiper-slide-shadow,
  .swiper-slide-shadow-left,
  .swiper-slide-shadow-right,
  .swiper-slide-shadow-top,
  .swiper-slide-shadow-bottom,
  .swiper-slide-shadow,
  .swiper-slide-shadow-left,
  .swiper-slide-shadow-right,
  .swiper-slide-shadow-top,
  .swiper-slide-shadow-bottom {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 10;
  }
  .swiper-slide-shadow {
    background: rgba(0, 0, 0, 0.15);
  }
  .swiper-slide-shadow-left {
    background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  }
  .swiper-slide-shadow-right {
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  }
  .swiper-slide-shadow-top {
    background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  }
  .swiper-slide-shadow-bottom {
    background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
  }
}

.swiper-lazy-preloader {
  width: 42px;
  height: 42px;
  position: absolute;
  left: 50%;
  top: 50%;
  margin-left: -21px;
  margin-top: -21px;
  z-index: 10;
  transform-origin: 50%;
  box-sizing: border-box;
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-radius: 50%;
  border-top-color: transparent;
}

.swiper:not(.swiper-watch-progress),
.swiper-watch-progress .swiper-slide-visible {
  .swiper-lazy-preloader {
    animation: swiper-preloader-spin 1s infinite linear;
  }
}

.swiper-lazy-preloader-white {
  --swiper-preloader-color: #fff;
}

.swiper-lazy-preloader-black {
  --swiper-preloader-color: #000;
}

@keyframes swiper-preloader-spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
/* Slide styles end */
.swiper-fade {
  &.swiper-free-mode {
    .swiper-slide {
      transition-timing-function: ease-out;
    }
  }
  .swiper-slide {
    pointer-events: none;
    transition-property: opacity;
    .swiper-slide {
      pointer-events: none;
    }
  }
  .swiper-slide-active {
    pointer-events: auto;
    & .swiper-slide-active {
      pointer-events: auto;
    }
  }
}

/* ==========================================================================
   print.scss
   ========================================================================== */
@media print {
  body {
    font-size: 12px;
    background-color: #fff;
  }
}
/* ==========================================================================
   base.scss
   ========================================================================== */
*,
*::before,
*::after {
  box-sizing: border-box;
}

* {
  -webkit-font-smoothing: antialiased;
  -moz-font-smoothing: antialiased;
}

/* Font Setting
   ========================================================================== */
body {
  text-rendering: optimizelegibility;
}

/* link
   ========================================================================== */
a {
  color: var(--link-color);
  text-decoration: none;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.4em;
  transition: color 0.2s ease-out 0s;
  -webkit-tap-highlight-color: rgba(189, 185, 185, 0);
  -webkit-touch-callout: none;
}
a:visited {
  color: var(--link-color-visited);
}
a:hover {
  color: var(--link-color-hover);
  text-decoration-line: underline;
}
a:active {
  color: var(--link-color-active);
}

/* ==========================================================================
   main.scss
   ========================================================================== */
/* selection
   ========================================================================== */
::selection {
  color: var(--color-white);
  background: rgba(209, 103, 110, 0.6666666667);
}

/* Base
   ========================================================================== */
html,
body {
  min-block-size: 100%;
  font-feature-settings: "pkna";
  -webkit-font-smoothing: antialiased;
}

html {
  line-break: strict;
  overflow-wrap: break-word;
  hanging-punctuation: allow-end;
  background: url("../images/common/bg-noise.png") repeat top center/140px 140px var(--background-color);
  transition: background-color 0.5s ease;
}

body {
  inline-size: 100%;
  overflow-y: scroll;
  font-family: var(--font-family-ja);
  font-size: var(--font-medium);
  font-weight: 400;
  line-height: 1.8;
  color: var(--base-text-color);
  letter-spacing: 0.03em;
}
@media screen and (width <= 1080px) {
  .is-opened-navigation body {
    block-size: 100vh;
    padding-inline-end: var(--scrollbar-width);
    overflow: hidden;
  }
}

[id] {
  scroll-margin-block-start: var(--header-height);
}

.svg-symbols {
  display: none;
}

.l-page {
  display: flex;
  flex-direction: column;
  inline-size: 100%;
  min-block-size: 100vh;
}

.l-main {
  position: relative;
  flex: 1 0 auto;
  inline-size: 100%;
  padding-block-start: var(--content-spacing-top);
  margin-block-end: var(--main-spacing-bottom);
}
@media screen and (width <= 1080px) {
  .l-main {
    padding-block-start: var(--header-height);
  }
  .p-top .l-main {
    contain: paint;
  }
}
.l-container {
  inline-size: 100%;
  padding-inline: var(--side-spacing);
}

.l-content {
  max-inline-size: 800px;
  padding-block-start: 100px;
  margin-inline: auto;
}
@media screen and (width > 1600px) {
  .l-content {
    max-inline-size: calc(800 * var(--max-fluid-ratio));
    padding-block-start: calc(100 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .l-content {
    padding-block-start: calc(140 * var(--min-fluid-ratio));
  }
}

.l-content_head + .l-content_body {
  margin-block-start: 50px;
}
@media screen and (width > 1600px) {
  .l-content_head + .l-content_body {
    margin-block-start: calc(50 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .l-content_head + .l-content_body {
    margin-block-start: calc(40 * var(--min-fluid-ratio));
  }
}

.l-section + .l-section {
  margin-block-start: 180px;
}
@media screen and (width > 1600px) {
  .l-section + .l-section {
    margin-block-start: calc(180 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .l-section + .l-section {
    margin-block-start: calc(200 * var(--min-fluid-ratio));
  }
}

/* ============================
  .g-overlay
============================ */
.g-overlay {
  position: fixed;
  inset: 0;
  z-index: var(--overlay-zindex);
  display: none;
  background: url("../images/common/bg-noise.png") repeat top center/140px 140px var(--background-color);
  opacity: 0;
}

/* ============================
  lazyload
============================ */
.lazyload-wrapper {
  background-color: rgba(228, 228, 228, 0.4);
}

.lazyload,
.lazyautosizes {
  opacity: 0;
  transition: opacity 1s cubic-bezier(0.215, 0.61, 0.355, 1) 0s;
}
.lazyload.lazyloaded,
.lazyautosizes.lazyloaded {
  opacity: 1;
}

/* ============================
  other
============================ */
.js-animation-text {
  backface-visibility: hidden;
}

.grecaptcha-badge {
  pointer-events: none;
  opacity: 0;
}

/* ==========================================================================
   header.scss
   ========================================================================== */
.l-header {
  z-index: var(--header-zindex);
  inline-size: 100%;
  padding: 56px var(--side-spacing);
  line-height: 1.02;
  color: var(--base-text-color);
  pointer-events: none;
  transition: opacity 1s ease-out 0s, transform 1s ease 0s;
}
.l-header a {
  color: var(--base-text-color);
  text-decoration: none;
}
@media screen and (width <= 1080px) {
  .l-header {
    position: fixed;
    inset-block-start: 0;
    inset-inline-end: 0;
  }
}
.is-opened-navigation .l-header {
  padding-inline-end: calc(var(--side-spacing) + var(--scrollbar-width));
}
@media screen and (width > 1600px) {
  .l-header {
    padding-block: calc(56 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .l-header {
    padding-block: calc(54 * var(--min-fluid-ratio));
  }
}

/* ============================
  .g-logo
============================ */
.g-logo {
  inline-size: clamp(380px, 42vw, 420px);
  line-height: 1;
  pointer-events: auto;
  transition: opacity 0.3s ease-out 0s;
}
@media screen and (width > 1600px) {
  .g-logo {
    inline-size: calc(420 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .g-logo {
    inline-size: calc(460 * var(--min-fluid-ratio));
  }
}

a.g-logo_link {
  display: block;
  text-decoration: none;
}

.g-logo_svg {
  display: block;
  inline-size: 100%;
  block-size: auto;
  padding-block-end: 1px;
}

/* ==========================================================================
   footer.scss
   ========================================================================== */
/* ============================
.l-footer
============================ */
.l-footer {
  position: relative;
  z-index: 1;
  inline-size: 100%;
  padding: 40px;
  line-height: 1.02;
  color: var(--color-white);
}
.l-footer a {
  color: var(--color-white);
}
@media screen and (width > 1600px) {
  .l-footer {
    padding: calc(40 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 940px) {
  .l-footer {
    padding: 20px;
  }
}
@media screen and (width <= 576px) {
  .l-footer {
    padding: calc(20 * var(--min-fluid-ratio));
  }
}

.g-footer-inner {
  display: grid;
  grid-template: "logo navigation sub-navigation" auto "information navigation sub-navigation" auto "copyright navigation sub-navigation" auto/1fr auto auto;
  gap: 48px clamp(20px, 5vw, 130px);
  padding-block: 80px;
  padding-inline: var(--side-spacing);
  background-color: var(--color-eclipse);
  border-radius: 60px;
}
@media screen and (width > 1600px) {
  .g-footer-inner {
    gap: calc(48 * var(--max-fluid-ratio)) calc(130 * var(--max-fluid-ratio));
    padding-block: calc(80 * var(--max-fluid-ratio));
    border-radius: calc(60 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 1080px) {
  .g-footer-inner {
    grid-template: "logo cart cart" auto "information navigation sub-navigation" auto "copyright navigation sub-navigation" auto/1fr auto auto;
  }
}
@media screen and (width <= 940px) {
  .g-footer-inner {
    grid-template: "logo logo logo" auto "cart cart cart" auto "navigation sub-navigation information" auto "copyright copyright copyright" auto/auto auto 1fr;
    gap: 50px 40px;
    border-radius: 50px;
  }
}
@media screen and (width <= 830px) {
  .g-footer-inner {
    grid-template: "logo logo" auto "cart cart" auto "navigation sub-navigation" auto "information information" auto "copyright copyright" auto/auto 1fr;
    gap: 50px 80px;
    padding-block: 58px;
  }
}
@media screen and (width <= 576px) {
  .g-footer-inner {
    grid-template-columns: auto auto;
    gap: calc(90 * var(--min-fluid-ratio)) calc(20 * var(--min-fluid-ratio));
    padding-block: calc(100 * var(--min-fluid-ratio));
    border-radius: calc(60 * var(--min-fluid-ratio));
  }
}

/* .g-footer-logo */
.g-footer-logo {
  grid-area: logo;
  inline-size: clamp(380px, 40vw, 388px);
  line-height: 1;
  pointer-events: auto;
  transition: opacity 0.3s ease-out 0s;
}
@media screen and (width > 1600px) {
  .g-footer-logo {
    inline-size: calc(388 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .g-footer-logo {
    inline-size: calc(460 * var(--min-fluid-ratio));
  }
}

a.g-footer-logo_link {
  display: block;
  text-decoration: none;
}

.g-footer-logo_svg {
  display: block;
  inline-size: 100%;
  block-size: auto;
  padding-block-end: 1px;
}

/* .g-footer-navigation-cart */
.g-footer-navigation-cart {
  grid-area: cart;
  inline-size: fit-content;
  font-weight: 700;
  letter-spacing: 0;
}
@media screen and (width > 1080px) {
  .g-footer-navigation-cart {
    display: none;
  }
}

a.g-footer-navigation-cart_link {
  position: relative;
  z-index: 1;
  display: flex;
  gap: 6px;
  align-items: baseline;
  justify-content: center;
  padding: 14px 24px;
  font-size: 15px;
  line-height: 1;
  color: var(--color-white);
  text-decoration: none;
  background: var(--base-text-color);
  border: 2.5px solid var(--color-white);
  border-radius: 100vmax;
  transition: background 0.2s ease 0s, color 0.2s ease 0s;
}
a.g-footer-navigation-cart_link .icon-cart {
  font-size: 90%;
  color: var(--color-white);
  transition: color 0.3s ease 0s;
}
a.g-footer-navigation-cart_link::after {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  z-index: -1;
  inline-size: 100%;
  block-size: 100%;
  content: "";
  background: var(--base-text-color);
  border-radius: 100vmax;
  transform: translate(-50%, -50%);
  transition: inline-size 0.3s var(--ease-bounce) 0s, block-size 0.3s var(--ease-bounce) 0s, background-color 0.3s ease 0s;
}
a.g-footer-navigation-cart_link:hover, a.g-footer-navigation-cart_link:active {
  color: var(--base-text-color) !important;
}
a.g-footer-navigation-cart_link:hover::after, a.g-footer-navigation-cart_link:active::after {
  inline-size: calc(100% + 8px);
  block-size: calc(100% + 8px);
  background: var(--color-white);
}
a.g-footer-navigation-cart_link:hover .icon-cart, a.g-footer-navigation-cart_link:active .icon-cart {
  color: var(--base-text-color) !important;
}
@media screen and (width <= 1080px) {
  a.g-footer-navigation-cart_link {
    padding: 15px 32px;
    font-size: 16px;
  }
}
@media screen and (width <= 576px) {
  a.g-footer-navigation-cart_link {
    gap: calc(12 * var(--min-fluid-ratio));
    padding: calc(24 * var(--min-fluid-ratio)) calc(52 * var(--min-fluid-ratio));
    font-size: calc(26 * var(--min-fluid-ratio));
  }
}

/*
.g-footer-navigation
---------------------------- */
.g-footer-navigation {
  display: flex;
  flex-flow: column wrap;
  grid-area: navigation;
  gap: 24px;
}
@media screen and (width > 1600px) {
  .g-footer-navigation {
    gap: calc(24 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .g-footer-navigation {
    gap: calc(40 * var(--min-fluid-ratio));
    justify-self: start;
    inline-size: fit-content;
  }
}

.g-footer-navigation-list {
  display: flex;
  flex-flow: column wrap;
  gap: 22px;
}
@media screen and (width > 1600px) {
  .g-footer-navigation-list {
    gap: calc(22 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .g-footer-navigation-list {
    gap: calc(40 * var(--min-fluid-ratio));
  }
}

.g-footer-navigation-item {
  font-size: 15px;
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: 0.1em;
  white-space: nowrap;
}
@media screen and (width > 1600px) {
  .g-footer-navigation-item {
    font-size: calc(15 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .g-footer-navigation-item {
    font-size: calc(28 * var(--min-fluid-ratio));
  }
}

a.g-footer-navigation-item_link {
  position: relative;
  display: block;
  inline-size: fit-content;
  text-decoration: none;
  transition: opacity 0.3s ease-out 0s;
}
a.g-footer-navigation-item_link::after {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  display: block;
  inline-size: calc(100% + 10px);
  block-size: calc(100% + 10px);
  content: "";
  transform: translate(-50%, -50%);
}
@media (any-hover: hover) {
  a.g-footer-navigation-item_link:hover, a.g-footer-navigation-item_link:active {
    opacity: 0.6;
  }
}

/*
.g-footer-social-media-list
---------------------------- */
.g-footer-social-media-list {
  font-size: 13px;
  letter-spacing: 0;
}
@media screen and (width > 1600px) {
  .g-footer-social-media-list {
    font-size: calc(13 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .g-footer-social-media-list {
    font-size: calc(30 * var(--min-fluid-ratio));
  }
}

a.g-footer-social-media-item_link {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 28px;
  block-size: 28px;
  color: var(--base-text-color);
  text-decoration: none;
  transition: opacity 0.3s ease-out 0s;
}
a.g-footer-social-media-item_link::after {
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
  z-index: -1;
  inline-size: 100%;
  block-size: 100%;
  content: "";
  background-color: var(--color-white);
  border-radius: 50%;
  transition: transform 0.3s var(--ease-out-back) 0s;
}
a.g-footer-social-media-item_link:hover::after, a.g-footer-social-media-item_link:active::after {
  transform: scale(1.1);
}
@media screen and (width > 1600px) {
  a.g-footer-social-media-item_link {
    inline-size: calc(28 * var(--max-fluid-ratio));
    block-size: calc(28 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  a.g-footer-social-media-item_link {
    inline-size: calc(48 * var(--min-fluid-ratio));
    block-size: calc(48 * var(--min-fluid-ratio));
  }
}

.g-footer-social-media-item_text {
  overflow: hidden;
  text-indent: -9999px;
}

/*
.g-footer-sub-navigation
---------------------------- */
.g-footer-sub-navigation {
  grid-area: sub-navigation;
  inline-size: fit-content;
}
@media screen and (width <= 576px) {
  .g-footer-sub-navigation {
    justify-self: end;
  }
}

.g-footer-sub-navigation-list {
  display: flex;
  flex-flow: column wrap;
  gap: 25px;
  font-weight: 700;
}
@media screen and (width > 1600px) {
  .g-footer-sub-navigation-list {
    gap: calc(25 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .g-footer-sub-navigation-list {
    gap: calc(48 * var(--min-fluid-ratio));
  }
}

.g-footer-sub-navigation-item {
  font-size: 84%;
  white-space: nowrap;
}
@media screen and (width <= 576px) {
  .g-footer-sub-navigation-item {
    font-size: calc(22 * var(--min-fluid-ratio));
  }
}

a.g-footer-sub-navigation-item_link {
  position: relative;
  display: block;
  inline-size: fit-content;
  text-decoration: none;
  transition: opacity 0.3s ease-out 0s;
}
a.g-footer-sub-navigation-item_link::after {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  display: block;
  inline-size: calc(100% + 10px);
  block-size: calc(100% + 10px);
  content: "";
  transform: translate(-50%, -50%);
}
@media (any-hover: hover) {
  a.g-footer-sub-navigation-item_link:hover, a.g-footer-sub-navigation-item_link:active {
    opacity: 0.6;
  }
}

/*
.g-footer-information
---------------------------- */
.g-footer-information {
  grid-area: information;
  font-size: var(--font-medium);
  line-height: 1.8;
}
.g-footer-information::before, .g-footer-information::after {
  display: block;
  inline-size: 0;
  block-size: 1px;
  content: "";
}
.g-footer-information::before {
  margin-block-end: calc((1 - 2) * 0.5em);
}
.g-footer-information::after {
  margin-block-start: calc((1 - 2) * 0.5em);
}
.g-footer-information a {
  display: inline-flex;
  gap: 4px;
  align-items: center;
  inline-size: fit-content;
}
.g-footer-information a .icon-pin {
  text-decoration: none;
}
.g-footer-information ul {
  margin-block-start: 0.8em;
}
@media screen and (width <= 576px) {
  .g-footer-information {
    font-size: var(--font-small);
  }
}

/* .g-copyright  */
.g-copyright {
  grid-area: copyright;
  margin-block-start: auto;
  font-size: var(--font-xsmall);
  color: var(--color-mountain-mist);
  letter-spacing: 0.1em;
  white-space: nowrap;
}

/* ==========================================================================
   navigation.scss
   ========================================================================== */
/* ============================
  .g-navigation
============================ */
.g-navigation {
  position: fixed;
  inset-block-start: 0;
  inset-inline-end: 0;
  z-index: var(--navigation-zindex);
  overflow: hidden;
  line-height: 1.02;
  color: var(--color-white);
}
.g-navigation a {
  text-decoration: none;
}
@media screen and (width > 1080px) {
  .g-navigation {
    display: block !important;
  }
}
@media screen and (width <= 1080px) {
  .g-navigation {
    inline-size: 100%;
    block-size: 100%;
    pointer-events: none;
  }
  .is-opened-navigation .g-navigation {
    pointer-events: auto;
  }
}
@media screen and (width <= 576px) {
  .g-navigation {
    inset-block-start: -999em;
    z-index: -1;
    transition: inset-block-start 0s ease 0.8s;
  }
  .is-opened-navigation .g-navigation {
    inset-block-start: 0;
    z-index: var(--navigation-zindex);
    transition: inset-block-start 0s ease 0s;
  }
}

@media screen and (width <= 1080px) {
  .g-navigation-scroll-area {
    position: relative;
    z-index: 1;
    inline-size: fit-content;
    block-size: 100%;
    padding: 20px;
    margin-inline-start: auto;
    overflow: hidden auto;
  }
}
@media screen and (width <= 576px) {
  .g-navigation-scroll-area {
    inline-size: 100%;
    min-block-size: 100%;
    padding: calc(20 * var(--min-fluid-ratio));
  }
}

.g-navigation-inner {
  position: relative;
  z-index: 2;
  inline-size: fit-content;
  padding-block: 50px;
  padding-inline: 70px;
  transition: transform 0.25s ease-out 0s, opacity 0.25s ease-out 0s;
}
@media screen and (width <= 1080px) {
  .g-navigation-inner {
    padding-block: 100px 50px;
    padding-inline-end: var(--side-spacing);
    opacity: 0;
  }
  .is-opened-navigation .g-navigation-inner {
    opacity: 1;
    transition: opacity 0.4s ease-out 0.1s;
  }
}
@media screen and (width <= 576px) {
  .g-navigation-inner {
    display: grid;
    grid-template: "logo logo" auto "cart cart" auto "navigation sub-navigation" auto "information information" auto/1fr auto;
    gap: calc(90 * var(--min-fluid-ratio)) calc(20 * var(--min-fluid-ratio));
    align-content: start;
    inline-size: 100%;
    min-block-size: 100%;
    padding-block: calc(150 * var(--min-fluid-ratio)) calc(80 * var(--min-fluid-ratio));
    padding-inline: var(--side-spacing);
    background-color: var(--base-text-color);
    border-radius: calc(60 * var(--min-fluid-ratio));
    transform: scale(0.6);
    transform-origin: top right;
  }
  .is-opened-navigation .g-navigation-inner {
    transform: scale(1);
    transition: transform 0.3s var(--ease-out-quint) 0.1s, opacity 0.4s ease-out 0.1s;
  }
}

/* .g-navigation-logo */
.g-navigation-logo {
  display: none;
  inline-size: 388px;
  line-height: 1;
}
@media screen and (width <= 576px) {
  .g-navigation-logo {
    display: block;
    grid-area: logo;
    inline-size: calc(460 * var(--min-fluid-ratio));
  }
}

a.g-navigation-logo_link {
  display: block;
  color: var(--color-white);
  text-decoration: none;
}

.g-navigation-logo_svg {
  display: block;
  inline-size: 100%;
  block-size: auto;
  padding-block-end: 1px;
}
.g-navigation-logo_svg path {
  fill: var(--color-white);
}

/* .g-navigation-cart */
.g-navigation-cart {
  inline-size: fit-content;
  font-weight: 700;
  letter-spacing: 0;
}
@media screen and (width > 1080px) {
  [data-animate] .g-navigation-cart {
    opacity: 0;
    transform: translateX(30px);
    transition: transform 0.6s var(--ease-out-quint) 0.3s, opacity 0.2s var(--ease-out-quint) 0.3s;
  }
  [data-animate=active] .g-navigation-cart {
    opacity: 1;
    transform: translateX(0);
  }
}
@media screen and (width > 576px) and (width <= 1080px) {
  .g-navigation-cart {
    opacity: 0;
    transform: translateX(30px);
    transition: transform 0.4s var(--ease-out-quint) 0.6s, opacity 0.4s var(--ease-out-quint) 0.6s;
  }
  .is-opened-navigation .g-navigation-cart {
    opacity: 1;
    transform: translateX(0);
    transition: transform 0.6s var(--ease-out-quint) 0s, opacity 0.2s var(--ease-out-quint) 0s;
  }
}

a.g-navigation-cart_link {
  position: relative;
  z-index: 1;
  display: flex;
  gap: 6px;
  align-items: baseline;
  justify-content: center;
  padding: 14px 24px;
  font-size: 15px;
  line-height: 1;
  color: var(--base-text-color);
  border: 2px solid var(--base-text-color);
  border-radius: 100vmax;
  transition: background 0.2s ease 0s, color 0.2s ease 0s;
}
a.g-navigation-cart_link .icon-cart {
  font-size: 90%;
  transition: color 0.3s ease 0s;
}
a.g-navigation-cart_link::after {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  z-index: -1;
  inline-size: 100%;
  block-size: 100%;
  content: "";
  background-color: rgba(255, 255, 255, 0.6);
  border-radius: 100vmax;
  transform: translate(-50%, -50%);
  transition: inline-size 0.3s var(--ease-bounce) 0s, block-size 0.3s var(--ease-bounce) 0s, background-color 0.3s ease 0s;
}
a.g-navigation-cart_link:hover, a.g-navigation-cart_link:active {
  color: var(--color-white);
}
a.g-navigation-cart_link:hover::after, a.g-navigation-cart_link:active::after {
  inline-size: calc(100% + 8px);
  block-size: calc(100% + 8px);
  background: var(--base-text-color);
}
@media screen and (width > 1600px) {
  a.g-navigation-cart_link {
    gap: calc(6 * var(--max-fluid-ratio));
    padding: calc(14 * var(--max-fluid-ratio)) calc(24 * var(--max-fluid-ratio));
    font-size: calc(15 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 1080px) {
  a.g-navigation-cart_link {
    padding: 15px 32px;
    font-size: 16px;
    border-width: 2.5px;
  }
}
@media screen and (width <= 576px) {
  a.g-navigation-cart_link {
    gap: calc(12 * var(--min-fluid-ratio));
    padding: calc(24 * var(--min-fluid-ratio)) calc(52 * var(--min-fluid-ratio));
    font-size: calc(26 * var(--min-fluid-ratio));
    color: var(--color-white);
    background: var(--base-text-color);
    border-color: var(--color-white);
  }
  a.g-navigation-cart_link .icon-cart {
    color: var(--color-white);
  }
  a.g-navigation-cart_link::after {
    background: var(--base-text-color);
  }
  a.g-navigation-cart_link:hover, a.g-navigation-cart_link:active {
    color: var(--base-text-color) !important;
  }
  a.g-navigation-cart_link:hover::after, a.g-navigation-cart_link:active::after {
    background: var(--color-white);
  }
  a.g-navigation-cart_link:hover .icon-cart, a.g-navigation-cart_link:active .icon-cart {
    color: var(--base-text-color) !important;
  }
}

.g-main-navigation {
  display: flex;
  flex-flow: column wrap;
  gap: 24px;
  margin-block-start: 28px;
  line-height: 1.02;
}
@media screen and (width > 1600px) {
  .g-main-navigation {
    gap: calc(24 * var(--max-fluid-ratio));
    margin-block-start: calc(28 * var(--max-fluid-ratio));
  }
}
@media screen and (width > 1080px) {
  [data-animate] .g-main-navigation {
    opacity: 0;
    transform: translateX(30px);
    transition: transform 0.6s var(--ease-out-quint) 0.4s, opacity 0.2s var(--ease-out-quint) 0.4s;
  }
  [data-animate=active] .g-main-navigation {
    opacity: 1;
    transform: translateX(0);
  }
}
@media screen and (width <= 1080px) {
  .g-main-navigation {
    gap: 26px;
    margin-block-start: 30px;
  }
}
@media screen and (width > 576px) and (width <= 1080px) {
  .g-main-navigation {
    opacity: 0;
    transform: translateX(30px);
    transition: transform 0.4s var(--ease-out-quint) 0.6s, opacity 0.4s var(--ease-out-quint) 0.6s;
  }
  .is-opened-navigation .g-main-navigation {
    opacity: 1;
    transform: translateX(0);
    transition: transform 0.6s var(--ease-out-quint) 0.1s, opacity 0.2s var(--ease-out-quint) 0.1s;
  }
}
@media screen and (width <= 576px) {
  .g-main-navigation {
    grid-area: navigation;
    gap: calc(46 * var(--min-fluid-ratio));
    justify-self: start;
    margin-block-start: 0;
  }
}

.g-main-navigation-list {
  display: flex;
  flex-flow: column wrap;
  gap: 22px;
}
@media screen and (width > 1600px) {
  .g-main-navigation-list {
    gap: calc(22 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 1080px) {
  .g-main-navigation-list {
    gap: 25px;
  }
}
@media screen and (width <= 576px) {
  .g-main-navigation-list {
    gap: calc(40 * var(--min-fluid-ratio));
  }
}

.g-main-navigation-item {
  font-size: 15px;
  font-weight: 700;
  line-height: 1.02;
  letter-spacing: 0.1em;
}
@media screen and (width > 1600px) {
  .g-main-navigation-item {
    font-size: calc(15 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 1080px) {
  .g-main-navigation-item {
    font-size: 16px;
  }
}
@media screen and (width <= 576px) {
  .g-main-navigation-item {
    --font-medium: calc(28 * var(--min-fluid-ratio));
  }
}

a.g-main-navigation-item_link {
  position: relative;
  display: block;
  inline-size: fit-content;
  text-decoration: none;
  transition: opacity 0.3s ease-out 0s;
}
a.g-main-navigation-item_link::after {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  display: block;
  inline-size: calc(100% + 10px);
  block-size: calc(100% + 10px);
  content: "";
  transform: translate(-50%, -50%);
}
@media (any-hover: hover) {
  a.g-main-navigation-item_link:hover, a.g-main-navigation-item_link:active {
    opacity: 0.6;
  }
}
@media screen and (width <= 576px) {
  a.g-main-navigation-item_link {
    color: var(--color-white);
  }
}

/* ============================
  .g-social-media-list
============================ */
.g-social-media-list {
  font-size: 13px;
  letter-spacing: 0;
}
@media screen and (width > 1600px) {
  .g-social-media-list {
    font-size: calc(13 * var(--max-fluid-ratio));
  }
}
@media screen and (width > 1080px) {
  [data-animate] .g-social-media-list {
    opacity: 0;
    transform: translateX(30px);
    transition: transform 0.6s var(--ease-out-quint) 0.5s, opacity 0.2s var(--ease-out-quint) 0.5s;
  }
  [data-animate=active] .g-social-media-list {
    opacity: 1;
    transform: translateX(0);
  }
}
@media screen and (width <= 1080px) {
  .g-social-media-list {
    font-size: 15px;
  }
}
@media screen and (width > 576px) and (width <= 1080px) {
  .g-social-media-list {
    opacity: 0;
    transform: translateX(30px);
    transition: transform 0.4s var(--ease-out-quint) 0.6s, opacity 0.4s var(--ease-out-quint) 0.6s;
  }
  .is-opened-navigation .g-social-media-list {
    opacity: 1;
    transform: translateX(0);
    transition: transform 0.6s var(--ease-out-quint) 0.2s, opacity 0.2s var(--ease-out-quint) 0.2s;
  }
}
@media screen and (width <= 576px) {
  .g-social-media-list {
    font-size: calc(30 * var(--min-fluid-ratio));
  }
}

a.g-social-media-item_link {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 28px;
  block-size: 28px;
  color: var(--color-white);
  text-decoration: none;
  border-radius: 50%;
  transition: opacity 0.3s ease-out 0s;
}
a.g-social-media-item_link::after {
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
  z-index: -1;
  inline-size: 100%;
  block-size: 100%;
  content: "";
  background-color: var(--base-text-color);
  border-radius: 50%;
  transition: transform 0.3s var(--ease-out-back) 0s;
}
a.g-social-media-item_link:hover::after, a.g-social-media-item_link:active::after {
  transform: scale(1.1);
}
@media screen and (width > 1600px) {
  a.g-social-media-item_link {
    inline-size: calc(28 * var(--max-fluid-ratio));
    block-size: calc(28 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 1080px) {
  a.g-social-media-item_link {
    inline-size: 32px;
    block-size: 32px;
  }
}
@media screen and (width <= 576px) {
  a.g-social-media-item_link {
    inline-size: calc(48 * var(--min-fluid-ratio));
    block-size: calc(48 * var(--min-fluid-ratio));
    color: var(--base-text-color);
  }
  a.g-social-media-item_link::after {
    background-color: var(--color-white);
  }
}

.g-social-media-item_text {
  overflow: hidden;
  text-indent: -9999px;
}

/*
.g-sub-navigation
---------------------------- */
.g-sub-navigation {
  display: none;
  grid-area: sub-navigation;
  inline-size: fit-content;
}
@media screen and (width <= 576px) {
  .g-sub-navigation {
    display: block;
    justify-self: end;
  }
}

.g-sub-navigation-list {
  display: flex;
  flex-flow: column wrap;
  gap: 25px;
  font-weight: 700;
}
@media screen and (width > 1600px) {
  .g-sub-navigation-list {
    gap: calc(25 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .g-sub-navigation-list {
    gap: calc(48 * var(--min-fluid-ratio));
  }
}

.g-sub-navigation-item {
  font-size: 86%;
  white-space: nowrap;
}
@media screen and (width <= 576px) {
  .g-sub-navigation-item {
    font-size: calc(22 * var(--min-fluid-ratio));
  }
}

a.g-sub-navigation-item_link {
  position: relative;
  display: block;
  inline-size: fit-content;
  color: var(--color-white);
  text-decoration: none;
  transition: opacity 0.3s ease-out 0s;
}
a.g-sub-navigation-item_link::after {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  display: block;
  inline-size: calc(100% + 10px);
  block-size: calc(100% + 10px);
  content: "";
  transform: translate(-50%, -50%);
}
@media (any-hover: hover) {
  a.g-sub-navigation-item_link:hover, a.g-sub-navigation-item_link:active {
    opacity: 0.6;
  }
}

/*
.g-navigation-information
---------------------------- */
.g-navigation-information {
  display: none;
  grid-area: information;
  line-height: 1.8;
}
.g-navigation-information a {
  display: inline-flex;
  gap: 4px;
  align-items: center;
  inline-size: fit-content;
  color: var(--color-white);
}
.g-navigation-information a .icon-pin {
  text-decoration: none;
}
.g-navigation-information ul {
  margin-block-start: 0.8em;
}
@media screen and (width <= 576px) {
  .g-navigation-information {
    display: block;
    font-size: var(--font-small);
  }
}

/*
  .g-navigation-salsiccia-kun
============================ */
.g-navigation-salsiccia-kun {
  inline-size: 145px;
  margin-block-start: 8px;
  margin-inline-start: -30px;
  pointer-events: none;
  user-select: none;
}
@media screen and (width > 1600px) {
  .g-navigation-salsiccia-kun {
    inline-size: calc(145 * var(--max-fluid-ratio));
  }
}
@media screen and (width > 1080px) {
  [data-animate] .g-navigation-salsiccia-kun {
    opacity: 0;
    transform: translateX(30px);
    transition: transform 1s var(--ease-out-quint) 0.6s, opacity 0.2s var(--ease-out-quint) 0.6s;
  }
  [data-animate=active] .g-navigation-salsiccia-kun {
    opacity: 1;
    transform: translateX(0);
  }
}
@media screen and (width > 576px) and (width <= 1080px) {
  .g-navigation-salsiccia-kun {
    opacity: 0;
    transform: translateX(30px);
    transition: transform 0.4s var(--ease-out-quint) 0.6s, opacity 0.4s var(--ease-out-quint) 0.6s;
  }
  .is-opened-navigation .g-navigation-salsiccia-kun {
    opacity: 1;
    transform: translateX(0);
    transition: transform 0.9s var(--ease-out-quint) 0.3s, opacity 0.2s var(--ease-out-quint) 0.3s;
  }
}
@media screen and (width <= 576px) {
  .g-navigation-salsiccia-kun {
    display: none;
  }
}

.g-navigation-salsiccia-kun_img {
  inline-size: 100%;
  block-size: auto;
}

/* .g-navigation-background */
.g-navigation-background {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  inline-size: 100%;
  block-size: 100%;
  pointer-events: none;
}
@media screen and (width <= 1080px) {
  .g-navigation-background {
    background-color: transparent;
    opacity: 0;
    backdrop-filter: blur(10px);
    transition: opacity 0.35s var(--ease-out-quint) 0s;
    will-change: backdrop-filter;
  }
  .is-opened-navigation .g-navigation-background {
    pointer-events: auto;
    background-color: rgba(234, 221, 205, 0.7);
    opacity: 1;
  }
}
@media screen and (width <= 576px) {
  .is-opened-navigation .g-navigation-background {
    background-color: var(--background-color);
  }
}

/* ============================
  .g-navigation-open-close-button
============================ */
.g-navigation-open-close-button {
  all: unset;
  position: fixed;
  top: 61px;
  right: var(--side-spacing);
  z-index: var(--navigation-open-close-button-zindex);
  display: block;
  inline-size: 36px;
  block-size: 26px;
  line-height: 1.02;
  pointer-events: none;
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.3s ease-out 0s, transform 1.2s ease 0s;
  -webkit-tap-highlight-color: transparent;
}
.g-navigation-open-close-button::after {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  display: block;
  inline-size: calc(100% + 10px);
  block-size: calc(100% + 30px);
  content: "";
  transform: translate(-50%, -50%);
}
.g-navigation-open-close-button.step1 .g-navigation-open-close-button_line._1 {
  transform: translateY(7px);
}
.g-navigation-open-close-button.step1 .g-navigation-open-close-button_line._2 {
  transform: translateY(-7px);
}
.g-navigation-open-close-button.step2 .g-navigation-open-close-button_line._1 {
  transform: translateY(7px) rotate(-20deg);
}
.g-navigation-open-close-button.step2 .g-navigation-open-close-button_line._2 {
  transform: translateY(-7px) rotate(20deg);
}
@media screen and (width <= 1080px) {
  .g-navigation-open-close-button {
    pointer-events: auto;
    opacity: 1;
  }
  .is-opened-navigation .g-navigation-open-close-button {
    right: calc(var(--side-spacing) + var(--scrollbar-width));
  }
}
@media screen and (width <= 576px) {
  .g-navigation-open-close-button {
    top: calc(57 * var(--min-fluid-ratio));
    inline-size: calc(50 * var(--min-fluid-ratio));
    block-size: calc(20 * var(--min-fluid-ratio));
  }
  .g-navigation-open-close-button.step1 .g-navigation-open-close-button_line._1 {
    transform: translateY(calc(9 * var(--min-fluid-ratio)));
  }
  .g-navigation-open-close-button.step1 .g-navigation-open-close-button_line._2 {
    transform: translateY(calc(9 * var(--min-fluid-ratio) * -1));
  }
  .g-navigation-open-close-button.step2 .g-navigation-open-close-button_line {
    background-color: var(--color-white);
  }
  .g-navigation-open-close-button.step2 .g-navigation-open-close-button_line._1 {
    transform: translateY(calc(9 * var(--min-fluid-ratio))) rotate(-20deg);
  }
  .g-navigation-open-close-button.step2 .g-navigation-open-close-button_line._2 {
    transform: translateY(calc(9 * var(--min-fluid-ratio) * -1)) rotate(20deg);
  }
}

.g-navigation-open-close-button_line {
  position: absolute;
  inset-inline-start: 0;
  display: block;
  inline-size: 100%;
  block-size: 4px;
  background-color: var(--base-text-color);
  border-radius: 100vmax;
  transition: opacity 0.2s ease 0s, transform 0.2s ease 0s;
}
.g-navigation-open-close-button_line._1 {
  inset-block-start: 0;
}
.g-navigation-open-close-button_line._2 {
  inset-block-start: 14px;
}
@media screen and (width <= 576px) {
  .g-navigation-open-close-button_line {
    block-size: calc(5 * var(--min-fluid-ratio));
  }
  .g-navigation-open-close-button_line._2 {
    inset-block-start: calc(18 * var(--min-fluid-ratio));
  }
}

/* ==========================================================================
   component.scss
   Prefix : .c-
   ========================================================================== */
/* .c-separator */
.c-separator {
  margin: 3em 0;
}

/* .c-input */
.c-input {
  inline-size: 100%;
  padding: 0.8em 1em;
  font-weight: 400;
  line-height: 1.4;
  color: var(--base-text-color);
  appearance: none;
  outline: none;
  background-color: #fff;
  border: 1px solid var(--color-white);
  border-radius: 6px;
  transition: border-color 0.2s ease-out 0s, box-shadow 0.2s ease-out 0s;
}
.c-input::placeholder {
  color: #858585;
}
.c-input:focus {
  color: var(--base-text-color);
  border-color: var(--light-grey);
  box-shadow: 0 0 0 0.2em rgba(114, 147, 175, 0.22);
}
.ios .c-input {
  font-size: 16px;
}
@media screen and (width <= 1366px) {
  .c-input {
    border-radius: calc(6 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .c-input {
    border-radius: calc(10 * var(--min-fluid-ratio));
  }
  .c-input:focus {
    border-radius: calc(8 * var(--min-fluid-ratio));
  }
}

.c-select-container {
  position: relative;
}
.wpcf7-form .c-select-container::before {
  position: absolute;
  top: 50%;
  right: 1em;
  width: 0;
  height: 0;
  content: "";
  border-top: 0.5em solid var(--color-dove-gray);
  border-right: 0.3em solid transparent;
  border-left: 0.3em solid transparent;
  transform: translateY(-50%);
}

.c-select {
  inline-size: 100%;
  padding: 0.8em 1em;
  font-weight: 400;
  line-height: 1.4;
  color: var(--base-text-color);
  appearance: none;
  outline: none;
  background-color: #fff;
  border: 1px solid var(--color-white);
  border-radius: 0;
  transition: all 0.2s ease-out 0s;
}
.c-select:focus {
  color: var(--base-text-color);
  border-color: var(--light-grey);
  border-radius: 3px;
  box-shadow: 0 0 0 0.2em rgba(114, 147, 175, 0.22);
}
.c-select:focus::placeholder {
  color: #858585;
}
.c-select::placeholder {
  color: #858585;
}
.ios .c-select {
  font-size: 16px;
}
@media screen and (width <= 576px) {
  .c-select:focus {
    border-radius: calc(8 * var(--min-fluid-ratio));
  }
}

/* .c-textarea */
.c-textarea {
  position: relative;
  inline-size: 100%;
  min-block-size: 433px;
  padding: 0.8em 1em;
  font-weight: 400;
  line-height: 1.8;
  color: var(--base-text-color);
  appearance: none;
  outline: none;
  background-color: #fff;
  border: 1px solid var(--color-white);
  border-radius: 6px;
  transition: border-color 0.2s ease-out 0s, box-shadow 0.2s ease-out 0s;
}
.c-textarea::placeholder {
  color: #858585;
}
.c-textarea:focus {
  color: var(--base-text-color);
  border-color: var(--light-grey);
  border-radius: 3px;
  box-shadow: 0 0 0 0.2em rgba(114, 147, 175, 0.22);
}
.c-textarea:focus::placeholder {
  transition: all 0.2s ease-out 0s;
}
.ios .c-textarea {
  font-size: 16px;
}
@media screen and (width <= 1366px) {
  .c-textarea {
    border-radius: calc(6 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .c-textarea {
    min-block-size: 300px;
    border-radius: calc(10 * var(--min-fluid-ratio));
  }
}

.c-radio-container {
  display: flex;
  flex-flow: row wrap;
  gap: 1em 2em;
  align-items: center;
}
.c-radio-container label {
  display: flex;
  gap: 0 0.5em;
  align-items: center;
  white-space: nowrap;
}
@media screen and (width > 770px) {
  .c-radio-container {
    padding-block-start: 0.7em;
  }
}

/* .c-checkbox */
.c-checkbox {
  inline-size: 1em;
  block-size: 1em;
  margin-inline-end: 0.3em;
  appearance: none;
  outline: none;
  background-color: var(--color-white);
  border: 1px solid var(--line-color);
  border-radius: 3px;
  transition: all 0.2s ease-out 0s;
}
.c-checkbox:focus {
  color: var(--base-text-color);
  border-color: var(--color-gull-gray);
  box-shadow: 0 0 0 0.2em rgba(114, 147, 175, 0.22);
}
.c-checkbox:checked {
  background-color: var(--color-gull-gray);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 18 18' width='18' height='18'%3E%3Cpath d='M4 9l3 3 7-7' fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 1em 1em;
}
@media screen and (width > 1600px) {
  .c-checkbox {
    border-radius: calc(3 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .c-checkbox {
    border-radius: calc(8 * var(--min-fluid-ratio));
  }
}

.mwform-checkbox-field,
.wpcf7-checkbox .wpcf7-list-item {
  position: relative;
  display: block;
}
.mwform-checkbox-field label,
.wpcf7-checkbox .wpcf7-list-item label {
  display: flex;
  gap: 0 0.5em;
  align-items: center;
  white-space: nowrap;
}
.mwform-checkbox-field + .mwform-checkbox-field, .mwform-checkbox-field + .wpcf7-list-item,
.wpcf7-checkbox .wpcf7-list-item + .mwform-checkbox-field,
.wpcf7-checkbox .wpcf7-list-item + .wpcf7-list-item {
  margin-block-start: 0.8em;
}

/* .c-radio */
.c-check-label {
  margin-inline-start: 0.5em;
}

/* ==========================================================================
   module.scss
   Prefix : .m-
   ========================================================================== */
/* ============================
  .m-heading
============================ */
.m-heading {
  display: flex;
  flex-flow: column wrap;
  gap: 10px;
  font-weight: 700;
  line-height: 1.2;
}
@media screen and (width > 1600px) {
  .m-heading {
    gap: calc(10 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .m-heading {
    gap: calc(15 * var(--min-fluid-ratio));
  }
}

.m-heading_ja {
  font-size: var(--font-xlarge);
  letter-spacing: 0.17em;
}

.m-heading_en {
  padding-inline-start: 0.1em;
  font-size: var(--font-medium-large);
  text-transform: uppercase;
  letter-spacing: 0.09em;
}

/* ============================
  .m-pagination
============================ */
.m-pagination {
  position: relative;
  display: flex;
  flex-flow: row wrap;
  align-items: flex-end;
  justify-content: space-between;
  inline-size: 100%;
  margin-block-start: 160px;
  font-family: var(--font-family-en);
  font-size: 12px;
  line-height: 1.02;
}
.m-pagination a {
  position: relative;
  display: block;
  text-decoration: none;
}
.m-pagination a::after {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  inline-size: 2em;
  block-size: 2em;
  content: "";
  transform: translate(-50%, -50%);
}
.m-pagination ._off {
  pointer-events: none;
}
@media screen and (width > 1600px) {
  .m-pagination {
    margin-block-start: calc(160 * var(--max-fluid-ratio));
    font-size: calc(12 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .m-pagination {
    margin-block-start: calc(280 * var(--min-fluid-ratio));
    font-size: calc(22 * var(--min-fluid-ratio));
  }
}

.m-pagination-pages {
  display: flex;
  flex-flow: row wrap;
  gap: 1em 42px;
  align-items: flex-end;
  justify-content: center;
}
@media screen and (width > 1600px) {
  .m-pagination-pages {
    gap: 1em calc(42 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .m-pagination-pages {
    gap: 1em calc(62 * var(--min-fluid-ratio));
  }
  ._desktop .m-pagination-pages {
    gap: 1em calc(45 * var(--min-fluid-ratio));
  }
}

.m-pagination_current,
a.m-pagination_link,
.m-pagination-prev,
.m-pagination-next {
  position: relative;
  display: block;
  padding-bottom: 1em;
}
.m-pagination_current::before,
a.m-pagination_link::before,
.m-pagination-prev::before,
.m-pagination-next::before {
  position: absolute;
  bottom: 0;
  left: 50%;
  display: block;
  inline-size: 30px;
  block-size: 1px;
  content: "";
  background-color: var(--color-mercury);
  transform: translateX(-50%);
}
@media screen and (width > 1600px) {
  .m-pagination_current::before,
  a.m-pagination_link::before,
  .m-pagination-prev::before,
  .m-pagination-next::before {
    inline-size: calc(30 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .m-pagination_current::before,
  a.m-pagination_link::before,
  .m-pagination-prev::before,
  .m-pagination-next::before {
    inline-size: calc(24 * var(--min-fluid-ratio));
  }
}

a.m-pagination_link {
  transition: opacity 0.3s ease-out 0s;
}
@media (any-hover: hover) {
  a.m-pagination_link:hover, a.m-pagination_link:active {
    opacity: 0.4;
  }
}

.m-pagination_current::before {
  background-color: var(--color-pink-swan);
}

.m-pagination_ellipses {
  display: block;
  padding-block: 1em;
}
@media screen and (width <= 576px) {
  .m-pagination_ellipses {
    margin-inline: -0.8em;
  }
}

.m-pagination-prev,
.m-pagination-next {
  position: relative;
  display: block;
  transition: opacity 0.3s ease-out 0s;
}
.m-pagination-prev._off .m-pagination_arrow,
.m-pagination-next._off .m-pagination_arrow {
  color: var(--color-mercury);
}

.m-pagination_arrow {
  font-size: 90%;
}

.m-pagination-prev_text,
.m-pagination-next_text {
  position: absolute;
  left: -9999px;
}

@media (any-hover: hover) {
  a.m-pagination-prev:hover, a.m-pagination-prev:active,
  a.m-pagination-next:hover,
  a.m-pagination-next:active {
    opacity: 0.4;
  }
}

.m-editor-style {
  line-height: 2;
  --base-margin: 1em;
  --base-margin-large: 4em;
}
.m-editor-style a {
  word-break: break-all;
  text-decoration-line: underline;
  transition: opacity 0.3s ease-out 0s;
}
@media (any-hover: hover) {
  .m-editor-style a:hover, .m-editor-style a:active {
    opacity: 0.4;
  }
}
.m-editor-style h1,
.m-editor-style h2,
.m-editor-style h3,
.m-editor-style h4,
.m-editor-style h5,
.m-editor-style h6 {
  clear: both;
  margin-block: var(--base-margin-large) 0.8em;
  font-weight: 600;
  line-height: 1.6;
}
.m-editor-style h1 + h1, .m-editor-style h1 + h2, .m-editor-style h1 + h3, .m-editor-style h1 + h4, .m-editor-style h1 + h5, .m-editor-style h1 + h6,
.m-editor-style h2 + h1,
.m-editor-style h2 + h2,
.m-editor-style h2 + h3,
.m-editor-style h2 + h4,
.m-editor-style h2 + h5,
.m-editor-style h2 + h6,
.m-editor-style h3 + h1,
.m-editor-style h3 + h2,
.m-editor-style h3 + h3,
.m-editor-style h3 + h4,
.m-editor-style h3 + h5,
.m-editor-style h3 + h6,
.m-editor-style h4 + h1,
.m-editor-style h4 + h2,
.m-editor-style h4 + h3,
.m-editor-style h4 + h4,
.m-editor-style h4 + h5,
.m-editor-style h4 + h6,
.m-editor-style h5 + h1,
.m-editor-style h5 + h2,
.m-editor-style h5 + h3,
.m-editor-style h5 + h4,
.m-editor-style h5 + h5,
.m-editor-style h5 + h6,
.m-editor-style h6 + h1,
.m-editor-style h6 + h2,
.m-editor-style h6 + h3,
.m-editor-style h6 + h4,
.m-editor-style h6 + h5,
.m-editor-style h6 + h6 {
  margin-block-start: -0.3em;
}
.m-editor-style h1,
.m-editor-style h2,
.m-editor-style h3 {
  font-size: var(--font-large);
  font-weight: normal;
}
.m-editor-style h4,
.m-editor-style h5,
.m-editor-style h6 {
  font-size: var(--font-medium);
}
.m-editor-style h1:first-child,
.m-editor-style h2:first-child,
.m-editor-style h3:first-child,
.m-editor-style h4:first-child,
.m-editor-style h5:first-child,
.m-editor-style h6:first-child {
  margin-block-start: 0;
}
.m-editor-style ul,
.m-editor-style ol {
  line-height: 1.6;
}
.m-editor-style ul li,
.m-editor-style ol li {
  margin-inline-start: 0.2em;
}
.m-editor-style ul li:not(:last-child),
.m-editor-style ol li:not(:last-child) {
  margin-block-end: 0.4em;
}
.m-editor-style ul li {
  position: relative;
  padding-inline-start: 1.2em;
  list-style: none;
}
.m-editor-style ul li::before {
  position: absolute;
  top: 0;
  left: 0;
  margin-inline-end: 0.2em;
  content: "・";
}
.m-editor-style ol li {
  padding-inline-start: 1em;
  text-indent: -1em;
  list-style: decimal inside;
}
.m-editor-style ol {
  padding-inline-start: 0.2em;
}
.m-editor-style dt {
  margin-block-end: 0.2em;
  font-weight: 600;
}
.m-editor-style hr + * {
  margin-block-start: 0;
}
.m-editor-style blockquote {
  position: relative;
  padding: 2.5em 2.7em;
  margin-block: var(--base-margin-large);
  line-height: 2.1;
  background-color: #fff;
}
.m-editor-style blockquote h1,
.m-editor-style blockquote h2,
.m-editor-style blockquote h3,
.m-editor-style blockquote h4,
.m-editor-style blockquote h5,
.m-editor-style blockquote h6 {
  padding-block-start: 0;
  margin-block-start: 0;
}
.m-editor-style blockquote p {
  margin-block-end: 1em;
}
.m-editor-style blockquote hr {
  margin: calc(var(--base-margin) / 1.4) 0;
  border-color: var(--line-color);
}
.m-editor-style blockquote *:first-child {
  margin-block-start: 0;
}
.m-editor-style blockquote *:last-child {
  margin-block-end: 0;
}
@media screen and (width <= 576px) {
  .m-editor-style blockquote {
    padding: calc(var(--side-spacing) * 1.4) var(--side-spacing);
  }
}
.m-editor-style blockquote:nth-last-child(1) {
  margin-block-end: 0;
}
.m-editor-style img {
  block-size: auto;
}
.m-editor-style figure {
  margin-block-end: var(--base-margin);
}
.m-editor-style figure + p {
  margin-block-start: var(--base-margin);
}
.m-editor-style figcaption {
  display: block;
  margin-block-start: 0.7em;
  font-size: 85%;
  line-height: 1.6;
  text-align: center;
  opacity: 0.8;
}
.m-editor-style p,
.m-editor-style ul,
.m-editor-style ol,
.m-editor-style dl {
  margin-block-end: var(--base-margin);
}
.m-editor-style p + .wp-block-embed, .m-editor-style p + .wp-block-image,
.m-editor-style ul + .wp-block-embed,
.m-editor-style ul + .wp-block-image,
.m-editor-style ol + .wp-block-embed,
.m-editor-style ol + .wp-block-image,
.m-editor-style dl + .wp-block-embed,
.m-editor-style dl + .wp-block-image {
  margin-block-start: var(--base-margin-large) !important;
}
.m-editor-style hr {
  clear: both;
  margin-block: var(--base-margin-large);
  border: none;
  border-block-start: 1px solid var(--line-color);
}
.m-editor-style table {
  width: 100%;
  margin-block: calc(var(--base-margin) * 2);
  border-spacing: 0;
  border-collapse: collapse;
  border-block-start: 1px solid var(--line-color);
}
.m-editor-style table th,
.m-editor-style table td {
  padding: 1.2em 1.5em;
  border-block-end: 1px solid var(--line-color);
}
.m-editor-style table th,
.m-editor-style table caption {
  vertical-align: baseline;
  text-align: left;
}
.m-editor-style table th {
  inline-size: 30%;
}
.m-editor-style table td {
  vertical-align: baseline;
}
.m-editor-style embed,
.m-editor-style iframe,
.m-editor-style object {
  max-inline-size: 100%;
}
.m-editor-style .alignright {
  float: right;
  margin-block-end: var(--base-margin);
  margin-inline-start: 1.5em;
}
.m-editor-style .alignleft {
  float: left;
  margin-block-end: var(--base-margin);
  margin-inline-start: 1.5em;
}
.m-editor-style .aligncenter {
  margin-inline: auto;
  text-align: center;
}
.m-editor-style .wp-block-image:not(:first-of-type) {
  margin-block-start: var(--base-margin);
}
.m-editor-style .wp-block-embed {
  inline-size: 100%;
}
.m-editor-style .wp-block-embed iframe {
  inline-size: 100%;
  margin: 0;
  vertical-align: top;
}
.m-editor-style .wp-block-embed:not(:first-of-type) {
  margin-block-start: var(--base-margin);
}
.m-editor-style .wp-block-pullquote {
  all: unset;
}
@media screen and (width <= 576px) {
  .m-editor-style table {
    border: none;
  }
  .m-editor-style table tr,
  .m-editor-style table th,
  .m-editor-style table td {
    display: block;
    padding: 0;
    border: none;
  }
  .m-editor-style table tr {
    padding: 1em 0;
    border-block-end: none;
  }
  .m-editor-style table th {
    width: 100%;
    padding-block: 0;
    padding-inline-end: 0;
    border-block-end: none;
  }
  .m-editor-style table td {
    padding-block: 0;
    padding-inline-end: 0;
    border-block-end: none;
  }
}
.m-editor-style:first-child {
  margin-block-start: 0;
}
.m-editor-style > :last-child {
  margin-block-end: 0;
}

/* ==========================================================================
   utility.scss
   Prefix : .u-
   ========================================================================== */
/* ============================
  .u-leading-trim
============================ */
/* カスタムプロパティの型宣言（対応ブラウザ: Chromium 96+, Safari 17.2+, Firefox 110+） */
@property --lh {
  syntax: "<number>";
  inherits: true;
  initial-value: 1; /* デフォルト：line-height 1 */
}
.u-leading-trim {
  /* 任意の line-height をここで指定（上書き可） */
  line-height: var(--lh);
  /* 擬似要素共通設定 */
}
.u-leading-trim::before, .u-leading-trim::after {
  display: block;
  inline-size: 0;
  block-size: 1px; /* margin 相殺防止用のダミー高さ */
  content: "";
}
.u-leading-trim {
  /* 上下余白を打ち消す */
}
.u-leading-trim::before {
  margin-block-end: calc((1 - var(--lh)) * 0.5em);
}
.u-leading-trim::after {
  margin-block-start: calc((1 - var(--lh)) * 0.5em);
}

/* clearfix */
.u-cf::after {
  clear: both;
  display: block;
  visibility: hidden;
  block-size: 0;
  content: "";
}

/* end clearfix */
.u-font-en {
  font-family: gill-sans-nova, sans-serif;
}

.u-d-none {
  display: none;
}

.u-d-block {
  display: block;
}

@media screen and (width > 576px) {
  .u-flex {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
  }
}

.u-d-inline {
  display: inline;
}

.u-clear {
  clear: both;
}

.u-fl {
  float: left;
  display: inline;
}

.u-fr {
  float: right;
  display: inline;
}

.u-al {
  text-align: left;
}

.u-ar {
  text-align: right;
}

.u-ac {
  text-align: center;
}

@media screen and (width > 576px) {
  .u-dt-ac {
    text-align: center;
  }
}

@media screen and (width <= 576px) {
  .u-mb-ac {
    text-align: center;
  }
}

.u-m-a {
  margin-inline: auto;
}

.u-vt {
  vertical-align: top !important;
}

.u-vm {
  vertical-align: middle !important;
}

.u-vb {
  vertical-align: bottom !important;
}

.u-superscript {
  font-size: 60%;
  vertical-align: super;
}

.u-pos-t {
  position: absolute;
  top: 0;
}

.u-pos-b {
  position: absolute;
  bottom: 0;
}

.u-pos-l {
  position: absolute;
  left: 0;
}

.u-pos-r {
  position: absolute;
  right: 0;
}

.u-indent1 {
  padding-inline-start: 1em !important;
  text-indent: -1em !important;
}

.u-indent2 {
  padding-inline-start: 2em !important;
  text-indent: -2em !important;
}

.u-indent3 {
  padding-inline-start: 3em !important;
  text-indent: -3em !important;
}

.u-fz-s {
  font-size: 80%;
}

.u-fw-nml {
  font-weight: normal !important;
}

.u-fw-bld {
  font-weight: bold !important;
}

.u-break-word {
  overflow-wrap: break-word;
}

.u-disable-event {
  pointer-events: none;
}

.u-bdr-t-none {
  border-block-start: none !important;
}

.u-bdr-l-none {
  border-inline-start: none !important;
}

.u-bdr-r-none {
  border-inline-end: none !important;
}

.u-bdr-b-none {
  border-block-end: none !important;
}

@media screen and (width <= 576px) {
  .u-dt-br {
    display: none;
  }
}

.u-mb-br {
  display: none;
}
@media screen and (width <= 576px) {
  .u-mb-br {
    display: inline;
  }
}

.u-alpha-over {
  transition: opacity 0.3s ease-out;
}
@media (any-hover: hover) {
  .u-alpha-over:hover, .u-alpha-over:active {
    opacity: 0.85;
  }
}

.u-textfix {
  max-block-size: 100%;
}

/* ==========================================================================
   animation.scss
   ========================================================================== */
[data-animate][fade-in] {
  opacity: 0;
  transition: opacity 1s ease-in-out 0s;
}
.ie [data-animate][fade-in] {
  opacity: 1;
  transition: none;
}

[data-animate=active][fade-in] {
  opacity: 1;
}

[data-animate][fade-in-up] {
  opacity: 0;
  transform: translateY(50px);
  transition: opacity 0.7s ease-in-out 0s, transform 1.5s var(--ease-out-cubic) 0s;
}
@media screen and (width <= 576px) {
  [data-animate][fade-in-up] {
    transform: translateY(30px);
  }
}
.ie [data-animate][fade-in-up] {
  opacity: 1;
  transform: none;
  transition: none;
}
@media screen and (width <= 576px) {
  .ie [data-animate][fade-in-up] {
    transform: none;
  }
}

[data-animate=active][fade-in-up] {
  opacity: 1;
  transform: translateY(0);
}
@media screen and (width <= 576px) {
  [data-animate=active][fade-in-up] {
    transform: translateY(0);
  }
}

[data-animate][move-up] {
  transform: translateY(100px);
  transition: transform 0s var(--ease-out-cubic) 0s;
}
@media screen and (width <= 576px) {
  [data-animate][move-up] {
    transform: translateY(50px);
  }
}

[data-animate=active][move-up] {
  transform: translateY(0);
  transition: transform 1.5s var(--ease-out-cubic) 0s;
}
@media screen and (width <= 576px) {
  [data-animate=active][move-up] {
    transform: translateY(0);
  }
}

/* ==========================================================================
   top.scss
   ========================================================================== */
.top-salsiccia-kun[data-animate] {
  opacity: 0;
  scale: 0.7;
  translate: 0 30px;
  transition: opacity 0.1s ease-out 0.4s, scale 0.4s var(--ease-out-back) 0.4s, translate 0.4s var(--ease-out-back) 0.4s;
}
.top-salsiccia-kun[data-animate=active] {
  opacity: 1;
  scale: 1;
  translate: 0 0;
}

/* ============================
 .top-introduction
============================ */
.top-introduction {
  position: relative;
  inline-size: 100%;
  padding-inline-end: 14%;
}
@media screen and (width > 940px) {
  .top-introduction {
    margin-block-start: calc(clamp(0px, 2vw, 20px) * -1);
  }
}
@media screen and (width > 1124px) {
  .top-introduction {
    padding-inline-end: 14%;
  }
}
@media screen and (width <= 1080px) {
  .top-introduction {
    padding-inline-end: 0;
  }
}
@media screen and (width <= 576px) {
  .top-introduction {
    padding-block-start: calc(15 * var(--min-fluid-ratio));
  }
}

.top-introduction-carousel {
  position: relative;
  z-index: 2;
  inline-size: 119%;
  margin-inline-start: -18%;
  opacity: 0;
  transform: scale(0.9);
  transition: transform 1s cubic-bezier(0.175, 0.885, 0.32, 1) 0.3s, opacity 0.5s ease-out 0.2s;
}
.top-introduction-carousel::after {
  position: absolute;
  inset-block-start: 4.5%;
  inset-inline-end: 1%;
  z-index: -1;
  display: block;
  inline-size: 100%;
  block-size: 100%;
  content: "";
  background: url("../images/top/kv-background.svg") no-repeat center center/100% 100%;
  opacity: 0;
  transform: scale(0.99);
  transition: opacity 1.4s ease 0.7s;
}
.top-introduction-carousel.swiper-initialized {
  opacity: 1;
  transform: scale(1);
}
.top-introduction-carousel.swiper-initialized::after {
  opacity: 1;
}
.top-introduction-carousel.swiper-initialized .top-introduction-carousel-background {
  opacity: 1;
}
@media screen and (width <= 1080px) {
  .top-introduction-carousel {
    inline-size: 114%;
    margin-inline-start: -14%;
  }
}
@media screen and (width <= 940px) {
  .top-introduction-carousel {
    inline-size: 135%;
    margin-inline-start: -25%;
  }
}

.top-introduction-carousel-item {
  font-size: 0;
  line-height: 0;
  opacity: 0 !important;
}
.top-introduction-carousel-item.swiper-slide-active {
  opacity: 1 !important;
}
.top-introduction-carousel-item.swiper-slide-prev {
  opacity: 0 !important;
  transition-delay: 0.6s;
}

.top-introduction-carousel-item-picture {
  display: block;
}

.top-introduction-carousel-item-picture_img {
  inline-size: 100%;
  block-size: 100%;
  vertical-align: top;
  mask-image: url("../images/top/kv-mask.svg");
  mask-repeat: no-repeat;
  mask-position: 0 0;
  mask-position: 50% 50%;
  mask-size: 90%;
  transition: mask-size 1s cubic-bezier(0.175, 0.885, 0.32, 1) 0.3s;
}
.swiper-initialized .top-introduction-carousel-item-picture_img {
  mask-size: 100%;
}

@media screen and (width > 576px) {
  .top-introduction-salsiccia-kun {
    display: none;
  }
}
@media screen and (width <= 576px) {
  .top-introduction-salsiccia-kun {
    position: absolute;
    inset-block-end: -10%;
    inset-inline-end: 12%;
    inline-size: calc(240 * var(--min-fluid-ratio));
  }
}

.top-introduction-salsiccia-kun_img {
  inline-size: 100%;
  block-size: auto;
}

.top-introduction_text {
  position: relative;
  z-index: 2;
  inline-size: fit-content;
  max-inline-size: 70%;
  margin-block-start: -9%;
  margin-inline-start: auto;
  font-size: clamp(14px, 1.3vw, 18px);
  line-height: 2.2;
}
@media screen and (width > 1600px) {
  .top-introduction_text {
    margin-block-start: -12%;
    font-size: calc(18 * var(--max-fluid-ratio));
  }
}
@media screen and (940px <= width <= 1080px) {
  .top-introduction_text {
    margin-block-start: -4%;
  }
}
@media screen and (width <= 940px) {
  .top-introduction_text {
    max-inline-size: 100%;
    margin-block-start: 8vw;
    font-size: clamp(16px, 1.8vw, 22px);
  }
}
@media screen and (width <= 576px) {
  .top-introduction_text {
    max-inline-size: 100%;
    margin-block-start: calc(80 * var(--min-fluid-ratio));
    font-size: calc(24 * var(--min-fluid-ratio));
  }
}

/* ============================
 .top-content
============================ */
.top-content {
  max-inline-size: 1080px;
  margin-block-start: 140px;
  margin-inline: auto;
}
@media screen and (width > 1600px) {
  .top-content {
    max-inline-size: calc(1080 * var(--max-fluid-ratio));
    margin-block-start: calc(140 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-content {
    margin-block-start: calc(180 * var(--min-fluid-ratio));
  }
}

/* ============================
 .top-shopping
============================ */
.top-shopping_head {
  position: relative;
}

.top-shopping-salsiccia-kun {
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 210px;
  z-index: 1;
  inline-size: 71px;
  pointer-events: none;
  user-select: none;
}
@media screen and (width > 1600px) {
  .top-shopping-salsiccia-kun {
    inset-inline-start: calc(210 * var(--max-fluid-ratio));
    inline-size: calc(71 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-shopping-salsiccia-kun {
    inset-block-start: calc(18 * var(--min-fluid-ratio) * -1);
    inset-inline-start: calc(262 * var(--min-fluid-ratio));
    inline-size: calc(105 * var(--min-fluid-ratio));
  }
}

.top-shopping-salsiccia-kun_img {
  inline-size: 100%;
  block-size: auto;
}

.top-shopping_body {
  max-inline-size: 860px;
  margin-block-start: 80px;
  margin-inline: auto;
}
@media screen and (width > 1600px) {
  .top-shopping_body {
    max-inline-size: calc(860 * var(--max-fluid-ratio));
    margin-block-start: calc(80 * var(--max-fluid-ratio));
  }
}
@media screen and (940px <= width <= 1080px) {
  .top-shopping_body {
    max-inline-size: 88%;
  }
}
@media screen and (width <= 576px) {
  .top-shopping_body {
    margin-block-start: calc(80 * var(--min-fluid-ratio));
  }
}

.top-shopping-information {
  padding: 40px;
  margin-block-end: 100px;
  font-size: 90%;
  background: rgba(255, 255, 255, 0.15);
  border-radius: 30px;
  border: 1px solid rgba(52, 26, 28, 0.3);
}
.top-shopping-information h1,
.top-shopping-information h2,
.top-shopping-information h3,
.top-shopping-information h4,
.top-shopping-information h5,
.top-shopping-information h6 {
  font-size: var(--font-medium-large);
}
.top-shopping-information img {
  margin-block: 1em;
  max-inline-size: 400px;
  inline-size: 100%;
  border-radius: 15px;
}
@media screen and (width > 1600px) {
  .top-shopping-information {
    padding: calc(40 * var(--max-fluid-ratio));
    margin-block-end: calc(100 * var(--max-fluid-ratio));
    border-radius: calc(30 * var(--max-fluid-ratio));
  }
  .top-shopping-information img {
    max-inline-size: calc(400 * var(--max-fluid-ratio));
    border-radius: calc(15 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-shopping-information {
    padding: calc(56 * var(--min-fluid-ratio)) calc(50 * var(--min-fluid-ratio));
    margin-block-end: calc(100 * var(--min-fluid-ratio));
    line-height: 1.8;
    border-radius: calc(46 * var(--min-fluid-ratio));
  }
  .top-shopping-information img {
    border-radius: calc(20 * var(--min-fluid-ratio));
  }
}

.top-shopping-section + .top-shopping-section {
  margin-block-start: 100px;
}
@media screen and (width > 1600px) {
  .top-shopping-section + .top-shopping-section {
    margin-block-start: calc(100 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-shopping-section + .top-shopping-section {
    margin-block-start: calc(160 * var(--min-fluid-ratio));
  }
}

.top-shopping-section_head {
  display: flex;
  flex-flow: column wrap;
  gap: 8px;
}
@media screen and (width > 1600px) {
  .top-shopping-section_head {
    gap: calc(8 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-shopping-section_head {
    gap: calc(12 * var(--min-fluid-ratio));
  }
}

.top-shopping-section_title {
  font-size: var(--font-large);
  line-height: 1.5;
  letter-spacing: 0.1em;
}
@media screen and (width <= 576px) {
  .top-shopping-section_title {
    font-weight: 700;
  }
}

.top-shopping-section_text {
  margin-block-start: 0.6em;
}

.top-shopping-section_body {
  margin-block-start: 40px;
}
@media screen and (width > 1600px) {
  .top-shopping-section_body {
    margin-block-start: calc(40 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-shopping-section_body {
    margin-block-start: calc(60 * var(--min-fluid-ratio));
  }
}

.top-shopping-list,
.top-recommend-list {
  opacity: 0;
  transition: opacity 1s ease-out 0s;
}
.top-shopping-list.swiper-initialized,
.top-recommend-list.swiper-initialized {
  opacity: 1;
}
@media screen and (width > 1600px) {
  .top-shopping-list .swiper-wrapper,
  .top-recommend-list .swiper-wrapper {
    row-gap: calc(60 * var(--max-fluid-ratio));
  }
}
@media screen and (width > 1124px) {
  .top-shopping-list .swiper-wrapper,
  .top-recommend-list .swiper-wrapper {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 60px 4%;
  }
}
@media screen and (width <= 1124px) {
  .top-shopping-list .swiper-wrapper,
  .top-recommend-list .swiper-wrapper {
    align-items: stretch;
  }
}
@media screen and (width <= 576px) {
  .top-shopping-list,
  .top-recommend-list {
    padding-block-end: calc(40 * var(--min-fluid-ratio));
  }
}

.top-shopping-carousel-scrollbar {
  position: relative;
  display: none;
  inline-size: 100%;
  block-size: 2px;
  margin: 3em auto 0;
  background-color: #fff;
  border-radius: 4px;
}
.top-shopping-carousel-scrollbar .swiper-scrollbar-drag {
  position: relative;
  inset-block-start: 0;
  inset-inline-start: 0;
  inline-size: 100%;
  block-size: 100%;
  cursor: pointer;
  background: var(--base-text-color);
  border-radius: 4px;
}
.top-shopping-carousel-scrollbar .swiper-scrollbar-drag::after {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 0;
  display: block;
  inline-size: 100%;
  block-size: 20px;
  content: "";
  transform: translateY(-50%);
}
@media screen and (width < 1366px) {
  .swiper-initialized .top-shopping-carousel-scrollbar {
    display: block;
  }
}

.top-shopping-item_form {
  display: contents;
}

.top-shopping-item,
.top-recommend-item {
  display: flex;
  flex-direction: column;
  gap: 26px;
  align-items: center;
  block-size: auto;
  container-name: item;
  container-type: inline-size;
  font-size: 14px;
}
@media screen and (width > 1600px) {
  .top-shopping-item,
  .top-recommend-item {
    gap: calc(26 * var(--max-fluid-ratio));
    font-size: calc(14 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-shopping-item,
  .top-recommend-item {
    gap: calc(36 * var(--min-fluid-ratio));
    font-size: calc(28 * var(--min-fluid-ratio));
  }
}

.top-shopping-item_picture-button:hover .top-shopping-item-picture_img, .top-shopping-item_picture-button:active .top-shopping-item-picture_img {
  transform: scale(1.04);
}

.top-shopping-item-picture,
.top-recommend-item-picture {
  position: relative;
  display: block;
  inline-size: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
}
@container item (min-width: 0) {
  .top-shopping-item-picture,
  .top-recommend-item-picture {
    border-radius: 42cqi;
  }
}

.top-shopping-item-picture_img,
.top-recommend-item-picture_img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.3s var(--ease-out-back) 0s;
}

.top-shopping-item_body {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 12px;
}
@media screen and (width > 1600px) {
  .top-shopping-item_body {
    gap: calc(12 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-shopping-item_body {
    gap: calc(18 * var(--min-fluid-ratio));
  }
}

.top-shopping-item_name,
.top-recommend-item-name_ja {
  line-height: 1.6;
}
@media screen and (width <= 576px) {
  .top-shopping-item_name,
  .top-recommend-item-name_ja {
    font-size: calc(24 * var(--min-fluid-ratio));
  }
}

.top-shopping-item_text {
  font-size: 12px;
}
@media screen and (width > 1600px) {
  .top-shopping-item_text {
    font-size: calc(12 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-shopping-item_text {
    font-size: calc(22 * var(--min-fluid-ratio));
  }
}

.top-shopping-item_price-wrapper {
  display: flex;
  flex-flow: row wrap;
  gap: 1em 0;
  align-items: center;
  justify-content: space-between;
  padding-block-start: 0.3em;
  margin-block-start: auto;
}

.top-shopping-item_quantity {
  padding: 4px 10px;
  font-family: Manrope, sans-serif;
  font-weight: 600;
  appearance: none;
  background: var(--color-white);
  border: 1px solid #d4c8b1;
  border-radius: 10px;
}
@media screen and (770px <= width <= 1124px) {
  @container item (min-width: 0) {
    .top-shopping-item_quantity {
      padding: 2.1cqi 4.62cqi;
      font-size: 10.5cqi;
    }
  }
}
@media screen and (width > 1600px) {
  .top-shopping-item_quantity {
    padding: calc(4 * var(--max-fluid-ratio)) calc(10 * var(--max-fluid-ratio));
    border-radius: calc(10 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-shopping-item_quantity {
    padding: calc(5 * var(--min-fluid-ratio)) calc(14 * var(--min-fluid-ratio));
    border-radius: calc(12 * var(--min-fluid-ratio));
  }
}

.top-shopping-item_price {
  display: flex;
  flex-flow: row wrap;
  gap: 0.1em;
  align-items: baseline;
  margin-inline-start: auto;
  font-size: 22px;
  font-weight: 500;
  line-height: 1.02;
  letter-spacing: 0;
}
@media screen and (770px <= width <= 1124px) {
  @container item (min-width: 0) {
    .top-shopping-item_price {
      font-size: 12.6cqi;
    }
  }
}
@media screen and (width > 1600px) {
  .top-shopping-item_price {
    font-size: calc(22 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-shopping-item_price {
    font-size: calc(38 * var(--min-fluid-ratio));
  }
}

.top-shopping-item_kurai {
  font-size: 65%;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.top-shopping-item_price-label,
.top-shopping-item_price-unit {
  letter-spacing: 0.05em;
}
@media screen and (width <= 576px) {
  .top-shopping-item_price-label,
  .top-shopping-item_price-unit {
    font-size: calc(24 * var(--min-fluid-ratio));
  }
}

.top-shopping-item_price-number {
  font-size: 22px;
  font-weight: 600;
  font-feature-settings: "kern";
  letter-spacing: 0;
}
@media screen and (770px <= width <= 1124px) {
  @container item (min-width: 0) {
    .top-shopping-item_price-number {
      font-size: 12.6cqi;
    }
  }
}
@media screen and (width > 1600px) {
  .top-shopping-item_price-number {
    font-size: calc(22 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-shopping-item_price-number {
    font-size: calc(38 * var(--min-fluid-ratio));
  }
}

button.top-shopping-item_button {
  position: relative;
  z-index: 1;
  display: block;
  inline-size: 100%;
  padding: 20px 0;
  margin-block-start: 12px;
  font-weight: 700;
  line-height: 1.5;
  color: var(--color-white);
  text-align: center;
  letter-spacing: 0.1em;
  text-decoration: none;
  appearance: none;
  cursor: pointer;
  background: none;
  border: none;
}
button.top-shopping-item_button::before {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  z-index: -1;
  inline-size: 100%;
  block-size: 100%;
  content: "";
  background: var(--color-contessa);
  border-radius: 100vmax;
  transform: translate(-50%, -50%);
  transition: inline-size 0.3s var(--ease-bounce) 0s, block-size 0.3s var(--ease-bounce) 0s;
}
button.top-shopping-item_button[disabled] {
  cursor: not-allowed;
}
button.top-shopping-item_button[disabled]::before {
  background: #adadad;
}
button.top-shopping-item_button:not([disabled]):hover::before, button.top-shopping-item_button:not([disabled]):active::before {
  inline-size: calc(100% + 5px);
  block-size: calc(100% + 5px);
}
@media screen and (width > 1600px) {
  button.top-shopping-item_button {
    padding: calc(20 * var(--max-fluid-ratio)) 0;
    margin-block-start: calc(12 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  button.top-shopping-item_button {
    padding: calc(30 * var(--min-fluid-ratio)) 0;
    margin-block-start: calc(18 * var(--min-fluid-ratio));
  }
}

/* ============================
 .top-recommend
============================ */
a.top-recommend-item_link {
  display: flex;
  flex-flow: column wrap;
  gap: 26px;
  text-decoration: none;
}
a.top-recommend-item_link:hover .top-recommend-item-picture_img, a.top-recommend-item_link:active .top-recommend-item-picture_img {
  transform: scale(1.04);
}
@media screen and (width > 1600px) {
  a.top-recommend-item_link {
    gap: calc(26 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  a.top-recommend-item_link {
    gap: calc(36 * var(--min-fluid-ratio));
  }
}

.top-recommend-item_body {
  display: flex;
  flex-flow: column wrap;
  gap: 8px;
  line-height: 1.5;
}
@media screen and (width > 1600px) {
  .top-recommend-item_body {
    gap: calc(8 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-recommend-item_body {
    gap: calc(12 * var(--min-fluid-ratio));
  }
}

.top-recommend-item-name {
  display: flex;
  flex-flow: column wrap;
  gap: 4px;
}
@media screen and (width > 1600px) {
  .top-recommend-item-name {
    gap: calc(4 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-recommend-item-name {
    gap: calc(6 * var(--min-fluid-ratio));
  }
}

.top-recommend-item_url {
  font-size: var(--font-small);
  text-decoration-line: underline;
}

/* ============================
 .top-shopping-banner
============================ */
.top-shopping-banner {
  overflow: hidden;
  border-radius: 35px;
}
@media screen and (width > 1600px) {
  .top-shopping-banner {
    border-radius: calc(35 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-shopping-banner {
    border-radius: calc(40 * var(--min-fluid-ratio));
  }
}

a.top-shopping-banner_link {
  display: grid;
  grid-template-columns: 1fr 1fr;
  aspect-ratio: 100/18;
  text-decoration: none;
  background: var(--color-white);
}
a.top-shopping-banner_link:hover .top-shopping-banner_icon::before, a.top-shopping-banner_link:active .top-shopping-banner_icon::before {
  animation: arrow-right-animation 0.6s ease;
}
a.top-shopping-banner_link:hover .top-shopping-banner_icon::after, a.top-shopping-banner_link:active .top-shopping-banner_icon::after {
  transform: scale(1.1);
}
a.top-shopping-banner_link:hover .top-shopping-banner_img, a.top-shopping-banner_link:active .top-shopping-banner_img {
  transform: scale(1.04);
}
@media screen and (width <= 770px) {
  a.top-shopping-banner_link {
    grid-template-columns: 40% auto;
    aspect-ratio: 100/25;
  }
}
@media screen and (width <= 576px) {
  a.top-shopping-banner_link {
    grid-template-columns: 34% auto;
    aspect-ratio: 100/32;
  }
}

.top-shopping-banner_image-block {
  position: relative;
  block-size: 100%;
  overflow: hidden;
}

.top-shopping-banner_img {
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.3s var(--ease-out-back) 0s;
}

.top-shopping-banner_text-block {
  display: flex;
  flex-flow: row nowrap;
  align-items: center;
  justify-content: space-between;
  padding: 20px clamp(20px, 3vw, 36px);
}
@media screen and (width > 1600px) {
  .top-shopping-banner_text-block {
    padding: calc(10 * var(--max-fluid-ratio)) calc(36 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-shopping-banner_text-block {
    padding: calc(10 * var(--min-fluid-ratio)) calc(34 * var(--min-fluid-ratio));
  }
}

.top-shopping-banner_text {
  font-size: clamp(18px, 2vw, 25px);
  line-height: 1.8;
  letter-spacing: 0.1em;
}
@media screen and (width > 1600px) {
  .top-shopping-banner_text {
    font-size: calc(25 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-shopping-banner_text {
    font-size: calc(26 * var(--min-fluid-ratio));
  }
}

.top-shopping-banner_icon {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: clamp(30px, 5vw, 52px);
  block-size: clamp(30px, 5vw, 52px);
  font-size: var(--font-medium);
  color: var(--color-white);
}
.top-shopping-banner_icon::before {
  position: relative;
  z-index: 1;
}
.top-shopping-banner_icon::after {
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
  inline-size: 100%;
  block-size: 100%;
  content: "";
  background: var(--color-contessa);
  border-radius: 100%;
  transition: transform 0.3s var(--ease-out-back) 0s;
}
@media screen and (width > 1600px) {
  .top-shopping-banner_icon {
    inline-size: calc(52 * var(--max-fluid-ratio));
    block-size: calc(52 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-shopping-banner_icon {
    inline-size: calc(54 * var(--min-fluid-ratio));
    block-size: calc(54 * var(--min-fluid-ratio));
    font-size: calc(26 * var(--min-fluid-ratio));
  }
}

@keyframes arrow-right-animation {
  0% {
    transform: translateX(0);
  }
  50% {
    opacity: 0;
    transform: translateX(10px);
  }
  50.1% {
    opacity: 0;
    transform: translateX(-10px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
/* ============================
 .top-shopping-annotation
============================ */
.top-shopping-annotation {
  max-inline-size: fit-content;
  margin-block-start: 60px;
  margin-inline: auto;
}
@media screen and (width > 1600px) {
  .top-shopping-annotation {
    margin-block-start: calc(60 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-shopping-annotation {
    margin-block-start: calc(40 * var(--min-fluid-ratio));
  }
}

.top-shopping-annotation-list {
  display: flex;
  flex-flow: column wrap;
  gap: 0.4em;
}

.top-shopping-annotation-item {
  padding-inline-start: 1em;
  font-size: var(--font-small);
  line-height: 1.8;
  text-indent: -1em;
}
.top-shopping-annotation-item::before {
  content: "・";
}

/* ============================
 .top-howtoeat
============================ */
.top-howtoeat_body {
  position: relative;
  max-inline-size: 860px;
  margin-block-start: 80px;
  margin-inline: auto;
}
@media screen and (width > 1600px) {
  .top-howtoeat_body {
    max-inline-size: calc(860 * var(--max-fluid-ratio));
    margin-block-start: calc(80 * var(--max-fluid-ratio));
  }
}
@media screen and (770px <= width <= 1080px) {
  .top-howtoeat_body {
    max-inline-size: 88%;
  }
}
@media screen and (width <= 576px) {
  .top-howtoeat_body {
    margin-block-start: calc(70 * var(--min-fluid-ratio));
  }
}

.top-howtoeat_text {
  font-size: var(--font-medium);
  letter-spacing: 0.1em;
}

.top-howtoeat-salsiccia-kun {
  position: absolute;
  inset-block-start: -70px;
  inset-inline-end: 6%;
  z-index: 1;
  inline-size: 161px;
  pointer-events: none;
  user-select: none;
}
@media screen and (width > 1600px) {
  .top-howtoeat-salsiccia-kun {
    inset-block-start: calc(-70 * var(--max-fluid-ratio));
    inline-size: calc(161 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 940px) {
  .top-howtoeat-salsiccia-kun {
    inset-block-start: -120px;
    inset-inline-end: 0;
  }
}
@media screen and (width <= 576px) {
  .top-howtoeat-salsiccia-kun {
    inset-block-start: calc(-160 * var(--min-fluid-ratio));
    inline-size: calc(212 * var(--min-fluid-ratio));
  }
}

.top-howtoeat-salsiccia-kun_img {
  inline-size: 100%;
  block-size: auto;
}

.top-howtoeat-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 60px 8%;
  margin-block-start: 40px;
}
@media screen and (width > 1600px) {
  .top-howtoeat-list {
    column-gap: calc(60 * var(--max-fluid-ratio));
    margin-block-start: calc(40 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 940px) {
  .top-howtoeat-list {
    grid-template-columns: repeat(2, 1fr);
    column-gap: 8vw;
  }
}
@media screen and (width <= 576px) {
  .top-howtoeat-list {
    gap: calc(80 * var(--min-fluid-ratio)) 6vw;
    margin-block-start: calc(60 * var(--min-fluid-ratio));
  }
}

a.top-howtoeat-item_link {
  display: flex;
  flex-flow: column wrap;
  gap: 14px;
  text-decoration: none;
}
a.top-howtoeat-item_link:hover .top-howtoeat-item-picture_img, a.top-howtoeat-item_link:active .top-howtoeat-item-picture_img {
  transform: scale(1.04);
}
@media screen and (width > 1600px) {
  a.top-howtoeat-item_link {
    gap: calc(14 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  a.top-howtoeat-item_link {
    gap: calc(20 * var(--min-fluid-ratio));
  }
}

.top-howtoeat-item-picture {
  display: block;
  inline-size: 100%;
  aspect-ratio: 28/15;
  overflow: hidden;
  border-radius: 30px;
}
@media screen and (width > 1600px) {
  .top-howtoeat-item-picture {
    border-radius: calc(30 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-howtoeat-item-picture {
    aspect-ratio: 28/20;
    border-radius: calc(45 * var(--min-fluid-ratio));
  }
}

.top-howtoeat-item-picture_img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.3s var(--ease-out-back) 0s;
}

.top-howtoeat-item_text {
  line-height: 1.5;
  letter-spacing: 0.1em;
}

/* ============================
 .top-shop-information
============================ */
.top-shop-information-carousel {
  position: relative;
  inline-size: 135%;
  margin-block-start: 40px;
  margin-inline-start: -32%;
  opacity: 0;
  transform: scale(0.9);
  transition: transform 1s cubic-bezier(0.175, 0.885, 0.32, 1) 0.3s, opacity 0.5s ease-out 0.2s;
}
.top-shop-information-carousel[data-animate=active] {
  opacity: 1;
  transform: scale(1);
}
@media screen and (width > 1600px) {
  .top-shop-information-carousel {
    margin-block-start: calc(40 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 1080px) {
  .top-shop-information-carousel {
    inline-size: 126%;
    margin-inline-start: -14%;
  }
}
@media screen and (width <= 770px) {
  .top-shop-information-carousel {
    inline-size: 166%;
    margin-block-start: calc(60 * var(--min-fluid-ratio));
    margin-inline-start: -33%;
  }
}

.top-shop-information-carousel-item {
  font-size: 0;
  line-height: 0;
  vertical-align: top;
}

.top-shop-information-carousel-item-picture {
  display: block;
  aspect-ratio: 1428/625;
}

.top-shop-information-carousel-item-picture_img {
  inline-size: 100%;
  block-size: 100%;
  vertical-align: top;
  object-fit: cover;
  mask-image: url("../images/top/kv-shop-information-mask.svg");
  mask-repeat: no-repeat;
  mask-position: 50% 50%;
  mask-size: 90%;
  transition: mask-size 1s cubic-bezier(0.175, 0.885, 0.32, 1) 0.3s;
}
[data-animate=active] .top-shop-information-carousel-item-picture_img {
  mask-size: 100%;
}

.top-shop-information_body {
  display: flex;
  flex-flow: column wrap;
  gap: 60px;
  max-inline-size: 698px;
  margin-block-start: 74px;
  margin-inline: auto;
}
@media screen and (width > 1600px) {
  .top-shop-information_body {
    gap: calc(60 * var(--max-fluid-ratio));
    max-inline-size: calc(698 * var(--max-fluid-ratio));
    margin-block-start: calc(74 * var(--max-fluid-ratio));
  }
}
@media screen and (770px <= width <= 1080px) {
  .top-shop-information_body {
    max-inline-size: 88%;
  }
}
@media screen and (width <= 576px) {
  .top-shop-information_body {
    gap: calc(80 * var(--min-fluid-ratio));
    margin-block-start: calc(80 * var(--min-fluid-ratio));
  }
}

.top-shop-information_message {
  font-size: var(--font-medium);
  line-height: 2;
  letter-spacing: 0.1em;
}
.top-shop-information_message p + p {
  margin-block-start: 2em;
}

.top-shop-information-content {
  display: flex;
  flex-flow: column wrap;
  gap: 22px;
}
@media screen and (width > 1600px) {
  .top-shop-information-content {
    gap: calc(22 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-shop-information-content {
    gap: calc(30 * var(--min-fluid-ratio));
  }
}

.top-shop-information-content_title {
  font-size: var(--font-large);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.1em;
}

.top-shop-information-content_body {
  position: relative;
}
.top-shop-information-content_body a {
  text-decoration-line: underline;
}

/*
  .top-shop-information-salsiccia-kun
============================ */
.top-shop-information-salsiccia-kun {
  position: absolute;
  inset-block-start: 0;
  inset-inline-end: 100px;
  z-index: 1;
  inline-size: 67px;
  pointer-events: none;
  user-select: none;
}
@media screen and (width > 1600px) {
  .top-shop-information-salsiccia-kun {
    inset-inline-end: calc(100 * var(--max-fluid-ratio));
    inline-size: calc(67 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 940px) {
  .top-shop-information-salsiccia-kun {
    inset-inline-end: -20px;
  }
}
@media screen and (width <= 770px) {
  .top-shop-information-salsiccia-kun {
    inset-block-start: -150px;
    inset-inline-end: 50px;
  }
}
@media screen and (width <= 576px) {
  .top-shop-information-salsiccia-kun {
    inset-block-start: calc(-200 * var(--min-fluid-ratio));
    inset-inline-end: calc(80 * var(--min-fluid-ratio));
    inline-size: calc(100 * var(--min-fluid-ratio));
  }
}

.top-shop-information-salsiccia-kun_img {
  inline-size: 100%;
  block-size: auto;
}

/*
 .top-business-hours
============================ */
.top-business-hours {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px 30px;
}
@media screen and (width > 1600px) {
  .top-business-hours {
    gap: calc(40 * var(--max-fluid-ratio)) calc(30 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 770px) {
  .top-business-hours {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (width <= 576px) {
  .top-business-hours {
    gap: calc(60 * var(--min-fluid-ratio)) calc(50 * var(--min-fluid-ratio));
  }
}

.top-business-hours-section_label {
  inline-size: fit-content;
  padding: 6px 12px 7px;
  font-size: var(--font-small);
  font-weight: 700;
  line-height: 1.02;
  color: var(--color-white);
  letter-spacing: 0.1em;
  background: var(--base-text-color);
  border-radius: 100vmax;
}
@media screen and (width > 1600px) {
  .top-business-hours-section_label {
    padding: calc(6 * var(--max-fluid-ratio)) calc(12 * var(--max-fluid-ratio)) calc(7 * var(--max-fluid-ratio));
  }
}

.top-business-hours-section-title {
  display: flex;
  flex-flow: column wrap;
  margin-block-start: 5px;
  line-height: 1.5;
}
@media screen and (width > 1600px) {
  .top-business-hours-section-title {
    margin-block-start: calc(5 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-business-hours-section-title {
    margin-block-start: calc(10 * var(--min-fluid-ratio));
  }
}

.top-business-hours-section-title_en {
  letter-spacing: 0.13em;
}

.top-business-hours-table {
  margin-block-start: 12px;
}
@media screen and (width > 1600px) {
  .top-business-hours-table {
    margin-block-start: calc(12 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-business-hours-table {
    margin-block-start: calc(18 * var(--min-fluid-ratio));
  }
}

.top-business-hours-row {
  display: flex;
  flex-flow: row nowrap;
  gap: 1em;
  white-space: nowrap;
}

a.top-shop-information-content_link {
  text-decoration-line: underline;
}
a.top-shop-information-content_link .icon-pin {
  margin-inline-start: 0.2em;
}

.top-shop-information-map {
  position: relative;
  display: block;
  block-size: 450px;
  inline-size: 100%;
  margin-block-start: 20px;
  overflow: hidden;
  border-radius: 30px;
}
.top-shop-information-map iframe {
  position: absolute;
  inset: 0;
  inline-size: 100%;
  block-size: 100%;
  filter: grayscale(86%);
}
@media screen and (width > 1600px) {
  .top-shop-information-map {
    margin-block-start: calc(20 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 770px) {
  .top-shop-information-map {
    /* 親の高さに依存しない固定高さ（vw 基準で正方形に近い値） */
    block-size: 80vmin;
  }
}
@media screen and (width > 576px) {
  .top-shop-information-map {
    inline-size: 100%;
  }
}
@media screen and (width <= 576px) {
  .top-shop-information-map {
    inline-size: auto;
    margin-block-start: calc(50 * var(--min-fluid-ratio));
    margin-inline: calc(var(--side-spacing) * -1);
    border-radius: 0;
  }
}

/* ============================
 .top-faq
============================ */
.top-faq {
  position: relative;
}

/*
  .top-faq-salsiccia-kun
============================ */
.top-faq-salsiccia-kun {
  position: absolute;
  inset-block-start: -36px;
  inset-inline-end: 50px;
  z-index: 1;
  inline-size: 113px;
  pointer-events: none;
  user-select: none;
}
@media screen and (width > 1600px) {
  .top-faq-salsiccia-kun {
    inset-block-start: calc(-36 * var(--max-fluid-ratio));
    inset-inline-end: calc(50 * var(--max-fluid-ratio));
    inline-size: calc(113 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 940px) {
  .top-faq-salsiccia-kun {
    inset-inline-end: 14px;
  }
}
@media screen and (width <= 770px) {
  .top-faq-salsiccia-kun {
    inset-block-start: -16px;
    inset-inline-end: 28px;
  }
}
@media screen and (width <= 576px) {
  .top-faq-salsiccia-kun {
    inset-block-start: calc(20 * var(--min-fluid-ratio) * -1);
    inset-inline-end: calc(10 * var(--min-fluid-ratio));
    inline-size: calc(146 * var(--min-fluid-ratio));
  }
}

.top-faq-salsiccia-kun_img {
  inline-size: 100%;
  block-size: auto;
}

.top-faq_body {
  max-inline-size: 698px;
  margin-block-start: 60px;
  margin-inline: auto;
}
@media screen and (width > 1600px) {
  .top-faq_body {
    max-inline-size: calc(698 * var(--max-fluid-ratio));
    margin-block-start: calc(60 * var(--max-fluid-ratio));
  }
}
@media screen and (770px <= width <= 1080px) {
  .top-faq_body {
    max-inline-size: 88%;
  }
}
@media screen and (width > 770px) {
  .top-faq_body {
    position: relative;
  }
}
@media screen and (width <= 576px) {
  .top-faq_body {
    margin-block-start: calc(60 * var(--min-fluid-ratio));
  }
}

.top-faq_text {
  font-size: var(--font-medium);
  line-height: 2;
}

.top-faq-content {
  margin-block-start: 30px;
}
@media screen and (width > 1600px) {
  .top-faq-content {
    margin-block-start: calc(30 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-faq-content {
    margin-block-start: calc(80 * var(--min-fluid-ratio));
  }
}

.top-faq-group {
  display: flex;
  flex-flow: column wrap;
  gap: 24px;
  padding: 40px;
  background: rgba(255, 255, 255, 0.5);
  border: 4px solid var(--base-text-color);
  border-radius: 30px;
}
.top-faq-group + .top-faq-group {
  margin-block-start: 60px;
}
@media screen and (width > 1600px) {
  .top-faq-group {
    gap: calc(24 * var(--max-fluid-ratio));
    padding: calc(40 * var(--max-fluid-ratio));
    border-radius: calc(30 * var(--max-fluid-ratio));
  }
  .top-faq-group + .top-faq-group {
    margin-block-start: calc(60 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-faq-group {
    gap: calc(36 * var(--min-fluid-ratio));
    padding: calc(56 * var(--min-fluid-ratio)) calc(50 * var(--min-fluid-ratio));
    border-radius: calc(46 * var(--min-fluid-ratio));
  }
  .top-faq-group + .top-faq-group {
    margin-block-start: calc(80 * var(--min-fluid-ratio));
  }
}

.top-faq-group_title {
  font-size: var(--font-large);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.15em;
}

.top-faq-list {
  display: flex;
  flex-flow: column wrap;
  gap: 20px;
}
@media screen and (width > 1600px) {
  .top-faq-list {
    gap: calc(20 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-faq-list {
    gap: calc(30 * var(--min-fluid-ratio));
  }
}

.top-faq-item_q {
  position: relative;
  inline-size: 100%;
  padding-inline: 1.8em 2em;
  font-weight: 700;
  cursor: pointer;
}
.top-faq-item_q::before {
  position: absolute;
  inset-inline-start: 0;
  flex-shrink: 0;
  padding-inline-end: 0;
  content: "Q.";
}

.top-faq-item_q_text {
  text-decoration-thickness: 1px;
  text-underline-offset: 0.5em;
}

.top-faq-item_q_icon {
  position: absolute;
  inset-block-start: 0.4em;
  inset-inline-end: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  inline-size: 18px;
  block-size: 18px;
  line-height: 1;
  letter-spacing: 0;
  background-color: var(--base-text-color);
  border-radius: 100%;
  transition: transform 0.1s ease 0s;
}
.top-faq-item_q_icon::before, .top-faq-item_q_icon::after {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  inline-size: 5px;
  block-size: 2px;
  content: "";
  background-color: var(--color-white);
  transition: transform 0.2s ease 0s, inline-size 0.2s ease 0s;
}
.top-faq-item_q_icon::before {
  transform: translate(-80%, -50%) rotate(45deg);
}
.top-faq-item_q_icon::after {
  transform: translate(-20%, -50%) rotate(-45deg);
}
.is-active .top-faq-item_q_icon::before {
  inline-size: 9px;
  transform: translate(-50%, -50%) rotate(-45deg);
}
.is-active .top-faq-item_q_icon::after {
  inline-size: 9px;
  transform: translate(-50%, -50%) rotate(45deg);
}
@media screen and (width > 1600px) {
  .top-faq-item_q_icon {
    inline-size: calc(18 * var(--max-fluid-ratio));
    block-size: calc(18 * var(--max-fluid-ratio));
  }
  .top-faq-item_q_icon::before, .top-faq-item_q_icon::after {
    inline-size: calc(5 * var(--max-fluid-ratio));
  }
  .is-active .top-faq-item_q_icon::before {
    inline-size: calc(9 * var(--max-fluid-ratio));
  }
  .is-active .top-faq-item_q_icon::after {
    inline-size: calc(9 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .top-faq-item_q_icon {
    inline-size: calc(30 * var(--min-fluid-ratio));
    block-size: calc(30 * var(--min-fluid-ratio));
  }
  .top-faq-item_q_icon::before, .top-faq-item_q_icon::after {
    inline-size: calc(9 * var(--min-fluid-ratio));
    block-size: calc(3 * var(--min-fluid-ratio));
  }
  .is-active .top-faq-item_q_icon::before {
    inline-size: calc(15 * var(--min-fluid-ratio));
  }
  .is-active .top-faq-item_q_icon::after {
    inline-size: calc(15 * var(--min-fluid-ratio));
  }
}

.top-faq-item_a {
  height: 0;
  padding-inline: 1.8em 2em;
  overflow: hidden;
  transition: height 0.3s ease 0s, padding-block-start 0.3s ease 0s;
}
.top-faq-item_a *:first-child {
  padding-block-start: 0.8em;
}
.top-faq-item_a a {
  word-break: break-all;
  text-decoration-line: underline;
}
.top-faq-item_a p + p {
  margin-block-start: 1em;
}
@media screen and (width <= 576px) {
  .top-faq-item_a {
    padding-inline: 0;
  }
}

/* ==========================================================================
   contact.scss
   ========================================================================== */
.contact-content_head + .contact-content_body {
  margin-block-start: 100px;
}
@media screen and (width > 1600px) {
  .contact-content_head + .contact-content_body {
    margin-block-start: calc(100 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .contact-content_head + .contact-content_body {
    margin-block-start: calc(80 * var(--min-fluid-ratio));
  }
}

.contact-note {
  margin-block-end: 4em;
}

/* ============================
.form-inquiry
============================ */
.form-inquiry p:empty {
  display: none;
}
.form-inquiry .wpcf7-checkbox .wpcf7-list-item input[type=checkbox] {
  all: unset;
}
.form-inquiry .wpcf7-checkbox .wpcf7-list-item label {
  gap: 0 0.3em;
}
.form-inquiry .wpcf7-not-valid-tip,
.form-inquiry .wpcf7-validation-errors,
.form-inquiry .wpcf7-mail-sent-ng,
.form-inquiry .wpcf7-mail-sent-ok {
  margin-block-start: 0.5em;
}

.form-inquiry-list {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 65px;
}
@media screen and (width > 1600px) {
  .form-inquiry-list {
    gap: calc(65 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 770px) {
  .form-inquiry-list {
    gap: 40px;
  }
}
@media screen and (width <= 576px) {
  .form-inquiry-list {
    gap: calc(65 * var(--min-fluid-ratio));
  }
}

.form-inquiry-item {
  display: grid;
  grid-template: "head body" auto/200px 1fr;
  gap: 16px;
  inline-size: 100%;
}
@media screen and (width > 1600px) {
  .form-inquiry-item {
    grid-template: "head body" auto/calc(200 * var(--max-fluid-ratio)) 1fr;
    gap: calc(16 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 770px) {
  .form-inquiry-item {
    grid-template: "head" "body" auto/1fr;
    gap: 1em;
  }
}
@media screen and (width <= 576px) {
  .form-inquiry-item {
    gap: calc(15 * var(--min-fluid-ratio));
  }
}

.form-inquiry-item_head {
  grid-area: head;
}
.form-inquiry._input .form-inquiry-item:not(:first-child) .form-inquiry-item_head {
  padding-block-start: 0.6em;
}

.form-inquiry-item_body {
  grid-area: body;
}

.form-input-label {
  display: block;
}
.form-inquiry._confirm .form-input-label::before {
  content: "- ";
}
@media screen and (width <= 576px) {
  .form-input-label {
    margin-block-end: calc(20 * var(--min-fluid-ratio));
  }
}

.form-input-radio-list {
  display: flex;
  flex-flow: column wrap;
  gap: 0.6em 1.5em;
}
.form-input-radio-list label:has(input[type=radio]) {
  display: inline-flex;
  gap: 0 0.5em;
  align-items: center;
}
.form-input-radio-list input[type=radio] {
  position: relative;
  inline-size: 20px;
  block-size: 20px;
  line-height: 1.02;
  appearance: none;
  outline: none;
  background-size: 0 0;
  border: 1px solid var(--color-contessa);
  border-radius: 100vmax;
  transition: box-shadow 0.2s ease-out 0s;
}
.form-input-radio-list input[type=radio]::before {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  inline-size: 12px;
  block-size: 12px;
  content: "";
  background-color: var(--color-contessa);
  border-radius: 100vmax;
  opacity: 0;
  transform: translate(-50%, -50%);
  transition: opacity 0.15s ease 0s;
}
.form-input-radio-list input[type=radio]:checked::before {
  opacity: 1;
}
.form-input-radio-list input[type=radio]:focus {
  box-shadow: 0 0 0 0.2em rgba(114, 147, 175, 0.22);
}
@media screen and (width > 1600px) {
  .form-input-radio-list input[type=radio] {
    inline-size: calc(20 * var(--max-fluid-ratio));
    block-size: calc(20 * var(--max-fluid-ratio));
  }
  .form-input-radio-list input[type=radio]::before {
    inline-size: calc(12 * var(--max-fluid-ratio));
    block-size: calc(12 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .form-input-radio-list input[type=radio] {
    inline-size: calc(32 * var(--min-fluid-ratio));
    block-size: calc(32 * var(--min-fluid-ratio));
  }
  .form-input-radio-list input[type=radio]::before {
    inline-size: calc(22 * var(--min-fluid-ratio));
    block-size: calc(22 * var(--min-fluid-ratio));
  }
}

.form-input-item_annotation {
  padding-inline-start: 1em;
  margin-block-start: 1em;
  line-height: 1.8;
  text-indent: -1em;
}

.wpcf7-turnstile {
  inline-size: fit-content;
  margin: 50px auto 0;
}
@media screen and (width > 1600px) {
  .wpcf7-turnstile {
    margin-block-start: calc(50 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .wpcf7-turnstile {
    margin-block-start: calc(50 * var(--min-fluid-ratio));
  }
}

.form-button-list {
  display: flex;
  flex-flow: row wrap;
  gap: 2em;
  align-items: center;
  justify-content: center;
  inline-size: 100%;
  margin-block-start: 50px;
}
.form-button-list .wpcf7-spinner {
  display: none;
}
.form-button-list p {
  display: contents;
}
@media screen and (width > 1600px) {
  .form-button-list {
    margin-block-start: calc(50 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .form-button-list {
    gap: 1em;
    margin-block-start: calc(50 * var(--min-fluid-ratio));
  }
}

.form-button {
  position: relative;
  z-index: 2;
  display: block;
  inline-size: 100%;
  max-inline-size: 240px;
  padding: 22px 0;
  font-weight: 700;
  line-height: 1.5;
  color: var(--color-white);
  text-align: center;
  letter-spacing: 0.1em;
  text-decoration: none;
  appearance: none;
  cursor: pointer;
  outline: none;
  background: none;
  border: none;
  border-radius: 100vmax;
  transition: box-shadow 0.2s ease-out 0s, filter 0.2s ease-out 0s;
}
.form-button::before {
  position: absolute;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  z-index: -1;
  inline-size: 100%;
  block-size: 100%;
  content: "";
  background: var(--color-contessa);
  border-radius: 100vmax;
  transform: translate(-50%, -50%);
  transition: inline-size 0.3s var(--ease-bounce) 0s, block-size 0.3s var(--ease-bounce) 0s;
}
.form-button._back-button::before {
  background: var(--color-tapa);
}
.form-button:focus {
  box-shadow: 0 0 0 0.2em rgba(114, 147, 175, 0.22);
  filter: brightness(1.15);
}
.form-button[disabled] {
  cursor: not-allowed;
}
.form-button[disabled]::before {
  background: #adadad;
}
.form-button:not([disabled]):hover::before, .form-button:not([disabled]):active::before {
  inline-size: calc(100% + 5px);
  block-size: calc(100% + 5px);
}
@media screen and (width > 1600px) {
  .form-button {
    padding: calc(22 * var(--max-fluid-ratio)) 0;
  }
}
@media screen and (width <= 576px) {
  .form-button {
    max-inline-size: calc(285 * var(--min-fluid-ratio));
    padding: calc(30 * var(--min-fluid-ratio)) 0;
  }
}

.wpcf7-form .wpcf7-response-output {
  padding: 0 !important;
  margin: 4em auto 0 !important;
  color: var(--color-contessa) !important;
  text-align: center !important;
  background-color: none;
  border: none !important;
}

/* ============================
確認ページ
============================ */
.form-confirm-message {
  font-size: 16px;
  font-weight: 500;
}
@media screen and (width > 1600px) {
  .form-confirm-message {
    font-size: calc(16 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .form-confirm-message {
    font-size: calc(16 * var(--min-fluid-ratio));
  }
}

/* ============================
完了ページ
============================ */
.form-completed-text {
  font-size: 16px;
  font-weight: 500;
}
@media screen and (width > 1600px) {
  .form-completed-text {
    font-size: calc(16 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .form-completed-text {
    font-size: calc(16 * var(--min-fluid-ratio));
  }
}

.form-completed-button {
  margin-block-start: 50px;
  font-family: var(--font-family-en);
  font-size: 18px;
  font-weight: 600;
  line-height: 1.02;
  letter-spacing: 0.05em;
}
@media screen and (width > 1600px) {
  .form-completed-button {
    margin-block-start: calc(50 * var(--max-fluid-ratio));
    font-size: calc(18 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .form-completed-button {
    margin-block-start: calc(50 * var(--min-fluid-ratio));
    font-size: calc(18 * var(--min-fluid-ratio));
  }
}

a.form-completed-button_link {
  display: block;
  text-decoration: none;
  transition: opacity 0.3s ease-out;
}
@media (any-hover: hover) {
  a.form-completed-button_link:hover, a.form-completed-button_link:active {
    opacity: 0.8;
  }
}

/* ==========================================================================
   privacy-policy.scss
   ========================================================================== */
/* ============================
 privacy-policy
============================ */
@media screen and (width > 770px) {
  .privacy-policy-content_body {
    grid-column: 6/18;
  }
}
@media screen and (width > 576px) and (width <= 770px) {
  .privacy-policy-content_body {
    grid-column: 4/19;
  }
}

/* ==========================================================================
   404.scss
   ========================================================================== */
@media screen and (width <= 576px) {
  .p404-text {
    margin-block-start: calc(80 * var(--min-fluid-ratio));
  }
}

.p404-home {
  margin-block-start: 40px;
}
@media screen and (width > 1600px) {
  .p404-home {
    margin-block-start: calc(40 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .p404-home {
    margin-block-start: calc(60 * var(--min-fluid-ratio));
  }
}

.p404-salsiccia-kun {
  inline-size: 67px;
  margin-block-start: 40px;
  margin-inline-start: 120px;
}
@media screen and (width > 1600px) {
  .p404-salsiccia-kun {
    inline-size: calc(67 * var(--max-fluid-ratio));
    margin-block-start: calc(40 * var(--max-fluid-ratio));
    margin-inline-start: calc(120 * var(--max-fluid-ratio));
  }
}
@media screen and (width <= 576px) {
  .p404-salsiccia-kun {
    inline-size: calc(80 * var(--min-fluid-ratio));
    margin-block-start: calc(80 * var(--min-fluid-ratio));
    margin-inline-start: calc(240 * var(--min-fluid-ratio));
  }
}

.p404-salsiccia-kun_img {
  inline-size: 100%;
  block-size: auto;
}
