@charset "UTF-8";
/*--------------------------------------------------
Functions
--------------------------------------------------*/
/*--------------------------------------------------
Base
--------------------------------------------------*/
:root {
  --font-family: "メイリオ", "Hiragino Kaku Gothic ProN", "游ゴシック", "Yu Gothic", sans-serif;
  --font-size-base: 2rem;
  --common-black: #000000de;
  --common-white: #fff;
  --text-primary: #000000DE;
  --text-secondary: #00000099;
  --text-disabled: #00000061;
  --primary-main: #2563eb;
  --primary-dark: #1d4ed8;
  --primary-light: #42a5f5;
  --primary-contrast-text: #fff;
  --error-color: #dc2626;
  --action-active: #0000008f;
  --action-hover: #0000000a;
  --action-selected: #00000014;
  --action-disabled-background: #0000001f;
  --action-focus: #0000001f;
  --action-disabled: #00000061;
  --devider-color: #0000001f;
  --gray-50: #f9fafb;
  --gray-100: #f3f4f6;
  --gray-200: #e0e0e0;
  --gray-300: #d1d5db;
  --gray-400: #a0aec0;
  --gray-500: #9e9e9e;
  --gray-600: #6b7280;
  --gray-700: #374151;
  --gray-800: #1f2937;
  --box-shadow-1: 0px 1px 3px 0px rgba(0, 0, 0, 0.12),
    0px 1px 1px 0px rgba(0, 0, 0, 0.14),
    0px 2px 1px -1px rgba(0, 0, 0, 0.20);
  --box-shadow-2: 0px 1px 5px 0px rgba(0, 0, 0, 0.12),
    0px 2px 2px 0px rgba(0, 0, 0, 0.14),
    0px 3px 1px -2px rgba(0, 0, 0, 0.20);
  --box-shadow-3: 0px 1px 8px 0px rgba(0, 0, 0, 0.12),
    0px 3px 4px 0px rgba(0, 0, 0, 0.14),
    0px 3px 3px -2px rgba(0, 0, 0, 0.20);
  --box-shadow-4: 0px 1px 10px 0px rgba(0, 0, 0, 0.12),
    0px 4px 5px 0px rgba(0, 0, 0, 0.14),
    0px 2px 4px -1px rgba(0, 0, 0, 0.20);
  --box-shadow-5: 0px 1px 14px 0px rgba(0, 0, 0, 0.12),
    0px 5px 8px 0px rgba(0, 0, 0, 0.14),
    0px 3px 5px -1px rgba(0, 0, 0, 0.20);
  --box-shadow-6: 0px 1px 18px 0px rgba(0, 0, 0, 0.12),
    0px 6px 10px 0px rgba(0, 0, 0, 0.14),
    0px 3px 5px -1px rgba(0, 0, 0, 0.20);
  --transition-duration: 0.3s;
  --transition-easing: ease-in-out;
}

html {
  font-size: 1rem;
  line-height: 1.6;
  letter-spacing: 0.025em;
  -ms-touch-action: manipulation;
      touch-action: manipulation;
}

body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100dvh;
  max-height: 100svh;
  margin: 0;
  padding: 0;
  background-color: var(--gray-50);
  color: var(--text-primary);
  font-family: var(--font-family);
  font-size: 2rem;
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0.025em;
  -ms-touch-action: manipulation;
      touch-action: manipulation;
  overflow: hidden;
}
@media (max-width: 1024px) {
  body {
    height: 100dvh;
    max-height: 100svh;
  }
}
@media (max-width: 768px) {
  body {
    background-color: var(--common-white);
    font-size: 1.125rem;
  }
}

* {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  scrollbar-width: thin;
}

a {
  color: var(--text-primary);
}

@media (hover: hover) {
  a:hover {
    color: var(--text-secondary);
  }
}

button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  margin: 0;
  padding: 0;
  border: none;
  background: none;
  color: var(--text-primary);
  cursor: pointer;
}

img {
  max-width: 100%;
  height: auto;
}

.desktop_only {
  display: block;
}
@media (max-width: 768px) {
  .desktop_only {
    display: none;
  }
}

