@charset "UTF-8";
/* ============================================
** reset
=============================================== */
* {
  margin: 0;
  padding: 0;
  line-height: calc(0.25rem + 1em + 0.25rem);
}

*,
::before,
::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  border-width: 0;
  border-style: solid;
  min-inline-size: 0;
}

*:where(:not(fieldset, progress, meter)) {
  border-width: 0;
  border-style: solid;
  background-repeat: no-repeat;
  background-origin: border-box;
}

:where(html) {
  block-size: 100%;
  -webkit-hyphens: auto;
      -ms-hyphens: auto;
  line-height: 1.5;
          hyphens: auto;
  text-align: start;
  word-break: normal;
  overflow-wrap: anywhere;
  -ms-touch-action: manipulation;
      touch-action: manipulation;
  -webkit-text-size-adjust: 100%;
     -moz-text-size-adjust: 100%;
      -ms-text-size-adjust: 100%;
          text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  hanging-punctuation: first last allow-end;
  line-break: strict;
}

:where(html):where(:lang(ja)) {
  -webkit-font-kerning: none;
          font-kerning: none;
}

:where(body) {
  margin: unset;
  min-block-size: 100svb;
}

:where(h1, h2, h3, h4, h5, h6) {
  margin-block: unset;
  font-size: unset;
}

:where(p, h1, h2, h3, h4, h5, h6) {
  overflow-wrap: break-word;
}

:where(search) {
  display: block;
}

:where(p, blockquote, figure, pre, address, ul, ol, dl) {
  margin-block: unset;
}

:where(blockquote, figure) {
  margin-inline: unset;
}

:where(address):where(:lang(ja)) {
  font-style: unset;
}

:where(ul, ol) {
  -webkit-padding-start: unset;
          padding-inline-start: unset;
  list-style-type: "";
  list-style-position: inside;
}

:where(dt) {
  font-weight: 700;
}

:where(dd) {
  -webkit-margin-start: unset;
          margin-inline-start: unset;
}

:where(hr) {
  border-block-start-width: 1px;
}

:where(pre) {
  -moz-tab-size: 2;
    -o-tab-size: 2;
       tab-size: 2;
}

:where(img, svg, video, canvas, audio, iframe, embed, object) {
  display: block;
  vertical-align: middle;
}

:where(img, svg, video) {
  max-inline-size: 100%;
  block-size: auto;
}

:where(:-webkit-any-link) {
  color: unset;
  -webkit-text-decoration-line: none;
  background-color: unset;
          text-decoration-line: none;
  text-decoration-thickness: from-font;
  text-underline-offset: 0.25em;
}

:where(:-moz-any-link) {
  background-color: unset;
  color: unset;
  text-decoration-line: none;
  text-decoration-thickness: from-font;
  text-underline-offset: 0.25em;
}

:where(:any-link) {
  color: unset;
  -webkit-text-decoration-line: none;
  background-color: unset;
          text-decoration-line: none;
  text-decoration-thickness: from-font;
  text-underline-offset: 0.25em;
}

:where(svg) {
  vertical-align: middle;
  fill: currentcolor;
  stroke: none;
}

:where(svg):where(:not([fill])) {
  fill: none;
  stroke: currentcolor;
  stroke-linecap: round;
  stroke-linejoin: round;
}

:where(svg):where(:not([width])) {
  inline-size: 5rem;
}

:where(input, button, textarea, select),
:where(input[type=file])::-webkit-file-upload-button {
  color: inherit;
  font: inherit;
  font-size: inherit;
  letter-spacing: inherit;
  word-spacing: inherit;
}

:where(textarea) {
  margin-block: unset;
  resize: block;
  field-sizing: content;
}

@supports (resize: block) {
  :where(textarea) {
    resize: block;
  }
}
:where(a[href], area, button, input, label[for], select, summary, textarea, [tabindex]:not([tabindex*="-"])) {
  -ms-touch-action: manipulation;
  /* cursor: pointer; */
      touch-action: manipulation;
}

:where(input[type=file]) {
  cursor: auto;
}

:where(input[type=file])::-webkit-file-upload-button {
  cursor: pointer;
}

:where(input[type=file])::-webkit-file-upload-button,
:where(input[type=file])::file-selector-button {
  cursor: pointer;
}
:where(:not(:active)):focus-visible {
  outline-offset: 5px;
}

:where(input[type=file])::-webkit-file-upload-button {
  text-align: center;
  -webkit-user-select: none;
          user-select: none;
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
}

:where(button, button[type], input[type=button], input[type=submit], input[type=reset]),
:where(input[type=file])::-webkit-file-upload-button,
:where(input[type=file])::file-selector-button {
  text-align: center;
  -webkit-user-select: none;
          user-select: none;
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
}

::-webkit-file-upload-button {
  vertical-align: middle;
  border-width: 1px;
  border-color: transparent;
  border-radius: unset;
  background-color: unset;
  padding: unset;
  color: unset;
  font: unset;
  letter-spacing: unset;
  text-align: unset;
  text-transform: unset;
}

:where(button, input, select, textarea),
::file-selector-button {
  vertical-align: middle;
  border-width: 1px;
  border-color: transparent;
  border-radius: unset;
  background-color: unset;
  padding: unset;
  color: unset;
  font: unset;
  letter-spacing: unset;
  text-align: unset;
  text-transform: unset;
}

:where(button, button[type], input[type=button], input[type=submit], input[type=reset])[disabled] {
  cursor: not-allowed;
}

:where(:focus:not(:focus-visible)) {
  outline: none;
}

:where(summary) {
  display: block;
  cursor: pointer;
}

::-webkit-details-marker {
  display: none;
}

:where(dialog) {
  background-color: unset;
  padding: unset;
  inline-size: unset;
  max-inline-size: unset;
  block-size: unset;
  max-block-size: unset;
  overflow: unset;
  color: unset;
}

:where([popover]) {
  background-color: unset;
  padding: unset;
  inline-size: unset;
  block-size: unset;
  overflow: unset;
  color: unset;
}

::-ms-backdrop {
  background-color: unset;
}

::backdrop {
  background-color: unset;
}

/* ============================================
** 変数
=============================================== */
:root {
  --color-primary: #333;
  --color-black: #000;
  --color-white: #fff;
  --color-yellow: #f0dc42;
  --color-green: #11a27b;
  --color-gray: #f5f5f5;
  --color-dark-gray: #4a4a4a;
  --noto-sans-jp: "Noto Sans JP", sans-serif;
  --montserrat: "Montserrat", sans-serif;
  --weight-light: 300;
  --weight-regular: 400;
  --weight-medium: 500;
  --weight-semi-bold: 600;
  --weight-bold: 700;
}

/* ============================================
** bodyなどサイト全体リセット上書き
=============================================== */
html {
  scroll-padding-block-start: var(--header-block-size);
  font-size: 100%;
}

body {
  color: var(--color-black);
  font-weight: var(--weight-regular);
  font-family: var(--noto-sans-jp);
}
body.is-active {
  overflow: hidden;
  -ms-scroll-chaining: none;
      overscroll-behavior: none;
  -ms-touch-action: none;
      touch-action: none;
}

a[href^="tel:"] {
  pointer-events: none;
}

/* ============================================ */
/* ============================================
** heading
=============================================== */
.primaryHeading {
  display: grid;
}
.primaryHeading[data-color=white] {
  color: var(--color-white);
}

.primaryHeading-main {
  grid-area: 2;
  font-weight: var(--weight-bold);
  font-size: 1rem;
}

.primaryHeading-sub {
  grid-area: 1;
  font-weight: var(--weight-semi-bold);
  font-size: clamp(2.1875rem, 1.1971830986rem + 4.2253521127vw, 5rem);
  font-family: var(--montserrat);
  text-transform: uppercase;
}

.primaryHeading-text {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-area: 3;
  -webkit-column-gap: 0.625rem;
     -moz-column-gap: 0.625rem;
          column-gap: 0.625rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-margin-before: 1.25rem;
          margin-block-start: 1.25rem;
  font-weight: var(--weight-bold);
  font-size: clamp(0.875rem, 0.3028169014rem + 2.441314554vw, 2.5rem);
}
.primaryHeading-text::before {
  background-color: var(--color-black);
  inline-size: 1.25rem;
  block-size: 1px;
  content: "";
}
.primaryHeading-text[data-color=white] {
  color: var(--color-white);
}
.primaryHeading-text[data-color=yellow] {
  color: var(--color-yellow);
}

/*
** lowerHeading
*/
.page .ly-lowerHeading .primaryHeading:not(:has(.primaryHeading-text)) {
  -webkit-margin-after: 2.5rem;
          margin-block-end: 2.5rem;
}

.ly-lowerHeading {
  --padding-top: 3.75rem;
  position: relative;
  z-index: 2;
  -webkit-padding-before: calc(var(--padding-top) + var(--header-block-size));
          padding-block-start: calc(var(--padding-top) + var(--header-block-size));
}

/* ============================================
** gnav
=============================================== */
.gnavWrapper {
  display: none;
}

.gnav {
  display: grid;
  grid-auto-flow: column;
  grid-area: nav;
  gap: 2rem;
}

.gnav__item:nth-child(1) {
  text-transform: uppercase;
}

.gnav__link {
  color: var(--color-white);
  font-weight: var(--weight-regular);
  font-size: 1rem;
}

.gnavButtonWrapper {
  grid-area: button;
}

