@charset "UTF-8";
/**
* Foundation
* ========================== */
/*!
 * ress.css • v1.2.2
 * MIT License
 * github.com/filipelinhares/ress
 */
/* # =================================================================
   # Global selectors
   # ================================================================= */
html {
  box-sizing: border-box;
  overflow-y: scroll; /* All browsers without overlaying scrollbars */
  -webkit-text-size-adjust: 100%; /* iOS 8+ */
}

*,
::before,
::after {
  background-repeat: no-repeat; /* Set `background-repeat: no-repeat` to all elements and pseudo elements */
  box-sizing: inherit;
}

::before,
::after {
  text-decoration: inherit; /* Inherit text-decoration and vertical align to ::before and ::after pseudo elements */
  vertical-align: inherit;
}

* {
  padding: 0; /* Reset `padding` and `margin` of all elements */
  margin: 0;
}

/* # =================================================================
   # General elements
   # ================================================================= */
/* Add the correct display in iOS 4-7.*/
audio:not([controls]) {
  display: none;
  height: 0;
}

hr {
  overflow: visible; /* Show the overflow in Edge and IE */
}

/*
* Correct `block` display not defined for any HTML5 element in IE 8/9
* Correct `block` display not defined for `details` or `summary` in IE 10/11
* and Firefox
* Correct `block` display not defined for `main` in IE 11
*/
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
  display: block;
}

summary {
  display: list-item; /* Add the correct display in all browsers */
}

small {
  font-size: 80%; /* Set font-size to 80% in `small` elements */
}

[hidden],
template {
  display: none; /* Add the correct display in IE */
}

abbr[title] {
  border-bottom: 1px dotted; /* Add a bordered underline effect in all browsers */
  text-decoration: none; /* Remove text decoration in Firefox 40+ */
}

a {
  background-color: transparent; /* Remove the gray background on active links in IE 10 */
  -webkit-text-decoration-skip: objects; /* Remove gaps in links underline in iOS 8+ and Safari 8+ */
  text-decoration: none;
}

a:active,
a:hover {
  outline-width: 0; /* Remove the outline when hovering in all browsers */
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace; /* Specify the font family of code elements */
}

b,
strong {
  font-weight: bolder; /* Correct style set to `bold` in Edge 12+, Safari 6.2+, and Chrome 18+ */
}

dfn {
  font-style: italic; /* Address styling not present in Safari and Chrome */
}

/* Address styling not present in IE 8/9 */
mark {
  background-color: #ff0;
  color: #000;
}

/* https://gist.github.com/unruthless/413930 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* # =================================================================
   # Forms
   # ================================================================= */
input {
  border-radius: 0;
}

/* Apply cursor pointer to button elements */
button,
[type=button],
[type=reset],
[type=submit],
[role=button] {
  cursor: pointer;
}

/* Replace pointer cursor in disabled elements */
[disabled] {
  cursor: default;
}

[type=number] {
  width: auto; /* Firefox 36+ */
}

[type=search] {
  -webkit-appearance: textfield; /* Safari 8+ */
}

[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none; /* Safari 8 */
}

textarea {
  overflow: auto; /* Internet Explorer 11+ */
  resize: vertical; /* Specify textarea resizability */
}

button,
input,
optgroup,
select,
textarea {
  font: inherit; /* Specify font inheritance of form elements */
}

optgroup {
  font-weight: bold; /* Restore the font weight unset by the previous rule. */
}

button {
  overflow: visible; /* Address `overflow` set to `hidden` in IE 8/9/10/11 */
}

/* Remove inner padding and border in Firefox 4+ */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: 0;
  padding: 0;
}

/* Replace focus style removed in the border reset above */
button:-moz-focusring,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  outline: 1px dotted ButtonText;
}

button,
html [type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button; /* Correct the inability to style clickable types in iOS */
}

button,
select {
  text-transform: none; /* Firefox 40+, Internet Explorer 11- */
}

/* Remove the default button styling in all browsers */
button,
input,
select,
textarea {
  background-color: transparent;
  border-style: none;
  color: inherit;
}

/* Style select like a standard input */
select {
  -moz-appearance: none; /* Firefox 36+ */
  -webkit-appearance: none; /* Chrome 41+ */
}

select::-ms-expand {
  display: none; /* Internet Explorer 11+ */
}

select::-ms-value {
  color: currentColor; /* Internet Explorer 11+ */
}

legend {
  border: 0; /* Correct `color` not being inherited in IE 8/9/10/11 */
  color: inherit; /* Correct the color inheritance from `fieldset` elements in IE */
  display: table; /* Correct the text wrapping in Edge and IE */
  max-width: 100%; /* Correct the text wrapping in Edge and IE */
  white-space: normal; /* Correct the text wrapping in Edge and IE */
}

::-webkit-file-upload-button {
  -webkit-appearance: button; /* Correct the inability to style clickable types in iOS and Safari */
  font: inherit; /* Change font properties to `inherit` in Chrome and Safari */
}

[type=search] {
  -webkit-appearance: textfield; /* Correct the odd appearance in Chrome and Safari */
  outline-offset: -2px; /* Correct the outline style in Safari */
}

/* # =================================================================
   # Specify media element style
   # ================================================================= */
img {
  width: 100%;
  height: auto;
  /* border-style: none; Remove border when inside `a` element in IE 8/9/10 */
}

/* Add the correct vertical alignment in Chrome, Firefox, and Opera */
progress {
  vertical-align: baseline;
}

svg:not(:root) {
  overflow: hidden; /* Internet Explorer 11- */
}

audio,
canvas,
progress,
video {
  display: inline-block; /* Internet Explorer 11+, Windows Phone 8.1+ */
}

/* # =================================================================
   # Accessibility
   # ================================================================= */
/* Hide content from screens but not screenreaders */
@media screen {
  [hidden~=screen] {
    display: inherit;
  }
  [hidden~=screen]:not(:active):not(:focus):not(:target) {
    position: absolute !important;
    clip: rect(0 0 0 0) !important;
  }
}
/* Specify the progress cursor of updating elements */
[aria-busy=true] {
  cursor: progress;
}

/* Specify the pointer cursor of trigger elements */
[aria-controls] {
  cursor: pointer;
}

/* Specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
[aria-disabled] {
  cursor: default;
}

/* # =================================================================
   # Selection
   # ================================================================= */
/* Specify text selection background color and omit drop shadow */
::-moz-selection {
  background-color: #b3d4fc; /* Required when declaring ::selection */
  color: #000;
  text-shadow: none;
}

::selection {
  background-color: #b3d4fc; /* Required when declaring ::selection */
  color: #000;
  text-shadow: none;
}

/* add */
ul {
  list-style-type: none;
}

p,
h2,
h3 {
  margin: 0;
  padding: 0;
}

html {
  font-size: 62.5%;
  /* 1rem > 10px */
}

body {
  font-size: 1.6em;
  line-height: 1.75;
}

/**
* Layout
* ========================== */
.footer {
  position: relative;
  color: #ffffff;
  overflow: hidden;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .footer {
    padding: 40px 0 0;
  }
}
@media screen and (min-width: 768px) {
  .footer {
    margin-top: -15em;
    z-index: 10;
  }
}
@media screen and (min-width: 1000px) {
  .footer {
    z-index: 10;
  }
}
.footer__container {
  position: relative;
  z-index: 2;
  margin: 0 auto;
  padding: 0 20px;
}
@media screen and (max-width: 767px) {
  .footer__container {
    padding: 0 15px;
  }
}
@media screen and (min-width: 768px) {
  .footer__container:first-child {
    padding-top: 75px;
  }
}
.footer__links-wrap {
  position: relative;
  background-color: transparent;
}
@media screen and (max-width: 767px) {
  .footer__links-wrap {
    height: 4.5em;
  }
}
@media screen and (min-width: 768px) {
  .footer__links-wrap {
    height: 212px;
  }
}
.footer__links-wrap::before {
  content: "";
  position: absolute;
  top: 1px;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to bottom right, transparent 50%, #0d0d0d 50%);
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  z-index: 1;
}
.footer__links-wrap > .footer__container {
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .footer__links-container {
    margin-inline: auto;
    width: 87%;
    max-width: 1280px;
  }
}
.footer__links-inner {
  display: flex;
  flex-direction: column;
  width: fit-content;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .footer__links-inner {
    padding-top: 156px;
    margin-inline: auto;
    gap: 33px;
    width: 100%;
    max-width: 233px;
  }
}
@media screen and (min-width: 768px) {
  .footer__links-inner {
    margin-inline-start: auto;
    gap: 30px;
    padding-top: 176px;
  }
}
.footer__buttons {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}
@media screen and (max-width: 767px) {
  .footer__buttons {
    gap: 1.5em;
  }
}
@media screen and (min-width: 768px) {
  .footer__buttons {
    gap: 2em;
  }
}
.footer__buttons .btn-double-border__link {
  margin-inline: 0;
  pointer-events: auto;
}
@media screen and (max-width: 767px) {
  .footer__buttons .btn-double-border__link {
    max-width: 100%;
  }
}
.footer__button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 280px;
  padding: 15px 25px;
  border: 2px solid #ffffff;
  background: transparent;
  color: #ffffff;
  text-decoration: none;
  font-size: 16px;
  font-weight: 500;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  .footer__button {
    width: 100%;
    max-width: 320px;
    margin: 0 auto;
  }
}
.footer__button:hover {
  background-color: rgba(255, 255, 255, 0.1);
  transform: translateY(-2px);
}
.footer__button-text {
  font-size: inherit;
}
.footer__button-arrow {
  font-size: 18px;
  font-weight: bold;
}
.footer__sns-content {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .footer__sns-content {
    justify-content: space-between;
    margin-bottom: 10em;
    column-gap: 31px;
  }
}
@media screen and (min-width: 768px) {
  .footer__sns-content {
    justify-content: flex-end;
    padding-bottom: 5em;
    column-gap: 37px;
  }
}
.footer__sns {
  display: flex;
  justify-content: center;
  align-items: center;
  column-gap: 20px;
}
@media screen and (max-width: 767px) {
  .footer__sns {
    column-gap: 9px;
  }
}
.footer__sns-label {
  font-family: "Cormorant Infant", serif;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.05rem;
  color: #ffffff;
}
@media screen and (max-width: 767px) {
  .footer__sns-label {
    font-size: 12px;
  }
}
.footer__sns-link {
  display: flex;
  position: relative;
  align-items: center;
  justify-content: center;
  border: 1px solid #ffffff;
  border-radius: 50%;
  color: #ffffff;
  text-decoration: none;
  transform-origin: center center;
  transition: all 0.3s ease;
  pointer-events: auto;
}
@media screen and (max-width: 767px) {
  .footer__sns-link {
    width: 35px;
    height: 35px;
  }
}
@media screen and (min-width: 768px) {
  .footer__sns-link {
    width: 58px;
    height: 58px;
  }
}
.footer__sns-link:hover {
  background-color: #ffffff;
  border: 1px solid #0d0d0d;
  color: #0d0d0d;
  transform: scale(1.1);
}
.footer__sns-icon {
  display: flex;
  justify-content: center;
  align-items: center;
}
.footer__sns-icon--x {
  width: 17px;
}
@media screen and (max-width: 767px) {
  .footer__sns-icon--x {
    width: 11px;
  }
}
.footer__sns-icon--egg {
  width: 21px;
}
@media screen and (max-width: 767px) {
  .footer__sns-icon--egg {
    width: 13px;
  }
}
.footer__bottom-wrap {
  width: 100%;
  background-color: #0d0d0d;
}
@media screen and (max-width: 767px) {
  .footer__bottom-wrap {
    padding-top: 259px;
  }
}
@media screen and (min-width: 768px) {
  .footer__bottom-wrap {
    padding-top: 5em;
  }
}
@media screen and (min-width: 1000px) {
  .footer__bottom-wrap {
    padding-top: 6em;
  }
}
@media screen and (max-width: 767px) {
  .footer__bottom-wrap .footer__container {
    padding-bottom: 2em;
  }
}
.footer__logo {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .footer__logo {
    margin-bottom: 0.5em;
  }
}
.footer__logo-text {
  display: block;
}
.footer__logo-main {
  display: block;
  font-size: 48px;
  font-weight: bold;
  color: #ff1493;
  line-height: 1.2;
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .footer__logo-main {
    font-size: 32px;
  }
}
.footer__logo-sub {
  display: block;
  font-size: 14px;
  font-weight: 500;
  color: #ff1493;
  letter-spacing: 2px;
}
@media screen and (max-width: 767px) {
  .footer__logo-sub {
    font-size: 12px;
    letter-spacing: 1px;
  }
}
.footer__logo img {
  height: auto;
}
@media screen and (max-width: 767px) {
  .footer__logo img {
    max-width: 91.7%;
  }
}
.footer__copyright {
  text-align: center;
  font-family: "Noto Serif JP", serif;
}
.footer__copyright p {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.7);
  margin: 0;
  padding-top: 1em;
  padding-bottom: 1.5em;
}
@media screen and (max-width: 767px) {
  .footer__copyright p {
    font-size: 11px;
  }
}
@media screen and (max-width: 767px) {
  .footer .btn-double-border__link {
    margin-top: 0;
    padding-top: 10px;
    padding-bottom: 10px;
  }
}
@media screen and (min-width: 768px) {
  .footer .btn-double-border__link {
    margin-top: 0;
  }
}

/*
*--- -- - -- --- -- - -- --- -- - -- --- -- - -- ---
* モーダルアニメーション用のキーフレーム
*--- -- - -- --- -- - -- --- -- - -- --- -- - -- ---
*/
@keyframes mmfadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes mmfadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes mmslideIn {
  from {
    transform: translateY(-15%) scale(0.95);
    opacity: 0;
  }
  to {
    transform: translateY(0) scale(1);
    opacity: 1;
  }
}
@keyframes mmslideOut {
  from {
    transform: translateY(0) scale(1);
    opacity: 1;
  }
  to {
    transform: translateY(-15%) scale(0.95);
    opacity: 0;
  }
}
@media screen and (min-width: 768px) {
  .footer__logo-image {
    max-width: 1440px;
  }
}

/*
*--- -- - -- --- -- - -- --- -- - -- --- -- - -- ---
* R7モーダルのスタイル
*--- -- - -- --- -- - -- --- -- - -- --- -- - -- ---
*/
.modal {
  display: none;
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  transition: all 0.3s ease;
}
.modal.is-open {
  display: block;
}
.modal.is-open .modal__overlay {
  opacity: 1;
  visibility: visible;
}
.modal.micromodal-slide[aria-hidden=false] .modal__overlay {
  animation: mmfadeIn 0.3s cubic-bezier(0, 0, 0.2, 1);
}
.modal.micromodal-slide[aria-hidden=false] .modal__container {
  animation: mmslideIn 0.3s cubic-bezier(0, 0, 0.2, 1);
}
.modal.micromodal-slide[aria-hidden=true] .modal__overlay {
  animation: mmfadeOut 0.4s cubic-bezier(0, 0, 0.2, 1);
  animation-fill-mode: forwards;
}
.modal.micromodal-slide[aria-hidden=true] .modal__container {
  animation: mmslideOut 0.4s cubic-bezier(0, 0, 0.2, 1);
  animation-fill-mode: forwards;
}
.modal__overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.8);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9998;
  opacity: 0;
  visibility: hidden;
}
.modal__container {
  display: grid;
  align-items: center;
  position: relative;
  background-color: #0d0d0d;
  overflow-y: auto;
  color: #ffffff;
}
@media screen and (max-width: 767px) {
  .modal__container {
    width: 100%;
    height: 100%;
    padding-bottom: 64px;
  }
}
@media screen and (min-width: 768px) {
  .modal__container {
    margin: 0 auto;
    width: 100%;
    height: 100%;
    max-width: 1440px;
    max-height: 860px;
  }
}
.modal__close {
  background: none;
  border: none;
  font-size: 30px;
  cursor: pointer;
  color: #0d0d0d;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: background-color 0.3s ease;
}
.modal__close:hover {
  background-color: rgba(0, 0, 0, 0.1);
}
@media screen and (max-width: 767px) {
  .modal__content {
    padding: 12%;
  }
}
@media screen and (min-width: 768px) {
  .modal__content {
    padding: 5%;
  }
}
@media screen and (min-width: 1000px) {
  .modal__content {
    padding: 7%;
  }
}
@media screen and (min-width: 1230px) {
  .modal__content {
    padding: 8.5em 13em;
  }
}
.modal__r7-content {
  text-align: center;
}
.modal__r7-grid {
  display: grid;
}
@media screen and (max-width: 767px) {
  .modal__r7-grid {
    grid-template-columns: repeat(2, 1fr);
    grid-template-areas: "item1 item2" "item3 item4" "item5 item6" "item7 view-more";
    gap: 40px 24px;
  }
}
@media screen and (min-width: 768px) {
  .modal__r7-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 100px 60px;
  }
}
.modal__r7-grid-item {
  display: flex;
  position: relative;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 768px) {
  .modal__r7-grid-item:nth-child(4) .modal__r7-item-container {
    position: relative;
  }
}
@media screen and (min-width: 768px) {
  .modal__r7-grid-item:nth-child(4) .modal__r7-item-container .modal__r7-item-number {
    left: -38%;
  }
}
@media screen and (min-width: 1000px) {
  .modal__r7-grid-item:nth-child(4) .modal__r7-item-container .modal__r7-item-number {
    left: -46%;
  }
}
@media screen and (max-width: 767px) {
  .modal__r7-grid-item:nth-child(7) {
    grid-area: item7;
  }
}
.modal__r7-grid-item:nth-child(8) {
  display: flex;
  justify-content: center;
  align-items: flex-end;
}
@media screen and (max-width: 767px) {
  .modal__r7-grid-item:nth-child(8) {
    grid-area: view-more;
  }
}
.modal__r7-item-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5em;
  color: #ffffff;
}
.modal__r7-image {
  height: 65.7%;
  object-fit: contain;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .modal__r7-image {
    max-height: 62px;
  }
}
@media screen and (min-width: 768px) {
  .modal__r7-image {
    max-height: 100px;
  }
}
@media screen and (min-width: 1000px) {
  .modal__r7-image {
    max-height: 142px;
  }
}
.modal__r7-item-number {
  position: absolute;
  font-size: 72px;
  font-family: "Rochester", cursive;
  z-index: 0;
  background: linear-gradient(to bottom, #ffffff, #888888);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  opacity: 0.4;
}
@media screen and (max-width: 767px) {
  .modal__r7-item-number {
    font-size: 32px;
    top: -30px;
    left: -3px;
  }
}
@media screen and (min-width: 768px) {
  .modal__r7-item-number {
    font-size: 48px;
    top: -48px;
    left: -24px;
  }
}
@media screen and (min-width: 1000px) {
  .modal__r7-item-number {
    font-size: 72px;
    top: -62px;
    left: -34px;
  }
}
@media screen and (min-width: 1000px) {
  .modal__r7-title-main {
    font-size: 1.375em;
  }
}
@media screen and (min-width: 768px) {
  .modal__r7-title-main {
    font-size: 1.25em;
  }
}
@media screen and (max-width: 767px) {
  .modal__r7-title-main {
    font-size: 1em;
  }
}
@media screen and (max-width: 767px) {
  .modal__r7-title-sub {
    position: relative;
    top: -0.5em;
    font-size: 0.6125em;
  }
}
@media screen and (min-width: 768px) {
  .modal__r7-title-sub {
    font-size: 0.6875em;
    position: relative;
    top: -10px;
  }
}
.modal__r7-button-wrap {
  margin-top: 30px;
}

.modal__bottom-menu {
  transition: transform 2s ease-in-out;
}
@media screen and (max-width: 767px) {
  .modal__bottom-menu {
    position: fixed;
    bottom: 0;
    width: 100%;
    z-index: 9999;
    border-radius: 1em 1em 0 0;
    background-color: #ffffff;
  }
}
@media screen and (min-width: 768px) {
  .modal__bottom-menu {
    position: absolute;
    bottom: 0;
    right: 0;
    width: 26.67%;
    max-width: 384px;
    background-color: #0d0d0d;
  }
}
.modal__bottom-menu .bottom-menu__container {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .modal__bottom-menu .bottom-menu__container {
    justify-content: space-between;
    height: 60px;
  }
}
@media screen and (min-width: 768px) {
  .modal__bottom-menu .bottom-menu__container {
    justify-content: space-between;
  }
}
.modal__bottom-menu .bottom-menu__inner {
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .modal__bottom-menu .bottom-menu__inner:first-child {
    width: 77.6%;
  }
}
@media screen and (max-width: 767px) {
  .modal__bottom-menu .bottom-menu__inner:last-child {
    display: grid;
    width: 22.4%;
    justify-content: end;
    padding-inline-end: 24px;
    padding-block: 8px;
    background-color: #0d0d0d;
    border-radius: 0 16px 0 0;
  }
}
.modal__bottom-menu .bottom-menu__r7-logo {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .modal__bottom-menu .bottom-menu__r7-logo {
    width: 83%;
  }
}
.modal__bottom-menu .bottom-menu__r7-logo img {
  vertical-align: bottom;
}
@media screen and (max-width: 767px) {
  .modal__bottom-menu .bottom-menu__r7-logo img {
    width: 58%;
  }
}
@media screen and (min-width: 768px) {
  .modal__bottom-menu .bottom-menu__r7-logo img {
    padding: 28px 0 28px 32px;
  }
}
@media screen and (min-width: 768px) {
  .modal__bottom-menu .bottom-menu__r7-button {
    padding: 32px;
  }
}
.modal__bottom-menu .bottom-menu__r7-link {
  display: grid;
  place-items: center;
}
@media screen and (max-width: 767px) {
  .modal__bottom-menu .bottom-menu__r7-link img {
    width: 1em;
    background-color: #ffffff;
  }
}
@media screen and (min-width: 768px) {
  .modal__bottom-menu .bottom-menu__r7-link img {
    width: 1em;
    padding-block: 24px;
  }
}
@media screen and (max-width: 767px) {
  .modal__bottom-menu .bottom-menu__r7-link-text {
    font-size: 10px;
    letter-spacing: 0.05em;
  }
}
@media screen and (min-width: 768px) {
  .modal__bottom-menu .bottom-menu__r7-link-text {
    font-size: 14px;
    font-weight: 400;
    color: #ffffff;
    letter-spacing: 0.05em;
  }
}
@media screen and (max-width: 767px) {
  .modal__bottom-menu .bottom-menu__menu-wrap {
    display: flex;
    flex-direction: column;
  }
}
@media screen and (max-width: 767px) {
  .modal__bottom-menu .bottom-menu__menu-icon {
    width: 30px;
    height: 30px;
  }
}
.modal__bottom-menu .bottom-menu__menu-text {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .modal__bottom-menu .bottom-menu__menu-text {
    font-size: 10px;
    letter-spacing: 0.05em;
  }
}

#modal-r7.modal {
  display: none;
}