.mobile_only {
  display: none;
}
@media (max-width: 768px) {
  .mobile_only {
    display: block;
  }
}

/*--------------------------------------------------
Loading
--------------------------------------------------*/
/*--------------------------------------------------
Typography
--------------------------------------------------*/
.headline1 {
  font-size: 2.5rem;
  font-weight: 400;
}
@media (max-width: 768px) {
  .headline1 {
    font-size: 1.875rem;
  }
}

.headline2 {
  font-size: 1.5rem;
  font-weight: 400;
}
@media (max-width: 768px) {
  .headline2 {
    font-size: 1.25rem;
  }
}

.headline3 {
  font-size: 1.25rem;
  font-weight: 400;
}
@media (max-width: 768px) {
  .headline3 {
    font-size: 1.125rem;
  }
}

/*--------------------------------------------------
Layout
--------------------------------------------------*/
.container {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1.5rem;
  width: 100%;
  max-width: 1320px;
  padding-block: 1.5rem;
}
@media (max-width: 1024px) {
  .container {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0;
    max-width: none;
  }
}
@media (max-width: 768px) {
  .container {
    padding-bottom: 0;
  }
}

/*--------------------------------------------------
Form
--------------------------------------------------*/
.form-content {
  display: none;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100%;
}

.slide-item.active .form-content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.form-group {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  height: 100%;
  padding: 1.5rem;
  overflow-y: auto;
}
@media (max-width: 768px) {
  .form-group {
    padding-inline: 0.75rem;
  }
}

.form-section {
  width: 100%;
}

.form-section:not(:first-of-type) {
  margin-top: 1rem;
}

.form-section .input_groups {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}
@media (max-width: 768px) {
  .form-section .input_groups {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
}

.form-section-title {
  margin-bottom: 0.75rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--gray-200);
  color: var(--gray-800);
  font-size: var(--font-size-base);
  font-weight: bold;
}
@media (max-width: 768px) {
  .form-section-title {
    font-size: 1.25rem;
  }
}

.input_group {
  margin-bottom: 1.5rem;
  font-size: 1.125rem;
}
@media (max-width: 768px) {
  .input_group {
    margin: 0;
  }
}

.form-label {
  display: block;
  margin-bottom: 0.5rem;
  color: var(--gray-700);
  font-size: var(--font-size-base);
}
@media (max-width: 768px) {
  .form-label {
    font-size: 1.125rem;
  }
}

.form-control,
.form-select {
  width: 100%;
  min-height: 5rem;
  padding: 0.75rem 1rem;
  font-size: var(--font-size-base);
  border: 2px solid var(--gray-300);
  border-radius: 0.5rem;
  -webkit-transition: var(--transition-duration) var(--transition-easing);
  transition: var(--transition-duration) var(--transition-easing);
}
@media (max-width: 768px) {
  .form-control,
  .form-select {
    min-height: auto;
    font-size: 1.125rem;
  }
}

.form-select {
  padding-right: 2.25rem;
}

.form-control:focus,
.form-select:focus {
  outline: none;
  border-color: var(--primary-main);
  -webkit-box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.2);
          box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.2);
}

.form-control::-webkit-input-placeholder, .form-select::-webkit-input-placeholder {
  color: var(--gray-300);
}

.form-control::-moz-placeholder, .form-select::-moz-placeholder {
  color: var(--gray-300);
}

.form-control:-ms-input-placeholder, .form-select:-ms-input-placeholder {
  color: var(--gray-300);
}

.form-control::-ms-input-placeholder, .form-select::-ms-input-placeholder {
  color: var(--gray-300);
}

.form-control::placeholder,
.form-select::placeholder {
  color: var(--gray-300);
}

.form-text {
  font-size: 1.5rem;
}
@media (max-width: 768px) {
  .form-text {
    font-size: 1.125rem;
  }
}

input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* 住所 */
.zipcode-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
  max-width: 50%;
}
@media (max-width: 768px) {
  .zipcode-group {
    max-width: 100%;
  }
}

