@charset "UTF-8";
:root {
  --rem: 1rem / 16;
  --em: 1em / 16;
  --vw: 1440 * 100vw;
  --inner-percent: 335 * 100%;
}

:root {
  --inner-value: 1100;
  --inner: 1100px;
  --padding-pc: max(20px, 20/var(--vw));
  --padding-sp: 16px;
}

:root {
  --base-font: "Shippori Mincho B1", serif;
  --gothic-font: "IBM Plex Sans JP", "Noto Sans JP", sans-serif;
  --en-font: "Cinzel", serif;
  --en-sub-font: "Cormorant", serif;
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  --fw-extrabold: 800;
  --fw-black: 900;
}

:root {
  --white: #fff;
  --black: #150102;
  --off-white: #fffcf5;
  --red-dark: #580003;
  --red: #8b0005;
  --red-deepest: #0f0000;
  --gold: #d9ba60;
  --gold-medium: #c59d48;
  --gold-dark: #976e00;
  --gold-brown: #bb842a;
  --gold-yellow: #c99300;
  --cream: #fff4dd;
  --cream-light: #fff2d8;
  --cream-gold: #ffebc1;
  --cream-pale: #ffe9bc;
  --navy: #002e7d;
  --navy-dark: #071e47;
  --blue: #0046bf;
  --wine: #7f1142;
  --wine-dark: #460924;
  --magenta: #c81263;
  --brown: #654101;
  --brown-dark: #503500;
  --brown-gold: #59330f;
  --brown-orange: #965803;
  --gray: #525252;
  --gray-mauve: #ae9080;
}

:root {
  --z-index-loader: 200;
  --z-index-header: 100;
  --z-index-fixed-cta: 90;
}

:root {
  --scrollbar-width: 0;
}

@property --scrollbar {
  syntax: "<length>";
  initial-value: 0;
  inherits: true;
}
body {
  color: var(--white);
  font-family: var(--base-font);
  font-weight: var(--fw-medium);
}

body::before {
  background-image: url(../images/common/bg02.avif);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  content: "";
  height: 100%;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: -1;
}

a {
  color: inherit;
  text-decoration: none;
  transition: opacity 0.3s;
}

html {
  font-size: 16px;
}

main {
  overflow-x: clip;
}

/*! kiso.css v1.2.2 | MIT License | https://github.com/tak-dcxi/kiso.css */
/* ======================================================
//  MARK: Universal
// ====================================================== */
*,
::before,
::after {
  /*
  * Includes `padding` and `border` in the element's specified dimensions.
  * It is highly recommended to set `box-sizing: border-box;` by default, as it makes styling much easier, especially when specifying `width: 100%;`.
  */
  box-sizing: border-box;
}

/* ======================================================
//  MARK: Document and Body Elements
// ====================================================== */
:where(:root) {
  /* In Safari, if `font-family` is not specified, a serif font is applied by default, so `sans-serif` is set as the default here. */
  font-family: sans-serif;
  /*
  * For accessibility, it is recommended to set the `line-height` to at least 1.5 times the text size within paragraphs.
  * @see https://waic.jp/translations/WCAG21/#visual-presentation
  */
  line-height: 1.5;
  /* Remove space when punctuation marks are adjacent, and also remove leading spaces in a line. */
  text-spacing-trim: trim-start;
  /* Prevents misreading by applying strict line-breaking rules. */
  line-break: strict;
  /* Wraps English words mid-word. Specifying `anywhere` also prevents content from overflowing in layouts like `flex` or `grid`. */
  overflow-wrap: anywhere;
  /* Improves readability by inserting a small space between Japanese and alphanumeric characters. */
  text-autospace: normal;
  /*
  * Mobile browsers have an algorithm that automatically adjusts font sizes to prevent text from becoming too small.
  * This controls the auto-adjustment feature to prevent unwanted resizing.
  */
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
       text-size-adjust: 100%;
  /* Prevents layout shift caused by the appearance or disappearance of the scrollbar. */
  scrollbar-gutter: stable;
  /* Suppresses the tap highlight on iOS. */
  -webkit-tap-highlight-color: transparent;
}

:where(body) {
  /* The `margin` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset here. */
  margin: unset;
  /*
  * When creating a sticky footer, a minimum height is often required.
  * Setting the `min-block-size` to the dynamic viewport height ensures enough space for the footer.
  */
  min-block-size: 100dvb;
}

/* ======================================================
// MARK: Sections
// ------------------------------------------------------ */
:where(h1, h2, h3, h4, h5, h6) {
  /* Prevents the last line of text from ending with a single word, which can look awkward (known as an orphan). */
  text-wrap: pretty;
}

:where(h1) {
  font-size: 2em;
  /*
  * Adjusts user agent (UA) styles for `h1` elements within sectioning content.
  * This addresses DevTools warnings that appear when `h1` elements nested within sectioning content lack `font-size` and `margin` properties.
  * @see https://html.spec.whatwg.org/#sections-and-headings
  */
  margin-block: 0;
}

:where(h2, h3, h4, h5, h6) {
  /* The `margin-block` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset. */
  margin-block: unset;
}

:where(search) {
  /*
  * The `<search>` element is supported from Safari 17.
  * This prevents it from being displayed as an inline element in unsupported environments.
  */
  display: block flow;
}

/* ======================================================
//  MARK: Grouping content
// ====================================================== */
:where(p, blockquote, figure, pre, address, ul, ol, dl, menu) {
  /* The `margin-block` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset. */
  margin-block: unset;
}

:where(blockquote, figure) {
  /* The `margin-inline` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset. */
  margin-inline: unset;
}

:where(p:lang(en)) {
  /*
  * In English, a single word on the last line is called a "widow" or "orphan" and is considered something to avoid as it makes the text harder to read.
  * Therefore, when lang="en", this prevents the last line from ending with a single word.
  */
  text-wrap: pretty;
}

:where(address:lang(ja)) {
  /* Italic style is not common in Japanese, so the `font-style` is reset. */
  font-style: unset;
}

:where(ul, ol, menu) {
  /*
  * In Safari, using `list-style: none` prevents screen readers from announcing lists.
  * `list-style-type: ""` is used to hide markers without affecting accessibility.
  * @see https://matuzo.at/blog/2023/removing-list-styles-without-affecting-semantics
  */
  list-style-type: "";
  /* The `padding-inline-start` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset. */
  padding-inline-start: unset;
}

:where(dt) {
  /* It is common to display `<dt>` elements in bold, so `font-weight: bolder;` is set by default. */
  font-weight: bolder;
}

:where(dd) {
  /* The `margin-inline-start` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset. */
  margin-inline-start: unset;
}

:where(pre) {
  /*
  * Since `text-spacing-trim` can affect spacing in `<pre>` elements even with its initial value, the final rendering may depend on the user's font settings.
  * To ensure consistent alignment, `space-all` is explicitly specified and inheritance is prevented.
  */
  text-spacing-trim: space-all;
  /* Set to `no-autospace` as it can cause misalignment with monospaced fonts. */
  text-autospace: no-autospace;
}

/* ======================================================
//  MARK: Text-level semantics
// ====================================================== */
:where(em:lang(ja)) {
  /* In Japanese, emphasis is commonly represented by bold text, so `font-weight: bolder;` is set by default. */
  font-weight: bolder;
}

:where(:is(i, cite, em, dfn, var):lang(ja)) {
  /* Italic style is not common in Japanese, so the `font-style` is reset. */
  font-style: unset;
}

:where(code, kbd, samp) {
  /*
  * Set a monospace font family referencing Tailwind.
  * @see https://tailwindcss.com/docs/font-family
  */
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  /* Font feature settings can have adverse effects on monospaced fonts, so their values are explicitly set to `initial` to prevent inheritance. */
  font-feature-settings: initial;
  /* Resets the `font-size` specified in the UA stylesheet to allow inheritance. */
  font-size: unset;
  /*
  * Disables font ligatures for programming fonts (like Fira Code)
  * to prevent character combinations like `=>` from being rendered as a single symbol (e.g., `⇒`).
  */
  font-variant-ligatures: none;
  font-variation-settings: initial;
}

:where(abbr[title]) {
  cursor: help;
  /*
  * The `<abbr>` element with the `title` attribute isn't helpful regarding accessibility because support is inconsistent, and it's only accessible to some users.
  * This rule shows a dotted underline on abbreviations in all browsers (there's a bug in Safari) and changes the cursor.
  * @see https://adrianroselli.com/2024/01/using-abbr-element-with-title-attribute.html
  */
  text-decoration-line: underline;
  text-decoration-style: dotted;
}

:where(time) {
  /* Set to `no-autospace` because date notations in typography do not include spaces. */
  text-autospace: no-autospace;
}
/* ======================================================
//  MARK: Links
// ====================================================== */
:where(a:-moz-any-link) {
  /* The default `color` from the UA stylesheet is rarely used as is, so it's reset to allow inheritance. */
  color: unset;
  /*
  * While link underlines can be useful, they are often obstructive.
  * They are disabled by default.
  * If needed, restore them using `text-decoration-line: revert;`.
  */
  text-decoration-line: unset;
  /* Set the underline thickness to the font's default thickness. */
  text-decoration-thickness: from-font;
}
:where(a:any-link) {
  /* The default `color` from the UA stylesheet is rarely used as is, so it's reset to allow inheritance. */
  color: unset;
  /*
  * While link underlines can be useful, they are often obstructive.
  * They are disabled by default.
  * If needed, restore them using `text-decoration-line: revert;`.
  */
  text-decoration-line: unset;
  /* Set the underline thickness to the font's default thickness. */
  text-decoration-thickness: from-font;
}

/* ======================================================
//  MARK: Embedded content
// ====================================================== */
:where(img, svg, picture, video, canvas, model, audio, iframe, embed, object) {
  /* Automatically adjust block size based on content. */
  block-size: auto;
  inline-size: 100%;
  /* Prevents overflow by setting the maximum width to `100%`. */
  max-inline-size: 100%;
  /* Prevents extra space from appearing at the bottom of the element. */
  vertical-align: bottom;
}

:where(iframe) {
  /* The `border` specified in the UA stylesheet is often unnecessary, so it is reset. */
  border: unset;
}

/* ======================================================
//  MARK: Tabular data
// ====================================================== */
:where(table) {
  /* Collapse borders for a more refined table design. */
  border-collapse: collapse;
}

:where(caption, th) {
  /* The `text-align` specified in the UA stylesheet is often unnecessary, so it is reset. */
  text-align: unset;
}

:where(caption) {
  /* Prevents the last line of text from ending with a single word, which can look awkward (known as an orphan). */
  text-wrap: pretty;
}

