@charset "UTF-8";
/* DotGothic16 Noto Sans Japanese */
@import "https://fonts.googleapis.com/css2?family=DotGothic16&family=Noto+Sans+JP:wght@400;500;700&display=swap";
*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  scroll-behavior: smooth;
  overflow-x: clip;
}

html {
  scroll-padding-top: 40px;
}
@media (width >= 768px) {
  html {
    scroll-padding-top: 92px;
  }
}

body {
  font-family: var(--noto-sans), "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  font-size: 16px;
  font-weight: 400;
  font-feature-settings: "palt" 1;
  line-height: 1.5;
  color: var(--main-dark);
  min-width: 320px;
}

img {
  max-width: 100%;
  vertical-align: middle;
}

.page-numbers {
  display: flex;
  gap: 2rem;
  place-content: center;
  margin-top: 4rem;
}

/* ----------------------------------
	functions SCSSの関数
------------------------------------ */
:root {
  --base-dark: #001e70;
  --base: #03f;
  --base-light: 0 15 112;
  --primary: #fff;
  --accent: #ff0;
  --accent01: #ffa2f0;
  --accent02: #ff7878;
  --red: #f00;
  --button-blue: #0a84d5;
  --base-light-blue: #e8f7ff;
  --main-darkest: #000;
  --main-dark: #333;
  --main-dark01: #414141;
  --gray-lightest: #00000029;
  --gray-lighter: #bbb;
  --gray-lighter01: #d1d1d1;
  --gray-light: #0000008c;
  --gray-dark: #8d8d8d;
  --gray-dark01: #707070;
  --gray-darker: #686868;
  --gray-darkest: #6a6a6a;
  --light-gray-lightest: #f1f1f1;
  --light-gray-lighter: #e3e3e3;
  --light-gray-light01: #ebebeb;
  --light-gray-light02: #dbdbdb;
  --light-gray-dark: #00000029;
  /* 文字サイズ */
  --font-xl: 60px;
  --font-lg: 50px;
  --font-md1: 36px;
  --font-md2: 26px;
  --font-md3: 24px;
  --font-md4: 20px;
  --font-sm: 18px;
  --font-xs: 16px;
  --font-xxs: 14px;
  /* font */
  --noto-sans: "Noto Sans JP", sans-serif;
  --dot-gothic: "DotGothic16", sans-serif;
  --inner: 75rem;
  --header-height: 62px;
}

.c-bandHeading {
  display: flex;
  column-gap: 21px;
  align-items: center;
}
@media screen and (min-width: 992px) {
  .c-bandHeading {
    font-size: 1.625rem;
    line-height: 2.3076923077;
    letter-spacing: 0.07em;
    font-weight: 700;
  }
}
.c-bandHeading {
  font-size: 1rem;
  line-height: 1.5;
  letter-spacing: 0.11375em;
  font-weight: 700;
}

.c-bandHeading::before {
  display: inline-block;
}
@media screen and (min-width: 992px) {
  .c-bandHeading::before {
    min-width: 0.6875rem;
  }
}
.c-bandHeading::before {
  min-width: 0.4375rem;
  height: 3.125rem;
  content: "";
  background: #13007c;
}

@media screen and (min-width: 992px) {
  .c-combinedHeading.-lgGl {
    font-size: 3.125rem;
    line-height: 1.2;
    letter-spacing: 0.07em;
    font-weight: 400;
  }
}
@media screen and (min-width: 768px) {
  .c-combinedHeading.-lgGl {
    font-size: 2.25rem;
    line-height: 1.6666666667;
    letter-spacing: 0.0972222222em;
    font-weight: 400;
  }
}
.c-combinedHeading.-lgGl {
  font-size: 1.25rem;
  line-height: 2;
  letter-spacing: 0.175em;
  font-weight: 400;
}

@media screen and (min-width: 992px) {
  .c-combinedHeading.-mid {
    font-size: 2.25rem;
    line-height: 1.6666666667;
    letter-spacing: 0.03em;
    font-weight: 700;
  }
}

@media screen and (min-width: 992px) {
  .c-combinedHeading.-mid[data-lineHeight=wide] {
    font-size: 2.25rem;
    line-height: 1.6666666667;
    letter-spacing: 0.07em;
    font-weight: 700;
  }
}

@media screen and (min-width: 992px) {
  .c-combinedHeading.-mid2 {
    font-size: 1.625rem;
    line-height: 2.3076923077;
    letter-spacing: 0.07em;
    font-weight: 700;
  }
}

@media screen and (min-width: 992px) {
  .c-combinedHeading.-mid3 {
    font-size: 1.5rem;
    line-height: 2.5;
    letter-spacing: 0.07em;
    font-weight: 700;
  }
}

@media screen and (min-width: 992px) {
  .c-combinedHeading.-small {
    font-size: 0.875rem;
    line-height: 4.2857142857;
    letter-spacing: 0.1em;
    font-weight: 700;
  }
}

.c-combinedHeading.-white {
  color: var(--primary);
}

@media screen and (min-width: 992px) {
  .c-combinedHeading.-dot {
    font-size: 2.25rem;
    line-height: 1.6666666667;
    letter-spacing: 0.03em;
    font-weight: 400;
  }
}
.c-combinedHeading.-dot {
  font-family: var(--dot-gothic);
}

@media screen and (max-width: 991px) {
  .c-combinedHeading:is(.-sp) {
    font-size: 1.125rem;
    line-height: 1.4444444444;
    letter-spacing: 0.03em;
    font-weight: 700;
  }
}

@media screen and (min-width: 992px) {
  .c-combinedBodyText.-md {
    font-size: 1.125rem;
    line-height: 2.4444444444;
    letter-spacing: 0.1em;
    font-weight: 400;
  }
}

.c-combinedBodyText.-white {
  color: var(--primary);
}

@media screen and (min-width: 992px) {
  .c-combinedBodyText.-sm {
    font-size: 1rem;
    line-height: 2.75;
    letter-spacing: 0.03em;
    font-weight: 400;
  }
}

@media screen and (max-width: 991px) {
  .c-combinedBodyText.-sm.-sp {
    font-size: 0.875rem;
    line-height: 1.8571428571;
    letter-spacing: 0.03em;
    font-weight: 400;
  }
}

@media screen and (max-width: 991px) {
  .c-combinedBodyText.-spsm {
    font-size: 0.875rem;
    line-height: 1.8571428571;
    letter-spacing: 0.03em;
    font-weight: 400;
  }
}

@media screen and (max-width: 991px) {
  .c-contactArea__wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
  }
}

@media screen and (max-width: 991px) {
  .c-contactArea {
    width: 100vw;
  }
}
.c-contactArea {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  aspect-ratio: 131/58;
  padding: 2.3125rem 0 2.0625rem;
  color: var(--primary);
  background-image: var(--contact-area);
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (min-width: 992px) {
  .c-contactArea {
    aspect-ratio: 1280/316;
    padding: 0;
  }
}

.c-contactArea__text {
  font-size: 1.25rem;
  line-height: 2;
  letter-spacing: 0.07em;
  font-weight: 500;
  padding-inline: 1.25rem;
  font-size: clamp(0.875rem, 0.7794117647rem + 0.3921568627vw, 1.25rem);
  text-align: center;
}

.c-contactArea__buttonText {
  font-size: 1.25rem;
  line-height: 2;
  letter-spacing: 0.07em;
  font-weight: 500;
  font-size: clamp(0.875rem, 0.7794117647rem + 0.3921568627vw, 1.25rem);
}

.c-contactArea__button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 60%;
  max-width: 20.75rem;
  aspect-ratio: 332/68;
  background-color: #0a84d5;
  border-radius: 3.125rem;
}
@media screen and (min-width: 992px) {
  .c-contactArea__button {
    width: 100%;
  }
}

@media screen and (min-width: 992px) {
  .c-slash-cover {
    position: relative;
    display: grid;
    place-items: center;
    width: 100%;
    min-height: 100vh;
  }
}

@media screen and (min-width: 992px) {
  .c-slash-cover[data-sectionName=news]::after {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%;
    clip-path: polygon(55% 90%, 100% 90%, 100% 100%, 0 100%, 0% 55%);
    content: "";
    background-color: rgb(var(--base-light)/85%);
  }
}

@media screen and (min-width: 992px) {
  .c-slash-cover[data-sectionName=hisotory] {
    min-height: 120vh;
  }
}

@media screen and (min-width: 992px) {
  .c-slash-cover[data-sectionName=product] {
    min-height: 140vh;
    background-color: rgb(var(--base-light)/85%);
  }
}

@media screen and (min-width: 992px) {
  .c-slash-cover[data-sectionName=product]::after {
    position: absolute;
    bottom: -1px;
    left: 0;
    display: block;
    width: 100%;
    height: 50vw;
    clip-path: polygon(0 50%, 0% 100%, 100% 100%);
    content: "";
    background: var(--primary);
  }
}

@media screen and (min-width: 992px) {
  .c-slash-cover[data-sectionName=solution] {
    min-height: 60vh;
    background: #f1f1f1;
  }
}

.c-slash-cover[data-sectionName=history] {
  display: block;
  width: 100%;
  min-height: 120vh;
}