.form-select.prefecture {
  width: auto;
}

/* 生年月日 */
.birthdate-form .form-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.birthdate-form .form-section {
  width: 100%;
}

@media (max-width: 1024px) {
  .birthdate-form .form-section .input_groups {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
}

.birthdate-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  gap: 0.5rem;
}

.birthdate-group .form-control {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  min-height: 112px;
  text-align: center;
}
@media (max-width: 768px) {
  .birthdate-group .form-control {
    min-height: 72px;
  }
}

/* 性別 */
.gender-form .form-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.gender-form .form-section {
  width: 100%;
}

@media (max-width: 1024px) {
  .gender-form .form-section .input_groups {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
}

.gender-options {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5rem;
}

.gender-option {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  position: relative;
  cursor: pointer;
}
@media (max-width: 768px) {
  .gender-option {
    -webkit-box-flex: 1;
        -ms-flex: auto;
            flex: auto;
  }
}

.radio-option input {
  position: absolute;
  opacity: 0;
}

.radio-option .check-mark {
  display: none;
  position: absolute;
  top: 0;
  right: 0;
}

.custom-radio {
  position: relative;
  display: grid;
  place-items: center;
  width: 100%;
  min-height: 112px;
  padding: 0.75rem 1rem;
  font-size: var(--font-size-base);
  border: 2px solid var(--gray-300);
  border-radius: 0.5rem;
  background-color: var(--common-white);
  text-align: center;
  cursor: pointer;
  -webkit-transition: var(--transition-duration) var(--transition-easing);
  transition: var(--transition-duration) var(--transition-easing);
}
@media (max-width: 768px) {
  .custom-radio {
    min-height: 72px;
    font-size: 1.125rem;
  }
}

.custom-radio .radio-label {
  white-space: nowrap;
}

.radio-option input:checked + .custom-radio {
  border-color: var(--primary-main);
  background-color: rgba(25, 118, 210, 0.3019607843);
  color: var(--primary-main);
}

.radio-option input:checked + .custom-radio .check-mark {
  display: block;
}

/* 電話番号 */
.phone-form .form-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.phone-form .form-section {
  width: 100%;
}

.phone-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
}

.phone-group .form-control {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  min-height: 112px;
  text-align: center;
}
@media (max-width: 768px) {
  .phone-group .form-control {
    min-height: 72px;
  }
}

/* 確認 */
@media (max-width: 768px) {
  .confirm-value {
    font-size: 1.125rem;
  }
}

/*--------------------------------------------------
Stepper
--------------------------------------------------*/
.stepper {
  width: 15rem;
  height: 100%;
  max-height: calc(100vh - 3rem);
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media (max-width: 1024px) {
  .stepper {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto;
    height: auto;
  }
}

.stepper-inner {
  height: 100%;
  padding: 1rem;
  overflow-y: auto;
}
@media (max-width: 1024px) {
  .stepper-inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 1rem;
  }
}
@media (max-width: 768px) {
  .stepper-inner {
    gap: 0.5rem;
  }
}

.step {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1rem;
  margin-bottom: 2rem;
}
@media (max-width: 1024px) {
  .step {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 0;
    margin-bottom: 0;
  }
}

