/* ========== 登录 / 注册 / 忘记密码 ========== */
.vape-auth-page .ec-layoutRole__main { display: block; }

.vape-auth {
  max-width: 440px;
  margin: 0 auto;
  padding: 40px 20px 80px;
}

.vape-auth--wide { max-width: 520px; }

.vape-auth__card {
  padding: 32px 28px;
  background: var(--vape-bg-card);
  border: 1px solid var(--vape-border);
  border-radius: var(--vape-radius-lg);
}

.vape-auth__card--center { text-align: center; }

.vape-auth__head { text-align: center; margin-bottom: 28px; }

.vape-auth__icon {
  width: 56px;
  height: 56px;
  margin: 0 auto 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--vape-brand-dim);
  color: var(--vape-brand);
  font-size: 24px;
}

.vape-auth__icon--lg {
  width: 72px;
  height: 72px;
  font-size: 32px;
  margin-bottom: 20px;
}

.vape-auth__title {
  font-size: 1.5rem;
  margin: 0 0 8px;
}

.vape-auth__subtitle {
  font-size: 1.125rem;
  color: var(--vape-text-muted);
  margin: 0 0 12px;
  font-weight: 600;
}

.vape-auth__sub {
  margin: 0;
  font-size: 13px;
  color: var(--vape-text-dim);
  line-height: 1.6;
}

.vape-auth__form { display: flex; flex-direction: column; gap: 16px; }

.vape-auth__submit { width: 100%; }

.vape-auth__links {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid var(--vape-border);
  text-align: center;
  font-size: 14px;
}

.vape-form-field { display: flex; flex-direction: column; gap: 6px; }

.vape-form-stack { display: flex; flex-direction: column; gap: 20px; margin-bottom: 24px; }

.vape-form-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--vape-text-dim);
}

.vape-input,
body.vape-theme.mypage .ec-input input,
body.vape-theme.mypage .ec-input textarea,
body.vape-theme.mypage .ec-input select,
body.vape-theme.mypage .ec-select select,
body.vape-theme.mypage .ec-birth select,
body.vape-theme.mypage .ec-zipInput input,
body.vape-theme.mypage .ec-telInput input,
body.vape-theme.mypage .ec-halfInput input {
  width: 100%;
  padding: 12px 14px;
  background: var(--vape-bg-elevated);
  border: 1px solid var(--vape-border);
  border-radius: var(--vape-radius);
  color: var(--vape-text);
  font-family: var(--vape-font-ja);
  font-size: 14px;
  transition: border-color var(--vape-transition);
}

.vape-input:focus,
body.vape-theme.mypage .ec-input input:focus,
body.vape-theme.mypage .ec-select select:focus {
  outline: none;
  border-color: var(--vape-brand);
}

.vape-form-check label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--vape-text-muted);
  cursor: pointer;
}

.vape-form-check input[type="checkbox"] {
  accent-color: var(--vape-brand);
}

.vape-form-error,
body.vape-theme.mypage .ec-errorMessage,
body.vape-theme.mypage .form-error-message {
  margin: 4px 0 0;
  font-size: 12px;
  color: var(--vape-danger);
}

/* ========== 会員登録 /entry ========== */
body.vape-theme.vape-entry-page .vape-layout__main {
  padding-top: 28px;
  padding-bottom: 80px;
}

.vape-entry {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 20px;
}

.vape-entry__header {
  text-align: center;
  margin-bottom: 28px;
}

.vape-entry__header--center {
  margin-bottom: 24px;
}

.vape-entry__icon {
  width: 56px;
  height: 56px;
  margin: 0 auto 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--vape-brand-dim);
  color: var(--vape-brand);
  font-size: 24px;
}

.vape-entry__icon--success {
  width: 72px;
  height: 72px;
  font-size: 32px;
  background: rgba(6, 199, 85, 0.12);
  color: #06c755;
}

.vape-entry h1,
.vape-entry h2 {
  margin-left: 0;
  margin-right: 0;
}

.vape-entry__title {
  margin: 0 0 10px;
  font-size: clamp(1.35rem, 3vw, 1.75rem);
  font-weight: 700;
  color: var(--vape-text);
}

.vape-entry__subtitle {
  margin: 0 0 12px;
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--vape-text-muted);
}

.vape-entry__lead {
  margin: 0 0 20px;
  font-size: 14px;
  line-height: 1.7;
  color: var(--vape-text-muted);
}