@media screen and (min-width: 992px) {
  .c-slash-cover .history__item1 {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: -1;
    display: block;
    width: 100%;
    min-height: 100%;
    clip-path: polygon(0 0, 100% 0, 100% 72%, 0 100%, 0 49%);
    background-color: #f1f1f1;
  }
}

@media screen and (min-width: 992px) {
  .c-slash-cover .history__item2 {
    position: absolute;
    top: calc(-100vw + 1px);
    bottom: -0.5px;
    left: 0;
    z-index: -2;
    display: block;
    width: 100%;
    height: 100vw;
    clip-path: polygon(100% 50%, 0% 100%, 100% 100%);
    background-color: rgba(0, 15, 112, 0.85);
  }
}

@media screen and (min-width: 992px) {
  .c-cover-item {
    position: absolute;
    inset: 0;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    background: rgba(255, 255, 255, 0.8117647059);
    transition: 0.3s transform cubic-bezier(0.37, 0, 0.63, 1) 0.2s;
  }
}
.c-cover-item {
  display: none;
}

@media screen and (min-width: 992px) {
  .c-cover-item.-down {
    margin-block-end: auto;
    transform: translateY(-100%);
  }
}

@media screen and (min-width: 992px) {
  .c-cover-item.-up {
    margin-block-start: auto;
    transform: translateY(100%);
  }
}

@media screen and (min-width: 992px) {
  .c-imageClip:hover .c-cover-item.-down,
  .c-imageClip:hover .c-cover-item.-up {
    transform: translateY(0);
  }
}

.c-gear {
  position: relative;
  z-index: 0;
}
@media screen and (max-width: 991px) {
  .c-gear {
    display: none;
  }
}

.c-gear__wrap {
  position: fixed;
  z-index: 1;
  width: 7.8125vw;
  height: 7.8125vw;
}
.c-gear__wrap::after {
  position: fixed;
  width: 7.8125vw;
  height: 7.8125vw;
  content: "";
  background-image: var(--gear);
  background-repeat: no-repeat;
  background-size: cover;
  transform: rotate(var(--rotate));
}
.c-gear__wrap::before {
  position: fixed;
  width: 7.8125vw;
  height: 7.8125vw;
  content: "";
  background-image: var(--gear);
  background-repeat: no-repeat;
  background-size: cover;
  transform: rotate(var(--rotate));
}

.c-gear__item {
  position: fixed;
  z-index: 1;
  width: 7.8125vw;
  height: 7.8125vw;
  background-image: var(--gear);
  background-repeat: no-repeat;
  background-size: cover;
  transform: rotate(var(--rotate));
}

.c-gear__left {
  top: 18.2291666667vw;
  left: -4.84375vw;
}
.c-gear__left::before {
  top: 23.9583333333vw;
  left: -1.0416666667vw;
}
.c-gear__left::after {
  top: 29.6875vw;
  left: -4.84375vw;
}

.c-gear__right {
  top: 18.2291666667vw;
  right: calc(14rem + -4.84375vw);
}
.c-gear__right::before {
  top: 23.9583333333vw;
  right: calc(14rem + -1.0416666667vw);
}
.c-gear__right::after {
  top: 29.6875vw;
  right: calc(14rem + -4.84375vw);
}

.c-headingBorder {
  position: relative;
  display: block;
  width: 100%;
  height: 0.0625rem;
  background-color: var(--border-color, var(--primary));
}
.c-headingBorder::after {
  position: absolute;
  top: 0;
  left: 0;
  width: 3.75rem;
}
@media screen and (min-width: 768px) {
  .c-headingBorder::after {
    width: 5rem;
  }
}
.c-headingBorder::after {
  height: 0.0625rem;
  content: "";
  background-color: var(--sub-border-color);
}

.c-headingBorder[data-border=gray] {
  --border-color: var(--light-gray-light01);
}

.c-headingBorder[data-border=lightGray] {
  --border-color: var(--light-gray-light02);
}

.c-headingBorder[data-sub-border=red] {
  --sub-border-color: #f00;
}

.c-headingBorder[data-sub-border=orange] {
  --sub-border-color: #ff9100;
}

.c-headingBorder[data-sub-border=yellow] {
  --sub-border-color: #b7b709;
}

.c-headingBorder[data-sub-border=green] {
  --sub-border-color: #008e18;
}

.c-headingBorder[data-sub-border=blue] {
  --sub-border-color: #03f;
}

.c-humburger {
  position: relative;
  display: block;
  width: 20px;
  height: 15px;
}
@media screen and (min-width: 992px) {
  .c-humburger {
    display: none;
  }
}

.c-humburger__line {
  position: absolute;
  left: 0;
  z-index: 99;
  display: block;
  width: 20px;
  height: 2px;
  background: rgb(var(--base-light));
  border-radius: 7.5px;
  transition: all 0.4s;
}

.c-humburger__line--1 {
  top: 0;
}

.c-humburger__line--2 {
  top: 50%;
}

.c-humburger__line--3 {
  top: 100%;
}

.c-humburger.is-active .c-humburger__line {
  background: var(--primary);
}

.c-humburger.is-active .c-humburger__line--1 {
  transform: translateY(7.5px) translateX(0) rotate(45deg);
}

.c-humburger.is-active .c-humburger__line--2 {
  opacity: 0;
}

.c-humburger.is-active .c-humburger__line--3 {
  transform: translateY(-7.5px) translateX(0) rotate(-45deg);
}

@media screen and (min-width: 992px) {
  .c-imageClip {
    position: relative;
    display: flex;
    width: 100%;
    max-width: 46.875rem;
    max-height: 26.875rem;
    overflow: hidden;
  }
}

.c-imageClip__item {
  width: 100%;
  object-fit: cover;
}

@media screen and (min-width: 992px) {
  .c-imageClip__item.-up {
    clip-path: polygon(0 0%, 100% 25%, 100% 100%, 0% 100%);
    object-position: top;
  }
}

@media screen and (min-width: 992px) {
  .c-imageClip__item.-down {
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 75%);
    object-position: top;
  }
}

.c-detailButton {
  display: inline-block;
  padding: 0.5rem 2.25rem;
  font-size: 0.875rem;
  line-height: 1.4285714286;
  letter-spacing: 0.1em;
  font-weight: 500;
  border: 0.0625rem solid #010101;
}

.c-detailButton::before {
  display: inline-block;
  width: 0.75rem;
  height: 0.75rem;
  margin-right: 0.5625rem;
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  content: "";
  background-color: #010101;
}

.c-equipmentList th:first-child {
  border-top: #d8dadc 1px solid;
}

.c-equipmentList th {
  padding: 25px;
  font-weight: normal;
  color: #000;
  background: #f0f0f0;
  border-bottom: #d8dadc 1px solid;
}

.c-equipmentList td {
  padding: 25px;
  border: solid 1px #d8dadc;
}

@media (width <= 991px) {
  .c-equipmentList .thead {
    display: none;
  }
  .c-equipmentList tr td:first-child {
    background: #d8dadc;
  }
  .c-equipmentList th,
  .c-equipmentList td {
    display: block;
    width: 100%;
    border-bottom: none;
  }
  .c-equipmentList th:last-child,
  .c-equipmentList td:last-child {
    border-bottom: solid 1px #d8dadc;
  }
  .c-equipmentList tr td::before {
    float: left;
    margin-right: 20px;
    font-weight: bold;
    content: attr(data-label);
  }
}
.c-linkText {
  color: #2680eb;
}

.c-linkTextWithIcon {
  display: flex;
  column-gap: 0.3125rem;
  align-items: center;
}
@media screen and (min-width: 992px) {
  .c-linkTextWithIcon {
    column-gap: 0.625rem;
  }
}

@media screen and (min-width: 992px) and (any-hover: hover) {
  .c-linkTextWithIcon::after {
    width: 1.6875rem;
    height: 1.6875rem;
    aspect-ratio: 1/1;
    content: "";
    object-fit: contain;
    background-image: var(--dot-arrow);
    background-repeat: no-repeat;
    background-size: contain;
    opacity: 0;
    transition: 0.2s opacity ease;
  }
}

@media screen and (min-width: 992px) and (any-hover: hover) {
  .c-linkTextWithIcon.-whiteArrow::after {
    background-image: var(--dot-arrow-white);
  }
}

@media screen and (min-width: 992px) and (any-hover: hover) {
  .c-linkTextWithIcon:hover::after {
    opacity: 1;
  }
}

@media screen and (min-width: 992px) {
  .c-linkTextWithIcon__icon {
    max-width: clamp(1.5rem, 0.2974137931rem + 1.9396551724vw, 2.625rem);
  }
}
.c-linkTextWithIcon__icon {
  max-width: clamp(1.25rem, 0.3814655172rem + 1.400862069vw, 2.0625rem);
}

.c-linkTextWithIcon__text {
  font-size: 1.125rem;
  line-height: 1.5;
  letter-spacing: 0.07em;
  font-weight: 700;
  font-size: clamp(0.75rem, 0.349137931rem + 0.6465517241vw, 1.125rem);
}
@media screen and (max-width: 991px) {
  .c-linkTextWithIcon__text {
    font-size: clamp(0.75rem, 0.6307749627rem + 0.5961251863vw, 1rem);
  }
}

.c-linkTextWithIcon__text.-white {
  color: var(--primary);
}