.step:not(:last-child)::after {
  content: "";
  position: absolute;
  left: 1.5rem;
  top: 3rem;
  z-index: -2;
  width: 2px;
  height: calc(100% + 1rem);
  background-color: var(--gray-200);
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media (max-width: 1024px) {
  .step:not(:last-child)::after {
    top: 50%;
    left: calc(100% + 1rem);
    width: 2rem;
    height: 4px;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
  }
}

.step.active .step-number {
  position: relative;
  background-color: var(--primary-main);
  color: var(--common-white);
}

.step.active .step-number::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: -1;
  width: 130%;
  height: 130%;
  background-color: var(--common-white);
  border-radius: 50%;
  border: 2px solid var(--primary-main);
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.step-number {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 3rem;
  height: 3rem;
  background-color: var(--gray-200);
  border-radius: 50%;
  color: var(--text-disabled);
  font-weight: bold;
  font-size: 1.25rem;
  font-size: var(--font-size-base);
}
@media (max-width: 1024px) {
  .step-number {
    width: 2.5rem;
    height: 2.5rem;
    font-size: 1rem;
    font-size: var(--font-size-base);
  }
}
@media (max-width: 768px) {
  .step-number {
    width: 1.75rem;
    height: 1.75rem;
  }
}

@media (max-width: 1024px) {
  .step-number .number {
    display: none;
  }
}

.step.active .step-title {
  color: var(--text-primary);
}

.step-title {
  font-weight: bold;
  font-size: var(--font-size-base);
  color: var(--text-disabled);
}
@media (max-width: 1024px) {
  .step-title {
    display: none;
  }
}

/*--------------------------------------------------
Buttons
--------------------------------------------------*/
.btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-width: 4.5rem;
  min-height: 2.5rem;
  padding: 0.5rem 1rem;
  border: none;
  border-radius: 0.5rem;
  background: var(--gray-200);
  -webkit-box-shadow: var(--box-shadow-2);
          box-shadow: var(--box-shadow-2);
  color: var(--primary-main);
  font-size: var(--font-size-base);
  font-weight: bold;
  cursor: pointer;
  opacity: 1;
  text-transform: uppercase;
  -webkit-transition: background-color var(--transition-duration) var(--transition-easing), -webkit-box-shadow var(--transition-duration) var(--transition-easing);
  transition: background-color var(--transition-duration) var(--transition-easing), -webkit-box-shadow var(--transition-duration) var(--transition-easing);
  transition: background-color var(--transition-duration) var(--transition-easing), box-shadow var(--transition-duration) var(--transition-easing);
  transition: background-color var(--transition-duration) var(--transition-easing), box-shadow var(--transition-duration) var(--transition-easing), -webkit-box-shadow var(--transition-duration) var(--transition-easing);
}
@media (max-width: 768px) {
  .btn {
    font-size: 1.125rem;
  }
}

.btn-sm {
  padding: 0.25rem 0.625rem;
  min-width: 3.875rem;
  min-height: 1.875rem;
}

.btn-lg {
  padding: 0.75rem 1.25rem;
  min-width: 5.125rem;
  min-height: 3.125rem;
}

@media (hover: hover) {
  .btn:hover {
    background-color: var(--gray-100);
    -webkit-box-shadow: var(--box-shadow-4);
            box-shadow: var(--box-shadow-4);
  }
}

.btn:active {
  background-color: var(--gray-500);
  -webkit-box-shadow: var(--box-shadow-6);
          box-shadow: var(--box-shadow-6);
}

.btn:disabled {
  background-color: var(--action-disabled-background);
  color: var(--action-disabled);
  -webkit-box-shadow: none;
          box-shadow: none;
  opacity: 1;
}

.btn-primary {
  background: var(--primary-main);
  color: var(--primary-contrast-text);
}

@media (hover: hover) {
  .btn-primary:hover {
    background: var(--primary-dark);
    color: var(--primary-contrast-text);
  }
}

.btn-primary:active {
  background: var(--primary-light);
  color: var(--primary-contrast-text);
}

.btn-outline {
  border: 1px solid rgba(0, 0, 0, 0.87);
  background-color: var(--common-white);
  color: rgba(0, 0, 0, 0.87);
  -webkit-box-shadow: none;
          box-shadow: none;
}

@media (hover: hover) {
  .btn-outline:hover {
    border: 1px solid rgba(0, 0, 0, 0.87);
    background: rgba(0, 0, 0, 0.04);
    -webkit-box-shadow: none;
            box-shadow: none;
  }
}

.btn-outline:disabled {
  border: 1px solid rgba(0, 0, 0, 0.12);
  color: rgba(0, 0, 0, 0.38);
  -webkit-box-shadow: none;
          box-shadow: none;
}

.btn-outline-primary {
  border: 1px solid var(--primary-main);
  color: var(--primary-main);
}

@media (hover: hover) {
  .btn-outline-primary:hover {
    border: 1px solid rgba(25, 118, 210, 0.5);
    background: rgba(25, 118, 210, 0.04);
    color: var(--primary-main);
  }
}

