:root {
  --l-inner: 1200;
  --l-inner-lg: 1080;
  --l-inner-md: 1000;
}
:root {
  --padding-pc: 3.3333%;
  --padding-sp: 5.71%;
}
:root {
  --font-family-base: "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN",
    "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  --font-en: "Edu TAS Beginner", cursive;
}
:root {
  --font-size-base: 16;
}
:root {
  --color-base: #701738;
  --color-white: #fff;
  --color-black: #000;
  --color-red: #d70061;
  --color-red-rose: #e7336b;
  --color-red-light: #e7336e;
  --color-red-lighter: #e6007e;
  --color-pink: #f7c7c6;
  --color-pink-light: #f9d2d4;
  --color-pink-lighter: #f9e9f0;
  --color-pink-lightest: #fadbda;
  --color-green: #41b8a4;
  --color-green-light: #c9eae5;
  --color-green-lighter: #e9f9f7;
  --color-white-light: #f9f9f9;
  --color-gray: #fff4f4;
  --color-gray-light: #e9f6f4;
  --color-yellow: #fffb08;
  --color-yellow-light: #fff9c4;
  --gradient-pink: linear-gradient(180deg, #fff 0%, #f9d2d4 86%);
}
:root {
  --z-index-base: 0;
  --z-index-back: -1;
  --z-index-front: 1;
} /*! destyle.css v4.0.1 | MIT License | https://github.com/nicolas-cusan/destyle.css
  をベースに作成
*/
:where(*, ::before, ::after) {
  box-sizing: border-box;
  min-width: 0;
  border-width: 0;
  border-style: solid;
}
:where(:root) {
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  tab-size: 4;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}
:where(body) {
  margin: 0;
}
:where(main) {
  display: block;
}
:where(p, table, blockquote, address, pre, iframe, form, figure, dl) {
  margin: 0;
}
:where(h1, h2, h3, h4, h5, h6) {
  margin: 0;
  font-weight: inherit;
  font-size: inherit;
}
:where(ul, ol) {
  margin: 0;
  padding: 0;
  list-style: none;
}
:where(dt) {
  font-weight: bold;
}
:where(dd) {
  margin-left: 0;
}
:where(hr) {
  box-sizing: content-box;
  height: 0;
  margin: 0;
  clear: both;
  overflow: visible;
  border-top-width: 1px;
  color: inherit;
}
:where(pre) {
  font-size: inherit;
  font-family: monospace, monospace;
}
:where(address) {
  font-style: inherit;
}
:where(a) {
  background-color: rgba(0, 0, 0, 0);
  color: inherit;
  text-decoration: none;
}
:where(abbr[title]) {
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted;
}
:where(b, strong) {
  font-weight: bolder;
}
:where(code, kbd, samp) {
  font-size: inherit;
  font-family: monospace, monospace;
}
:where(small) {
  font-size: 80%;
}
:where(sub, sup) {
  position: relative;
  font-size: 75%;
  line-height: 0;
  vertical-align: baseline;
}
:where(sub) {
  bottom: -0.25em;
}
:where(sup) {
  top: -0.5em;
}
:where(svg, img, embed, object, iframe) {
  vertical-align: bottom;
}
:where(button, input, optgroup, select, textarea) {
  appearance: none;
  margin: 0;
  padding: 0;
  border-radius: 0;
  background: rgba(0, 0, 0, 0);
  color: inherit;
  font: inherit;
  text-align: inherit;
  text-transform: inherit;
  vertical-align: middle;
}
:where(button, [type="button"], [type="reset"], [type="submit"]) {
  cursor: pointer;
}
:where(
    button:disabled,
    [type="button"]:disabled,
    [type="reset"]:disabled,
    [type="submit"]:disabled
  ) {
  cursor: default;
}
:where(:-moz-focusring) {
  outline: auto;
}
:where(select:disabled) {
  opacity: inherit;
}
:where(option) {
  padding: 0;
}
:where(fieldset) {
  min-width: 0;
  margin: 0;
  padding: 0;
}
:where(legend) {
  padding: 0;
}
:where(progress) {
  vertical-align: baseline;
}
:where(textarea) {
  overflow: auto;
}
:where(
    [type="number"]::-webkit-inner-spin-button,
    [type="number"]::-webkit-outer-spin-button
  ) {
  height: auto;
}
:where([type="search"]) {
  outline-offset: -2px;
}
:where([type="search"]::-webkit-search-decoration) {
  -webkit-appearance: none;
}
:where(::-webkit-file-upload-button) {
  -webkit-appearance: button;
  font: inherit;
}
:where([type="number"]) {
  -moz-appearance: textfield;
}
:where(label[for]) {
  cursor: pointer;
}
:where(details) {
  display: block;
}
:where(summary) {
  display: list-item;
}
:where([contenteditable]:focus) {
  outline: auto;
}
:where(table) {
  border-color: inherit;
  border-collapse: collapse;
}
:where(caption) {
  text-align: left;
}
:where(td, th) {
  padding: 0;
  vertical-align: top;
}
:where(th) {
  font-weight: bold;
  text-align: left;
}
:where([aria-busy="true" i]) {
  cursor: progress;
}
:where([aria-disabled="true" i], [disabled]) {
  cursor: not-allowed;
}
:where([aria-hidden="false" i][hidden]) {
  display: initial;
}
:where([aria-hidden="false" i][hidden]:not(:focus)) {
  clip: rect(0, 0, 0, 0);
  position: absolute;
}
:where(html) {
  font-size: calc(var(--font-size-base) * 1px);
}
:where(:root) {
  -webkit-hyphens: auto;
  hyphens: auto;
  line-break: strict;
  word-break: normal;
  overflow-wrap: anywhere;
  text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  overflow-x: clip;
  line-height: 1.5;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  color: var(--color-base);
  font-family: var(--font-family-base);
}
:where(body) {
  min-block-size: 100svb;
}
:where(
    a,
    area,
    button,
    [role="button"],
    input:not([type="range"]),
    label,
    select,
    summary,
    textarea
  ) {
  touch-action: manipulation;
}
:where(a) {
  color: inherit;
  text-decoration: none;
  cursor: pointer;
  opacity: unset;
}
:where(img) {
  width: 100%;
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}
:where(dialog) {
  width: unset;
  max-width: unset;
  height: unset;
  max-height: unset;
  padding: unset;
  overflow: unset;
  border: unset;
  background-color: unset;
  color: unset;
}
:root:has(dialog[open]) {
  overflow: hidden;
}
::backdrop {
  background-color: unset;
}
textarea {
  field-sizing: content;
  min-height: 4lh;
}
html:has(.loading) {
  overflow: hidden;
  scrollbar-gutter: stable;
}
body.loading.is-animating::after {
  transform: translate(-50%, -50%) translateY(0);
  opacity: 1;
  transition: opacity 1.2s ease-out, transform 1.2s ease-out;
}
body.loading.is-fading-out::before {
  opacity: 0;
  transition: opacity 1.2s ease-out;
}
body.loading.is-fading-out::after {
  transition: all 1.2s ease-in-out;
}
body.loading.is-completed::before,
body.loading.is-completed::after {
  display: none;
}
body.loading .js-mv-copy {
  opacity: 0;
}
body.page-transition .l-main {
  opacity: 0;
}
.l-footer {
  margin-top: -6.25rem;
}
.l-inner {
  width: 100%;
  max-width: calc(var(--l-inner) * 1px + var(--padding-pc) * 2);
  height: inherit;
  margin: 0 auto;
  padding-inline: var(--padding-pc);
}
.l-inner._md {
  max-width: calc(var(--l-inner-md) * 1px + var(--padding-pc) * 2);
}
.l-inner._lg {
  max-width: calc(var(--l-inner-lg) * 1px + var(--padding-pc) * 2);
}
.l-main._page {
  margin-top: 5rem;
}
.l-page {
  margin-block: 5.9375rem;
}
.l-page._no-bottom {
  margin-bottom: 0;
}
.c-accordion summary::-webkit-details-marker {
  display: none;
}
.c-accordion__title {
  display: grid;
  position: relative;
  grid-template-columns: 1fr auto;
  align-items: center;
  width: 100%;
  padding: 0.75rem 1.0625rem 0.75rem 4rem;
  border-radius: 1.25rem 1.25rem 1.25rem 0;
  background: var(--color-gray);
  color: var(--color-red);
  font-weight: 700;
  font-size: 1.25rem;
  line-height: 1.5;
  text-decoration: none;
  cursor: pointer;
}
.c-accordion__title::before {
  position: absolute;
  top: 50%;
  left: 1.25rem;
  transform: translateY(-50%);
  content: "Q";
  color: var(--color-red-light);
  font-weight: 500;
  font-size: 2.5rem;
  line-height: 1.17;
  font-family: var(--font-en);
  opacity: 0.5;
}
.c-accordion__icon {
  margin-left: 1.25rem;
  border-radius: 1.7646875rem;
  box-shadow: 0.1470625rem 0.1470625rem 0 0 var(--color-red);
}
.c-accordion__icon img {
  position: relative;
  position: relative;
  right: 0;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 1.7646875rem;
  background: var(--color-red);
  transition: transform 0.3s ease-out;
}
.c-accordion.is-open .c-accordion__icon img {
  transform: rotate(-180deg);
}
.c-accordion__content {
  overflow: hidden;
  background: var(--color-white);
  color: var(--color-base);
  font-size: 1.125rem;
  letter-spacing: 0.03em;
  text-decoration: none;
}
.c-accordion__content-inner {
  padding: 0.75rem 1.25rem;
}
.c-banner__link {
  display: block;
  width: 100%;
  padding: 1.875rem 1.875rem 1.25rem;
  border-radius: 1.875rem;
  background-color: var(--color-white);
}
.c-banner__image {
  display: block;
  aspect-ratio: 280/120;
  width: 100%;
  overflow: hidden;
  border-radius: 0.625rem;
}
.c-banner__title {
  margin-top: 1.25rem;
  font-weight: 700;
  font-size: 1.375rem;
  line-height: 1.68;
  text-align: center;
}
.c-breadcrumb__items {
  display: flex;
  flex-wrap: wrap;
}
.c-breadcrumb__item {
  display: inline-block;
  position: relative;
  padding-right: 1.8125rem;
  color: var(--color-red-rose);
  font-weight: 400;
  font-weight: 500;
  font-size: 0.75rem;
  font-size: 0.8125rem;
  line-height: 2;
  line-height: 2.07;
  letter-spacing: 0.00325em;
}
.c-breadcrumb__item::before {
  display: block;
  position: absolute;
  top: 50%;
  right: 0.5rem;
  width: 0.625rem;
  height: 0.625rem;
  transform: translateY(-50%);
  background-color: var(--color-red-rose);
  content: "";
  content: "";
  clip-path: polygon(45% 9%, 75% 51%, 45% 90%, 30% 90%, 60% 50%, 30% 10%);
}
.c-breadcrumb__item:last-child::before {
  display: none;
}
.c-breadcrumb__link {
  text-transform: uppercase;
}
.c-button {
  display: block;
  padding-block: 1.5rem;
  border: 0.1875rem solid var(--color-red-light);
  border-radius: 100vmax;
  background-color: var(--color-white);
  box-shadow: 0.25rem 0.25rem 0 var(--color-red-lighter);
  color: var(--color-red-lighter);
  color: var(--color-red-light);
  font-weight: 700;
  font-size: 1.25rem;
  line-height: 1;
  text-align: center;
  transition: transform 0.2s ease-out, box-shadow 0.2s ease-out;
}
.c-button._arrow {
  position: relative;
}
.c-button._arrow::after {
  position: absolute;
  top: 50%;
  right: 1.875rem;
  width: 0.75rem;
  height: 1.125rem;
  transform: translateY(-50%);
  background: url(../../assets/images/common/arrow-icon@2x.webp) center/cover
    no-repeat;
  content: "";
}
.c-button._small {
  padding-block: 1rem;
  font-size: 1rem;
}
.c-button._fit {
  display: inline-block;
  width: 100%;
  padding: 1.5625rem 3.75rem;
}
.c-button._2column {
  padding-block: 1.25rem;
  line-height: 1.4;
}
.c-button02 {
  display: block;
  position: relative;
}
.c-button02__text {
  padding-block: 4.0625rem;
  border-radius: 100vmax;
  background: var(--color-green);
  color: var(--color-white);
  font-weight: 700;
  font-size: 2.375rem;
  line-height: 1.5;
  letter-spacing: 0.01em;
  text-align: center;
}
.c-button02::before {
  position: absolute;
  top: -10.3125rem;
  left: 50%;
  width: 37.0625rem;
  height: 15.625rem;
  translate: -50% 0;
  background: url(../../assets/images/common/button-background@2x.webp)
    center/cover no-repeat;
  content: "";
}
.c-button02__balloonText {
  position: absolute;
  top: -4.75rem;
  left: calc(50% - 16.125rem);
  rotate: -4.377deg;
  color: var(--color-red-rose);
  font-weight: 900;
  font-size: 1.75rem;
  line-height: 1.44;
}
.c-button02__textNote {
  display: block;
  margin-top: 0.5rem;
  color: #fff;
  font-weight: 700;
  font-size: 1.375rem;
  line-height: 1.6818181818;
  text-align: center;
}
.c-button02._arrow {
  border-radius: 100vmax;
  box-shadow: 0.625rem 0.625rem 0 var(--color-green-light);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.c-button02._arrow::after {
  position: absolute;
  top: 50%;
  right: 2.5rem;
  width: 4.3125rem;
  height: 4.375rem;
  translate: 0 -50%;
  background: url(../../assets/images/common/circle-arrow.svg) center/cover
    no-repeat;
  content: "";
}
.c-button02._how::before {
  top: -7.5rem;
  width: 28.1875rem;
  height: 11.25rem;
  background: url(../../assets/images/common/button-background02@2x.webp)
    center/cover no-repeat;
}
.c-button02._how .c-button02__text {
  padding-block: 2.8125rem;
}
.c-button02._how .c-button02__balloonText {
  top: -3.125rem;
  left: calc(50% - 12.5rem);
  rotate: 0deg;
  color: var(--color-red-rose);
  font-size: 1.25rem;
}
.c-button02._cancer::before {
  background: url(../../assets/images/common/button-background03@2x.webp)
    center/cover no-repeat;
}
.c-button03 {
  display: block;
  position: relative;
  padding-block: 1.875rem;
  border: 0.1875rem solid var(--color-red-light);
  border-radius: 100vmax;
  background-color: var(--color-white);
  box-shadow: 0.3125rem 0.3125rem 0 var(--color-red-lighter);
  color: var(--color-red-lighter);
  color: var(--color-red-light);
  font-weight: 900;
  font-size: 1.5rem;
  line-height: 1.5;
  letter-spacing: 0.001em;
  text-align: center;
  transition: transform 0.2s ease-out, box-shadow 0.2s ease-out;
}
.c-button03::before {
  position: absolute;
  top: 50%;
  right: 1.875rem;
  width: 1.1875rem;
  height: 1.8125rem;
  transform: translateY(-50%);
  background: url(../../assets/images/common/arrow-icon@2x.webp) center/cover
    no-repeat;
  content: "";
}
.c-button03::after {
  position: absolute;
  top: 0.4375rem;
  left: -1.75rem;
  width: 6.1875rem;
  height: 5.0625rem;
  transform: translateY(-50%);
  background: url(../../assets/images/common/icon-ribbon@2x.webp) center/cover
    no-repeat;
  content: "";
}
.c-button03__small {
  font-weight: 900;
  font-size: 1.625rem;
  line-height: 1.3846153846;
  letter-spacing: 0.01em;
}
.c-button03._none::after {
  display: none;
}
.c-card {
  display: flex;
  flex-direction: column;
  padding: 1.875rem;
  border-radius: 1.875rem;
  background: var(--color-white);
}
.c-card__image {
  display: block;
  aspect-ratio: 280/180;
  width: 100%;
  overflow: hidden;
  border-radius: 0.405rem;
}
.c-card__sponsor {
  margin-top: 0.625rem;
  color: var(--color-red-rose);
  font-weight: 700;
  font-size: 1.375rem;
  line-height: 1.68;
  text-align: center;
}
.c-card__title {
  margin-top: 0.625rem;
  color: var(--color-base);
  font-weight: 700;
  font-size: 1.75rem;
  line-height: 1.23;
  text-align: center;
}
.c-card__number {
  margin-top: 0.875rem;
  padding-block: 0.25rem;
  border-radius: 2.5rem;
  background: var(--color-pink-lightest);
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 1.68;
  letter-spacing: 0.054em;
  text-align: center;
}
.c-card__numberAccent {
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.12;
}
.c-card__text {
  margin-top: 0.875rem;
  font-weight: 500;
  font-size: 1rem;
  line-height: 1.68;
  letter-spacing: 0.048em;
  text-align: justify;
}
.c-card__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.5rem;
}
.c-drawer__button {
  display: flex;
  position: relative;
  align-items: center;
  justify-content: center;
  width: clamp(
    calc(100 * 375 / 540 / 16 * 1rem),
    calc(100 / 540 * 100vw),
    6.25rem
  );
  height: clamp(
    calc(100 * 375 / 540 / 16 * 1rem),
    calc(100 / 540 * 100vw),
    6.25rem
  );
  border-radius: 0 0 0
    clamp(calc(20 * 375 / 540 / 16 * 1rem), calc(20 / 540 * 100vw), 1.25rem);
  background-color: var(--color-red-light);
  box-shadow: 0 0 2rem rgba(0, 0, 0, 0);
  transition: all 0.3s ease-out;
}
.c-drawer__button::before {
  position: absolute;
  width: 100%;
  inset: auto auto
    clamp(calc(26 * 375 / 540 / 16 * 1rem), calc(26 / 540 * 100vw), 1.625rem)
    50%;
  translate: -50% 0;
  content: "OPEN";
  color: #fff;
  font-weight: 900;
  font-size: clamp(
    calc(20 * 375 / 540 / 16 * 1rem),
    calc(20 / 540 * 100vw),
    1.25rem
  );
  line-height: 1;
  text-align: center;
}
.c-drawer__button[aria-expanded="true"]::before {
  content: "CLOSE";
}
.c-drawer__button._close {
  position: fixed;
  top: 0;
  right: 0;
}
.c-drawer__dialog.is-close .c-drawer__button._close {
  pointer-events: none;
}
.c-drawer__button._close::before {
  content: "CLOSE";
}
.c-drawer__line,
.c-drawer__line::before,
.c-drawer__line::after {
  display: block;
  position: absolute;
  width: clamp(
    calc(55 * 375 / 540 / 16 * 1rem),
    calc(55 / 540 * 100vw),
    3.4375rem
  );
  height: clamp(
    calc(3 * 375 / 540 / 16 * 1rem),
    calc(3 / 540 * 100vw),
    0.1875rem
  );
  background-color: var(--color-blue);
  background-color: #fff;
  content: "";
  transition: all 0.3s ease-out;
}
.c-drawer__line {
  inset: clamp(
      calc(30 * 375 / 540 / 16 * 1rem),
      calc(30 / 540 * 100vw),
      1.875rem
    )
    auto auto 50%;
  translate: -50% 0;
  background-color: rgba(0, 0, 0, 0);
}
.c-drawer__line::before {
  top: clamp(calc(7 * 375 / 540 / 16 * 1rem), calc(7 / 540 * 100vw), 0.4375rem);
}
.c-drawer__line::after {
  bottom: clamp(
    calc(7 * 375 / 540 / 16 * 1rem),
    calc(7 / 540 * 100vw),
    0.4375rem
  );
}
.c-drawer__dialog.is-open .c-drawer__button._close .c-drawer__line,
.c-drawer__button[aria-expanded="true"] .c-drawer__line {
  background-color: rgba(0, 0, 0, 0);
}
.c-drawer__dialog.is-open .c-drawer__button._close .c-drawer__line::before,
.c-drawer__button[aria-expanded="true"] .c-drawer__line::before {
  top: 0;
  transform: rotate(25deg);
}
.c-drawer__dialog.is-open .c-drawer__button._close .c-drawer__line::after,
.c-drawer__button[aria-expanded="true"] .c-drawer__line::after {
  bottom: 0;
  transform: rotate(-25deg);
}
.c-drawer__dialog {
  display: block;
  width: 100vw;
  height: 100dvh;
  max-height: 100dvh;
  inset: 0;
  inset-block: 0;
  inset-inline: auto 0;
  overflow-y: auto;
  -ms-overflow-style: none;
  display: grid;
  justify-content: end;
  clip-path: inset(0 0 0 100%);
  scrollbar-width: none;
}
.c-drawer__dialog::-webkit-scrollbar {
  display: none;
}
.c-drawer__dialog.is-open {
  animation: modalContainerOpen 0.3s ease-out forwards;
}
.c-drawer__dialog.is-close {
  animation: modalContainerClose 0.3s ease-out forwards;
}
.c-drawer__dialog::backdrop {
  background-color: rgba(0, 0, 0, 0.2);
  opacity: 0;
  transition: opacity 0.3s ease-out, transform 0.3s ease-out,
    background-color 0.3s ease-out;
}
.c-drawer__dialog.is-open::backdrop {
  opacity: 1;
}
.c-drawer__dialog.is-close::backdrop {
  opacity: 0;
}
.c-drawer__dialog.is-open .c-drawer__container {
  animation: modalContainerOpen 0.3s ease-out forwards;
}
.c-drawer__dialog.is-close .c-drawer__container {
  animation: modalContainerClose 0.3s ease-out forwards;
}
.c-drawer__container {
  height: 100%;
  height: 100dvh;
  overflow: auto;
  background-color: var(--color-gray);
  scrollbar-width: none;
  transition: transform 0.3s ease-out;
  -ms-overflow-style: none;
  max-width: clamp(
    calc(540 * 375 / 540 / 16 * 1rem),
    calc(540 / 540 * 100vw),
    33.75rem
  );
  padding: clamp(
    calc(30 * 375 / 540 / 16 * 1rem),
    calc(30 / 540 * 100vw),
    1.875rem
  );
}
.c-drawer__container::-webkit-scrollbar {
  display: none;
}
@keyframes modalContainerOpen {
  0% {
    border-radius: 0 0 0
      clamp(calc(20 * 375 / 540 / 16 * 1rem), calc(20 / 540 * 100vw), 1.25rem);
    clip-path: inset(0 0 100% 100%);
  }
  100% {
    border-radius: 0 0 0 0;
    clip-path: inset(0 0 0 0);
  }
}
@keyframes modalContainerClose {
  0% {
    border-radius: 0 0 0 0;
    clip-path: inset(0 0 0 0);
  }
  100% {
    border-radius: 0 0 0
      clamp(calc(20 * 375 / 540 / 16 * 1rem), calc(20 / 540 * 100vw), 1.25rem);
    clip-path: inset(0 0 100% 100%);
  }
}
.c-drawer__nav {
  padding: clamp(
      calc(30 * 375 / 540 / 16 * 1rem),
      calc(30 / 540 * 100vw),
      1.875rem
    )
    clamp(calc(30 * 375 / 540 / 16 * 1rem), calc(30 / 540 * 100vw), 1.875rem)
    clamp(calc(20 * 375 / 540 / 16 * 1rem), calc(20 / 540 * 100vw), 1.25rem);
  border-radius: clamp(
    calc(60 * 375 / 540 / 16 * 1rem),
    calc(60 / 540 * 100vw),
    3.75rem
  );
  background: #fff;
}
.c-drawer__item a {
  display: block;
  padding-block: clamp(
    calc(18 * 375 / 540 / 16 * 1rem),
    calc(18 / 540 * 100vw),
    1.125rem
  );
  border-bottom: 1px dashed var(--color-base);
  color: var(--color-red);
  font-weight: 900;
  transition: color 0.2s ease-out, background-color 0.2s ease-out;
}
.c-drawer__item a:focus {
  outline: none;
}
.c-drawer__links {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin-top: clamp(
    calc(20 * 375 / 540 / 16 * 1rem),
    calc(20 / 540 * 100vw),
    1.25rem
  );
  gap: clamp(
    calc(10 * 375 / 540 / 16 * 1rem),
    calc(10 / 540 * 100vw),
    0.625rem
  );
}
.c-drawer__link {
  place-content: center;
  padding: clamp(
      calc(27 * 375 / 540 / 16 * 1rem),
      calc(27 / 540 * 100vw),
      1.6875rem
    )
    clamp(calc(20 * 375 / 540 / 16 * 1rem), calc(20 / 540 * 100vw), 1.25rem);
  border-radius: clamp(
    calc(10 * 375 / 540 / 16 * 1rem),
    calc(10 / 540 * 100vw),
    0.625rem
  );
  color: #fff;
  font-weight: 900;
  font-size: clamp(
    calc(16 * 375 / 540 / 16 * 1rem),
    calc(16 / 540 * 100vw),
    1rem
  );
  line-height: 1;
  text-align: center;
  transition: filter 0.2s ease-out;
}
.c-drawer__link._chart {
  background-color: var(--color-red);
}
.c-drawer__link._form {
  background-color: var(--color-green);
}
.c-drawer__policy {
  margin-top: clamp(
    calc(20 * 375 / 540 / 16 * 1rem),
    calc(20 / 540 * 100vw),
    1.25rem
  );
  color: var(--color-red-light);
  font-weight: 900;
  text-align: center;
  transition: color 0.2s ease-out;
}
.c-drawer__bottom {
  position: relative;
  margin-top: clamp(
    calc(-30 * 375 / 540 / 16 * 1rem),
    calc(-30 / 540 * 100vw),
    -1.875rem
  );
}
.c-drawer__character {
  max-width: 90.2083333333%;
}
.c-drawer__sns {
  display: grid;
  position: absolute;
  right: clamp(
    calc(10 * 375 / 540 / 16 * 1rem),
    calc(10 / 540 * 100vw),
    0.625rem
  );
  bottom: clamp(calc(80 * 375 / 540 / 16 * 1rem), calc(80 / 540 * 100vw), 5rem);
  grid-template-columns: repeat(3, 1fr);
  max-width: clamp(
    calc(210 * 375 / 540 / 16 * 1rem),
    calc(210 / 540 * 100vw),
    13.125rem
  );
  gap: clamp(calc(12 * 375 / 540 / 16 * 1rem), calc(12 / 540 * 100vw), 0.75rem);
}
.c-drawer__sns img {
  transition: filter 0.2s ease-out;
}
.c-flow {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4.75rem;
}
.c-flow__item {
  position: relative;
}
.c-flow__item::before {
  position: absolute;
  bottom: -4.1875rem;
  left: 50%;
  width: 4.75rem;
  height: 2.1875rem;
  transform: translateX(-50%);
  background-color: var(--color-green);
  content: "";
  clip-path: polygon(50% 2.1875rem, 0% 0%, 4.75rem 0%);
}
.c-flow__item:last-child::before {
  display: none;
}
.c-flow__title {
  display: flex;
  align-items: center;
  margin-left: 3.125rem;
  gap: 1.25rem;
  color: var(--color-red);
  font-weight: 900;
  font-size: 3.25rem;
  line-height: 0.9038461538;
}
.c-flow__number {
  z-index: 1;
  position: relative;
  flex-shrink: 0;
  color: var(--color-white);
  font-weight: 500;
  font-size: 4.375rem;
  line-height: 1;
  font-family: var(--font-en);
}
.c-flow__number._01::before,
.c-flow__number._01::after {
  content: "01";
}
.c-flow__number._02::before,
.c-flow__number._02::after {
  content: "02";
}
.c-flow__number._03::before,
.c-flow__number._03::after {
  content: "03";
}
.c-flow__number::before {
  z-index: -2;
  position: absolute;
  top: 0;
  left: 0;
  color: var(--color-red-rose);
  -webkit-text-stroke: 0.25rem var(--color-red-rose);
}
.c-flow__number::after {
  z-index: -3;
  position: absolute;
  top: 0.3125rem;
  left: 0.3125rem;
  width: 100%;
  color: var(--color-red-rose);
}
.c-flow__content {
  margin-top: -1.5rem;
  padding: 2rem 3.125rem 2.5rem;
  border-radius: 1.875rem;
  background: var(--color-gray);
}
.c-flow__content-subTitle {
  color: var(--color-red);
  font-weight: 900;
  font-size: 1.5rem;
  line-height: 1.9583333333;
}
.c-flow__texts {
  margin-top: 0.5rem;
}
.c-flow__text {
  font-weight: 700;
  font-size: 1.375rem;
  line-height: 1.6818181818;
}
.c-flow02 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.875rem;
}
.c-flow02__card {
  position: relative;
  border-radius: 1.875rem;
  background: var(--color-red-rose);
}
.c-flow02__title {
  padding-block: 1.25rem;
  border-radius: 1.875rem 1.875rem 0 0;
  background: var(--color-green);
  color: var(--color-white);
  font-weight: 900;
  font-size: 1.375rem;
  line-height: 1.36;
  text-align: center;
}
.c-flow02__image {
  display: block;
  aspect-ratio: 340/210;
  width: 100%;
  overflow: hidden;
}
.c-flow02__text {
  padding: 1.875rem 2.5rem;
  border-radius: 0 0 1.875rem 1.875rem;
  color: var(--color-white);
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.054em;
  text-align: center;
}
.c-flow02__numberBlock {
  z-index: 1;
  position: absolute;
  top: -1.25rem;
  left: -1.875rem;
  content: "";
}
.c-flow02__number {
  z-index: 1;
  position: relative;
  color: var(--color-white);
  font-weight: 500;
  font-size: 3.375rem;
  line-height: 1;
  font-family: var(--font-en);
}
.c-flow02__number._01::before,
.c-flow02__number._01::after {
  content: "01";
}
.c-flow02__number._02::before,
.c-flow02__number._02::after {
  content: "02";
}
.c-flow02__number._03::before,
.c-flow02__number._03::after {
  content: "03";
}
.c-flow02__number::before {
  z-index: -2;
  position: absolute;
  top: 0;
  left: 0;
  color: var(--color-red-rose);
  -webkit-text-stroke: 0.25rem var(--color-red-rose);
}
.c-flow02__number::after {
  z-index: -3;
  position: absolute;
  top: 0.3125rem;
  left: 0.3125rem;
  width: 100%;
  color: var(--color-red-rose);
}
.c-heading__en {
  transform: rotate(-5deg);
  color: var(--color-green-light);
  font-weight: 500;
  font-size: 3rem;
  line-height: 0.9791666667;
  font-family: var(--font-en);
  text-align: center;
  text-transform: capitalize;
}
.c-heading__jp {
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  margin-top: 0.75rem;
  padding-bottom: 0.5rem;
  border-bottom: 0.1875rem solid var(--color-red-light);
  color: var(--color-red-light);
  font-weight: 900;
  font-size: 2rem;
  line-height: 1.46875;
  text-align: center;
}
.c-heading02__text {
  color: var(--color-red);
  font-weight: 900;
  font-size: 1.875rem;
  line-height: 1.5666666667;
  text-align: center;
}
.c-heading02__title {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1.25rem;
  gap: 0.125rem;
  color: var(--color-red);
  font-weight: 900;
  font-size: 3.75rem;
  line-height: 0.7833333333;
  letter-spacing: 0.0458333333em;
  text-align: center;
}
.c-heading02__titleLarge {
  display: block;
  margin-top: -1.1875rem;
  color: var(--color-red);
  font-weight: 900;
  font-size: 5.9375rem;
  line-height: 0.4947368421;
}
.c-heading03 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}
.c-heading03__titleEn {
  color: var(--color-green-light);
  font-weight: 500;
  font-size: 3rem;
  line-height: 0.9791666667;
  font-family: var(--font-en);
  text-align: center;
  text-transform: capitalize;
}
.c-heading03__image {
  width: 100%;
  max-width: 21.5625rem;
  margin-inline: auto;
}
.c-heading03__titleJp {
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  padding: 0 0.625rem 0.75rem;
  background: linear-gradient(transparent 53%, var(--color-pink) 47%);
  color: var(--color-red-light);
  font-weight: 900;
  font-size: 3rem;
  line-height: 0.9791666667;
  text-align: center;
}
.c-heading03__titleJp-small {
  font-size: 2.5rem;
}
.c-heading03._noImage .c-heading03__image {
  display: none;
}
.c-heading03._dark .c-heading03__titleEn {
  color: var(--color-green);
}
.c-heading04 {
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  padding-bottom: 0.5rem;
  border-bottom: 0.1875rem solid var(--color-red-light);
  color: var(--color-red-light);
  font-weight: 900;
  font-size: 2rem;
  line-height: 1.46875;
}
.c-heading05 {
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
}
.c-heading05__title {
  width: 30rem;
  padding-inline: 4.375rem;
  padding-block: 0.75rem;
  border: 0.3125rem solid var(--color-red-light);
  background: var(--color-red-light);
  color: var(--color-white);
  font-weight: 900;
  font-size: 1.75rem;
  line-height: 1;
  text-align: center;
  clip-path: polygon(0 0, 100% 0, 96% 50%, 100% 100%, 0 100%, 4% 50%);
}
.c-heading05__contents {
  display: flex;
  position: absolute;
  top: 50%;
  right: -3.125rem;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 7.5rem;
  height: 7.3125rem;
  gap: 0.125rem;
  transform: translateY(-50%);
  background: url(../../assets/images/common/icon-heart@2x.webp) center/contain
    no-repeat;
  content: "";
  color: var(--color-white);
  text-shadow: 0.1875rem 0.1875rem 0 #ec6d88, -0.1875rem -0.1875rem 0 #ec6d88,
    -0.1875rem 0.1875rem 0 #ec6d88, 0.1875rem -0.1875rem 0 #ec6d88,
    0rem 0.1875rem 0 #ec6d88, 0rem -0.1875rem 0 #ec6d88,
    -0.1875rem 0rem 0 #ec6d88, 0.1875rem 0rem 0 #ec6d88;
}
.c-heading05__number {
  font-weight: 600;
  font-size: 2.125rem;
  line-height: 1;
  font-family: var(--font-en);
}
.c-heading05__text {
  font-weight: 700;
  font-size: 1.375rem;
  line-height: 1;
}
.c-heading06 {
  position: relative;
}
.c-heading06__text {
  color: var(--color-red-light);
  font-weight: 900;
  font-size: 1.5rem;
  line-height: 1.9583333333;
}
.c-heading06__title {
  margin-top: 0.25rem;
  color: var(--color-red-light);
  font-weight: 900;
  font-size: 3.25rem;
  line-height: 0.9038461538;
}
.c-heading06__textAccent {
  position: absolute;
  top: -2.1875rem;
  left: -3.8125rem;
  transform: rotate(-5deg);
  color: var(--color-green-light);
  font-weight: 500;
  font-size: 3rem;
  line-height: 0.9791666667;
  font-family: var(--font-en);
  text-transform: capitalize;
}
.c-heading06._center {
  text-align: center;
}
.c-heading06._none .c-heading06__textAccent {
  display: none;
}
.c-heading07 {
  width: -moz-fit-content;
  width: fit-content;
  min-width: 30rem;
  margin-inline: auto;
  padding: 0.75rem 0.875rem;
  background: var(--color-green);
  color: #fff;
  font-weight: 900;
  font-size: 2rem;
  line-height: 1.46875;
  text-align: center;
  clip-path: polygon(0 0, 100% 0, 96% 51%, 100% 100%, 0 100%, 4% 50%);
}
.c-news__link {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 1.875rem;
  color: var(--color-white);
}
.c-news__meta {
  display: grid;
  grid-template-columns: repeat(2, auto);
  align-items: center;
  gap: 1.875rem;
}
.c-news__date {
  font-weight: 700;
  font-size: 1rem;
  line-height: normal;
}
.c-news__category {
  display: inline-block;
  width: 100%;
  min-width: 7.5rem;
  padding-block: 0.375rem;
  border-radius: 2.5rem;
  background: var(--color-base);
  color: var(--color-white);
  font-weight: 700;
  font-size: 0.9375rem;
  line-height: normal;
  text-align: center;
}
.c-news__title {
  position: relative;
  padding-right: 2.5rem;
  font-weight: 700;
  font-size: 1rem;
  line-height: normal;
  transition: -webkit-text-decoration 0.2s ease-out;
  transition: text-decoration 0.2s ease-out;
  transition: text-decoration 0.2s ease-out,
    -webkit-text-decoration 0.2s ease-out;
}
.c-news__title::before {
  position: absolute;
  top: 50%;
  right: 0.1103125rem;
  width: 2.0625rem;
  height: 2.0625rem;
  translate: 0 -50%;
  border-radius: 1.3235rem;
  background: url(../../assets/images/common/blog-arrow.svg) center/cover
    no-repeat;
  box-shadow: 0.1103125rem 0.1103125rem 0 0 var(--color-red);
  content: "";
  transition: box-shadow 0.2s ease-out, top 0.2s ease-out,
    translate 0.2s ease-out;
}
.c-news02__link {
  display: grid;
  grid-template-columns: 13.625rem 1fr;
  align-items: center;
  gap: 1.875rem;
}
.c-news02__meta {
  display: flex;
  align-items: center;
  gap: 1.875rem;
}
.c-news02__date {
  font-weight: 700;
  font-size: 1rem;
  line-height: normal;
}
.c-news02__category {
  display: inline-block;
  width: 100%;
  max-width: 7.5rem;
  padding-block: 0.375rem;
  border-radius: 2.5rem;
  background: var(--color-red-light);
  color: var(--color-white);
  font-weight: 700;
  font-size: 0.9375rem;
  line-height: normal;
  text-align: center;
}
.c-news02__title {
  position: relative;
  padding-right: 2.5rem;
  font-weight: 700;
  font-size: 1rem;
  line-height: normal;
  transition: -webkit-text-decoration 0.2s ease-out;
  transition: text-decoration 0.2s ease-out;
  transition: text-decoration 0.2s ease-out,
    -webkit-text-decoration 0.2s ease-out;
}
.c-news02__title::before {
  position: absolute;
  top: 50%;
  right: 0.1103125rem;
  width: 2.0625rem;
  height: 2.0625rem;
  translate: 0 -50%;
  border-radius: 1.3235rem;
  background: url(../../assets/images/common/blog-arrow.svg) center/cover
    no-repeat;
  box-shadow: 0.1103125rem 0.1103125rem 0 0 var(--color-red);
  content: "";
  transition: box-shadow 0.2s ease-out, top 0.2s ease-out,
    translate 0.2s ease-out;
}
.c-side__link {
  display: flex;
  padding-block: 1.25rem;
  background-image: repeating-linear-gradient(
    90deg,
    var(--color-base),
    var(--color-base) 0.0625rem,
    transparent 0.0625rem,
    transparent 0.1875rem
  );
  background-position: left -0.0625rem bottom;
  background-size: 300% 0.125rem;
  background-repeat: repeat-x;
  color: var(--color-red);
  font-weight: 900;
  font-size: 1rem;
  line-height: normal;
}
.c-side__item:first-child .c-side__link {
  padding-top: 0;
}
.p-campaign-link {
  z-index: 10;
  position: fixed;
  right: 3.4375rem;
  bottom: 2.5rem;
}
.p-campaign-link__link {
  display: block;
  max-width: 13.3125rem;
}
.p-cancer__blocks {
  display: grid;
  margin-top: 12.1875rem;
  gap: 1.875rem;
}
.p-cancer__block {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: start;
  padding: 3.75rem 3.125rem;
  gap: 3.75rem;
}
.p-cancer__block {
  padding: 3.125rem;
  border-radius: 3.75rem;
  background: var(--color-gray);
}
.p-cancer__block._risk {
  background-color: var(--color-yellow-light);
}
.p-cancer__block._breast01 {
  grid-template-columns: 465fr 595fr;
  gap: 2.5rem;
}
.p-cancer__block._block02 {
  grid-template-columns: 800fr 300fr;
  align-items: center;
  gap: 0;
  background-color: var(--color-yellow-light);
}
.p-cancer__blockContent {
  display: flex;
  flex-direction: column;
  gap: 1.875rem;
}
.p-cancer__blockTitle {
  color: var(--color-red-rose);
  font-weight: 900;
  font-size: 2rem;
  line-height: 1.46875;
  text-align: left;
}
.p-cancer__blocks._image .p-cancer__blockTitle {
  text-align: left;
}
.p-cancer__blockText {
  margin-top: 0;
  font-weight: 500;
  font-size: 1.25rem;
  line-height: 1.85;
}
.p-cancer__accent {
  color: var(--color-red-rose);
  font-weight: 700;
}
.p-cancer__accentLine {
  background-color: var(--color-red-light);
  color: #fff;
}
.p-cancer__note {
  margin: 0;
  color: var(--color-red-rose);
  line-height: 1.4;
}
.p-cancer__symptomsList {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 3rem 1.875rem;
  gap: 1.5rem;
  border: 0.125rem solid var(--color-red-rose);
  border-radius: 1.25rem;
  background: #fff;
}
.p-cancer__symptomsTitle {
  color: var(--color-red-rose);
  font-weight: 700;
  font-size: 1.75rem;
  line-height: 1.6785714286;
  letter-spacing: 0.1em;
  text-align: center;
}
.p-cancer__symptoms {
  display: flex;
  flex-direction: column;
  width: 100%;
  margin: 0;
  padding: 0;
  gap: 0.75rem;
  list-style: none;
}
.p-cancer__block._breast01 .p-cancer__symptoms {
  gap: 0.25rem;
}
.p-cancer__symptom {
  display: flex;
  align-items: center;
  gap: 1.25rem;
}
.p-cancer__symptomIcon {
  display: block;
  flex-shrink: 0;
  width: 1.4375rem;
  height: 1.4375rem;
}
.p-cancer__symptomIcon svg {
  width: 100%;
  height: 100%;
}
.p-cancer__symptomText {
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 2.0555555556;
}
.p-cancer__chartContainer {
  display: flex;
  align-items: center;
  justify-content: center;
}
.p-cancer__chartImage {
  max-width: 100%;
  height: auto;
}
.p-cancer__block._breast01 .p-cancer__chartContent {
  display: grid;
  grid-template-columns: 295fr 200fr;
  align-items: center;
  gap: 2rem;
}
.p-cancer-about {
  margin-top: 6.25rem;
  padding-block: 6.25rem;
  background-image: url(../../assets/images/common/dot-background@2x.webp);
  background-position: center;
  background-size: contain;
  background-repeat: repeat;
}
.p-cancer-about__flow {
  margin-top: 3.75rem;
}
.p-cancer-about__point {
  margin-top: 5.625rem;
}
.p-cancer-check {
  margin-top: 10.875rem;
}
.p-cancer-check__button {
  max-width: 45rem;
  margin-top: 8.3125rem;
  margin-inline: auto;
}
.p-cancer-how {
  margin-top: 7.1875rem;
  padding-block: 13.75rem 9.375rem;
  background: url(../../assets/images/common/background-wave@2x.webp) repeat-x
      top center/90rem 7.75rem,
    linear-gradient(
      to bottom,
      transparent 0%,
      transparent 7.5rem,
      var(--color-gray) 7.5rem,
      var(--color-gray) 100%
    );
}
.p-cancer-how__button {
  max-width: 55.5rem;
  margin-top: 9.375rem;
  margin-inline: auto;
}
.chart-page::before {
  z-index: 9999;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
  content: "";
  opacity: 1;
  pointer-events: none;
  transition: opacity 0.3s ease-out;
}
.chart-page.is-loaded::before {
  opacity: 0;
  pointer-events: none;
}
.chart-page.is-fade-complete::before {
  display: none;
}
.p-cancer__content {
  display: flex;
  flex-direction: column;
  gap: 1.875rem;
}
.p-cancer__title {
  margin: 0;
  color: var(--color-red-rose);
  font-weight: 900;
  font-size: 2rem;
  line-height: 1.46875;
}
.p-cancer__text {
  margin: 0;
  font-weight: 500;
  font-size: 1.25rem;
  line-height: 1.85;
}
.p-cancer__source {
  margin-top: 1.25rem;
  font-weight: 500;
  font-size: 1rem;
}
.p-chart {
  display: flex;
  position: relative;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 100svh;
  padding-block: 11.25rem 6.25rem;
  background: var(--color-gray);
}
.p-chart__contents {
  position: relative;
  padding-block: 5.625rem;
  border-radius: 6.25rem;
  background: var(--color-white);
}
.p-chart__heading {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
}
.p-chart__subTitle,
.p-chart__text {
  font-weight: 700;
  font-size: 1.25rem;
  line-height: 1.85;
  text-align: center;
}
.p-chart__title {
  color: var(--color-red);
  font-weight: 900;
  font-size: 3.75rem;
  line-height: 0.7833333333;
  letter-spacing: 0.05em;
  text-align: center;
}
.p-chart__title._flex {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-chart__title._medium {
  font-weight: 900;
  font-size: 2.5rem;
  line-height: 1.45;
  letter-spacing: 0.05em;
}
.p-chart__titleSmall {
  color: var(--color-red);
  font-weight: 900;
  font-size: 2rem;
  line-height: 1.46875;
  letter-spacing: 0.05em;
  text-align: center;
}
.p-chart__titleSmall._black {
  color: var(--color-base);
}
.p-chart__questionTitle {
  font-weight: 900;
  font-size: 2rem;
  line-height: 1.46875;
  letter-spacing: 0.05em;
  text-align: center;
}
.p-chart__text {
  margin-top: 2.375rem;
}
.p-chart__buttons {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 3.125rem;
  gap: 3.75rem;
}
.p-chart__button {
  text-align: center;
}
.p-chart._point .p-chart__contents::before {
  position: absolute;
  right: 2.5rem;
  bottom: 2.5rem;
  width: 11.75rem;
  height: 15.625rem;
  background: url(../../assets/images/common/pointing-character@2x.webp)
    center/cover no-repeat;
  content: "";
}
.p-chart._point._home .p-chart__contents::before {
  right: -0.625rem;
  bottom: -6.25rem;
}
.p-chart__textNote {
  margin-top: 2.625rem;
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.9285714286;
  letter-spacing: 0.03em;
  text-align: center;
}
.p-chart._home .p-chart__buttonsItem {
  width: 100%;
  max-width: 28.125rem;
}
.p-chart._question .p-chart__contents {
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 28.9375rem;
}
.p-chart._question .p-chart__buttonsItem {
  width: 100%;
  max-width: 18.75rem;
}
.p-chart._medical .p-chart__title {
  line-height: 1.2;
}
.p-chart._medical .p-chart__contents::before {
  position: absolute;
  right: 5rem;
  bottom: 3.75rem;
  width: 14.75rem;
  height: 20.4375rem;
  background: url(../../assets/images/about/point-character@2x.webp)
    center/cover no-repeat;
  content: "";
}
.p-chart._self .p-chart__contents::before {
  position: absolute;
  right: 4.375rem;
  bottom: 2.5rem;
  width: 12.875rem;
  height: 15.1875rem;
  background: url(../../assets/images/about/check-character@2x.webp)
    center/cover no-repeat;
  content: "";
}
.p-chart._no-symptoms .p-chart__heading {
  gap: 0.375rem;
}
.p-chart__image {
  width: 100%;
  max-width: 14.25rem;
  margin-inline: auto;
  margin-block: 3.125rem 2.875rem;
}
.p-check._none .p-check__container {
  display: none;
}
.p-check__contents {
  position: relative;
  margin-top: 2.375rem;
  padding: 4.625rem 6.25rem;
  border-radius: 3.75rem;
  background: url(../../assets/images/about/check-background@2x.webp)
    center/cover no-repeat;
}
.p-check__contents::before {
  position: absolute;
  top: -9.9375rem;
  right: 4.9375rem;
  width: 10.9375rem;
  height: 13.125rem;
  background: url(../../assets/images/about/check-character@2x.webp)
    center/cover no-repeat;
  content: "";
}
.p-check__text {
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.03em;
  text-align: center;
}
.p-check__lists {
  display: grid;
  grid-template-columns: 1fr auto;
  justify-content: space-between;
  margin-top: 2.875rem;
  gap: 1rem;
}
.p-check__list {
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
  font-weight: 700;
  font-size: 1.375rem;
  line-height: 1.6818181818;
}
.p-check__checkbox {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 1.25rem;
}
.p-check__checkbox input[type="checkbox"] {
  position: relative;
  top: 0.125rem;
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 0.1875rem;
  border-radius: 0.3125rem;
  background: var(--color-white);
  box-shadow: 0 0 0 0.3125rem var(--color-red-light);
}
.p-check__checkbox input[type="checkbox"]:checked::before {
  position: absolute;
  width: 0.75rem;
  height: 0.375rem;
  inset: 0.1875rem auto auto 0.125rem;
  transform: rotate(-45deg);
  border-bottom: 0.1875rem solid var(--color-red-light);
  border-left: 0.1875rem solid var(--color-red-light);
  content: "";
}
.p-check__items {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  width: 100%;
  max-width: 46.1875rem;
  margin-inline: auto;
  margin-top: 3.75rem;
  gap: 1.25rem;
}
.p-check__image {
  display: block;
  aspect-ratio: 233/232;
  width: 100%;
  overflow: hidden;
}
.p-check__containerText {
  margin-top: 2.375rem;
  color: var(--color-red-light);
  font-weight: 700;
  font-size: 1.375rem;
  line-height: 1.6818181818;
  text-align: center;
  text-decoration: underline;
}
.p-dot-background {
  position: relative;
  background-image: url(../../assets/images/common/dot-background@2x.webp);
  background-position: center;
  background-size: contain;
  background-repeat: repeat;
}
.p-faq__inner {
  display: grid;
  grid-template-columns: 15rem 1fr;
  grid-template-areas: "side content";
  align-items: start;
  gap: 2.5rem;
}
.p-faq__content {
  grid-area: content;
}
.p-faq__section + .p-faq__section {
  margin-top: 2rem;
}
.p-faq__sectionTitle {
  font-weight: 900;
  font-size: 2rem;
  line-height: 1.46875;
}
.p-faq__list {
  display: grid;
  margin-top: 2rem;
  gap: 2.5rem;
}
.p-faq__sidebar {
  position: sticky;
  top: 10rem;
  grid-area: side;
}
.p-faq__button {
  max-width: 33.25rem;
  margin-top: 3.75rem;
}
.p-footer {
  position: relative;
  padding-block: 5rem 0.875rem;
  background-image: url(../../assets/images/common/footer-background@2x.webp);
  background-position: bottom;
  background-size: 90rem 9.6875rem;
  background-repeat: repeat-x;
  color: var(--color-white);
}
.p-footer__character {
  display: block;
  z-index: 1;
  position: absolute;
  top: -26.875rem;
  left: 49%;
  width: 46.25rem;
  height: 25.4375rem;
  transform: translateX(-50%);
}
.p-footer__text {
  z-index: 2;
  position: absolute;
  top: 8.9375rem;
  left: calc(50% - 20rem);
  transform: rotate(-2deg);
  color: var(--color-red-rose);
  font-weight: 900;
  font-size: 1.75rem;
  line-height: 1;
}
.p-footer__inner {
  z-index: 0;
  position: relative;
}
.p-footer__lists {
  display: flex;
  justify-content: center;
  gap: 1.4375rem;
}
.p-footer__list {
  font-weight: 500;
  font-size: 0.9375rem;
  line-height: 2.6893333333;
}
.p-footer__copyright {
  display: block;
  font-weight: 500;
  font-size: 0.9375rem;
  letter-spacing: 0.06em;
  text-align: center;
}
.p-header {
  z-index: 100;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
}
.p-header__inner {
  display: grid;
  align-items: center;
  height: 5.9375rem;
}
.p-header__logo {
  position: absolute;
  top: 0;
  left: 0;
  padding: 0.9375rem 0.9375rem 0.625rem 3.125rem;
  border-radius: 0 0 1.5rem 0;
  background-color: var(--color-white);
}
.p-header__logo img {
  max-width: 14.125rem;
}
.p-header__nav {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  max-width: -moz-fit-content;
  max-width: fit-content;
  margin-right: 13.75rem;
  margin-left: auto;
  gap: 2.5rem;
}
.p-header__navKnow {
  display: grid;
  grid-auto-flow: column;
  align-items: center;
  padding: 0.125rem 1.25rem;
  gap: 40px;
  border-radius: 0.625rem;
  background-color: var(--color-gray);
}
.p-header__navTitle {
  font-weight: 700;
  font-size: 0.875rem;
}
.p-header__list {
  display: grid;
  grid-template-columns: repeat(2, auto);
  gap: 1.875rem;
}
.p-header__item a {
  color: var(--color-red);
  font-weight: 700;
  font-size: 1.25rem;
  transition: color 0.2s ease-out;
}
.p-header__item a:hover {
  color: var(--color-base);
}
.p-header__cahrt {
  font-weight: 700;
  font-size: 1.25rem;
  transition: color 0.2s ease-out;
}
.p-header__cahrt:hover {
  color: var(--color-red);
}
.p-header__drawer {
  display: block;
  z-index: 200;
  position: fixed;
  top: 0;
  right: 0;
}
.p-line {
  position: relative;
}
.p-line::before,
.p-line::after {
  z-index: 1;
  position: absolute;
  top: 0;
  left: 0;
  width: 2.0625rem;
  height: 100%;
  background-image: url(../../assets/images/top/side-ribbon@2x.webp);
  background-position: left top;
  background-size: contain;
  background-repeat: repeat-y;
  content: "";
}
.p-line::after {
  right: 0;
  left: auto;
  rotate: 180deg;
}
.p-link {
  padding-bottom: 18.75rem;
  background: var(--color-gray);
}
.p-link__container {
  padding-block: 6.875rem 15rem;
  border-radius: 0 0 14.375rem 14.375rem;
  background: var(--color-white);
}
.p-link__inner.l-inner {
  max-width: calc(67.5rem + var(--padding-pc) * 2);
}
.p-link__title {
  color: var(--color-red-rose);
  font-weight: 900;
  font-size: 3.25rem;
  line-height: 0.9038461538;
  text-align: center;
}
.p-link__items {
  display: grid;
  grid-template-columns: 1fr;
  margin-top: 6.25rem;
  gap: 3.125rem;
}
.p-loading-overlay {
  display: flex;
  visibility: visible;
  z-index: 9999;
  position: fixed;
  top: 0;
  left: 0;
  align-items: center;
  justify-content: center;
  width: 100vw;
  height: 100vh;
  background-color: #fff;
  opacity: 1;
}
.p-loading-overlay.is-hidden {
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.8s ease-out, visibility 0.8s ease-out;
}
.p-loading-image {
  width: 90%;
  max-width: 51.6875rem;
  transform: translateY(30px);
  opacity: 0;
}
body.loading::before {
  z-index: 9999;
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background-color: #fff;
  content: "";
  opacity: 1;
  pointer-events: none;
}
body.loading::after {
  z-index: 10000;
  position: fixed;
  top: 50%;
  left: 50%;
  aspect-ratio: 895/480;
  width: min(51.6875rem, 90vw);
  height: auto;
  transform: translate(-50%, -50%);
  transform: translate(-50%, -50%) translateY(30px);
  background-image: url(../../assets/images/top/mv-copy@2x.webp);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  content: "";
  opacity: 0;
}
.p-policy__section:not(:first-child) {
  margin-top: 3.375rem;
}
.p-policy__heading {
  font-weight: 900;
  font-size: 2rem;
  line-height: 1;
}
.p-policy__text {
  margin-top: 2rem;
  font-weight: 500;
  line-height: 2.25;
  letter-spacing: 0.03em;
}
.p-media {
  display: grid;
  grid-template-columns: 30.625rem 1fr;
  grid-template-areas: "content image";
  align-items: center;
  padding: 3.125rem 3.125rem 3.125rem 9.375rem;
  gap: 3.75rem;
  border-radius: 18.75rem;
  background: var(--color-gray);
}
.p-media__content {
  grid-area: content;
}
.p-media__heading {
  position: relative;
}
.p-media._first .p-media__heading::before {
  position: absolute;
  right: 6.25rem;
  bottom: 0;
  width: 6.9375rem;
  height: 8.125rem;
  background: url(../../assets/images/top/media-character01@2x.webp)
    center/cover no-repeat;
  content: "";
}
.p-media._second .p-media__heading::before {
  position: absolute;
  right: 0.375rem;
  bottom: 0;
  width: 7.5625rem;
  height: 8.125rem;
  background: url(../../assets/images/top/media-character02@2x.webp)
    center/cover no-repeat;
  content: "";
}
.p-media__text {
  margin-top: 2.5rem;
  font-weight: 700;
  font-size: 1.375rem;
  line-height: 1.6818181818;
  text-align: justify;
}
.p-media__button {
  width: 100%;
  max-width: 17.5rem;
  margin-top: 2.5rem;
}
.p-media__image {
  display: block;
  grid-area: image;
  aspect-ratio: 450/450;
  width: 100%;
  overflow: hidden;
}
.p-media._reverse {
  grid-template-columns: 1fr 30.625rem;
  grid-template-areas: "image content";
  padding: 3.125rem 9.375rem 3.125rem 3.125rem;
}
.p-media02 {
  display: grid;
  grid-template-columns: 21.875rem 1fr;
  align-items: center;
  align-self: stretch;
  gap: 1.875rem;
}
.p-media02__image {
  display: block;
  aspect-ratio: 350/220;
  width: 100%;
  overflow: hidden;
}
.p-media02__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0.78125rem;
}
.p-media02__content {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}
.p-media02__title {
  color: var(--color-red-rose);
  font-weight: 700;
  font-size: 2rem;
  line-height: 1.15625;
  text-decoration-line: underline;
  text-decoration-thickness: 0.0625rem;
  text-underline-position: from-font;
}
.p-media02__text {
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.03em;
  text-align: justify;
}
.p-media03 {
  display: grid;
  grid-template-columns: 1fr 29.25rem;
  align-items: center;
  gap: 3.625rem;
}
.p-media03__content {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3.625rem;
}
.p-media03__text {
  font-weight: 500;
  font-size: 1.375rem;
  line-height: 1.6818181818;
  text-align: justify;
}
.p-media03__textAccent {
  color: var(--color-red-light);
}
.p-media03__textLine {
  background-color: var(--color-red-light);
  color: #fff;
}
.p-media03__image {
  position: relative;
  margin-right: 4.25rem;
}
.p-media03__image::before {
  position: absolute;
  right: -4.25rem;
  bottom: -9.25rem;
  width: 10.4375rem;
  height: 14.4375rem;
  background: url(../../assets/images/about/point-character@2x.webp)
    center/cover no-repeat;
  content: "";
}
.p-media03__list {
  display: grid;
  grid-template-columns: repeat(2, auto);
  width: -moz-fit-content;
  width: fit-content;
  gap: 3.75rem;
}
.p-media03__listItem {
  display: flex;
  align-items: center;
  gap: 0.625rem;
}
.p-media03__listTitle {
  width: -moz-fit-content;
  width: fit-content;
  padding: 0.3125rem 0.625rem;
  border-radius: 100vmax;
  background-color: var(--color-red);
  color: #fff;
  font-weight: 700;
  font-size: 1.375rem;
  line-height: 1.6818181818;
}
.p-media03__listTitle._green {
  background-color: var(--color-green);
}
.p-media03__listText {
  color: #3e3a39;
  font-weight: 500;
  font-size: 1.5rem;
  line-height: 1.5416666667;
}
.p-media04 {
  display: grid;
  grid-template-columns: 1fr 41.0625rem;
  align-items: center;
  gap: 2.5rem;
}
.p-media04__titles {
  position: relative;
}
.p-media04__titleAccent {
  position: absolute;
  top: -1.25rem;
  right: 0;
  transform: rotate(-10deg);
  content: "";
  color: var(--color-green-light);
  font-weight: 500;
  font-size: 3rem;
  line-height: 0.9791666667;
  font-family: var(--font-en);
  text-transform: capitalize;
}
.p-media04__title {
  color: var(--color-red);
  font-weight: 900;
  font-size: 1.625rem;
  line-height: 1.8076923077;
}
.p-media04__title-exlarge {
  padding-right: 0.5rem;
  font-weight: 900;
  font-size: 3rem;
  line-height: 0.9791666667;
}
.p-media04__title-large {
  padding-left: 0.5rem;
  font-weight: 900;
  font-size: 2.375rem;
  line-height: 1.2368421053;
}
.p-media04__titleSmall {
  font-weight: 900;
  font-size: 1.5rem;
  line-height: 1.9583333333;
}
.p-media04__texts {
  margin-top: 1.25rem;
}
.p-media04__text {
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.03em;
}
.p-media04__contents {
  display: grid;
  grid-template-columns: 1fr;
  margin-top: 1.75rem;
  gap: 1.25rem;
}
.p-media04__content {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.5rem;
}
.p-media04__subTitle {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0.375rem 2.5rem;
  border-radius: 2.5rem;
  background: var(--color-green);
  color: var(--color-white);
  font-weight: 900;
  font-size: 1.5rem;
  line-height: 1;
  text-align: center;
}
.p-media04__date {
  font-weight: 700;
  font-size: 1.625rem;
  line-height: 1.8076923077;
  letter-spacing: 0.05em;
  vertical-align: bottom;
}
.p-media04__dateLarge {
  font-weight: 700;
  font-size: 2.25rem;
  line-height: 1.3055555556;
  letter-spacing: 0.05em;
}
.p-media04__dateLarge._accent {
  padding-left: 1.25rem;
}
.p-media04__dateSmall {
  font-weight: 700;
  font-size: 1.5625rem;
  line-height: 1.88;
  letter-spacing: 0.05em;
}
.p-media04__location {
  font-weight: 700;
  font-size: 1.625rem;
  line-height: 1.8076923077;
  letter-spacing: 0.05em;
}
.p-media05 {
  display: grid;
  grid-template-columns: 18.75rem 1fr;
  align-items: center;
  gap: 1.875rem;
}
.p-media05__first {
  display: flex;
  align-items: center;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0.4375rem 1.875rem 0.625rem;
  gap: 0.25rem;
  border-radius: 100vmax;
  background-color: var(--color-green);
  color: #fff;
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 1.5555555556;
  letter-spacing: 0.03em;
}
.p-media05__firstNumber {
  position: relative;
  top: -0.125rem;
  color: var(--color-yellow);
  font-weight: 500;
  font-size: 2.25rem;
  line-height: 0.75;
  letter-spacing: 0.03em;
}
.p-media05__image {
  border-radius: 1.25rem;
}
.p-media05__heading {
  font-weight: 900;
  font-size: 2.25rem;
}
.p-media05__heading span {
  display: block;
  color: var(--color-red);
  font-weight: 900;
  font-size: 1.75rem;
  line-height: 1.6785714286;
  letter-spacing: 0%;
}
.p-media05__heading:not(:first-child) {
  margin-top: 0.5rem;
}
.p-media05__content {
  position: relative;
}
.p-media05__text {
  margin-top: 1.25rem;
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.03em;
}
.p-media05__textNote {
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.9285714286;
  letter-spacing: 0.03em;
}
.p-media05__textAccent {
  font-weight: 800;
  color: var(--color-red);
}
.p-media05__coffee {
  max-width: 13.875rem;
  margin-top: 1.25rem;
}
.p-media05__balloon {
  position: absolute;
  top: -3.125rem;
  right: -3.125rem;
  max-width: 17.125rem;
  height: auto;
}
.p-media05__info {
  display: flex;
  align-items: center;
  margin-top: 1.625rem;
  padding: 0.375rem 1.875rem;
  gap: 1.25rem;
  border-radius: 100vmax;
  background-color: var(--color-red-light);
  color: #fff;
}
.p-media05__infoDate {
  display: flex;
  align-items: center;
}
.p-media05__infoSmall {
  font-weight: 500;
  font-size: 1.125rem;
  letter-spacing: 0.03em;
}
.p-media05__infoMedium {
  font-weight: 700;
  font-size: 1.25rem;
  letter-spacing: 0.03em;
}
.p-media05__textNumber {
  font-weight: 700;
  font-size: 1.6875rem;
  line-height: 0.9;
  letter-spacing: 0.03em;
}
.p-news__item {
  border-bottom: 1px dashed var(--color-base);
}
.p-news__item:first-child {
  border-top: 1px dashed var(--color-base);
}
.p-news__item .c-news02__link {
  padding-block: 1.5625rem;
}
.p-page-mv {
  position: relative;
  padding-block: 7rem 1.25rem;
  background: url(../../assets/images/common/mvLower-background@2x.webp)
    center/cover no-repeat;
}
.p-page-mv__heading {
  color: var(--color-red-rose);
  font-weight: 900;
  font-size: 3.25rem;
  line-height: 0.9038461538;
  text-align: center;
}
.p-page-mv__breadcrumb {
  margin-top: 5.5rem;
}
.p-page-mv._image .p-page-mv__image {
  display: block;
}
.p-page-mv__image {
  display: inline-block;
  display: none;
  z-index: 1;
  position: absolute;
  top: 68%;
  right: calc(50% - min(46.4375rem, 53%));
  transform: translate(-50%, -50%);
  content: "";
}
.p-page-mv__image img {
  width: min(18.75rem, 20.8333333333vw);
  height: min(18.75rem, 20.8333333333vw);
  border-radius: 50%;
}
.p-point {
  display: grid;
  grid-template-columns: 1fr 12.4375rem;
  align-items: flex-end;
  gap: 1.25rem;
}
.p-point__contents {
  display: grid;
  position: relative;
  grid-template-columns: 1fr;
  padding: 2.25rem 3.125rem;
  gap: 2.375rem;
  border-radius: 1.875rem;
  background: var(--color-gray-light);
}
.p-point__content::before {
  z-index: -1;
  position: absolute;
  top: 50%;
  right: -3.125rem;
  width: 4.84375rem;
  height: 3.3125rem;
  background: url(../../assets/images/about/triangle-icon@2x.webp) center/cover
    no-repeat;
  content: "";
}
.p-point__content {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.875rem;
}
.p-point__title {
  color: var(--color-red);
  font-weight: 900;
  font-size: 1.5rem;
  line-height: 1.9583333333;
  text-decoration-line: underline;
  text-decoration-thickness: 0.125rem;
  text-underline-position: from-font;
  text-underline-offset: 0.25rem;
}
.p-point__lists {
  display: grid;
  grid-template-columns: 1fr;
  padding-left: 1.3125rem;
  gap: 0.375rem;
}
.p-point__list,
.p-point__text {
  font-weight: 700;
  font-size: 1.375rem;
}
.p-point__text {
  line-height: 1.6818181818;
}
.p-point__list {
  position: relative;
  line-height: 1;
}
.p-point__list::before {
  position: absolute;
  top: 54%;
  left: -1.5625rem;
  width: 0.625rem;
  height: 0.625rem;
  transform: translateY(-50%);
  border-radius: 50%;
  background-color: var(--color-green);
  content: "";
}
.p-point__textAccent {
  position: absolute;
  top: -4rem;
  left: 2.875rem;
  transform: rotate(-5deg);
  color: var(--color-green);
  font-weight: 500;
  font-size: 5rem;
  font-family: var(--font-en);
  text-transform: capitalize;
}
.p-policy__section:not(:first-child) {
  margin-top: 3.375rem;
}
.p-policy__heading {
  font-weight: 900;
  font-size: 2rem;
  line-height: 1;
}
.p-policy__text {
  margin-top: 2rem;
  font-weight: 500;
  line-height: 2.25;
  letter-spacing: 0.03em;
}
.p-single {
  margin-bottom: 12.5rem;
}
.p-single__meta {
  padding-bottom: 2.1875rem;
  background-image: repeating-linear-gradient(
    90deg,
    var(--color-base),
    var(--color-base) 0.125rem,
    transparent 0.125rem,
    transparent 0.25rem
  );
  background-position: left -0.0625rem bottom;
  background-size: 400% 0.0625rem;
  background-repeat: repeat-x;
}
.p-single__header {
  display: flex;
  align-items: center;
  gap: 1.25rem;
}
.p-single__date {
  font-weight: 500;
  font-size: 1rem;
  line-height: 1.875;
  letter-spacing: 0.07em;
}
.p-single__category {
  padding: 0.125rem 1.875rem;
  border-radius: 6.25rem;
  background: var(--color-red-light);
  color: var(--color-white);
  font-weight: 500;
  font-size: 1rem;
  line-height: 1.875;
  letter-spacing: 0.07em;
}
.p-single__title {
  margin-top: 1.25rem;
  font-weight: 900;
  font-size: 2rem;
  line-height: 1.15625;
}
.p-single__editor {
  margin-top: 2.5rem;
}
.p-single__editor > * {
  margin-block: 2.5rem;
}
.p-single__editor > *:first-child {
  margin-top: 0;
}
.p-single__editor > *:last-child {
  margin-bottom: 0;
}
.p-single__editor p {
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 2;
  letter-spacing: 0.03em;
}
.p-single__editor a {
  color: var(--color-green);
  font-weight: 500;
  font-size: 1.125em;
  line-height: 2;
  letter-spacing: 0.03em;
  text-decoration-line: underline;
}
.p-single__editor .p-single__col2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin-block: 3.75rem;
  gap: 2.5rem;
}
.p-single__footer {
  margin-top: 2.5rem;
  padding-top: 2.5rem;
  border-top: 1px solid var(--color-base);
}
.p-single__button {
  max-width: 18.75rem;
}
.p-sponsoring {
  padding-block: 6.875rem;
  border-top: 0.625rem solid var(--color-red-light);
  border-bottom: 0.625rem solid var(--color-red-light);
  background: var(--color-green-light);
}
.p-sponsoring__inner.l-inner {
  max-width: calc(67.5rem + var(--padding-pc) * 2);
}
.p-sponsoring__title {
  color: var(--color-green);
  font-weight: 900;
  font-size: 3.25rem;
  line-height: 0.9038461538;
  text-align: center;
}
.p-sponsoring__items {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 6.25rem;
  gap: 1.875rem;
}
.p-sponsoring__item {
  width: calc(33.3333333333% - 1.25rem);
}
.p-table {
  width: 100%;
  max-width: 67.5rem;
  margin-inline: auto;
  border-collapse: collapse;
}
.p-table__row {
  background-image: repeating-linear-gradient(
    90deg,
    var(--color-base),
    var(--color-base) 0.0625rem,
    transparent 0.0625rem,
    transparent 0.1875rem
  );
  background-position: left -0.0625rem bottom;
  background-size: 300% 0.125rem;
  background-repeat: repeat-x;
}
.p-table__header,
.p-table__data,
.p-table__text,
.p-table__link,
.p-table__textNote {
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.03em;
}
.p-table__textNote {
  margin-top: 0.25rem;
  font-size: 0.875rem;
}
.p-table__link {
  display: inline-block;
  margin-top: 1.5rem;
  padding-bottom: 0;
  border-bottom: 0.0625rem solid var(--color-red-light);
  color: var(--color-red-light);
}
.p-table__list {
  font-weight: 500;
  font-size: 0.9375rem;
  line-height: 1.8;
}
.p-table__wrapper {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}
.p-table__textMedium {
  color: var(--color-red-light);
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.5;
}
.p-table__contents {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.5rem;
}
.p-table__content {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.25rem;
}
.p-table__title {
  position: relative;
  padding-left: 3.125rem;
}
.p-table__title,
.p-table__period {
  color: var(--color-red-light);
  font-weight: 700;
  font-size: 1.375rem;
  line-height: 1;
}
.p-table__title::before {
  position: absolute;
  top: 50%;
  left: 0;
  width: 2.5rem;
  height: 1.775rem;
  transform: translateY(-50%);
  background: url(../../assets/images/top/table-ribbon@2x.webp) center/cover
    no-repeat;
  content: "";
}
.p-table__periodSmall {
  font-size: 1rem;
}
.p-table__header {
  width: 10rem;
  padding-block: 1.5625rem;
  font-weight: 700;
  vertical-align: middle;
}
.p-table__data {
  padding-block: 1.5625rem;
}
.p-table__lists {
  margin-left: 1.5rem;
  list-style: disc;
}
.p-table__data._flex .p-table__lists:last-child {
  max-width: 100%;
}
.p-line {
  position: relative;
}
.p-line::before,
.p-line::after {
  z-index: 1;
  position: absolute;
  top: 0;
  left: 0;
  width: 2.0625rem;
  height: 100%;
  background-image: url(../../assets/images/top/side-ribbon@2x.webp);
  background-position: left top;
  background-size: contain;
  background-repeat: repeat-y;
  content: "";
}
.p-line::after {
  right: 0;
  left: auto;
  rotate: 180deg;
}
.p-top-mv {
  position: relative;
  width: 100%;
  height: 93.5rem;
  padding-top: 3.75rem;
  background-image: url(../../assets/images/top/mv_background@2x.webp);
  background-position: bottom center;
  background-size: contain;
  background-repeat: repeat-x;
}
.p-top-mv__character {
  max-width: 74rem;
  margin: 0 auto;
  padding-left: min(6.2836624776%, 4.375rem);
}
.p-top-mv__copy {
  position: relative;
  max-width: 51.6875rem;
  margin: -15rem auto 0;
}
.p-top-mv__about {
  position: relative;
  max-width: 51.6875rem;
  margin: 3rem auto 0;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.p-top-mv__aboutInner {
  display: flex;
  gap: 2rem;
  background: #fff;
  padding: 2rem;
  border-radius: 2.5rem;
  border: 5px solid;
  border-color: var(--color-red);
}
.p-top-mv__aboutTtl {
  width: 30%;
}
.p-top-mv__aboutTtl.p-media04__title {
  font-size: 1.5rem;
  color: var(--color-red-light);
}
.p-top-mv__aboutText {
  width: 70%;
}
.p-top-mv__accent {
  font-size: 2rem;
  color: var(--color-green);
  line-height: 0.75;
}
.p-top-news {
  background-color: var(--color-red-light);
  padding-top: 2.75rem;
  padding-bottom: 2.75rem;
}
.p-top-news__inner {
  display: grid;
  grid-template-columns: auto minmax(58.125rem, 1fr);
  align-items: center;
  gap: 1.875rem;
}
.p-top-news__heading {
  color: #fff;
  font-weight: 700;
  font-size: 2.125rem;
  line-height: 1.2058823529;
}
.p-top-news__list {
  display: grid;
  justify-self: end;
  width: 100%;
  max-width: 58.125rem;
  gap: 0.625rem;
}
.p-top-limit {
  margin-top: -0.0625rem;
  padding-block: 6.875rem 3.75rem;
  background-color: var(--color-red-light);
}
.p-top-limit__ribbon {
  position: absolute;
  top: -10.625rem;
  left: -10rem;
  max-width: 58.1875rem;
}
.p-top-limit__inner {
  position: relative;
  max-width: calc(var(--l-inner) / 16 * 1rem);
  padding: 7.5rem;
  border-radius: 7.5rem;
  background-color: #fff;
}
.p-top-limit__heading {
  position: relative;
}
.p-top-limit__character {
  position: absolute;
  right: 0;
  bottom: -0.625rem;
  max-width: 11.0625rem;
}
.p-top-limit__content:not(:first-child) {
  margin-top: 3.125rem;
}
.p-top-limit__media {
  margin-top: 3.125rem;
}
.p-top-limit__cardList {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin-top: 3.125rem;
  gap: 1.875rem;
}
.p-top-limit__card {
  position: relative;
  padding: 1.5rem 1.875rem;
  border-radius: 2.5rem;
  background-color: var(--color-gray);
}
.p-top-limit__card::before {
  z-index: 1;
  position: absolute;
  top: -1.875rem;
  left: -1.875rem;
  width: 6.0625rem;
  height: 5rem;
  background-image: url(../../assets/images/top/limit-card-ribbon@2x.webp);
  background-position: left top;
  background-size: contain;
  background-repeat: no-repeat;
  content: "";
}
.p-top-limit__cardHeading {
  text-align: center;
}
.p-top-limit__cardText {
  font-weight: 900;
  font-size: 1.125rem;
  line-height: 1.5;
}
.p-top-limit__cardTitle {
  margin-top: 0.75rem;
  color: var(--color-red-light);
  font-weight: 900;
  font-size: 1.75rem;
  line-height: 1.3214285714;
}
.p-top-limit__cardImage {
  max-width: 17.5rem;
  margin-top: 1.875rem;
  margin-inline: auto;
}
.p-top-action {
  overflow: hidden;
  border-bottom: 0.625rem solid var(--color-red-light);
  background-color: #fff;
}
.p-top-action__inner {
  display: grid;
  grid-template-columns: 44.6774193548% 1fr;
  align-items: center;
  max-width: calc(77.5rem + var(--padding-pc) * 2);
  gap: 2.8125rem;
}
.p-top-action__ribbon {
  margin-top: 2.5rem;
  margin-bottom: -3.75rem;
}
.p-top-action__text {
  font-weight: 700;
  font-size: 1.375rem;
  line-height: 2.1363636364;
}
.p-top-action__text + .p-top-action__text {
  margin-top: 1.25rem;
}
.p-top-cancer {
  padding-block: 7.5rem 27.5rem;
}
.p-top-cancer__media {
  display: grid;
  margin-top: 5rem;
  gap: 2.5rem;
}
.p-top-cancer__button {
  max-width: 45rem;
  margin-top: 8.75rem;
  margin-inline: auto;
}
.p-top-campaign {
  position: relative;
  margin-top: -18.75rem;
  border-radius: 18.75rem 18.75rem 0 0;
  background-color: var(--color-gray);
}
.p-top-campaign__heading {
  position: relative;
  top: -4.8125rem;
  max-width: 36.25rem;
  margin-inline: auto;
}
.p-top-campaign__ankerList {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  max-width: 65.125rem;
  margin-inline: auto;
  gap: 2.5rem;
}
.p-top-campaign__ankerLink {
  display: grid;
  position: relative;
  grid-template-columns: 1fr auto;
  align-items: center;
  padding: 0.625rem 0.9375rem 0.625rem 2.75rem;
  gap: 0.625rem;
  border: 0.375rem solid var(--color-red-light);
  border-radius: 100vmax;
  background-color: #fff;
  color: var(--color-red-light);
  font-weight: 900;
  font-size: 1.35rem;
  line-height: 1.2307692308;
  text-align: center;
}
.p-top-campaign__ankerLink::before {
  position: absolute;
  top: 50%;
  left: 2.25rem;
  width: 1.75rem;
  height: 1rem;
  translate: 0 -50%;
  background-image: url(../../assets/images/top/icon-arrow.svg);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  content: "";
}
.p-top-campaign__ankerIcon {
  max-width: 3.75rem;
}
.p-top-campaign__description {
  margin-top: 2.5rem;
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.03em;
  text-align: center;
}
.p-top-campaign__period {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  width: -moz-fit-content;
  width: fit-content;
  margin-top: 2.5rem;
  margin-inline: auto;
  padding: 0.9375rem 2rem;
  gap: 1.25rem;
  border-radius: 100vmax;
  background-color: #fff;
}
.p-top-campaign__periodTitle {
  padding: 0.25rem 2.5rem;
  border-radius: 100vmax;
  background-color: var(--color-red-light);
  color: #fff;
  font-weight: 900;
  font-size: 1.5rem;
  text-align: center;
}
.p-top-campaign__periodText {
  display: grid;
  grid-auto-flow: column;
  align-items: center;
  justify-content: space-between;
  gap: 1.875rem;
  font-weight: 700;
  font-size: 1.5625rem;
  letter-spacing: 0.05em;
}
dl.p-top-campaign__period.col-assort {
  background: var(--color-gray);
}
.p-top-campaign__periodNumber {
  font-size: 2.25rem;
  line-height: 1.3055555556;
  letter-spacing: 0.05em;
}
.p-top-campaign._second {
  margin-top: 0;
  border-radius: 0;
  background-color: var(--color-green);
}
.p-top-form {
  padding-top: 6.25rem;
}
.p-top-form__buttons {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  max-width: 62.5rem;
  margin-inline: auto;
  margin-top: 2.5rem;
  gap: 2.5rem;
}
.p-top-overview {
  max-width: 75rem;
  margin-inline: auto;
  margin-top: 6.25rem;
  padding: 3.125rem;
  border-radius: 9.375rem;
  background-color: #fff;
}
.p-top-overview__heading {
  text-align: center;
}
.p-top-overview__col2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  margin-top: 2.5rem;
  gap: 2.5rem;
}
.p-top-overview__col2Content {
  padding: 3.125rem 1.875rem;
  border-radius: 1.875rem;
  background-color: var(--color-gray);
}
.p-top-overview__col2Heading {
  font-weight: 900;
  font-size: 1.5rem;
}
.p-top-overview__col2List {
  margin-top: 0.5rem;
}
.p-top-overview__col2Item {
  padding-left: 1em;
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.03em;
  text-indent: -1em;
}
.p-top-overview__col2Item::before {
  content: "・";
}
.p-top-overview__col2Bottom {
  display: grid;
  grid-template-columns: auto 1fr;
  margin-top: 1.875rem;
}
.p-top-overview__col2Bottom .p-top-overview__col2Item {
  font-weight: 500;
  font-size: 0.9375rem;
  line-height: 1.8;
  letter-spacing: 0.03em;
}
.p-top-overview__col2BottomItem + .p-top-overview__col2BottomItem {
  margin-left: 1.25rem;
  padding-left: 1.25rem;
  border-left: 0.0625rem dashed var(--color-red-light);
}
.p-top-overview__col2BottomText {
  font-weight: 500;
  font-size: 0.9375rem;
  line-height: 1.8;
  letter-spacing: 0.03em;
}
.p-top-overview__col2SubHeading {
  color: var(--color-red-light);
  font-weight: 900;
  font-size: 1.125rem;
}
.p-top-overview__col2Text {
  margin-top: 0.5rem;
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.03em;
}
.p-top-overview__col2Button {
  max-width: 19.875rem;
  margin-top: 1rem;
}
.p-top-overview__table {
  margin-top: 2.5rem;
}
.p-top-overview__button {
  max-width: 33.875rem;
  margin-top: 2.5rem;
  margin-inline: auto;
}
.p-top-prize {
  padding-block: 6.25rem;
}
.p-top-prize__text {
  margin-top: 2.5rem;
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.03em;
  text-align: center;
}
.p-top-prize__text + .p-top-prize__text {
  margin-top: 1.125rem;
}
.p-top-prize__block {
  position: relative;
  max-width: 62.5rem;
  margin-top: 5.625rem;
  margin-inline: auto;
  padding: 3.75rem 1.875rem;
  border-radius: 1.875rem;
  background: #fff;
}
.p-top-prize__blockHeading {
  margin-top: -5.625rem;
  margin-bottom: 1.875rem;
  text-align: center;
}
.p-top-prize__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
.p-top-prize__item {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 3;
  padding: 1.875rem;
}
.p-top-prize__item + .p-top-prize__item {
  border-left: 0.0625rem dashed var(--color-red-light);
}
.p-top-prize__title {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  gap: 0.625rem;
}
.p-top-prize__titleIcon {
  display: grid;
  place-content: center;
  width: 2.5rem;
  height: 2.5rem;
  padding-bottom: 0.1875rem;
  border-radius: 100vmax;
  background-color: var(--color-green);
  color: var(--color-white);
  font-weight: 700;
  font-size: 1.875rem;
  line-height: 0.9;
}
.p-top-prize__titleText {
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.125;
}
.p-top-prize__titleSmall {
  display: block;
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.5;
}
.p-top-prize__itemImage {
  max-width: 13.75rem;
  margin: 1rem 0;
  margin-inline: auto;
}