/* ======================================================
//  MARK: Forms
// ====================================================== */
:where(button, input, select, textarea),
::file-selector-button {
  /* These styles specified in the UA stylesheet are often unnecessary, so they are reset to allow for inheritance. */
  border-color: unset;
  border-radius: unset;
  border-style: solid;
  /*
  * These elements are often styled with a border, so a `1px` border is applied by default for consistency.
  * This ensures readability even for unstyled elements.
  * When resetting, it's recommended to use `border-color: transparent` instead of `border: none` to account for forced color modes.
  */
  border-width: 1px;
  color: unset;
  font: unset;
  letter-spacing: unset;
  text-align: unset;
}

:where(input:is([type=radio i], [type=checkbox i])) {
  /* The `margin` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset here. */
  margin: unset;
}

:where(input[type=file i]) {
  /* The `border` is often unnecessary, so it is reset here. */
  border: unset;
}

:where(input[type=search i]) {
  /* Remove the rounded corners of search inputs on macOS and normalize the background color. */
  -webkit-appearance: textfield;
}

@supports (-webkit-touch-callout: none) {
  :where(input[type=search i]) {
    /* normalize the background color on iOS. */
    background-color: Canvas;
  }
}
:where(input:is([type=tel i],
[type=url i],
[type=email i],
[type=number i]):not(:-moz-placeholder)) {
  /*
  * Certain input types need to maintain left alignment even in right-to-left (RTL) languages.
  * However, this only applies when the value is not empty, as the placeholder should be right-aligned.
  * @see https://rtlstyling.com/posts/rtl-styling#form-inputs
  */
  direction: ltr;
}
:where(input:is([type=tel i],
[type=url i],
[type=email i],
[type=number i]):not(:placeholder-shown)) {
  /*
  * Certain input types need to maintain left alignment even in right-to-left (RTL) languages.
  * However, this only applies when the value is not empty, as the placeholder should be right-aligned.
  * @see https://rtlstyling.com/posts/rtl-styling#form-inputs
  */
  direction: ltr;
}

:where(textarea) {
  /* The `margin-block` specified in Firefox's UA stylesheet is often unnecessary, so it is reset. */
  margin-block: unset;
  /* Allows vertical resizing for `<textarea>` elements. */
  resize: block;
}

:where(input:not([type=button i], [type=submit i], [type=reset i]),
textarea,
[contenteditable]) {
  /* Set to `no-autospace` because `text-autospace` can insert spaces during input, potentially causing erratic behavior. */
  text-autospace: no-autospace;
}

:where(button,
input:is([type=button i], [type=submit i], [type=reset i])),
::file-selector-button {
  /* The `background-color` specified in the User Agent (UA) stylesheet is often unnecessary, so it is reset here. */
  background-color: unset;
}

:where(button,
input:is([type=button i], [type=submit i], [type=reset i]),
[role=tab i],
[role=button i],
[role=option i]),
::file-selector-button {
  /*
  * On iOS, double-tapping a button can cause zooming, which harms usability.
  * `touch-action: manipulation` is specified to disable zooming on double-tap.
  * Third-party plugins such as Swiper sometimes use div elements with these roles as buttons, since double-tapping a div can still trigger zooming, it's advisable to specify this property.
  */
  touch-action: manipulation;
}

:where(button:enabled,
label[for],
select:enabled,
input:is([type=button i],
[type=submit i],
[type=reset i],
[type=radio i],
[type=checkbox i]):enabled,
[role=tab i],
[role=button i],
[role=option i]),
:where(:enabled)::file-selector-button {
  /* Indicate clickable elements with a pointer cursor. */
  cursor: pointer;
}

:where(fieldset) {
  border: unset;
  /* The following default styles are often unnecessary, so they are reset. */
  margin-inline: unset;
  /*
  * Prevent fieldset from causing overflow.
  * Reset the default `min-inline-size: min-content` to prevent children from stretching fieldset.
  * @see https://github.com/twbs/bootstrap/issues/12359
  */
  min-inline-size: 0;
  padding: unset;
}

:where(legend) {
  /* The default `padding-inline` is often unnecessary, so it is reset. */
  padding-inline: unset;
}

:where(progress) {
  /* Resets the vertical alignment of the `<progress>` element to its initial value. */
  vertical-align: unset;
}

::-moz-placeholder {
  /* Standardize the opacity of placeholder text (it may be set lower by default in Firefox). */
  opacity: unset;
}

::placeholder {
  /* Standardize the opacity of placeholder text (it may be set lower by default in Firefox). */
  opacity: unset;
}

/* ======================================================
//  MARK: Interactive elements
// ====================================================== */
:where(summary) {
  /* Changing the cursor to a pointer clarifies the clickability of the element. */
  cursor: pointer;
  /* The default triangle marker is often unnecessary, so it is disabled. */
  list-style-type: "";
}

:where(summary)::-webkit-details-marker {
  /* In Safari versions earlier than 18.4 (released in April 2025), a triangle icon is displayed using the -webkit-details-marker CSS pseudo-element, so it should be removed. */
  display: none;
}

:where(dialog, [popover]) {
  border: unset;
  /*
  * When these fixed-position elements are scrolled, preventing scroll chaining on the underlying page and bounce effects on mobile improves usability.
  * Disabling block-direction scroll chaining is recommended.
  */
  overscroll-behavior-block: contain;
  /* The following default styles are often unnecessary, so they are reset. */
  padding: unset;
}

:where(dialog:not([open], [popover]), [popover]:not(:popover-open)) {
  /*
  * These elements can be easily displayed by explicitly setting their `display` property.
  * To prevent them from appearing when not in an open state, they are forcibly hidden.
  */
  display: none !important;
}

:where(dialog) {
  max-block-size: unset;
  /*
  * The max width and height of a `<dialog>` element are typically determined by the design.
  * These UA stylesheet properties are reset as they can be obstructive, especially when trying to make the dialog full-screen.
  */
  max-inline-size: unset;
}

:where(dialog)::backdrop {
  /* Normalize the background color of the `::backdrop` element. */
  background-color: oklch(0% 0 0deg / 0.3);
}

:where([popover]) {
  /*
  * While the UA stylesheet's `margin` for `<dialog>` elements is useful for centering with `inset: 0`,
  * but `margin` for `popover` elements is often obstructive as they frequently use Anchor Positioning.
  */
  margin: unset;
}

/* ======================================================
//  MARK: Focus Styles
// ====================================================== */
:where(:focus-visible) {
  /* Add space between the content and the focus outline. */
}

[tabindex="-1"]:focus {
  /* Prevent programmatically focused elements from displaying an outline unless they are naturally focusable. */
  outline: none !important;
}

/* ======================================================
//  MARK: Misc
// ====================================================== */
:where(:disabled, [aria-disabled=true i]) {
  /* Display the default cursor on disabled elements to reflect their non-interactive state. */
  cursor: default;
}

[hidden]:not([hidden=until-found i]) {
  /* Ensure that elements intended to be hidden are not displayed, improving clarity and layout control. */
  display: none !important;
}

/* ======================================================
//  MARK: a[href^="tel:"]
// ====================================================== */
.l-banner {
  margin-top: 10.25rem;
}

.l-cvr {
  bottom: 1.875rem;
  opacity: 0;
  position: fixed;
  right: 0;
  transition: opacity 0.3s, visibility 0.3s;
  visibility: hidden;
  z-index: var(--z-index-fixed-cta);
}

.l-cvr.is-visible {
  opacity: 1;
  visibility: visible;
}

.l-footer {
  margin-top: 2.375rem;
}

.l-header {
  position: relative;
  width: 100%;
  z-index: var(--z-index-header);
}

.l-inner {
  margin-inline: auto;
  max-width: calc(var(--inner) + var(--padding-pc) * 2);
  padding-inline: var(--padding-pc);
  width: 100%;
}

.l-mv {
  margin-top: -9.5625rem;
}

.l-product-detail {
  margin-top: 9.6875rem;
}

.l-recording-cards {
  margin-top: 23.375rem;
}

.c-btn {
  background-image: url(../images/common/btn.avif);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  border: 1px solid var(--cream);
  border-radius: 3.75rem;
  color: var(--cream);
  display: inline-block;
  font-family: var(--gothic-font);
  font-size: 2rem;
  max-width: 37.625rem;
  padding-block: 2.375rem 2.125rem;
  position: relative;
  text-align: center;
  width: 100%;
}

.c-btn.c-btn--x {
  letter-spacing: -0.05em;
}

.c-btn::before {
  border: 1px solid var(--gray-mauve);
  border-radius: 3.5625rem;
  bottom: 0.5rem;
  content: "";
  left: 0.5rem;
  position: absolute;
  right: 0.5rem;
  top: 0.5rem;
}

.c-btn::after {
  border-bottom: 0.625rem solid transparent;
  border-left: 0.9375rem solid var(--cream);
  border-top: 0.625rem solid transparent;
  content: "";
  display: inline-block;
  height: 0;
  margin-left: 0.9375rem;
  position: relative;
  top: -0.0625rem;
  vertical-align: middle;
  width: 0;
}