.c-button--recruit__button {
  width: 100%;
  padding: 11px 4px;
  background: #fff;
  border: 1px solid #707070;
  transition: 0.4s;
}
@media screen and (width >= 992px) {
  .c-button--recruit__button {
    padding: 21px 42px;
  }
}
.c-button--recruit__button:focus-visible {
  outline-color: var(--accent);
}

.c-button--recruit.active .c-button--recruit__button {
  color: #fff;
  background: #333;
}

.c-read-policy {
  margin-top: 10rem;
}
@media screen and (max-width: 991px) {
  .c-read-policy {
    margin-top: 4.375rem;
    font-size: 0.8125rem;
  }
}

@media screen and (max-width: 991px) {
  .c-read-policy > * + * {
    margin-top: 1.25rem;
  }
}

.c-read-policy__google label {
  display: inline-flex;
  column-gap: 0.3125rem;
  align-items: baseline;
}

.c-read-policy__google input[type=checkbox] {
  top: 4px;
  position: relative;
}
@media screen and (min-width: 992px) {
  .c-read-policy__google input[type=checkbox] {
    width: 1.375rem;
    height: 1.375rem;
    margin-top: 0;
  }
}

@media screen and (max-width: 991px) {
  .c-recruit-form {
    font-size: 0.875rem;
  }
}

.c-recruit-form > * + * {
  margin-top: 2.5rem;
}

.c-recruit-form__mark {
  display: inline-grid;
  align-self: baseline;
  padding: 0.75rem 1.75rem;
  color: var(--primary);
  background: var(--accent02);
  border-radius: 0.3125rem;
}
@media screen and (max-width: 991px) {
  .c-recruit-form__mark {
    padding: 5px 20px;
  }
}

.c-recruit-form__mark--any {
  background: #c5c5c5;
}

.c-recruit-form__column {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 0.625rem 0.9375rem;
}
@media screen and (min-width: 992px) {
  .c-recruit-form__column {
    grid-template-columns: 6.1875rem max-content 1fr;
    column-gap: 3rem;
  }
}

.c-recruit-form__labelText {
  display: inline-grid;
  align-self: baseline;
  max-width: 26.25rem;
  font-weight: 500;
}
@media screen and (min-width: 992px) {
  .c-recruit-form__labelText {
    width: 21.875vw;
  }
}

.c-recruit-form__field {
  height: 3.25rem;
  border: 1px solid var(--gray-dark01);
}

.c-recruit-form__textarea {
  border: 1px solid var(--gray-dark01);
}

@media screen and (max-width: 991px) {
  .c-recruit-form__item {
    grid-area: 2/1/2/3;
    line-height: 1.3;
  }
}

:is(.c-recruit-form__field input, .c-recruit-form__textarea textarea) {
  width: 100%;
  height: 100%;
  padding: 0.5rem 0.375rem;
}

.c-recruit-form__selectWrap select {
  width: 100%;
  height: 100%;
  padding: 0.825rem 1rem;
  appearance: none;
  cursor: pointer;
  border: 1px solid var(--gray-dark01);
}
@media screen and (min-width: 992px) {
  .c-recruit-form__selectWrap select {
    width: 18.75rem;
    min-width: max-content;
    padding-right: 1.875rem;
    line-height: 1;
  }
}
@media screen and (max-width: 991px) {
  .c-recruit-form__selectWrap select {
    height: 2.75rem;
    padding: 0.5rem 0.75rem;
    font-size: 0.875rem;
    line-height: 1.5;
  }
}

.c-recruit-form__selectInner {
  position: relative;
  display: flex;
}
@media screen and (min-width: 992px) {
  .c-recruit-form__selectInner {
    display: inline-block;
  }
}

.c-recruit-form__selectInner::before {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 0;
  display: inline-block;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: 100%;
  height: 100%;
  padding: 0 0.625rem;
  pointer-events: none;
  content: "▼";
}

.c-recruit-form__uploadWrap {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}
@media screen and (min-width: 992px) {
  .c-recruit-form__uploadWrap {
    flex-direction: row;
    row-gap: 1.25rem;
    align-items: center;
  }
}

.c-recruit-form :is(.mw_wp_form input[type=file], .mwform-file-delete) {
  display: none;
}

.c-recruit-form__upload-wrap {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}
@media screen and (width >= 992px) {
  .c-recruit-form__upload-wrap {
    flex-direction: row;
    row-gap: 1.25rem;
    align-items: center;
  }
}

.c-recruit-form__chose {
  display: inline-flex;
  width: 100%;
  padding: 0.825rem 1rem;
  margin-right: 0.625rem;
  margin-bottom: 0;
  color: #fff;
  text-align: center;
  cursor: pointer;
  background: #000;
  border: 1px solid #fff;
  align-items: center;
  line-height: 1.625rem;
  justify-content: center;
}
@media screen and (min-width: 992px) {
  .c-recruit-form__chose {
    width: 18.75rem;
    height: 3.5625rem;
    line-height: 1.75rem;
  }
}
.c-recruit-form__chose:hover {
  opacity: 0.8;
}
@media screen and (max-width: 991px) {
  .c-recruit-form__chose {
    height: 2.75rem;
    padding: 0.5rem 0.75rem;
    font-size: 0.875rem;
    line-height: 1.5;
  }
}

.c-recruit-form__btn-wrap input {
  display: inline-block;
  width: 100%;
  padding: 0.825rem 1rem;
  font-size: 1.125rem;
  font-weight: 500;
  cursor: pointer;
  background: var(--primary);
  border: 1px solid #707070;
  transition: all 0.4s;
}
@media screen and (min-width: 576px) {
  .c-recruit-form__btn-wrap input {
    max-width: 18.75rem;
    height: 3.5625rem;
    line-height: 1.75rem;
  }
}
@media screen and (max-width: 991px) {
  .c-recruit-form__btn-wrap input {
    height: 2.75rem;
    padding: 0.5rem 0.75rem;
    font-size: 0.875rem;
  }
}
.c-recruit-form__btn-wrap input:hover {
  color: #fff;
  background: #000;
}

.c-recruit-form__btn-wrap {
  margin-top: 1.875rem;
  text-align: center;
}

.c-recruit-form__link {
  padding-block-end: 1px;
  color: var(--base);
  border-block-end: 1px solid currentcolor;
}

.l-contentPage {
  min-height: calc(100svh - 5.75rem);
}

.l-contentPage > * + * {
  margin-top: 1.5rem;
}

@media screen and (max-width: 991px) {
  .c-recruit-form .mw_wp_form .mw_wp_form_input > div[class*=border],
  .c-recruit-form .mw_wp_form .mw_wp_form_confirm > div[class*=border] {
    flex-direction: column !important;
  }
}
@media screen and (max-width: 991px) {
  .c-recruit-form .mw_wp_form .mw_wp_form_input > div[class*=border] > div:first-child,
  .c-recruit-form .mw_wp_form .mw_wp_form_confirm > div[class*=border] > div:first-child {
    width: 100% !important;
  }
}
@media screen and (max-width: 991px) {
  .c-recruit-form .mw_wp_form .mw_wp_form_input > div[class*=border] > div:last-child,
  .c-recruit-form .mw_wp_form .mw_wp_form_confirm > div[class*=border] > div:last-child {
    width: 100% !important;
  }
}
.c-recruit-form .mw_wp_form .mwform-tel-field {
  display: flex;
  flex-direction: row;
  align-items: center;
}
@media screen and (min-width: 992px) {
  .c-recruit-form .mw_wp_form .mwform-tel-field {
    gap: 0.625rem;
    max-width: 25rem;
  }
}
@media screen and (max-width: 991px) {
  .c-recruit-form .mw_wp_form .mwform-tel-field {
    gap: 0.375rem;
    width: 100%;
  }
}
.c-recruit-form .mw_wp_form .mwform-tel-field input[type=tel] {
  flex: 1;
  min-width: 0;
}
@media screen and (min-width: 992px) {
  .c-recruit-form .mw_wp_form .mwform-tel-field input[type=tel] {
    max-width: 7.5rem;
  }
}
@media screen and (max-width: 991px) {
  .c-recruit-form .mw_wp_form .mwform-tel-field input[type=tel] {
    min-height: 2.75rem;
    padding: 0.5rem 0.375rem;
    font-size: 0.875rem;
    text-align: center;
  }
}
.c-recruit-form .mw_wp_form .mwform-tel-field > span {
  flex-shrink: 0;
}
@media screen and (max-width: 991px) {
  .c-recruit-form .mw_wp_form input[type=text],
  .c-recruit-form .mw_wp_form input[type=email],
  .c-recruit-form .mw_wp_form input[type=tel] {
    width: 100%;
    min-height: 2.75rem;
    padding: 0.5rem 0.75rem;
    font-size: 0.875rem;
  }
}
@media screen and (max-width: 991px) {
  .c-recruit-form .mw_wp_form textarea {
    min-height: 7.5rem;
    padding: 0.5rem 0.75rem;
    font-size: 0.875rem;
  }
}
@media screen and (max-width: 991px) {
  .c-recruit-form .mw_wp_form .mwform-checkbox-field,
  .c-recruit-form .mw_wp_form .mwform-radio-field {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
  }
}
@media screen and (max-width: 991px) {
  .c-recruit-form .mw_wp_form .mwform-checkbox-field label,
  .c-recruit-form .mw_wp_form .mwform-radio-field label {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    min-height: 2.75rem;
    padding: 0.5rem;
  }
}
@media screen and (max-width: 991px) {
  .c-recruit-form .mw_wp_form .mwform-checkbox-field-text,
  .c-recruit-form .mw_wp_form .mwform-radio-field-text {
    font-size: 0.875rem;
    line-height: 1.6;
  }
}