.p-top-prize__item._e-gift .p-top-prize__logoImage,
.p-top-prize__logoImage {
  max-width: 15.875rem;
}
.p-top-gift__note {
  text-align: left;
  margin-top: 1rem;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.85px;
}
.p-top-prize__itemWrapper {
  max-width: 21.875rem;
  margin-inline: auto;
  text-align: center;
  margin-top: 1rem;
}
.p-top-prize__box {
  margin-top: 0.75rem;
  padding: 0.5rem 1.25rem;
  border-radius: 0.625rem;
  background-color: #fff;
  font-weight: 700;
  font-size: 0.875rem;
  line-height: 1.5714285714;
  text-align: center;
}
.p-top-prize__boxLink {
  color: var(--color-red);
}
.p-top-prize__itemNumber {
  font-weight: 700;
  font-size: 2rem;
}
.p-top-prize__section {
  margin-top: 3.75rem;
}
.p-top-prize__cards {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  max-width: 67.5rem;
  margin-top: 3.75rem;
  margin-inline: auto;
  gap: 1.875rem;
}
.p-top-prize__card {
  width: calc(33.3333333333% - 1.25rem);
}
.p-top-prize__itemImg {
  display: flex;
  flex-direction: column;
}
.p-top-second {
  padding-block: 3.75rem 7.5rem;
  background-image: url(../../assets/images/common/background-square@2x.webp);
  background-position: center;
  background-size: contain;
  background-repeat: repeat;
}
.p-top-flow {
  margin-top: 6.25rem;
}
.p-top-flow__flow {
  margin-top: 2.5rem;
}
.p-top-flow__sns {
  position: relative;
  max-width: 50.1875rem;
  margin-inline: auto;
  margin-top: 2.5rem;
}
.p-top-flow__snsLink {
  display: grid;
  position: absolute;
  grid-template-columns: auto 1fr;
  align-items: center;
  inset: auto auto 2.3125rem 0;
  padding: 0.625rem 1.25rem;
  gap: 0.625rem;
  border-radius: 100vmax;
  background: var(--color-black);
  color: #fff;
  font-weight: 700;
  font-size: 1.25rem;
  line-height: 1;
}
.p-top-flow__snsIcon {
  width: 1.3125rem;
  height: 1.3125rem;
}
.p-top-flow__snsTag {
  margin-right: 0.625rem;
  text-align: center;
}
.p-top-flow__note {
  padding-inline: 0.85rem;
  margin-top: 2rem;
  font-size: 1rem;
  font-weight: 500;
}