#modal-r7.modal.is-open {
  display: flex;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100vw;
  height: 100vh;
  background-color: rgba(0, 0, 0, 0.95);
  justify-content: center;
  align-items: center;
  z-index: 9990;
}

#modal-r7 .modal__container {
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  margin: 0;
  overflow: auto;
}

@media screen and (max-width: 767px) {
  .footer-modal .bottom-menu__r7-link {
    background-color: #ffffff;
  }
}
@media screen and (max-width: 767px) {
  .footer-modal .bottom-menu__r7-link-text {
    margin-top: 10px;
  }
}

/**
* Foundation
* ========================== */
.header {
  pointer-events: none;
}
.header > * {
  pointer-events: auto;
}
@media screen and (max-width: 767px) {
  .header {
    z-index: 1000;
    transition: opacity 0.5s ease;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .header {
    z-index: 100;
    position: fixed;
    top: 0;
    width: 100%;
  }
}
.header img {
  vertical-align: bottom;
}
.header__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .header__inner {
    padding-block: 32px;
  }
}
@media screen and (min-width: 768px) {
  .header__inner {
    height: 160px;
  }
}
@media screen and (max-width: 767px) {
  .header__title {
    width: 81.6%;
  }
}
@media screen and (min-width: 768px) {
  .header__title {
    padding-bottom: 16px;
  }
}
.header__logo-link {
  display: block;
  pointer-events: auto;
}
@media screen and (max-width: 767px) {
  .header__logo-link {
    max-width: 306px;
    line-height: 0;
  }
}
.header__nav {
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .header__nav {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .header__nav {
    display: block;
    margin-inline-end: 45px;
    width: 54px;
  }
}
.header__menu-button {
  pointer-events: auto;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  pointer-events: auto;
}
.header__menu-button:hover .header__menu-icon {
  animation: button-sparkle 375ms ease;
}
.header__menu-icon {
  width: 53px;
  height: 53px;
}
.header__menu-icon img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.header__menu-text {
  font-family: "Cormorant Infant", serif;
  font-size: 1.4rem;
  font-weight: bold;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .header__menu-text {
    margin-top: 6px;
  }
}
.header__menu-text--white {
  font-family: "Cormorant Infant", serif;
  font-size: 1.4rem;
  font-weight: bold;
  color: #ffffff;
}
@media screen and (min-width: 768px) {
  .header__menu-text--white {
    margin-top: 6px;
  }
}
.header__page-title {
  width: 100%;
  height: 100%;
  align-items: center;
  font-family: "Cormorant Infant", serif;
  font-size: 1.25em;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .header__page-title {
    display: flex;
  }
}
@media screen and (min-width: 768px) {
  .header__page-title {
    position: absolute;
    top: 100%;
    left: 0;
  }
}

@keyframes button-sparkle {
  0% {
    scale: 1;
  }
  20% {
    scale: 0.5;
  }
  75% {
    scale: 1.2;
  }
  100% {
    scale: 1;
  }
}
/*
*--- -- - -- --- -- - -- --- -- - -- --- -- - -- ---
* グローバルナビゲーション（ハンバーガーメニュー）
*--- -- - -- --- -- - -- --- -- - -- --- -- - -- ---
*/
.global-nav {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.global-nav.is-open {
  opacity: 1;
  visibility: visible;
}
@media screen and (max-width: 767px) {
  .global-nav.is-open {
    z-index: 2000 !important;
  }
}
@media screen and (min-width: 768px) {
  .global-nav.is-open {
    z-index: 2002 !important;
  }
}
.global-nav__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #0d0d0d;
  overflow-y: auto;
  background-image: url(../images/common/bg_text-circle.svg);
  background-size: 961px;
  background-repeat: no-repeat;
  background-position: calc(100% + 403px) calc(100% + 398px);
}
@media screen and (max-width: 767px) {
  .global-nav__overlay {
    background-size: 400px;
    background-repeat: no-repeat;
    background-position: calc(100% + 205px) calc(100% + 141px);
  }
}
.global-nav__container {
  position: relative;
  display: grid;
  grid-template-areas: "header" "main" "footer";
  gap: 0;
}
@media screen and (max-width: 767px) {
  .global-nav__container {
    grid-template-rows: repeat(3, auto);
  }
}
@media screen and (min-width: 768px) {
  .global-nav__container {
    grid-template-rows: 18.6% auto 1fr;
    min-height: 100vh;
    margin: 0 auto;
  }
}
.global-nav__header {
  grid-area: header;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .global-nav__header {
    padding-top: 36px;
  }
}
@media screen and (min-width: 768px) {
  .global-nav__header {
    padding-left: 39px;
    padding-right: 48px;
    height: 160px;
  }
}
.global-nav__title {
  color: #ffffff;
  font-size: 24px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .global-nav__title {
    margin-inline: auto;
    font-size: 18px;
  }
}
.global-nav__title-link {
  display: flex;
  align-items: center;
  width: 100%;
  height: auto;
  pointer-events: auto;
}
@media screen and (max-width: 767px) {
  .global-nav__title-link {
    max-width: 218px;
  }
}
@media screen and (min-width: 768px) {
  .global-nav__title-link {
    max-width: 230px;
  }
}
.global-nav__title-link img {
  width: 100%;
}
.global-nav__close-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  background: none;
  border: none;
  color: #ffffff;
  cursor: pointer;
  font-family: "Cormorant Infant", serif;
  font-weight: bold;
  font-size: 14px;
  pointer-events: auto;
}
@media screen and (max-width: 767px) {
  .global-nav__close-btn {
    display: none;
  }
}
.global-nav__close-btn.is-active .global-nav__close-line:first-child {
  transform: translateY(-50%) rotate(0deg);
}
.global-nav__close-btn.is-active .global-nav__close-line:last-child {
  transform: translateY(-50%) rotate(0deg);
}
.global-nav__close-icon {
  position: relative;
  width: 28px;
  height: 30px;
}
@media screen and (max-width: 767px) {
  .global-nav__close-icon {
    width: 22px;
    height: 24px;
  }
}
.global-nav__close-line {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #ffffff;
  transition: all 0.3s ease;
  transform-origin: center;
}
.global-nav__close-line:first-child {
  transform: translateY(-50%) rotate(45deg);
}
.global-nav__close-line:last-child {
  transform: translateY(-50%) rotate(-45deg);
}
.global-nav__close-text {
  letter-spacing: 0.05em;
}
.global-nav__main {
  grid-area: main;
  display: flex;
  padding: 0 20px;
  margin-inline: auto;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .global-nav__main {
    padding-top: 40px;
    padding-inline: 8%;
  }
}
@media screen and (min-width: 768px) {
  .global-nav__main {
    max-width: 1440px;
    padding: 0 2.7%;
  }
}
.global-nav__main-list {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .global-nav__main-list {
    display: flex;
    flex-direction: column;
    gap: 0;
  }
}
@media screen and (min-width: 768px) {
  .global-nav__main-list {
    display: flex;
    flex-direction: column;
    margin-inline-start: 4.4%;
  }
}
@media screen and (max-width: 767px) {
  .global-nav__main-item {
    padding-bottom: 48px;
  }
}
@media screen and (min-width: 768px) {
  .global-nav__main-item {
    padding-block: 1.5em;
  }
}
.global-nav__main-link {
  display: flex;
  align-items: center;
  gap: 1.25em;
  color: #ffffff;
  text-decoration: none;
  transition: opacity 0.3s ease;
  pointer-events: auto;
}
.global-nav__main-link:hover {
  opacity: 0.7;
}
@media screen and (max-width: 767px) {
  .global-nav__main-link {
    gap: 10px;
  }
}
.global-nav__main-en {
  font-family: "Cormorant Infant", serif;
  font-weight: bold;
  font-size: 3em;
  line-height: 1.2;
  letter-spacing: 0.03em;
}
@media screen and (max-width: 767px) {
  .global-nav__main-en {
    font-size: 24px;
    line-height: 1;
  }
}
.global-nav__main-ja {
  font-family: "Noto Serif JP", serif;
  font-size: 1.25em;
  font-weight: 400;
  color: #ffdfc4;
  opacity: 0.8;
}
@media screen and (max-width: 767px) {
  .global-nav__main-ja {
    font-size: 12px;
  }
}
.global-nav__footer {
  grid-area: footer;
  display: flex;
  align-items: center;
  margin-inline: auto;
  padding-inline: 20px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .global-nav__footer {
    padding-inline-start: 1em;
    flex-direction: column;
    align-items: flex-start;
    gap: 20px;
    padding-inline: 8%;
  }
}
@media screen and (min-width: 768px) {
  .global-nav__footer {
    display: block;
    max-width: 1440px;
    padding: 2.5em 2.7% 0 7.1%;
    justify-content: space-between;
  }
}
@media screen and (min-width: 1441px) {
  .global-nav__footer {
    padding: 2.5em 2.7% 0 101px;
  }
}
.global-nav__sub-list {
  display: flex;
  gap: 3.125em;
}
@media screen and (max-width: 767px) {
  .global-nav__sub-list {
    flex-direction: column;
    gap: 12px;
  }
}
.global-nav__sub-link {
  font-family: "Noto Serif JP", serif;
  color: #ffffff;
  letter-spacing: 0.03em;
  text-decoration: none;
  pointer-events: auto;
  opacity: 0.8;
  transition: opacity 0.3s ease;
}
@media screen and (min-width: 768px) {
  .global-nav__sub-link {
    font-size: 0.875em;
    line-height: 1.45;
  }
}
.global-nav__sub-link:hover {
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .global-nav__sub-link {
    font-size: 13px;
  }
}
.global-nav__sub-link[target=_blank] {
  display: inline-flex;
  align-items: center;
}
.global-nav__sub-link[target=_blank]::after {
  margin-left: 10px;
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  background-image: url("../images/common/icon_footer_link_external_01.svg");
  background-size: cover;
  background-repeat: no-repeat;
}
@media screen and (min-width: 768px) {
  .global-nav__sns {
    margin-top: 1.5em;
  }
}
.global-nav__sns-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border: 1px solid #ffffff;
  border-radius: 50%;
  color: #ffffff;
  text-decoration: none;
  transform-origin: center center;
  transition: all 0.3s ease;
  pointer-events: auto;
}
.global-nav__sns-link:hover {
  background-color: #ffffff;
  border: 1px solid #0d0d0d;
  color: #0d0d0d;
}
.global-nav__sns-icon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 18px;
}
.global-nav__romantic7 {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  .global-nav__romantic7 {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .global-nav__romantic7 {
    right: -100px;
  }
}
.global-nav__r7-circle {
  position: relative;
  width: 400px;
  height: 400px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 50%;
}
@media screen and (min-width: 768px) {
  .global-nav__r7-circle {
    width: 350px;
    height: 350px;
  }
}

.bottom-header {
  background-color: #0d0d0d;
  position: fixed;
  transition: transform 2s ease-in-out;
  z-index: 2001;
}
@media screen and (max-width: 767px) {
  .bottom-header {
    bottom: 0;
    width: 100%;
    border-radius: 1em 1em 0 0;
  }
}
@media screen and (min-width: 768px) {
  .bottom-header {
    bottom: 0;
    right: 0;
    border-radius: 30px 0 0 0;
  }
}
@media screen and (min-width: 768px) {
  .home .bottom-header {
    transform: translateY(100%);
  }
}
.bottom-header__container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px white solid;
  border-left: 1px white solid;
  border-right: 1px white solid;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .bottom-header__container {
    border-radius: 1em 1em 0 0;
  }
}
@media screen and (min-width: 768px) {
  .bottom-header__container {
    border-radius: 30px 0 0 0;
    border-right: 1px black solid;
  }
}
.bottom-header__romantic7 {
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: auto;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .bottom-header__romantic7 {
    padding: 0.5em 0.75em 0.5em 2.5em;
    gap: 1.25em;
    border-radius: 1em 0 0 0;
  }
}
@media screen and (min-width: 768px) {
  .bottom-header__romantic7 {
    padding: 1.5em 0 1.5em 2em;
  }
}
@media screen and (max-width: 767px) {
  .bottom-header__romantic7.is-open {
    background-color: #ffffff;
  }
}
@media screen and (min-width: 768px) {
  .bottom-header__romantic7.is-open {
    background-color: #0d0d0d;
  }
}
@media screen and (max-width: 767px) {
  .bottom-header__romantic7.is-open .bottom-header__r7-button-text {
    color: #0d0d0d;
  }
}
.bottom-header__r7-logo {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .bottom-header__r7-logo img {
    width: 80%;
    max-height: 60px;
  }
}
@media screen and (min-width: 768px) {
  .bottom-header__r7-logo img {
    width: 245px;
  }
}
.bottom-header__r7-button {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.3em;
  color: #ffffff;
  font-family: "Cormorant Infant", serif;
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .bottom-header__r7-button {
    font-size: 0.625em;
  }
}
@media screen and (min-width: 768px) {
  .bottom-header__r7-button {
    padding: 0 2em;
  }
}
.bottom-header__r7-button-icon {
  display: inline-flex;
  align-items: flex-end;
  justify-content: center;
  width: 2.2em;
  height: 2.2em;
}
@media screen and (max-width: 767px) {
  .bottom-header__r7-button-icon img {
    width: 1.6em;
  }
}
@media screen and (min-width: 768px) {
  .bottom-header__r7-button-icon img {
    width: 1em;
  }
}
.bottom-header__r7-button-text {
  width: 4.5em;
}
@media screen and (max-width: 767px) {
  .bottom-header__r7-button-text {
    display: block;
    margin-top: 0.05em;
    font-size: 1em;
  }
}
@media screen and (min-width: 768px) {
  .bottom-header__r7-button-text {
    display: inline-block;
    font-size: 0.875em;
  }
}
.bottom-header__menu-wrap {
  pointer-events: auto;
}
@media screen and (max-width: 767px) {
  .bottom-header__menu-wrap {
    display: block;
    min-width: 85px;
    padding: 0.5em 1.64em;
    border-left: 1px solid #ffffff;
    text-align: center;
    border-radius: 0 1em 0 0;
  }
}
@media screen and (min-width: 768px) {
  .bottom-header__menu-wrap {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .bottom-header__menu-wrap.is-open {
    background-color: #ffffff;
  }
}
@media screen and (max-width: 767px) {
  .bottom-header__menu-wrap.is-open .bottom-header__menu-text {
    color: #0d0d0d;
  }
}
.bottom-header__menu-icon {
  display: inline-block;
  width: 1.6em;
  height: 1.6em;
}
.bottom-header__menu-icon img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .bottom-header__menu-icon img[src*="icon_close.svg"] {
    width: 1.2em;
  }
}
.bottom-header__menu-text {
  display: block;
  color: #ffffff;
  font-family: "Cormorant Infant", serif;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .bottom-header__menu-text {
    margin-top: -0.2em;
    font-size: 0.625em;
  }
}