.btn-outline-primary:active {
  background: rgba(25, 118, 210, 0.3019607843) !important;
  color: var(--primary-main) !important;
}

/*--------------------------------------------------
Link
--------------------------------------------------*/
.link-underline-primary {
  padding: 0.75rem 1.25rem;
  min-width: 5.125rem;
  min-height: 3.125rem;
  color: var(--primary-main);
  -webkit-text-decoration: underline currentColor;
          text-decoration: underline currentColor;
  -webkit-transition: var(--transition-duration) var(--transition-easing);
  transition: var(--transition-duration) var(--transition-easing);
}
@media (max-width: 768px) {
  .link-underline-primary {
    font-size: 1.125rem;
  }
}

@media (hover: hover) {
  .link-underline-primary:hover {
    color: var(--primary-dark);
    background: var(--action-hover);
    -webkit-box-shadow: none;
            box-shadow: none;
  }
}

/*--------------------------------------------------
会員登録
--------------------------------------------------*/
/* メインコンテンツ */
.main-content {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  width: 100%;
  height: calc(100dvh - 3rem);
  max-height: calc(100svh - 3rem);
  overflow: hidden;
}
@media (max-width: 1024px) {
  .main-content {
    height: calc(100dvh - 48px - 72px);
    max-height: calc(100svh - 48px - 72px);
  }
}
@media (max-width: 768px) {
  .main-content {
    height: calc(100dvh - 1.5rem - 3.75rem);
    max-height: calc(100svh - 1.5rem - 3.75rem);
  }
}

.task-title {
  display: none;
  margin: 0;
  font-size: var(--font-size-base);
  font-weight: bold;
  text-align: center;
}
@media (max-width: 1024px) {
  .task-title {
    display: block;
    padding-bottom: 0.67em;
  }
}
@media (max-width: 768px) {
  .task-title {
    font-size: 1.125rem;
    border-bottom: 1px solid var(--gray-200);
  }
}

.registration-form {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  height: 100%;
  padding: 0.5rem;
}
@media (max-width: 768px) {
  .registration-form {
    padding: 0;
  }
}

.form-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  width: 100%;
  height: 100%;
  border-radius: 0.75rem;
  background-color: var(--common-white);
  -webkit-box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
          box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
}
@media (max-width: 1024px) {
  .form-container {
    height: calc(100dvh - 3rem - 4.5rem - 3.75rem - 1rem);
    max-height: calc(100svh - 3rem - 4.5rem - 3.75rem - 1rem);
  }
}
@media (max-width: 768px) {
  .form-container {
    height: calc(100dvh - 1.5rem - 3.75rem - 2.125rem);
    max-height: calc(100svh - 1.5rem - 3.75rem - 2.125rem);
    border-radius: 0;
    -webkit-box-shadow: none;
            box-shadow: none;
  }
}

/* Slider */
.slide-container {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: calc(100% - 6.5625rem);
  -webkit-transition: -webkit-transform var(--transition-duration) var(--transition-easing);
  transition: -webkit-transform var(--transition-duration) var(--transition-easing);
  transition: transform var(--transition-duration) var(--transition-easing);
  transition: transform var(--transition-duration) var(--transition-easing), -webkit-transform var(--transition-duration) var(--transition-easing);
}
@media (max-width: 1024px) {
  .slide-container {
    height: 100%;
    max-height: calc(100% - 6.5625rem);
  }
}
@media (max-width: 768px) {
  .slide-container {
    max-height: calc(100% - 5.25rem);
  }
}

.slide-item {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 100%;
          flex: 0 0 100%;
}

/* 利用規約 */
.terms-container {
  max-height: 15rem;
  padding: 0.625rem;
  border: 1px solid var(--gray-300);
  background-color: var(--gray-50);
  font-size: 1rem;
  overflow-y: auto;
}

.terms-box,
.privacy-box {
  margin-bottom: 2rem;
}