.c-btn.c-btn--x::after {
  background-image: url(../images/common/x.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  border: none;
  height: 2.125rem;
  width: 2.3125rem;
}

.p-autographed-cards {
  overflow-x: clip;
  position: relative;
}

.p-autographed-cards::before {
  background-image: url(../images/autographed-cards/autographed-cards02-pc.avif);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  content: "";
  height: 22rem;
  left: 0;
  position: absolute;
  top: 1.875rem;
  width: 100%;
  z-index: -1;
}

.p-autographed-cards::after {
  background-image: url(../images/autographed-cards/autographed-cards01.avif);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  content: "";
  height: 36.125rem;
  left: calc(50% - 79.0625rem);
  position: absolute;
  top: 73%;
  transform: translateY(-50%);
  width: 137.6875rem;
  z-index: -1;
}

.p-autographed-cards__line {
  background-image: url(../images/autographed-cards/autographed-cards08-pc.avif);
  background-position: center;
  background-repeat: repeat-x;
  background-size: cover;
  border-bottom: 0.125rem solid var(--cream);
  border-top: 0.125rem solid var(--cream);
  height: 1.875rem;
  width: 100%;
}

.p-autographed-cards__title {
  margin: 8.75rem auto 0;
  max-width: 64.625rem;
  width: 100%;
}

.p-autographed-cards__title picture {
  display: block;
}

.p-autographed-cards__swiper {
  margin: 4.375rem auto 0;
  max-width: 50rem;
}

.p-autographed-cards__swiper {
  position: relative;
}

.p-autographed-cards__swiper .swiper {
  padding-block: 3rem;
}

.p-autographed-cards__swiper .swiper-slide {
  cursor: pointer;
  transform: scale(0.92);
  transition: all 0.5s;
}

.p-autographed-cards__swiper .swiper-slide.swiper-slide-active {
  transform: scale(1.31);
}

.p-autographed-cards__swiper .swiper-slide img {
  aspect-ratio: 5/7;
  border-radius: 0.875rem;
  object-fit: cover;
  width: 100%;
}

.p-autographed-cards__swiper .swiper-button-prev,
.p-autographed-cards__swiper .swiper-button-next {
  background-image: url(../images/common/arrow.avif);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  height: 4rem;
  width: 4rem;
}

.p-autographed-cards__swiper .swiper-button-prev::after,
.p-autographed-cards__swiper .swiper-button-next::after {
  display: none;
}

.p-autographed-cards__swiper .swiper-button-prev {
  left: -13%;
  transform: translateY(-25%) rotate(180deg);
}
.p-autographed-cards__swiper .swiper-button-next {
  right: -13%;
  transform: translateY(-25%);
}

.p-autographed-cards__pagination.swiper-pagination {
  align-items: center;
  bottom: -2.9375rem;
  display: flex;
  justify-content: center;
  left: 0;
  position: absolute;
  width: 100%;
}

.p-autographed-cards__pagination.swiper-pagination .swiper-pagination-bullet {
  background: transparent;
  height: 0.9375rem;
  margin: 0 0.3125rem;
  opacity: 1;
  position: relative;
  transition: all 0.5s ease;
  vertical-align: middle;
  width: 0.9375rem;
}

.p-autographed-cards__pagination .swiper-pagination-bullet::before {
  background-color: var(--cream);
  content: "";
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  width: 100%;
  -webkit-mask-image: url(../images/common/deco03.svg);
  mask-image: url(../images/common/deco03.svg);
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  mask-size: contain;
  transition: all 0.3s ease;
}

.p-autographed-cards__pagination.swiper-pagination .swiper-pagination-bullet-active {
  height: 1.5rem;
  width: 1.5rem;
}

.p-autographed-cards__pagination .swiper-pagination-bullet-active::before {
  background-color: var(--cream);
  -webkit-mask-image: url(../images/autographed-cards/autographed-cards05.svg);
  mask-image: url(../images/autographed-cards/autographed-cards05.svg);
}

.p-autographed-cards__name-wrap {
  margin: 2.5rem auto 0;
  max-width: 37.5rem;
  width: 100%;
}

.p-autographed-cards__name {
  align-items: center;
  background-image: url(../images/autographed-cards/autographed-cards04-pc.avif);
  border: 0.125rem solid var(--gold);
  border-radius: 0.1875rem;
  color: var(--brown-orange);
  display: flex;
  font-size: 1.5rem;
  height: 6.25rem;
  justify-content: center;
  line-height: 1.3;
  position: relative;
}

.p-autographed-cards__name::before,
.p-autographed-cards__name::after {
  background-image: url(../images/autographed-cards/autographed-cards07.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  flex-shrink: 0;
  height: 1rem;
  width: 0.9375rem;
}

.p-autographed-cards__name::before {
  margin-right: 1rem;
}

.p-autographed-cards-modal {
  align-items: center;
  background-color: rgba(0, 0, 0, 0.4);
  display: flex;
  flex-direction: column;
  height: 100vh;
  height: 100dvh;
  justify-content: center;
  left: 0;
  opacity: 0;
  pointer-events: none;
  position: fixed;
  top: 0;
  transition: opacity 0.3s, visibility 0.3s;
  visibility: hidden;
  width: 100%;
  z-index: 1000;
}
.p-autographed-cards-modal.is-open {
  opacity: 1;
  pointer-events: auto;
  visibility: visible;
}

.p-autographed-cards-modal__close {
  background: transparent;
  border: none;
  color: var(--white);
  cursor: pointer;
  font-family: var(--base-font);
  font-size: 1.5rem;
  font-weight: var(--fw-medium);
  line-height: 1;
  margin: 0;
  margin-bottom: 1rem;
  max-width: 68.75rem;
  padding: 0;
  text-align: right;
  transition: opacity 0.3s;
  width: 90%;
}

.p-autographed-cards-modal__inner {
  align-items: center;
  background-image: url(../images/autographed-cards/autographed-cards12.avif);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  border: 1px solid var(--gold);
  border-radius: 0.5rem;
  display: flex;
  flex-direction: column;
  height: 50rem;
  justify-content: center;
  max-width: 68.75rem;
  overflow: hidden;
  position: relative;
  width: 90%;
}

.p-autographed-cards-modal__title {
  align-items: center;
  border-bottom: 1px solid var(--gold);
  display: flex;
  gap: 1.5rem;
  padding-block: 1rem;
  position: relative;
  z-index: 1;
}

.p-autographed-cards-modal__title-icon {
  background-color: #D9BA60;
  flex-shrink: 0;
  height: 2rem;
  width: 1.875rem;
  -webkit-mask-image: url(../images/autographed-cards/autographed-cards07.svg);
  mask-image: url(../images/autographed-cards/autographed-cards07.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
}

.p-autographed-cards-modal__title-text {
  color: var(--white);
  font-family: var(--base-font);
  font-size: 2.5rem;
  font-weight: var(--fw-medium);
  line-height: 1;
}

.p-autographed-cards-modal__card {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  margin-top: 3rem;
  position: relative;
  z-index: 1;
}

.p-autographed-cards-modal__img {
  height: 30rem;
  object-fit: cover;
  width: 21.5rem;
}

.p-autographed-cards-modal__name {
  color: var(--white);
  font-family: var(--base-font);
  font-size: 1.5rem;
  font-weight: var(--fw-semibold);
  line-height: 1;
  text-align: center;
}

.p-banner__link {
  display: block;
}

.p-banner__link img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.p-banner__btn-wrap {
  margin-top: 10rem;
  text-align: center;
}

.c-cvr {
  border: none;
  display: block;
  margin: 0;
  padding: 0;
  transition: opacity 0.3s, visibility 0.3s;
  width: 22.75rem;
}

.c-cvr img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.c-cvr__deco01 {
  border: 1px solid var(--gold);
  border-radius: 0.125rem;
  bottom: 0.25rem;
  left: 0.25rem;
  pointer-events: none;
  position: absolute;
  right: 0.25rem;
  top: 0.25rem;
}

.c-cvr__deco01::before,
.c-cvr__deco01::after {
  background-image: url(../images/common/deco07.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 1rem;
  left: 0;
  position: absolute;
  width: 1rem;
}

.c-cvr__deco01::before {
  top: 0;
}

.c-cvr__deco01::after {
  bottom: 0;
  transform: rotate(-90deg);
}

.c-cvr__deco02::before,
.c-cvr__deco02::after {
  background-color: var(--gold);
  content: "";
  height: 1px;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
  width: 11.8125rem;
}

.c-cvr__deco02::before {
  top: 0.625rem;
}

.c-cvr__deco02::after {
  bottom: 0.625rem;
}

.p-cvr-modal {
  align-items: center;
  background-image: url(../images/common/bg01-pc.avif);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  display: flex;
  height: 100vh;
  height: 100dvh;
  justify-content: center;
  left: 0;
  opacity: 0;
  pointer-events: none;
  position: fixed;
  top: 0;
  transition: opacity 0.3s, visibility 0.3s;
  visibility: hidden;
  width: 100%;
  z-index: 999;
}
.p-cvr-modal.is-open {
  opacity: 1;
  pointer-events: auto;
  visibility: visible;
}

.p-cvr-modal__inner {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  height: 100%;
  justify-content: center;
  position: relative;
  width: 100%;
}

.p-cvr-modal__close {
  align-items: center;
  background: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  height: 7.625rem;
  justify-content: center;
  margin: 0;
  outline: none;
  padding: 0;
  position: fixed;
  right: 2.75rem;
  top: 2.75rem;
  width: 7.625rem;
  z-index: 1000;
}
.p-cvr-modal__close::before {
  background-image: url(../images/common/header01.avif);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  inset: 0;
  position: absolute;
  transition: transform 0.3s ease;
}

.p-cvr-modal__close-line {
  background-color: var(--white);
  display: block;
  height: 1px;
  position: relative;
  width: 3.25rem;
}

.p-cvr-modal__close-line:nth-of-type(1) {
  transform: translateY(0.25rem) rotate(10deg);
}

.p-cvr-modal__close-line:nth-of-type(2) {
  margin-top: 0.5625rem;
  transform: translateY(-0.375rem) rotate(-10deg);
}

.p-cvr-modal__close-text {
  align-items: center;
  color: var(--white);
  display: flex;
  font-family: var(--en-font);
  font-size: 1rem;
  font-weight: var(--fw-bold);
  letter-spacing: 0.1em;
  line-height: 1;
  margin-top: 0.5rem;
  position: relative;
  text-transform: uppercase;
}

.p-cvr-modal__text {
  background-color: #C59D48;
  color: var(--white);
  font-family: var(--base-font);
  font-size: 1.5rem;
  line-height: 1;
  padding: 0.625rem;
  text-align: center;
}

.p-cvr-modal__btn-wrap {
  text-align: center;
  width: 100%;
}

.p-cvr-modal__btn {
  align-items: center;
  background-image: url(../images/common/cvr03.avif);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  border: 0.125rem solid #C59D48;
  border-radius: 3.125rem;
  color: #FFF4DD;
  display: inline-flex;
  font-family: var(--base-font);
  font-size: 2rem;
  font-weight: var(--fw-medium);
  gap: 0.625rem;
  height: 6.5rem;
  justify-content: center;
  letter-spacing: 0.1em;
  line-height: 1;
  position: relative;
  text-decoration: none;
  transition: opacity 0.3s;
  width: 31.5rem;
}

.p-cvr-modal__btn::after {
  background-color: #FFF4DD;
  content: "";
  flex-shrink: 0;
  height: 0.9375rem;
  position: relative;
  top: 0.5rem;
  width: 0.9375rem;
  -webkit-mask-image: url(../images/common/link.svg);
          mask-image: url(../images/common/link.svg);
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
}

.p-cvr-modal__note-wrap {
  text-align: center;
}

.p-cvr-modal__note {
  color: #965803;
  display: inline-block;
  font-family: var(--gothic-font);
  font-size: 0.875rem;
  font-weight: var(--fw-medium);
  line-height: 1.5;
  max-width: 37.5rem;
  text-align: left;
  width: 100%;
}

.p-cvr-modal__copyright {
  bottom: 3rem;
  color: var(--brown-orange);
  display: block;
  font-family: var(--gothic-font);
  font-size: 1rem;
  font-weight: var(--fw-medium);
  left: 50%;
  line-height: 1;
  position: absolute;
  text-align: center;
  transform: translateX(-50%);
}

.p-footer {
  align-items: center;
  background-image: url(../images/common/footer-pc.avif);
  background-position: top center;
  background-repeat: no-repeat;
  background-size: cover;
  display: flex;
  justify-content: center;
  min-height: 25rem;
  padding-block: 11.625rem 1.5625rem;
}

.p-footer__inner {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  position: relative;
  width: 100%;
}

.p-footer__inner::before {
  background-image: url(../images/common/deco06-pc.avif);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  content: "";
  height: 46rem;
  left: 0;
  position: absolute;
  top: -50rem;
  width: 100%;
  z-index: -1;
}

.p-footer__logo {
  display: block;
  width: 20.125rem;
}

.p-footer__logo img {
  height: auto;
  width: 100%;
}

.p-footer__link {
  align-items: center;
  border-bottom: 1px solid var(--white);
  color: var(--white);
  display: inline-flex;
  gap: 0.375rem;
  padding-bottom: 0.3125rem;
  text-decoration: none;
}

.p-footer__link-text {
  font-family: var(--gothic-font);
  font-size: 1rem;
  font-weight: var(--fw-medium);
  line-height: 1;
}

.p-footer__link-icon {
  height: 0.8125rem;
  position: relative;
  top: -0.125rem;
  width: 0.8125rem;
}

.p-footer__copyright {
  color: var(--white);
  font-family: var(--gothic-font);
  font-size: 1rem;
  font-weight: var(--fw-medium);
}

.p-header__logo-wrap {
  padding-top: 3.75rem;
  width: 12.625rem;
}

.p-header__logo {
  display: block;
}

.p-header__logo img {
  height: auto;
  width: 100%;
}

.p-header__hamburger {
  align-items: center;
  background: transparent;
  border: none;
  cursor: pointer;
  display: flex;
  flex-direction: column;
  height: 7.625rem;
  justify-content: center;
  margin: 0;
  outline: none;
  padding: 0;
  position: fixed;
  right: 2.75rem;
  top: 2.75rem;
  width: 7.625rem;
  z-index: 999;
}
.p-header__hamburger::before {
  background-image: url(../images/common/header01.avif);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  inset: 0;
  position: absolute;
  transition: transform 0.3s ease;
}

.p-header__hamburger-line {
  background-color: var(--white);
  display: block;
  height: 1px;
  position: relative;
  transition: transform 0.5s, opacity 0.3s;
  width: 3.25rem;
}

.p-header__hamburger-line + .p-header__hamburger-line {
  margin-top: 0.5625rem;
}

.p-header__hamburger.is-open .p-header__hamburger-line:nth-of-type(1) {
  transform: translateY(0.25rem) rotate(10deg);
}

.p-header__hamburger.is-open .p-header__hamburger-line:nth-of-type(2) {
  transform: translateY(-0.375rem) rotate(-10deg);
}

.p-header__hamburger-text {
  align-items: center;
  color: var(--white);
  display: flex;
  font-family: var(--en-font);
  font-size: 1rem;
  font-weight: var(--fw-bold);
  letter-spacing: 0.1em;
  line-height: 1;
  margin-top: 0.5rem;
  position: relative;
  text-transform: uppercase;
}

.p-header__drawer-logo {
  left: 2.75rem;
  opacity: 0;
  position: fixed;
  top: 2.75rem;
  transition: opacity 0.5s, visibility 0.5s;
  visibility: hidden;
  width: 20.0625rem;
  z-index: 999;
}

.p-header__drawer-logo.is-visible {
  opacity: 1;
  visibility: visible;
}

.p-header__drawer-logo-sp {
  left: 0;
  margin-inline: auto;
  opacity: 1;
  position: relative;
  top: 0;
  visibility: visible;
  width: 10.0625rem;
}

.p-header__drawer-logo img,
.p-header__drawer-logo-sp img {
  height: auto;
  width: 100%;
}

.p-header__drawer {
  background-image: url(../images/common/bg01-pc.avif);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  display: none;
  height: 100vh;
  height: 100dvh;
  left: 0;
  opacity: 0;
  overflow-y: scroll;
  padding-block: 2.75rem 1.5625rem;
  position: fixed;
  top: 0;
  transition: opacity 0.3s, visibility 0.3s;
  visibility: hidden;
  width: 100%;
  z-index: 910;
}
.p-header__drawer.is-open {
  opacity: 1;
  visibility: visible;
}

.p-header__drawer::-webkit-scrollbar {
  display: none;
}

.p-header__drawer-product-logo {
  margin-inline: auto;
  width: 30.375rem;
}

.p-header__drawer-product-logo img {
  height: auto;
  width: 100%;
}

.p-header__drawer-nav {
  margin-top: 7.5rem;
  position: relative;
}

.p-header__drawer-item {
  position: relative;
  text-align: center;
}

.p-header__drawer-item:not(:last-of-type)::after {
  background-image: url(../images/common/deco03.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  bottom: -0.75rem;
  content: "";
  display: block;
  height: 1.59375rem;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
  width: 1.59375rem;
}

.p-header__drawer-link {
  color: inherit;
  display: inline-block;
  padding-block: 2.34375rem;
  text-align: center;
  text-decoration: none;
  transition: opacity 0.3s;
}

.p-header__drawer-link-en {
  color: var(--brown-orange);
  font-family: var(--en-font);
  font-size: 1rem;
  font-weight: var(--fw-black);
  letter-spacing: 0.01em;
  text-transform: uppercase;
}

.p-header__drawer-link-ja {
  color: var(--brown-orange);
  font-family: var(--gothic-font);
  font-size: 3rem;
  font-style: italic;
  font-weight: var(--fw-bold);
  letter-spacing: 0.15em;
  line-height: 1;
  margin-top: 0.625rem;
}

.p-header__drawer-copyright {
  bottom: 3rem;
  color: var(--brown-orange);
  display: block;
  font-family: var(--gothic-font);
  font-size: 1rem;
  font-weight: var(--fw-medium);
  left: 50%;
  line-height: 1;
  position: absolute;
  text-align: center;
  transform: translateX(-50%);
}

.p-opening {
  align-items: center;
  display: flex;
  inset: 0;
  justify-content: center;
  position: fixed;
  z-index: var(--z-index-loader);
}

.p-opening__img {
  height: 100%;
  inset: 0;
  object-fit: cover;
  position: absolute;
  width: 100%;
}

.p-opening__text {
  background-clip: text;
  background-image: linear-gradient(180deg, #fff4dd 0%, #d9ba60 100%);
  font-family: var(--base-font);
  font-size: 3rem;
  font-weight: var(--fw-extrabold);
  letter-spacing: -0.07em;
  line-height: 1.5;
  position: relative;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  opacity: 0;
  text-align: center;
}

.p-opening__text-medium {
  font-size: 4rem;
  font-weight: var(--fw-medium);
  letter-spacing: 0;
  margin-right: -1.25rem;
}

.p-opening__text-semibold {
  font-size: 4rem;
  font-weight: var(--fw-semibold);
}

.p-opening__text-normal {
  letter-spacing: 0;
}

.p-opening__text-large {
  font-size: 6rem;
  letter-spacing: -0.44em;
  margin-right: 1.25rem;
}

.p-opening__text br {
  display: none;
}

.p-mv__img-wrap {
  position: relative;
}

.p-mv__img {
  display: block;
  width: 100%;
}

.p-mv__img img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.p-mv__title {
  bottom: 4.375rem;
  left: 50%;
  opacity: 0;
  position: absolute;
  transform: translateX(-50%);
  transform: translateX(-50%) translateY(1.875rem);
  transition: opacity 1s, transform 1s;
}
.p-mv__title.is-visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.p-mv__lead-wrap {
  background-image: url(../images/mv/mv04-pc.avif);
  background-position: bottom;
  background-repeat: no-repeat;
  background-size: cover;
  margin-top: -24.25rem;
  padding-block: 30.375rem 6.125rem;
}

.p-mv__lead-img {
  display: block;
  margin-inline: auto;
  max-width: 64.75rem;
  width: 100%;
}

.p-mv__lead-text {
  color: var(--cream);
  font-size: 2.5rem;
  letter-spacing: 0.1em;
  margin-top: 1.125rem;
  text-align: center;
}

.p-mv__lead-text span {
  font-size: 2rem;
}

.p-product-detail__wrap {
  align-items: flex-start;
  display: flex;
  gap: 2.5rem;
  justify-content: center;
  margin-top: 5.75rem;
}

.p-product-detail__img {
  display: block;
  max-width: 25rem;
  padding-top: 0.625rem;
  width: 100%;
}

.p-product-detail__img img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.p-product-detail__content {
  font-family: var(--gothic-font);
  line-height: 1.5;
  max-width: 32.5rem;
  width: 100%;
}

.p-product-detail__name {
  font-size: 2rem;
  font-weight: var(--fw-medium);
}

.p-product-detail__release-date {
  background-color: var(--gold-medium);
  border-radius: 5.375rem;
  display: inline-block;
  font-size: 1.5rem;
  letter-spacing: -0.02em;
  margin-top: 1.25rem;
  padding: 0.3125rem 0.9375rem 0.0625rem 0.8125rem;
}

.p-product-detail__term {
  font-size: 1.5rem;
  font-weight: var(--fw-medium);
  margin-top: 1.4375rem;
}

.p-product-detail__term::before {
  background-color: var(--gold);
  content: "";
  display: inline-block;
  height: 0.9375rem;
  margin-right: 0.625rem;
  transform: rotate(45deg);
  vertical-align: middle;
  width: 0.9375rem;
}

.p-product-detail__description {
  font-size: 1.25rem;
  margin-top: 0.375rem;
}

.p-product-detail__description span {
  display: block;
  margin-top: 2rem;
}

.p-product-detail__btn-wrap {
  margin-top: 4.6875rem;
  text-align: center;
}

.p-product-detail__description .pc-only {
  display: block;
}

.p-product-detail__description .sp-only {
  display: none;
}

.p-recording-cards {
  scroll-margin-top: 12.5rem;
}

.p-recording-cards__title-wrap {
  position: relative;
}

.p-recording-cards__bg {
  background-image: url(../images/recording-cards/recording-cards01.avif);
  background-position: center;
  background-repeat: repeat-x;
  background-size: cover;
  border-bottom: 0.1875rem solid var(--cream);
  border-top: 0.1875rem solid var(--cream);
  height: 20.875rem;
  left: 0;
  position: absolute;
  top: 25%;
  transform: translateY(-50%);
  width: 100%;
  z-index: 5;
}

.p-recording-cards__bg::before,
.p-recording-cards__bg::after {
  background-image: url(../images/recording-cards/recording-cards01.avif);
  background-position: center;
  background-size: auto 26.5rem;
  content: "";
  height: 9.375rem;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
  width: 21.25rem;
  z-index: 1;
}

.p-recording-cards__bg::before {
  border-radius: 50% 50% 0 0;
  top: -3rem;
}

.p-recording-cards__bg::after {
  border-radius: 0 0 50% 50%;
  bottom: -3rem;
}

.p-recording-cards__bg span::before,
.p-recording-cards__bg span::after {
  background-image: url(../images/recording-cards/recording-cards02.avif);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 16.375rem;
  left: 50%;
  position: absolute;
  transform: translateX(-50%);
  width: 20rem;
  z-index: 2;
}

.p-recording-cards__bg span::before {
  top: -8.3125rem;
}

.p-recording-cards__bg span::after {
  bottom: -8.3125rem;
  transform: translateX(-50%) rotate(180deg);
}

.p-recording-cards__title {
  position: relative;
  top: -4.1875rem;
  z-index: 10;
}

.p-recording-cards__title::before {
  background-image: url(../images/recording-cards/deco01-pc.avif);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 3.75rem;
  left: 50%;
  position: absolute;
  top: -5.125rem;
  transform: translateX(-50%);
  width: 16.25rem;
}

.p-recording-cards__text {
  font-size: 1.5rem;
  font-weight: var(--fw-regular);
  line-height: 1.5;
  position: relative;
  text-align: center;
  top: -1.5625rem;
  z-index: 10;
}

.p-recording-cards__text::after {
  background-image: url(../images/recording-cards/deco01-pc.avif);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  bottom: -5.5rem;
  content: "";
  height: 3.75rem;
  left: 50%;
  position: absolute;
  transform: translateX(-50%) rotate(180deg);
  width: 16.25rem;
}

.p-recording-cards__type-wrap {
  position: relative;
}

.p-recording-cards__type-bg {
  height: 100vh;
  height: 100dvh;
  pointer-events: none;
  position: sticky;
  top: 0;
  z-index: 1;
}

.p-recording-cards__type-bg::after {
  background-image: url(../images/recording-cards/bg-pc.avif);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  content: "";
  height: 100%;
  left: 0;
  mix-blend-mode: multiply;
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1;
}

.p-recording-cards__type-bg-gradient {
  height: 100%;
  left: 0;
  position: absolute;
  top: 0;
  transition: opacity 0.4s ease-out;
  width: 100%;
}

.p-recording-cards__type-bg-gradient.p-recording-cards__type-bg-gradient--princess {
  background: linear-gradient(to right, #7F1142, #C81263 50%, #7F1142);
}

.p-recording-cards__type-bg-gradient.p-recording-cards__type-bg-gradient--fairy {
  background: linear-gradient(to right, #002E7D, #0046BF 50%, #002E7D);
  opacity: 0;
}

.p-recording-cards__type-bg-gradient.p-recording-cards__type-bg-gradient--angel {
  background: linear-gradient(to right, #976E00, #C99300 50%, #976E00);
  opacity: 0;
}

.p-recording-cards__type-bg-gradient.p-recording-cards__type-bg-gradient--bnp {
  background: linear-gradient(to right, #8B8B8B, #AFAFAF 50%, #8B8B8B);
  opacity: 0;
}

.p-recording-cards__type-list {
  margin-top: -100vh;
  margin-top: -100dvh;
  position: relative;
}

.p-recording-cards__type-item {
  padding-block: 7.8125rem;
  position: relative;
  text-align: center;
}

.p-recording-cards__type-item:first-of-type {
  margin-top: -100vh;
  margin-top: -100dvh;
  padding-block: 11.875rem 7.8125rem;
}

.p-recording-cards__type-item:last-of-type {
  padding-bottom: 5.8125rem;
}

.p-recording-cards__princess-border {
  align-items: center;
  display: flex;
  display: none;
  height: 100vh;
  height: 100dvh;
  justify-content: center;
  pointer-events: none;
  position: sticky;
  top: 0;
  z-index: 2;
}

.p-recording-cards__princess-border-outer {
  background-color: var(--gold);
  inset: 0;
  position: absolute;
  -webkit-mask-image: linear-gradient(black, black), linear-gradient(black, black), linear-gradient(black, black), linear-gradient(black, black), radial-gradient(circle at 0 0, transparent 3rem, black 3rem, black 3.125rem, transparent 3.125rem), radial-gradient(circle at 100% 0, transparent 3rem, black 3rem, black 3.125rem, transparent 3.125rem), radial-gradient(circle at 0 100%, transparent 3rem, black 3rem, black 3.125rem, transparent 3.125rem), radial-gradient(circle at 100% 100%, transparent 3rem, black 3rem, black 3.125rem, transparent 3.125rem);
  -webkit-mask-size: calc(100% - 6.25rem) 0.125rem, calc(100% - 6.25rem) 0.125rem, 0.125rem calc(100% - 6.25rem), 0.125rem calc(100% - 6.25rem), 3.125rem 3.125rem, 3.125rem 3.125rem, 3.125rem 3.125rem, 3.125rem 3.125rem;
  -webkit-mask-position: top center, bottom center, left center, right center, top left, top right, bottom left, bottom right;
  -webkit-mask-repeat: no-repeat;
  mask-image: linear-gradient(black, black), linear-gradient(black, black), linear-gradient(black, black), linear-gradient(black, black), radial-gradient(circle at 0 0, transparent 3rem, black 3rem, black 3.125rem, transparent 3.125rem), radial-gradient(circle at 100% 0, transparent 3rem, black 3rem, black 3.125rem, transparent 3.125rem), radial-gradient(circle at 0 100%, transparent 3rem, black 3rem, black 3.125rem, transparent 3.125rem), radial-gradient(circle at 100% 100%, transparent 3rem, black 3rem, black 3.125rem, transparent 3.125rem);
  mask-position: top center, bottom center, left center, right center, top left, top right, bottom left, bottom right;
  mask-repeat: no-repeat;
  mask-size: calc(100% - 6.25rem) 0.125rem, calc(100% - 6.25rem) 0.125rem, 0.125rem calc(100% - 6.25rem), 0.125rem calc(100% - 6.25rem), 3.125rem 3.125rem, 3.125rem 3.125rem, 3.125rem 3.125rem, 3.125rem 3.125rem;
}

.p-recording-cards__princess-border-wrap {
  height: 90.83%;
  max-height: 65.875rem;
  max-width: 117.50375rem;
  position: relative;
  width: 97.92%;
}

.p-recording-cards__princess-border-inner {
  border: 1px solid #D9BA60;
  inset: 3%;
  position: absolute;
}

.p-recording-cards__type {
  align-items: center;
  display: inline-flex;
  flex-direction: column;
  gap: 1rem;
  position: relative;
  z-index: 2;
}

.p-recording-cards__type-item.p-recording-cards__type-item--princess .p-recording-cards__type::before,
.p-recording-cards__type-item.p-recording-cards__type-item--fairy .p-recording-cards__type::before,
.p-recording-cards__type-item.p-recording-cards__type-item--angel .p-recording-cards__type::before {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  height: 4.6875rem;
  left: 50%;
  position: absolute;
  top: -4.8125rem;
  transform: translateX(-50%);
  width: 4.6875rem;
}

.p-recording-cards__type-item.p-recording-cards__type-item--princess .p-recording-cards__type::before {
  background-image: url(../images/recording-cards/deco04.avif);
}

.p-recording-cards__type-item.p-recording-cards__type-item--fairy .p-recording-cards__type::before {
  background-image: url(../images/recording-cards/deco05.avif);
}

.p-recording-cards__type-item.p-recording-cards__type-item--angel .p-recording-cards__type::before {
  background-image: url(../images/recording-cards/deco06.avif);
}

.p-recording-cards__type-ja {
  color: var(--cream);
  font-size: 1.5rem;
  font-weight: var(--fw-extra-bold);
  letter-spacing: 0.5em;
  line-height: 1;
  text-align: center;
}

.p-recording-cards__type-en {
  position: relative;
  width: 100%;
}

.p-recording-cards__type-en::before,
.p-recording-cards__type-en::after {
  background-color: var(--cream);
  content: "";
  height: 1.625rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 1.625rem;
  -webkit-mask-image: url(../images/common/deco03.svg);
  mask-image: url(../images/common/deco03.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
}

.p-recording-cards__type-en::before {
  left: -3.625rem;
}

.p-recording-cards__type-en::after {
  right: -3.625rem;
}

.p-recording-cards__type-item.p-recording-cards__type-item--princess .p-recording-cards__type-en {
  max-width: 27.125rem;
}

.p-recording-cards__type-item.p-recording-cards__type-item--fairy .p-recording-cards__type-en {
  max-width: 15.625rem;
}

.p-recording-cards__type-item.p-recording-cards__type-item--angel .p-recording-cards__type-en {
  max-width: 17.25rem;
}

.p-recording-cards__type-item.p-recording-cards__type-item--bnp .p-recording-cards__type > * {
  filter: drop-shadow(0 0 10px rgba(0, 0, 0, 0.5));
}

.p-recording-cards__type-item.p-recording-cards__type-item--bnp .p-recording-cards__type-en {
  max-width: 9.9375rem;
}

.p-recording-cards__type-en img {
  height: 100%;
  object-fit: contain;
  width: 100%;
}

.p-recording-cards__type-lead {
  color: var(--cream);
  font-size: 1.5rem;
  line-height: 1.4;
}

.p-recording-cards__type-text {
  font-family: var(--gothic-font);
  font-size: 0.875rem;
}

.p-recording-cards__swiper {
  margin-inline: auto;
  margin-top: 0.3125rem;
  max-width: 120rem;
  overflow: hidden;
  position: relative;
  z-index: 2;
  -webkit-mask-image: linear-gradient(to right, transparent, black 10.5625rem, black calc(100% - 10.5625rem), transparent);
  mask-image: linear-gradient(to right, transparent, black 10.5625rem, black calc(100% - 10.5625rem), transparent);
}

.p-recording-cards__swiper .swiper {
  padding-block: 2.5rem;
}

.p-recording-cards__swiper .swiper-slide {
  cursor: pointer;
  width: 18.4375rem;
  will-change: transform;
}

.p-recording-cards__swiper .swiper-slide img {
  aspect-ratio: 295/400;
  border: 0.1875rem solid transparent;
  border-radius: 0.625rem;
  box-shadow: 0 0 1.875rem rgba(0, 0, 0, 0.5);
  object-fit: cover;
  width: 100%;
}

.p-recording-cards__swiper .swiper-slide::after {
  background-color: rgba(76, 11, 40, 0.2);
  border-radius: 0.625rem;
  content: "";
  height: 100%;
  left: 0;
  pointer-events: none;
  position: absolute;
  top: 0;
  transition: opacity 0.5s;
  width: 100%;
}

.p-recording-cards__swiper .swiper-slide-active::after {
  opacity: 0;
}

.p-recording-cards__swiper .swiper-slide-active img {
  border-color: var(--gold);
  box-shadow: 0 0 1.875rem var(--white);
}

.p-recording-cards__swiper .swiper-button-prev,
.p-recording-cards__swiper .swiper-button-next {
  background-image: url(../images/common/arrow.avif);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  height: 4rem;
  width: 4rem;
  z-index: 11;
}

.p-recording-cards__swiper .swiper-button-prev::after,
.p-recording-cards__swiper .swiper-button-next::after {
  display: none;
}

.p-recording-cards__swiper .swiper-button-prev {
  left: 36%;
  transform: rotate(180deg);
}

.p-recording-cards__swiper .swiper-button-next {
  right: 36%;
}

.p-recording-cards__icons {
  align-items: center;
  display: flex;
  gap: 2.5rem;
  justify-content: center;
  margin-top: 0.9375rem;
  position: relative;
  z-index: 2;
}

.p-recording-cards__icons-deco {
  flex-shrink: 0;
  height: 4.1875rem;
  width: 3.0625rem;
}

.p-recording-cards__icons-deco img {
  height: 100%;
  object-fit: contain;
  width: 100%;
}

.p-recording-cards__icons-deco--left {
  transform: rotate(180deg);
}

.p-recording-cards__icons-deco--right {
  transform: rotate(360deg);
}

.p-recording-cards__icons-list {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 1.5rem;
  justify-content: center;
  max-width: 52.5rem;
}

.p-recording-cards__icons-item {
  border: 0.125rem solid var(--gold);
  border-radius: 50%;
  cursor: pointer;
  height: 4.5rem;
  opacity: 0.5;
  overflow: hidden;
  transition: opacity 0.3s, box-shadow 0.3s;
  width: 4.5rem;
}

.p-recording-cards__icons-item.is-active {
  box-shadow: 0 0 0.625rem var(--gold);
  opacity: 1;
}

.p-recording-cards__icons-item img {
  height: 100%;
  object-fit: cover;
  width: 100%;
}

.p-recording-cards-modal {
  align-items: center;
  background-color: rgba(0, 0, 0, 0.4);
  display: flex;
  flex-direction: column;
  height: 100vh;
  height: 100dvh;
  justify-content: center;
  left: 0;
  opacity: 0;
  pointer-events: none;
  position: fixed;
  top: 0;
  transition: opacity 0.3s, visibility 0.3s;
  visibility: hidden;
  width: 100%;
  z-index: 1000;
}
.p-recording-cards-modal.is-open {
  opacity: 1;
  pointer-events: auto;
  visibility: visible;
}

.p-recording-cards-modal__close {
  background: transparent;
  border: none;
  color: var(--white);
  cursor: pointer;
  font-family: var(--base-font);
  font-size: 1.5rem;
  font-weight: var(--fw-medium);
  line-height: 1;
  margin: 0;
  margin-bottom: 1rem;
  max-width: 68.75rem;
  padding: 0;
  text-align: right;
  transition: opacity 0.3s;
  width: 90%;
}

.p-recording-cards-modal__inner {
  align-items: center;
  border: 1px solid var(--gold);
  border-radius: 0.5rem;
  display: flex;
  flex-direction: column;
  height: 50rem;
  justify-content: center;
  max-width: 68.75rem;
  overflow: hidden;
  position: relative;
  width: 90%;
}

.p-recording-cards__type-item.p-recording-cards__type-item--princess .p-recording-cards-modal__inner {
  background-color: #7F1142;
}

.p-recording-cards__type-item.p-recording-cards__type-item--fairy .p-recording-cards-modal__inner {
  background-color: #002E7D;
}

.p-recording-cards__type-item.p-recording-cards__type-item--angel .p-recording-cards-modal__inner {
  background-color: #976E00;
}

.p-recording-cards__type-item.p-recording-cards__type-item--bnp .p-recording-cards-modal__inner {
  background-color: #8D8D8D;
}

.p-recording-cards-modal__title {
  align-items: center;
  border-bottom: 1px solid var(--gold);
  display: flex;
  gap: 1.5rem;
  margin-top: -1.25rem;
  padding-block: 1rem;
  position: relative;
  z-index: 1;
}

.p-recording-cards-modal__title-icon {
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  flex-shrink: 0;
  height: 3.125rem;
  width: 3.125rem;
}

.p-recording-cards__type-item.p-recording-cards__type-item--princess .p-recording-cards-modal__title-icon {
  background-image: url(../images/recording-cards/deco04.avif);
}

.p-recording-cards__type-item.p-recording-cards__type-item--fairy .p-recording-cards-modal__title-icon {
  background-image: url(../images/recording-cards/deco05.avif);
}

.p-recording-cards__type-item.p-recording-cards__type-item--angel .p-recording-cards-modal__title-icon {
  background-image: url(../images/recording-cards/deco06.avif);
}

.p-recording-cards__type-item.p-recording-cards__type-item--bnp .p-recording-cards-modal__title-icon {
  background-image: url(../images/recording-cards/deco07.svg);
  height: 1.875rem;
  width: 1.875rem;
}

.p-recording-cards-modal__title-text {
  color: var(--white);
  font-family: var(--base-font);
  font-size: 2.5rem;
  font-weight: var(--fw-medium);
  line-height: 1;
}

.p-recording-cards-modal__card {
  display: flex;
  gap: 1.5rem;
  justify-content: center;
  margin-top: 3rem;
  position: relative;
  z-index: 1;
}

.p-recording-cards-modal__card-item {
  align-items: center;
  display: flex;
  flex-direction: column;
}

.p-recording-cards-modal__card-label {
  font-family: "Cinzel", serif;
  font-size: 2.25rem;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 1rem;
}

.p-recording-cards-modal__card-label.p-recording-cards-modal__card-label--sp {
  color: #D9BA60;
}

.p-recording-cards-modal__card-label.p-recording-cards-modal__card-label--n {
  color: #fff;
}

.p-recording-cards-modal__card-label.p-recording-cards-modal__card-label--bnp {
  color: #FFF4DD;
}

.p-recording-cards-modal__img {
  height: 30rem;
  object-fit: cover;
  width: 21.5rem;
}

.p-recording-cards__loop {
  background: linear-gradient(to right, #4D150D, #331713);
  border-bottom: 1px solid var(--gold);
  border-top: 1px solid var(--gold);
  display: flex;
  gap: 0.625rem;
  height: 2.5rem;
  overflow: hidden;
  position: relative;
  width: 100%;
  z-index: 1;
}

.p-recording-cards__loop-img {
  animation: recording-cards-loop 60s infinite linear both;
  display: flex;
  flex-shrink: 0;
  gap: 0.625rem;
  height: 100%;
}

.p-recording-cards__loop-img img {
  filter: drop-shadow(0 0 12px #FFFFFF);
  flex-shrink: 0;
  height: 100%;
  object-fit: contain;
  width: 641px;
}

@keyframes recording-cards-loop {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(0);
  }
}
.p-title {
  margin-inline: auto;
  max-width: 42.625rem;
  position: relative;
  text-align: center;
  width: 100%;
}

.p-title::after {
  background-image: url(../images/common/deco04-pc.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  bottom: -1.875rem;
  content: "";
  display: block;
  height: 0.9375rem;
  left: 0;
  position: absolute;
  width: 100%;
}

.p-title__en {
  background: linear-gradient(to bottom, #ffe9bc 0%, #fff4dd 50%, #ffe9bc 100%);
  color: #ffe9bc;
  font-family: var(--en-font);
  font-size: 1.5rem;
  font-weight: var(--fw-black);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.p-title__ja {
  background: linear-gradient(to bottom, #ffe9bc 0%, #fff4dd 50%, #ffe9bc 100%);
  color: #ffe9bc;
  display: inline-block;
  font-family: var(--gothic-font);
  font-size: 4rem;
  font-style: italic;
  font-weight: var(--fw-bold);
  letter-spacing: 0.3em;
  line-height: 1;
  margin-top: 0.625rem;
  position: relative;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.p-title__ja::before,
.p-title__ja::after {
  background-image: url(../images/common/deco05.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  content: "";
  display: block;
  height: 2.5rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2.5rem;
}

.p-title__ja::before {
  left: -3.25rem;
}

.p-title__ja::after {
  right: -3.25rem;
}

.pc-only {
  display: block;
}

.sp-only {
  display: none;
}

@media (min-width: 768px){
  a[href^="tel:"] {
    pointer-events: none;
  }
}

@media (min-width: 768px) and (max-width: 1300px){
  .p-autographed-cards__swiper .swiper-button-prev {
    left: -10%;
  }
  .p-autographed-cards__swiper .swiper-button-next {
    right: -10%;
  }
  .p-header__drawer-logo.is-visible {
    width: 15.625rem;
  }
  .p-mv__lead-text {
    font-size: 2rem;
  }
  .p-mv__lead-text span {
    font-size: 1.5rem;
  }
}

@media (min-width: 1921px){
  .p-footer {
    padding-block: 9.75vw 1.5vw;
  }
}

@media (max-width: 1450px){
  .p-opening__text br {
    display: block;
  }
}

@media (max-width: 1200px){
  html {
    font-size: calc(16 / var(--inner-value) * 100vw);
  }
}

@media screen and (max-width: 767px){
  :root {
    --vw: 375 * 100vw;
  }
  html {
    font-size: 16px;
  }
  .l-banner {
    margin-top: 4rem;
  }
  .l-cvr {
    bottom: 0;
  }
  .l-footer {
    margin-top: -3.3125rem;
  }
  .l-inner {
    max-width: 500px;
    padding-inline: var(--padding-sp);
  }
  .l-mv {
    margin-top: -4.375rem;
  }
  .l-product-detail {
    margin-top: 3.75rem;
  }
  .l-recording-cards {
    margin-top: 14.375rem;
  }
  .c-btn {
    font-size: 1rem;
    max-width: 23.875rem;
    padding-block: 1.6875rem 1.4375rem;
  }
  .c-btn::before {
    border-radius: 2.6875rem;
    bottom: 0.375rem;
    left: 0.375rem;
    right: 0.375rem;
    top: 0.375rem;
  }
  .c-btn::after {
    border-bottom: 0.5rem solid transparent;
    border-left: 0.625rem solid var(--cream);
    border-top: 0.5rem solid transparent;
    margin-left: 0.625rem;
  }
  .c-btn.c-btn--x::after {
    height: 1.5rem;
    width: 1.625rem;
  }
  .p-autographed-cards::before {
    background-image: url(../images/autographed-cards/autographed-cards02-sp.avif);
    height: 7.5rem;
  }
  .p-autographed-cards::after {
    height: 13.9375rem;
    left: calc(50% - 22.0625rem);
    width: 53.1875rem;
  }
  .p-autographed-cards__line {
    background-image: url(../images/autographed-cards/autographed-cards08-sp.avif);
    border-bottom: 1px solid var(--cream);
    border-top: 1px solid var(--cream);
  }
  .p-autographed-cards__title {
    margin-top: 5rem;
    padding-inline: 0.625rem;
  }
  .p-autographed-cards__swiper {
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    margin-top: -0.9375rem;
    width: 100vw;
  }
  .p-autographed-cards__swiper .swiper {
    padding-block: 1.875rem;
  }
  .p-autographed-cards__swiper .swiper-slide {
    transform: scale(0.71);
  }
  .p-autographed-cards__swiper .swiper-slide.swiper-slide-active {
    transform: scale(0.9);
  }
  .p-autographed-cards__swiper .swiper-button-prev,
  .p-autographed-cards__swiper .swiper-button-next {
    height: 3rem;
    width: 3rem;
  }
  .p-autographed-cards__swiper .swiper-button-prev {
    left: 20%;
  }
  .p-autographed-cards__swiper .swiper-button-next {
    right: 20%;
  }
  .p-autographed-cards__pagination.swiper-pagination {
    bottom: -3.5625rem;
  }
  .p-autographed-cards__name-wrap {
    margin-top: -0.625rem;
    max-width: 25.125rem;
    padding-inline: 0.625rem;
  }
  .p-autographed-cards__name {
    background-image: url(../images/autographed-cards/autographed-cards04-sp.avif);
    font-size: 1.25rem;
    height: 4rem;
  }
  .p-autographed-cards__name::before,
  .p-autographed-cards__name::after {
    height: 0.75rem;
    width: 0.6875rem;
  }
  .p-autographed-cards__name::before {
    margin-right: 0.8125rem;
  }
  .p-autographed-cards-modal__close {
    font-size: 1rem;
    margin-bottom: -1.875rem;
    max-width: 34.375rem;
    padding-right: 0.5rem;
    position: relative;
    width: 92%;
    z-index: 2;
  }
  .p-autographed-cards-modal__inner {
    height: 62.5vh;
    max-height: 34.375rem;
    max-width: 34.375rem;
    min-height: 28.125rem;
    overflow-y: auto;
    width: 92%;
  }
  .p-autographed-cards-modal__title {
    gap: 0.5rem;
    padding-block: 0.3125rem;
  }
  .p-autographed-cards-modal__title-icon {
    height: 1rem;
    width: 0.9375rem;
  }
  .p-autographed-cards-modal__title-text {
    font-size: 1.5rem;
  }
  .p-autographed-cards-modal__card {
    gap: 1rem;
    margin-top: 1.5rem;
  }
  .p-autographed-cards-modal__img {
    height: auto;
    width: 9.8125rem;
  }
  .p-autographed-cards-modal__name {
    font-size: 1.25rem;
  }
  .p-banner__btn-wrap {
    margin-top: 4rem;
  }
  .c-cvr {
    background-image: url(../images/common/cvr02.avif);
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
    border-bottom: 0.125rem solid var(--gold);
    border-top: 0.125rem solid var(--gold);
    color: var(--gold-brown);
    font-size: 1.5rem;
    font-weight: var(--fw-extrabold);
    height: 4.25rem;
    padding-right: 1rem;
    text-align: center;
    width: 100%;
  }
  .c-cvr span {
    font-size: 1.25rem;
  }
  .c-cvr span:not([class])::after {
    content: "";
    height: 1rem;
    position: absolute;
    right: calc(50% - 4.6875rem);
    top: 55%;
    transform: translateY(-50%);
    width: 1rem;
    -webkit-mask-image: url(../images/common/link.svg);
            mask-image: url(../images/common/link.svg);
    -webkit-mask-size: contain;
            mask-size: contain;
    -webkit-mask-position: center;
            mask-position: center;
    -webkit-mask-repeat: no-repeat;
    background-color: var(--gold-brown);
            mask-repeat: no-repeat;
  }
  .c-cvr::before,
  .c-cvr::after {
    background-image: url(../images/common/deco07.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    height: 1rem;
    pointer-events: none;
    position: absolute;
    right: 0.25rem;
    width: 1rem;
  }
  .c-cvr::before {
    top: 0.25rem;
    transform: rotate(-90deg);
  }
  .c-cvr::after {
    bottom: 0.25rem;
    transform: rotate(-180deg);
  }
  .p-cvr-modal__inner {
    gap: 1.5rem;
    padding-inline: 0.3125rem;
  }
  .p-cvr-modal__close {
    height: 5rem;
    right: 1rem;
    top: 1rem;
    width: 5rem;
  }
  .p-cvr-modal__close-line {
    width: 2.0625rem;
  }
  .p-cvr-modal__close-line:nth-of-type(1) {
    transform: translateY(0.1875rem) rotate(10deg);
  }
  .p-cvr-modal__close-line:nth-of-type(2) {
    margin-top: 0.3125rem;
    transform: translateY(-0.1875rem) rotate(-10deg);
  }
  .p-cvr-modal__close-text {
    font-size: 0.625rem;
    letter-spacing: 0;
    margin-top: 0.375rem;
  }
  .p-cvr-modal__text {
    font-size: 0.875rem;
    padding: 0.5rem 0.25rem;
  }
  .p-cvr-modal__btn {
    font-size: 1.5rem;
    height: 4.75rem;
    letter-spacing: 0.1em;
    max-width: 23.875rem;
    width: 100%;
  }
  .p-cvr-modal__btn::after {
    top: 0.3125rem;
  }
  .p-cvr-modal__note {
    font-size: 0.875rem;
    max-width: 23.875rem;
    padding-left: 0.875rem;
    text-indent: -0.875rem;
  }
  .p-cvr-modal__copyright {
    bottom: 1rem;
    font-size: 0.75rem;
    letter-spacing: 0.01em;
    margin-top: 13.4375rem;
    width: 100%;
  }
  .p-footer {
    background-image: url(../images/common/footer-sp.avif);
    padding-block: 44.5vw 5.8125rem;
  }
  .p-footer__inner {
    gap: 1.75rem;
  }
  .p-footer__inner::before {
    background-image: url(../images/common/deco06-sp.avif);
    height: 67.25vw;
    top: -57.25vw;
  }
  .p-footer__logo {
    width: 15.625rem;
  }
  .p-footer__copyright {
    font-size: 0.75rem;
    margin-top: -0.4375rem;
  }
  .p-header {
    padding-left: 0.9375rem;
  }
  .p-header__logo-wrap {
    padding-top: 0.9375rem;
    width: 7.625rem;
  }
  .p-header__hamburger {
    height: 5rem;
    right: 1rem;
    top: 1rem;
    width: 5rem;
  }
  .p-header__hamburger-line {
    width: 2.0625rem;
  }
  .p-header__hamburger-line + .p-header__hamburger-line {
    margin-top: 0.3125rem;
  }
  .p-header__hamburger.is-open .p-header__hamburger-line:nth-of-type(1) {
    transform: translateY(0.1875rem) rotate(10deg);
  }
  .p-header__hamburger.is-open .p-header__hamburger-line:nth-of-type(2) {
    transform: translateY(-0.1875rem) rotate(-10deg);
  }
  .p-header__hamburger-text {
    font-size: 0.625rem;
    letter-spacing: 0;
    margin-top: 0.375rem;
  }
  .p-header__drawer {
    padding-block: 1.5rem 1.5625rem;
  }
  .p-header__drawer-product-logo {
    margin-top: 0.5rem;
    width: 17.125rem;
  }
  .p-header__drawer-nav {
    margin-top: 5rem;
  }
  .p-header__drawer-item:not(:last-of-type)::after {
    bottom: -0.5625rem;
    height: 1rem;
    width: 1rem;
  }
  .p-header__drawer-link {
    padding-block: 1.4375rem;
  }
  .p-header__drawer-link-en {
    font-size: 0.875rem;
  }
  .p-header__drawer-link-ja {
    font-size: 2.25rem;
    margin-top: 0.1875rem;
  }
  .p-header__drawer-copyright {
    bottom: 1rem;
    font-size: 0.75rem;
    letter-spacing: 0.01em;
    width: 100%;
  }
  .p-opening__text {
    font-size: 1.5rem;
  }
  .p-opening__text-medium {
    font-size: 2rem;
    margin-right: -0.625rem;
  }
  .p-opening__text-semibold {
    font-size: 2rem;
  }
  .p-opening__text-large {
    font-size: 3rem;
    margin-right: 0.625rem;
  }
  .p-mv__title {
    bottom: 2.75rem;
    width: 92.25%;
  }
  .p-mv__lead-wrap {
    background-image: url(../images/mv/mv04-sp.avif);
    background-position: center;
    margin-top: -21.375rem;
    padding-block: 24.375rem 2.5rem;
  }
  .p-mv__lead-img {
    max-width: 37.5rem;
    padding-inline: 0.625rem;
  }
  .p-mv__lead-text {
    font-size: 1.5rem;
    letter-spacing: -0.05em;
    margin-top: 1.375rem;
  }
  .p-mv__lead-text span {
    font-size: 1.25rem;
  }
  .p-product-detail__wrap {
    flex-direction: column;
    gap: 0.9375rem;
    margin-top: 2.6875rem;
  }
  .p-product-detail__img {
    max-width: 100%;
    padding-top: 0;
  }
  .p-product-detail__name {
    font-size: 1.5rem;
    letter-spacing: -0.02em;
  }
  .p-product-detail__release-date {
    font-size: 1.25rem;
    margin-top: 0.8125rem;
    padding-block: 0.375rem 0.1875rem;
  }
  .p-product-detail__term {
    font-size: 1.25rem;
    margin-top: 1.1875rem;
  }
  .p-product-detail__description {
    font-size: 1rem;
  }
  .p-product-detail__description span {
    margin-top: 1.5625rem;
  }
  .p-product-detail__btn-wrap {
    margin-top: 3rem;
  }
  .p-product-detail__description .pc-only {
    display: none;
  }
  .p-product-detail__description .sp-only {
    display: block;
  }
  .p-recording-cards {
    scroll-margin-top: 6.25rem;
  }
  .p-recording-cards__bg {
    border-width: 1px;
    height: 12.25rem;
    top: 12%;
  }
  .p-recording-cards__bg::before,
  .p-recording-cards__bg::after {
    height: 4.375rem;
    width: 9.6875rem;
  }
  .p-recording-cards__bg::before {
    top: -1.375rem;
  }
  .p-recording-cards__bg::after {
    bottom: -1.375rem;
  }
  .p-recording-cards__bg span::before,
  .p-recording-cards__bg span::after {
    height: 13.125rem;
    width: 9.0625rem;
  }
  .p-recording-cards__bg span::before {
    top: -6.625rem;
  }
  .p-recording-cards__bg span::after {
    bottom: -6.625rem;
  }
  .p-recording-cards__title::before {
    background-image: url(../images/recording-cards/deco01-sp.avif);
    top: -3.4375rem;
    width: 8rem;
  }
  .p-recording-cards__text {
    font-size: 1rem;
    margin-top: -0.9375rem;
  }
  .p-recording-cards__text::after {
    background-image: url(../images/recording-cards/deco01-sp.avif);
    bottom: -4.375rem;
    width: 8rem;
  }
  .p-recording-cards__type-bg::after {
    background-image: url(../images/recording-cards/bg-sp.avif);
  }
  .p-recording-cards__type-item {
    padding-block: 3.75rem;
  }
  .p-recording-cards__type-item:first-of-type {
    padding-block: 4.25rem 3.75rem;
  }
  .p-recording-cards__type-item:last-of-type {
    padding-bottom: 2rem;
  }
  .p-recording-cards__princess-border-outer {
    -webkit-mask-image: linear-gradient(black, black), linear-gradient(black, black), linear-gradient(black, black), linear-gradient(black, black), radial-gradient(circle at 0 0, transparent 1.1875rem, black 1.1875rem, black 1.3125rem, transparent 1.3125rem), radial-gradient(circle at 100% 0, transparent 1.1875rem, black 1.1875rem, black 1.3125rem, transparent 1.3125rem), radial-gradient(circle at 0 100%, transparent 1.1875rem, black 1.1875rem, black 1.3125rem, transparent 1.3125rem), radial-gradient(circle at 100% 100%, transparent 1.1875rem, black 1.1875rem, black 1.3125rem, transparent 1.3125rem);
    -webkit-mask-size: calc(100% - 2.625rem) 0.125rem, calc(100% - 2.625rem) 0.125rem, 0.125rem calc(100% - 2.625rem), 0.125rem calc(100% - 2.625rem), 1.3125rem 1.3125rem, 1.3125rem 1.3125rem, 1.3125rem 1.3125rem, 1.3125rem 1.3125rem;
    mask-image: linear-gradient(black, black), linear-gradient(black, black), linear-gradient(black, black), linear-gradient(black, black), radial-gradient(circle at 0 0, transparent 1.1875rem, black 1.1875rem, black 1.3125rem, transparent 1.3125rem), radial-gradient(circle at 100% 0, transparent 1.1875rem, black 1.1875rem, black 1.3125rem, transparent 1.3125rem), radial-gradient(circle at 0 100%, transparent 1.1875rem, black 1.1875rem, black 1.3125rem, transparent 1.3125rem), radial-gradient(circle at 100% 100%, transparent 1.1875rem, black 1.1875rem, black 1.3125rem, transparent 1.3125rem);
    mask-size: calc(100% - 2.625rem) 0.125rem, calc(100% - 2.625rem) 0.125rem, 0.125rem calc(100% - 2.625rem), 0.125rem calc(100% - 2.625rem), 1.3125rem 1.3125rem, 1.3125rem 1.3125rem, 1.3125rem 1.3125rem, 1.3125rem 1.3125rem;
  }
  .p-recording-cards__princess-border-wrap {
    height: 92.5%;
    width: 94.2%;
  }
  .p-recording-cards__type {
    gap: 0.625rem;
    margin-top: 2.5rem;
  }
  .p-recording-cards__type-item.p-recording-cards__type-item--princess .p-recording-cards__type::before,
  .p-recording-cards__type-item.p-recording-cards__type-item--fairy .p-recording-cards__type::before,
  .p-recording-cards__type-item.p-recording-cards__type-item--angel .p-recording-cards__type::before {
    height: 3.4375rem;
    top: -3.75rem;
    width: 3.4375rem;
  }
  .p-recording-cards__type-ja {
    font-size: 1rem;
  }
  .p-recording-cards__type-en::before,
  .p-recording-cards__type-en::after {
    height: 1.125rem;
    width: 1.125rem;
  }
  .p-recording-cards__type-en::before {
    left: -1.75rem;
  }
  .p-recording-cards__type-en::after {
    right: -1.75rem;
  }
  .p-recording-cards__type-item.p-recording-cards__type-item--princess .p-recording-cards__type-en {
    max-width: 17.1875rem;
  }
  .p-recording-cards__type-item.p-recording-cards__type-item--fairy .p-recording-cards__type-en {
    max-width: 9.9375rem;
  }
  .p-recording-cards__type-item.p-recording-cards__type-item--angel .p-recording-cards__type-en {
    max-width: 11.125rem;
  }
  .p-recording-cards__type-item.p-recording-cards__type-item--bnp .p-recording-cards__type-en {
    max-width: 6.5625rem;
  }
  .p-recording-cards__type-lead {
    font-size: 1rem;
  }
  .p-recording-cards__type-text {
    margin-inline: auto;
    max-width: 31.25rem;
    padding-inline: 1.4375rem 0.625rem;
    text-align: left;
    text-indent: -0.8125rem;
    width: 100%;
  }
  .p-recording-cards__swiper {
    margin-top: 1.875rem;
    -webkit-mask-image: linear-gradient(to right, transparent, black 8.875rem, black calc(100% - 8.875rem), transparent);
    mask-image: linear-gradient(to right, transparent, black 8.875rem, black calc(100% - 8.875rem), transparent);
  }
  .p-recording-cards__swiper .swiper {
    padding-block: 1.25rem;
  }
  .p-recording-cards__swiper .swiper-slide {
    width: 12.9375rem;
    will-change: auto;
  }
  .p-recording-cards__swiper .swiper-slide img {
    border-width: 0.125rem;
    box-shadow: 0 0 0.9375rem rgba(0, 0, 0, 0.5);
  }
  .p-recording-cards__swiper .swiper-slide-active img {
    border-radius: 0.625rem;
    box-shadow: 0 0 0.9375rem var(--white);
  }
  .p-recording-cards__swiper .swiper-button-prev,
  .p-recording-cards__swiper .swiper-button-next {
    height: 3rem;
    width: 3rem;
  }
  .p-recording-cards__swiper .swiper-button-prev {
    left: 15%;
  }
  .p-recording-cards__swiper .swiper-button-next {
    right: 15%;
  }
  .p-recording-cards__icons {
    flex-direction: column;
    gap: 1.0625rem;
    margin-top: 0.625rem;
  }
  .p-recording-cards__icons-deco {
    height: 2.6875rem;
    width: 2rem;
  }
  .p-recording-cards__icons-deco--left {
    transform: rotate(-90deg) scaleY(-1);
  }
  .p-recording-cards__icons-deco--right {
    transform: rotate(90deg);
  }
  .p-recording-cards__icons-list {
    gap: 0.75rem 1rem;
    max-width: 20rem;
  }
  .p-recording-cards__icons-item {
    height: 2.5rem;
    width: 2.5rem;
  }
  .p-recording-cards-modal__close {
    font-size: 1rem;
    margin-bottom: -1.875rem;
    max-width: 34.375rem;
    padding-right: 0.5rem;
    position: relative;
    width: 92%;
    z-index: 2;
  }
  .p-recording-cards-modal__inner {
    height: 62.5vh;
    max-height: 34.375rem;
    max-width: 34.375rem;
    min-height: 28.125rem;
    overflow-y: auto;
    width: 92%;
  }
  .p-recording-cards-modal__title {
    gap: 0.5rem;
    margin-inline: 0.9375rem;
    margin-top: -0.625rem;
    padding-block: 0.3125rem;
  }
  .p-recording-cards-modal__title-icon {
    height: 1.5625rem;
    width: 1.5625rem;
  }
  .p-recording-cards__type-item.p-recording-cards__type-item--bnp .p-recording-cards-modal__title-icon {
    height: 0.9375rem;
    width: 0.9375rem;
  }
  .p-recording-cards-modal__title-text {
    font-size: 1.5rem;
    line-height: 1.3;
  }
  .p-recording-cards-modal__card {
    gap: 1rem;
    margin-top: 1.5rem;
  }
  .p-recording-cards-modal__card-label {
    font-size: 1.5rem;
    margin-bottom: 0.625rem;
  }
  .p-recording-cards-modal__img {
    aspect-ratio: 344/480;
    height: auto;
    width: 9.8125rem;
  }
  .p-title {
    max-width: 23.875rem;
  }
  .p-title::after {
    background-image: url(../images/common/deco04-sp.svg);
    bottom: -1.3125rem;
  }
  .p-title__en {
    font-size: 1rem;
  }
  .p-title__ja {
    font-size: 2.25rem;
    margin-top: 0.5rem;
  }
  .p-title__ja::before,
  .p-title__ja::after {
    height: 1.25rem;
    width: 1.25rem;
  }
  .p-title__ja::before {
    left: -1.5625rem;
  }
  .p-title__ja::after {
    right: -1.5625rem;
  }
  .pc-only {
    display: none;
  }
  .sp-only {
    display: block;
  }
}

@media (max-width: 600px){
  .p-autographed-cards__title {
    margin-top: 4.125rem;
    max-width: 24.3125rem;
  }
  .p-mv__lead-img {
    max-width: 24.5rem;
  }
}

@media (max-width: 500px){
  .p-opening__text {
    font-size: 1.125rem;
  }
  .p-opening__text-medium {
    font-size: 1.5rem;
  }
  .p-opening__text-semibold {
    font-size: 1.5rem;
  }
  .p-opening__text-large {
    font-size: 2.25rem;
  }
}

@media (max-width: 375px){
  html {
    font-size: 4.2666666667vw;
  }
}

@media (any-hover: hover){
  a:hover {
    opacity: 0.7;
  }
  .p-autographed-cards-modal__close:hover {
    opacity: 0.7;
  }
  .c-cvr:hover {
    opacity: 0.7;
  }
  .p-cvr-modal__close:hover::before {
    transform: rotate(90deg);
  }
  .p-header__hamburger:hover::before {
    transform: rotate(90deg);
  }
  .p-header__drawer-logo.is-visible:hover {
    opacity: 0.7;
  }
  .p-recording-cards-modal__close:hover {
    opacity: 0.7;
  }
}

@media (forced-colors: active){
  :where(mark) {
    /*
    * In forced-colors mode, the color of the mark element may not change, which can be problematic. Use system colors in forced-colors mode.
    * @see https://adrianroselli.com/2017/12/tweaking-text-level-styles.html#MarkWHCM
    */
    background-color: Highlight;
    color: HighlightText;
  }
}

@media print{
  :where(mark) {
    border-style: dotted;
    /*
    * Not all printers support color, and users might print in grayscale.
    * It's worth adding a non-disruptive style that scales with the text, as an alternative to relying only on background color.
    * @see https://adrianroselli.com/2017/12/tweaking-text-level-styles.html#MarkPrint
    */
    border-width: 1px;
  }
}