@media screen and (max-width: 767px) {
  .bottom-menu {
    display: flex;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    z-index: 999;
    background-color: #0d0d0d;
  }
}
@media screen and (min-width: 768px) {
  .bottom-menu {
    display: none;
  }
}

.bottom-menu__logo-wrapper {
  background: #0d0d0d;
  border-radius: 20px 0px 0px 0px;
  border-style: solid;
  border-color: #808080;
  border-width: 0.5px 0px 0px 0.5px;
  padding: 0px 0px 0px 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: center;
  justify-content: center;
  align-self: stretch;
  flex-shrink: 0;
  width: 64.2666666667%;
  position: relative;
}

.bottom-menu__logo {
  flex-shrink: 0;
  width: 61.7647058824%;
  position: relative;
  overflow: visible;
}

.bottom-menu__r7-link {
  background: #0d0d0d;
  display: flex;
  padding-top: 12px;
  padding-right: 16px;
  flex-direction: column;
  gap: 0px;
  align-items: center;
  justify-content: center;
  align-self: stretch;
  flex-shrink: 0;
  width: 50px;
  position: relative;
}

.r7-link__icon {
  display: flex;
  flex-direction: column;
  gap: 0px;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  position: relative;
}

.r7-link__icon-image {
  flex-shrink: 0;
  width: 16px;
  height: 15.67px;
  position: relative;
  overflow: visible;
}

.r7-link__text-wrapper {
  display: flex;
  flex-direction: column;
  gap: 0px;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  position: relative;
}

.r7-link__text {
  color: #ffffff;
  text-align: center;
  font-family: "Cormorant Infant", serif;
  font-size: 10px;
  letter-spacing: 0.05em;
  font-weight: 700;
  position: relative;
}

.bottom-menu__close-button {
  margin: 0 0 0 -0.5px;
  background: #ffffff;
  border-radius: 0px 20px 0px 0px;
  border-style: solid;
  border-color: #ffffff;
  border-width: 0.5px 0px 0px 0.5px;
  padding: 8px;
  display: flex;
  flex-direction: row;
  gap: 8px;
  align-items: center;
  justify-content: center;
  align-self: stretch;
  flex: 1;
  position: relative;
}

.component-312 {
  padding: 2px 0px 0px 0px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
  width: 30px;
  height: 41px;
  position: relative;
}

.group-2420 {
  flex-shrink: 0;
  width: 20.51px;
  height: 23.04px;
  position: relative;
  overflow: visible;
}

.group-2421 {
  flex-shrink: 0;
  width: 31px;
  height: 11.34px;
  position: static;
}

.close-button__text-wrapper {
  width: 31px;
  height: 11.34px;
  position: static;
}

.close-button__text {
  color: #000000;
  text-align: left;
  font-family: "Cormorant Infant", serif;
  font-size: 9px;
  font-weight: 700;
  position: absolute;
  right: -1.67%;
  left: -1.67%;
  width: 103.33%;
  bottom: 0%;
  top: 72.35%;
  height: 27.65%;
}

.header.is-white .header__menu-text {
  color: #ffffff !important;
}
.header.is-white .header__menu-icon img {
  filter: brightness(0) invert(1) !important;
}

@media screen and (min-width: 1000px) {
  .main {
    padding-top: 40px;
  }
}