.p-top-gift {
  margin-top: 6.25rem;
}
.p-top-gift__text {
  margin-top: 2.5rem;
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.03em;
  text-align: center;
}
.p-top-gift__content {
  position: relative;
  max-width: 62.5rem;
  margin-inline: auto;
  margin-top: 5rem;
  padding: 2.5rem 3.75rem;
  border-radius: 1.875rem;
  background-color: var(--color-gray);
}
.p-top-gift__title {
  position: absolute;
  top: -2.25rem;
  left: 50%;
  width: -moz-fit-content;
  width: fit-content;
  transform: translateX(-50%);
  text-align: center;
}
.p-top-gift__items {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  width: -moz-fit-content;
  width: fit-content;
  margin-top: 2.1875rem;
  margin-inline: auto;
  gap: 0.25rem;
}
.p-top-gift__item {
  display: grid;
  justify-content: center;
  height: 100%;
}
.p-top-gift__itemWrapper {
  max-width: 22.5rem;
  margin-top: 1rem;
  text-align: center;
}
.p-top-gift__item._ticket .p-top-gift__itemImage {
  max-width: 18.75rem;
  object-fit: cover;
}
.p-top-gift__itemText {
  font-weight: 700;
  font-size: 1.875rem;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
}
.p-top-gift__itemTitle {
  display: block;
}
.p-top-gift__itemNumber {
  font-weight: 700;
  font-size: 2.75rem;
  line-height: 1;
}
.p-top-gift__or {
  display: grid;
  place-content: center;
  width: 3.375rem;
  height: 3.375rem;
  padding-top: 0.125rem;
  border-radius: 100vmax;
  background-color: var(--color-red-light);
  color: #fff;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 2.1428571429;
  font-family: var(--font-en);
  letter-spacing: 0.03em;
  text-align: center;
  text-transform: uppercase;
}
.p-top-sns {
  padding-bottom: 6.25rem;
}
.p-top-sns__content {
  display: grid;
  grid-template-columns: 550fr 490fr;
  margin-top: 2.5rem;
  gap: 2.5rem;
}
.p-top-sns__head {
  display: grid;
  grid-auto-flow: column;
  align-items: center;
  gap: 1.25rem;
}
.p-top-sns__headLine {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.p-top-sns__headIcon {
  width: 3.8125rem;
  height: 3.8125rem;
}
.p-top-sns__headText {
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.5;
}
.p-top-sns__headText._center {
  text-align: center;
}
.p-top-sns__headButton {
  width: 11.875rem;
}
.p-top-sns__icons {
  display: flex;
  justify-content: center;
  gap: 3.75rem;
}
.p-top-sns__icons,
.p-top-sns__line {
  margin-top: 2.5rem;
  padding: 2.5rem 1.25rem;
  border-radius: 1.875rem;
  background-color: #fff;
}
.p-top-sns__lineTitle {
  color: #e7336e;
  font-weight: 700;
  font-size: 1.125rem;
  line-height: 1.2222222222;
  letter-spacing: 0.03em;
  text-align: center;
  margin-top: 1rem;
}
.p-top-sns__lineQr {
  display: block;
  max-width: 11.25rem;
  margin-inline: auto;
}
.p-top-sns__lineText {
  margin-top: 0.75rem;
  font-weight: 500;
  font-size: 0.875rem;
  line-height: 1.5714285714;
  letter-spacing: 0.03em;
  text-align: center;
}
.p-top-event {
  position: relative;
  padding-block: 6.875rem;
  overflow: hidden;
  border-block: 0.625rem solid var(--color-red-light);
}
.p-top-event::before {
  position: absolute;
  width: 15.625rem;
  height: 21.5625rem;
  inset: auto 5.6875rem -3.75rem auto;
  background-image: url(../../assets/images/top/event-character@2x.webp);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  content: "";
}
.p-top-event__media {
  margin-top: 5rem;
}
.p-top-video {
  margin-top: 5rem;
}
.p-top-video__iframe {
  margin-top: 2.5rem;
}
.p-top-video__iframe iframe {
  aspect-ratio: 16/9;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.p-top-video__link {
  margin-top: 1rem;
}
.p-top-video__link a {
  color: var(--color-red);
  text-decoration: underline;
}
.u-hidden-pc {
  display: none;
}
.u-hidden-sp {
  display: block;
}
.u-visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
}
.u-text-red {
  color: var(--color-red);
}
.u-text-bold {
  font-weight: 700;
}
@media screen and (max-width: 1440px) {
  .c-heading06__textAccent {
    left: 0;
  }
}
@media screen and (max-width: 1280px) {
  :where(html) {
    font-size: calc(var(--font-size-base) / var(--l-inner) * 100svi);
  }
  .p-chart._point .p-chart__contents::before {
    right: 1.875rem;
    bottom: 1.875rem;
    width: 10rem;
    height: 13.125rem;
  }
}
@media screen and (max-width: 768px) {
  :where(html) {
    font-size: calc(var(--font-size-base) * 1px);
  }
  .l-inner {
    padding-inline: var(--padding-sp);
  }
  .l-page {
    margin-block: 3.75rem;
  }
  .c-accordion__title {
    padding: 0.75rem 1.0625rem 0.75rem 2.375rem;
    font-size: 1rem;
  }
  .c-accordion__title::before {
    top: 0.625rem;
    left: 0.625rem;
    transform: translateY(0);
    font-size: 1.75rem;
  }
  .c-accordion__icon {
    margin-left: 0.625rem;
  }
  .c-accordion__icon img {
    width: 1.5rem;
    height: 1.5rem;
  }
  .c-accordion__content {
    font-size: 0.875rem;
  }
  .c-banner__link {
    padding: 1.25rem 1.25rem 0.625rem;
  }
  .c-banner__image {
    border-radius: 1.125rem;
  }
  .c-banner__title {
    margin-top: 0.625rem;
    font-size: 1.125rem;
  }
  .c-button {
    padding-block: 1.25rem;
    font-size: 1.125rem;
  }
  .c-button._arrow::after {
    right: 1.25rem;
    width: 0.625rem;
    height: 0.9375rem;
  }
  .c-button._small {
    padding-block: 0.75rem;
    font-size: 0.75rem;
  }
  .c-button._fit {
    display: block;
    width: 100%;
    width: 17.875rem;
    margin-inline: auto;
    padding: 1.5625rem 2rem;
  }
  .c-button02__text {
    padding-block: 1.875rem;
    font-size: 1.375rem;
  }
  .c-button02::before {
    top: -5.625rem;
    width: 18.75rem;
    height: 7.5rem;
  }
  .c-button02__balloonText {
    top: -3rem;
    left: calc(50% - 7.9375rem);
    font-size: 0.9375rem;
  }
  .c-button02__textNote {
    margin-top: 0.25rem;
    font-size: 1rem;
  }
  .c-button02._arrow {
    box-shadow: 0.5rem 0.5rem 0 var(--color-green-light);
  }
  .c-button02._arrow::after {
    right: 0.9375rem;
    width: 2.1875rem;
    height: 2.1875rem;
  }
  .c-button02._how::before {
    top: -6.5625rem;
    width: 20.625rem;
    height: 8.1875rem;
  }
  .c-button02._how .c-button02__text {
    padding-block: 1.25rem;
  }
  .c-button02._how .c-button02__balloonText {
    top: -3.4375rem;
    left: calc(50% - 9.375rem);
    font-size: 0.9375rem;
  }
  .c-button03 {
    padding-block: 1.25rem;
    font-size: 1.125rem;
  }
  .c-button03::before {
    right: 1.25rem;
    width: 0.625rem;
    height: 0.9375rem;
  }
  .c-button03::after {
    top: 0.4375rem;
    left: -1.125rem;
    width: 4.625rem;
    height: 4.1875rem;
  }
  .c-button03__small {
    font-size: 1.125rem;
    line-height: 1.3333333333;
    letter-spacing: 0.01em;
  }
  .c-card {
    padding: 1.25rem;
  }
  .c-card__sponsor {
    font-size: 1.25rem;
  }
  .c-card__title {
    margin-top: 0.5rem;
    font-size: 1.375rem;
  }
  .c-card__number {
    padding-block: 0.1875rem;
    font-size: 1rem;
  }
  .c-card__numberAccent {
    font-size: 1.25rem;
  }
  .c-drawer__button {
    width: 4.375rem;
    height: 4.375rem;
  }
  .c-drawer__button::before {
    inset: auto auto
      clamp(calc(12 * 375 / 540 / 16 * 1rem), calc(12 / 540 * 100vw), 0.75rem)
      50%;
    font-size: 1rem;
  }
  .c-drawer__line,
  .c-drawer__line::before,
  .c-drawer__line::after {
    width: 2.8125rem;
    height: 0.125rem;
  }
  .c-drawer__line {
    inset: 1.5rem auto auto 50%;
  }
  .c-drawer__line::before {
    top: 0.25rem;
  }
  .c-flow {
    gap: 2.5rem;
  }
  .c-flow__item::before {
    bottom: -2.5rem;
    width: 2.5rem;
    height: 1.25rem;
    clip-path: polygon(50% 1.25rem, 0% 0%, 2.5rem 0%);
  }
  .c-flow__title {
    margin-left: 1.25rem;
    gap: 0.625rem;
    font-size: 1.5rem;
  }
  .c-flow__number {
    font-size: 2.5rem;
  }
  .c-flow__number::after {
    top: 0.1875rem;
    left: 0.1875rem;
  }
  .c-flow__content {
    padding: 2rem 1.25rem 2rem;
  }
  .c-flow__content-subTitle {
    font-size: 1.25rem;
  }
  .c-flow__text {
    font-size: 1.125rem;
  }
  .c-flow02 {
    grid-template-columns: repeat(1, 1fr);
    padding-inline: 1.25rem;
  }
  .c-flow02__card {
    border-radius: 1.25rem;
  }
  .c-flow02__title {
    padding-block: 0.75rem;
    border-radius: 1.25rem 1.25rem 0 0;
    font-size: 1.125rem;
  }
  .c-flow02__text {
    padding: 1.25rem 1.25rem;
    font-size: 1rem;
  }
  .c-flow02__numberBlock {
    top: -1.25rem;
    left: -1.25rem;
  }
  .c-flow02__number {
    font-size: 3rem;
  }
  .c-flow02__number::after {
    top: 0.1875rem;
    left: 0.1875rem;
  }
  .c-heading__en {
    font-size: 2rem;
  }
  .c-heading__jp {
    padding-top: 0.5rem;
    font-size: 1.25rem;
  }
  .c-heading02__text {
    font-size: 1.375rem;
    line-height: 2.1363636364;
  }
  .c-heading02__title {
    margin-top: 0.75rem;
    font-size: 2.75rem;
    line-height: 1.0681818182;
  }
  .c-heading02__titleLarge {
    margin-top: -0.875rem;
    font-size: 4.25rem;
    line-height: 0.6911764706;
  }
  .c-heading03 {
    gap: 1.25rem;
  }
  .c-heading03__titleEn {
    font-size: 2rem;
  }
  .c-heading03__image {
    padding-inline: 4rem;
  }
  .c-heading03__titleJp {
    padding: 0 0.5rem 0.125rem;
    background: linear-gradient(transparent 60%, var(--color-pink) 40%);
    font-size: 1.75rem;
    line-height: 1.25;
  }
  .c-heading03__titleJp-small {
    font-size: 1.5rem;
  }
  .c-heading04 {
    font-size: 1.5rem;
  }
  .c-heading05__title {
    width: -moz-fit-content;
    width: fit-content;
    padding-inline: 2.75rem;
    padding-block: 0.375rem;
    font-size: 1.125rem;
  }
  .c-heading05__contents {
    right: -2rem;
    width: 5rem;
    height: 5rem;
  }
  .c-heading05__number {
    font-size: 1.5rem;
  }
  .c-heading05__text {
    font-size: 1.125rem;
  }
  .c-heading06__text {
    font-size: 1.125rem;
  }
  .c-heading06__title {
    font-size: 1.875rem;
    line-height: 1.2;
  }
  .c-heading06__textAccent {
    top: -1.75rem;
    left: -1.125rem;
    font-size: 2rem;
  }
  .c-heading07 {
    width: 80%;
    min-width: unset;
    padding: 0.75rem 2rem;
    font-size: 1.125rem;
  }
  .c-news__link {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
  .c-news__title::before {
    width: 1.5rem;
    height: 1.5rem;
  }
  .c-news02__link {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
  .c-news02__title::before {
    width: 1.5rem;
    height: 1.5rem;
  }
  .p-campaign-link {
    right: 1.25rem;
    bottom: 1.25rem;
    max-width: 6.25rem;
  }
  .p-cancer__blocks {
    margin-top: 7.5rem;
  }
  .p-cancer__block {
    grid-template-columns: 1fr;
    padding: 1.875rem 1.25rem;
    gap: 2.5rem;
  }
  .p-cancer__block {
    padding: 1.875rem 1.25rem;
    border-radius: 1.875rem;
  }
  .p-cancer__block._breast01 {
    grid-template-columns: 1fr;
  }
  .p-cancer__block._block02 {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
  .p-cancer__blockContent {
    gap: 1.25rem;
  }
  .p-cancer__blockTitle {
    font-size: 1.5rem;
    text-align: center;
  }
  .p-cancer__blocks._image .p-cancer__blockTitle {
    text-align: center;
  }
  .p-cancer__blockText {
    font-size: 1.125rem;
  }
  .p-cancer__note {
    font-size: 0.875rem;
  }
  .p-cancer__symptomsList {
    padding: 1.25rem;
    gap: 1rem;
  }
  .p-cancer__symptomsTitle {
    font-size: 1.25rem;
  }
  .p-cancer__symptoms {
    margin-top: 0.75rem;
    gap: 0.75rem;
  }
  .p-cancer__block._breast01 .p-cancer__symptoms {
    gap: 0.75rem;
  }
  .p-cancer__symptom {
    gap: 0.9375rem;
  }
  .p-cancer__symptomIcon {
    width: 1.25rem;
    height: 1.25rem;
  }
  .p-cancer__symptomText {
    font-size: 1rem;
    line-height: 1.5625;
  }
  .p-cancer__chartImage {
    max-width: 25rem;
  }
  .p-cancer__block._breast01 .p-cancer__chartContent {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
  .p-cancer-about {
    margin-top: 3.75rem;
    padding-block: 3.75rem;
  }
  .p-cancer-about__flow {
    margin-top: 2.5rem;
  }
  .p-cancer-about__point {
    margin-top: 3.75rem;
  }
  .p-cancer-check {
    margin-top: 5rem;
  }
  .p-cancer-check__button {
    margin-top: 5rem;
  }
  .p-cancer-how {
    margin-top: 3.75rem;
    padding-block: 3.75rem 3.75rem;
    background: url(../../assets/images/common/background-wave@2x.webp) repeat-x
        top center/45rem 3.875rem,
      linear-gradient(
        to bottom,
        transparent 0%,
        transparent 3.75rem,
        var(--color-gray) 3.75rem,
        var(--color-gray) 100%
      );
  }
  .p-cancer-how__button {
    margin-top: 7.5rem;
  }
  .p-cancer__content {
    gap: 1.25rem;
  }
  .p-cancer__title {
    font-size: 1.5rem;
    line-height: 1.4583333333;
  }
  .p-cancer__text {
    font-size: 1.125rem;
    line-height: 1.7777777778;
  }
  .p-cancer__source {
    margin-top: 0.9375rem;
    font-size: 0.875rem;
  }
  .p-cancer__character {
    justify-self: center;
    max-width: 18.75rem;
  }
  .p-chart__contents {
    padding-block: 2.5rem;
    padding: 3.75rem 1.25rem;
    border-radius: 3.75rem;
  }
  .p-chart__subTitle,
  .p-chart__text {
    font-size: 1rem;
  }
  .p-chart__title {
    font-size: 2.375rem;
  }
  .p-chart__title._medium {
    font-size: 1.375rem;
  }
  .p-chart__titleSmall {
    font-size: 1.375rem;
  }
  .p-chart__questionTitle {
    font-size: 1.375rem;
  }
  .p-chart__text {
    margin-top: 1.25rem;
  }
  .p-chart__buttons {
    flex-direction: column;
    margin-top: 1.875rem;
    margin-inline: auto;
    gap: 1.25rem;
  }
  .p-chart._point .p-chart__contents::before {
    right: calc(50% - 11.375rem);
    bottom: -1.25rem;
    width: 4.0625rem;
    height: 5.625rem;
  }
  .p-chart._point._home .p-chart__contents::before {
    right: -0.625rem;
    bottom: -2.1875rem;
  }
  .p-chart__textNote {
    margin-top: 2rem;
  }
  .p-chart._home .p-chart__buttonsItem {
    width: 17.5rem;
  }
  .p-chart._question .p-chart__contents {
    height: unset;
  }
  .p-chart._question .p-chart__buttonsItem {
    width: 17.5rem;
  }
  .p-chart._medical .p-chart__contents::before {
    right: calc(50% - 11.375rem);
    bottom: -1.25rem;
    width: 4.0625rem;
    height: 5.625rem;
  }
  .p-chart._self .p-chart__contents::before {
    right: calc(50% - 10.75rem);
    bottom: -1.25rem;
    width: 4.6875rem;
    height: 5.625rem;
  }
  .p-chart__image {
    margin-block: 1.875rem 1.625rem;
    padding-inline: 3rem;
  }
  .p-check__contents {
    margin-top: 3rem;
    padding: 2.5rem 1.25rem;
  }
  .p-check__contents::before {
    top: -4.375rem;
    right: 0.625rem;
    width: 5rem;
    height: 6.25rem;
  }
  .p-check__text {
    font-size: 1rem;
    line-height: 1.5;
    text-align: left;
  }
  .p-check__lists {
    grid-template-columns: 1fr;
    margin-top: 1.875rem;
  }
  .p-check__list {
    font-size: 1.125rem;
    line-height: 1.5;
  }
  .p-check__checkbox {
    gap: 1rem;
  }
  .p-check__checkbox input[type="checkbox"] {
    top: 0.0625rem;
    width: 1.125rem;
    height: 1.125rem;
    border-radius: 0.125rem;
    box-shadow: 0 0 0 0.1875rem var(--color-red-light);
  }
  .p-check__checkbox input[type="checkbox"]:checked::before {
    width: 0.625rem;
    height: 0.3125rem;
  }
  .p-check__items {
    margin-top: 2rem;
    gap: 0.75rem;
  }
  .p-check__containerText {
    margin-top: 1.5rem;
    font-size: 1.125rem;
    line-height: 1.5;
    text-align: left;
  }
  .p-faq__inner {
    grid-template-columns: 1fr;
    grid-template-areas: "content" "side";
  }
  .p-faq__sectionTitle {
    font-size: 1.5rem;
  }
  .p-faq__list {
    margin-top: 1.5rem;
  }
  .p-faq__sidebar {
    position: static;
  }
  .p-faq__button {
    max-width: 100%;
    margin-top: 2.5rem;
  }
  .p-footer {
    padding-block: 0.875rem 0.875rem;
    background: var(--color-red-rose);
  }
  .p-footer::before {
    display: block;
    position: absolute;
    top: -7.5rem;
    left: 0;
    width: 100%;
    height: 7.5625rem;
    background-image: url(../../assets/images/common/footer-background@2x.webp);
    background-position: bottom;
    background-size: 100% auto;
    background-repeat: repeat-x;
    content: "";
  }
  .p-footer__character {
    z-index: 1;
    top: -12.5rem;
    left: 50%;
    width: 19.875rem;
    height: 10.9375rem;
  }
  .p-footer__text {
    top: 3.75rem;
    left: calc(50% - 9.25rem);
    font-size: 0.9375rem;
  }
  .p-footer__lists {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    width: 100%;
    max-width: 20.9375rem;
    margin-inline: auto;
    gap: 0.5rem;
  }
  .p-footer__copyright {
    margin-top: 0.75rem;
  }
  .p-header {
    height: auto;
  }
  .p-header__inner {
    height: 4.4375rem;
  }
  .p-header__logo {
    padding: 0.9375rem 0.9375rem 0.625rem 1.25rem;
  }
  .p-header__logo img {
    max-width: 9.375rem;
    transition: max-width 0.3s ease-out;
  }
  .p-header.is-scroll .p-header__logo {
    padding: 0.625rem;
  }
  .p-header.is-scroll .p-header__logo img {
    max-width: 6.875rem;
  }
  .p-header__nav {
    display: none;
  }
  .p-line::before,
  .p-line::after {
    width: 1.25rem;
  }
  .p-link {
    padding-bottom: 16.75rem;
  }
  .p-link__container {
    padding-block: 2.5rem 2.5rem;
    border-radius: 0 0 2.5rem 2.5rem;
  }
  .p-link__inner.l-inner {
    max-width: 37.5rem;
  }
  .p-link__title {
    font-size: 2rem;
  }
  .p-link__items {
    margin-top: 2.5rem;
    gap: 1.75rem;
  }
  .p-loading-image {
    max-width: 90%;
  }
  body.loading::after {
    width: 85vw;
  }
  .p-policy__section:not(:first-child) {
    margin-top: 2.5rem;
  }
  .p-policy__heading {
    font-size: 1.5rem;
  }
  .p-policy__text {
    margin-top: 1.5rem;
  }
  .p-media {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-areas: "image" "content";
    padding: 2.5rem 1.25rem;
    gap: 2.5rem;
    border-radius: 3.75rem;
  }
  .p-media._first .p-media__heading::before {
    right: 0;
    bottom: -1.25rem;
    width: 16vw;
    height: 18.6666666667vw;
  }
  .p-media._second .p-media__heading::before {
    right: 0;
    bottom: -1.25rem;
    width: 16vw;
    height: 17.3333333333vw;
  }
  .p-media__text {
    margin-top: 1.25rem;
    font-size: 1.125rem;
  }
  .p-media__button {
    margin-inline: auto;
  }
  .p-media__image {
    width: 18.75rem;
    margin-inline: auto;
  }
  .p-media._reverse {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-areas: "image" "content";
    padding: 2.5rem 1.25rem;
    gap: 2.5rem;
  }
  .p-media02 {
    grid-template-columns: 1fr;
    gap: 1.125rem;
  }
  .p-media02__title {
    font-size: 1.5rem;
  }
  .p-media02__text {
    font-size: 1rem;
    line-height: 1.5;
  }
  .p-media03 {
    grid-template-columns: 1fr;
    max-width: 37.5rem;
    margin: 0 auto;
    gap: 1.875rem;
  }
  .p-media03__content {
    gap: 1.875rem;
  }
  .p-media03__text {
    font-size: 1.125rem;
  }
  .p-media03__image {
    margin-right: 0;
  }
  .p-media03__image::before {
    right: -0.625rem;
    bottom: -6.25rem;
    width: min(10rem, 26.6666666667vw);
    height: min(14rem, 37.3333333333vw);
  }
  .p-media03__list {
    grid-template-columns: 1fr;
    gap: 0.625rem;
  }
  .p-media03__listTitle {
    padding: 0.1875rem 0.625rem;
    font-size: 1.125rem;
  }
  .p-media03__listText {
    font-size: 1.125rem;
  }
  .p-media04 {
    grid-template-columns: 1fr;
    gap: 3.75rem;
  }
  .p-media04__titleAccent {
    top: -3rem;
    font-size: 2.5rem;
  }
  .p-media04__title {
    font-size: 1.25rem;
    line-height: 1.5;
    text-align: center;
  }
  .p-media04__title-exlarge {
    padding-right: 0;
    font-size: 2rem;
    line-height: 1.5;
  }
  .p-media04__title-large {
    font-size: 1.5rem;
    line-height: 1.5;
  }
  .p-media04__titleSmall {
    font-size: 1.125rem;
    line-height: 1.5;
  }
  .p-media04__subTitle {
    font-size: 1.125rem;
  }
  .p-media04__date {
    font-size: 1.375rem;
  }
  .p-media04__dateLarge {
    font-size: 1.75rem;
  }
  .p-media04__dateLarge._accent {
    padding-left: 1rem;
  }
  .p-media04__dateSmall {
    font-size: 1.375rem;
  }
  .p-media04__location {
    font-size: 1.375rem;
  }
  .p-media05 {
    grid-template-columns: 1fr;
  }
  .p-media05._coffee {
    gap: 3.75rem;
  }
  .p-media05__first {
    padding: 0.4375rem 1.25rem 0.4375rem;
    gap: 0.125rem;
    font-size: 1rem;
    line-height: 1.5;
  }
  .p-media05__firstNumber {
    font-size: 1.5rem;
  }
  .p-media05__heading {
    font-size: min(5.1282051282vw, 1.25rem);
  }
  .p-media05__heading span {
    font-size: 1.25rem;
    line-height: 1.5;
  }
  .p-media05__heading:not(:first-child) {
    margin-top: 0.625rem;
  }
  .p-media05__text {
    margin-top: 1rem;
    font-size: 1rem;
  }
  .p-media05__textNote {
    margin-top: 0.625rem;
  }
  .p-media05__coffee {
    max-width: 12.5rem;
    margin-top: 1rem;
  }
  .p-media05__balloon {
    top: -4.375rem;
    right: -1.25rem;
    max-width: max(50%, 11.25rem);
  }
  .p-media05__info {
    flex-direction: column;
    width: 100%;
    margin-top: 1rem;
    padding: 1rem 0.75rem;
    gap: 0;
  }
  .p-media05__infoSmall {
    font-size: 1rem;
  }
  .p-media05__infoMedium {
    font-size: 1.125rem;
  }
  .p-media05__textNumber {
    font-size: 1.375rem;
  }
  .p-page-mv {
    padding-block: 3.75rem 1.25rem;
  }
  .p-page-mv__heading {
    font-size: 2rem;
    line-height: 1.46875;
  }
  .p-page-mv__breadcrumb {
    margin-top: 2.5rem;
  }
  .p-point {
    grid-template-columns: 1fr;
  }
  .p-point__contents {
    padding: 1.25rem;
    gap: 1.25rem;
  }
  .p-point__content::before {
    top: unset;
    right: 60%;
    bottom: -1.875rem;
    transform: rotate(180deg);
  }
  .p-point__title {
    font-size: 1.25rem;
  }
  .p-point__list,
  .p-point__text {
    font-size: 1.125rem;
  }
  .p-point__list {
    line-height: 1.6818181818;
  }
  .p-point__list::before {
    top: 0.75rem;
    left: -1rem;
    width: 0.5rem;
    height: 0.5rem;
    transform: translateY(0);
  }
  .p-point__textAccent {
    top: -2.5rem;
    left: 1.875rem;
    font-size: 3.25rem;
    line-height: 1.3333333333;
  }
  .p-point__image {
    width: 100%;
    max-width: 21.875rem;
    margin-inline: auto;
    padding-inline: 5rem;
  }
  .p-policy__section:not(:first-child) {
    margin-top: 2.5rem;
  }
  .p-policy__heading {
    font-size: 1.5rem;
  }
  .p-policy__text {
    margin-top: 1.5rem;
  }
  .p-single {
    margin-bottom: 6.25rem;
  }
  .p-single__meta {
    padding-bottom: 1.25rem;
  }
  .p-single__category {
    font-size: 0.875rem;
  }
  .p-single__title {
    font-size: 1.25rem;
    line-height: 1.5;
  }
  .p-single__editor {
    margin-top: 1.875rem;
  }
  .p-single__editor > * {
    margin-block: 1.875rem;
  }
  .p-single__editor p {
    font-size: 1rem;
  }
  .p-single__editor .p-single__col2 {
    grid-template-columns: 1fr;
    margin-block: 2.5rem;
    gap: 1.875rem;
  }
  .p-single__button {
    margin-inline: auto;
  }
  .p-sponsoring {
    padding-block: 4rem;
  }
  .p-sponsoring__title {
    font-size: 2rem;
    line-height: 1.15625;
  }
  .p-sponsoring__items {
    margin-top: 2.5rem;
    gap: 1.25rem;
  }
  .p-sponsoring__item {
    width: calc(50% - 0.9375rem);
  }
  .p-table__header,
  .p-table__data,
  .p-table__text,
  .p-table__link,
  .p-table__textNote {
    font-size: 1rem;
    line-height: 1.75;
    letter-spacing: 0.04375em;
  }
  .p-table__textNote {
    font-size: 0.75rem;
  }
  .p-table__header {
    font-size: 1.125rem;
    line-height: 1.6666666667;
  }
  .p-table__link {
    margin-top: 1rem;
  }
  .p-table__wrapper {
    gap: 0.875rem;
  }
  .p-table__textMedium {
    word-break: auto-phrase;
  }
  .p-table__contents {
    gap: 0.875rem;
  }
  .p-table__title,
  .p-table__period {
    font-size: 1.125rem;
    line-height: 1.6;
  }
  .p-table__header {
    display: block;
    width: 100%;
    padding-block: 1.5rem 0.1875rem;
  }
  .p-table__data {
    display: block;
    width: 100%;
    padding-block: 0.1875rem 1.5rem;
    font-size: 0.875rem;
  }
  .p-table__data._flex .p-table__lists:last-child {
    margin-top: 0.5rem;
  }
  .p-line::before,
  .p-line::after {
    width: 1.25rem;
  }
  .p-top-mv {
    padding-top: 6.5rem;
    display: grid;
    place-content: center;
    height: auto;
  }
  .p-top-mv__character {
    max-width: 90%;
    padding-left: 0;
  }
  .p-top-mv__copy {
    max-width: 85%;
    margin-top: -6.25rem;
  }
  .p-top-mv__about {
    padding-inline: var(--padding-sp);
    margin-top: 0;
    margin-bottom: 3.5rem;
    gap: 1rem;
  }
  .p-top-mv__aboutInner {
    padding: 1rem;
    flex-direction: column;
    border-radius: 1.5rem;
    gap: 1rem;
  }
  .p-top-mv__aboutTtl {
    font-size: 2rem;
  }
  .p-top-mv__aboutTtl,
  .p-top-mv__aboutText {
    text-align: left;
    width: 100%;
    font-size: 1rem;
    font-weight: 500;
  }
  .p-top-news {
    margin-inline: 1.25rem;
    padding-block: 2.5rem;
  }
  .p-top-news__inner {
    grid-template-columns: 1fr;
  }
  .p-top-news__heading {
    font-size: 1.5rem;
  }
  .p-top-limit {
    margin-top: -1px;
    padding-block: 3.75rem;
  }
  .p-top-limit__ribbon {
    top: -5.125rem;
    left: -4.375rem;
    max-width: 31.25rem;
  }
  .p-top-limit__inner {
    padding: 3.75rem 1.5rem;
    border-radius: 3.75rem;
  }
  .p-top-limit__heading {
    text-align: center;
  }
  .p-top-limit__character {
    top: -6.25rem;
    max-width: 20%;
  }
  .p-top-limit__content:not(:first-child) {
    margin-top: 2.1875rem;
  }
  .p-top-limit__media {
    margin-top: 2.1875rem;
  }
  .p-top-limit__cardList {
    grid-template-columns: 1fr;
    margin-top: 2.5rem;
  }
  .p-top-limit__card {
    padding: 1.25rem 1.5rem;
    border-radius: 1.25rem;
  }
  .p-top-limit__card::before {
    top: -1.25rem;
    left: -1.25rem;
    width: 4.375rem;
    height: 3.125rem;
  }
  .p-top-limit__cardText {
    font-size: 1rem;
  }
  .p-top-limit__cardTitle {
    margin-top: 0.5rem;
    font-size: 1.25rem;
  }
  .p-top-limit__cardImage {
    margin-top: 1.25rem;
  }
  .p-top-action {
    margin-inline: 1.25rem;
    padding-block: 2.5rem;
  }
  .p-top-action__inner {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
  .p-top-action__ribbon {
    max-width: 18.75rem;
    margin-inline: auto;
    margin-block: 0;
  }
  .p-top-action__text {
    font-size: 1.125rem;
  }
  .p-top-action__text + .p-top-action__text {
    margin-top: 1rem;
  }
  .p-top-cancer {
    padding-block: 3.75rem 12.5rem;
  }
  .p-top-cancer__media {
    margin-top: 2.5rem;
    gap: 1.25rem;
  }
  .p-top-cancer__button {
    margin-top: 6.25rem;
  }
  .p-top-campaign {
    margin-top: -5rem;
    border-radius: 3.75rem 3.75rem 0 0;
  }
  .p-top-campaign__heading {
    top: -3.75rem;
  }
  .p-top-campaign__ankerList {
    grid-template-columns: 1fr;
    gap: 1.5625rem;
  }
  .p-top-campaign__ankerLink {
    max-width: 25rem;
    margin-inline: auto;
    padding: 0.625rem 0.75rem;
    padding-left: 2rem;
    font-size: 1.25rem;
  }
  .p-top-campaign__ankerLink::before {
    width: 1.25rem;
    height: 0.75rem;
    left: 0.75rem;
  }
  .p-top-campaign__ankerIcon {
    max-width: 2.5rem;
  }
  .p-top-campaign__description {
    margin-top: 1.25rem;
    font-size: 1rem;
  }
  .p-top-campaign__period {
    grid-template-columns: 1fr;
    width: 100%;
    max-width: 25rem;
    padding: 1rem;
    gap: 0.25rem;
  }
  .p-top-campaign__periodTitle {
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto;
    padding: 0.125rem 1.875rem;
    font-size: 1.25rem;
  }
  .p-top-campaign__periodText {
    grid-template-columns: 1fr auto;
    grid-auto-flow: unset;
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto;
    gap: 0;
    font-size: 1.25rem;
  }
  .p-top-campaign__periodNumber {
    font-size: 1.75rem;
  }
  .p-top-form {
    padding-top: 3.75rem;
  }
  .p-top-form__buttons {
    grid-template-columns: 1fr;
    margin-top: 1.25rem;
    gap: 1.25rem;
  }
  .p-top-overview {
    margin-top: 3.75rem;
    padding: 2.5rem 1.25rem;
    border-radius: 3.75rem;
  }
  .p-top-overview__col2 {
    grid-template-columns: 1fr;
    gap: 1.25rem;
  }
  .p-top-overview__col2Content {
    padding: 1.875rem 1.25rem;
  }
  .p-top-overview__col2Heading {
    font-size: 1.25rem;
  }
  .p-top-overview__col2List {
    margin-top: 0.25rem;
  }
  .p-top-overview__col2Item {
    font-size: 1rem;
  }
  .p-top-overview__col2Bottom {
    grid-template-columns: 1fr;
    margin-top: 1.25rem;
    gap: 0.625rem;
  }
  .p-top-overview__col2Bottom .p-top-overview__col2Item {
    font-size: 0.875rem;
  }
  .p-top-overview__col2BottomItem + .p-top-overview__col2BottomItem {
    margin-left: 0;
    padding-left: 0;
    border-left: none;
  }
  .p-top-overview__col2BottomText {
    font-size: 0.875rem;
  }
  .p-top-overview__col2SubHeading {
    font-size: 1rem;
  }
  .p-top-overview__col2Text {
    font-size: 1rem;
  }
  .p-top-overview__col2Button {
    max-width: 18.75rem;
    margin-top: 0.625rem;
    margin-inline: auto;
  }
  .p-top-overview__table {
    margin-top: 1.25rem;
  }
  .p-top-overview__button {
    max-width: 25rem;
    margin-top: 1.875rem;
  }
  .p-top-prize {
    padding-block: 3.75rem;
  }
  .p-top-prize__text {
    font-size: 1rem;
  }
  .p-top-prize__text + .p-top-prize__text {
    margin-top: 0.75rem;
  }
  .p-top-prize__block {
    margin-top: 3.75rem;
    padding: 1.875rem;
  }
  .p-top-prize__blockHeading {
    margin-top: -3.125rem;
    margin-bottom: 1.25rem;
  }
  .p-top-prize__list {
    grid-template-columns: 1fr;
  }
  .p-top-prize__item {
    grid-template-rows: unset;
    padding: 1.875rem 0.625rem;
  }
  .p-top-prize__item + .p-top-prize__item {
    border-top: 0.0625rem dashed var(--color-red-light);
    border-left: none;
  }
  .p-top-prize__titleIcon {
    width: 2rem;
    height: 2rem;
    font-size: 1.5rem;
  }
  .p-top-prize__titleText {
    font-size: 1.25rem;
  }
  .p-top-prize__titleSmall {
    font-size: 0.875rem;
  }
  .p-top-prize__itemNumber {
    font-size: 1.75rem;
  }
  .p-top-prize__section {
    margin-top: 2.5rem;
  }
  .p-top-prize__cards {
    gap: 1.25rem;
  }
  .p-top-prize__card {
    width: calc(50% - 0.625rem);
  }
  .p-top-second {
    padding-block: 3.75rem 5rem;
  }
  .p-top-second .p-top-campaign__head {
    margin-top: 1.25rem;
  }
  .p-top-flow {
    margin-top: 3.75rem;
  }
  .p-top-flow__flow {
    margin-top: 1.25rem;
  }
  .p-top-flow__sns {
    margin-top: 1.25rem;
  }
  .p-top-flow__snsLink {
    position: relative;
    max-width: 18.75rem;
    margin-top: 0.625rem;
    margin-inline: auto;
    inset: auto;
    font-size: 1rem;
    line-height: 1.375;
  }
  .p-top-flow__snsTag {
    display: block;
    text-align: left;
  }
  .p-top-gift {
    margin-top: 3.75rem;
  }
  .p-top-gift__text {
    margin-top: 1.875rem;
    font-size: 1rem;
  }
  .p-top-gift__content {
    padding: 1.875rem;
  }
  .p-top-gift__title {
    top: -1.875rem;
  }
  .p-top-gift__items {
    grid-template-columns: 1fr;
    margin-top: 1.25rem;
    gap: 1.25rem;
  }
  .p-top-gift__itemText {
    font-size: 1.25rem;
  }
  .p-top-gift__itemNumber {
    font-size: 2rem;
  }
  .p-top-gift__or {
    justify-self: center;
    width: 2.5rem;
    height: 2.5rem;
    font-size: 1rem;
  }
  .p-top-sns__content {
    grid-template-columns: 1fr;
  }
  .p-top-sns__head {
    grid-template-columns: auto 1fr;
    grid-auto-flow: unset;
    gap: 0.625rem;
  }
  .p-top-sns__headIcon {
    width: 2.5rem;
    height: 2.5rem;
  }
  .p-top-sns__headText {
    font-size: 1rem;
  }
  .p-top-sns__headButton {
    grid-column: 1/-1;
    width: 7.5rem;
  }
  .p-top-sns__icons {
    gap: 1.25rem;
  }
  .p-top-sns__icons,
  .p-top-sns__line {
    margin-top: 1.25rem;
    padding: 1.25rem;
  }
  .p-top-sns__lineTitle {
    font-size: 1rem;
  }
  .p-top-sns__lineQr {
    margin-top: 0.5rem;
  }
  .p-top-sns__lineText {
    margin-top: 0.5rem;
  }
  .p-top-event {
    margin-top: 3.75rem;
    margin-inline: 1.25rem;
    padding-block: 3.75rem 6.875rem;
  }
  .p-top-event::before {
    width: 7.5rem;
    height: 12.5rem;
    inset: auto 0.625rem -3.125rem auto;
  }
  .p-top-event__media {
    margin-top: 2.5rem;
  }
  .u-hidden-pc {
    display: block;
  }
  .u-hidden-sp {
    display: none;
  }
}
@media screen and (max-width: 600px) {
  .p-sponsoring__item {
    width: 100%;
  }
  .p-top-prize__card {
    width: 100%;
  }
}
@media (max-width: 480px) {
  .p-top-mv__about {
    max-width: 25rem;
    margin-top: 2rem;
    padding-inline: var(--padding-sp);
  }
  .p-top-mv__aboutInner {
    border: none;
    background: none;
    padding-top: 0;
    padding-bottom: 0;
  }
  .p-top-mv__aboutTtl.p-media04__title {
    margin: 0 auto;
    text-align: center;
  }
  .p-top-mv__aboutTtl.p-media04__title img {
    max-width: 70%;
  }
}
@media (max-width: 375px) {
  :where(html) {
    font-size: calc(var(--font-size-base) / 375 * 100svi);
  }
  .p-line::before,
  .p-line::after {
    width: 1rem;
  }
  .p-top-action,
  .p-top-news {
    margin-inline: 1rem;
  }
}
@media (any-hover: hover) {
  :where(a[href^="tel:"]) {
    pointer-events: none;
  }
  .c-breadcrumb__link:hover {
    text-decoration: underline;
  }
  .c-button:hover {
    transform: translateY(0.25rem) translateX(0.25rem);
    box-shadow: 0 0 0 var(--color-red-lighter);
  }
  .c-button02._arrow:hover {
    transform: translateY(0.625rem) translateX(0.625rem);
    box-shadow: 0 0 0 var(--color-green-light);
  }
  .c-button03:hover {
    transform: translateY(0.3125rem) translateX(0.3125rem);
    box-shadow: 0 0 0 var(--color-red-lighter);
  }
  .c-drawer__item a:hover {
    background-color: var(--color-gray);
  }
  .c-drawer__formLink:hover .c-drawer__formButton {
    background: #fff;
    color: var(--color-blue-dark);
  }
  .c-drawer__link:hover {
    filter: brightness(1.1);
  }
  .c-drawer__policy:hover {
    color: var(--color-base);
  }
  .c-drawer__sns img:hover {
    filter: brightness(1.1);
  }
  .c-news__link:hover .c-news__title {
    text-decoration: underline;
  }
  .c-news__link:hover .c-news__title::before {
    translate: 0.125rem calc(-50% + 0.125rem);
    box-shadow: 0 0 0 0 var(--color-red);
  }
  .c-news02__link:hover .c-news02__title {
    text-decoration: underline;
  }
  .c-news02__link:hover .c-news02__title::before {
    translate: 0.125rem calc(-50% + 0.125rem);
    box-shadow: 0 0 0 0 var(--color-red);
  }
  .p-single__editor a:hover {
    text-decoration-line: none;
  }
  .p-top-prize__boxLink:hover {
    text-decoration: underline;
  }
  .p-campaign-link__link {
    transition: scale 0.2s ease-out;
  }
  .p-campaign-link__link:hover {
    scale: 1.05;
  }
}