.terms-container h2 {
  margin-bottom: 2rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid currentColor;
  font-size: 1.125rem;
  font-weight: bold;
}

.terms-container h3 {
  margin: 1rem 0;
  font-size: 1.125rem;
  font-weight: bold;
}

.terms-container h4 {
  margin: 1.5rem 0 1rem;
  font-size: 1.1rem;
  font-weight: bold;
}

.terms-container p {
  margin-bottom: 1rem;
}

.terms-container ul,
.terms-container ol {
  margin: 1rem 0;
  padding-left: 1.5rem;
}

.terms-container ol {
  padding-left: 2.5rem;
  list-style: auto;
}

.terms-container li {
  margin-bottom: 0.5rem;
}

.terms-container .section {
  margin-bottom: 2rem;
}

.terms-container .note {
  margin-top: 1rem;
  font-size: 0.9rem;
}

.terms-container .contact-info {
  padding: 1.5rem;
}

.terms-container address {
  margin-top: 1rem;
}

/* ボタン */
.button-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.5rem;
  border-top: 1px solid var(--gray-200);
}
@media (max-width: 768px) {
  .button-container {
    padding-inline: 0.75rem;
  }
}

.prev-btn {
  display: block;
  margin-right: auto;
}

.next-btn {
  display: block;
  margin-left: auto;
  min-width: 12.5rem;
}
@media (max-width: 768px) {
  .next-btn {
    min-width: 7.5rem;
  }
}

/*--------------------------------------------------
登録完了
--------------------------------------------------*/
.page-thanks {
  background-color: var(--common-white);
}

.page-thanks .container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0;
  padding: 1.5rem;
  text-align: center;
}

.page-thanks .logo {
  width: 100%;
  max-width: 18.5rem;
  margin: 0 auto 2.5rem;
}
@media (max-width: 768px) {
  .page-thanks .logo {
    max-width: 12.5rem;
  }
}

.page-thanks .headline1 {
  font-weight: bold;
}
@media (max-width: 768px) {
  .page-thanks .headline1 {
    font-size: 1.875rem;
  }
}

.page-thanks .btn-home {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 2.5rem auto 0;
}

/*--------------------------------------------------
店舗選択
--------------------------------------------------*/
.page-store-selection .page-title {
  word-break: keep-all;
  text-align: center;
}
@media (max-width: 768px) {
  .page-store-selection .page-title {
    margin-top: 0;
    font-size: 1.25rem;
  }
}

.page-store-selection .form {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.page-store-selection .form-container {
  height: 100%;
  max-height: none;
  -webkit-box-shadow: none;
          box-shadow: none;
}

.page-store-selection .form-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media (max-width: 768px) {
  .page-store-selection .form-group {
    display: block;
  }
}

.store-options {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5rem;
}
@media (max-width: 768px) {
  .store-options {
    grid-template-columns: 1fr;
  }
}

.page-store-selection .button-container {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.page-store-selection .clear-btn {
  min-width: 12.5rem;
}

/*--------------------------------------------------
カード確認
--------------------------------------------------*/
.page-card-verification {
  height: auto;
  max-height: none;
  overflow: auto;
}

.page-card-verification .container {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media (max-width: 768px) {
  .page-card-verification .container {
    margin-bottom: 1.5rem;
  }
}

.page-card-verification .page-header {
  text-align: center;
}

.page-card-verification .page-header .description {
  word-break: keep-all;
}
@media (max-width: 768px) {
  .page-card-verification .page-header .description {
    word-break: break-word;
  }
}

.page-card-verification .form-container {
  height: auto;
  max-height: none;
  background-color: transparent;
  -webkit-box-shadow: none;
          box-shadow: none;
}

.page-card-verification .button-container {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border: none;
}

.page-card-verification .button-container .btn-submit {
  width: 80%;
  margin: 0 auto;
}

.page-card-verification .card-image-container {
  margin-top: 1.5rem;
  text-align: center;
}

.page-card-verification .card-image {
  width: 100%;
  max-width: 35rem;
  margin: 0 auto 0.5rem;
}

.page-card-verification .card-image-container .description {
  word-break: keep-all;
}