/* MW WP Form - 送信ボタン */
.mwform-submit-button {
  width: 100%;
  cursor: pointer;
  border: 1px solid var(--main-dark);
  padding: 0.75rem 1.5rem;
  font-weight: 500;
  background-color: transparent;
  transition: background-color 0.2s, color 0.2s;
}

.mwform-submit-button:hover {
  background-color: var(--main-dark);
  color: white;
}

/**  ======================
 * 枠をはみ出すコンポーネント
 *========================  **/
.c-crowdedOut {
  width: 100vw;
  margin: 0 calc(50% - 50vw);
}

@media screen and (min-width: 992px) {
  .c-crowdedOut-min {
    width: 100vw;
    margin: 0 calc(50% - 50vw);
  }
}

@media screen and (max-width: 991px) {
  .c-crowdedOut-max {
    margin: 0 calc(50% - 50vw);
  }
}

@media screen and (max-width: 991px) {
  .c-internalLink {
    scroll-margin-top: 2.5rem;
  }
}
.c-internalLink {
  scroll-margin-top: 5.75rem;
}

.c-animateSlide {
  top: 0;
  left: 0;
  width: 100%;
  height: 100svh;
  overflow: hidden;
}
.c-animateSlide.swiper {
  position: fixed;
}
.c-animateSlide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.c-animation-btn {
  position: relative;
  display: inline-block;
  display: flex;
  justify-content: center;
  width: 100%;
  width: 250px;
  max-width: 250px;
  padding: 10px;
  margin: auto;
  overflow: hidden;
  font-size: 16px;
  text-align: center;
  text-decoration: none;
  border: 1px solid #3a3a3a;
  outline: none;
  transition: ease 0.2s;
}

.c-animation-btn::before {
  position: absolute;
  top: 0;
  left: -130%;
  width: 120%;
  height: 104%;
  content: "";
  background: #3a3a3a;
  transform: skewX(-25deg);
}

.c-animation-btn:hover {
  text-decoration: none;
}

.c-animation-btn span {
  position: relative;
  z-index: 1;
}

.c-animation-btn:hover span {
  color: #fff;
}

.c-animation-btn:hover::before {
  content: "";
  animation: skewanime 0.5s forwards;
}

@keyframes skewanime {
  100% {
    left: -10%;
  }
}
.p-header {
  position: fixed;
  top: 0;
  z-index: 99;
  background-color: var(--h-bg-color, transparent);
}
@media screen and (max-width: 991px) {
  .p-header {
    --h-bg-color: var(--primary);
  }
}

.p-header--page {
  --h-bg-color: var(--primary);
}
@media screen and (min-width: 992px) {
  .p-header--page .p-header__item {
    color: var(--main-dark01);
  }
}

.l-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 5.75rem;
}
@media screen and (min-width: 992px) {
  .l-header {
    column-gap: 2.6875rem;
    padding: 1.75rem 2.3125rem;
  }
}
@media screen and (max-width: 991px) {
  .l-header {
    height: 2.5rem;
    padding: 0.75rem 0.625rem;
  }
}

.p-header__logo {
  width: 71.7948717949vw;
  max-width: 15.625rem;
}
@media screen and (min-width: 992px) {
  .p-header__logo {
    max-width: clamp(15.625rem, 5.6034482759rem + 16.1637931034vw, 25rem);
  }
}

.p-header__list {
  display: flex;
  align-items: center;
}
@media screen and (min-width: 992px) {
  .p-header__list {
    column-gap: clamp(1.5rem, 0.2306034483rem + 2.0474137931vw, 2.6875rem);
  }
}
@media screen and (max-width: 991px) {
  .p-header__list {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 99;
    flex-direction: column;
    row-gap: 0.9375rem;
    justify-content: center;
    width: 100%;
    min-height: 100svh;
    color: var(--main-dark);
    background-color: rgb(var(--base-light));
    transition: 0.4s transform ease-in-out;
    transform: translateX(100%);
  }
}

@media screen and (max-width: 991px) {
  .p-header__list > * + * {
    display: flex;
    justify-content: center;
    width: 80%;
    padding-top: 0.9375rem;
    border-top: 2px solid #fff;
  }
}

.p-header__list.is-active {
  transform: translateX(0);
}

.p-header__item {
  font-size: 1.125rem;
}
@media screen and (min-width: 992px) {
  .p-header__item {
    font-size: clamp(0.8125rem, 0.4784482759rem + 0.5387931034vw, 1.125rem);
  }
}
.p-header__item {
  font-weight: bold;
  color: var(--primary);
  white-space: nowrap;
}

.l-main {
  min-width: 0;
  padding-inline: 1.25rem;
  margin-inline: auto;
  padding-block: calc(1.875rem + var(--header-height)) 80px;
}
@media screen and (min-width: 992px) {
  .l-main {
    padding-block: calc(5rem + var(--header-height)) 20.8333333333vw;
    max-width: 80rem;
  }
}
@media screen and (min-width: 992px) {
  .page-template-page-contact .l-main {
    padding-block-end: 5rem;
  }
}
.page-template-product_takuya .l-main, .page-template-privaseeld .l-main, .page-template-product_taco .l-main {
  max-width: 100%;
  padding-block-start: 40px;
}
@media screen and (min-width: 992px) {
  .page-template-product_takuya .l-main, .page-template-privaseeld .l-main, .page-template-product_taco .l-main {
    padding-block-start: 92px;
  }
}
.l-main:has(.recruit-header) {
  max-width: 100%;
}
.l-main:has(.header-title) {
  padding-top: calc(var(--header-height) + 1rem);
}

.no-header-padding .l-main {
  padding-block-start: 0;
}

:where(.p-contentPage) {
  font-size: 1rem;
  line-height: 2;
}
@media screen and (min-width: 992px) {
  :where(.p-contentPage) {
    font-size: 1.125rem;
    line-height: 1.8;
  }
}

.p-contentPage__content :where(a) {
  color: #0056b3;
  text-decoration: underline;
}

.l-footer {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 992px) {
  .l-footer {
    min-height: 100svh;
    padding: 1.25rem;
  }
}
.l-footer {
  padding: 2.1875rem 10.2564102564vw;
}

.p-footer {
  background-color: var(--light-gray-light01);
}

.p-footer__picture {
  max-width: 19.1875rem;
  height: auto;
}
@media screen and (min-width: 992px) {
  .p-footer__picture {
    width: 100%;
    max-width: 25.875rem;
  }
}

.p-footer__navigation {
  width: 100%;
  max-width: 65.875rem;
  margin-top: 2.5rem;
}
@media screen and (min-width: 992px) {
  .p-footer__navigation {
    display: flex;
    justify-content: space-between;
    margin-top: 6.25rem;
  }
}
@media screen and (max-width: 991px) {
  .p-footer__navigation {
    display: grid;
    grid-template-columns: repeat(2, auto);
    row-gap: 1.9375rem;
    place-content: center;
    justify-content: space-between;
  }
}

.p-footer__block:nth-child(5) {
  grid-area: 3/2/4/3;
}

@media screen and (min-width: 992px) {
  .-pcWrap:is(.p-footer__item, .p-footer__block) {
    display: contents;
  }
}

@media screen and (max-width: 991px) {
  .p-footer__item.-sp-column {
    display: flex;
    flex-direction: column;
    row-gap: 1.9375rem;
  }
}

.p-footer__item {
  margin-top: 0.8125rem;
  font-size: 1.125rem;
  line-height: 1.9444444444;
  letter-spacing: 0.05em;
  font-weight: 500;
}
@media screen and (max-width: 991px) {
  .p-footer__item {
    font-size: clamp(0.75rem, 0.522082658rem + 0.9724473258vw, 1.125rem);
  }
}

.p-footer__item.-first {
  margin-top: 0;
  font-weight: 700;
}

.p-footer__copyright {
  margin-top: 6.25rem;
  font-size: 0.875rem;
  line-height: 1.7142857143;
  letter-spacing: 0.0642857143em;
  font-weight: 400;
}
@media screen and (max-width: 991px) {
  .p-footer__copyright {
    font-size: 0.625rem;
  }
}

@media screen and (max-width: 991px) {
  .l-contents.-sp {
    display: contents;
  }
}

@media screen and (min-width: 992px) {
  .l-contentPage {
    max-width: 60vw;
    margin-inline: auto;
  }
}
.l-contentPage {
  line-height: 2;
}

.l-grid {
  display: grid;
}

.l-grid[data-item~=center] {
  place-items: center;
}