/**
* Object
* ========================== */
/**
* Components
* ========================== */
.block01 {
  background: #ff008e;
  box-shadow: 8px 8px 0 #a6c6f1;
  padding: 45px;
}
.block01 *:first-child {
  margin: 0 !important;
}
@media screen and (max-width: 767px) {
  .block01 {
    padding: 30px 20px;
    margin: 0 15px;
  }
}
.block01 h6 {
  color: #ff008e;
  font-weight: bold;
  background-image: linear-gradient(to right, #ff008e, #ff008e 3px, transparent 3px, transparent 3px);
  background-size: 10px 3px;
  background-position: left bottom;
  background-repeat: repeat-x;
  padding-bottom: 15px;
}
@media screen and (max-width: 767px) {
  .block01 h6 {
    font-size: 1.6rem;
  }
}
@media screen and (min-width: 768px) {
  .block01 h6 {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 767px) {
  .block01 p,
  .block01 ul,
  .block01 ol {
    margin-top: 20px !important;
  }
}
@media screen and (min-width: 768px) {
  .block01 p,
  .block01 ul,
  .block01 ol {
    margin-top: 25px !important;
  }
}
.block01 p {
  color: #ff008e;
  font-size: 1.5rem;
  padding: 0 !important;
  letter-spacing: 0.25rem !important;
}
.block01 ul li:not(:first-child),
.block01 ol li:not(:first-child) {
  margin-top: 5px !important;
}
@media screen and (max-width: 767px) {
  .block01 ul {
    margin-left: 0 !important;
    padding-right: 0 !important;
  }
}
@media screen and (min-width: 768px) {
  .block01 ul {
    padding: 0 15px !important;
  }
}
.block01 ul li {
  position: relative;
  padding-left: 1rem;
  font-size: 1.4rem !important;
  font-weight: normal !important;
}
.block01 ul li:before {
  background: #ff008e;
  position: absolute;
  content: "";
  width: 6px !important;
  height: 6px !important;
  border-radius: 50%;
  top: 1rem;
  left: -1rem;
}
.block01 ol {
  counter-reset: item;
  list-style-type: none;
  margin-top: 25px !important;
  font-size: 1.4rem;
  font-weight: normal;
  padding: 0 !important;
}
.block01 ol li::before {
  font-size: 1.5rem !important;
}
.block01 ol li + li {
  margin-top: 15px;
}

.block02 {
  display: flex;
}
@media screen and (max-width: 767px) {
  .block02 {
    flex-direction: column-reverse;
    padding: 0 15px;
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .block02 {
    gap: 0 65px;
  }
}
@media screen and (max-width: 767px) {
  .block02__content, .block02__img {
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .block02__content, .block02__img {
    width: 460px;
  }
}
@media screen and (max-width: 767px) {
  .block02__ttl {
    margin-top: 27px !important;
    padding: 0 !important;
  }
}
@media screen and (max-width: 767px) {
  .block02__text, .block02__button {
    margin-top: 20px !important;
  }
}
@media screen and (min-width: 768px) {
  .block02__text, .block02__button {
    margin-top: 25px;
  }
}
@media screen and (max-width: 767px) {
  .block02__text {
    padding: 0 !important;
  }
}
.block02__button a {
  font-size: 1.6rem;
  font-weight: 500;
  color: #ff008e;
  text-decoration: none;
}
.block02__button a[target=_blank]::before {
  position: absolute;
  content: "\ea0b";
  font-size: 1.6rem;
  line-height: 1;
  color: #001b74;
  display: inline-block;
  font-family: icon;
  line-height: 1;
  bottom: 0;
  margin: auto;
  left: 28px;
  top: calc(50% - 7px);
}
@media screen and (max-width: 767px) {
  .block02__button {
    text-align: center;
  }
}

.block03 {
  position: relative;
  display: grid;
}
@media screen and (min-width: 768px) {
  .block03 {
    grid-template-columns: 51% 49%;
    max-height: 345px;
    height: 100%;
  }
}
.block03__img {
  z-index: 2;
  max-height: 345px;
  height: 100%;
}
@media screen and (max-width: 767px) {
  .block03__img {
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .block03__img img {
    object-fit: cover;
    height: 100%;
  }
}
.block03__content {
  z-index: 2;
  background: #ffffff;
}
@media screen and (max-width: 767px) {
  .block03__content {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 27px;
  }
}
@media screen and (min-width: 768px) {
  .block03__content {
    padding: 35px;
  }
}
.block03__ttl {
  padding: 0 !important;
  color: #ff008e;
  font-weight: 500;
  font-size: 2.2rem !important;
  background: none !important;
}
@media screen and (max-width: 767px) {
  .block03__ttl {
    text-align: center;
  }
}
.block03__line {
  position: relative;
}
.block03__line:before {
  content: "";
  position: absolute;
  width: 27px;
  height: 3px;
  background-color: #ff008e;
}
@media screen and (max-width: 767px) {
  .block03__line:before {
    left: 50%;
    transform: translateX(-50%);
    margin-top: 21px;
  }
}
@media screen and (min-width: 768px) {
  .block03__line:before {
    margin-top: 27px;
  }
}
.block03__txt {
  padding: 0 !important;
}
@media screen and (max-width: 767px) {
  .block03__txt {
    margin-top: 40px !important;
  }
}
@media screen and (min-width: 768px) {
  .block03__txt {
    margin-top: 67.5px;
  }
}
.block03__button {
  padding: 0 !important;
}
@media screen and (max-width: 767px) {
  .block03__button {
    margin-top: 18px;
  }
}
@media screen and (min-width: 768px) {
  .block03__button {
    margin-top: 25px;
    text-align: right;
  }
}
@media screen and (max-width: 767px) {
  .block03__button a {
    padding: 12px 43px;
  }
}
.block03:after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background: linear-gradient(to bottom right, #ff008e);
}
@media screen and (max-width: 767px) {
  .block03:after {
    top: 13px;
    right: -13px;
  }
}
@media screen and (min-width: 768px) {
  .block03:after {
    top: 36px;
    right: -36px;
  }
}

.btn-double-border__link {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  column-gap: 16px;
  max-width: 279px;
  width: 100%;
  padding: 14px 24px;
  margin-top: 42px;
  margin-inline: auto;
  position: relative;
  border: 1px solid #ffffff;
}
@media screen and (max-width: 767px) {
  .btn-double-border__link {
    display: flex;
    justify-content: center;
    column-gap: 10px;
    max-width: 230px;
    margin-top: 30px;
  }
}
.btn-double-border__link-text {
  display: block;
  font-size: 1.6rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  line-height: 1.44;
  letter-spacing: 0.05rem;
  color: #ffffff;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .btn-double-border__link-text {
    font-size: 1.4rem;
    line-height: 1.43;
  }
}
.btn-double-border__link::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  border: 1px solid #ffffff;
  background: transparent;
  pointer-events: none;
  transform: translateX(5px) translateY(5px);
  position: absolute;
  top: 0;
  left: 0;
  transition: all 0.3s ease-in-out;
}
@media screen and (max-width: 767px) {
  .btn-double-border__link::before {
    transform: translateX(3px) translateY(3px);
  }
}
.btn-double-border__link::after {
  content: "";
  display: block;
  width: 15px;
  height: 10px;
  background-image: url("../../assets/images/common/icon_arrow_next.svg");
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .btn-double-border__link::after {
    width: 13px;
    height: 9px;
  }
}
.btn-double-border__link:hover::before {
  opacity: 0;
  transform: translateX(0) translateY(0);
}

.card01 {
  width: 320px;
  transition: all 0.3s ease-in-out;
}
.card01 a {
  text-decoration: none;
}
.card01__img img {
  width: 320px;
  height: 200px;
  object-fit: cover;
}
.card01__ttl {
  text-align: center;
  color: #ff008e;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  .card01__ttl {
    margin-top: 14px !important;
    font-size: 1.9rem;
  }
}
@media screen and (min-width: 768px) {
  .card01__ttl {
    margin-top: 24px;
    font-size: 2rem;
  }
}
.card01:hover {
  opacity: 0.8;
}

.card02 {
  width: 100%;
  max-width: 300px;
  height: auto;
}
.card02__wrapper {
  display: grid;
}
@media screen and (max-width: 767px) {
  .card02__wrapper {
    flex-direction: column;
    justify-content: center;
    gap: 60px;
  }
}
@media screen and (min-width: 768px) {
  .card02__wrapper {
    grid-template-columns: repeat(3, 1fr);
    gap: 50px;
  }
}
.card02__post {
  text-decoration: none;
  transition: all 0.3s ease-in-out;
}
.card02__post:hover {
  opacity: 0.8;
}
.card02__thumb {
  position: relative;
  width: 100%;
  max-width: 300px;
  height: 190px;
}
.card02__news {
  position: absolute;
  z-index: 1;
  top: -30px;
  left: -15px;
  width: 50px;
  height: 50px;
}
.card02__image {
  position: relative;
}
.card02__image img {
  width: 300px;
  height: 190px;
  object-fit: cover;
}
.card02__desc {
  display: flex;
  justify-content: flex-end;
}
.card02__desc--wrapper {
  margin-top: 16px;
}
.card02__cat {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 !important;
  padding: 6px 18.5px;
  border-radius: 14px;
  background: linear-gradient(to right, #ff008e);
  color: #ffffff;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  font-size: 1.1rem;
}
.card02__date {
  margin: 0 !important;
  padding: 0 !important;
  color: #a7b4be;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  font-size: 1.2rem;
}
.card02__ttl {
  margin-top: 15px !important;
  padding: 0 !important;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  font-size: 1.4rem;
  color: #ff008e;
}

.card03 {
  padding: 20px 0;
  border-top: 1px solid #ff008e;
}
.card03__post {
  text-decoration: none;
  transition: all 0.3s ease-in-out;
}
.card03__post:hover {
  opacity: 0.8;
}
.card03__thumb {
  position: relative;
  width: 100%;
  max-width: 300px;
  height: 190px;
}
.card03__news {
  position: absolute;
  z-index: 1;
  top: -30px;
  left: -15px;
  width: 50px;
  height: 50px;
}
.card03__desc {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .card03__desc {
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .card03__desc {
    width: 180px;
  }
}
.card03__cat {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 !important;
  padding: 6px 18.5px;
  border-radius: 14px;
  background: linear-gradient(to right, #ff008e);
  color: #ffffff;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  font-size: 1.1rem;
}
.card03__date {
  margin: 0 !important;
  padding: 0 !important;
  color: #a7b4be;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  font-size: 1.2rem;
  vertical-align: middle;
}
.card03__ttl {
  margin-top: 15px !important;
  padding: 0 !important;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  font-size: 1.4rem;
  color: #ff008e;
}

.heading01 {
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #ff008e;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .heading01 {
    margin: 0 24px;
    padding: 42px 15px;
    font-size: 2.2rem;
  }
}
@media screen and (min-width: 768px) {
  .heading01 {
    margin: 0 288px;
    padding: 65px 92px;
    font-size: 3rem;
  }
}
.heading01 .ja {
  color: #ff008e;
}
.heading01 .en {
  color: #ff008e;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .heading01 .en {
    margin-top: 7px;
    font-size: 1.2rem;
  }
}
@media screen and (min-width: 768px) {
  .heading01 .en {
    margin-top: 5px;
    font-size: 1.5rem;
  }
}

.heading02 {
  background-image: linear-gradient(to right, #ff008e, #ff008e 3px, transparent 3px, transparent 3px);
  background-size: 8px 3px;
  background-position: left bottom;
  background-repeat: repeat-x;
  padding: 16px 20px;
}
@media screen and (max-width: 767px) {
  .heading02 {
    font-size: 2rem;
  }
}
@media screen and (min-width: 768px) {
  .heading02 {
    font-size: 2.5rem;
  }
}

.heading03 {
  background: linear-gradient(to bottom right, #ff008e);
  color: #ff008e;
  font-weight: bold;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  .heading03 {
    font-size: 1.9rem;
    padding: 16px;
  }
}
@media screen and (min-width: 768px) {
  .heading03 {
    font-size: 2.2rem;
    padding: 20px;
  }
}
.heading03::after {
  position: absolute;
  content: "";
  width: 125px;
  height: 100%;
  top: 0;
  z-index: -1;
  background: url("../images/common/img_heading03.svg") no-repeat top left/contain;
}
@media screen and (max-width: 767px) {
  .heading03::after {
    background: url("../images/common/img_heading03_sp.svg") no-repeat top left/contain;
  }
}
.heading03::after {
  right: 0;
}

.heading04 {
  position: relative;
}
@media screen and (max-width: 767px) {
  .heading04 {
    font-weight: 500;
    font-size: 1.8rem;
    padding-left: 25px;
    padding-right: 15px;
  }
}
@media screen and (min-width: 768px) {
  .heading04 {
    font-weight: 600;
    font-size: 2.1rem;
    padding-left: 20px;
  }
}
.heading04::before, .heading04::after {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto 0;
  content: "";
  display: inline-block;
  width: 13px;
  height: 13px;
  border-radius: 50%;
}
.heading04::before {
  background: linear-gradient(180deg, #ff008e);
  opacity: 0.54;
  transform: translate(3px, 3px);
}
.heading04::after {
  border: solid 1px #ff008e;
}

@media screen and (max-width: 767px) {
  .heading05 {
    font-weight: 500;
    font-size: 1.7rem;
  }
}
@media screen and (min-width: 768px) {
  .heading05 {
    font-weight: 600;
    font-size: 2rem;
  }
}

.heading06 {
  color: #ff008e;
  font-weight: bold;
  background-image: linear-gradient(to right, #ff008e, #ff008e 3px, transparent 3px, transparent 3px);
  background-size: 10px 3px;
  background-position: left bottom;
  background-repeat: repeat-x;
  padding-bottom: 15px;
}
@media screen and (max-width: 767px) {
  .heading06 {
    font-size: 1.6rem;
  }
}
@media screen and (min-width: 768px) {
  .heading06 {
    font-size: 1.8rem;
  }
}

.heading07 {
  color: #ff008e;
  font-weight: bold;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .heading07 {
    font-size: 2rem;
  }
}
@media screen and (min-width: 768px) {
  .heading07 {
    font-size: 2.5rem;
  }
}
.heading07 span {
  color: #ff008e;
}

.list01 {
  margin-left: 1rem;
}
.list01 li {
  position: relative;
  padding-left: 1rem;
}
@media screen and (max-width: 767px) {
  .list01 li {
    margin-bottom: 10px;
  }
}
@media screen and (min-width: 768px) {
  .list01 li {
    margin-bottom: 12px;
  }
}
.list01 li:before {
  background: #ff008e;
  position: absolute;
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  top: 1rem;
  left: -1rem;
}

.list02 {
  counter-reset: number 0;
  padding-left: 1rem;
}
.list02 li {
  list-style: none;
  position: relative;
  padding-left: 1.1rem;
}
@media screen and (max-width: 767px) {
  .list02 li {
    margin-bottom: 10px;
  }
}
@media screen and (min-width: 768px) {
  .list02 li {
    margin-bottom: 12px;
  }
}
.list02 li:before {
  position: absolute;
  left: -1rem;
  counter-increment: number 1;
  content: counter(number) ".";
  font-weight: bold;
  color: #ff008e;
}

.list03 {
  margin-left: 1rem;
}
.list03 li {
  position: relative;
  padding-left: 1.5rem;
}
@media screen and (max-width: 767px) {
  .list03 li {
    margin-bottom: 10px;
  }
}
@media screen and (min-width: 768px) {
  .list03 li {
    margin-bottom: 12px;
  }
}
.list03 li:before {
  content: "";
  display: inline-block;
  left: 3px;
  width: 6px;
  height: 6px;
  border-top: 2px solid #ff7857;
  border-right: 2px solid #ff7857;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  position: absolute;
}
@media screen and (max-width: 767px) {
  .list03 li:before {
    top: 11px;
  }
}
@media screen and (min-width: 768px) {
  .list03 li:before {
    top: 13px;
  }
}

.tag01 {
  text-decoration: none;
  color: #ff008e;
  height: 35px;
  border-radius: 20px;
  display: inline-flex;
  align-items: center;
  padding: 0 20px;
  font-weight: bold;
  font-size: 1.4rem;
  background: #ffffff;
  border: 2px solid #ff008e;
}
.tag01.is-front {
  background: #ffffff;
}
@media screen and (min-width: 768px) {
  .tag01:hover {
    background: #ff008e;
    color: #ffffff;
  }
}

@keyframes pageTitleRotation {
  0% {
    transform: rotate(0);
  }
  100% {
    transform: rotate(360deg);
  }
}
.page-title {
  display: flex;
  align-items: flex-end;
  width: 100%;
  height: 376px;
  padding-inline: 10px;
  padding-bottom: 45px;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .page-title {
    justify-content: center;
    align-items: center;
    height: auto;
    margin-top: 110px;
    padding: 30px 20px;
    background-color: #0d0d0d;
  }
}
.page-title::after {
  content: "";
  display: block;
  width: 786px;
  height: 786px;
  aspect-ratio: 1/1;
  background-image: url("../images/common/page-title-bg-01.svg");
  background-size: cover;
  position: absolute;
  bottom: 0;
  right: -393px;
  z-index: -1;
  animation: 90s linear infinite pageTitleRotation;
}
@media screen and (max-width: 767px) {
  .page-title::after {
    display: none;
  }
}
.page-title__group {
  width: 100%;
  max-width: 1239px;
  margin-inline: auto;
}
.page-title__main {
  display: inline-block;
  padding: 6px 20px 6px 10px;
  background-color: #0d0d0d;
  font-size: 8rem;
  font-family: "Cormorant Infant", serif;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.1rem;
  color: #ffffff;
}
@media screen and (max-width: 767px) {
  .page-title__main {
    display: block;
    font-size: 3.5rem;
    text-align: center;
    padding: 0;
  }
}
.page-title__sub {
  display: flex;
  align-items: flex-end;
  column-gap: 9px;
  margin-top: 5px;
}
@media screen and (max-width: 767px) {
  .page-title__sub {
    flex-direction: column;
    align-items: center;
    row-gap: 5px;
  }
}
.page-title__sub-text {
  font-size: 3.2rem;
  font-weight: 500;
  line-height: 1.18;
  letter-spacing: 0.1rem;
  font-family: "Noto Serif JP", serif;
  color: #ffffff;
}
@media screen and (max-width: 767px) {
  .page-title__sub-text {
    font-size: 1.6rem;
    text-align: center;
  }
}
.page-title__sub::before {
  content: "";
  display: block;
  width: 26px;
  height: auto;
  aspect-ratio: 1/1;
  background-image: url("../images/common/page-title-subtitle-01.svg");
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .page-title__sub::before {
    width: 15px;
  }
}

.breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  column-gap: 16px;
  row-gap: 7px;
}
@media screen and (max-width: 767px) {
  .breadcrumb {
    column-gap: 5px;
  }
}
.breadcrumb__item {
  font-size: 1.4rem;
  line-height: 1.4;
  letter-spacing: 0.1rem;
  font-weight: 500;
  font-family: "Zen Kaku Gothic New", sans-serif;
}
@media screen and (max-width: 767px) {
  .breadcrumb__item {
    font-size: 1.2rem;
  }
}
.breadcrumb__item:not(:last-of-type) {
  display: flex;
  align-items: center;
  column-gap: 16px;
}
@media screen and (max-width: 767px) {
  .breadcrumb__item:not(:last-of-type) {
    column-gap: 5px;
  }
}
.breadcrumb__item:not(:last-of-type)::after {
  content: "";
  display: block;
  width: 10px;
  height: auto;
  aspect-ratio: 1/1;
  background-image: url("../images/common/breadcrumb-icon-pc-01.svg");
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .breadcrumb__item:not(:last-of-type)::after {
    width: 11px;
    background-image: url("../images/common/breadcrumb-icon-sp-01.svg");
  }
}
.breadcrumb__link {
  text-decoration: underline;
  color: #0d0d0d;
}
.breadcrumb__link:hover {
  text-decoration: none;
}
.breadcrumb__name {
  font-size: 1.4rem;
  line-height: 1.4;
  letter-spacing: 0.1rem;
  font-weight: 500;
  font-family: "Zen Kaku Gothic New", sans-serif;
}
@media screen and (max-width: 767px) {
  .breadcrumb__name {
    font-size: 1.2rem;
  }
}
.breadcrumb__name.is_active {
  max-width: 100%;
  color: #ffffff;
}
.breadcrumb__item__name.is_active {
  color: #ffffff;
}

.category-list {
  max-width: 100%;
  height: auto;
  margin-inline: auto;
}
.category-list__items-wrapper {
  display: block;
  position: relative;
  width: fit-content;
  max-width: 100%;
  height: auto;
  padding-bottom: 5px;
  overflow-x: auto;
  margin-top: 20px;
  margin-inline: auto;
  padding-inline: 10px;
  z-index: 99;
  transition: z-index 0s ease;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
@media screen and (max-width: 767px) {
  .category-list__items-wrapper {
    padding-inline: 0;
  }
}
.category-list__items-wrapper::-webkit-scrollbar {
  display: none;
}
.category-list__title {
  font-size: 3.5rem;
  font-family: "Cormorant Infant", serif;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.1rem;
  color: #ffffff;
  text-align: center;
}
.category-list__items-content {
  width: 100%;
  max-width: 841px;
  background-color: #ffffff;
  border-radius: 100px;
  box-shadow: 3px 3px 0 0 #000;
  padding-top: 10px;
  padding-bottom: 10px;
  padding-inline: 50px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .category-list__items-content {
    width: 100%;
    min-width: fit-content;
    padding-inline: 15px;
    border-radius: 0;
  }
}
.category-list__items {
  display: flex;
  width: fit-content;
  max-width: 100%;
  justify-content: space-between;
  align-items: center;
  column-gap: 20px;
}
@media (max-width: 849px) {
  .category-list__items {
    column-gap: 0px;
  }
}
.category-list__link {
  font-size: 2rem;
  font-family: "Cormorant Infant", serif;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.1rem;
  color: #000;
  transition: all 0.3s ease-in-out;
}
.category-list__link.is-active {
  color: #ff008e;
}
.category-list__link:hover {
  color: #ff008e;
}
.category-list__link--icon {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 76px;
}
@media screen and (min-width: 768px) {
  .category-list__link--icon {
    width: 80px;
  }
}
.category-list__link--icon:hover .category-list__icon svg path {
  fill: #ff008e;
}
.category-list__link--icon:hover .category-list__name {
  color: #ff008e;
}
.category-list__link--icon.is-active .category-list__icon svg path {
  fill: #ff008e;
}
.category-list__link--icon.is-active .category-list__name {
  color: #ff008e;
}
.category-list__icon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: auto;
  height: 42px;
}
.category-list__icon svg path {
  transition: all 0.3s ease-in-out;
}
.category-list__name {
  font-size: 1.2rem;
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
  line-height: 1;
  letter-spacing: -0.1rem;
  color: #000;
  transition: all 0.3s ease-in-out;
}

.pagination {
  display: grid;
  width: 100%;
  max-width: 328px;
  grid-template-columns: auto 1fr auto;
  column-gap: 9px;
  border: 2px solid #0d0d0d;
  background-color: #ffffff;
  border-radius: 100px;
  padding: 7px 9px;
  box-shadow: 3px 3px 0 0 #000;
}
@media screen and (max-width: 767px) {
  .pagination {
    padding: 5px 9px;
  }
}
.pagination__link {
  display: flex;
  justify-content: center;
  align-items: center;
  column-gap: 8px;
  padding: 17px 8px;
}
.pagination__link.is-noActive .pagination__link-text {
  color: #9B9B9B;
}
@media screen and (max-width: 767px) {
  .pagination__link {
    padding: 12px 8px;
  }
}
.pagination__link--prev {
  border-right: 1px solid #000;
  border-radius: 100px 0 0 100px;
}
.pagination__link--next {
  border-left: 1px solid #000;
  border-radius: 0 100px 100px 0;
}
.pagination__link-text {
  font-size: 1.5rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  line-height: 1;
  letter-spacing: 0;
  color: #000;
}
.pagination__link-icon {
  display: flex;
  justify-content: center;
  align-items: center;
}
.pagination__select {
  width: 100%;
  height: 100%;
  text-align: center;
  font-size: 1.9rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  color: #0d0d0d;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0;
  padding-inline: 20px;
}
.pagination__select.is-noActive {
  color: #9B9B9B;
}
.pagination__select-wrapper {
  position: relative;
}
.pagination__select-icon {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 50%;
  right: 5px;
  transform: translateY(-50%);
  pointer-events: none;
}

.copy {
  display: none;
  writing-mode: vertical-rl;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.1rem;
  font-family: "Noto Serif", serif;
  font-weight: 500;
  line-height: 1.36;
  letter-spacing: 0;
  color: #0d0d0d;
  transition: color 0.3s ease;
}
@media screen and (min-width: 768px) {
  .copy {
    display: block;
    position: fixed;
    left: 2%;
    z-index: 99;
  }
}
@media screen and (min-width: 768px) and (max-height: 660px) {
  .copy {
    /* 高さ660px以下の場合の非表示 */
    display: none;
  }
}

.custom-notes {
  padding-inline: 20px;
  font-size: 1.3rem;
  font-family: "Noto Serif JP", serif;
  line-height: 1.5;
  letter-spacing: 0.05rem;
  color: #ff008e;
}
@media screen and (max-width: 767px) {
  .custom-notes {
    padding-inline: 15px;
    font-size: 1.2rem;
  }
}
.custom-notes::before {
  content: "※";
  display: inline-block;
  margin-right: 6px;
  font-size: 1.4rem;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.57;
  letter-spacing: 0;
}

.custom-lead {
  margin-top: 40px;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  padding: 30px 70px 30px 84px;
}
@media screen and (max-width: 767px) {
  .custom-lead {
    margin-top: 30px;
    padding: 20px 40px;
  }
}
.custom-lead > p {
  font-size: 2.2rem;
  font-weight: bold;
  font-family: "Noto Serif JP", serif;
  line-height: 2;
  letter-spacing: 0.15rem;
  color: #0d0d0d;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .custom-lead > p {
    font-size: 1.8rem;
    line-height: 1.8;
  }
}
.custom-lead::before {
  content: "";
  display: block;
  width: 56px;
  height: auto;
  aspect-ratio: 1/1;
  background-image: url("../images/common/block-lead-icon-left-01.svg");
  background-size: cover;
  position: absolute;
  top: 0;
  left: 0;
}
@media screen and (max-width: 767px) {
  .custom-lead::before {
    width: 40px;
  }
}
.custom-lead::after {
  content: "";
  display: block;
  width: 56px;
  height: auto;
  aspect-ratio: 1/1;
  background-image: url("../images/common/block-lead-icon-right-01.svg");
  background-size: cover;
  position: absolute;
  bottom: 0;
  right: 0;
}
@media screen and (max-width: 767px) {
  .custom-lead::after {
    width: 40px;
  }
}

.custom-remarks-section {
  display: block;
  width: 100%;
  margin-top: 40px;
  padding: 20px;
  background-color: #ff008e;
  border: 1px solid #0d0d0d;
  box-shadow: 5px 5px 0 0 #0d0d0d;
}
@media screen and (max-width: 767px) {
  .custom-remarks-section {
    width: calc(100% - 20px);
    margin-top: 30px;
    margin-inline: auto;
  }
}
.custom-remarks-section__title {
  font-size: 2rem;
  font-family: "Noto Serif JP", serif;
  line-height: 1.2;
  letter-spacing: 0;
  color: #ffffff;
}
.custom-remarks-section__text {
  font-size: 1.6rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  line-height: 2.1;
  letter-spacing: 0;
  color: #ffffff;
  margin-top: 10px;
}

.custom-profile-card {
  margin-top: 40px;
  padding: 31px 41px;
  border: 1px solid #000;
  outline: 1px solid #000;
  outline-offset: -7px;
}
@media screen and (max-width: 767px) {
  .custom-profile-card {
    margin-top: 30px;
    margin-inline: 10px;
    padding: 35px 28px;
  }
}
.custom-profile-card__title {
  display: flex;
  justify-content: center;
  align-items: center;
  column-gap: 20px;
  font-size: 5rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.1rem;
  font-family: "Cormorant Infant", serif;
  color: #000;
}
@media screen and (max-width: 767px) {
  .custom-profile-card__title {
    font-size: 3.5rem;
    column-gap: 10px;
  }
}
.custom-profile-card__title::before {
  content: "";
  display: block;
  width: 40px;
  height: 1px;
  background-color: #000;
}
.custom-profile-card__title::after {
  content: "";
  display: block;
  width: 40px;
  height: 1px;
  background-color: #000;
}
.custom-profile-card__content {
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 20px;
  margin-top: 36px;
}
@media screen and (max-width: 767px) {
  .custom-profile-card__content {
    grid-template-columns: 1fr;
    row-gap: 20px;
    margin-top: 20px;
  }
}
.custom-profile-card__figure {
  display: block;
  max-width: 264px;
  width: 100%;
  height: auto;
}
@media screen and (max-width: 767px) {
  .custom-profile-card__figure {
    max-width: 100%;
  }
}
.custom-profile-card__image {
  display: block;
  width: 100%;
  object-fit: cover;
}
.custom-profile-card__detail {
  display: flex;
  flex-direction: column;
  row-gap: 19px;
}
.custom-profile-card__name {
  display: block;
  border-bottom: 1px solid #000;
  font-size: 2.3rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  line-height: 1.435;
  letter-spacing: 0.05rem;
  color: #000;
}
.custom-profile-card__list {
  display: flex;
  flex-direction: column;
  row-gap: 4px;
}
@media screen and (max-width: 767px) {
  .custom-profile-card__list {
    row-gap: 8px;
  }
}
.custom-profile-card__list-text {
  position: relative;
  padding-left: 21px;
  font-size: 1.6rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  line-height: 1.44;
  letter-spacing: 0.05rem;
  color: #000;
}
.custom-profile-card__list-text::before {
  content: "";
  display: block;
  width: 18px;
  height: auto;
  aspect-ratio: 1/1;
  background-image: url("../images/common/block-profile-card-list-icon-01.svg");
  background-size: cover;
  position: absolute;
  top: 5px;
  left: 0;
}
.custom-profile-card__link-list {
  display: flex;
  flex-direction: column;
  row-gap: 10px;
}
@media screen and (max-width: 767px) {
  .custom-profile-card__link-list {
    display: grid;
    grid-template-columns: 1fr;
    justify-content: center;
    max-width: 100%;
    margin-inline: auto;
  }
}
.custom-profile-card__link {
  display: flex;
  align-items: center;
  max-width: 100%;
  width: fit-content;
  column-gap: 10px;
  font-size: 1.6rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  line-height: 1.44;
  letter-spacing: 0.05rem;
  color: #0d0d0d;
  text-decoration: none;
}
@media screen and (max-width: 767px) {
  .custom-profile-card__link {
    width: 100%;
    justify-content: space-between;
  }
}
.custom-profile-card__link-icon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 27px;
  height: 27px;
  aspect-ratio: 1/1;
  background-color: #0d0d0d;
  border-radius: 100px;
  border: 1px solid #0d0d0d;
  transition: all 0.3s ease-in-out;
}
.custom-profile-card__link-icon svg path {
  transition: all 0.3s ease-in-out;
}
.custom-profile-card__link:not([target=_blank]):hover .custom-profile-card__link-icon {
  transform: translateX(8px);
}
.custom-profile-card__link[target=_blank]:hover .custom-profile-card__link-icon {
  background-color: #ffffff;
}
.custom-profile-card__link[target=_blank]:hover .custom-profile-card__link-icon svg path {
  fill: #0d0d0d;
}
.custom-profile-card__link[target=_blank]:hover .custom-profile-card__link-icon svg .custom-profile-card__link-icon-path--black {
  fill: #ffffff;
}
.custom-profile-card__text {
  display: block;
  margin-top: 23px;
  padding: 25px 30px;
  background-color: #0d0d0d;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.44;
  letter-spacing: 0.05rem;
  color: #ffffff;
}
@media screen and (max-width: 767px) {
  .custom-profile-card__text {
    padding: 15px;
  }
}

.custom-fixed-button {
  margin-top: 40px;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  column-gap: 16px;
  max-width: 279px;
  width: 100%;
  padding: 14px 22px 14px 24px;
  background-color: #0d0d0d;
  border: 1px solid #0d0d0d;
  border-radius: 40px;
  transition: all 0.3s ease-in-out;
}
@media screen and (max-width: 767px) {
  .custom-fixed-button {
    margin-top: 30px;
    margin-inline: 10px;
  }
}
.custom-fixed-button__text {
  display: block;
  text-align: center;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.05rem;
  color: #ffffff;
  transition: all 0.3s ease-in-out;
}
@media screen and (max-width: 767px) {
  .custom-fixed-button__text {
    font-size: 1.6rem;
  }
}
.custom-fixed-button__icon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 15px;
}
.custom-fixed-button__icon path {
  transition: all 0.3s ease-in-out;
}
.custom-fixed-button__icon.is-external {
  width: 19px;
}
.custom-fixed-button:hover {
  background-color: #ffffff;
}
.custom-fixed-button:hover .custom-fixed-button__text {
  color: #0d0d0d;
}
.custom-fixed-button:hover .custom-fixed-button__icon.is-internal path {
  stroke: #0d0d0d;
}
.custom-fixed-button:hover .custom-fixed-button__icon.is-external path {
  fill: #0d0d0d;
}
.custom-fixed-button:hover .custom-fixed-button__icon.is-external path.custom-fixed-button__icon-path--black {
  fill: #ffffff;
}

.custom-flexible-button {
  margin-top: 40px;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  column-gap: 16px;
  max-width: 100%;
  width: fit-content;
  padding: 14px 24px;
  background-color: #0d0d0d;
  border: 1px solid #0d0d0d;
  border-radius: 40px;
  transition: all 0.3s ease-in-out;
}
@media screen and (max-width: 767px) {
  .custom-flexible-button {
    margin-top: 30px;
    margin-inline: 10px;
  }
}
.custom-flexible-button__text {
  display: block;
  text-align: center;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.05rem;
  color: #ffffff;
  transition: all 0.3s ease-in-out;
}
@media screen and (max-width: 767px) {
  .custom-flexible-button__text {
    font-size: 1.5rem;
  }
}
.custom-flexible-button__icon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 15px;
}
.custom-flexible-button__icon path {
  transition: all 0.3s ease-in-out;
}
.custom-flexible-button__icon.is-external {
  width: 19px;
}
.custom-flexible-button:hover {
  background-color: #ffffff;
}
.custom-flexible-button:hover .custom-flexible-button__text {
  color: #0d0d0d;
}
.custom-flexible-button:hover .custom-flexible-button__icon.is-internal path {
  stroke: #0d0d0d;
}
.custom-flexible-button:hover .custom-flexible-button__icon.is-external path {
  fill: #0d0d0d;
}
.custom-flexible-button:hover .custom-flexible-button__icon.is-external path.custom-flexible-button__icon-path--black {
  fill: #ffffff;
}

.custom-card__unite--1col {
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .custom-card__unite--1col {
    margin-top: 30px;
    margin-inline: 10px;
  }
}
.custom-card__unite--1col > div {
  display: grid;
  grid-template-columns: 1fr;
  gap: 15px;
}
.custom-card__unite--2col {
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .custom-card__unite--2col {
    margin-top: 30px;
    margin-inline: 10px;
  }
}
.custom-card__unite--2col > div {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 15px 30px;
}
@media screen and (max-width: 767px) {
  .custom-card__unite--2col > div {
    display: grid;
    grid-template-columns: 1fr;
    gap: 15px;
  }
}
.custom-card__unite--3col {
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .custom-card__unite--3col {
    margin-top: 30px;
    margin-inline: 10px;
  }
}
.custom-card__unite--3col > div {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 15px;
}
@media screen and (max-width: 767px) {
  .custom-card__unite--3col > div {
    display: grid;
    grid-template-columns: 1fr;
    gap: 15px;
  }
}

.custom-card {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: subgrid;
  grid-row: span 2;
  height: 100%;
  max-width: 100%;
  row-gap: 11px;
}
.custom-card__figure {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
}
.custom-card__image {
  display: block;
  max-width: 100%;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.custom-card__inner {
  padding-inline: 15px;
}
.custom-card__title {
  font-size: 1.8rem;
  font-family: "Noto Serif JP", serif;
  font-weight: bold;
  line-height: 1.8;
  letter-spacing: 0.03rem;
  text-align: center;
  color: #ff008e;
}
.custom-card__text {
  margin-top: 15px;
  font-size: 1.6rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  line-height: 1.8;
  letter-spacing: 0;
  color: #0d0d0d;
}
.custom-card__link {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  column-gap: 10px;
  font-size: 1.6rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.05rem;
  color: #0d0d0d;
  transition: all 0.3s ease-in-out;
  margin-top: 15px;
}
.custom-card__link-icon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 27px;
  height: 27px;
  aspect-ratio: 1/1;
  border-radius: 100px;
  background-color: #0d0d0d;
  transition: all 0.3s ease-in-out;
  border: 1px solid #0d0d0d;
}
.custom-card__link-icon svg path {
  transition: all 0.3s ease-in-out;
}
.custom-card__link:not([target=_blank]):hover .custom-card__link-icon {
  transform: translateX(8px);
}
.custom-card__link[target=_blank]:hover .custom-card__link-icon {
  background-color: #ffffff;
}
.custom-card__link[target=_blank]:hover .custom-card__link-icon path {
  fill: #0d0d0d;
}
.custom-card__link[target=_blank]:hover .custom-card__link-icon path.custom-card__link-path--black {
  fill: #ffffff !important;
}

.custom-corner {
  margin-top: 40px;
  display: block;
  padding: 30px 40px;
  background-color: #0d0d0d;
  border: 1px solid #ffffff;
  outline: 1px solid #ffffff;
  outline-offset: -5px;
}
@media screen and (max-width: 767px) {
  .custom-corner {
    margin-top: 30px;
    margin-inline: 10px;
    padding: 35px 20px;
  }
}
.custom-corner__heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: 15px;
}
.custom-corner__heading::after {
  content: "";
  display: block;
  width: 86px;
  height: 13px;
  background-image: url("../images/common/block-corner-title-01.svg");
  background-size: cover;
}
.custom-corner__title {
  font-size: 2rem;
  font-family: "Noto Serif JP", serif;
  font-weight: bold;
  line-height: 1.2;
  letter-spacing: 0;
  color: #ffffff;
  text-align: center;
}
.custom-corner__inner {
  margin-top: 24px;
  display: grid;
  grid-template-columns: 1fr auto;
  column-gap: 20px;
}
@media screen and (max-width: 767px) {
  .custom-corner__inner {
    display: flex;
    flex-direction: column-reverse;
    row-gap: 20px;
  }
}
.custom-corner__inner.is-noImage {
  display: block;
}
.custom-corner__inner.is-noImage .custom-corner__content {
  padding-top: 0;
}
.custom-corner__content {
  padding-top: 20px;
}
@media screen and (max-width: 767px) {
  .custom-corner__content {
    padding-top: 0;
  }
}
.custom-corner__text {
  display: block;
  font-size: 1.6rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.1rem;
  color: #ffffff;
}
@media screen and (max-width: 767px) {
  .custom-corner__text {
    padding-inline: 10px;
  }
}
.custom-corner__button {
  margin-top: 24px;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  column-gap: 16px;
  max-width: 279px;
  width: 100%;
  padding: 14px 22px 14px 24px;
  background-color: #0d0d0d;
  border: 1px solid #ffffff;
  border-radius: 40px;
  transition: all 0.3s ease-in-out;
}
@media screen and (max-width: 767px) {
  .custom-corner__button {
    max-width: 100%;
  }
}
.custom-corner__button-text {
  display: block;
  text-align: center;
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.05rem;
  color: #ffffff;
  transition: all 0.3s ease-in-out;
}
.custom-corner__button-icon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 15px;
}
.custom-corner__button-icon path {
  transition: all 0.3s ease-in-out;
}
.custom-corner__button-icon.is-external {
  width: 19px;
}
.custom-corner__button:hover {
  background-color: #ffffff;
}
.custom-corner__button:hover .custom-corner__button-text {
  color: #0d0d0d;
}
.custom-corner__button:hover .custom-corner__button-icon.is-internal path {
  stroke: #0d0d0d;
}
.custom-corner__button:hover .custom-corner__button-icon.is-external path {
  fill: #0d0d0d;
}
.custom-corner__button:hover .custom-corner__button-icon.is-external path.custom-corner__button-icon-path--black {
  fill: #ffffff;
}
.custom-corner__figure {
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: 6px;
  max-width: 270px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .custom-corner__figure {
    max-width: 100%;
  }
}
.custom-corner__image {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
}
.custom-corner__figcaption {
  display: block;
  text-align: center;
  font-size: 1.3rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  line-height: 1.46;
  letter-spacing: 0;
  color: #FFDFC4;
  padding-inline: 4px;
}

