/* ============================================================
   Auth 페이지 (login, adult_verify) — mobile-first
   ============================================================ */

/* ── 공통 심플 헤더 ───────────────────────────────────────── */
.login-page-header,
.adult-page-header {
  background: var(--mute-7, #f8f8f8);
  border-bottom: 1px solid var(--mute-5, #ddd);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px 0;
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--mute-1, #333);
}

/* ── 로그인 페이지 ────────────────────────────────────────── */
.login-page {
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
  padding: 24px var(--container-px) 60px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

.login-page__logo {
  display: block;
  text-align: center;
}

.login-page__logo img {
  width: 200px;
  height: auto;
  object-fit: contain;
}

/* 로그인 + 성인 안내 (Figma PC Adult certi non-login / Frame 543) */
.login-adult-gate {
  width: 100%;
  max-width: 100%;
  padding: 32px 0 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.login-adult-gate__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  width: 100%;
  max-width: 592px;
}

.login-adult-gate__img {
  width: 100px;
  height: auto;
  object-fit: contain;
}

.login-adult-gate__text {
  font-size: var(--fs-base);
  color: var(--mute-1, #333);
  text-align: center;
  line-height: 1.75;
}

.login-adult-gate__text p {
  margin: 0 0 0.35em;
}

.login-adult-gate__text strong {
  font-weight: 700;
}

.login-adult-gate__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  width: 100%;
}

.login-adult-gate__exit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 8px 20px;
  border: 1px solid var(--mute-4, #ccc);
  border-radius: 3px;
  background: var(--white, #fff);
  color: var(--mute-1, #333);
  font-size: var(--fs-base);
  line-height: 1.8;
  text-decoration: none;
  font-family: var(--font);
  transition: background 0.15s;
}

.login-adult-gate__exit:hover {
  background: var(--mute-7, #f8f8f8);
}

.login-adult-gate__actions--stack {
  flex-direction: column;
  width: 100%;
  max-width: 360px;
}

.login-adult-gate__verify {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  width: 100%;
  max-width: 360px;
  padding: 10px 20px;
  border: none;
  border-radius: 3px;
  background: var(--mute-1, #333);
  color: var(--mute-7, #f8f8f8);
  font-size: var(--fs-base);
  line-height: 1.8;
  text-decoration: none;
  font-family: var(--font);
  text-align: center;
  transition: opacity 0.2s;
  box-sizing: border-box;
}

.login-adult-gate__verify:hover {
  opacity: 0.88;
}

.login-adult-gate__login {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  width: 100%;
  max-width: 360px;
  padding: 10px 20px;
  border: 1px solid var(--mute-4, #ccc);
  border-radius: 3px;
  background: var(--white, #fff);
  color: var(--mute-1, #333);
  font-size: var(--fs-base);
  line-height: 1.8;
  text-decoration: none;
  font-family: var(--font);
  text-align: center;
  transition: background 0.15s;
  box-sizing: border-box;
}

.login-adult-gate__login:hover {
  background: var(--mute-7, #f8f8f8);
}

.login-form-wrap {
  width: 100%;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding-bottom: 40px;
}

.login-section__title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--mute-1, #333);
}

.login-section__secure {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: var(--fs-sm);
  font-weight: 400;
  color: var(--mute-3, #999);
}

.login-section__secure img {
  width: 16px;
  height: 16px;
}

.login-form-body {
  border-top: 1px solid var(--mute-4, #ccc);
  border-bottom: 1px solid var(--mute-4, #ccc);
  padding: 20px 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* 모바일: 인풋+버튼 세로 스택 */
.login-input-group {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.login-fields {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* 모바일: 라벨→인풋 세로 스택 */
.login-row {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}

.login-row__label {
  width: 100%;
  font-size: var(--fs-sm);
  color: var(--mute-1, #333);
  display: flex;
  align-items: center;
  gap: 3px;
}

.login-row__label--required::after {
  content: '';
  display: inline-block;
  width: 4px;
  height: 4px;
  background: #e43d3d;
  border-radius: 50%;
  margin-left: 2px;
}

.login-input {
  width: 100%;
  height: 44px;
  border: 1px solid var(--mute-4, #ccc);
  padding: 0 12px;
  font-size: var(--fs-sm);
  color: var(--mute-1, #333);
  font-family: var(--font);
  background: var(--white, #fff);
  box-sizing: border-box;
}

.login-input:focus {
  outline: none;
  border-color: var(--mute-1, #333);
}

.login-input-pw-wrap {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
}

.login-input-pw-wrap .login-input {
  width: 100%;
  padding-right: 44px;
}

.login-input-pw-wrap__eye {
  position: absolute;
  right: 12px;
  width: 16px;
  height: 16px;
  cursor: pointer;
  opacity: 0.5;
  background: none;
  border: none;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.login-input-pw-wrap__eye img {
  width: 16px;
  height: 16px;
  display: block;
}

/* 모바일: 로그인 버튼 전폭 */
.login-btn-submit {
  width: 100%;
  height: 48px;
  background: var(--mute-1, #333);
  color: var(--mute-7, #f8f8f8);
  border: none;
  font-size: var(--fs-base);
  font-weight: 600;
  font-family: var(--font);
  cursor: pointer;
  transition: opacity 0.2s;
}

.login-btn-submit:hover {
  opacity: 0.85;
}

.login-remember-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: var(--fs-xs);
  color: var(--mute-3, #999);
}

.login-remember-label {
  display: flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  user-select: none;
}

.login-remember-label span {
  color: var(--mute-2, #777);
}

.login-remember-row a {
  color: var(--mute-3, #999);
  text-decoration: none;
}

.login-remember-row a:hover {
  text-decoration: underline;
}

.login-divider {
  height: 1px;
  background: var(--mute-4, #ccc);
  border: none;
  margin: 0;
}

/* 모바일: SNS/회원가입 행 세로 스택 */
.login-sns-row,
.login-join-row {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 10px;
}

.login-sns-row__label,
.login-join-row__label {
  width: 100%;
  font-size: var(--fs-sm);
  color: var(--mute-1, #333);
  line-height: 1.5;
}

.login-btn-sns,
.login-btn-join {
  width: 100%;
  border: 1px solid var(--mute-3, #999);
  border-radius: 30px;
  background: var(--white, #fff);
  padding: 10px 20px;
  font-size: var(--fs-base);
  color: #000;
  font-family: var(--font);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  text-decoration: none;
  line-height: 1.8;
  transition: background 0.15s;
}

.login-btn-sns:hover,
.login-btn-join:hover {
  background: var(--mute-7, #f8f8f8);
}

.login-btn-sns__icon {
  width: 20px;
  height: 20px;
  object-fit: contain;
}

.login-msg {
  font-size: var(--fs-xs);
  color: #e43d3d;
  display: none;
  text-align: center;
  margin-top: 4px;
}

.login-msg.show {
  display: block;
}

.login-copyright {
  font-size: var(--fs-xs);
  color: var(--mute-4, #ccc);
}

/* ── 성인인증 페이지 ──────────────────────────────────────── */
.adult-page {
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
  padding: 24px var(--container-px) 60px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

.adult-page__logo {
  display: block;
  text-align: center;
}

.adult-page__logo img {
  width: 200px;
  height: auto;
  object-fit: contain;
}

.adult-verify-wrap {
  width: 100%;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  padding: 40px 0;
}

.adult-verify__icon {
  width: 100px;
  height: auto;
  object-fit: contain;
}

.adult-verify__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  width: 100%;
}

.adult-verify__text {
  font-size: var(--fs-base);
  color: var(--mute-1, #333);
  text-align: center;
  line-height: 1.7;
}

.adult-verify__text strong {
  font-weight: 700;
}

/* 모바일: 버튼 전폭 */
.adult-verify__actions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 10px;
  width: 100%;
  max-width: 360px;
}

.adult-verify__btn--primary,
.adult-verify__btn--secondary {
  width: 100%;
  height: 48px;
  font-size: var(--fs-base);
  font-family: var(--font);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: opacity 0.2s;
}

.adult-verify__btn--primary {
  background: var(--mute-1, #333);
  color: var(--mute-7, #f8f8f8);
  border: none;
  border-radius: 3px;
}

.adult-verify__btn--primary:hover {
  opacity: 0.85;
}

.adult-verify__btn--secondary {
  border: 1px solid var(--mute-4, #ccc);
  border-radius: 3px;
  background: var(--white, #fff);
  color: var(--mute-1, #333);
  line-height: 1.8;
  transition: background 0.15s;
}

.adult-verify__btn--secondary:hover {
  background: var(--mute-7, #f8f8f8);
}

.adult-copyright {
  font-size: var(--fs-xs);
  color: var(--mute-4, #ccc);
}

/* ── 데스크탑 오버라이드 ─────────────────────────────────── */
@media (min-width: 1280px) {
  .login-page-header,
  .adult-page-header {
    padding: 15px 0;
    font-size: 20px;
  }

  .login-page,
  .adult-page {
    max-width: 1280px;
    padding: 50px 20px 80px;
    gap: 40px;
  }

  .login-page__logo img,
  .adult-page__logo img {
    width: 290px;
    height: 47px;
  }

  .login-adult-gate {
    max-width: 800px;
    padding: 40px 0 20px;
    gap: 40px;
  }

  .login-adult-gate__inner {
    gap: 30px;
  }

  .login-adult-gate__img {
    width: 140px;
    height: auto;
    max-height: 181px;
  }

  .login-adult-gate__text {
    font-size: 18px;
    max-width: 592px;
    line-height: normal;
  }

  .login-adult-gate__exit {
    min-height: 42px;
    font-size: 18px;
  }

  .login-adult-gate__verify,
  .login-adult-gate__login {
    width: 200px;
    min-height: 42px;
    font-size: 18px;
    max-width: none;
  }

  .login-adult-gate__actions--stack {
    max-width: none;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
  }

  .login-form-wrap {
    max-width: 800px;
    gap: 20px;
    padding-bottom: 100px;
  }

  .login-section__title {
    font-size: 24px;
    gap: 10px;
  }

  .login-section__secure {
    font-size: 16px;
    gap: 5px;
  }

  .login-section__secure img {
    width: 19px;
    height: 19px;
  }

  .login-form-body {
    padding: 40px 0;
    gap: 20px;
  }

  /* PC: 인풋+버튼 가로 배치 */
  .login-input-group {
    flex-direction: row;
    align-items: stretch;
    gap: 20px;
  }

  .login-fields {
    gap: 14px;
  }

  /* PC: 라벨+인풋 가로 배치 */
  .login-row {
    flex-direction: row;
    align-items: center;
    gap: 10px;
  }

  .login-row__label {
    width: 170px;
    flex-shrink: 0;
    font-size: 16px;
  }

  .login-input {
    height: 47px;
    padding: 0 15px;
    font-size: 14px;
  }

  /* PC: 버튼 우측 고정 너비 */
  .login-btn-submit {
    width: 200px;
    flex-shrink: 0;
    height: auto;
    font-size: 14px;
    align-self: stretch;
  }

  .login-remember-row {
    font-size: 14px;
  }

  /* PC: SNS/회원가입 가로 배치 */
  .login-sns-row,
  .login-join-row {
    flex-direction: row;
    align-items: center;
    gap: 20px;
  }

  .login-sns-row__label,
  .login-join-row__label {
    width: 170px;
    flex-shrink: 0;
    font-size: 16px;
  }

  .login-btn-sns,
  .login-btn-join {
    width: 250px;
    font-size: 16px;
  }

  .login-msg {
    font-size: 13px;
  }

  /* adult verify PC */
  .adult-verify-wrap {
    max-width: 800px;
    gap: 40px;
    padding: 100px 0;
  }

  .adult-verify__icon {
    width: 140px;
    height: 181px;
  }

  .adult-verify__content {
    gap: 30px;
  }

  .adult-verify__text {
    font-size: 18px;
    max-width: 592px;
  }

  .adult-verify__actions {
    flex-direction: row;
    align-items: flex-start;
    gap: 10px;
    width: auto;
    max-width: none;
  }

  .adult-verify__btn--primary,
  .adult-verify__btn--secondary {
    width: 200px;
    height: 42px;
    font-size: 18px;
  }

  .adult-verify__btn--secondary {
    width: auto;
    padding: 5px 20px;
    height: auto;
  }
}