.vape-entry-steps {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
}

.vape-entry-steps__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  min-width: 88px;
  position: relative;
  color: var(--vape-text-dim);
}

.vape-entry-steps__item:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 16px;
  left: calc(50% + 22px);
  width: calc(100% - 44px);
  height: 2px;
  background: var(--vape-border);
  pointer-events: none;
}

.vape-entry-steps__item.is-done:not(:last-child)::after {
  background: var(--vape-brand);
}

.vape-entry-steps__num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 2px solid var(--vape-border);
  background: var(--vape-bg-card);
  font-family: var(--vape-font-en);
  font-size: 13px;
  font-weight: 700;
}

.vape-entry-steps__item.is-active .vape-entry-steps__num,
.vape-entry-steps__item.is-done .vape-entry-steps__num {
  border-color: var(--vape-brand);
  background: var(--vape-brand);
  color: var(--vape-on-brand);
}

.vape-entry-steps__label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
}

.vape-entry-steps__item.is-active {
  color: var(--vape-brand);
}

.vape-entry-steps__item.is-done {
  color: var(--vape-text-muted);
}

.vape-entry__benefits {
  margin-bottom: 20px;
  padding: 14px 18px;
  background: var(--vape-brand-dim);
  border: 1px solid rgba(0, 168, 142, 0.2);
  border-radius: var(--vape-radius);
}

.vape-entry__benefits-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 20px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.vape-entry__benefits-list li {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--vape-text-muted);
}

.vape-entry__benefits-list i {
  color: var(--vape-brand);
  font-size: 14px;
}

.vape-entry__card {
  padding: 28px 24px 24px;
  background: var(--vape-bg-card);
  border: 1px solid var(--vape-border);
  border-radius: var(--vape-radius-lg);
}

.vape-entry__card--center {
  text-align: center;
  padding: 32px 28px;
}

.vape-entry__section + .vape-entry__section {
  margin-top: 28px;
  padding-top: 28px;
  border-top: 1px solid var(--vape-border);
}

.vape-entry__section-title {
  margin: 0 0 16px;
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--vape-brand);
  text-transform: uppercase;
}

.vape-entry .ec-borderedDefs > dl {
  display: grid;
  grid-template-columns: minmax(120px, 28%) 1fr;
  gap: 12px 20px;
  margin: 0;
  padding: 16px 0;
  border-bottom: 1px solid var(--vape-border);
}

.vape-entry .ec-borderedDefs > dl:first-child {
  padding-top: 0;
}

.vape-entry .ec-borderedDefs > dl:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.vape-entry .ec-borderedDefs dt {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  align-content: flex-start;
  gap: 6px 8px;
  margin: 0;
  padding-top: 10px;
}

.vape-entry .ec-borderedDefs dt .ec-label {
  display: inline;
  margin: 0;
  font-size: 13px;
  font-weight: 600;
  color: var(--vape-text);
  line-height: 1.5;
}

/* 必須バッジ（form_div_layout.twig の span.ec-required） */
.vape-entry .ec-borderedDefs dt .ec-required,
body.vape-theme.vape-entry-page .ec-required {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin: 0;
  padding: 2px 7px;
  border-radius: 4px;
  background: rgba(224, 62, 62, 0.1);
  border: 1px solid rgba(224, 62, 62, 0.35);
  color: var(--vape-danger);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.35;
  vertical-align: middle;
  white-space: nowrap;
}

/* 任意項目（拡張フィールド等で付く場合） */
.vape-entry .ec-borderedDefs dt .ec-required--optional,
body.vape-theme .ec-required--optional {
  background: var(--vape-bg-elevated);
  border-color: var(--vape-border);
  color: var(--vape-text-dim);
  font-weight: 600;
}

.vape-entry .ec-borderedDefs dd {
  margin: 0;
  min-width: 0;
}