.gnavButton {
  --background: var(--color-yellow);
  display: inline-block;
  border-radius: calc(infinity * 1px);
  background-color: var(--color-yellow);
  background-color: color-mix(in sRGB, var(--background), #000 var(--darken, 0%));
  padding-inline: 2.625rem;
  padding-block: 0.6875rem;
  font-weight: var(--weight-bold);
  font-size: 0.875rem;
  -webkit-transition: background-color 0.3s;
  transition: background-color 0.3s;
}
.gnavButton:focus-visible {
  --darken: 20%;
}

/* ============================================
** menu
=============================================== */
.menu {
  display: grid;
  grid-area: menu;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  justify-self: end;
}

/* ============================================
** burger
=============================================== */
.burger {
  display: inline-grid;
  position: relative;
  place-items: center;
  justify-self: end;
  z-index: calc(infinity);
  border-radius: 10px;
  background-color: var(--color-yellow);
  aspect-ratio: 1;
  inline-size: 50px;
  pointer-events: all;
}
.burger[aria-expanded=true] .burger__line {
  --translate: 0px;
  --rotate: 45deg;
  background-color: transparent;
}
.burger[aria-expanded=true] .burger__line::before {
  translate: 0 var(--translate);
  rotate: var(--rotate);
}
.burger[aria-expanded=true] .burger__line::after {
  translate: 0 calc(var(--translate) * -1);
  rotate: calc(var(--rotate) * -1);
}

.burger__line {
  --translate: 4px;
  --rotate: 0deg;
  display: inline-grid;
  grid-area: 1/1/-1/-1;
  place-items: center;
  background-color: transparent;
  inline-size: 1.875rem;
  block-size: 1px;
}
.burger__line::before, .burger__line::after {
  position: absolute;
  grid-column: 1/-1;
  background-color: var(--color-primary);
  inline-size: inherit;
  block-size: inherit;
  content: "";
  -webkit-transition: translate 0.3s, rotate 0.3s, background-color 0.3s;
  transition: translate 0.3s, rotate 0.3s, background-color 0.3s;
}
.burger__line::before {
  translate: 0 var(--translate);
  rotate: var(--rotate);
}
.burger__line::after {
  translate: 0 calc(var(--translate) * -1);
  rotate: var(--rotate);
}

/* ============================================
** drawer
=============================================== */
.drawer {
  position: fixed;
  visibility: hidden;
  opacity: 0;
  z-index: 9999;
  inset-block-start: var(--header-block-size);
  inset-inline-start: 0;
  background-color: var(--color-yellow);
  inline-size: 100lvw;
  block-size: calc(100dvh - var(--header-block-size));
  overflow: clip auto;
}

.drawer__inner {
  --padding-block: 1.25rem;
  --padding-inline: 6vw;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  z-index: 1;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  padding-inline: var(--padding-inline);
  padding-block: var(--padding-block);
  inline-size: 100%;
  block-size: inherit;
}
.drawer__inner::before {
  position: absolute;
  z-index: -1;
  inset-block-end: 0;
  inset-inline-end: -1.4375rem;
  background-image: url("../images/common/other/face-bg.webp");
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  aspect-ratio: 320/273;
  inline-size: 20rem;
  pointer-events: none;
  content: "";
}

.drawer__list {
  display: grid;
  -webkit-box-align: start;
  -webkit-align-items: start;
      -ms-flex-align: start;
          align-items: start;
  -webkit-margin-before: 0.1875rem;
          margin-block-start: 0.1875rem;
}

.drawer__item {
  padding-inline: 1.5625rem;
  overflow: hidden;
  -webkit-border-after: 1px solid var(--color-white);
          border-block-end: 1px solid var(--color-white);
}

.drawer__link {
  display: block;
  padding-block: 0.625rem;
  font-weight: var(--weight-medium);
  font-size: 0.9375rem;
}

.drawer__title {
  color: var(--color-white);
  font-weight: var(--weight-regular);
  font-size: 0.9375rem;
  font-family: var(--montserrat);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.drawer__footer {
  margin-block: 3rem;
}

.drawer__buttonText {
  font-weight: var(--weight-bold);
  font-size: 0.75rem;
  text-align: center;
}

.drawer__buttonWrapper {
  max-inline-size: 310px;
  -webkit-margin-before: 0.8125rem;
  margin-inline: auto;
          margin-block-start: 0.8125rem;
}
.drawer__buttonWrapper .primaryButton {
  padding-inline: 1.125rem;
  padding-block: 0.9375rem;
  font-weight: var(--weight-medium);
  font-size: 0.9375rem;
}

.drawer__sns {
  -webkit-margin-before: 1.6875rem;
          margin-block-start: 1.6875rem;
  text-align: center;
}

.drawer__download {
  margin-inline: calc(var(--padding-inline) * -1);
  margin-block: auto calc(var(--padding-block) * -1);
  background-color: rgba(0, 0, 0, 0.5);
}

.drawer__downloadButton {
  display: grid;
  padding-block: 0.9375rem;
  color: var(--color-white);
  text-align: center;
}

.drawer__downloadButtonText {
  display: inline-grid;
  grid-template-columns: auto 1fr;
  -webkit-column-gap: 0.3125rem;
     -moz-column-gap: 0.3125rem;
          column-gap: 0.3125rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
  -webkit-padding-after: 0.25rem;
  margin-inline: auto;
          padding-block-end: 0.25rem;
  font-weight: var(--weight-medium);
  font-size: 0.875rem;
  -webkit-border-after: 1px solid var(--color-white);
          border-block-end: 1px solid var(--color-white);
}
.drawer__downloadButtonText::after {
  justify-self: start;
  background-image: url("../images/common/other/arrow-w.svg");
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  aspect-ratio: 10/9;
  inline-size: 0.625rem;
  content: "";
  -webkit-transition: translate 0.3s ease-in-out;
  transition: translate 0.3s ease-in-out;
}

.drawer__downloadText {
  display: block;
  -webkit-padding-before: 0.25rem;
          padding-block-start: 0.25rem;
  font-weight: var(--weight-regular);
  font-size: 0.75rem;
  font-family: var(--montserrat);
  letter-spacing: 0.2em;
  text-transform: capitalize;
}

/* ============================================
** button
=============================================== */
.primaryButtonWrapper {
  inline-size: 100%;
}

.primaryButton {
  display: inline-grid;
  grid-template-columns: 1fr auto 1fr;
  -webkit-column-gap: 1em;
     -moz-column-gap: 1em;
          column-gap: 1em;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: calc(infinity * 1px);
  inline-size: 100%;
}
.primaryButton::before, .primaryButton::after {
  content: "";
}
.primaryButton::before {
  grid-column: 1;
}
.primaryButton::after {
  grid-column: 3;
  justify-self: end;
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  -webkit-transition: translate 0.3s ease-in-out;
  transition: translate 0.3s ease-in-out;
}
.primaryButton:hover::after {
  translate: 5px 0;
}
.primaryButton[data-color=black] {
  background-color: var(--color-black);
  color: var(--color-white);
}
.primaryButton[data-color=black]::after {
  background-image: url("../images/common/other/arrow-w.svg");
  aspect-ratio: 10/9;
  inline-size: 0.625rem;
}
.primaryButton[data-color=yellow] {
  background-color: var(--color-yellow);
  color: var(--color-black);
}
.primaryButton[data-color=yellow]::after {
  background-image: url("../images/common/other/arrow-k.svg");
  aspect-ratio: 10/9;
  inline-size: 0.625rem;
}

/*
** contactButton
*/
.contactButton {
  margin-inline: auto;
  border-radius: 10px;
  background-color: var(--color-yellow);
  inline-size: 16.875rem;
  overflow: hidden;
}

.contactButton-link {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  place-content: center;
  padding-inline: 1.0625rem;
  padding-block: 0.4375rem;
  inline-size: 100%;
  block-size: 100%;
}
.contactButton-link::after {
  grid-column: 3;
  justify-self: end;
  background-image: url("../images/common/other/arrow-k.svg");
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  aspect-ratio: 10/9;
  inline-size: 0.625rem;
  content: "";
  -webkit-transition: translate 0.3s ease-in-out;
  transition: translate 0.3s ease-in-out;
}
.contactButton-link:hover::after {
  translate: 5px 0;
}

.contactButton-title {
  grid-column: 2;
  font-weight: var(--weight-bold);
  font-size: 0.625rem;
}

.contactButton-text {
  grid-column: 2;
  font-weight: var(--weight-semi-bold);
  font-size: 1.25rem;
  font-family: var(--montserrat);
  text-align: center;
  text-transform: uppercase;
}

/* ============================================
** worksItems
=============================================== */
.worksItems {
  display: grid;
  row-gap: 3.75rem;
}

.worksItem:has(.worksItem-title) .worksItem-list {
  -webkit-margin-before: 0.75rem;
          margin-block-start: 0.75rem;
}

.worksItem-title {
  font-weight: var(--weight-bold);
  font-size: 1.25rem;
}

.worksItem-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.1875rem;
}

.worksItem-item {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  gap: 0.8125rem;
}

.worksItem-itemImg {
  border-radius: 5px;
  overflow: hidden;
}
.worksItem-itemImg > img {
  aspect-ratio: 370/210;
  inline-size: 100%;
  block-size: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: scale 0.3s ease-in-out;
  transition: scale 0.3s ease-in-out;
}
.worksItem-itemImg:focus-visible > img {
  scale: 1.05;
}

.worksItem-itemName {
  font-weight: var(--weight-medium);
  font-size: 0.875rem;
  line-height: 1.4;
}

/* ============================================
** logo
=============================================== */
.logo__link > img {
  inline-size: 100%;
  block-size: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

/* ============================================
** planCards
=============================================== */
.planCards {
  display: grid;
  grid-template-columns: 1fr;
  row-gap: 2.0625rem;
  counter-reset: number 0;
}

.planCard {
  position: relative;
  counter-increment: number 1;
  border: 3px solid var(--color-black);
  border-radius: 20px;
  background-color: var(--color-white);
  block-size: -webkit-fit-content;
  block-size: -moz-fit-content;
  block-size: fit-content;
}
.planCard:nth-child(1) {
  padding-inline: 1.4375rem;
  padding-block: 1.5rem 1.75rem;
}
.planCard:nth-child(1) .planCard-img {
  inline-size: 12.5rem;
}
.planCard:nth-child(1) .planCard-img img {
  aspect-ratio: 200/86;
}
.planCard:nth-child(1) .planCard-text {
  -webkit-margin-before: 0.5rem;
          margin-block-start: 0.5rem;
}
.planCard:nth-child(1)::before {
  inset-inline-end: 1.25rem;
}
.planCard:nth-child(2) {
  padding-inline: 1.4375rem;
  padding-block: 1.3125rem 1.625rem;
}
.planCard:nth-child(2) .planCard-img {
  inline-size: 12.9375rem;
}
.planCard:nth-child(2) .planCard-img img {
  aspect-ratio: 207/92;
}
.planCard:nth-child(2) .planCard-text {
  -webkit-margin-before: 0.375rem;
          margin-block-start: 0.375rem;
}
.planCard:nth-child(2)::before {
  inset-inline-end: 0;
}
.planCard:nth-child(3) {
  padding-inline: 1.4375rem 0.75rem;
  padding-block: 1.625rem 1.875rem;
}
.planCard:nth-child(3) .planCard-img {
  inline-size: 12.5rem;
}
.planCard:nth-child(3) .planCard-img img {
  aspect-ratio: 200/83;
}
.planCard:nth-child(3) .planCard-text {
  -webkit-margin-before: 0.375rem;
          margin-block-start: 0.375rem;
}
.planCard:nth-child(3)::before {
  inset-inline-end: 0;
}
.planCard::before, .planCard::after {
  position: absolute;
  font-weight: var(--weight-semi-bold);
  font-family: var(--montserrat);
}
.planCard::before {
  position: absolute;
  z-index: 1;
  inset-block-start: -2.9375rem;
  content: counter(number);
  color: var(--color-yellow);
  font-size: 7.5625rem;
  line-height: 1;
}
.planCard::after {
  rotate: 90deg;
  z-index: 1;
  inset-block-start: 1.4375rem;
  inset-inline-end: 0.125rem;
  content: "plan";
  font-weight: var(--weight-semi-bold);
  font-size: 0.625rem;
  line-height: 1;
  font-family: var(--montserrat);
  text-transform: uppercase;
}
.planCard-img img {
  inline-size: 100%;
  block-size: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.planCard-text {
  font-weight: var(--weight-bold);
  font-size: 0.875rem;
  line-height: 1.4285714286;
}

.planCard-price {
  display: grid;
  position: relative;
  grid-auto-flow: column;
  -webkit-column-gap: 0.3125rem;
     -moz-column-gap: 0.3125rem;
          column-gap: 0.3125rem;
  place-content: center;
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  padding-inline: 0.5em;
  max-inline-size: 19.875rem;
  min-block-size: 5rem;
  -webkit-margin-before: 1.5rem;
  margin-inline: auto;
          margin-block-start: 1.5rem;
  border-radius: 10px;
  background-color: var(--color-yellow);
  font-weight: var(--weight-bold);
  font-size: 1.5rem;
  text-align: center;
}

.planCard-priceNumber {
  font-weight: var(--weight-semi-bold);
  font-size: 3.4375rem;
  font-family: var(--montserrat);
}

/* ============================================
** planList
=============================================== */
.planList {
  display: grid;
  gap: 2.5rem;
  counter-reset: number 0;
}

.planItem {
  --padding: 2.5rem;
  counter-increment: number 1;
  margin-inline: auto;
  border-radius: 20px;
  background-color: var(--color-gray);
  padding-block: 2rem 2.5rem;
  inline-size: calc(100% - var(--padding));
}

.planItem-inner {
  display: grid;
  grid-template-areas: "head" "meta" "footer";
}

.planItem-head {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-areas: "number" "body";
  grid-area: head;
  -webkit-border-after: 2px solid var(--color-yellow);
          border-block-end: 2px solid var(--color-yellow);
}

.plan-number {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-auto-flow: column;
  grid-area: number;
  -webkit-column-gap: 0.75rem;
     -moz-column-gap: 0.75rem;
          column-gap: 0.75rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.plan-number::after {
  -webkit-margin-before: -0.3125rem;
          margin-block-start: -0.3125rem;
  content: counter(number);
  color: var(--color-yellow);
  font-weight: var(--weight-semi-bold);
  font-size: 3.4375rem;
  line-height: 1;
  font-family: var(--montserrat);
}

.planItem-title {
  font-weight: var(--weight-semi-bold);
  font-size: 1.25rem;
  line-height: 1;
  font-family: var(--montserrat);
  text-transform: uppercase;
}

.planItem-body {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-areas: "img" "text" "price";
  row-gap: 1rem;
  grid-area: body;
  block-size: -webkit-fit-content;
  block-size: -moz-fit-content;
  block-size: fit-content;
  -webkit-padding-after: 1.5rem;
          padding-block-end: 1.5rem;
  -webkit-margin-before: 0.5rem;
          margin-block-start: 0.5rem;
}

.planItem-img {
  grid-area: img;
  inline-size: 12.5rem;
}

.planItem-price {
  display: grid;
  grid-auto-flow: column;
  grid-area: price;
  -webkit-column-gap: 0.3125rem;
     -moz-column-gap: 0.3125rem;
          column-gap: 0.3125rem;
  place-content: center;
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  border-radius: 10px;
  background-color: var(--color-yellow);
  padding-inline: 0.5em;
  block-size: -webkit-fit-content;
  block-size: -moz-fit-content;
  block-size: fit-content;
  min-block-size: 5rem;
  font-weight: var(--weight-bold);
  font-size: 1.5rem;
  text-align: center;
}

.planItem-priceNumber {
  font-weight: var(--weight-semi-bold);
  font-size: 3.4375rem;
  font-family: var(--montserrat);
}

.planItem-text {
  grid-area: text;
  font-weight: var(--weight-bold);
  font-size: 0.875rem;
  line-height: 1.4285714286;
}

.planItem-metaList {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
  grid-area: meta;
          flex-direction: column;
  gap: 1.25rem;
  -webkit-margin-before: 1.5rem;
          margin-block-start: 1.5rem;
}

.planItem-metaItem {
  display: inline-grid;
  border: 2px solid var(--color-black);
  background-color: var(--color-white);
  font-size: 0.875rem;
}

.planItem-metaTitle {
  background-color: var(--color-black);
  padding-inline: 0.5rem;
  padding-block: 0.125rem;
  color: var(--color-white);
  font-weight: var(--weight-bold);
}

.planItem-metaText {
  padding-inline: 0.5rem;
  padding-block: 0.125rem;
}

.planItem-footer {
  grid-area: footer;
  -webkit-margin-before: 2.25rem;
          margin-block-start: 2.25rem;
}

.planItem-footerHeading {
  border-radius: 5px;
  background-color: var(--color-yellow);
  padding-block: 0.75rem;
  font-weight: var(--weight-bold);
  font-size: 0.875rem;
  text-align: center;
}

.planItem-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  -webkit-margin-before: 1.875rem;
          margin-block-start: 1.875rem;
}

.planItem-cardImg {
  display: block;
  border-radius: 5px;
  inline-size: 100%;
  overflow: hidden;
}
.planItem-cardImg > img {
  aspect-ratio: 370/210;
  inline-size: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: scale 0.3s ease-in-out;
  transition: scale 0.3s ease-in-out;
}
.planItem-cardImg:focus-visible > img {
  scale: 1.08;
}

.planItem-cardMeta {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 0.5rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-margin-before: 0.75rem;
          margin-block-start: 0.75rem;
}

/* ============================================
** problemCases
=============================================== */
.problemCases {
  display: grid;
  gap: 2.75rem;
}

.problemCase {
  display: grid;
  position: relative;
  grid-template-columns: 1fr;
  -webkit-padding-after: 2.25rem;
  border-image-source: linear-gradient(0deg, var(--color-yellow) 0 100%);
  border-image-slice: fill 0;
  border-image-outset: 0 100vw;
          padding-block-end: 2.25rem;
}
.problemCase[data-case=promotion] .problemCase-img {
  inline-size: 12.75rem;
  -webkit-margin-before: 1.5625rem;
  margin-inline: auto;
          margin-block-start: 1.5625rem;
}
.problemCase[data-case=promotion] .problemCase-img > img {
  aspect-ratio: 204/129;
}
.problemCase[data-case=recruit] .problemCase-img {
  inline-size: 16.125rem;
  -webkit-margin-before: 0.75rem;
  margin-inline: auto;
          margin-block-start: 0.75rem;
}
.problemCase[data-case=recruit] .problemCase-img > img {
  aspect-ratio: 258/227;
}
.problemCase[data-case=youtube] .problemCase-img {
  inline-size: 16.1875rem;
  -webkit-margin-before: 1.0625rem;
  margin-inline: auto;
          margin-block-start: 1.0625rem;
}
.problemCase[data-case=youtube] .problemCase-img > img {
  aspect-ratio: 259/257;
}

.problemCase-body {
  display: contents;
}

.problemCase-title {
  position: relative;
  padding-block: 0.8125rem 1.25rem;
  max-inline-size: 50rem;
  -webkit-margin-before: -1.25rem;
          margin-block-start: -1.25rem;
  border-radius: 20px;
  background-color: var(--color-green);
  color: var(--color-white);
  font-weight: var(--weight-bold);
  font-size: 0.875rem;
  line-height: 1.4285714286;
  text-align: center;
}
.problemCase-title::after {
  position: absolute;
  margin-inline: auto;
  inset-block-end: 0.3125rem;
  inset-inline: 0;
  inline-size: 13px;
  block-size: 22px;
  -webkit-clip-path: polygon(50% 22px, 0% 0%, 13px 0%);
  translate: 0 100%;
          clip-path: polygon(50% 22px, 0% 0%, 13px 0%);
  background-color: inherit;
  content: "";
}

.problemCase-description {
  -webkit-margin-before: 2rem;
          margin-block-start: 2rem;
  color: var(--color-white);
  font-weight: var(--weight-bold);
  font-size: 1.375rem;
}

.problemCase-text {
  -webkit-box-ordinal-group: 5;
  -webkit-order: 4;
      -ms-flex-order: 4;
          order: 4;
  -webkit-margin-before: 1.25rem;
          margin-block-start: 1.25rem;
  font-weight: var(--weight-bold);
  font-size: 0.875rem;
  line-height: 1.4285714286;
}

.problemCase-img {
  z-index: 2;
  -webkit-box-ordinal-group: 4;
  -webkit-order: 3;
      -ms-flex-order: 3;
          order: 3;
}
.problemCase-img > img {
  inline-size: 100%;
  block-size: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.problemCase-button {
  -webkit-box-ordinal-group: 6;
  -webkit-order: 5;
      -ms-flex-order: 5;
          order: 5;
  inline-size: 100%;
  max-inline-size: 16.25rem;
  -webkit-margin-before: 1.4375rem;
  margin-inline: auto;
          margin-block-start: 1.4375rem;
}
.problemCase-button .primaryButton {
  -webkit-column-gap: 0.5rem;
     -moz-column-gap: 0.5rem;
          column-gap: 0.5rem;
  padding-inline: 0.8125rem;
  padding-block: 0.5625rem;
  font-weight: var(--weight-medium);
  font-size: 0.75rem;
}

/* ============================================
** flowList
=============================================== */
.flowList {
  display: none;
}

.flowItem {
  position: relative;
  border: 3px solid var(--color-black);
  border-radius: 20px;
  background-color: var(--color-white);
  padding-inline: 1rem;
  padding-block: 1rem 1.375rem;
}
.flowItem::before {
  grid-area: number;
  content: attr(data-number);
  font-weight: var(--weight-semi-bold);
  font-size: 1.875rem;
  font-family: var(--montserrat);
  text-align: center;
}
.flowItem::after {
  position: absolute;
  inset-block-start: 0.5rem;
  inset-inline-end: 0.75rem;
  inline-size: 15px;
  block-size: 13px;
  -webkit-clip-path: polygon(50% 13px, 0% 0%, 15px 0%);
  translate: 0 100%;
  rotate: -90deg;
          clip-path: polygon(50% 13px, 0% 0%, 15px 0%);
  background-color: var(--color-black);
  content: "";
}

.flowItem-heading {
  grid-area: heading;
  inline-size: 100%;
}

.flowItem-title {
  font-weight: var(--weight-bold);
  font-size: 1.125rem;
  line-height: 1.4666666667;
}

.flowItem-text {
  padding-block: 0.3125rem;
  -webkit-margin-before: 0.5rem;
          margin-block-start: 0.5rem;
  background-color: var(--color-yellow);
  font-weight: var(--weight-bold);
  font-size: 0.75rem;
  line-height: 1.4444444444;
  text-align: center;
}

.flowItem-description {
  grid-area: description;
  -webkit-margin-before: 0.5rem;
          margin-block-start: 0.5rem;
  font-weight: var(--weight-bold);
  font-size: 0.75rem;
  line-height: 1.5;
}

/* ============================================
** accordion
=============================================== */
/* Safariで表示されるデフォルトの三角形アイコンを消す */
summary::-webkit-details-marker {
  display: none;
}

.accordion {
  display: grid;
  gap: 0.375rem;
}

.accordion-item.is-opened .accordion-head::after {
  --rotate: 0;
}
.accordion-item.is-opened .accordion-content {
  -webkit-margin-before: 0.625rem;
          margin-block-start: 0.625rem;
}

.accordion-head {
  display: grid;
  grid-template-columns: 1fr auto;
  -webkit-column-gap: 1.25rem;
     -moz-column-gap: 1.25rem;
          column-gap: 1.25rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  padding-block: 0.9375rem;
  color: var(--color-white);
  font-weight: var(--weight-bold);
  font-size: 0.75rem;
  line-height: 1.5;
  -webkit-border-after: 1px solid var(--color-white);
          border-block-end: 1px solid var(--color-white);
}
.accordion-head::before, .accordion-head::after {
  --rotate: 90deg;
  --border-color: #fff;
  grid-row: 1/-1;
  grid-column: 2;
  border-radius: calc(infinity * 1px);
  background-color: var(--border-color);
  inline-size: 1rem;
  block-size: 3px;
  content: "";
  -webkit-transition: rotate 0.4s;
  transition: rotate 0.4s;
}
.accordion-head::after {
  rotate: var(--rotate);
}

.accordion-content {
  -webkit-margin-before: unset;
          margin-block-start: unset;
  border-radius: 5px;
  background-color: var(--color-white);
  -webkit-transition: -webkit-margin-before 0.4s;
  transition: -webkit-margin-before 0.4s;
  transition: margin-block-start 0.4s;
  transition: margin-block-start 0.4s, -webkit-margin-before 0.4s;
}

.accordion-contentInner {
  padding-inline: 1.125rem;
  padding-block: 1rem;
}

.accordion-contentText {
  font-weight: var(--weight-medium);
  font-size: 0.75rem;
  line-height: 1.5;
}

.accordion-button {
  max-inline-size: 13.75rem;
  -webkit-margin-before: 1.25rem;
  margin-inline: auto;
          margin-block-start: 1.25rem;
}
.accordion-button .primaryButton {
  margin-inline: unset;
  padding-inline: 1.75rem;
  padding-block: 0.6875rem;
  font-weight: var(--weight-medium);
  font-size: 0.875rem;
}

/* ============================================
** moovingBg
=============================================== */
.moovingBg {
  --size: 1rem;
  background-color: var(--color-dark-gray);
  padding-inline: var(--size);
  padding-block: calc(var(--size) + 0.1875rem);
  inline-size: 100%;
  block-size: clamp(12.5rem, 6.536259542rem + 25.4452926209vw, 18.75rem);
}

.moovingBg-video {
  position: relative;
  border-radius: 50px;
  inline-size: 100%;
  block-size: 100%;
  overflow: hidden;
}
.moovingBg-video::before {
  position: absolute;
  z-index: 1;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.7);
  content: "";
}
.moovingBg-video > video {
  grid-area: 1/-1;
  z-index: 1;
  inline-size: 100%;
  block-size: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.moovingBg-video > img {
  position: absolute;
  grid-area: 1/-1;
  z-index: 2;
  margin: auto;
  inset: 0;
  aspect-ratio: 312/77;
  inline-size: max(312px, 90%);
  -o-object-fit: contain;
  rotate: -17deg;
     object-fit: contain;
}

/* ============================================
** newsList
=============================================== */
.newsList {
  display: grid;
}

.newsItem {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-areas: "date" "heading";
  gap: 0.375rem;
  padding-block: 1rem;
  -webkit-border-after: 1px solid var(--color-white);
          border-block-end: 1px solid var(--color-white);
}

.newsItem-date {
  grid-area: date;
}
.newsItem-date > time {
  color: var(--color-yellow);
  font-weight: var(--weight-medium);
  font-size: 0.875rem;
  font-family: var(--montserrat);
}

.newsItem-title {
  grid-area: heading;
}
.newsItem-title > a {
  --font-color: var(--color-white);
  color: var(--color-white);
  color: color-mix(in sRGB, var(--font-color), #000 var(--darken, 0%));
  -webkit-transition: color 0.3s ease-in-out;
  transition: color 0.3s ease-in-out;
}
.newsItem-title > a:focus-visible {
  --darken: 30%;
}

.newsItem-heading {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  overflow: hidden;
  font-weight: var(--weight-bold);
  font-size: 1rem;
  -webkit-box-orient: vertical;
}

/* ============================================
** snsList
=============================================== */
.snsList {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-column-gap: 1.875rem;
     -moz-column-gap: 1.875rem;
          column-gap: 1.875rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  justify-self: end;
}

.snsItem > a {
  inline-size: 1.5625rem;
}
.snsItem > a > img {
  aspect-ratio: 25/25;
  inline-size: 100%;
}

/* ============================================
** breadcrumb
=============================================== */
.ly-breadcrumb-wrapper {
  position: relative;
  z-index: 100;
  -webkit-margin-before: 0.5rem;
          margin-block-start: 0.5rem;
  text-align: end;
}

.breadcrumb {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 0.375rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
.breadcrumb > span {
  font-weight: var(--weight-regular);
  font-size: 0.75rem;
}
.breadcrumb > span span.current-item.post-report {
  display: inline-block;
  vertical-align: middle;
  max-inline-size: 12em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.breadcrumb > span .taxonomy.works_category {
  pointer-events: none;
}

.breadcrumb-between {
  background-image: url("../images/common/other/breadcrumb-arrow.svg");
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  inline-size: 0.25rem;
  block-size: 0.4375rem;
}

/* ============================================
** form
=============================================== */
[class^=wpcf7-] {
  margin: unset;
  padding: unset;
}

.ly-form {
  margin-inline: auto;
  max-inline-size: 43.75rem;
}

.form {
  --border-color: #707070;
  --input-bg: #f5f5f5;
  display: grid;
  row-gap: 1.25rem;
}
.form input[type=checkbox] {
  position: relative;
  aspect-ratio: 1;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: 1px solid var(--color-black);
  background: var(--color-white);
  -webkit-transition-duration: 0.2s;
          transition-duration: 0.2s;
  -webkit-transition-property: background-color, border, color;
  transition-property: background-color, border, color;
}
.form input[type=checkbox]:checked {
  border-color: var(--color-yellow);
  background: var(--color-yellow);
}
.form input[type=checkbox]::before {
  display: block;
  position: absolute;
  opacity: 0;
  inset: 0;
  background-color: var(--color-white);
  inline-size: 100%;
  block-size: 100%;
  content: "";
  -webkit-mask-image: url("../images/common/icon/icon-checkbox.svg");
          mask-image: url("../images/common/icon/icon-checkbox.svg");
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}
.form input[type=checkbox]:checked::before {
  opacity: 1;
}

.form-subject {
  -webkit-padding-after: 1.875rem;
          padding-block-end: 1.875rem;
  -webkit-border-after: 2px solid var(--color-yellow);
          border-block-end: 2px solid var(--color-yellow);
}

.form-subjectCheckbox {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 1.5rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}

.form-subjectText {
  text-align: center;
}
.form-subjectText label {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.375rem;
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  cursor: pointer;
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
}
.form-subjectText input[type=checkbox] {
  inline-size: 0.875rem;
  block-size: 0.875rem;
}
.form-subjectText .wpcf7-list-item-label {
  font-weight: var(--weight-bold);
  font-size: 1rem;
}

.form-message {
  -webkit-margin-before: 0.625rem;
          margin-block-start: 0.625rem;
  font-weight: var(--weight-regular);
  font-size: 0.875rem;
  line-height: 1.7142857143;
}

.form-group {
  display: grid;
  grid-template-areas: "label" "input";
  row-gap: 0.625rem;
}
.form-group[data-group=name] {
  -webkit-margin-before: 1.25rem;
          margin-block-start: 1.25rem;
}
.form-group[data-group=checkbox], .form-group[data-group=textarea] {
  -webkit-margin-before: 0.625rem;
          margin-block-start: 0.625rem;
}
.form-group[data-group=checkbox] {
  row-gap: 1.25rem;
}
.form-group[data-group=checkbox] label {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.375rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
}
.form-group[data-group=checkbox] input[type=checkbox] {
  inline-size: 0.75rem;
  block-size: 0.75rem;
}
.form-group[data-group=checkbox] .wpcf7-list-item-label {
  cursor: pointer;
  font-weight: var(--weight-regular);
  font-size: 0.875rem;
}

.form-privacy {
  -webkit-margin-before: 1.25rem;
          margin-block-start: 1.25rem;
  text-align: center;
}
.form-privacy label {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.375rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
}
.form-privacy input[type=checkbox] {
  inline-size: 0.75rem;
  block-size: 0.75rem;
}
.form-privacy .wpcf7-list-item-label {
  cursor: pointer;
  font-weight: var(--weight-regular);
  font-size: 0.875rem;
}

.form-privacyLink {
  font-weight: var(--weight-medium);
  -webkit-border-after: 1px solid #707070;
          border-block-end: 1px solid #707070;
  -webkit-transition: color 0.3s ease-in-out;
  transition: color 0.3s ease-in-out;
}
.form-privacyLink:focus-visible {
  --color: var(--color-yellow);
  color: color-mix(in sRGB, var(--color), #fff var(--lighten, 0%));
}
.form-privacyLink:focus-visible:focus-visible {
  --lighten: 20%;
}

.form-label {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
}

.form-labelText {
  font-weight: var(--weight-medium);
  font-size: 1rem;
}

.form-required {
  font-size: 0.875rem;
}

.form-input,
.form-textarea {
  border: 1px solid var(--border-color);
  border-radius: 5px;
  background-color: var(--input-bg);
  padding-inline: 1em;
  padding-block: 0.5em;
  inline-size: 100%;
  font-size: 1rem;
}

.form-input {
  min-block-size: 3.125rem;
}

.form-genre {
  display: inline-grid;
  grid-template-columns: 1fr;
  gap: 0.5lh 1.875rem;
  -webkit-box-pack: start;
  -webkit-justify-content: start;
      -ms-flex-pack: start;
          justify-content: start;
}

.form-textarea {
  padding-block: 1em;
  min-block-size: 12.5rem;
}

.form-buttonWrapper {
  position: relative;
  inline-size: 100%;
  max-inline-size: 20rem;
  -webkit-margin-before: 0.75rem;
  margin-inline: auto;
          margin-block-start: 0.75rem;
  text-align: center;
}

.form-button {
  position: relative;
  z-index: 1;
  padding-inline: 1.5625rem;
  inline-size: 100%;
  min-block-size: 3.125rem;
}
.form-button::after {
  justify-self: end;
}
.form-button > input[type=submit] {
  position: absolute;
  z-index: 1;
  inset: 0;
  font-weight: var(--weight-medium);
  font-size: 0.875rem;
}

.wpcf7-spinner {
  display: none;
}

/* ============================================
** singleArticle
=============================================== */
.singleArticle-header {
  display: grid;
  grid-template-areas: "img" "title" "category";
}

.singleArticle-title {
  grid-area: title;
  -webkit-margin-before: 1.25rem;
          margin-block-start: 1.25rem;
  font-weight: var(--weight-bold);
  font-size: 1rem;
}

.singleArticle-img {
  grid-area: img;
  inline-size: 100%;
  overflow: hidden;
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.35);
  position: relative;
}
.singleArticle-img > img {
  aspect-ratio: 16/9;
  inline-size: 100%;
  -o-object-fit: cover;
  border-radius: 5px;
     object-fit: cover;
}

.singleArticle-img a {
  opacity: 1;
  transition: 0.3s ease;
}
.singleArticle-img a:hover {
  opacity: 0.7;
}

.singleArticle-categories {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 0.5rem;
}

.singleArticle-category {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 0.5rem;
}

.singleArticle-tag {
  font-weight: var(--weight-bold);
  font-size: 0.75rem;
}

.singleArticle-main {
  -webkit-margin-before: 2rem;
          margin-block-start: 2rem;
  -webkit-border-before: 1px solid var(--color-black);
          border-block-start: 1px solid var(--color-black);
}

.singleArticle-body {
  -webkit-margin-before: 2rem;
          margin-block-start: 2rem;
}
.singleArticle-body > div {
  font-weight: var(--weight-regular);
  font-size: 1rem;
  line-height: 1.8888888889;
  letter-spacing: 0.02em;
  text-align: justify;
}
.singleArticle-body h2 {
  padding-inline: 1.25rem;
  padding-block: 0.375rem;
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
  -webkit-margin-before: 2.5rem;
          margin-block-start: 2.5rem;
  border-radius: 5px;
  background-color: var(--color-black);
  color: var(--color-white);
  font-weight: var(--weight-bold);
  font-size: 1.25rem;
}
.singleArticle-body .singleArticle-h2 {
  padding-inline: 1.25rem;
  padding-block: 0.375rem;
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
  -webkit-margin-before: 2rem;
          margin-block-start: 2rem;
  border-radius: 5px;
  background-color: var(--color-black);
  color: var(--color-white);
  font-weight: var(--weight-bold);
  font-size: 0.9375rem;
}
.singleArticle-body h3 {
  -webkit-margin-before: 2.5rem;
          margin-block-start: 2.5rem;
  color: var(--blue);
  font-weight: var(--weight-medium);
  font-size: 1.125rem;
  line-height: 1.8888888889;
  letter-spacing: 0.02em;
}
.singleArticle-body p {
  -webkit-margin-before: 1.25rem;
          margin-block-start: 1.25rem;
  font-weight: var(--weight-regular);
  font-size: 0.875rem;
  line-height: 1.75;
}
.singleArticle-body .singleArticle-p {
  -webkit-margin-before: 1rem;
          margin-block-start: 1rem;
  font-weight: var(--weight-regular);
  font-size: 0.875rem;
  line-height: 1.75;
}
.singleArticle-body figure {
  inline-size: 100%;
  max-inline-size: 360px;
  -webkit-margin-before: 3.5rem;
          margin-block-start: 3.5rem;
}
.singleArticle-body figure img {
  aspect-ratio: 16/9;
  inline-size: 100% !important;
  -o-object-fit: cover;
     object-fit: cover;
}
.singleArticle-body figure figcaption {
  -webkit-margin-before: 0.625rem;
          margin-block-start: 0.625rem;
  font-weight: var(--weight-medium);
  font-size: 0.875rem;
  letter-spacing: 0.02em;
}
.singleArticle-body .aligncenter {
  margin-inline: auto;
}
.singleArticle-body .alignright {
  -webkit-margin-start: auto;
          margin-inline-start: auto;
}
.singleArticle-body .alignleft {
  -webkit-margin-end: auto;
          margin-inline-end: auto;
}
.singleArticle-body ul,
.singleArticle-body ol {
  padding-inline: 1.5rem;
  padding-block: 1.5rem;
  -webkit-margin-before: 3.5rem;
          margin-block-start: 3.5rem;
}
.singleArticle-body ul li,
.singleArticle-body ol li {
  display: inline-grid;
  grid-template-columns: auto 1fr;
  -webkit-column-gap: 0.5rem;
     -moz-column-gap: 0.5rem;
          column-gap: 0.5rem;
  padding-block: 0.625rem;
  font-weight: var(--weight-regular);
  font-size: 1rem;
  letter-spacing: 0.02em;
  -webkit-border-after: 1px dotted #ccc;
          border-block-end: 1px dotted #ccc;
}
.singleArticle-body ul {
  border-radius: 10px;
  background-color: var(--color-white);
  -webkit-box-shadow: 0 0 10px rgba(75, 137, 209, 0.3);
          box-shadow: 0 0 10px rgba(75, 137, 209, 0.3);
}
.singleArticle-body ul li::before {
  --size: 5px;
  margin-block: calc(1lh - var(--size) - 10px);
  border-radius: 50%;
  background-color: var(--blue);
  aspect-ratio: 1;
  inline-size: var(--size);
  content: "";
}
.singleArticle-body ol {
  counter-reset: number 0;
  background-color: #fafeff;
}
.singleArticle-body ol li {
  counter-increment: number 1;
}
.singleArticle-body ol li::before {
  content: counter(number, decimal-leading-zero) ".";
  color: var(--blue);
  font-weight: var(--weight-bold);
  font-size: 1.125rem;
  font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  letter-spacing: 0.1em;
}
.singleArticle-body pre {
  white-space: pre-wrap;
}
.singleArticle-body table {
  inline-size: 100%;
  -webkit-margin-before: 3.75rem;
          margin-block-start: 3.75rem;
}
.singleArticle-body table tr:nth-child(1) td:nth-child(1), .singleArticle-body table tr:nth-child(2) td:nth-child(1), .singleArticle-body table tr:nth-child(3) td:nth-child(1) {
  background-color: var(--blue);
  color: var(--color-white);
  -webkit-border-after: 1px solid var(--color-white);
          border-block-end: 1px solid var(--color-white);
}
.singleArticle-body table tr:nth-child(odd) td:nth-child(2), .singleArticle-body table tr:nth-child(odd) td:nth-child(3) {
  background-color: #fafeff;
  -webkit-border-after: 1px solid #ccc;
          border-block-end: 1px solid #ccc;
  -webkit-border-end: 1px solid #ccc;
          border-inline-end: 1px solid #ccc;
}
.singleArticle-body table tr:nth-child(odd) td:last-child {
  -webkit-border-end: unset;
          border-inline-end: unset;
}
.singleArticle-body table tr:nth-child(even) td:nth-child(2), .singleArticle-body table tr:nth-child(even) td:nth-child(3) {
  background-color: #fafafa;
  -webkit-border-after: 1px solid #ccc;
          border-block-end: 1px solid #ccc;
  -webkit-border-end: 1px solid #ccc;
          border-inline-end: 1px solid #ccc;
}
.singleArticle-body table tr:nth-child(even) td:last-child {
  -webkit-border-end: unset;
          border-inline-end: unset;
}
.singleArticle-body table tr td {
  padding-inline: 0.5em;
  padding-block: 0.75rem;
  inline-size: 33.3333333333% !important;
  font-size: 1rem;
  text-align: center;
}
.singleArticle-body a {
  display: inline-block;
  padding-inline: 1.25rem;
  padding-block: 0.375rem;
  inline-size: 100%;
  max-inline-size: 200px;
  -webkit-margin-before: 1.25rem;
          margin-block-start: 1.25rem;
  border-radius: calc(infinity * 1px);
  background-color: var(--blue);
  color: var(--color-white);
  font-weight: var(--weight-medium);
  font-size: 0.875rem;
  letter-spacing: 0.02em;
  text-align: center;
}
.singleArticle-body > * a {
  -webkit-margin-before: unset;
          margin-block-start: unset;
}

/* ============================================
** tag
=============================================== */
.tag {
  --border-color: #707070;
  border: 1px solid var(--border-color);
  border-radius: 5px;
  padding-inline: 0.5rem;
  padding-block: 0.25rem;
  font-weight: var(--weight-regular);
  font-size: 0.75rem;
  text-align: center;
}

/* ============================================
** searchForm
=============================================== */
.searchForm {
  display: grid;
  grid-template-areas: "button" "area";
  border-radius: 5px;
  overflow: clip;
}

.searchForm-area {
  --background: #ebe5b5;
  --padding: 1rem;
  display: grid;
  grid-template-columns: auto 1fr;
  grid-area: area;
  background-color: var(--background);
  padding-inline: max(24px, 5%);
  padding-block: 1rem;
}

.searchForm-block {
  display: grid;
  grid-template-columns: subgrid;
  grid-template-areas: "heading title";
  grid-column: span 2;
  -webkit-column-gap: 1.875rem;
     -moz-column-gap: 1.875rem;
          column-gap: 1.875rem;
  padding-block: var(--padding);
}
.searchForm-block:not(:last-of-type) {
  -webkit-border-after: 1px solid var(--color-white);
          border-block-end: 1px solid var(--color-white);
}

.searchForm-heading {
  grid-area: heading;
}

.searchForm-title {
  grid-area: title;
  font-weight: var(--weight-bold);
  font-size: 0.9375rem;
}

.searchForm-list {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 0.2lh 1em;
  font-size: 0.875rem;
  line-height: 1.875;
}

.searchForm-checkLabel {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.375rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
}

.searchForm-check {
  position: relative;
  aspect-ratio: 1;
  inline-size: 0.8125rem;
  block-size: 0.8125rem;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: 1px solid var(--color-black);
  background: var(--color-white);
  -webkit-transition-duration: 0.2s;
          transition-duration: 0.2s;
  -webkit-transition-property: background-color, border, color;
  transition-property: background-color, border, color;
}
.searchForm-check:checked {
  border-color: var(--color-yellow);
  background: var(--color-yellow);
}
.searchForm-check::before {
  display: block;
  position: absolute;
  opacity: 0;
  inset: 0;
  background-color: var(--color-white);
  inline-size: 100%;
  block-size: 100%;
  content: "";
  -webkit-mask-image: url("../images/common/icon/icon-checkbox.svg");
          mask-image: url("../images/common/icon/icon-checkbox.svg");
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-transition: opacity 0.2s;
  transition: opacity 0.2s;
}
.searchForm-check:checked::before {
  opacity: 1;
}

.searchForm-checkText {
  -webkit-margin-before: -0.125rem;
          margin-block-start: -0.125rem;
  font-weight: var(--weight-regular);
  font-size: 0.875rem;
}

.searchForm-toggle {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  grid-area: button;
  -webkit-column-gap: 0.75rem;
     -moz-column-gap: 0.75rem;
          column-gap: 0.75rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
  background-color: var(--color-white);
  padding-block: 1.25rem;
  inline-size: 100%;
  font-weight: var(--weight-bold);
  font-size: 0.875rem;
  line-height: 1.5;
  text-align: center;
}
.searchForm-toggle::before, .searchForm-toggle::after {
  --rotate: 90deg;
  --border-color: #000;
  grid-row: 1/-1;
  grid-column: 1;
  justify-self: end;
  background-color: var(--border-color);
  inline-size: 0.9375rem;
  block-size: 2px;
  content: "";
  -webkit-transition: rotate 0.4s;
  transition: rotate 0.4s;
}
.searchForm-toggle::after {
  rotate: var(--rotate);
}
.searchForm-toggle.is-opened::after {
  --rotate: 0deg;
}

.searchForm-buttonBlock {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
  grid-column: 1/-1;
          flex-wrap: wrap;
  gap: 1.25rem;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-margin-before: 2.5rem;
          margin-block-start: 2.5rem;
}

.searchForm-button {
  margin-inline: auto;
  border-radius: 5px;
  padding-inline: 0.9375rem;
  padding-block: 0.5625rem;
  inline-size: 100%;
  max-inline-size: 12.5rem;
  font-weight: var(--weight-medium);
  font-size: 0.75rem;
  text-align: center;
  -webkit-transition: background-color 0.3s ease-in-out;
  transition: background-color 0.3s ease-in-out;
}

.searchForm-buttonSubmit {
  --background: var(--color-yellow);
  background-color: color-mix(in sRGB, var(--background), #000 var(--darken, 0%));
}
.searchForm-buttonSubmit:focus-visible {
  --darken: 20%;
}

.searchForm-buttonClear {
  --background: var(--color-black);
  background-color: color-mix(in sRGB, var(--background), #fff var(--lighten, 0%));
  color: var(--color-white);
}
.searchForm-buttonClear:focus-visible {
  --lighten: 30%;
}

/* ============================================
** pagination
=============================================== */
.pagination-wrapper {
  -webkit-margin-before: 3.75rem;
          margin-block-start: 3.75rem;
}

.pagination > .nav-links {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 10px;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.pagination > .nav-links > .page-numbers {
  --number-background: transparent;
  display: grid;
  place-items: center;
  border: 1px solid var(--color-black);
  border-radius: 50%;
  background-color: var(--number-background);
  padding-inline: 0.5em;
  aspect-ratio: 1;
  inline-size: 2.1875rem;
  font-weight: var(--weight-bold);
  font-size: 0.875rem;
  font-family: var(--montserrat);
  text-align: center;
  -webkit-transition: color 0.3s, background-color 0.3s;
  transition: color 0.3s, background-color 0.3s;
}
.pagination > .nav-links > .page-numbers:focus-visible {
  --number-background: var(--color-black);
  color: var(--color-white);
}
.pagination > .nav-links > .page-numbers.current {
  --number-background: var(--color-black);
  color: var(--color-white);
}

/* ============================================
** swiper
=============================================== */
.swiper-container {
  position: relative;
}

.swiper-slide {
  block-size: auto;
}
.swiper-slide .flowItem {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
  -webkit-align-items: start;
      -ms-flex-align: start;
          align-items: start;
  min-block-size: 12.25rem;
}
.swiper-slide .flowItem[data-number="01"], .swiper-slide .flowItem[data-number="08"] {
  -webkit-padding-after: 1.875rem;
          padding-block-end: 1.875rem;
}
.swiper-slide .flowItem-description {
  -webkit-margin-before: auto;
          margin-block-start: auto;
}

.swiper-pagination {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  position: absolute;
  gap: 0.8125rem;
  inset-block-end: -1rem !important;
  inset-inline: 0;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-inline: auto;
}

.swiper-pagination-bullet {
  --pagination-color: var(--color-black);
  opacity: 1;
  margin-inline: unset !important;
  background-color: var(--pagination-color);
  aspect-ratio: 1;
  inline-size: 0.3125rem;
  block-size: 0.3125rem;
}
.swiper-pagination-bullet.swiper-pagination-bullet-active {
  --pagination-color: var(--color-yellow);
}

/* ============================================
** under
=============================================== */
.under {
  --icon-question: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIzNCIgaGVpZ2h0PSIzNCIgdmlld0JveD0iMCAwIDM0IDM0Ij4KICA8ZyBpZD0i44Kw44Or44O844OXXzIwOSIgZGF0YS1uYW1lPSLjgrDjg6vjg7zjg5cgMjA5IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtNzkgLTY1NCkiPgogICAgPGNpcmNsZSBpZD0i5qWV5YaG5b2iXzEwIiBkYXRhLW5hbWU9IualleWGhuW9oiAxMCIgY3g9IjE3IiBjeT0iMTciIHI9IjE3IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSg3OSA2NTQpIiBmaWxsPSIjZmZmIi8+CiAgICA8cGF0aCBpZD0i44OR44K5Xzc1NSIgZGF0YS1uYW1lPSLjg5HjgrkgNzU1IiBkPSJNNi42Ni02Ljk2aDMuODFjMC0zLjU0LDUuMTMtMy45OSw1LjEzLTguODgsMC0zLjQ1LTIuOTQtNS40Ni03LjM1LTUuNDZDNC41LTIxLjMsMS44LTE5LjkyLjEyLTE3LjY0bDIuOTEsMS44OWE1LjY1Nyw1LjY1NywwLDAsMSw0Ljg5LTIuMzFjMi4zMSwwLDMuNzUsMS4xNCwzLjc1LDIuODJDMTEuNjctMTIuMjQsNi42Ni0xMS40LDYuNjYtNi45NlpNOC41OC4yMWEyLjMxMiwyLjMxMiwwLDAsMCwyLjM3LTIuMzRBMi4yODgsMi4yODgsMCwwLDAsOC41OC00LjQ0YTIuMywyLjMsMCwwLDAtMi40LDIuMzFBMi4zMiwyLjMyLDAsMCwwLDguNTguMjFaIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSg4OCA2ODIpIiBmaWxsPSIjZWQ0ZTRhIi8+CiAgPC9nPgo8L3N2Zz4K);
  --under-translate: 0 100%;
  --under-opacity: 0;

  position: fixed;
  z-index: 9999;
  inset-block-end: 0.8rem;
  inset-inline: 0;
  display: block;
  visibility: visible;
  inline-size: min(600px,calc(100% - 40px));
  margin-inline: auto;
  background-color: #ED4E4A;
  border-radius: calc(infinity * 1px);
  translate: var(--under-translate);
  opacity: var(--under-opacity);
  transition: opacity 0.3s ease-in-out, translate 0.3s ease-in-out;


  &.upMove {
    --under-opacity: 1;
    --under-translate: 0;
  }
}

.under-item {
  display: grid;
  align-items: center;
  justify-content: center;
  min-block-size: max(3.15rem, 7.85dvw);
  padding: 0.2em;
}

.under-link {
  display: inline-grid;
  grid-template-columns: auto max-content;
  align-items: center;
  inline-size: 100%;
  block-size: 100%;
  column-gap: 8px;

  &::before {
    content: "";
    inline-size: 34px;
    aspect-ratio: 1;
    background-image: var(--icon-question);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
  }
}
.under-text {
  color: var(--color-white);
  font-size: max(1rem, 3dvw);
  font-weight: var(--weight-bold);
}
@media screen and (min-width: 768px) {
  .under {
    display: none;
    visibility: hidden;
  }
}


/* ============================================ */
/* ============================================
** common サイト全体の共通
=============================================== */
.wrapper {
  min-block-size: 100svh;
  overflow-x: clip;
}

.container {
  -webkit-box-sizing: initial;
          box-sizing: initial;
  margin-inline: auto;
  padding-inline: 20px;
  max-inline-size: 1180px;
}

/* ============================================
** header
=============================================== */
.header {
  --fixed-background: transparent;
  position: fixed;
  z-index: 9999;
  margin-inline: auto;
  inset-block-start: 0;
  inset-inline: 0;
  background-color: var(--fixed-background);
  -webkit-transition: background-color 0.3s ease-in-out;
  transition: background-color 0.3s ease-in-out;
}
.header.is-fixed, .header.is-active {
  --fixed-background: var(--color-black);
}

.page .header,
.archive .header,
.single .header,
.error404 .header {
  background-color: var(--color-black);
}

.header__inner {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-areas: "logo menu";
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  block-size: 4.375rem;
}

.header__logo {
  grid-area: logo;
  aspect-ratio: 120/29;
  inline-size: 7.5rem;
}
.header__logo > a {
  display: block;
  inline-size: 100%;
}

/* ============================================
** main
=============================================== */
.page .main,
.archive .main,
.single .main,
.error404 .main {
  background-color: var(--color-yellow);
  min-block-size: 100svh;
}

/* ============================================
** footer
=============================================== */
.ly-footer {
  padding-block: 2.625rem 1.5rem;
}

.footer {
  position: relative;
  z-index: 1;
  background-image: url("../../assets/images/common/other/footer-bg-sp.webp");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
.footer::before {
  position: absolute;
  z-index: -1;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.75);
  inline-size: 100%;
  block-size: 100%;
  content: "";
}

.footer__contents {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-areas: "contact" "sns" "logo" "message" "menu" "copy";
}

.footer__contact {
  grid-area: contact;
}

.footer__contactText {
  color: var(--color-yellow);
  font-weight: var(--weight-bold);
  font-size: 0.75rem;
  text-align: center;
}

.footer__contactButton {
  max-inline-size: 19.375rem;
  -webkit-margin-before: 0.8125rem;
  margin-inline: auto;
          margin-block-start: 0.8125rem;
}
.footer__contactButton .primaryButton {
  padding-inline: 1.125rem;
  padding-block: 0.9375rem;
  font-weight: var(--weight-bold);
  font-size: 0.9375rem;
}

.footer__left {
  display: contents;
}

.footer__logo {
  grid-area: logo;
  inline-size: 12rem;
  -webkit-margin-before: 2.6875rem;
          margin-block-start: 2.6875rem;
}
.footer__logo > img {
  aspect-ratio: 239/59;
  inline-size: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.footer__message {
  display: grid;
  row-gap: 1.125rem;
  grid-area: message;
  -webkit-margin-before: 1.125rem;
          margin-block-start: 1.125rem;
}

.footer__messageText {
  color: var(--color-white);
  font-weight: var(--weight-regular);
  font-size: 0.625rem;
  line-height: 1.8;
}

.footer__address {
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
  color: var(--color-white);
  font-weight: var(--weight-regular);
  font-size: 0.625rem;
  line-height: 1.8;
  text-align: center;
}

.footer__address-text {
  text-align: left;
  margin-left: 3em;
}

.footer__copyright {
  display: inline-block;
  grid-area: copy;
  -webkit-margin-before: 1.625rem;
          margin-block-start: 1.625rem;
  color: var(--color-white);
  font-weight: var(--weight-medium);
  font-size: 0.625rem;
  font-family: var(--montserrat);
  letter-spacing: 0.1em;
  text-align: center;
}

.footer__right {
  display: contents;
}
.footer__right .snsList {
  grid-area: sns;
  justify-self: center;
  -webkit-margin-before: 2.25rem;
          margin-block-start: 2.25rem;
}

.footer__menu {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
  row-gap: 0.5em;
  grid-area: menu;
          flex-wrap: wrap;
  max-inline-size: 24.375rem;
  -webkit-padding-start: 0.9375rem;
          padding-inline-start: 0.9375rem;
  -webkit-margin-before: 2.1875rem;
          margin-block-start: 2.1875rem;
  -webkit-margin-start: 1.5rem;
          margin-inline-start: 1.5rem;
  -webkit-border-start: 1px solid var(--color-white);
          border-inline-start: 1px solid var(--color-white);
}
.footer__menu::before {
  position: absolute;
  translate: -100% 50%;
  rotate: 90deg;
  inset-block-start: 0;
  inset-inline-start: 0.3125rem;
  content: "menu";
  color: var(--color-white);
  font-weight: var(--weight-regular);
  font-size: 0.625rem;
  font-family: var(--montserrat);
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.footer__menuLink {
  -webkit-box-flex: 1;
  -webkit-flex-grow: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  -webkit-flex-basis: 45%;
      -ms-flex-preferred-size: 45%;
          flex-basis: 45%;
  color: var(--color-white);
  font-weight: var(--weight-regular);
  font-size: 0.625rem;
}

/* ============================================ */
/* ============================================
** front
=============================================== */
.firstView {
  position: relative;
  inline-size: 100lvw;
  block-size: 100svh;
  max-block-size: 37.5rem;
  -webkit-padding-before: calc(var(--header-block-size));
          padding-block-start: calc(var(--header-block-size));
  color: var(--color-white);
}
/* .firstView::before {
  position: absolute;
  z-index: -1;
  inset: 0;
  background: url("../images/pages/front/fv/fv-video.webp");
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  inline-size: 100%;
  block-size: 100%;
  pointer-events: none;
  content: "";
} */

.firstView__bg {
  position: absolute;
  z-index: -2;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.firstView__bg::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.4);
  z-index: 0;
}

.firstView__bg video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.firstView__inner {
  display: grid;
  padding-inline: 20px;
  block-size: 100%;
}

.firstView__contents {
  display: grid;
  position: relative;
}

.firstView__message {
  -webkit-align-self: end;
      -ms-flex-item-align: end;
          align-self: end;
  text-align: center;
}

.firstView__title {
  white-space: nowrap;
}

.firstView__titleText {
  display: grid;
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
  max-inline-size: 47.6875rem;
  -webkit-padding-start: 0.625rem;
  margin-inline: auto;
          padding-inline-start: 0.625rem;
  text-align: start;
}
.firstView__titleText > span:nth-child(1) {
  font-weight: var(--weight-bold);
  font-size: clamp(3.125rem, 1.826584507rem + 5.5399061033vw, 6.8125rem);
  line-height: 1.4403669725;
}
.firstView__titleText > span:nth-child(2) {
  font-weight: var(--weight-medium);
  font-size: clamp(1.125rem, 0.6408450704rem + 2.0657276995vw, 2.5rem);
  line-height: 1.5;
  letter-spacing: -0.06em;
}
.firstView__titleText > span:nth-child(3) {
  padding-inline: 0.9375rem;
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
  -webkit-margin-before: 0.3125rem;
          margin-block-start: 0.3125rem;
  background-color: var(--color-white);
  color: var(--color-black);
  font-weight: 900;
  font-size: clamp(1.25rem, 0.6998239437rem + 2.3474178404vw, 2.8125rem);
  line-height: 1.3333333333;
  letter-spacing: -0.06em;
}
.firstView__titleText > span:nth-child(4) {
  font-weight: 900;
  font-size: clamp(1.8125rem, 1.0642605634rem + 3.1924882629vw, 3.9375rem);
  line-height: 1.3492063492;
  letter-spacing: -0.07em;
}

.firstView__titleLarge {
  text-align: center;
}
.firstView__titleLarge > span {
  font-weight: 900;
  font-size: clamp(3.9375rem, 2.463028169rem + 6.2910798122vw, 8.125rem);
  line-height: 1.2923076923;
  text-shadow: 0 0 20px rgba(0, 0, 0, 0.6);
}

.firstView__button {
  position: absolute;
  justify-self: center;
  z-index: 2;
  inset-block-end: -3.75rem;
  max-inline-size: 12.5rem;
  -webkit-margin-before: 1.25rem;
          margin-block-start: 1.25rem;
}
.firstView__button .primaryButton {
  padding-inline: 0.9375rem;
  padding-block: 0.625rem;
  font-weight: var(--weight-medium);
  font-size: 0.75rem;
}

.firstView__download {
  -webkit-align-self: end;
      -ms-flex-item-align: end;
          align-self: end;
  margin-inline: -20px;
  background-color: rgba(0, 0, 0, 0.5);
}

.firstView__downloadButton {
  display: grid;
  padding-block: 0.9375rem;
  color: var(--color-white);
  text-align: center;
}

.firstView__downloadButtonText {
  display: inline-grid;
  grid-template-columns: auto 1fr;
  -webkit-column-gap: 0.3125rem;
     -moz-column-gap: 0.3125rem;
          column-gap: 0.3125rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
  -webkit-padding-after: 0.25rem;
  margin-inline: auto;
          padding-block-end: 0.25rem;
  font-weight: var(--weight-medium);
  font-size: 0.875rem;
  -webkit-border-after: 1px solid var(--color-white);
          border-block-end: 1px solid var(--color-white);
}
.firstView__downloadButtonText::after {
  justify-self: start;
  background-image: url("../images/common/other/arrow-w.svg");
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  aspect-ratio: 10/9;
  inline-size: 0.625rem;
  content: "";
  -webkit-transition: translate 0.3s ease-in-out;
  transition: translate 0.3s ease-in-out;
}

.firstView__downloadText {
  display: block;
  -webkit-padding-before: 0.25rem;
          padding-block-start: 0.25rem;
  font-weight: var(--weight-regular);
  font-size: 0.75rem;
  font-family: var(--montserrat);
  letter-spacing: 0.2em;
  text-transform: capitalize;
}

/*
** works
*/
.ly-works {
  padding-block: 5.625rem 2.375rem;
}

.works {
  background-color: var(--color-yellow);
}

.works__heading {
  position: relative;
  z-index: 2;
}

.works__contents {
  position: relative;
  z-index: 1;
}
.works__contents::before {
  position: absolute;
  z-index: -1;
  inset-block-start: -13.125rem;
  inset-inline-end: -4.5rem;
  background-image: url("../images/common/other/face-bg.webp");
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  aspect-ratio: 357/305;
  inline-size: 22.3125rem;
  pointer-events: none;
  content: "";
}

.works__items {
  row-gap: 0.625rem;
  -webkit-margin-before: 1.25rem;
          margin-block-start: 1.25rem;
  -webkit-margin-end: -1.25rem;
          margin-inline-end: -1.25rem;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.works__items ::-webkit-scrollbar {
  display: none;
}
.works__items .worksItem {
  --background: rgb(255 255 255 / 30%);
  border-image-source: linear-gradient(0deg, var(--background) 0 100%);
  border-image-slice: fill 0;
  border-image-outset: 0 100vw;
  padding-block: 1.5rem;
  scroll-snap-align: start;
}
.works__items .worksItem-list {
  grid-template-columns: unset;
  grid-auto-columns: 20rem;
  grid-auto-flow: column;
  gap: 0;
  overflow-x: auto;
  -webkit-scroll-snap-type: x mandatory;
      -ms-scroll-snap-type: x mandatory;
          scroll-snap-type: x mandatory;
}
.works__items .worksItem-item {
  -webkit-padding-end: 1.25rem;
          padding-inline-end: 1.25rem;
  scroll-snap-align: start;
  scroll-snap-stop: always;
}

.works__button {
  max-inline-size: 12.5rem;
  -webkit-margin-before: 1.6875rem;
  margin-inline: auto;
          margin-block-start: 1.6875rem;
}
.works__button .primaryButton {
  padding-inline: 0.9375rem;
  padding-block: 0.5625rem;
  font-weight: var(--weight-medium);
  font-size: 0.75rem;
}

/*
** youtube
*/
.ly-youtube {
  padding-block: 2.25rem;
}

.youtube {
  background-color: var(--color-dark-gray);
}

.youtube__contents {
  display: grid;
  place-items: center;
}

.youtube__icon {
  inline-size: 3.75rem;
}
.youtube__icon > img {
  aspect-ratio: 60/41;
  inline-size: 100%;
  block-size: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.youtube__heading {
  position: relative;
  -webkit-margin-before: 1.4375rem;
          margin-block-start: 1.4375rem;
  color: var(--color-white);
  font-size: 1.5625rem;
  line-height: 1.52;
  text-align: center;
}
.youtube__heading > span {
  font-size: 2.1875rem;
  line-height: 0.9473684211;
}
.youtube__heading::before, .youtube__heading::after {
  position: absolute;
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  aspect-ratio: 32/134;
  inline-size: 2rem;
  content: "";
}
.youtube__heading::before {
  inset-block-start: -1.75rem;
  inset-inline-start: 0.1875rem;
  background-image: url("../images/common/other/ten.svg");
}
.youtube__heading::after {
  inset-block-start: -1.875rem;
  inset-inline-end: 0.25rem;
  background-image: url("../images/common/other/ten-reverse.svg");
}

.youtube__text {
  -webkit-margin-before: 1.5rem;
          margin-block-start: 1.5rem;
  color: var(--color-white);
  font-weight: var(--weight-bold);
  font-size: 0.75rem;
  line-height: 2;
}

.youtube__price {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-column-gap: 2.5625rem;
     -moz-column-gap: 2.5625rem;
          column-gap: 2.5625rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-block: 0.75rem;
  inline-size: 100%;
  max-inline-size: 57.5rem;
  -webkit-margin-before: 1.875rem;
  margin-inline: auto;
          margin-block-start: 1.875rem;
  border-radius: 20px;
  background-color: var(--color-yellow);
}

.youtube__priceText {
  font-weight: var(--weight-bold);
  font-size: 1.25rem;
  line-height: 1.75;
  text-align: center;
}

.youtube__priceNumber {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  font-weight: var(--weight-semi-bold);
  font-size: 3.4375rem;
  font-family: var(--montserrat);
}
.youtube__priceNumber > span:nth-of-type(1) {
  display: grid;
  place-items: center;
  place-self: center;
  aspect-ratio: 1;
  inline-size: 2.625rem;
  -webkit-margin-end: 0.5rem;
          margin-inline-end: 0.5rem;
  border-radius: 50%;
  background-color: var(--color-black);
  content: "月額";
  color: var(--color-white);
  font-weight: var(--bold);
  font-size: 0.75rem;
  font-family: var(--noto-sans-jp);
}
.youtube__priceNumber > span:nth-of-type(2) {
  font-weight: var(--weight-bold);
  font-size: 1.5rem;
  font-family: var(--noto-sans-jp);
}

.youtube__button {
  max-inline-size: 12.5rem;
  -webkit-margin-before: 1.375rem;
  margin-inline: auto;
          margin-block-start: 1.375rem;
}
.youtube__button .primaryButton {
  padding-inline: 0.9375rem;
  padding-block: 0.5625rem;
  font-weight: var(--weight-medium);
  font-size: 0.75rem;
}

/*
** plan（料金プラン）
*/
.ly-plan {
  padding-block: 2.6875rem;
}

.plan {
  background-color: var(--color-gray);
}

.plan__contents {
  margin-inline: auto;
  max-inline-size: 37.5rem;
}

.plan__cards {
  -webkit-margin-before: 3.0625rem;
          margin-block-start: 3.0625rem;
}
.plan__cards .planCard {
  --margin-block-start: 5.8125rem;
}

.plan__footer {
  -webkit-margin-before: 1.6875rem;
          margin-block-start: 1.6875rem;
}

.plan__footerText {
  font-weight: var(--weight-bold);
  font-size: 0.875rem;
  text-align: center;
}

.plan__button {
  max-inline-size: 12.5rem;
  -webkit-margin-before: 0.625rem;
  margin-inline: auto;
          margin-block-start: 0.625rem;
}
.plan__button .primaryButton {
  padding-inline: 0.9375rem;
  padding-block: 0.5625rem;
  font-weight: var(--weight-medium);
  font-size: 0.75rem;
}

/*
** problem（悩みはありませんか？）
*/
.ly-problem {
  -webkit-margin-before: 1.125rem;
          margin-block-start: 1.125rem;
}

.problem__inner {
  position: relative;
}

.problem__heading {
  display: grid;
}
.problem__heading > span {
  font-weight: 900;
}
.problem__heading > span:nth-child(1) {
  font-size: 2.5rem;
}
.problem__heading > span:nth-child(2) {
  font-size: 1.875rem;
}

.problem__contents {
  max-inline-size: 37.5rem;
  -webkit-margin-before: 2.75rem;
  margin-inline: auto;
          margin-block-start: 2.75rem;
}

/*
** flow（動画制作の流れ）
*/
.ly-flow {
  padding-block: 2.625rem 2.5rem;
}

.flow {
  background-color: var(--color-gray);
}

.flow__line {
  position: relative;
  z-index: 0;
  pointer-events: none;
}
.flow__line > svg {
  position: absolute;
  z-index: -1;
  inset-block-start: -5.5625rem;
  inset-inline-start: clamp(3.5625rem, -10.929389313rem + 61.8320610687vw, 18.75rem);
  aspect-ratio: 293/530;
  inline-size: 18.3125rem;
  stroke-width: 22px;
}

.flow__contents {
  position: relative;
  max-inline-size: 37.5rem;
  -webkit-margin-before: 1.875rem;
  margin-inline: auto;
          margin-block-start: 1.875rem;
}
.flow__contents::before {
  inset-block-start: 6.875rem;
  inset-inline-start: 29.8125rem;
  background-image: url("../images/pages/front/flow/flow-img01.webp");
  aspect-ratio: 184/143;
  inline-size: 11.5rem;
}
.flow__contents::after {
  inset-block-start: 37.8125rem;
  inset-inline-start: 34.875rem;
  background-image: url("../images/pages/front/flow/flow-img03.webp");
  aspect-ratio: 90/187;
  inline-size: 5.625rem;
}

.flow__contactButton {
  -webkit-margin-before: 3rem;
          margin-block-start: 3rem;
}

.flow__listWrapper {
  position: relative;
}

.flow__message {
  position: relative;
  z-index: 1;
  -webkit-margin-before: 1.875rem;
          margin-block-start: 1.875rem;
  font-weight: var(--weight-bold);
  font-size: 0.75rem;
  line-height: 1.6666666667;
}

/*
** faq（よくあるご質問）
*/
.ly-faq {
  padding-block: 1.5625rem 2.1875rem;
}

.faq {
  background-color: var(--color-dark-gray);
}

.faq__heading {
  grid-area: heading;
  block-size: -webkit-fit-content;
  block-size: -moz-fit-content;
  block-size: fit-content;
}

.faq__contents {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-areas: "heading" "accordion";
  gap: 1rem;
}

.faq__accordion {
  grid-area: accordion;
  margin-inline: auto;
  max-inline-size: 37.5rem;
}

/*
** news（お知らせ）
*/
.ly-news {
  padding-block: 1.6875rem 2.75rem;
}

.news {
  background-color: var(--color-dark-gray);
}

.news__contents {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-areas: "head" "body";
}

.news__head {
  display: contents;
}

.news__button {
  max-inline-size: 12.5rem;
  -webkit-margin-before: 2rem;
  margin-inline: auto;
          margin-block-start: 2rem;
}
.news__button .primaryButton {
  padding-inline: 0.9375rem;
  padding-block: 0.5625rem;
  font-weight: var(--weight-medium);
  font-size: 0.75rem;
}

.news__body {
  grid-area: body;
  max-inline-size: 37.5rem;
  -webkit-padding-before: 0.625rem;
  margin-inline: auto;
          padding-block-start: 0.625rem;
}

/* ============================================
** works
=============================================== */
.ly-pageWorks {
  -webkit-padding-after: 3.75rem;
          padding-block-end: 3.75rem;
  -webkit-margin-before: 2.5rem;
          margin-block-start: 2.5rem;
}

.pageWorks__items {
  max-inline-size: 28.125rem;
  -webkit-margin-before: 5rem;
  margin-inline: auto;
          margin-block-start: 5rem;
}

.pageWorks__noPost {
  -webkit-margin-before: 5rem;
          margin-block-start: 5rem;
  font-size: 0.875rem;
}

/* ============================================
** plan
=============================================== */
.ly-pagePlanCard {
  -webkit-margin-before: 2.5rem;
          margin-block-start: 2.5rem;
  background-color: var(--color-gray);
}

.pagePlanCard__contents {
  margin-inline: auto;
  padding-block: 5rem;
  max-inline-size: 37.5rem;
}

/*
** planDetails
*/
.ly-pagePlanDetails {
  padding-block: 2.5rem 3.75rem;
}

.pagePlanDetails__heading {
  font-weight: var(--weight-bold);
  font-size: clamp(1.125rem, 0.6408450704rem + 2.0657276995vw, 2.5rem);
  line-height: 1.25;
  text-align: center;
}

.pagePlanDetails__contents {
  -webkit-margin-before: 2.1875rem;
          margin-block-start: 2.1875rem;
}

/* ============================================
** contact
=============================================== */
.ly-contact {
  -webkit-padding-after: 3.75rem;
          padding-block-end: 3.75rem;
  -webkit-margin-before: 2.5rem;
          margin-block-start: 2.5rem;
}

.contact__contents {
  position: relative;
  z-index: 1;
  margin-inline: auto;
  border-radius: 5px;
  background-color: var(--color-white);
  padding-inline: min(20px, 50%);
  padding-block: 2.5rem;
  max-inline-size: 37.5rem;
}
.contact__contents::before {
  position: absolute;
  z-index: -1;
  inset-block-start: -13.75rem;
  inset-inline-end: -3.4375rem;
  background-image: url("../images/common/other/face-bg.webp");
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  aspect-ratio: 764/654;
  inline-size: clamp(16.5rem, 4.572519084rem + 50.8905852417vw, 29rem);
  pointer-events: none;
  content: "";
}

/* ============================================
** single
=============================================== */
.ly-pageSingle {
  margin-block: 2.5rem 3.75rem;
}

.pageSingle__contents {
  position: relative;
  border-radius: 5px;
  background-color: var(--color-white);
  padding-inline: max(1.5rem, 5%);
  padding-block: 3.125rem;
}
.pageSingle__contents::before {
  position: absolute;
  inset-block-start: 0.5rem;
  inset-inline-end: max(1.5rem, 5%);
  content: "moving WORKS";
  font-weight: var(--weight-medium);
  font-size: 0.625rem;
  font-family: var(--montserrat);
  letter-spacing: 0.2em;
}

.pageSingle__main {
  margin-inline: auto;
  max-inline-size: 52.5rem;
}

.singleReturnButton {
  max-inline-size: 12.5rem;
  -webkit-padding-after: 1.875rem;
          padding-block-end: 1.875rem;
  -webkit-margin-before: 1.875rem;
  margin-inline: auto;
          margin-block-start: 1.875rem;
}
.singleReturnButton .primaryButton {
  padding-inline: 0.9375rem;
  padding-block: 0.5625rem;
  font-weight: var(--weight-medium);
  font-size: 0.75rem;
}

/* ============================================
** privacy
=============================================== */
.ly-privacy {
  -webkit-padding-after: 3.75rem;
          padding-block-end: 3.75rem;
  -webkit-margin-before: 2.5rem;
          margin-block-start: 2.5rem;
}

.privacy__contents {
  display: grid;
  position: relative;
  row-gap: 3.125rem;
  z-index: 1;
  margin-inline: auto;
  border-radius: 5px;
  background-color: var(--color-white);
  padding-inline: min(20px, 50%);
  padding-block: 2.5rem;
  max-inline-size: 37.5rem;
}
.privacy__contents::before {
  position: absolute;
  z-index: -1;
  inset-block-start: -13.75rem;
  inset-inline-end: -3.4375rem;
  background-image: url("../images/common/other/face-bg.webp");
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  aspect-ratio: 764/654;
  inline-size: clamp(16.5rem, 4.572519084rem + 50.8905852417vw, 29rem);
  pointer-events: none;
  content: "";
}

.privacy__block {
  --border-color: #707070;
}

.privacy__title {
  -webkit-padding-after: 1rem;
          padding-block-end: 1rem;
  font-weight: var(--weight-bold);
  font-size: 1.0625rem;
  -webkit-border-after: 1px solid var(--border-color);
          border-block-end: 1px solid var(--border-color);
}

.privacy__text {
  -webkit-margin-before: 1.25rem;
          margin-block-start: 1.25rem;
  font-size: 0.875rem;
  line-height: 1.6;
}

.privacy__item {
  -webkit-margin-before: 1.875rem;
          margin-block-start: 1.875rem;
}

.privacy__itemTitle {
  font-weight: var(--weight-bold);
  font-size: 0.875rem;
  line-height: 1.6;
}

.privacy__itemText {
  -webkit-padding-start: 1em;
          padding-inline-start: 1em;
  font-size: 0.875rem;
  line-height: 1.6;
}

.privacy__right {
  -webkit-margin-before: 3.125rem;
          margin-block-start: 3.125rem;
  font-size: 0.875rem;
  line-height: 1.6;
  text-align: end;
}

.privacy__info {
  display: grid;
  row-gap: 1.625rem;
  -webkit-margin-before: 0.625rem;
          margin-block-start: 0.625rem;
}

.privacy__infoItem {
  text-align: center;
}

.privacy__infoLead {
  font-weight: var(--weight-bold);
  font-size: 0.875rem;
  line-height: 1.6;
}

.privacy__infoText {
  font-size: 0.875rem;
  line-height: 1.6;
}

.privacy__button {
  max-inline-size: 12.5rem;
  -webkit-margin-before: 0.625rem;
  margin-inline: auto;
          margin-block-start: 0.625rem;
}
.privacy__button .primaryButton {
  padding-inline: 0.9375rem;
  padding-block: 0.5625rem;
  font-weight: var(--weight-medium);
  font-size: 0.75rem;
}

/* ============================================
** thanks
=============================================== */
.ly-thanks {
  -webkit-padding-after: 3.75rem;
          padding-block-end: 3.75rem;
  -webkit-margin-before: 2.5rem;
          margin-block-start: 2.5rem;
}

.thanks__contents {
  display: grid;
  position: relative;
  row-gap: 2rem;
  place-items: center;
  z-index: 1;
  margin-inline: auto;
  border-radius: 5px;
  background-color: var(--color-white);
  padding-inline: min(20px, 50%);
  padding-block: 2.5rem;
  max-inline-size: 37.5rem;
}
.thanks__contents::before {
  position: absolute;
  z-index: -1;
  inset-block-start: -13.75rem;
  inset-inline-end: -3.4375rem;
  background-image: url("../images/common/other/face-bg.webp");
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  aspect-ratio: 764/654;
  inline-size: clamp(16.5rem, 4.572519084rem + 50.8905852417vw, 29rem);
  pointer-events: none;
  content: "";
}

.thanks__lead {
  font-weight: var(--weight-bold);
  font-size: 1.125rem;
  line-height: 1.8;
  text-align: center;
}

.thanks__text {
  font-size: 0.875rem;
  line-height: 1.8;
}

.thanks__message {
  border: 1px solid #707070;
  border-radius: 10px;
  padding-inline: max(0.75rem, 3.5%);
  padding-block: 2rem;
  inline-size: 100%;
  max-inline-size: 50rem;
}

.thanks__messageTitle {
  font-weight: var(--weight-bold);
  font-size: 1rem;
  text-align: center;
}

.thanks__messageText {
  -webkit-margin-before: 1.25rem;
          margin-block-start: 1.25rem;
  font-size: 0.875rem;
}

/* ============================================ */
/* ============================================
** helper
=============================================== */
[data-device=sp] {
  display: block;
}

[data-device=tab] {
  display: block;
}

[data-device=pc] {
  display: block;
}

[data-device=pc-only] {
  display: block;
}

.visually-hidden {
  display: block !important;
  position: fixed !important;
  visibility: visible !important;
  opacity: 0 !important;
  contain: strict !important;
  margin: 0 !important;
  inset-block-start: 0 !important;
  inset-inline-start: 0 !important;
  border: none !important;
  padding: 0 !important;
  inline-size: 4px !important;
  block-size: 4px !important;
  pointer-events: none !important;
}

/* 分割テキストをテキストリーダーに読んでもらうクラス */
.character:not(:lang(ja)) {
  display: none;
}

.alternative:lang(ja) {
  display: block !important;
  position: fixed !important;
  opacity: 0 !important;
  contain: strict !important;
  inset: 0 !important;
  inline-size: 4px !important;
  block-size: 4px !important;
  pointer-events: none !important;
}

@media (min-width: 576px){
  .worksItem-list {
    grid-template-columns: repeat(2, 1fr);
  }
  .planItem-cards {
    grid-template-columns: repeat(2, 1fr);
  }
  .pageWorks__items {
    margin-inline: unset;
    max-inline-size: unset;
  }
}

@media (min-width: 768px){
  html {
    font-size: 1.3008130081vw;
  }
  .primaryHeading-text {
    -webkit-column-gap: 0.75rem;
       -moz-column-gap: 0.75rem;
            column-gap: 0.75rem;
    -webkit-padding-start: 2.5rem;
            padding-inline-start: 2.5rem;
    -webkit-margin-before: 0.625rem;
            margin-block-start: 0.625rem;
  }
  .primaryHeading-text::before {
    inline-size: 4.375rem;
  }
  .page .ly-lowerHeading .primaryHeading:not(:has(.primaryHeading-text)) {
    -webkit-margin-after: 4.375rem;
            margin-block-end: 4.375rem;
  }
  .gnavWrapper {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-areas: "nav button";
    gap: 1.875rem;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .burger {
    display: none;
    pointer-events: none;
  }
  .contactButton {
    margin-inline: unset;
    border-radius: 50%;
    aspect-ratio: 1;
    inline-size: 10.875rem;
    -webkit-box-shadow: 0 0 10px rgba(0, 0, 0, 0.16);
            box-shadow: 0 0 10px rgba(0, 0, 0, 0.16);
  }
  .contactButton-link {
    grid-template-columns: auto;
    row-gap: 0.5625rem;
    padding-inline: unset;
    padding-block: unset;
  }
  .contactButton-link::after {
    grid-column: 1;
    justify-self: center;
  }
  .contactButton-title {
    grid-column: 1;
    font-size: 0.75rem;
  }
  .contactButton-text {
    grid-column: 1;
    font-size: 1.625rem;
  }
  .worksItem:has(.worksItem-title) .worksItem-list {
    -webkit-margin-before: 1.375rem;
            margin-block-start: 1.375rem;
  }
  .worksItem-title {
    font-size: 1.5625rem;
  }
  .worksItem-list {
    grid-template-columns: repeat(3, 1fr);
  }
  .worksItem-itemName {
    font-size: 1.25rem;
  }
  .planCards {
    grid-template-columns: repeat(3, 1fr);
    row-gap: unset;
    -webkit-column-gap: 2.1875rem;
       -moz-column-gap: 2.1875rem;
            column-gap: 2.1875rem;
  }
  .planCard:nth-child(1) {
    padding-inline: 2.1875rem;
    padding-block: 2.75rem 2rem;
  }
  .planCard:nth-child(1) .planCard-img {
    inline-size: 9.0625rem;
  }
  .planCard:nth-child(1) .planCard-img img {
    aspect-ratio: 145/282;
  }
  .planCard:nth-child(1) .planCard-text {
    -webkit-margin-before: 1.625rem;
            margin-block-start: 1.625rem;
  }
  .planCard:nth-child(1)::before {
    inset-inline-end: 0.8125rem;
  }
  .planCard:nth-child(2) {
    padding-inline: 0.75rem;
    padding-block: 3rem 2rem;
  }
  .planCard:nth-child(2) .planCard-img {
    inline-size: 9.625rem;
  }
  .planCard:nth-child(2) .planCard-img img {
    aspect-ratio: 154/256;
  }
  .planCard:nth-child(2) .planCard-text {
    -webkit-margin-before: 3rem;
            margin-block-start: 3rem;
  }
  .planCard:nth-child(2)::before {
    inset-inline-end: -2.3125rem;
  }
  .planCard:nth-child(3) {
    padding-inline: 0.75rem;
    padding-block: 2.6875rem 2rem;
  }
  .planCard:nth-child(3) .planCard-img {
    inline-size: 10.5625rem;
  }
  .planCard:nth-child(3) .planCard-img img {
    aspect-ratio: 169/277;
  }
  .planCard:nth-child(3) .planCard-text {
    -webkit-margin-before: 2rem;
            margin-block-start: 2rem;
  }
  .planCard:nth-child(3)::before {
    inset-inline-end: -2.1875rem;
  }
  .planCard::before {
    inset-block-start: -6rem;
    font-size: 15.625rem;
  }
  .planCard::after {
    inset-block-start: 2.1875rem;
    inset-inline-end: -0.4375rem;
    font-size: 1.25rem;
  }
  .planCard-img {
    margin-inline: auto;
  }
  .planCard-text {
    font-size: 1rem;
    line-height: 1.75;
    text-align: center;
  }
  .planCard-price {
    min-block-size: 6.25rem;
    -webkit-margin-before: 2rem;
            margin-block-start: 2rem;
    font-size: 2.1875rem;
  }
  .planCard-price::after {
    position: absolute;
    margin-inline: auto;
    inset-block-end: -3.4375rem;
    inset-inline: 0;
    inline-size: 2.375rem;
    block-size: 2rem;
    -webkit-clip-path: polygon(50% 32px, 0% 0%, 38px 0%);
    translate: 0 100%;
            clip-path: polygon(50% 32px, 0% 0%, 38px 0%);
    background-color: var(--color-black);
    content: "";
  }
  .planCard-priceNumber {
    font-size: 5rem;
  }
  .planList {
    gap: 3.125rem;
  }
  .planItem {
    --padding: 3.75rem;
    padding-block: 3.75rem;
  }
  .planItem-head {
    grid-template-columns: auto 1fr;
    grid-template-columns: 14.125rem 1fr;
    grid-template-areas: "number body";
  }
  .plan-number {
    grid-template-columns: 1fr;
    grid-auto-flow: row;
    -webkit-box-align: start;
    -webkit-align-items: start;
        -ms-flex-align: start;
            align-items: start;
    -webkit-padding-after: 0.3125rem;
            padding-block-end: 0.3125rem;
    text-align: center;
    -webkit-border-end: 2px solid var(--color-yellow);
            border-inline-end: 2px solid var(--color-yellow);
  }
  .plan-number::after {
    grid-column: 1;
    font-size: 15.625rem;
  }
  .planItem-title {
    grid-column: 1;
    -webkit-margin-before: -0.75rem;
            margin-block-start: -0.75rem;
  }
  .planItem-body {
    grid-template-columns: 1fr auto;
    grid-template-areas: "img price" "text text";
    row-gap: 0.625rem;
    -webkit-padding-after: 3.125rem;
            padding-block-end: 3.125rem;
    -webkit-padding-start: 3rem;
            padding-inline-start: 3rem;
    -webkit-margin-before: unset;
            margin-block-start: unset;
  }
  .planItem-img {
    inline-size: auto;
    -webkit-margin-before: -0.75rem;
            margin-block-start: -0.75rem;
  }
  .planItem-price {
    inline-size: 19.875rem;
    max-inline-size: 19.875rem;
    min-block-size: 6.25rem;
    font-size: 2.1875rem;
  }
  .planItem-priceNumber {
    font-size: 5rem;
  }
  .planItem-text {
    -webkit-padding-start: 0.625rem;
            padding-inline-start: 0.625rem;
    font-size: 1rem;
    line-height: 1.75;
  }
  .planItem-metaList {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 1.875rem;
    -webkit-margin-before: 2.25rem;
            margin-block-start: 2.25rem;
  }
  .planItem-metaItem {
    grid-auto-flow: column;
    font-size: 1.25rem;
  }
  .planItem-metaTitle {
    padding-inline: 1.1875rem;
  }
  .planItem-metaText {
    padding-inline: 1.1875rem;
  }
  .planItem-footer {
    -webkit-margin-before: 3.125rem;
            margin-block-start: 3.125rem;
  }
  .planItem-footerHeading {
    font-size: 1rem;
  }
  .planItem-cards {
    grid-template-columns: repeat(3, 1fr);
    gap: 2.1875rem;
    -webkit-margin-before: 1.875rem;
            margin-block-start: 1.875rem;
  }
  .planItem-cardMeta {
    gap: 0.625rem;
  }
  .problemCases {
    gap: 9.375rem;
  }
  .problemCase {
    grid-template-columns: 1fr auto;
    -webkit-padding-after: 3.5625rem;
            padding-block-end: 3.5625rem;
  }
  .problemCase[data-case=promotion] .problemCase-img {
    inset-block-end: -2.46875rem;
    inset-inline-end: 11.4375rem;
    inline-size: 30.8125rem;
    -webkit-margin-before: unset;
    margin-inline: unset;
            margin-block-start: unset;
  }
  .problemCase[data-case=promotion] .problemCase-img > img {
    aspect-ratio: 493/311;
  }
  .problemCase[data-case=recruit] .problemCase-img {
    inset-block-end: -2.375rem;
    inset-inline-end: 1.875rem;
    inline-size: 36.1875rem;
    -webkit-margin-before: unset;
    margin-inline: unset;
            margin-block-start: unset;
  }
  .problemCase[data-case=recruit] .problemCase-img > img {
    aspect-ratio: 579/509;
  }
  .problemCase[data-case=youtube] .problemCase-img {
    inset-block-end: -4.1875rem;
    inset-inline-end: 2.125rem;
    inline-size: 33.5rem;
    -webkit-margin-before: unset;
    margin-inline: unset;
            margin-block-start: unset;
  }
  .problemCase[data-case=youtube] .problemCase-img > img {
    aspect-ratio: 536/532;
  }
  .problemCase-body {
    display: block;
  }
  .problemCase-title {
    padding-block: 1.125rem;
    -webkit-margin-before: -2.8125rem;
            margin-block-start: -2.8125rem;
    font-size: 1.25rem;
    line-height: 1.5;
  }
  .problemCase-title::after {
    inset-block-end: 0.5rem;
    inline-size: 32px;
    block-size: 28px;
    -webkit-clip-path: polygon(50% 28px, 0% 0%, 32px 0%);
            clip-path: polygon(50% 28px, 0% 0%, 32px 0%);
  }
  .problemCase-description {
    -webkit-margin-before: 2rem;
            margin-block-start: 2rem;
    font-size: 3.125rem;
  }
  .problemCase-text {
    -webkit-margin-before: 2.875rem;
            margin-block-start: 2.875rem;
    font-size: 1.25rem;
    line-height: 1.5;
  }
  .problemCase-img {
    position: absolute;
  }
  .problemCase-button {
    max-inline-size: 24.8125rem;
    -webkit-margin-before: 1.375rem;
    margin-inline: unset;
            margin-block-start: 1.375rem;
  }
  .problemCase-button .primaryButton {
    padding-inline: 1.53125rem;
    padding-block: 1.125rem;
    font-size: 1rem;
  }
  .flowList {
    display: grid;
    grid-template-columns: auto auto 1fr;
    row-gap: 2.6875rem;
  }
  .flowItem {
    display: grid;
    grid-template-columns: subgrid;
    grid-template-areas: "number heading description";
    grid-column: span 3;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
    padding-block: 2.125rem;
    -webkit-padding-start: 2rem;
            padding-inline-start: 2rem;
  }
  .flowItem::before {
    -webkit-padding-end: 2.5rem;
            padding-inline-end: 2.5rem;
    font-size: 3.75rem;
  }
  .flowItem::after {
    inset-block: auto -0.9375rem;
    inset-inline: 3.75rem auto;
    inline-size: 20px;
    block-size: 18px;
    -webkit-clip-path: polygon(50% 18px, 0% 0%, 20px 0%);
    rotate: unset;
            clip-path: polygon(50% 18px, 0% 0%, 20px 0%);
  }
  .flowItem:last-child::after {
    content: none;
  }
  .flowItem-heading {
    -webkit-padding-end: 4.375rem;
            padding-inline-end: 4.375rem;
    -webkit-border-end: 3px solid var(--color-yellow);
            border-inline-end: 3px solid var(--color-yellow);
  }
  .flowItem-title {
    font-size: 1.875rem;
  }
  .flowItem-text {
    padding-inline: 0.8125rem;
    -webkit-margin-before: 0.75rem;
            margin-block-start: 0.75rem;
    font-size: 1.125rem;
    text-align: start;
  }
  .flowItem-description {
    -webkit-padding-start: 2.3125rem;
            padding-inline-start: 2.3125rem;
    -webkit-margin-before: unset;
            margin-block-start: unset;
    font-size: 1rem;
  }
  .accordion {
    gap: 1.25rem;
  }
  .accordion-head {
    padding-block: 1.25rem;
    font-size: 1rem;
  }
  .accordion-head::before, .accordion-head::after {
    inline-size: 1.25rem;
  }
  .accordion-contentInner {
    padding-inline: 3.125rem 1.25rem;
    padding-block: 1.4375rem;
  }
  .accordion-contentText {
    font-size: 1rem;
  }
  .moovingBg {
    --size: 2.1875rem;
    padding-inline: var(--size);
    padding-block: var(--size);
    block-size: 32.5rem;
  }
  .moovingBg-video > img {
    aspect-ratio: 1201/296;
    inline-size: 75.0625rem;
  }
  .newsList {
    grid-template-columns: -webkit-max-content 1fr;
    grid-template-columns: max-content 1fr;
  }
  .newsItem {
    grid-template-columns: subgrid;
    grid-template-areas: "date heading";
    grid-column: span 2;
    gap: 3.125rem;
    padding-block: 1.375rem;
  }
  .ly-breadcrumb-wrapper {
    -webkit-margin-before: unset;
            margin-block-start: unset;
  }
  .breadcrumb {
    gap: 0.9375rem;
  }
  .breadcrumb > span {
    font-size: 0.875rem;
  }
  .breadcrumb > span span.current-item.post-report {
    max-inline-size: 45em;
  }
  .form-subject {
    -webkit-padding-after: 2.34375rem;
            padding-block-end: 2.34375rem;
  }
  .form-subjectCheckbox {
    gap: 3.75rem;
  }
  .form-subjectText {
    text-align: start;
  }
  .form-subjectText label {
    gap: 0.625rem;
  }
  .form-subjectText input[type=checkbox] {
    inline-size: 1.125rem;
    block-size: 1.125rem;
  }
  .form-subjectText .wpcf7-list-item-label {
    font-size: 1.875rem;
  }
  .form-message {
    -webkit-margin-before: 1.4375rem;
            margin-block-start: 1.4375rem;
    font-size: 1rem;
    line-height: 1.75;
  }
  .form-group[data-group=name] {
    -webkit-margin-before: 2.5rem;
            margin-block-start: 2.5rem;
  }
  .form-group[data-group=checkbox] input[type=checkbox] {
    inline-size: 0.875rem;
    block-size: 0.875rem;
  }
  .form-group[data-group=checkbox] .wpcf7-list-item-label {
    -webkit-margin-before: -0.125rem;
            margin-block-start: -0.125rem;
    font-size: 1rem;
  }
  .form-privacy input[type=checkbox] {
    inline-size: 0.875rem;
    block-size: 0.875rem;
  }
  .form-privacy .wpcf7-list-item-label {
    -webkit-margin-before: -0.125rem;
            margin-block-start: -0.125rem;
    font-size: 1rem;
  }
  .form-labelText {
    font-size: 1.25rem;
  }
  .form-input,
  .form-textarea {
    padding-inline: 0.75rem;
    min-inline-size: 39.375rem;
    font-size: 1.125rem;
  }
  .form-input {
    min-block-size: 3.75rem;
  }
  .form-genre {
    grid-template-columns: repeat(2, 1fr);
  }
  .form-textarea {
    padding-block: 1.5rem;
    min-block-size: 18.75rem;
  }
  .form-buttonWrapper {
    -webkit-margin-before: 2.5rem;
            margin-block-start: 2.5rem;
  }
  .form-button {
    min-block-size: 3.75rem;
  }
  .form-button > input[type=submit] {
    font-size: 1.125rem;
  }
  .singleArticle-title {
    font-size: 1.875rem;
  }
  .singleArticle-img > img {
    aspect-ratio: 840/476;
  }
  .singleArticle-categories {
    gap: 0.75rem;
  }
  .singleArticle-category {
    gap: 0.75rem;
  }
  .singleArticle-tag {
    font-size: 1.875rem;
  }
  .singleArticle-main {
    -webkit-margin-before: 2.5rem;
            margin-block-start: 2.5rem;
  }
  .singleArticle-body {
    -webkit-margin-before: 2.5rem;
            margin-block-start: 2.5rem;
  }
  .singleArticle-body > div {
    font-size: 1.125rem;
    text-align: start;
  }
  .singleArticle-body .singleArticle-h2 {
    -webkit-margin-before: 2.5rem;
            margin-block-start: 2.5rem;
    font-size: 1.25rem;
  }
  .singleArticle-body h3 {
    -webkit-margin-before: 3.75rem;
            margin-block-start: 3.75rem;
  }
  .singleArticle-body p {
    font-size: 1rem;
  }
  .singleArticle-body .singleArticle-p {
    -webkit-margin-before: 1.25rem;
            margin-block-start: 1.25rem;
    font-size: 1rem;
  }
  .singleArticle-body figure {
    max-inline-size: 360px;
    -webkit-margin-before: 3.75rem;
            margin-block-start: 3.75rem;
  }
  .singleArticle-body figure img {
    aspect-ratio: 360/270;
  }
  .singleArticle-body ul,
  .singleArticle-body ol {
    padding-inline: 3.5625rem;
    padding-block: 1.875rem;
    -webkit-margin-before: 3.75rem;
            margin-block-start: 3.75rem;
  }
  .singleArticle-body ul li,
  .singleArticle-body ol li {
    -webkit-column-gap: 0.625rem;
       -moz-column-gap: 0.625rem;
            column-gap: 0.625rem;
    font-size: 1.125rem;
  }
  .singleArticle-body ol li::before {
    font-size: 1.375rem;
  }
  .singleArticle-body table tr td {
    font-size: 1.125rem;
  }
  .singleArticle-body a {
    font-size: 1rem;
  }
  .tag {
    padding-inline: 0.4375rem;
    padding-block: 0.3125rem;
    font-size: 0.875rem;
  }
  .searchForm-area {
    padding-inline: 4.0625rem;
    padding-block: 0.9375rem 1.3125rem;
  }
  .searchForm-block {
    -webkit-column-gap: 4.375rem;
       -moz-column-gap: 4.375rem;
            column-gap: 4.375rem;
  }
  .searchForm-title {
    font-size: 1rem;
  }
  .searchForm-list {
    gap: 0.2lh 2em;
    font-size: 1rem;
  }
  .searchForm-check {
    inline-size: 0.9375rem;
    block-size: 0.9375rem;
  }
  .searchForm-checkText {
    font-size: 1rem;
  }
  .searchForm-toggle {
    -webkit-column-gap: 1.25rem;
       -moz-column-gap: 1.25rem;
            column-gap: 1.25rem;
    padding-block: 1.875rem;
    font-size: 1rem;
  }
  .searchForm-toggle::before, .searchForm-toggle::after {
    inline-size: 1.25rem;
  }
  .searchForm-button {
    padding-inline: 1.53125rem;
    padding-block: 1.0625rem;
    max-inline-size: 20rem;
    font-size: 1.125rem;
  }
  .pagination-wrapper {
    -webkit-margin-before: 6.25rem;
            margin-block-start: 6.25rem;
  }
  .pagination > .nav-links > .page-numbers {
    inline-size: 2.8125rem;
    font-size: 1.25rem;
  }
  .swiper-container {
    display: none;
  }
  .container {
    padding-inline: 25px;
  }
  .header__inner {
    block-size: 5.875rem;
  }
  .header__logo {
    aspect-ratio: 180/44;
    inline-size: 11.25rem;
  }
  .ly-footer {
    padding-block: 5.625rem 4.375rem;
  }
  .footer {
    background-image: url("../../assets/images/common/other/footer-bg.webp");
  }
  .footer__contents {
    grid-template-columns: 1fr auto;
    grid-template-areas: "contact contact" "left right";
    row-gap: 5.75rem;
  }
  .footer__contactText {
    font-size: 1.5625rem;
  }
  .footer__contactButton {
    max-inline-size: 29.5rem;
    -webkit-margin-before: 1.5rem;
            margin-block-start: 1.5rem;
  }
  .footer__contactButton .primaryButton {
    padding-inline: 1.75rem;
    padding-block: 1.5rem;
    font-size: 1.5625rem;
  }
  .footer__left {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
    grid-area: left;
            flex-direction: column;
  }
  .footer__logo {
    inline-size: 14.9375rem;
    -webkit-margin-before: unset;
            margin-block-start: unset;
  }
  .footer__message {
    row-gap: 1.875rem;
    -webkit-margin-before: 1.875rem;
            margin-block-start: 1.875rem;
  }
  .footer__messageText {
    font-size: 0.875rem;
    line-height: 1.7142857143;
  }
  .footer__address {
    font-size: 0.875rem;
    line-height: 1.7142857143;
  }
  .footer__copyright {
    -webkit-margin-before: auto;
            margin-block-start: auto;
    font-size: 0.75rem;
    text-align: start;
  }
  .footer__right {
    display: grid;
    row-gap: 3.125rem;
    grid-area: right;
    justify-self: end;
    block-size: -webkit-fit-content;
    block-size: -moz-fit-content;
    block-size: fit-content;
    -webkit-margin-before: 5.375rem;
            margin-block-start: 5.375rem;
  }
  .footer__right .snsList {
    grid-area: unset;
    justify-self: end;
    -webkit-margin-before: unset;
            margin-block-start: unset;
  }
  .footer__menu {
    row-gap: 1em;
    grid-area: unset;
    padding-block: 1.25rem;
    -webkit-padding-start: 3.25rem;
            padding-inline-start: 3.25rem;
    -webkit-margin-before: unset;
            margin-block-start: unset;
    -webkit-margin-start: unset;
            margin-inline-start: unset;
  }
  .footer__menu::before {
    translate: -100% 100%;
    inset-inline-start: 0;
    font-size: 0.75rem;
  }
  .footer__menuLink {
    -webkit-flex-basis: 50%;
        -ms-flex-preferred-size: 50%;
            flex-basis: 50%;
    font-size: 0.875rem;
  }
  .firstView {
    max-block-size: 46.625rem;
    -webkit-padding-before: calc(var(--header-block-size) + 2.5rem);
            padding-block-start: calc(var(--header-block-size) + 2.5rem);
  }
  .firstView__inner {
    padding-inline: unset;
  }
  .firstView__message {
    text-align: start;
  }
  .firstView__title {
    display: grid;
    justify-self: center;
  }
  .firstView__titleText {
    -webkit-padding-start: unset;
            padding-inline-start: unset;
  }
  .firstView__titleText > span:nth-child(1) {
    font-size: 6.8125rem;
  }
  .firstView__titleText > span:nth-child(2) {
    font-size: 2.5rem;
  }
  .firstView__titleText > span:nth-child(3) {
    -webkit-padding-start: 2.0625rem;
            padding-inline-start: 2.0625rem;
    font-size: 2.8125rem;
  }
  .firstView__titleText > span:nth-child(4) {
    font-size: 3.9375rem;
  }
  .firstView__titleLarge {
    -webkit-padding-end: 1rem;
            padding-inline-end: 1rem;
  }
  .firstView__titleLarge > span {
    -webkit-margin-end: -6.25rem;
            margin-inline-end: -6.25rem;
    font-size: 8.125rem;
  }
  .firstView__button {
    position: static;
    max-inline-size: 20rem;
  }
  .firstView__button .primaryButton {
    padding-inline: 1.53125rem;
    padding-block: 1.0625rem;
    font-weight: var(--weight-medium);
    font-size: 1.125rem;
  }
  .firstView__download {
    display: grid;
    position: absolute;
    rotate: 90deg;
    margin-inline: unset;
    inset-block-start: 8.75rem;
    inset-inline-end: -2.5rem;
    background-color: transparent;
  }
  .ly-works {
    padding-block: 10.9375rem 6.75rem;
    -webkit-margin-before: -7.6875rem;
            margin-block-start: -7.6875rem;
  }
  .works__contents::before {
    inset-block-start: -26.375rem;
    inset-inline-end: -12.125rem;
    aspect-ratio: 1217/1041;
    inline-size: 76.0625rem;
  }
  .works__items {
    row-gap: 3.75rem;
    -webkit-margin-before: 3.5rem;
            margin-block-start: 3.5rem;
    -webkit-margin-end: unset;
            margin-inline-end: unset;
  }
  .works__items .worksItem {
    padding-block: unset;
    -o-border-image: unset;
       border-image: unset;
  }
  .works__items .worksItem-list {
    grid-template-columns: repeat(3, 1fr);
    gap: 2.1875rem;
  }
  .works__items .worksItem-item {
    -webkit-padding-end: unset;
            padding-inline-end: unset;
  }
  .works__button {
    max-inline-size: 20rem;
    -webkit-margin-before: 5rem;
            margin-block-start: 5rem;
  }
  .works__button .primaryButton {
    padding-inline: 1.53125rem;
    padding-block: 1.0625rem;
    font-size: 1.125rem;
  }
  .ly-youtube {
    padding-block: 3.0625rem 4.125rem;
  }
  .youtube__icon {
    inline-size: 4.9375rem;
  }
  .youtube__icon > img {
    aspect-ratio: 79/55;
  }
  .youtube__heading {
    -webkit-margin-before: 1.875rem;
            margin-block-start: 1.875rem;
    font-size: 2.5rem;
    line-height: 1.5;
  }
  .youtube__heading > span {
    font-size: 3.125rem;
    line-height: 1.2;
  }
  .youtube__heading::before, .youtube__heading::after {
    aspect-ratio: 60/250;
    inline-size: 3.75rem;
  }
  .youtube__heading::before {
    inset-block-start: -3.25rem;
    inset-inline-start: -3.3125rem;
  }
  .youtube__heading::after {
    inset-block-start: -3.4375rem;
    inset-inline-end: -2.75rem;
  }
  .youtube__text {
    -webkit-margin-before: 1.875rem;
            margin-block-start: 1.875rem;
    font-size: 1.25rem;
    line-height: 1.75;
    text-align: center;
  }
  .youtube__price {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-direction: row;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-margin-before: 2.25rem;
            margin-block-start: 2.25rem;
  }
  .youtube__priceText {
    font-size: 1.5625rem;
    line-height: 1.4;
  }
  .youtube__priceNumber {
    font-size: 5rem;
  }
  .youtube__priceNumber > span:nth-of-type(1) {
    inline-size: 3.875rem;
    -webkit-margin-end: 0.625rem;
            margin-inline-end: 0.625rem;
    font-size: 1rem;
  }
  .youtube__priceNumber > span:nth-of-type(2) {
    font-size: 2.1875rem;
  }
  .youtube__button {
    max-inline-size: 20rem;
    -webkit-margin-before: 3.125rem;
            margin-block-start: 3.125rem;
  }
  .youtube__button .primaryButton {
    padding-inline: 1.53125rem;
    padding-block: 1.0625rem;
    font-size: 1.125rem;
  }
  .ly-plan {
    padding-block: 5rem 6rem;
  }
  .plan__contents {
    margin-inline: unset;
    max-inline-size: unset;
  }
  .plan__cards {
    -webkit-margin-before: 6.875rem;
            margin-block-start: 6.875rem;
  }
  .plan__cards .planCard:nth-child(2) {
    -webkit-margin-before: var(--margin-block-start);
            margin-block-start: var(--margin-block-start);
  }
  .plan__cards .planCard:nth-child(3) {
    -webkit-margin-before: calc(var(--margin-block-start) * 2);
            margin-block-start: calc(var(--margin-block-start) * 2);
  }
  .plan__footer {
    -webkit-margin-before: 1.0625rem;
            margin-block-start: 1.0625rem;
  }
  .plan__footerText {
    font-size: 1.25rem;
  }
  .plan__button {
    max-inline-size: 20rem;
    -webkit-margin-before: 1.125rem;
            margin-block-start: 1.125rem;
  }
  .plan__button .primaryButton {
    padding-inline: 1.53125rem;
    padding-block: 1.0625rem;
    font-size: 1.125rem;
  }
  .ly-problem {
    -webkit-margin-before: 9.5rem;
            margin-block-start: 9.5rem;
  }
  .problem__heading {
    position: absolute;
    z-index: 1;
    inset-block-start: 0.9375rem;
    inset-inline-start: -15.625rem;
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
  }
  .problem__heading > span:nth-child(1) {
    font-size: 5.625rem;
  }
  .problem__heading > span:nth-child(2) {
    -webkit-margin-start: 18.125rem;
            margin-inline-start: 18.125rem;
    font-size: 5rem;
  }
  .problem__contents {
    max-inline-size: unset;
    -webkit-margin-before: unset;
    margin-inline: unset;
            margin-block-start: unset;
  }
  .ly-flow {
    padding-block: 7.1875rem 5.25rem;
  }
  .flow__line > svg {
    inset-block-start: -17.1875rem;
    inset-inline-start: -4.375rem;
    aspect-ratio: 1146/2289;
    inline-size: 71.625rem;
    stroke-width: 10px;
  }
  .flow__contents {
    max-inline-size: unset;
    -webkit-margin-before: 4.375rem;
    margin-inline: unset;
            margin-block-start: 4.375rem;
  }
  .flow__contents::before, .flow__contents::after {
    position: absolute;
    z-index: 1;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    content: "";
  }
  .flow__contactButton {
    position: absolute;
    z-index: 1;
    inset-block-start: 2.875rem;
    inset-inline-end: 2.6875rem;
    -webkit-margin-before: unset;
    translate: 0 -100%;
            margin-block-start: unset;
  }
  .flow__listWrapper::after {
    position: absolute;
    z-index: 1;
    inset-block-end: 26.5625rem;
    inset-inline-start: 30.3125rem;
    background-image: url("../images/pages/front/flow/flow-img02.webp");
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    aspect-ratio: 182/136;
    inline-size: 11.375rem;
    content: "";
  }
  .flow__message {
    -webkit-margin-before: 3.125rem;
            margin-block-start: 3.125rem;
    font-size: 1.25rem;
    line-height: 1.45;
    text-align: center;
  }
  .ly-faq {
    padding-block: 6.25rem 4rem;
  }
  .faq__contents {
    grid-template-columns: auto 1fr;
    grid-template-areas: "heading accordion";
    gap: 10.9375rem;
  }
  .faq__accordion {
    margin-inline: unset;
    max-inline-size: unset;
  }
  .ly-news {
    padding-block: 2.375rem 5rem;
  }
  .news__contents {
    grid-template-columns: auto 1fr;
    grid-template-areas: "head body";
    gap: 5.75rem;
  }
  .news__head {
    display: block;
    grid-area: head;
  }
  .news__button {
    max-inline-size: 14.375rem;
    -webkit-margin-before: 5.0625rem;
    margin-inline: unset;
            margin-block-start: 5.0625rem;
  }
  .news__button .primaryButton {
    padding-inline: 1.75rem;
    padding-block: 1rem;
    font-size: 1.125rem;
  }
  .news__body {
    max-inline-size: unset;
    -webkit-padding-before: 1.75rem;
    margin-inline: unset;
            padding-block-start: 1.75rem;
  }
  .ly-pageWorks {
    -webkit-padding-after: 5.625rem;
            padding-block-end: 5.625rem;
    -webkit-margin-before: 3.125rem;
            margin-block-start: 3.125rem;
  }
  .pageWorks__items {
    -webkit-margin-before: 7.5rem;
            margin-block-start: 7.5rem;
  }
  .pageWorks__noPost {
    -webkit-margin-before: 6.25rem;
            margin-block-start: 6.25rem;
    font-size: 1rem;
  }
  .ly-pagePlanCard {
    -webkit-margin-before: 3.125rem;
            margin-block-start: 3.125rem;
  }
  .pagePlanCard__contents {
    margin-inline: unset;
    padding-block: 7.625rem 5.9375rem;
    max-inline-size: unset;
  }
  .pagePlanCard__cards .planCard:nth-child(1) .planCard-price {
    margin-inline: -0.75rem;
  }
  .ly-pagePlanDetails {
    padding-block: 3.25rem 3.875rem;
  }
  .ly-contact {
    -webkit-padding-after: 8.25rem;
            padding-block-end: 8.25rem;
    -webkit-margin-before: 3.125rem;
            margin-block-start: 3.125rem;
  }
  .contact__contents {
    margin-inline: unset;
    padding-inline: 3.125rem;
    padding-block: 5.0625rem 4.75rem;
    max-inline-size: unset;
  }
  .contact__contents::before {
    inset-block-start: -19.1875rem;
    inset-inline-end: -6.0625rem;
    inline-size: 47.75rem;
  }
  .ly-pageSingle {
    margin-block: 3.125rem 7.0625rem;
  }
  .pageSingle__contents {
    padding-block: 3.875rem;
  }
  .pageSingle__contents::before {
    rotate: 90deg;
    inset-block-start: 7.1875rem;
    font-size: 0.75rem;
  }
  .singleReturnButton {
    max-inline-size: 20rem;
    -webkit-padding-after: 3.125rem;
            padding-block-end: 3.125rem;
    -webkit-margin-before: 3.125rem;
            margin-block-start: 3.125rem;
  }
  .singleReturnButton .primaryButton {
    padding-inline: 1.53125rem;
    padding-block: 1.0625rem;
    font-size: 1.125rem;
  }
  .ly-privacy {
    -webkit-padding-after: 8.25rem;
            padding-block-end: 8.25rem;
    -webkit-margin-before: 3.125rem;
            margin-block-start: 3.125rem;
  }
  .privacy__contents {
    margin-inline: unset;
    padding-inline: 2.125rem;
    padding-block: 5.0625rem 4.75rem;
    max-inline-size: unset;
  }
  .privacy__contents::before {
    inset-block-start: -19.1875rem;
    inset-inline-end: -6.0625rem;
    inline-size: 47.75rem;
  }
  .privacy__title {
    font-size: 1.25rem;
  }
  .privacy__text {
    font-size: 1rem;
  }
  .privacy__item {
    -webkit-margin-before: 2.25rem;
            margin-block-start: 2.25rem;
  }
  .privacy__itemTitle {
    font-size: 1rem;
  }
  .privacy__itemText {
    font-size: 1rem;
  }
  .privacy__right {
    font-size: 1rem;
  }
  .privacy__info {
    row-gap: 2.25rem;
    -webkit-margin-before: 1.875rem;
            margin-block-start: 1.875rem;
  }
  .privacy__infoLead {
    font-size: 1rem;
  }
  .privacy__infoText {
    font-size: 1rem;
  }
  .privacy__button {
    max-inline-size: 20rem;
  }
  .privacy__button .primaryButton {
    padding-inline: 1.53125rem;
    padding-block: 1.0625rem;
    font-size: 1.125rem;
  }
  .ly-thanks {
    -webkit-padding-after: 8.25rem;
            padding-block-end: 8.25rem;
    -webkit-margin-before: 3.125rem;
            margin-block-start: 3.125rem;
  }
  .thanks__contents {
    row-gap: 3.125rem;
    margin-inline: unset;
    padding-inline: 3.125rem;
    padding-block: 5.0625rem 4.75rem;
    max-inline-size: unset;
  }
  .thanks__contents::before {
    inset-block-start: -19.1875rem;
    inset-inline-end: -6.0625rem;
    inline-size: 47.75rem;
  }
  .thanks__lead {
    font-size: 1.375rem;
  }
  .thanks__text {
    font-size: 1rem;
    text-align: center;
  }
  .thanks__message {
    padding-block: 2.5rem;
  }
  .thanks__messageText {
    text-align: center;
  }
  [data-device=sp] {
    display: none;
  }
}

@media (min-width: 960px){
  [data-device=tab] {
    display: none;
  }
}

@media (min-width: 1200px){
  [data-device=pc] {
    display: none;
  }
}

@media (min-width: 1230px){
  html {
    font-size: 100%;
  }
}

@media (min-width: 1280px){
  .problem__heading {
    inset-block-start: -1.5625rem;
  }
}

@media (min-width: 1920px){
  .firstView {
    max-block-size: 50rem;
  }
}

@media (max-width: 767px){
  a[href^="tel:"] {
    pointer-events: auto;
  }
  [data-device=pc-only] {
    display: none;
  }
}

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

@media (any-hover: hover){
  .gnavButton:hover {
    --darken: 20%;
  }
  .worksItem-itemImg:hover > img {
    scale: 1.05;
  }
  .planItem-cardImg:hover > img {
    scale: 1.08;
  }
  .newsItem-title > a:hover {
    --darken: 30%;
  }
  .form-privacyLink:focus-visible:hover {
    --lighten: 20%;
  }
  .form-privacyLink:hover {
    --color: var(--color-yellow);
    color: color-mix(in sRGB, var(--color), #fff var(--lighten, 0%));
  }
  .form-privacyLink:hover:focus-visible {
    --lighten: 20%;
  }
  .searchForm-buttonSubmit:hover {
    --darken: 20%;
  }
  .searchForm-buttonClear:hover {
    --lighten: 30%;
  }
  .pagination > .nav-links > .page-numbers:hover {
    --number-background: var(--color-black);
    color: var(--color-white);
  }
}

@media (any-hover: hover) and (any-hover: hover){
  .form-privacyLink:hover:hover {
    --lighten: 20%;
  }
}

@media (orientation: landscape){
  .firstView {
    block-size: 100lvw;
  }
}

@media (prefers-reduced-motion: no-preference){
  :focus-visible {
    -webkit-transition: outline-offset 145ms cubic-bezier(0.25, 0, 0.4, 1);
    transition: outline-offset 145ms cubic-bezier(0.25, 0, 0.4, 1);
  }
  :where(:not(:active)):focus-visible {
    -webkit-transition-duration: 0.25s;
            transition-duration: 0.25s;
  }
}

/* 資料請求ボタン */
.thanks__document-button-block {
  text-align: center;
  width: 100%;
}

.thanks__document-button {
  display: inline-flex;
  background-color: var(--color-yellow);
  border-radius: 9999px;
  align-items: center;
  justify-content: space-between;
  padding: 1rem;
  width: 30rem;
  max-width: 100%;
  transition: 0.3s ease-in-out;
  opacity: 1;
}

.thanks__document-button:hover {
  opacity: 0.7;
}

.thanks__document-button span {
  color: var(--color-black);
  font-weight: 700;
  font-size: 1rem;
}

.thanks__document-button img {
  width: 1.8rem;
}