.custom-more-link {
  margin-top: 40px;
  display: flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  column-gap: 10px;
}
@media screen and (max-width: 767px) {
  .custom-more-link {
    margin-top: 30px;
    margin-inline: 10px;
  }
}
.custom-more-link__text {
  font-size: 2rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  line-height: 1.45;
  letter-spacing: 0.05%;
  color: #0d0d0d;
}
@media screen and (max-width: 767px) {
  .custom-more-link__text {
    font-size: 1.6rem;
  }
}
.custom-more-link__icon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 50px;
  height: 50px;
  aspect-ratio: 1/1;
  border-radius: 100px;
  background-color: #0d0d0d;
  border: 1px solid #0d0d0d;
  transition: all 0.3s ease-in-out;
}
@media screen and (max-width: 767px) {
  .custom-more-link__icon {
    width: 27px;
    height: 27px;
  }
}
@media screen and (max-width: 767px) {
  .custom-more-link__icon svg {
    width: 10px;
  }
}
.custom-more-link__icon svg path {
  transition: all 0.3s ease-in-out;
}
.custom-more-link:hover .custom-more-link__icon {
  transform: translateX(8px);
}

.custom-download-button {
  margin-top: 40px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  column-gap: 10px;
  width: fit-content;
  max-width: 100%;
  padding: 16px 25px;
  border: 1px solid #0d0d0d;
  transition: all 0.3s ease-in-out;
}
@media screen and (max-width: 767px) {
  .custom-download-button {
    max-width: calc(100% - 20px);
    margin-top: 30px;
    margin-inline: auto;
  }
}
.custom-download-button__icon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 30px;
  height: 30px;
  aspect-ratio: 1/1;
}
.custom-download-button__icon svg path {
  transition: all 0.3s ease-in-out;
}
.custom-download-button__icon svg rect {
  transition: all 0.3s ease-in-out;
}
.custom-download-button__text {
  font-size: 1.6rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  line-height: 1.44;
  letter-spacing: 0.1rem;
  color: #0d0d0d;
  transition: all 0.3s ease-in-out;
}
.custom-download-button__size {
  font-size: 1.3rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  line-height: 1.46;
  letter-spacing: 0;
  color: #0d0d0d;
  transition: all 0.3s ease-in-out;
}
.custom-download-button__arrow {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 8px;
  height: auto;
}
.custom-download-button__arrow svg path {
  transition: all 0.3s ease-in-out;
}
.custom-download-button:hover {
  background-color: #0d0d0d;
}
.custom-download-button:hover .custom-download-button__icon.is-word svg path {
  fill: #ffffff;
}
.custom-download-button:hover .custom-download-button__icon.is-word svg rect {
  fill: #0d0d0d;
}
.custom-download-button:hover .custom-download-button__icon.is-excel svg path {
  fill: #ffffff;
}
.custom-download-button:hover .custom-download-button__icon.is-excel svg rect {
  fill: #0d0d0d;
}
.custom-download-button:hover .custom-download-button__icon.is-pdf svg path.is-path01 {
  stroke: #ffffff;
}
.custom-download-button:hover .custom-download-button__icon.is-pdf svg path.is-path02 {
  stroke: #ffffff;
  fill: #ffffff;
}
.custom-download-button:hover .custom-download-button__icon.is-pdf svg path.is-path03 {
  fill: #ffffff;
}
.custom-download-button:hover .custom-download-button__icon.is-pdf svg path.is-path04 {
  fill: #ffffff;
}
.custom-download-button:hover .custom-download-button__text {
  color: #ffffff;
}
.custom-download-button:hover .custom-download-button__size {
  color: #ffffff;
}
.custom-download-button:hover .custom-download-button__arrow svg path {
  fill: #ffffff;
}

/**
* Project
* ========================== */
/*----------------------------
固定ページはマージンを削除
----------------------------*/
/*----------------------------
投稿ページ
----------------------------*/
.editor > *:first-child {
  margin-top: 0;
}
.editor > p {
  margin-top: 40px;
}
.editor > p:not([class]) {
  display: block;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: 0;
  color: #0d0d0d;
  padding-inline: 20px;
}
@media screen and (max-width: 767px) {
  .editor > p:not([class]) {
    margin-top: 30px;
    line-height: 1.7;
    padding-inline: 15px;
  }
}
.editor > p:not([class]) > a {
  display: inline;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 2.1;
  letter-spacing: 0.05rem;
  color: #ff008e;
  text-decoration: underline;
  word-break: break-all;
  word-wrap: break-word;
}
.editor > p:not([class]) > a:hover {
  text-decoration: none;
}
.editor > p:not([class]) > a[target=_blank]::after {
  content: "";
  display: inline-block;
  width: 16px;
  height: auto;
  aspect-ratio: 1/1;
  background-image: url("../images/news/icon-link-external-01.svg");
  background-size: cover;
  margin-inline: 10px;
}
.editor > .wp-block-heading {
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .editor > .wp-block-heading {
    margin: 30px 15px 0 15px;
  }
}
.editor h2.wp-block-heading {
  display: block;
  padding: 10px 20px;
  font-size: 2.7rem;
  font-family: "Noto Serif JP", serif;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.05rem;
  color: #ffffff;
  background-color: #0d0d0d;
}
@media screen and (max-width: 767px) {
  .editor h2.wp-block-heading {
    padding: 10px 15px;
    font-size: 2.3rem;
  }
}
.editor h3.wp-block-heading {
  display: block;
  padding: 4px 20px;
  font-size: 2.5rem;
  font-family: "Noto Serif JP", serif;
  font-weight: bold;
  line-height: 1.8;
  letter-spacing: 0.05rem;
  color: #0d0d0d;
  border: 1px solid #0d0d0d;
  outline: 1px solid #0d0d0d;
  outline-offset: -4px;
  background-color: #ffffff;
  box-shadow: 3px 3px 0 0 #0d0d0d;
}
@media screen and (max-width: 767px) {
  .editor h3.wp-block-heading {
    padding: 4px 15px;
    font-size: 2.2rem;
  }
}
.editor h4.wp-block-heading {
  display: block;
  padding: 10px 0 10px 20px;
  font-size: 2.3rem;
  font-family: "Noto Serif JP", serif;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.05rem;
  color: #0d0d0d;
  position: relative;
}
@media screen and (max-width: 767px) {
  .editor h4.wp-block-heading {
    padding: 5px 0 5px 15px;
    font-size: 2rem;
  }
}
.editor h4.wp-block-heading::before {
  content: "";
  display: block;
  width: 16px;
  height: auto;
  aspect-ratio: 1/1;
  background-image: url("../images/news/icon-heading04-01.svg");
  background-size: cover;
  position: absolute;
  top: 20.5px;
  left: 3px;
}
@media screen and (max-width: 767px) {
  .editor h4.wp-block-heading::before {
    width: 11px;
    top: 15px;
    left: 1px;
  }
}
.editor h5.wp-block-heading {
  display: block;
  padding: 10px 20px;
  font-size: 2.2rem;
  font-family: "Noto Serif JP", serif;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.05rem;
  border-bottom: 1px solid #0d0d0d;
}
@media screen and (max-width: 767px) {
  .editor h5.wp-block-heading {
    padding: 13px 15px;
    font-size: 1.8rem;
  }
}
.editor h6.wp-block-heading {
  display: block;
  padding: 10px 20px;
  font-size: 2rem;
  font-family: "Noto Serif JP", serif;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.05rem;
}
@media screen and (max-width: 767px) {
  .editor h6.wp-block-heading {
    padding: 12px 15px;
    font-size: 1.7rem;
  }
}
.editor > .wp-block-list {
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .editor > .wp-block-list {
    margin-top: 30px;
  }
}
.editor ul.wp-block-list {
  padding-inline: 16px;
}
.editor ul.wp-block-list li {
  display: block;
  padding-left: 24px;
  position: relative;
  font-size: 16px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0;
  color: #0d0d0d;
}
.editor ul.wp-block-list li::before {
  content: "・";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}
.editor ul.wp-block-list li + li {
  margin-top: 10px;
}
.editor ul.wp-block-list li > a {
  display: inline;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0;
  color: #ff008e;
  text-decoration: underline;
  word-break: break-all;
  word-wrap: break-word;
}
.editor ul.wp-block-list li > a:hover {
  text-decoration: none;
}
.editor ul.wp-block-list li > a[target=_blank]::after {
  content: "";
  display: inline-block;
  width: 16px;
  height: auto;
  aspect-ratio: 1/1;
  background-image: url("../images/news/icon-link-external-01.svg");
  background-size: cover;
  margin-inline: 10px;
}
.editor ol.wp-block-list {
  padding-left: 40px;
  padding-right: 16px;
}
.editor ol.wp-block-list li {
  display: block;
  font-size: 16px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0;
  color: #0d0d0d;
}
.editor ol.wp-block-list li + li {
  margin-top: 10px;
}
.editor ol.wp-block-list li > a {
  display: inline;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0;
  color: #ff008e;
  text-decoration: underline;
  word-break: break-all;
  word-wrap: break-word;
}
.editor ol.wp-block-list li > a:hover {
  text-decoration: none;
}
.editor ol.wp-block-list li > a[target=_blank]::after {
  content: "";
  display: inline-block;
  width: 16px;
  height: auto;
  aspect-ratio: 1/1;
  background-image: url("../images/news/icon-link-external-01.svg");
  background-size: cover;
  margin-inline: 10px;
}
.editor > figure.wp-block-image {
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .editor > figure.wp-block-image {
    margin-top: 30px;
  }
}
.editor figure.wp-block-image {
  max-width: 100%;
}
.editor figure.wp-block-image img {
  aspect-ratio: auto !important;
}
.editor figure.wp-block-image figcaption.wp-element-caption {
  font-size: 1.4rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  line-height: 1.7;
  letter-spacing: 0.03rem;
  color: #333;
  text-align: center;
  margin: 5px 0 0;
  text-shadow: none;
}
.editor > figure.wp-block-gallery {
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .editor > figure.wp-block-gallery {
    margin-top: 30px;
  }
}
.editor figure.wp-block-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, 256px);
  gap: 15px;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .editor figure.wp-block-gallery {
    grid-template-columns: 1fr;
  }
}
.editor figure.wp-block-gallery figure.wp-block-image {
  display: grid;
  width: 100% !important;
  max-width: 100%;
  grid-template-rows: subgrid;
  grid-row: span 2;
  row-gap: 5px;
}
.editor figure.wp-block-gallery figure.wp-block-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.editor figure.wp-block-gallery figure.wp-block-image figcaption.wp-element-caption {
  height: auto;
  font-size: 1.4rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  line-height: 1.7;
  letter-spacing: 0.03rem;
  color: #333;
  text-align: center;
  position: static;
  background: none;
  max-height: none;
  overflow: visible;
  margin: 0;
}
.editor figure.wp-block-flexible-table-block-table {
  margin-top: 40px;
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
}
@media screen and (max-width: 767px) {
  .editor figure.wp-block-flexible-table-block-table {
    max-width: calc(100% - 20px);
    margin-top: 30px;
    margin-inline: auto;
  }
}
.editor figure.wp-block-flexible-table-block-table th,
.editor figure.wp-block-flexible-table-block-table td {
  border: 1.14px solid #0d0d0d !important;
}
.editor figure.wp-block-flexible-table-block-table th {
  background-color: #ff008e !important;
  font-size: 1.6rem;
  font-family: "Noto Serif JP", serif;
  line-height: 1.18;
  letter-spacing: 0.05rem;
  color: #ffffff;
  padding: 11px 23px !important;
}
.editor figure.wp-block-flexible-table-block-table td {
  padding: 12px 23px !important;
  font-size: 1.5rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  line-height: 1.47;
  letter-spacing: 0;
  color: #0d0d0d;
}
.editor figure.wp-block-flexible-table-block-table td > a {
  display: inline;
  font-weight: 400;
  color: #ff008e;
  text-decoration: underline;
  word-break: break-all;
  word-wrap: break-word;
}
.editor figure.wp-block-flexible-table-block-table td > a:hover {
  text-decoration: none;
}
.editor figure.wp-block-flexible-table-block-table td > a[target=_blank]::after {
  content: "";
  display: inline-block;
  width: 16px;
  height: auto;
  aspect-ratio: 1/1;
  background-image: url("../images/news/icon-link-external-01.svg");
  background-size: cover;
  margin-inline: 10px;
}
.editor .has-fixed-layout.is-stacked-on-mobile th {
  margin: -1px 0 !important;
}
.editor .has-fixed-layout.is-stacked-on-mobile table {
  border-top: 1px solid #0d0d0d;
}