.vape-entry .ec-halfInput {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.vape-entry .ec-input,
.vape-entry .ec-telInput,
.vape-entry .ec-zipInput,
.vape-entry .ec-select,
.vape-entry .ec-birth,
.vape-entry .ec-radio {
  margin-bottom: 10px;
}

.vape-entry .ec-input:last-child,
.vape-entry .ec-telInput:last-child,
.vape-entry .ec-select:last-child {
  margin-bottom: 0;
}

.vape-entry .ec-input input,
.vape-entry .ec-input textarea,
.vape-entry .ec-select select,
.vape-entry .ec-zipInput input,
.vape-entry .ec-telInput input,
.vape-entry .ec-halfInput input,
.vape-entry .ec-birth select {
  width: 100%;
  padding: 12px 14px;
  background: var(--vape-bg-elevated);
  border: 1px solid var(--vape-border);
  border-radius: var(--vape-radius);
  color: var(--vape-text);
  font-family: var(--vape-font-ja);
  font-size: 14px;
  transition: border-color var(--vape-transition);
}

.vape-entry .ec-input input:focus,
.vape-entry .ec-select select:focus,
.vape-entry .ec-zipInput input:focus,
.vape-entry .ec-telInput input:focus,
.vape-entry .ec-halfInput input:focus,
.vape-entry .ec-birth select:focus {
  outline: none;
  border-color: var(--vape-brand);
}

.vape-entry .ec-birth {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.vape-entry .ec-birth select {
  width: auto;
  min-width: 5rem;
  flex: 1 1 auto;
}

.vape-entry .ec-birth span {
  color: var(--vape-text-dim);
}

.vape-entry .ec-radio {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 20px;
}

.vape-entry .ec-radio label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  color: var(--vape-text-muted);
  cursor: pointer;
}

.vape-entry .ec-radio input {
  accent-color: var(--vape-brand);
}

.vape-entry .ec-zipInput,
.vape-entry .ec-zipInputHelp {
  font-size: 13px;
  color: var(--vape-text-dim);
}

.vape-entry .ec-zipInputHelp {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
}

.vape-entry .ec-zipInputHelp a {
  color: var(--vape-brand);
}

.vape-entry .ec-errorMessage,
.vape-entry .form-error-message {
  margin-top: 6px;
  font-size: 12px;
  color: var(--vape-danger);
}

.vape-entry .error input,
.vape-entry .error select,
.vape-entry .error textarea {
  border-color: var(--vape-danger);
}

.vape-entry__actions {
  margin-top: 28px;
  padding-top: 24px;
  border-top: 1px solid var(--vape-border);
}

.vape-entry__policy label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
  line-height: 1.65;
  color: var(--vape-text-muted);
  cursor: pointer;
}

.vape-entry__policy input[type="checkbox"] {
  margin-top: 3px;
  accent-color: var(--vape-brand);
  flex-shrink: 0;
}

.vape-entry__policy a {
  color: var(--vape-brand);
}

.vape-entry__buttons {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 20px;
}

.vape-entry__buttons--single {
  max-width: 320px;
  margin-left: auto;
  margin-right: auto;
}

.vape-entry__buttons .vape-btn {
  width: 100%;
  justify-content: center;
}

.vape-entry__login-hint {
  margin: 24px 0 0;
  text-align: center;
  font-size: 14px;
  color: var(--vape-text-dim);
}

.vape-entry__login-hint a {
  color: var(--vape-brand);
  font-weight: 600;
}

.vape-entry__confirm-value {
  margin: 0;
  padding: 10px 0;
  font-size: 14px;
  line-height: 1.7;
  color: var(--vape-text);
  word-break: break-word;
}

.vape-entry--confirm .vape-entry__confirm-defs dl {
  padding: 14px 0;
}

.vape-entry__complete-text {
  margin: 0 0 28px;
  font-size: 14px;
  line-height: 1.85;
  color: var(--vape-text-muted);
}

/* 旧 EC レイアウトが残る場合の抑止 */
body.vape-theme.vape-entry-page .ec-registerRole .ec-pageHeader,
body.vape-theme.vape-entry-page .ec-registerCompleteRole .ec-pageHeader {
  display: none;
}

@media screen and (max-width: 768px) {
  .vape-entry {
    padding: 0 16px;
  }

  .vape-entry__card {
    padding: 22px 16px 20px;
  }

  .vape-entry .ec-borderedDefs > dl {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 14px 0;
  }

  .vape-entry .ec-borderedDefs dt {
    padding-top: 0;
  }

  .vape-entry .ec-halfInput {
    grid-template-columns: 1fr;
  }

  .vape-entry__benefits-list {
    flex-direction: column;
    gap: 8px;
  }

  .vape-entry-steps__item {
    min-width: 72px;
  }

  .vape-entry-steps__item:not(:last-child)::after {
    left: calc(50% + 18px);
    width: calc(100% - 36px);
  }
}