@media screen and (min-width: 992px) {
  .l-grid[data-col~="md:col2"] {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media screen and (min-width: 992px) {
  .l-grid[data-col~="md:col4"] {
    grid-template-columns: repeat(4, 1fr);
  }
}

@media screen and (min-width: 576px) {
  .l-grid[data-col~="sm:col4"] {
    grid-template-columns: repeat(4, 1fr);
  }
}

@media screen and (max-width: 991px) {
  .l-grid[data-col~="min:col2"] {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media screen and (min-width: 992px) {
  .l-grid[data-col~="md:col3"] {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media screen and (min-width: 992px) {
  .l-grid[data-gap~="md:50vw"] {
    gap: 2.6041666667vw;
  }
}

@media screen and (min-width: 992px) {
  .l-grid[data-gap~="md:60vw"] {
    gap: 3.125vw;
  }
}

@media screen and (max-width: 991px) {
  .l-grid[data-gap~="min:40vw"] {
    gap: 10.2564102564vw;
  }
}

@media screen and (max-width: 991px) {
  .l-grid[data-gap~="min:28vw"] {
    gap: 7.1794871795vw;
  }
}

@media screen and (max-width: 991px) {
  .l-grid[data-gap~="min:24vw"] {
    gap: 6.1538461538vw;
  }
}

@media screen and (max-width: 991px) {
  .l-grid[data-rowGap~="min:40vw"] {
    row-gap: 10.2564102564vw;
  }
}

.l-grid[data-rowGap~="min:15px"] {
  row-gap: 15px;
}

.l-grid[data-col~=col3] {
  grid-template-columns: repeat(3, 1fr);
}

.l-grid[data-colGap~="md:30px"] {
  column-gap: 30px;
}

@media screen and (max-width: 991px) {
  .l-grid[data-colGap~="min:18px"] {
    column-gap: 1.125rem;
  }
}

.l-grid__item :where(img) {
  width: 100%;
}

:where(.l-split) {
  display: flex;
}

@media screen and (max-width: 991px) {
  .l-split[data-col~="min:col1"] {
    flex-direction: column;
  }
}

.l-split.-items-center {
  align-items: center;
}

.l-split.-center {
  align-items: center;
  justify-content: center;
}

.l-split[data-colGap~="md:15px"] {
  column-gap: 0.9375rem;
}

.l-split[data-colGap~="md:65px"] {
  column-gap: 4.0625rem;
}

@media screen and (min-width: 992px) {
  .l-split[data-colGap~="md:25px"] {
    column-gap: 1.5625rem;
  }
}

.l-split[data-colGap~="min:18px"] {
  column-gap: 1.125rem;
}

.l-split[data-rowGap~="min:18px"] {
  row-gap: 1.125rem;
}

@media screen and (min-width: 992px) {
  .l-split[data-colGap~="md:41px"] {
    column-gap: 2.5625rem;
  }
}

@media screen and (min-width: 992px) {
  .l-split[data-colGap~="md:12to41px"] {
    column-gap: clamp(0.75rem, -1.1875rem + 3.125vw, 2.5625rem);
  }
}

@media screen and (max-width: 991px) {
  .l-split[data-colGap~="min:8to22px"] {
    column-gap: clamp(0.5rem, 0.0827123696rem + 2.086438152vw, 1.375rem);
  }
}

@media screen and (max-width: 991px) {
  .l-split[data-colGap~="min:to22px"] {
    column-gap: 5.641025641vw;
  }
}

@media screen and (max-width: 991px) {
  .l-split[data-colGap~="min:to30px"] {
    column-gap: 7.6923076923vw;
  }
}

@media screen and (min-width: 992px) {
  .l-split[data-colGap~="md:61px"] {
    column-gap: 3.8125rem;
  }
}

.l-split[data-colGap~="md:133px"] {
  column-gap: 8.3125rem;
}

.l-split[data-colGap~="md:153px"] {
  column-gap: 9.5625rem;
}

@media screen and (min-width: 992px) {
  .l-split[data-colGap~="md:30px"] {
    column-gap: 30px;
  }
}

@media screen and (min-width: 992px) {
  .p-history {
    min-height: 100vh;
    padding: 11.25rem 0 5.625rem;
  }
}
@media screen and (max-width: 991px) {
  .p-history {
    padding: 3.125rem 0.9375rem;
    background-color: var(--light-gray-lightest);
  }
}

.p-history__column {
  display: flex;
  column-gap: 7.5rem;
}
@media screen and (max-width: 991px) {
  .p-history__column {
    flex-direction: column;
  }
}

@media screen and (max-width: 991px) {
  .p-history__stack:nth-child(1) {
    order: 2;
    margin-top: 1.5625rem;
  }
}

@media screen and (max-width: 991px) {
  .p-history__stack:nth-child(2) {
    display: contents;
  }
}

@media screen and (min-width: 992px) {
  .p-history__image {
    position: relative;
    z-index: 1;
    width: 100%;
    max-width: 28.125rem;
  }
}

@media screen and (min-width: 992px) {
  .p-history__image:nth-child(2) {
    margin-top: 3rem;
    margin-left: 28%;
  }
}

@media screen and (max-width: 991px) {
  .p-history__details {
    order: 3;
  }
}

.p-history__figure {
  position: relative;
}

@media screen and (min-width: 992px) {
  .p-history__image:first-child::after {
    position: absolute;
    top: -5rem;
    right: -6.25rem;
    z-index: 0;
    width: 15.625rem;
    height: 15.625rem;
    content: "";
    background: var(--primary);
  }
}

@media screen and (min-width: 992px) {
  .p-history__image:first-child::before {
    position: absolute;
    right: 20%;
    bottom: -140%;
    z-index: 0;
    width: 512px;
    height: 475px;
    content: "";
    background: var(--primary);
  }
}

@media screen and (max-width: 991px) {
  .p-history__head {
    width: 100%;
  }
}

@media screen and (max-width: 991px) {
  .p-history__description {
    width: 100%;
  }
}

@media screen and (min-width: 992px) {
  .p-mainRecruit {
    min-height: 100vh;
  }
}
.p-mainRecruit {
  background-color: rgb(var(--base-light)/85%);
}

.p-mainRecruit__column {
  height: 100%;
}
@media screen and (max-width: 991px) {
  .p-mainRecruit__column {
    padding: 3.125rem 0.9375rem;
  }
}

@media screen and (max-width: 991px) {
  .p-mainRecruit__left {
    order: 2;
  }
}

@media screen and (min-width: 992px) {
  .p-mainRecruit__right {
    padding: 2.5rem;
  }
}

.p-mainRecruit__image {
  object-fit: cover;
}
@media screen and (min-width: 992px) {
  .p-mainRecruit__image {
    height: 100%;
    min-height: 100vh;
  }
}

@media screen and (max-width: 991px) {
  .p-mainRecruit__textWraper {
    order: 1;
  }
}

@media screen and (max-width: 991px) {
  .p-mainRecruit__iconArea {
    justify-content: center;
    order: 3;
  }
}

@media screen and (min-width: 992px) {
  .p-newsText {
    position: absolute;
    top: calc(91.9831223629% - 0.3125rem);
    right: 5.2083333333vw;
    display: inline-flex;
    gap: 1.25rem;
    align-items: baseline;
    font-size: 1.375rem;
    line-height: 1.4545454545;
    letter-spacing: 0.0159090909em;
    font-weight: 400;
  }
}
.p-newsText {
  font-family: var(--dot-gothic);
  font-size: 0.875rem;
  line-height: 1.5714285714;
  letter-spacing: 0.0157142857em;
  font-weight: 400;
  color: var(--primary);
}

@media screen and (max-width: 991px) {
  .p-newsText.-pc {
    display: none;
  }
}

.p-newsText__spHead {
  display: flex;
  gap: 0.9375rem;
  align-items: center;
  white-space: nowrap;
}

@media screen and (max-width: 991px) {
  .p-newsText__spHead::after {
    flex-grow: 1;
    height: 1px;
    content: "";
    background-color: var(--primary);
  }
}

.p-newsText.-sp {
  display: inline-grid;
  gap: 8px;
  padding: 0 0.9375rem;
}
@media screen and (min-width: 992px) {
  .p-newsText.-sp {
    display: none;
  }
}

.p-newsText__more {
  margin-left: auto;
}

.p-newsText__secondary-color {
  color: var(--accent);
}

.p-newsText__date {
  font-size: 1rem;
}
@media screen and (max-width: 991px) {
  .p-newsText__date {
    font-size: 0.75rem;
  }
}

.p-newsText__body {
  max-width: 39.625rem;
}

.p-newsList {
  display: grid;
  place-content: center;
  background-color: rgb(var(--base-light)/85%);
  border-top: 1px solid var(--gray-darker);
  position: relative;
}
@media screen and (min-width: 992px) {
  .p-newsList {
    min-height: 50vh;
  }
}
@media screen and (max-width: 991px) {
  .p-newsList {
    padding-block: 3.125rem;
  }
}
.p-newsList {
  --swiper-pagination-bullet-inactive-color:#fff;
  --swiper-theme-color:#000;
  --swiper-pagination-bullet-inactive-opacity:0.5;
  --swiper-navigation-size:14px;
}

.p-newsList__stack {
  width: 100%;
  max-width: var(--inner);
  padding-inline: 0.9375rem;
  margin-inline: auto;
  overflow: hidden;
}
@media screen and (min-width: 992px) {
  .p-newsList__stack {
    padding-block: 3.75rem;
  }
}
.p-newsList__stack .swiper-button-prev,
.p-newsList__stack .swiper-button-next {
  background: #fff;
  padding: 18px;
  border-radius: 50%;
}

.p-newsList__head {
  display: flex;
  column-gap: 0.9375rem;
  align-items: center;
}
.p-newsList__head::after {
  display: inline-block;
  flex-grow: 1;
  height: 1px;
  content: "";
  background-color: var(--primary);
}
@media screen and (max-width: 991px) {
  .p-newsList__head {
    font-size: 0.875rem;
    line-height: 1.5714285714;
    letter-spacing: 0.0157142857em;
    font-weight: 400;
    padding-top: 3.125rem;
    font-family: var(--dot-gothic);
    color: var(--accent);
  }
}

.p-newsList__column {
  display: flex;
  column-gap: 1.5625rem;
  margin-top: 2.0625rem;
}

.p-newsList__thumnail {
  /* 	flex: 1; */
}
.p-newsList__thumnail img {
  width: 100%;
}

.p-productionEquipments__gear {
  position: relative;
}

.p-productionEquipments__image {
  transition: 0.6s all;
  transform: rotate(0deg);
}

.p-productionEquipments__gear:hover .p-productionEquipments__image {
  transform: rotate(180deg);
}

.p-productionEquipments__gear::after {
  position: absolute;
  inset: 0;
  display: inline-block;
  width: 100%;
  max-width: 32%;
  aspect-ratio: 1/1;
  margin: auto;
  content: "";
  background-size: cover;
}
@media screen and (min-width: 992px) {
  .p-productionEquipments__gear::after {
    max-width: 2.6041666667vw;
  }
}

.p-productionEquipments__item:first-child .p-productionEquipments__gear::after {
  background-image: var(--icon-amuse);
}

.p-productionEquipments__item:nth-child(2) .p-productionEquipments__gear::after {
  background-image: var(--icon-train);
}

.p-productionEquipments__item:nth-child(3) .p-productionEquipments__gear::after {
  background-image: var(--icon-info);
}

.p-productionEquipments__item:nth-child(4) .p-productionEquipments__gear::after {
  background-image: var(--icon-handotai);
}

.p-productionEquipments__text {
  margin-top: 0.6875rem;
  text-align: center;
  font-size: 0.875rem;
  line-height: 1.7142857143;
  letter-spacing: 0.1285714286em;
  font-weight: 500;
}
@media screen and (min-width: 992px) {
  .p-productionEquipments__text {
    font-size: 1.125rem;
    line-height: 2.4444444444;
    letter-spacing: 0.1em;
    font-weight: 500;
  }
}

.p-mainVisual {
  position: relative;
}
@media screen and (height <= 700px) {
  .p-mainVisual {
    height: 59.25rem;
  }
}
@media screen and (max-width: 991px) {
  .p-mainVisual {
    display: flex;
    height: fit-content;
    aspect-ratio: 16/9;
    margin-top: 2.5rem;
  }
}

.p-mainVisual__video {
  position: fixed;
  top: 0;
  z-index: -3;
  width: 100%;
  object-fit: cover;
}
@media screen and (min-width: 992px) {
  .p-mainVisual__video {
    height: 100svh;
  }
}
@media screen and (max-width: 991px) {
  .p-mainVisual__video {
    top: 2.5rem;
    aspect-ratio: 16/9;
  }
}

@media screen and (max-width: 991px) {
  .p-mainVisual__headWrapper {
    padding: 0.9375rem 0.625rem;
    margin-top: auto;
  }
}

.p-mainVisual__head {
  font-size: 1.375rem;
  line-height: 1.6363636364;
  letter-spacing: 0.07em;
  font-weight: 700;
}
@media screen and (min-width: 992px) {
  .p-mainVisual__head {
    position: absolute;
    top: 64.135021097%;
    left: 9.21875vw;
    font-size: 3.125vw;
    white-space: nowrap;
  }
}
@media screen and (min-width: 1920px) {
  .p-mainVisual__head {
    font-size: 3.75rem;
    line-height: 1.6666666667;
    letter-spacing: 0.07em;
    font-weight: 700;
  }
}
.p-mainVisual__head {
  color: var(--primary);
}

.p-solution {
  position: relative;
  display: grid;
  background-color: var(--primary);
}
@media screen and (max-width: 991px) {
  .p-solution {
    padding: 3.125rem 0.9375rem;
  }
}

@media screen and (min-width: 992px) {
  .p-solution__column {
    display: flex;
    gap: 5.875rem;
    align-items: flex-end;
    justify-content: center;
    width: 100%;
    padding: 8vw 0;
    margin-top: -10vw;
  }
}
@media screen and (max-width: 991px) {
  .p-solution__column {
    display: contents;
  }
}

@media screen and (min-width: 992px) {
  .p-solution__item.-right {
    position: relative;
    width: 40%;
    max-width: 48.125rem;
    padding-bottom: 2.5rem;
  }
}
@media screen and (max-width: 991px) {
  .p-solution__item.-right {
    display: contents;
  }
}

@media screen and (min-width: 992px) {
  .p-solution__item.-left {
    width: 40%;
  }
}
@media screen and (max-width: 991px) {
  .p-solution__item.-left {
    order: 2;
  }
}

@media screen and (min-width: 992px) {
  .p-solution__images {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    margin-left: 27%;
  }
}
@media screen and (max-width: 991px) {
  .p-solution__images {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.9375rem;
    margin-top: 0.9375rem;
  }
}

@media screen and (min-width: 992px) {
  .p-solution__image:nth-child(1) {
    position: relative;
    top: 1.25rem;
    left: -37%;
    z-index: 0;
  }
}

@media screen and (min-width: 992px) {
  .p-solution__image:nth-child(2) {
    position: relative;
    z-index: 1;
  }
}

@media screen and (min-width: 992px) {
  .p-solution__stack {
    position: relative;
    z-index: 1;
  }
}
@media screen and (max-width: 991px) {
  .p-solution__stack {
    display: contents;
  }
}

@media screen and (min-width: 992px) {
  .p-solution__item.-right::before {
    position: absolute;
    right: 0;
    z-index: 1;
    display: inline-block;
    width: 100%;
    max-width: 20.8333333333vw;
    aspect-ratio: 4/3;
    content: "";
    background-image: var(--logo-gear);
    background-repeat: no-repeat;
    background-size: contain;
  }
}

.p-solution__iconArea {
  justify-content: center;
  order: 3;
}

@media screen and (min-width: 992px) {
  .p-productInfo {
    min-height: 100vh;
  }
}
.p-productInfo {
  background-color: rgb(var(--base-light)/85%);
}

.p-productInfo__column {
  align-items: start;
}
@media screen and (min-width: 1920px) {
  .p-productInfo__column {
    padding: 0 13.375rem;
  }
}
@media screen and (min-width: 992px) {
  .p-productInfo__column {
    position: relative;
    top: -13vw;
    padding: 0 11.1458333333vw;
  }
}
.p-productInfo__column {
  padding: 3.125rem 0.9375rem;
}

.p-productInfo__stack {
  max-width: 40.625rem;
}

@media screen and (max-width: 991px) {
  .p-productInfo__item {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    padding-inline: 0.5rem;
    padding-top: 0.5rem;
    background: var(--primary);
  }
}
@media screen and (min-width: 992px) {
  .p-productInfo__item {
    position: relative;
    max-width: 15.9375rem;
    overflow: hidden;
  }
}

@media screen and (max-width: 991px) {
  .p-productInfo__logoWrapper {
    padding-block: 1rem;
  }
}
@media screen and (min-width: 992px) {
  .p-productInfo__logoWrapper {
    position: absolute;
    top: 0;
    left: 0;
    display: grid;
    place-content: center;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.5215686275);
    transition: 0.3s transform ease-in-out;
    transform: translateX(-100%);
  }
}

.p-productInfo__item:hover .p-productInfo__logoWrapper {
  transform: translateX(0);
}

@media screen and (min-width: 992px) {
  .p-productInfo__logoImage {
    width: 100%;
    max-width: 12.6875rem;
    padding-inline: 0.625rem;
  }
}

@media screen and (max-width: 991px) {
  .p-productInfo__iconArea {
    justify-content: center;
    order: 3;
  }
}

@media screen and (max-width: 991px) {
  .p-productInfo__innercolumn {
    margin-top: 1.25rem;
  }
}
@media screen and (min-width: 992px) {
  .p-productInfo__innercolumn {
    align-items: center;
  }
}

@media screen and (min-width: 992px) {
  .p-productInfo__image {
    height: 39.0625rem;
    object-fit: cover;
  }
}

@media screen and (min-width: 992px) {
  .p-equipmentIntroduction {
    min-height: 100svh;
  }
}
.p-equipmentIntroduction {
  background-color: var(--light-gray-light01);
}

@media screen and (min-width: 1920px) {
  .p-equipmentIntroduction__column {
    padding: 16.1875rem 8.375rem;
  }
}
@media screen and (min-width: 992px) {
  .p-equipmentIntroduction__column {
    padding: 13.4895833333vw 6.9791666667vw;
  }
}
.p-equipmentIntroduction__column {
  padding: 3.125rem 0.9375rem;
}
@media screen and (max-width: 991px) {
  .p-equipmentIntroduction__column {
    flex-direction: column;
  }
}

@media screen and (min-width: 992px) {
  .p-equipmentIntroduction__item {
    position: relative;
    z-index: 1;
  }
}

@media screen and (max-width: 991px) {
  .p-equipmentIntroduction__item:first-child {
    display: contents;
  }
}

@media screen and (max-width: 991px) {
  .p-equipmentIntroduction__item:nth-child(2) {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.125rem;
    order: 2;
    margin-top: 1.125rem;
  }
}

@media screen and (max-width: 991px) {
  .p-equipmentIntroduction__iconArea {
    display: none;
  }
}

@media screen and (max-width: 991px) {
  .p-equipmentIntroduction__factoryLogo {
    justify-content: center;
    margin-top: 1.125rem;
  }
}

@media screen and (min-width: 992px) {
  .p-equipmentIntroduction__head {
    position: relative;
  }
}
@media screen and (max-width: 991px) {
  .p-equipmentIntroduction__head {
    width: 100%;
  }
}

@media screen and (min-width: 992px) {
  .p-equipmentIntroduction__description {
    position: relative;
    max-width: 41.9375rem;
  }
}
@media screen and (max-width: 991px) {
  .p-equipmentIntroduction__description {
    width: 100%;
  }
}

@media screen and (min-width: 992px) {
  .p-equipmentIntroduction__description::after {
    position: absolute;
    top: 0;
    left: 0;
    left: -8.0625rem;
    z-index: -1;
    display: inline-block;
    width: 13.375rem;
    aspect-ratio: 1/1;
    content: "";
    background: rgba(227, 227, 227, 0.568627451);
  }
}

@media screen and (min-width: 992px) {
  .p-equipmentIntroduction__description::before {
    position: absolute;
    top: 0;
    top: 3.125rem;
    left: 0;
    left: -5rem;
    z-index: -1;
    display: inline-block;
    width: 13.375rem;
    aspect-ratio: 1/1;
    content: "";
    background: rgba(227, 227, 227, 0.568627451);
  }
}

@media screen and (min-width: 992px) {
  .p-equipmentIntroduction__item:first-child::before {
    position: absolute;
    top: -1.0416666667vw;
    right: 5.2083333333vw;
    display: inline-block;
    width: 13.5416666667vw;
    max-width: 16.25rem;
    aspect-ratio: 1/1;
    content: "";
    background-color: rgba(227, 227, 227, 0.568627451);
  }
}

.p-typewriter {
  font-family: "DotGothic16", sans-serif;
  font-feature-settings: "palt" 1;
}

.p-typewriter__cursor {
  display: inline-block;
  width: 2px;
  height: 1.75rem;
}
@media screen and (min-width: 768px) {
  .p-typewriter__cursor {
    height: 3.25rem;
  }
}
.p-typewriter__cursor {
  background-color: black;
  animation: blink 0.7s infinite;
}

@keyframes blink {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.p-table-info__list {
  display: grid;
  border: 1px solid #d0d1d2;
}
@media screen and (min-width: 992px) {
  .p-table-info__list {
    grid-template-columns: 20.5rem 1fr;
  }
}

:is(.p-table-info__data, .p-table-info__heading):not(:first-of-type) {
  border-top: 1px solid #d0d1d2;
}

.p-table-info__heading {
  display: grid;
  align-items: center;
}
@media screen and (min-width: 992px) {
  .p-table-info__heading {
    min-height: 7.375rem;
  }
}
.p-table-info__heading {
  min-height: 3.75rem;
  padding-inline: 1.5rem;
  background-color: #f0f0f0;
}

.p-table-info__data {
  display: grid;
  align-items: center;
  padding: 1.5rem;
}
@media screen and (min-width: 992px) {
  .p-table-info__data {
    border-left: 1px solid #d0d1d2;
  }
}

.p-tabParent {
  border-top: 1px solid var(--primary);
  border-right: 1px solid var(--primary);
  border-left: 1px solid var(--primary);
}
.p-tabParent.active {
  position: relative;
  padding-top: 1.375rem;
  padding-bottom: 1.25rem;
  border-top: 1px solid var(--color-gray-400);
  border-right: 1px solid var(--color-gray-400);
  border-left: 1px solid var(--color-gray-400);
}
.p-tabParent.active::after {
  position: absolute;
  bottom: -2px;
  z-index: 1;
  height: fit-content;
  width: 100%;
  border-bottom: 1px solid var(--color-gray-400);
  top: 0;
  content: "";
  background: var(--primary);
  border-top: 0.625rem solid var(--base-light-blue);
}

.p-tab__childWrap {
  flex-direction: column;
}

.p-tab__list {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  margin-bottom: clamp(48px, 3.125vw, 60px);
}
@media screen and (min-width: 992px) {
  .p-tab__list {
    gap: 2.25rem;
  }
}

.p-tabParent__list {
  margin-bottom: clamp(40px, 7.8125vw, 150px);
  border-bottom: 1px solid var(--color-gray-400);
}

.p-tab__contentItem {
  flex-direction: column;
}

.p-tab__item {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 33.3333%;
}
@media screen and (max-width: 991px) {
  .p-tab__item {
    font-size: 3.3333333333vw;
  }
}

.p-tab__button {
  position: relative;
  z-index: 2;
}

.p-recruit {
  font-size: 1.25rem;
  transition: opacity 0.4s ease-in-out;
}
@media screen and (width <= 991px) {
  .p-recruit {
    font-size: 0.8125rem;
  }
}

.p-recruit.isInvisible {
  opacity: 0;
}

.p-recruitTable {
  font-size: 0.875rem;
  line-height: 1.7142857143;
  letter-spacing: 0.1285714286em;
  font-weight: 400;
}
@media screen and (min-width: 768px) {
  .p-recruitTable {
    font-size: 1.125rem;
    line-height: 2.4444444444;
    letter-spacing: 0.1em;
    font-weight: 400;
  }
}
.p-recruitTable {
  margin-top: 0;
  margin-bottom: clamp(1rem, 6.25vw, 7.5rem);
}

.p-recruitTable__list {
  display: grid;
  row-gap: 10px;
}
.p-recruitTable__list:not(:first-child) {
  margin-top: 40px;
}

.p-recruitTable__childList {
  padding-left: 1em;
}

@media screen and (width >= 992px) {
  .p-recruitTable__head {
    width: 20.625rem;
    padding: 2.5rem;
  }
}
@media screen and (width <= 991px) {
  .p-recruitTable__head {
    display: block;
    padding: 1.125rem 0 0;
    font-size: 1rem;
    border-block-end: 0;
  }
  .p-recruitTable__head::before {
    display: inline-block;
    margin-right: 0.3125rem;
    content: "■";
  }
}
.p-recruitTable__head {
  vertical-align: top;
  background: var(--primary);
  border-block: solid 1px var(--gray-lighter01);
}

.p-recruitTable__row:first-child .p-recruitTable__head {
  border-block-start: solid 1px var(--gray-lighter01);
}

.p-recruitTable__data {
  border-block: solid 1px var(--gray-lighter01);
}
@media screen and (width >= 992px) {
  .p-recruitTable__data {
    padding: 2.5rem;
  }
}
@media screen and (width <= 991px) {
  .p-recruitTable__data {
    display: block;
    padding: 1.125rem 0;
    border-block: 0;
  }
}

.p-recruitTable__row:last-child .p-recruitTable__data {
  border-block-end: solid 1px var(--gray-lighter01);
}

.p-form > * + * {
  margin-top: 2.5rem;
}

.p-form__mark {
  display: inline-grid;
  grid-area: mark;
  align-self: baseline;
  padding: 0.75rem 1.75rem;
  color: var(--primary);
  text-align: center;
  background: var(--accent02);
  border-radius: 0.3125rem;
}
@media screen and (max-width: 991px) {
  .p-form__mark {
    padding: 5px 20px;
  }
}

.p-form__mark.--any {
  background: #c5c5c5;
}

.p-form__column {
  display: grid;
  grid-template-areas: "mark text" "input input";
  grid-template-columns: max-content 1fr;
  gap: 0.625rem 0.9375rem;
}
@media screen and (min-width: 992px) {
  .p-form__column {
    grid-template-areas: "mark text input";
    grid-template-columns: 6.1875rem max-content 1fr;
    column-gap: 3rem;
  }
}

.p-form__labelText {
  display: inline-grid;
  grid-area: text;
  align-self: baseline;
  font-weight: 500;
}
@media screen and (min-width: 992px) {
  .p-form__labelText {
    width: 21.875vw;
    max-width: 26.25rem;
  }
}

.p-form__input {
  grid-area: input;
}

.p-form__field {
  height: 3.25rem;
  border: 1px solid var(--gray-dark01);
}

:is(.p-form__input.p-form__tel input) {
  width: 100%;
  height: 3.25rem;
  border: 1px solid var(--gray-dark01);
}

.p-form__tel > span {
  display: flex;
  gap: 5px;
  align-items: center;
}

.p-form__field.--textarea {
  grid-area: 3/1/3/3;
  height: 11.25rem;
  border: 1px solid var(--gray-dark01);
}
@media screen and (min-width: 992px) {
  .p-form__field.--textarea {
    grid-area: 2/3/2/4;
  }
}

:is(.p-form__field input, .p-form__field textarea, .p-form__tel input) {
  width: 100%;
  height: 100%;
  padding: 0.5rem 0.375rem;
}

.p-form__select {
  width: 100%;
  height: 100%;
  padding: 0.825rem 1rem;
  appearance: none;
  cursor: pointer;
  border: 1px solid var(--gray-dark01);
}
@media screen and (min-width: 992px) {
  .p-form__select {
    width: 18.75rem;
    line-height: 1;
  }
}
@media screen and (max-width: 991px) {
  .p-form__select {
    height: 2.25rem;
    padding: 0.25rem 0.375rem;
    font-size: 0.8125rem;
    line-height: 1.3;
  }
}

.p-form__selectInner {
  position: relative;
}
@media screen and (min-width: 992px) {
  .p-form__selectInner {
    display: inline-block;
  }
}

.p-form__selectInner::before {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 0;
  display: inline-block;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: 100%;
  height: 100%;
  padding: 0 0.625rem;
  pointer-events: none;
  content: "▼";
}

.p-form__btn-wrap input {
  display: inline-block;
  width: 100%;
  padding: 0.825rem 1rem;
  font-size: 1.125rem;
  font-weight: 500;
  cursor: pointer;
  background: var(--primary);
  border: 1px solid #707070;
  transition: all 0.4s;
}
@media screen and (min-width: 576px) {
  .p-form__btn-wrap input {
    max-width: 18.75rem;
    height: 3.5625rem;
    line-height: 1.75rem;
  }
}
@media screen and (max-width: 991px) {
  .p-form__btn-wrap input {
    height: 2.25rem;
    padding: 0.25rem 0.375rem;
    font-size: 0.8125rem;
  }
}
.p-form__btn-wrap input:hover {
  color: #fff;
  background: #000;
}

.p-form__btn-wrap {
  margin-top: 1.875rem;
  text-align: center;
}

.p-information {
  margin-inline: auto;
}
@media screen and (min-width: 992px) {
  .p-information {
    width: 60%;
  }
}

.p-information__list {
  display: grid;
  gap: 24px;
  margin-top: 4rem;
}

.p-information__list > * + * {
  padding-top: 24px;
  border-top: 1px solid var(--light-gray-light01);
}

.p-information__item {
  display: grid;
  gap: 14px;
  font-size: 18px;
}
@media screen and (min-width: 992px) {
  .p-information__item {
    grid-template-columns: auto 1fr;
    gap: 24px;
  }
}

@media screen and (max-width: 991px) {
  .p-amusementEquipment__item:first-child {
    order: 2;
  }
  .p-amusementEquipment__item:nth-child(2) {
    order: 1;
  }
}

.p-amusementEquipment__products {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  justify-content: center;
}
@media screen and (min-width: 992px) {
  .p-amusementEquipment__products {
    gap: 30px;
  }
}

.p-amusementEquipment__product {
  width: calc(50% - 9px);
}
@media screen and (min-width: 992px) {
  .p-amusementEquipment__product {
    flex: 1;
  }
}

.p-otherProductionEquipment__figure.-border {
  position: relative;
}
.p-otherProductionEquipment__figure.-border::after {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  z-index: 2;
  display: inline-block;
  width: calc(100% - 17px);
  height: 100%;
  margin: auto;
  content: "";
  border: 1px solid #707070;
}

.u-spacer {
  margin-top: var(--space);
}

@media screen and (min-width: 992px) {
  .u-spacer[data-padding="mdBottom:15vw"] {
    padding-bottom: 15vw;
  }
}

@media screen and (min-width: 992px) {
  .u-spacer[data-padding~="px:60px"] {
    padding-inline: 3.75rem;
  }
}

@media screen and (min-width: 992px) {
  .u-spacer[data-space~="md:24vw"] {
    --space: 1.25vw;
  }
}

@media screen and (min-width: 992px) {
  .u-spacer[data-space~="md:32vw"] {
    --space: 1.6666666667vw;
  }
}

@media screen and (min-width: 992px) {
  .u-spacer[data-space~="md:55vw"] {
    --space: 2.8645833333vw;
  }
}

@media screen and (min-width: 992px) {
  .u-spacer[data-space~="md:61vw"] {
    --space: 3.1770833333vw;
  }
}

@media screen and (min-width: 992px) {
  .u-spacer[data-space~="md:100vw"] {
    --space: 5.2083333333vw;
  }
}

@media screen and (min-width: 992px) {
  .u-spacer[data-space~="md:120vw"] {
    --space: 6.25vw;
  }
}

@media screen and (min-width: 992px) {
  .u-spacer[data-space~="md:26px"] {
    --space: 1.625rem;
  }
}

@media screen and (min-width: 992px) {
  .u-spacer[data-space~="md:14px"] {
    --space: 0.875rem;
  }
}

@media screen and (min-width: 992px) {
  .u-spacer[data-space~="md:24px"] {
    --space: 1.5rem;
  }
}

@media screen and (min-width: 992px) {
  .u-spacer[data-space~="md:34px"] {
    --space: 2.125rem;
  }
}

@media screen and (min-width: 992px) {
  .u-spacer[data-space~="md:38px"] {
    --space: 2.375rem;
  }
}

@media screen and (min-width: 992px) {
  .u-spacer[data-space~="md:40px"] {
    --space: 2.5rem;
  }
}

@media screen and (min-width: 992px) {
  .u-spacer[data-space~="md:60px"] {
    --space: 3.75rem;
  }
}

@media screen and (min-width: 992px) {
  .u-spacer[data-space~="md:80vw"] {
    --space: 4.1666666667vw;
  }
}

@media screen and (min-width: 992px) {
  .u-spacer[data-space~="md:100px"] {
    --space: 6.25rem;
  }
}

@media screen and (min-width: 992px) {
  .u-spacer[data-space~="md:200px"] {
    --space: 12.5rem;
  }
}

@media screen and (max-width: 991px) {
  .u-spacer[data-space~="min:14px"] {
    --space: 0.875rem;
  }
}

@media screen and (max-width: 991px) {
  .u-spacer[data-space~="min:15px"] {
    --space: 0.9375rem;
  }
}

@media screen and (max-width: 991px) {
  .u-spacer[data-space~="min:18px"] {
    --space: 1.125rem;
  }
}

@media screen and (max-width: 991px) {
  .u-spacer[data-space~="min:20px"] {
    --space: 1.25rem;
  }
}

@media screen and (max-width: 991px) {
  .u-spacer[data-space~="min:27px"] {
    --space: 1.6875rem;
  }
}

@media screen and (max-width: 991px) {
  .u-spacer[data-space~="min:30px"] {
    --space: 1.875rem;
  }
}

@media screen and (max-width: 991px) {
  .u-spacer[data-space~="min:37px"] {
    --space: 2.3125rem;
  }
}

@media screen and (max-width: 991px) {
  .u-spacer[data-space~="min:16vw"] {
    --space: 4.1025641026vw;
  }
}

@media screen and (max-width: 991px) {
  .u-spacer[data-space~="min:20vw"] {
    --space: 5.1282051282vw;
  }
}

@media screen and (max-width: 991px) {
  .u-spacer[data-space~="min:28vw"] {
    --space: 7.1794871795vw;
  }
}

@media screen and (max-width: 991px) {
  .u-spacer[data-space~="min:40vw"] {
    --space: 10.2564102564vw;
  }
}

@media screen and (max-width: 991px) {
  .u-spacer[data-space~="min:60vw"] {
    --space: 15.3846153846vw;
  }
}

@media screen and (max-width: 991px) {
  .u-spacer[data-space~="min:80vw"] {
    --space: 20.5128205128vw;
  }
}

.u-aspect-cover {
  aspect-ratio: 16/9;
  object-fit: cover;
}

/* pc時非表示 */
@media screen and (min-width: 992px) {
  .u-dn-md-min {
    display: none;
  }
}

@media screen and (max-width: 991px) {
  .u-dn-md-max {
    display: none;
  }
}

/* Form Badge Utilities */
/* 必須バッジ用の背景色 */
.bg-required {
  background-color: #ff756b;
}

/* 任意バッジ用の背景色 */
.bg-optional {
  background-color: #9ca3af;
}

/* Mobile Menu Dialog Styles */
.mobile-menu-dialog {
  /* dialogのデフォルトスタイルをリセット */
  border: none;
  padding: 2.5rem; /* p-10相当 */
  max-height: 100vh;
  max-width: 100%;
  overflow: visible;
  /* dialogのデフォルト配置をオーバーライド */
  position: fixed;
  inset: unset;
  top: 0;
  right: 0;
  height: 100%;
  margin: 0;
  /* 初期状態: 画面外（右側） */
  transform: translateX(100%);
  transition: transform 300ms ease-in-out;
  /* スライドインアニメーション */
}
.mobile-menu-dialog.is-open {
  transform: translateX(0);
}
.mobile-menu-dialog {
  /* バックドロップのスタイル */
}
.mobile-menu-dialog::backdrop {
  background-color: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(2px);
  opacity: 0;
  transition: opacity 300ms ease-out;
}
.mobile-menu-dialog {
  /* is-openクラスがある時のバックドロップ */
}
.mobile-menu-dialog.is-open::backdrop {
  opacity: 1;
}