.paging01 {
  display: block;
  text-align: center;
  line-height: 10rem;
}
.paging01 .prev {
  color: #ffffff;
  background-color: #ff008e;
  font-size: 1.6rem;
  padding: 15px 24px;
  border-radius: 3px;
  margin-right: 16px;
}
.paging01 .prev:hover {
  background-color: #ff008e;
  text-decoration: none;
}
@media screen and (max-width: 767px) {
  .paging01 .prev {
    font-size: 1.2rem;
    padding: 8px 15px;
    margin-right: 11px;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
}

.next {
  color: #ffffff;
  background-color: #ff008e;
  font-size: 1.6rem;
  padding: 15px 24px;
  border-radius: 3px;
  margin-left: 16px;
}
.next:hover {
  background-color: #ff008e;
  text-decoration: none;
}
@media screen and (max-width: 767px) {
  .next {
    font-size: 1.2rem;
    padding: 8px 15px;
    margin-left: 11px;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
}

.num {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2.3rem;
  margin-right: 6px;
  margin-left: 8px;
  border: 1px solid #ff008e;
  border-radius: 3px;
  padding: 13px 24px;
}
.num:hover {
  border-bottom: initial;
  background-color: #F7F4EC;
  border: 1px solid #F7F4EC;
  text-decoration: none;
}
@media screen and (max-width: 767px) {
  .num {
    font-size: 1.6rem;
    padding: 6px 12px;
    margin-left: 6px;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
}

.selected {
  color: #ffffff;
  background-color: #ff008e;
  border: 1px solid #ff008e;
}
.selected:hover {
  border-bottom: initial;
  background-color: #ff008e;
  border: 1px solid #ff008e;
  text-decoration: none;
}

.paging02 {
  background-color: #ff008e;
  width: 100vw;
  margin: 0 calc(50% - 50vw);
  margin-top: 100px;
}
.paging02__inner {
  display: flex;
  justify-content: center;
  align-items: center;
  padding-top: 55px;
  padding-bottom: 55px;
}
@media screen and (max-width: 767px) {
  .paging02__inner {
    display: block;
    padding-bottom: 70px;
  }
}
.paging02__detail {
  width: 164px;
}
.paging02__item {
  background-color: #ffffff;
  display: flex;
  padding: 12px 16px;
  height: 140px;
  width: 390px;
}
.paging02__item:hover {
  text-decoration: none;
}
@media screen and (max-width: 767px) {
  .paging02__item {
    height: 117px;
    width: 90vw;
    margin: 0 auto;
    padding: 10px 15px 10px 10px;
  }
}
@media screen and (max-width: 767px) {
  .paging02 .is-next {
    position: relative;
    bottom: 50px;
  }
}
.paging02__thumb {
  width: 164px;
  height: auto;
  margin-right: 20px;
}
@media screen and (max-width: 767px) {
  .paging02__thumb {
    max-width: 138px;
  }
}
.paging02__thumb img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}
.paging02__ttl {
  font-size: 1.5rem;
  margin-bottom: 9px;
  line-height: 2.4rem;
}
@media screen and (max-width: 767px) {
  .paging02__ttl {
    font-size: 1.3rem;
    margin-bottom: 0;
  }
}
.paging02__date {
  color: #8D8D8D;
  font-size: 1.4rem;
  position: relative;
  bottom: 0px;
  text-align: right;
}
@media screen and (max-width: 767px) {
  .paging02__date {
    font-size: 1.1rem;
    position: static;
  }
}
.paging02__cat {
  display: inline-block;
  margin-bottom: 8px;
  font-size: 1.3rem;
}
@media screen and (max-width: 767px) {
  .paging02__cat {
    font-size: 1rem;
    margin-bottom: 6px;
  }
}
.paging02__return {
  text-align: center;
  margin-right: 33px;
  margin-left: 33px;
}
@media screen and (max-width: 767px) {
  .paging02__return {
    position: relative;
    bottom: -166px;
  }
}
.paging02__return__icn {
  display: block;
}
.paging02__return__link {
  color: #ffffff;
}
.paging02__return__link:hover {
  text-decoration: none;
  opacity: 0.5;
}

.single {
  width: 100%;
}
.single__breadcrumb {
  width: 100%;
  max-width: 1258px;
  margin: 18px auto 21px;
  padding-inline: 15px;
}
.single__inner {
  width: 100%;
  padding-left: 20px;
  padding-right: 20px;
}
@media screen and (max-width: 767px) {
  .single__inner {
    padding-inline: 10px;
  }
}
.single__content {
  width: 100%;
  max-width: 1000px;
  margin: 59px auto 0;
  background-color: #ffffff;
  padding: 78px 20px 59px;
  border: 1px solid #0d0d0d;
  outline: 1px solid #0d0d0d;
  outline-offset: -10px;
}
@media screen and (max-width: 767px) {
  .single__content {
    padding: 42px 9px 51px;
  }
}
.single__content--thumbnail .single__editor {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  row-gap: 75px;
  margin-top: 41px;
}
@media screen and (max-width: 767px) {
  .single__content--thumbnail .single__editor {
    margin-top: 24px;
    row-gap: 39px;
  }
}
.single__content--thumbnail .single__footer {
  margin-top: 80px;
}
.single__header {
  width: 100%;
  max-width: 900px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .single__header {
    padding-inline: 15px;
  }
}
.single__label {
  display: block;
  padding: 3px 20px;
  width: fit-content;
  font-size: 16px;
  font-weight: bold;
  font-family: "Noto Serif JP", serif;
  line-height: 1.5;
  letter-spacing: 0.08rem;
  color: #ffffff;
  background-color: #0d0d0d;
}
@media screen and (max-width: 767px) {
  .single__label {
    margin-bottom: 10px;
  }
}
.single__title {
  font-size: 2.8rem;
  font-weight: bold;
  font-family: "Noto Serif JP", serif;
  line-height: 1.8;
  letter-spacing: 0.05rem;
  color: #0d0d0d;
}
@media screen and (max-width: 767px) {
  .single__title {
    font-size: 2.4rem;
    line-height: 1.6;
  }
}
.single__meta {
  display: flex;
  justify-content: flex-end;
  text-align: center;
  column-gap: 10px;
}
@media screen and (max-width: 767px) {
  .single__meta {
    margin-top: 15px;
  }
}
.single__date-time {
  font-size: 16px;
  font-weight: bold;
  font-family: "Cormorant Infant", serif;
  line-height: 1.5;
  letter-spacing: 0.08rem;
  color: #0d0d0d;
}
.single__category-list {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  column-gap: 10px;
}
.single__category {
  display: flex;
  justify-content: center;
  align-items: center;
  column-gap: 5px;
  width: 145px;
  padding: 8px 18px;
  border-radius: 100px;
  border: 1px solid #0d0d0d;
  background-color: #ffffff;
  text-decoration: none;
}
.single__category-image {
  width: auto;
  height: 12px;
}
.single__category-text {
  font-size: 1.4rem;
  font-weight: 400;
  font-family: "Noto Serif JP", serif;
  line-height: 1;
  letter-spacing: -0.1rem;
  color: #0d0d0d;
}
.single__thumbnail {
  display: block;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .single__thumbnail {
    padding-inline: 10px;
  }
}
.single__thumbnail-image {
  display: block;
  width: 100%;
  height: auto;
  box-shadow: 5px 5px 0 0 #000;
}
@media screen and (max-width: 767px) {
  .single__thumbnail-image {
    box-shadow: 3px 3px 0 0 #000;
  }
}
.single__editor {
  width: 100%;
  max-width: 800px;
  margin-top: 39px;
  margin-inline: auto;
}
.single__footer {
  display: block;
  width: 100%;
  max-width: 900px;
  margin-top: 106px;
  margin-inline: auto;
  padding-top: 20px;
  border-top: 1px solid #0d0d0d;
}
@media screen and (max-width: 767px) {
  .single__footer {
    width: calc(100% - 20px);
  }
}
.single__tags {
  display: block;
  width: 100%;
  padding-inline: 20px;
  margin-bottom: 20px;
}
.single__tags-list {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
  gap: 9px;
}
.single__tag {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 10px 20px;
  border-radius: 100px;
  border: 1px solid #0d0d0d;
  background-color: #ffffff;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.05rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  color: #0d0d0d;
}
@media screen and (max-width: 767px) {
  .single__tag {
    font-size: 1.2rem;
    padding-inline: 15px;
  }
}
.single__share {
  display: flex;
  justify-content: center;
  align-items: center;
  column-gap: 20px;
}
.single__share-title {
  font-size: 16px;
  font-family: "Cormorant Infant", serif;
  font-weight: bold;
  line-height: 1.75;
  letter-spacing: 0;
  color: #0d0d0d;
}
.single__share-links {
  display: flex;
  justify-content: center;
  align-items: center;
  column-gap: 20px;
}
@media screen and (max-width: 767px) {
  .single__share-links {
    column-gap: 10px;
  }
}
.single__share-link {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 40px;
  height: auto;
  aspect-ratio: 1/1;
  border-radius: 100%;
  border: 1px solid #0d0d0d;
  background-color: #0d0d0d;
  text-decoration: none;
  transition: all 0.3s ease-in-out;
}
.single__share-link:hover {
  background-color: #ffffff;
}
.single__share-link:hover .single__share-image path {
  fill: #0d0d0d;
}
.single__share-image {
  display: flex;
  width: 100%;
  height: auto;
  justify-content: center;
  align-items: center;
}
.single__share-image path {
  transition: all 0.3s ease-in-out;
}
.single__share-image--x {
  max-width: 14px;
}
.single__share-image--facebook {
  max-width: 8px;
}
.single__share-image--line {
  max-width: 19px;
}
.single__pager {
  width: 100%;
  max-width: 1000px;
  margin-inline: auto;
  margin-top: 64px;
}
@media screen and (max-width: 767px) {
  .single__pager {
    margin-top: 110px;
  }
}
.single__pager--thumbnail {
  margin-top: 53px;
}
@media screen and (max-width: 767px) {
  .single__pager--thumbnail {
    margin-top: 110px;
  }
}
.single__pager--thumbnail .single__pager-archive-link {
  margin-top: 53px;
}
.single__pager-links {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  column-gap: 10px;
}
@media screen and (max-width: 767px) {
  .single__pager-links {
    width: 100%;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    row-gap: 20px;
    padding-inline: 5px;
  }
}
.single__pager-links--first {
  justify-content: flex-end;
}
@media screen and (max-width: 767px) {
  .single__pager-links--first {
    justify-content: center;
  }
}
.single__pager-link {
  display: block;
  width: 100%;
  max-width: 469px;
  min-height: 100%;
}
.single__pager-link--prev {
  padding-left: 18px;
}
@media screen and (max-width: 767px) {
  .single__pager-link--prev {
    padding-right: 20px;
  }
}
.single__pager-link--prev .single__pager-link-inner {
  padding-left: 40px;
}
@media screen and (max-width: 767px) {
  .single__pager-link--prev .single__pager-link-inner {
    padding-left: 25px;
    padding-right: 30px;
  }
}
.single__pager-link--prev .single__pager-link-inner::before {
  content: "";
  display: block;
  width: 40px;
  height: auto;
  aspect-ratio: 1/1;
  background-image: url("../images/news/icon-news-pager-link-left-01.svg");
  background-size: cover;
  position: absolute;
  top: 50%;
  left: -18px;
  transform: translateY(-50%);
  transition: all 0.3s ease-in-out;
}
.single__pager-link--prev:hover .single__pager-link-inner::before {
  transform: translateX(-5px) translateY(-50%);
}
.single__pager-link--next {
  padding-right: 18px;
  transition: all 0.3s ease-in-out;
}
@media screen and (max-width: 767px) {
  .single__pager-link--next {
    padding-left: 20px;
  }
}
.single__pager-link--next .single__pager-link-inner {
  padding-right: 40px;
}
@media screen and (max-width: 767px) {
  .single__pager-link--next .single__pager-link-inner {
    padding-right: 30px;
  }
}
.single__pager-link--next .single__pager-link-inner::after {
  content: "";
  display: block;
  width: 40px;
  height: auto;
  aspect-ratio: 1/1;
  background-image: url("../images/news/icon-news-pager-link-left-01.svg");
  background-size: cover;
  position: absolute;
  top: 50%;
  right: -18px;
  transform: translateY(-50%) rotate(180deg);
  transition: all 0.3s ease-in-out;
}
.single__pager-link--next:hover .single__pager-link-inner::after {
  transform: translateX(5px) translateY(-50%) rotate(180deg);
}
@media screen and (max-width: 767px) {
  .single__pager-link--image.single__pager-link--prev .single__pager-link-inner {
    padding-left: 20px;
    padding-right: 30px;
  }
}
.single__pager-link--image .single__pager-link-inner {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: stretch;
  column-gap: 20px;
}
@media screen and (max-width: 767px) {
  .single__pager-link--image .single__pager-link-inner {
    column-gap: 10px;
  }
}
.single__pager-link--image .single__pager-link-text {
  justify-content: space-between;
}
.single__pager-link--image .single__pager-title {
  -webkit-line-clamp: 3;
}
.single__pager-link:hover .single__pager-link-inner {
  box-shadow: 5px 5px 0 0 #0d0d0d;
}
.single__pager-link:hover .single__pager-title {
  text-decoration: none;
}
.single__pager-link-inner {
  display: block;
  padding: 25px 30px;
  background-color: #ffffff;
  border: 1px solid #0d0d0d;
  outline: 1px solid #0d0d0d;
  outline-offset: -8px;
  transition: all 0.3s ease-in-out;
  position: relative;
}
@media screen and (max-width: 767px) {
  .single__pager-link-inner {
    padding: 15px 20px;
  }
}
.single__pager-link-text {
  display: flex;
  flex-direction: column;
  align-items: end;
  row-gap: 10px;
}
.single__pager-title {
  width: 100%;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 2;
  font-size: 1.5rem;
  font-weight: 600;
  font-family: "Noto Serif JP", serif;
  color: #0d0d0d;
  line-height: 1.8;
  letter-spacing: 0.05rem;
  text-decoration: underline;
}
@media screen and (max-width: 767px) {
  .single__pager-title {
    font-size: 1.4rem;
    line-height: 1.5;
  }
}
.single__pager-figure {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 150px;
  height: auto;
  aspect-ratio: 150/115;
}
@media screen and (max-width: 767px) {
  .single__pager-figure {
    max-width: 106px;
    aspect-ratio: 106/91;
  }
}
.single__pager-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.single__pager-time {
  font-size: 1.3rem;
  font-family: "Cormorant Infant", serif;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0;
  color: #0d0d0d;
}
.single__pager-archive-link {
  display: flex;
  width: 100%;
  max-width: 279px;
  justify-content: center;
  align-items: center;
  padding: 14px 55px 14px 24px;
  border: 1px solid #ffffff;
  background-color: #0d0d0d;
  border-radius: 100px;
  position: relative;
  text-decoration: none;
  transition: all 0.3s ease-in-out;
  margin-top: 48px;
  margin-inline: auto;
}
.single__pager-archive-link:hover {
  background-color: #ffffff;
}
.single__pager-archive-link:hover .single__pager-archive-link-text {
  color: #0d0d0d;
}
.single__pager-archive-link:hover .single__pager-archive-link-icon path {
  stroke: #0d0d0d;
}
.single__pager-archive-link-text {
  font-size: 1.8rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.05rem;
  text-align: center;
  color: #ffffff;
  transition: all 0.3s ease-in-out;
}
.single__pager-archive-link-icon {
  position: absolute;
  top: 50%;
  right: 24px;
  transform: translateY(-50%);
}
.single__pager-archive-link-icon path {
  transition: all 0.3s ease-in-out;
}

/**
* utility
* ========================== */
.u-bg-01 {
  background: #ff008e;
}

.u-bg-02 {
  background: #ff008e;
}

@media screen and (max-width: 767px) {
  .u-grad-01 {
    background: #ff008e;
  }
}
@media screen and (min-width: 768px) {
  .u-grad-01 {
    background: #ff008e;
  }
}

@media screen and (max-width: 767px) {
  .u-grad-02 {
    background: #ff008e;
  }
}
@media screen and (min-width: 768px) {
  .u-grad-02 {
    background: #ff008e;
  }
}

.u-border-radius-5 {
  border-radius: 5px;
}

.u-border-radius-10 {
  border-radius: 10px;
}

.u-border-radius-15 {
  border-radius: 15px;
}

@media screen and (min-width: 768px) {
  .u-pc-hide {
    display: none !important;
  }
}

@media screen and (max-width: 767px) {
  .u-sp-hide {
    display: none !important;
  }
}

.u-sr-only {
  position: absolute;
  display: block;
  padding: 0;
  width: 1px;
  height: 1px;
  white-space: nowrap;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  border: 0;
  background: transparent;
  overflow: hidden;
}

.u-m0 {
  margin: 0px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m0 {
    margin: 0px !important;
  }
}

.u-m1 {
  margin: 5px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m1 {
    margin: 5px !important;
  }
}

.u-m2 {
  margin: 10px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m2 {
    margin: 10px !important;
  }
}

.u-m3 {
  margin: 15px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m3 {
    margin: 15px !important;
  }
}

.u-m4 {
  margin: 20px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m4 {
    margin: 20px !important;
  }
}

.u-m5 {
  margin: 25px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m5 {
    margin: 25px !important;
  }
}

.u-m6 {
  margin: 30px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m6 {
    margin: 30px !important;
  }
}

.u-m7 {
  margin: 35px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m7 {
    margin: 35px !important;
  }
}

.u-m8 {
  margin: 40px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m8 {
    margin: 40px !important;
  }
}

.u-m9 {
  margin: 45px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m9 {
    margin: 45px !important;
  }
}

.u-m10 {
  margin: 50px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m10 {
    margin: 50px !important;
  }
}

.u-m11 {
  margin: 55px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m11 {
    margin: 55px !important;
  }
}

.u-m12 {
  margin: 60px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m12 {
    margin: 60px !important;
  }
}

.u-m13 {
  margin: 65px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m13 {
    margin: 65px !important;
  }
}

.u-m14 {
  margin: 70px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m14 {
    margin: 70px !important;
  }
}

.u-m15 {
  margin: 75px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m15 {
    margin: 75px !important;
  }
}

.u-m16 {
  margin: 80px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m16 {
    margin: 80px !important;
  }
}

.u-m17 {
  margin: 85px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m17 {
    margin: 85px !important;
  }
}

.u-m18 {
  margin: 90px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m18 {
    margin: 90px !important;
  }
}

.u-m19 {
  margin: 95px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m19 {
    margin: 95px !important;
  }
}

.u-m20 {
  margin: 100px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m20 {
    margin: 100px !important;
  }
}

.u-m21 {
  margin: 105px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m21 {
    margin: 105px !important;
  }
}

.u-m22 {
  margin: 110px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m22 {
    margin: 110px !important;
  }
}

.u-m23 {
  margin: 115px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m23 {
    margin: 115px !important;
  }
}

.u-m24 {
  margin: 120px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m24 {
    margin: 120px !important;
  }
}

.u-m25 {
  margin: 125px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m25 {
    margin: 125px !important;
  }
}

.u-m26 {
  margin: 130px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m26 {
    margin: 130px !important;
  }
}

.u-m27 {
  margin: 135px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m27 {
    margin: 135px !important;
  }
}

.u-m28 {
  margin: 140px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m28 {
    margin: 140px !important;
  }
}

.u-m29 {
  margin: 145px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m29 {
    margin: 145px !important;
  }
}

.u-m30 {
  margin: 150px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m30 {
    margin: 150px !important;
  }
}

.u-m31 {
  margin: 155px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m31 {
    margin: 155px !important;
  }
}

.u-m32 {
  margin: 160px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m32 {
    margin: 160px !important;
  }
}

.u-m33 {
  margin: 165px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m33 {
    margin: 165px !important;
  }
}

.u-m34 {
  margin: 170px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m34 {
    margin: 170px !important;
  }
}

.u-m35 {
  margin: 175px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m35 {
    margin: 175px !important;
  }
}

.u-m36 {
  margin: 180px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m36 {
    margin: 180px !important;
  }
}

.u-m37 {
  margin: 185px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m37 {
    margin: 185px !important;
  }
}

.u-m38 {
  margin: 190px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m38 {
    margin: 190px !important;
  }
}

.u-m39 {
  margin: 195px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m39 {
    margin: 195px !important;
  }
}

.u-m40 {
  margin: 200px !important;
}

@media screen and (max-width: 767px) {
  body .u-sp-m40 {
    margin: 200px !important;
  }
}

/* margin - utility
--------------------------------------------------------- */
/* auto margin */
.u-m-c {
  margin-right: auto !important;
  margin-left: auto !important;
}

/* Top margin */
.u-mt-0px {
  margin-top: 0pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-0px {
    margin-top: 0pxpx !important;
  }
}

.u-mt-10px {
  margin-top: 10pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-10px {
    margin-top: 5pxpx !important;
  }
}

.u-mt-20px {
  margin-top: 20pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-20px {
    margin-top: 10pxpx !important;
  }
}

.u-mt-30px {
  margin-top: 30pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-30px {
    margin-top: 15pxpx !important;
  }
}

.u-mt-40px {
  margin-top: 40pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-40px {
    margin-top: 20pxpx !important;
  }
}

.u-mt-50px {
  margin-top: 50pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-50px {
    margin-top: 25pxpx !important;
  }
}

.u-mt-60px {
  margin-top: 60pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-60px {
    margin-top: 30pxpx !important;
  }
}

.u-mt-70px {
  margin-top: 70pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-70px {
    margin-top: 35pxpx !important;
  }
}

.u-mt-80px {
  margin-top: 80pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-80px {
    margin-top: 40pxpx !important;
  }
}

.u-mt-90px {
  margin-top: 90pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-90px {
    margin-top: 45pxpx !important;
  }
}

.u-mt-100px {
  margin-top: 100pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-100px {
    margin-top: 50pxpx !important;
  }
}

.u-mt-110px {
  margin-top: 110pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-110px {
    margin-top: 55pxpx !important;
  }
}

.u-mt-120px {
  margin-top: 120pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-120px {
    margin-top: 60pxpx !important;
  }
}

.u-mt-130px {
  margin-top: 130pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-130px {
    margin-top: 65pxpx !important;
  }
}

.u-mt-140px {
  margin-top: 140pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-140px {
    margin-top: 70pxpx !important;
  }
}

.u-mt-150px {
  margin-top: 150pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-150px {
    margin-top: 75pxpx !important;
  }
}

.u-mt-160px {
  margin-top: 160pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-160px {
    margin-top: 80pxpx !important;
  }
}

.u-mt-170px {
  margin-top: 170pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-170px {
    margin-top: 85pxpx !important;
  }
}

.u-mt-180px {
  margin-top: 180pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-180px {
    margin-top: 90pxpx !important;
  }
}

.u-mt-190px {
  margin-top: 190pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-190px {
    margin-top: 95pxpx !important;
  }
}

.u-mt-200px {
  margin-top: 200pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-200px {
    margin-top: 100pxpx !important;
  }
}

.u-mt-210px {
  margin-top: 210pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-210px {
    margin-top: 105pxpx !important;
  }
}

.u-mt-220px {
  margin-top: 220pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-220px {
    margin-top: 110pxpx !important;
  }
}

.u-mt-230px {
  margin-top: 230pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-230px {
    margin-top: 115pxpx !important;
  }
}

.u-mt-240px {
  margin-top: 240pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mt-240px {
    margin-top: 120pxpx !important;
  }
}

/* Right margin */
.u-mr-0px {
  margin-right: 0pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-0px {
    margin-right: 0pxpx !important;
  }
}

.u-mr-10px {
  margin-right: 10pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-10px {
    margin-right: 5pxpx !important;
  }
}

.u-mr-20px {
  margin-right: 20pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-20px {
    margin-right: 10pxpx !important;
  }
}

.u-mr-30px {
  margin-right: 30pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-30px {
    margin-right: 15pxpx !important;
  }
}

.u-mr-40px {
  margin-right: 40pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-40px {
    margin-right: 20pxpx !important;
  }
}

.u-mr-50px {
  margin-right: 50pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-50px {
    margin-right: 25pxpx !important;
  }
}

.u-mr-60px {
  margin-right: 60pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-60px {
    margin-right: 30pxpx !important;
  }
}

.u-mr-70px {
  margin-right: 70pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-70px {
    margin-right: 35pxpx !important;
  }
}

.u-mr-80px {
  margin-right: 80pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-80px {
    margin-right: 40pxpx !important;
  }
}

.u-mr-90px {
  margin-right: 90pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-90px {
    margin-right: 45pxpx !important;
  }
}

.u-mr-100px {
  margin-right: 100pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-100px {
    margin-right: 50pxpx !important;
  }
}

.u-mr-110px {
  margin-right: 110pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-110px {
    margin-right: 55pxpx !important;
  }
}

.u-mr-120px {
  margin-right: 120pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-120px {
    margin-right: 60pxpx !important;
  }
}

.u-mr-130px {
  margin-right: 130pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-130px {
    margin-right: 65pxpx !important;
  }
}

.u-mr-140px {
  margin-right: 140pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-140px {
    margin-right: 70pxpx !important;
  }
}

.u-mr-150px {
  margin-right: 150pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-150px {
    margin-right: 75pxpx !important;
  }
}

.u-mr-160px {
  margin-right: 160pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-160px {
    margin-right: 80pxpx !important;
  }
}

.u-mr-170px {
  margin-right: 170pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-170px {
    margin-right: 85pxpx !important;
  }
}

.u-mr-180px {
  margin-right: 180pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-180px {
    margin-right: 90pxpx !important;
  }
}

.u-mr-190px {
  margin-right: 190pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-190px {
    margin-right: 95pxpx !important;
  }
}

.u-mr-200px {
  margin-right: 200pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-200px {
    margin-right: 100pxpx !important;
  }
}

.u-mr-210px {
  margin-right: 210pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-210px {
    margin-right: 105pxpx !important;
  }
}

.u-mr-220px {
  margin-right: 220pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-220px {
    margin-right: 110pxpx !important;
  }
}

.u-mr-230px {
  margin-right: 230pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-230px {
    margin-right: 115pxpx !important;
  }
}

.u-mr-240px {
  margin-right: 240pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mr-240px {
    margin-right: 120pxpx !important;
  }
}

/* Bottom margin */
.u-mb--10px {
  margin-bottom: -10pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb--10px {
    margin-bottom: -5pxpx !important;
  }
}

.u-mb-0px {
  margin-bottom: 0pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-0px {
    margin-bottom: 0pxpx !important;
  }
}

.u-mb-10px {
  margin-bottom: 10pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-10px {
    margin-bottom: 5pxpx !important;
  }
}

.u-mb-20px {
  margin-bottom: 20pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-20px {
    margin-bottom: 10pxpx !important;
  }
}

.u-mb-30px {
  margin-bottom: 30pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-30px {
    margin-bottom: 15pxpx !important;
  }
}

.u-mb-40px {
  margin-bottom: 40pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-40px {
    margin-bottom: 20pxpx !important;
  }
}

.u-mb-50px {
  margin-bottom: 50pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-50px {
    margin-bottom: 25pxpx !important;
  }
}

.u-mb-60px {
  margin-bottom: 60pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-60px {
    margin-bottom: 30pxpx !important;
  }
}

.u-mb-70px {
  margin-bottom: 70pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-70px {
    margin-bottom: 35pxpx !important;
  }
}

.u-mb-80px {
  margin-bottom: 80pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-80px {
    margin-bottom: 40pxpx !important;
  }
}

.u-mb-90px {
  margin-bottom: 90pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-90px {
    margin-bottom: 45pxpx !important;
  }
}

.u-mb-100px {
  margin-bottom: 100pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-100px {
    margin-bottom: 50pxpx !important;
  }
}

.u-mb-110px {
  margin-bottom: 110pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-110px {
    margin-bottom: 55pxpx !important;
  }
}

.u-mb-120px {
  margin-bottom: 120pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-120px {
    margin-bottom: 60pxpx !important;
  }
}

.u-mb-130px {
  margin-bottom: 130pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-130px {
    margin-bottom: 65pxpx !important;
  }
}

.u-mb-140px {
  margin-bottom: 140pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-140px {
    margin-bottom: 70pxpx !important;
  }
}

.u-mb-150px {
  margin-bottom: 150pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-150px {
    margin-bottom: 75pxpx !important;
  }
}

.u-mb-160px {
  margin-bottom: 160pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-160px {
    margin-bottom: 80pxpx !important;
  }
}

.u-mb-170px {
  margin-bottom: 170pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-170px {
    margin-bottom: 85pxpx !important;
  }
}

.u-mb-180px {
  margin-bottom: 180pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-180px {
    margin-bottom: 90pxpx !important;
  }
}

.u-mb-190px {
  margin-bottom: 190pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-190px {
    margin-bottom: 95pxpx !important;
  }
}

.u-mb-200px {
  margin-bottom: 200pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-200px {
    margin-bottom: 100pxpx !important;
  }
}

.u-mb-210px {
  margin-bottom: 210pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-210px {
    margin-bottom: 105pxpx !important;
  }
}

.u-mb-220px {
  margin-bottom: 220pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-220px {
    margin-bottom: 110pxpx !important;
  }
}

.u-mb-230px {
  margin-bottom: 230pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-230px {
    margin-bottom: 115pxpx !important;
  }
}

.u-mb-240px {
  margin-bottom: 240pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-mb-240px {
    margin-bottom: 120pxpx !important;
  }
}

/* Left margin */
.u-ml-0px {
  margin-left: 0pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-0px {
    margin-left: 0pxpx !important;
  }
}

.u-ml-10px {
  margin-left: 10pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-10px {
    margin-left: 5pxpx !important;
  }
}

.u-ml-20px {
  margin-left: 20pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-20px {
    margin-left: 10pxpx !important;
  }
}

.u-ml-30px {
  margin-left: 30pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-30px {
    margin-left: 15pxpx !important;
  }
}

.u-ml-40px {
  margin-left: 40pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-40px {
    margin-left: 20pxpx !important;
  }
}

.u-ml-50px {
  margin-left: 50pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-50px {
    margin-left: 25pxpx !important;
  }
}

.u-ml-60px {
  margin-left: 60pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-60px {
    margin-left: 30pxpx !important;
  }
}

.u-ml-70px {
  margin-left: 70pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-70px {
    margin-left: 35pxpx !important;
  }
}

.u-ml-80px {
  margin-left: 80pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-80px {
    margin-left: 40pxpx !important;
  }
}

.u-ml-90px {
  margin-left: 90pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-90px {
    margin-left: 45pxpx !important;
  }
}

.u-ml-100px {
  margin-left: 100pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-100px {
    margin-left: 50pxpx !important;
  }
}

.u-ml-110px {
  margin-left: 110pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-110px {
    margin-left: 55pxpx !important;
  }
}

.u-ml-120px {
  margin-left: 120pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-120px {
    margin-left: 60pxpx !important;
  }
}

.u-ml-130px {
  margin-left: 130pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-130px {
    margin-left: 65pxpx !important;
  }
}

.u-ml-140px {
  margin-left: 140pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-140px {
    margin-left: 70pxpx !important;
  }
}

.u-ml-150px {
  margin-left: 150pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-150px {
    margin-left: 75pxpx !important;
  }
}

.u-ml-160px {
  margin-left: 160pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-160px {
    margin-left: 80pxpx !important;
  }
}

.u-ml-170px {
  margin-left: 170pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-170px {
    margin-left: 85pxpx !important;
  }
}

.u-ml-180px {
  margin-left: 180pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-180px {
    margin-left: 90pxpx !important;
  }
}

.u-ml-190px {
  margin-left: 190pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-190px {
    margin-left: 95pxpx !important;
  }
}

.u-ml-200px {
  margin-left: 200pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-200px {
    margin-left: 100pxpx !important;
  }
}

.u-ml-210px {
  margin-left: 210pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-210px {
    margin-left: 105pxpx !important;
  }
}

.u-ml-220px {
  margin-left: 220pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-220px {
    margin-left: 110pxpx !important;
  }
}

.u-ml-230px {
  margin-left: 230pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-230px {
    margin-left: 115pxpx !important;
  }
}

.u-ml-240px {
  margin-left: 240pxpx !important;
}
@media screen and (max-width: 767px) {
  .u-ml-240px {
    margin-left: 120pxpx !important;
  }
}

/* no margin */
.u-m-0 {
  margin: 0 !important;
}

.u-mt-0 {
  margin-top: 0 !important;
}

.u-mb-0 {
  margin-bottom: 0 !important;
}

.u-ml-0 {
  margin-left: 0 !important;
}

.u-p0 {
  padding: 0px;
}

@media screen and (max-width: 767px) {
  .u-sp-p0 {
    padding: 0px !important;
  }
}

.u-p1 {
  padding: 5px;
}

@media screen and (max-width: 767px) {
  .u-sp-p1 {
    padding: 5px !important;
  }
}

.u-p2 {
  padding: 10px;
}

@media screen and (max-width: 767px) {
  .u-sp-p2 {
    padding: 10px !important;
  }
}

.u-p3 {
  padding: 15px;
}

@media screen and (max-width: 767px) {
  .u-sp-p3 {
    padding: 15px !important;
  }
}

.u-p4 {
  padding: 20px;
}

@media screen and (max-width: 767px) {
  .u-sp-p4 {
    padding: 20px !important;
  }
}

.u-p5 {
  padding: 25px;
}

@media screen and (max-width: 767px) {
  .u-sp-p5 {
    padding: 25px !important;
  }
}

.u-p6 {
  padding: 30px;
}

@media screen and (max-width: 767px) {
  .u-sp-p6 {
    padding: 30px !important;
  }
}

.u-p7 {
  padding: 35px;
}

@media screen and (max-width: 767px) {
  .u-sp-p7 {
    padding: 35px !important;
  }
}

.u-p8 {
  padding: 40px;
}

@media screen and (max-width: 767px) {
  .u-sp-p8 {
    padding: 40px !important;
  }
}

.u-p9 {
  padding: 45px;
}

@media screen and (max-width: 767px) {
  .u-sp-p9 {
    padding: 45px !important;
  }
}

.u-p10 {
  padding: 50px;
}

@media screen and (max-width: 767px) {
  .u-sp-p10 {
    padding: 50px !important;
  }
}

.u-p11 {
  padding: 55px;
}

@media screen and (max-width: 767px) {
  .u-sp-p11 {
    padding: 55px !important;
  }
}

.u-p12 {
  padding: 60px;
}

@media screen and (max-width: 767px) {
  .u-sp-p12 {
    padding: 60px !important;
  }
}

.u-p13 {
  padding: 65px;
}

@media screen and (max-width: 767px) {
  .u-sp-p13 {
    padding: 65px !important;
  }
}

.u-p14 {
  padding: 70px;
}

@media screen and (max-width: 767px) {
  .u-sp-p14 {
    padding: 70px !important;
  }
}

.u-p15 {
  padding: 75px;
}

@media screen and (max-width: 767px) {
  .u-sp-p15 {
    padding: 75px !important;
  }
}

.u-p16 {
  padding: 80px;
}

@media screen and (max-width: 767px) {
  .u-sp-p16 {
    padding: 80px !important;
  }
}

.u-p17 {
  padding: 85px;
}

@media screen and (max-width: 767px) {
  .u-sp-p17 {
    padding: 85px !important;
  }
}

.u-p18 {
  padding: 90px;
}

@media screen and (max-width: 767px) {
  .u-sp-p18 {
    padding: 90px !important;
  }
}

.u-p19 {
  padding: 95px;
}

@media screen and (max-width: 767px) {
  .u-sp-p19 {
    padding: 95px !important;
  }
}

.u-p20 {
  padding: 100px;
}

@media screen and (max-width: 767px) {
  .u-sp-p20 {
    padding: 100px !important;
  }
}

.u-p21 {
  padding: 105px;
}

@media screen and (max-width: 767px) {
  .u-sp-p21 {
    padding: 105px !important;
  }
}

.u-p22 {
  padding: 110px;
}

@media screen and (max-width: 767px) {
  .u-sp-p22 {
    padding: 110px !important;
  }
}

.u-p23 {
  padding: 115px;
}

@media screen and (max-width: 767px) {
  .u-sp-p23 {
    padding: 115px !important;
  }
}

.u-p24 {
  padding: 120px;
}

@media screen and (max-width: 767px) {
  .u-sp-p24 {
    padding: 120px !important;
  }
}

.u-p25 {
  padding: 125px;
}

@media screen and (max-width: 767px) {
  .u-sp-p25 {
    padding: 125px !important;
  }
}

.u-p26 {
  padding: 130px;
}

@media screen and (max-width: 767px) {
  .u-sp-p26 {
    padding: 130px !important;
  }
}

.u-p27 {
  padding: 135px;
}

@media screen and (max-width: 767px) {
  .u-sp-p27 {
    padding: 135px !important;
  }
}

.u-p28 {
  padding: 140px;
}

@media screen and (max-width: 767px) {
  .u-sp-p28 {
    padding: 140px !important;
  }
}

.u-p29 {
  padding: 145px;
}

@media screen and (max-width: 767px) {
  .u-sp-p29 {
    padding: 145px !important;
  }
}

.u-p30 {
  padding: 150px;
}

@media screen and (max-width: 767px) {
  .u-sp-p30 {
    padding: 150px !important;
  }
}

.u-p31 {
  padding: 155px;
}

@media screen and (max-width: 767px) {
  .u-sp-p31 {
    padding: 155px !important;
  }
}

.u-p32 {
  padding: 160px;
}

@media screen and (max-width: 767px) {
  .u-sp-p32 {
    padding: 160px !important;
  }
}

.u-p33 {
  padding: 165px;
}

@media screen and (max-width: 767px) {
  .u-sp-p33 {
    padding: 165px !important;
  }
}

.u-p34 {
  padding: 170px;
}

@media screen and (max-width: 767px) {
  .u-sp-p34 {
    padding: 170px !important;
  }
}

.u-p35 {
  padding: 175px;
}

@media screen and (max-width: 767px) {
  .u-sp-p35 {
    padding: 175px !important;
  }
}

.u-p36 {
  padding: 180px;
}

@media screen and (max-width: 767px) {
  .u-sp-p36 {
    padding: 180px !important;
  }
}

.u-p37 {
  padding: 185px;
}

@media screen and (max-width: 767px) {
  .u-sp-p37 {
    padding: 185px !important;
  }
}

.u-p38 {
  padding: 190px;
}

@media screen and (max-width: 767px) {
  .u-sp-p38 {
    padding: 190px !important;
  }
}

.u-p39 {
  padding: 195px;
}

@media screen and (max-width: 767px) {
  .u-sp-p39 {
    padding: 195px !important;
  }
}

.u-p40 {
  padding: 200px;
}

@media screen and (max-width: 767px) {
  .u-sp-p40 {
    padding: 200px !important;
  }
}

.u-pt0 {
  padding-top: 0px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt0 {
    padding-top: 0px !important;
  }
}

.u-pt1 {
  padding-top: 5px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt1 {
    padding-top: 5px !important;
  }
}

.u-pt2 {
  padding-top: 10px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt2 {
    padding-top: 10px !important;
  }
}

.u-pt3 {
  padding-top: 15px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt3 {
    padding-top: 15px !important;
  }
}

.u-pt4 {
  padding-top: 20px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt4 {
    padding-top: 20px !important;
  }
}

.u-pt5 {
  padding-top: 25px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt5 {
    padding-top: 25px !important;
  }
}

.u-pt6 {
  padding-top: 30px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt6 {
    padding-top: 30px !important;
  }
}

.u-pt7 {
  padding-top: 35px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt7 {
    padding-top: 35px !important;
  }
}

.u-pt8 {
  padding-top: 40px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt8 {
    padding-top: 40px !important;
  }
}

.u-pt9 {
  padding-top: 45px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt9 {
    padding-top: 45px !important;
  }
}

.u-pt10 {
  padding-top: 50px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt10 {
    padding-top: 50px !important;
  }
}

.u-pt11 {
  padding-top: 55px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt11 {
    padding-top: 55px !important;
  }
}

.u-pt12 {
  padding-top: 60px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt12 {
    padding-top: 60px !important;
  }
}

.u-pt13 {
  padding-top: 65px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt13 {
    padding-top: 65px !important;
  }
}

.u-pt14 {
  padding-top: 70px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt14 {
    padding-top: 70px !important;
  }
}

.u-pt15 {
  padding-top: 75px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt15 {
    padding-top: 75px !important;
  }
}

.u-pt16 {
  padding-top: 80px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt16 {
    padding-top: 80px !important;
  }
}

.u-pt17 {
  padding-top: 85px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt17 {
    padding-top: 85px !important;
  }
}

.u-pt18 {
  padding-top: 90px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt18 {
    padding-top: 90px !important;
  }
}

.u-pt19 {
  padding-top: 95px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt19 {
    padding-top: 95px !important;
  }
}

.u-pt20 {
  padding-top: 100px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt20 {
    padding-top: 100px !important;
  }
}

.u-pt21 {
  padding-top: 105px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt21 {
    padding-top: 105px !important;
  }
}

.u-pt22 {
  padding-top: 110px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt22 {
    padding-top: 110px !important;
  }
}

.u-pt23 {
  padding-top: 115px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt23 {
    padding-top: 115px !important;
  }
}

.u-pt24 {
  padding-top: 120px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt24 {
    padding-top: 120px !important;
  }
}

.u-pt25 {
  padding-top: 125px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt25 {
    padding-top: 125px !important;
  }
}

.u-pt26 {
  padding-top: 130px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt26 {
    padding-top: 130px !important;
  }
}

.u-pt27 {
  padding-top: 135px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt27 {
    padding-top: 135px !important;
  }
}

.u-pt28 {
  padding-top: 140px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt28 {
    padding-top: 140px !important;
  }
}

.u-pt29 {
  padding-top: 145px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt29 {
    padding-top: 145px !important;
  }
}

.u-pt30 {
  padding-top: 150px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt30 {
    padding-top: 150px !important;
  }
}

.u-pt31 {
  padding-top: 155px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt31 {
    padding-top: 155px !important;
  }
}

.u-pt32 {
  padding-top: 160px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt32 {
    padding-top: 160px !important;
  }
}

.u-pt33 {
  padding-top: 165px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt33 {
    padding-top: 165px !important;
  }
}

.u-pt34 {
  padding-top: 170px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt34 {
    padding-top: 170px !important;
  }
}

.u-pt35 {
  padding-top: 175px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt35 {
    padding-top: 175px !important;
  }
}

.u-pt36 {
  padding-top: 180px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt36 {
    padding-top: 180px !important;
  }
}

.u-pt37 {
  padding-top: 185px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt37 {
    padding-top: 185px !important;
  }
}

.u-pt38 {
  padding-top: 190px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt38 {
    padding-top: 190px !important;
  }
}

.u-pt39 {
  padding-top: 195px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt39 {
    padding-top: 195px !important;
  }
}

.u-pt40 {
  padding-top: 200px;
}

@media screen and (max-width: 767px) {
  .u-sp-pt40 {
    padding-top: 200px !important;
  }
}

.u-pb0 {
  padding-bottom: 0px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb0 {
    padding-bottom: 0px !important;
  }
}

.u-pb1 {
  padding-bottom: 5px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb1 {
    padding-bottom: 5px !important;
  }
}

.u-pb2 {
  padding-bottom: 10px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb2 {
    padding-bottom: 10px !important;
  }
}

.u-pb3 {
  padding-bottom: 15px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb3 {
    padding-bottom: 15px !important;
  }
}

.u-pb4 {
  padding-bottom: 20px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb4 {
    padding-bottom: 20px !important;
  }
}

.u-pb5 {
  padding-bottom: 25px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb5 {
    padding-bottom: 25px !important;
  }
}

.u-pb6 {
  padding-bottom: 30px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb6 {
    padding-bottom: 30px !important;
  }
}

.u-pb7 {
  padding-bottom: 35px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb7 {
    padding-bottom: 35px !important;
  }
}

.u-pb8 {
  padding-bottom: 40px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb8 {
    padding-bottom: 40px !important;
  }
}

.u-pb9 {
  padding-bottom: 45px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb9 {
    padding-bottom: 45px !important;
  }
}

.u-pb10 {
  padding-bottom: 50px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb10 {
    padding-bottom: 50px !important;
  }
}

.u-pb11 {
  padding-bottom: 55px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb11 {
    padding-bottom: 55px !important;
  }
}

.u-pb12 {
  padding-bottom: 60px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb12 {
    padding-bottom: 60px !important;
  }
}

.u-pb13 {
  padding-bottom: 65px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb13 {
    padding-bottom: 65px !important;
  }
}

.u-pb14 {
  padding-bottom: 70px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb14 {
    padding-bottom: 70px !important;
  }
}

.u-pb15 {
  padding-bottom: 75px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb15 {
    padding-bottom: 75px !important;
  }
}

.u-pb16 {
  padding-bottom: 80px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb16 {
    padding-bottom: 80px !important;
  }
}

.u-pb17 {
  padding-bottom: 85px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb17 {
    padding-bottom: 85px !important;
  }
}

.u-pb18 {
  padding-bottom: 90px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb18 {
    padding-bottom: 90px !important;
  }
}

.u-pb19 {
  padding-bottom: 95px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb19 {
    padding-bottom: 95px !important;
  }
}

.u-pb20 {
  padding-bottom: 100px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb20 {
    padding-bottom: 100px !important;
  }
}

.u-pb21 {
  padding-bottom: 105px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb21 {
    padding-bottom: 105px !important;
  }
}

.u-pb22 {
  padding-bottom: 110px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb22 {
    padding-bottom: 110px !important;
  }
}

.u-pb23 {
  padding-bottom: 115px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb23 {
    padding-bottom: 115px !important;
  }
}

.u-pb24 {
  padding-bottom: 120px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb24 {
    padding-bottom: 120px !important;
  }
}

.u-pb25 {
  padding-bottom: 125px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb25 {
    padding-bottom: 125px !important;
  }
}

.u-pb26 {
  padding-bottom: 130px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb26 {
    padding-bottom: 130px !important;
  }
}

.u-pb27 {
  padding-bottom: 135px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb27 {
    padding-bottom: 135px !important;
  }
}

.u-pb28 {
  padding-bottom: 140px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb28 {
    padding-bottom: 140px !important;
  }
}

.u-pb29 {
  padding-bottom: 145px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb29 {
    padding-bottom: 145px !important;
  }
}

.u-pb30 {
  padding-bottom: 150px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb30 {
    padding-bottom: 150px !important;
  }
}

.u-pb31 {
  padding-bottom: 155px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb31 {
    padding-bottom: 155px !important;
  }
}

.u-pb32 {
  padding-bottom: 160px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb32 {
    padding-bottom: 160px !important;
  }
}

.u-pb33 {
  padding-bottom: 165px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb33 {
    padding-bottom: 165px !important;
  }
}

.u-pb34 {
  padding-bottom: 170px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb34 {
    padding-bottom: 170px !important;
  }
}

.u-pb35 {
  padding-bottom: 175px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb35 {
    padding-bottom: 175px !important;
  }
}

.u-pb36 {
  padding-bottom: 180px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb36 {
    padding-bottom: 180px !important;
  }
}

.u-pb37 {
  padding-bottom: 185px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb37 {
    padding-bottom: 185px !important;
  }
}

.u-pb38 {
  padding-bottom: 190px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb38 {
    padding-bottom: 190px !important;
  }
}

.u-pb39 {
  padding-bottom: 195px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb39 {
    padding-bottom: 195px !important;
  }
}

.u-pb40 {
  padding-bottom: 200px;
}

@media screen and (max-width: 767px) {
  .u-sp-pb40 {
    padding-bottom: 200px !important;
  }
}

.u-pr0 {
  padding-right: 0px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr0 {
    padding-right: 0px !important;
  }
}

.u-pr1 {
  padding-right: 5px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr1 {
    padding-right: 5px !important;
  }
}

.u-pr2 {
  padding-right: 10px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr2 {
    padding-right: 10px !important;
  }
}

.u-pr3 {
  padding-right: 15px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr3 {
    padding-right: 15px !important;
  }
}

.u-pr4 {
  padding-right: 20px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr4 {
    padding-right: 20px !important;
  }
}

.u-pr5 {
  padding-right: 25px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr5 {
    padding-right: 25px !important;
  }
}

.u-pr6 {
  padding-right: 30px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr6 {
    padding-right: 30px !important;
  }
}

.u-pr7 {
  padding-right: 35px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr7 {
    padding-right: 35px !important;
  }
}

.u-pr8 {
  padding-right: 40px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr8 {
    padding-right: 40px !important;
  }
}

.u-pr9 {
  padding-right: 45px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr9 {
    padding-right: 45px !important;
  }
}

.u-pr10 {
  padding-right: 50px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr10 {
    padding-right: 50px !important;
  }
}

.u-pr11 {
  padding-right: 55px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr11 {
    padding-right: 55px !important;
  }
}

.u-pr12 {
  padding-right: 60px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr12 {
    padding-right: 60px !important;
  }
}

.u-pr13 {
  padding-right: 65px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr13 {
    padding-right: 65px !important;
  }
}

.u-pr14 {
  padding-right: 70px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr14 {
    padding-right: 70px !important;
  }
}

.u-pr15 {
  padding-right: 75px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr15 {
    padding-right: 75px !important;
  }
}

.u-pr16 {
  padding-right: 80px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr16 {
    padding-right: 80px !important;
  }
}

.u-pr17 {
  padding-right: 85px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr17 {
    padding-right: 85px !important;
  }
}

.u-pr18 {
  padding-right: 90px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr18 {
    padding-right: 90px !important;
  }
}

.u-pr19 {
  padding-right: 95px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr19 {
    padding-right: 95px !important;
  }
}

.u-pr20 {
  padding-right: 100px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr20 {
    padding-right: 100px !important;
  }
}

.u-pr21 {
  padding-right: 105px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr21 {
    padding-right: 105px !important;
  }
}

.u-pr22 {
  padding-right: 110px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr22 {
    padding-right: 110px !important;
  }
}

.u-pr23 {
  padding-right: 115px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr23 {
    padding-right: 115px !important;
  }
}

.u-pr24 {
  padding-right: 120px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr24 {
    padding-right: 120px !important;
  }
}

.u-pr25 {
  padding-right: 125px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr25 {
    padding-right: 125px !important;
  }
}

.u-pr26 {
  padding-right: 130px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr26 {
    padding-right: 130px !important;
  }
}

.u-pr27 {
  padding-right: 135px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr27 {
    padding-right: 135px !important;
  }
}

.u-pr28 {
  padding-right: 140px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr28 {
    padding-right: 140px !important;
  }
}

.u-pr29 {
  padding-right: 145px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr29 {
    padding-right: 145px !important;
  }
}

.u-pr30 {
  padding-right: 150px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr30 {
    padding-right: 150px !important;
  }
}

.u-pr31 {
  padding-right: 155px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr31 {
    padding-right: 155px !important;
  }
}

.u-pr32 {
  padding-right: 160px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr32 {
    padding-right: 160px !important;
  }
}

.u-pr33 {
  padding-right: 165px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr33 {
    padding-right: 165px !important;
  }
}

.u-pr34 {
  padding-right: 170px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr34 {
    padding-right: 170px !important;
  }
}

.u-pr35 {
  padding-right: 175px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr35 {
    padding-right: 175px !important;
  }
}

.u-pr36 {
  padding-right: 180px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr36 {
    padding-right: 180px !important;
  }
}

.u-pr37 {
  padding-right: 185px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr37 {
    padding-right: 185px !important;
  }
}

.u-pr38 {
  padding-right: 190px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr38 {
    padding-right: 190px !important;
  }
}

.u-pr39 {
  padding-right: 195px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr39 {
    padding-right: 195px !important;
  }
}

.u-pr40 {
  padding-right: 200px;
}

@media screen and (max-width: 767px) {
  .u-sp-pr40 {
    padding-right: 200px !important;
  }
}

.u-pl0 {
  padding-left: 0px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl0 {
    padding-left: 0px !important;
  }
}

.u-pl1 {
  padding-left: 5px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl1 {
    padding-left: 5px !important;
  }
}

.u-pl2 {
  padding-left: 10px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl2 {
    padding-left: 10px !important;
  }
}

.u-pl3 {
  padding-left: 15px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl3 {
    padding-left: 15px !important;
  }
}

.u-pl4 {
  padding-left: 20px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl4 {
    padding-left: 20px !important;
  }
}

.u-pl5 {
  padding-left: 25px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl5 {
    padding-left: 25px !important;
  }
}

.u-pl6 {
  padding-left: 30px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl6 {
    padding-left: 30px !important;
  }
}

.u-pl7 {
  padding-left: 35px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl7 {
    padding-left: 35px !important;
  }
}

.u-pl8 {
  padding-left: 40px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl8 {
    padding-left: 40px !important;
  }
}

.u-pl9 {
  padding-left: 45px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl9 {
    padding-left: 45px !important;
  }
}

.u-pl10 {
  padding-left: 50px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl10 {
    padding-left: 50px !important;
  }
}

.u-pl11 {
  padding-left: 55px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl11 {
    padding-left: 55px !important;
  }
}

.u-pl12 {
  padding-left: 60px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl12 {
    padding-left: 60px !important;
  }
}

.u-pl13 {
  padding-left: 65px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl13 {
    padding-left: 65px !important;
  }
}

.u-pl14 {
  padding-left: 70px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl14 {
    padding-left: 70px !important;
  }
}

.u-pl15 {
  padding-left: 75px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl15 {
    padding-left: 75px !important;
  }
}

.u-pl16 {
  padding-left: 80px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl16 {
    padding-left: 80px !important;
  }
}

.u-pl17 {
  padding-left: 85px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl17 {
    padding-left: 85px !important;
  }
}

.u-pl18 {
  padding-left: 90px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl18 {
    padding-left: 90px !important;
  }
}

.u-pl19 {
  padding-left: 95px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl19 {
    padding-left: 95px !important;
  }
}

.u-pl20 {
  padding-left: 100px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl20 {
    padding-left: 100px !important;
  }
}

.u-pl21 {
  padding-left: 105px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl21 {
    padding-left: 105px !important;
  }
}

.u-pl22 {
  padding-left: 110px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl22 {
    padding-left: 110px !important;
  }
}

.u-pl23 {
  padding-left: 115px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl23 {
    padding-left: 115px !important;
  }
}

.u-pl24 {
  padding-left: 120px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl24 {
    padding-left: 120px !important;
  }
}

.u-pl25 {
  padding-left: 125px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl25 {
    padding-left: 125px !important;
  }
}

.u-pl26 {
  padding-left: 130px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl26 {
    padding-left: 130px !important;
  }
}

.u-pl27 {
  padding-left: 135px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl27 {
    padding-left: 135px !important;
  }
}

.u-pl28 {
  padding-left: 140px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl28 {
    padding-left: 140px !important;
  }
}

.u-pl29 {
  padding-left: 145px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl29 {
    padding-left: 145px !important;
  }
}

.u-pl30 {
  padding-left: 150px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl30 {
    padding-left: 150px !important;
  }
}

.u-pl31 {
  padding-left: 155px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl31 {
    padding-left: 155px !important;
  }
}

.u-pl32 {
  padding-left: 160px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl32 {
    padding-left: 160px !important;
  }
}

.u-pl33 {
  padding-left: 165px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl33 {
    padding-left: 165px !important;
  }
}

.u-pl34 {
  padding-left: 170px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl34 {
    padding-left: 170px !important;
  }
}

.u-pl35 {
  padding-left: 175px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl35 {
    padding-left: 175px !important;
  }
}

.u-pl36 {
  padding-left: 180px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl36 {
    padding-left: 180px !important;
  }
}

.u-pl37 {
  padding-left: 185px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl37 {
    padding-left: 185px !important;
  }
}

.u-pl38 {
  padding-left: 190px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl38 {
    padding-left: 190px !important;
  }
}

.u-pl39 {
  padding-left: 195px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl39 {
    padding-left: 195px !important;
  }
}

.u-pl40 {
  padding-left: 200px;
}

@media screen and (max-width: 767px) {
  .u-sp-pl40 {
    padding-left: 200px !important;
  }
}

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

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

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

.ff-Princess {
  font-family: "Princess Sofia", cursive;
}