/* ==========================================================
   WC Login / Register - OurChapter v3
   Two-column desktop layout; single-column mobile stack.
   Loads after main-v2.css; brand tokens from tokens.css.
   ========================================================== */

/* ---- Warm light page wrapper ---- */
body.woocommerce-account:not(.logged-in) .pg-wc-page-wrapper {
  background: var(--pg-bone);
  min-height: 90vh;
  display: flex;
  align-items: center;
  padding: 96px 0 80px;
}

body.woocommerce-account:not(.logged-in) .pg-wc-page-wrapper > .pg-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
}

/* ---- Login page outer wrapper ---- */
.pg-login-page {
  width: 100%;
  max-width: 480px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* Split (registration enabled): wider two-column grid on desktop */
.pg-login-page--split {
  max-width: 900px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 0 32px;
  align-items: stretch;
}

/* Footer (guest + trust) spans both columns */
.pg-login-footer {
  grid-column: 1 / -1;
}

/* WC injects a notices wrapper as first child — pin it to full width row 1 */
.pg-login-page--split .woocommerce-notices-wrapper {
  grid-column: 1 / -1;
  grid-row: 1;
}

/* Push both columns into row 2 */
.pg-login-page--split .pg-login-col--login {
  grid-column: 1;
  grid-row: 2;
}

.pg-login-page--split .pg-login-col--register {
  grid-column: 2;
  grid-row: 2;
}

/* Footer into row 3 */
.pg-login-page--split .pg-login-footer {
  grid-row: 3;
}

/* ---- Columns ---- */
.pg-login-col {
  display: flex;
  flex-direction: column;
}

/* Forms fill the card so primary CTAs land on a shared baseline */
.pg-wc-login-form,
.pg-wc-register-form {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
}

.pg-wc-login-form .woocommerce-form-login__submit,
.pg-wc-register-form > div:last-of-type {
  margin-top: auto;
  padding-top: 4px;
}

/* ---- Cards ---- */
.pg-login-card {
  background: var(--pg-bone);
  border-radius: 18px;
  padding: clamp(24px, 3.5vw, 36px);
  box-shadow: 0 18px 44px rgba(42, 37, 31, 0.10), 0 4px 14px rgba(42, 37, 31, 0.06);
  border: 1px solid var(--pg-hairline);
  height: 100%;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
}

/* Register card: midnight-tinted panel */
.pg-login-card--register {
  background: var(--pg-paper);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--pg-hairline);
}

/* Subtle vertical separator: confined to the cards row only,
   drawn on the login column so it never reaches the footer row. */
.pg-login-page--split .pg-login-col--login {
  position: relative;
}

.pg-login-page--split .pg-login-col--login::after {
  content: '';
  position: absolute;
  top: 8%;
  bottom: 8%;
  right: -16px;
  width: 1px;
  background: var(--pg-hairline);
  pointer-events: none;
}

/* ---- Card header ---- */
.pg-login-card__header {
  margin-bottom: 26px;
}

.pg-login-card__eyebrow {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--pg-brass-text);
  margin-bottom: 6px;
}

.pg-login-card__eyebrow--light {
  color: var(--pg-brass-text);
}

.pg-login-card__title {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 500;
  color: var(--pg-ink);
  margin: 0;
  line-height: var(--leading-snug);
}

.pg-login-card__title--light {
  color: var(--pg-ink);
}

/* ---- Benefits list (register panel) ---- */
.pg-register-benefits {
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.pg-register-benefits li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13.5px;
  color: var(--pg-warm-grey-text);
  line-height: 1.4;
}

.pg-register-benefits li svg {
  flex-shrink: 0;
  stroke: var(--pg-brass-text);
}

/* ---- Form groups ---- */
.pg-form-group {
  margin-bottom: 18px;
}

.pg-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--pg-warm-grey-text);
  display: block;
  margin-bottom: 7px;
}

.pg-label--light {
  color: var(--pg-warm-grey-text);
}

/* ---- Inputs ---- */
.pg-input {
  width: 100%;
  background: #fff;
  border: 1.5px solid rgba(27, 26, 23, 0.18);
  color: var(--pg-ink);
  padding: 13px 15px;
  border-radius: 10px;
  font-size: 15px;
  font-family: var(--font-body);
  outline: none;
  box-sizing: border-box;
  transition: border-color 0.2s, box-shadow 0.2s;
  -webkit-appearance: none;
  appearance: none;
}

.pg-input:focus {
  border-color: var(--pg-brass);
  box-shadow: 0 0 0 3px rgba(182, 137, 63, 0.15);
}

/* Dark (register) variant */
.pg-input--dark {
  background: var(--pg-bone);
  border-color: var(--pg-hairline);
  color: var(--pg-ink);
}

.pg-input--dark::placeholder {
  color: var(--pg-warm-grey-text);
}

.pg-input--dark:focus {
  border-color: var(--pg-brass);
  box-shadow: 0 0 0 3px rgba(176, 135, 91, 0.15);
}

@media (prefers-reduced-motion: reduce) {
  .pg-input { transition: none; }
}

/* ---- Password field with show/hide toggle ---- */
.pg-input-wrap {
  position: relative;
  display: flex;
  align-items: center;
}

/* WC wraps the input in span.password-input — make it fill the wrapper */
.pg-input-wrap .password-input {
  flex: 1;
  display: block;
}

.pg-input-wrap .pg-input,
.pg-input-wrap .password-input .pg-input {
  padding-right: 48px;
  width: 100%;
}

/* Hide WooCommerce's own show-password button — we use .pg-toggle-pw */
.pg-input-wrap .show-password-input {
  display: none !important;
}

.pg-toggle-pw {
  position: absolute;
  right: 13px;
  background: none;
  border: none;
  padding: 4px;
  cursor: pointer;
  color: var(--pg-warm-grey);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: color 0.15s;
}

.pg-toggle-pw:hover {
  color: var(--pg-ink);
}

.pg-toggle-pw--dark {
  color: var(--pg-warm-grey);
}

.pg-toggle-pw--dark:hover {
  color: var(--pg-ink);
}

@media (prefers-reduced-motion: reduce) {
  .pg-toggle-pw { transition: none; }
}

/* ---- Remember me + forgot password row ---- */
.pg-login-remember-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}

.pg-login-remember-row .woocommerce-form__label-for-checkbox {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  color: var(--pg-ink);
  cursor: pointer;
}

.pg-login-forgot {
  font-size: 13px;
  color: var(--pg-brass-text);
  text-decoration: none;
  border-bottom: 1px solid rgba(138, 98, 30, 0.4);
  padding-bottom: 1px;
  white-space: nowrap;
  transition: border-color 0.2s, opacity 0.2s;
}

.pg-login-forgot:hover {
  opacity: 0.8;
}

@media (prefers-reduced-motion: reduce) {
  .pg-login-forgot { transition: none; }
}

/* ---- Terms checkbox ---- */
.pg-register-terms-label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
  color: #5A554C;
  cursor: pointer;
  line-height: 1.5;
}

.pg-register-terms-label--light {
  color: var(--pg-warm-grey-text);
}

.pg-register-terms-label input[type="checkbox"] {
  margin-top: 2px;
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  cursor: pointer;
  accent-color: var(--pg-brass);
}

.pg-register-terms-label a {
  color: var(--pg-brass-text);
  text-decoration: underline;
}

.pg-register-terms-label--light a {
  color: var(--pg-brass-text);
}

/* ---- Buttons ---- */
.pg-btn--full {
  display: block;
  width: 100%;
  text-align: center;
}

/* Brass button (login) */
.pg-login-page .pg-btn--brass {
  display: inline-block;
  background: var(--pg-btn-brass);
  color: var(--pg-bone);
  padding: 15px 28px;
  border-radius: var(--radius-pill);
  font-weight: 700;
  font-size: 15px;
  font-family: var(--font-body);
  box-shadow: 0 14px 40px rgba(182, 137, 63, 0.3);
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: filter 0.2s, transform 0.2s, box-shadow 0.2s;
}

.pg-login-page .pg-btn--brass:hover {
  filter: brightness(1.08);
  transform: translateY(-2px);
  box-shadow: 0 20px 50px rgba(182, 137, 63, 0.45);
}

@media (prefers-reduced-motion: reduce) {
  .pg-login-page .pg-btn--brass { transition: none; }
  .pg-login-page .pg-btn--brass:hover { transform: none; }
}

/* Bone button (register) - dark panel needs inverted button */
.pg-btn--bone {
  display: inline-block;
  background: var(--pg-bone);
  /* #1B1A17 on #FBF8F1 = 18:1, well above AA */
  color: var(--pg-ink);
  padding: 15px 28px;
  border-radius: var(--radius-pill);
  font-weight: 700;
  font-size: 15px;
  font-family: var(--font-body);
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: filter 0.2s, transform 0.2s;
}

.pg-btn--bone:hover {
  filter: brightness(0.96);
  transform: translateY(-2px);
}

@media (prefers-reduced-motion: reduce) {
  .pg-btn--bone { transition: none; }
  .pg-btn--bone:hover { transform: none; }
}

/* ---- Divider ---- */
.pg-login-divider {
  display: flex;
  align-items: center;
  gap: 14px;
  margin: 28px 0 20px;
}

.pg-login-divider::before,
.pg-login-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--pg-hairline);
}

.pg-login-divider span {
  font-size: 12px;
  color: var(--pg-warm-grey-text);
  white-space: nowrap;
}

/* ---- Guest checkout button ---- */
.pg-login-guest {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  background: transparent;
  color: var(--pg-warm-grey-text);
  border: 1.5px solid var(--pg-hairline);
  padding: 13px;
  border-radius: var(--radius-pill);
  font-weight: 600;
  font-size: 14.5px;
  font-family: var(--font-body);
  box-sizing: border-box;
  text-decoration: none;
  transition: border-color 0.2s, color 0.2s, background 0.2s;
}

.pg-login-guest:hover {
  border-color: var(--pg-brass);
  color: var(--pg-brass-text);
  background: rgba(182, 137, 63, 0.06);
}

@media (prefers-reduced-motion: reduce) {
  .pg-login-guest { transition: none; }
}

/* ---- Trust line ---- */
.pg-login-trust {
  text-align: center;
  color: var(--pg-warm-grey-text);
  font-size: 13px;
  margin: 16px 0 0;
}

/* ---- WC privacy / data-usage notice inside register form ---- */
.pg-login-card--register .woocommerce-privacy-policy-text,
.pg-login-card--register .woocommerce-privacy-policy-text p {
  font-size: 12px;
  color: var(--pg-warm-grey-text);
  margin: 0 0 16px;
  line-height: 1.5;
}

.pg-login-card--register .woocommerce-privacy-policy-text a {
  color: var(--pg-brass-text);
}

/* ---- WC error / notice alerts ---- */
.woocommerce-error {
  background: rgba(178, 58, 72, 0.08);
  border: 1px solid rgba(178, 58, 72, 0.25);
  border-left: 3px solid var(--pg-error);
  border-radius: var(--radius-sm);
  padding: 14px 16px;
  margin-bottom: 20px;
  list-style: none;
  font-size: 14px;
  color: var(--pg-error);
}

.woocommerce-message {
  background: rgba(47, 125, 91, 0.08);
  border: 1px solid rgba(47, 125, 91, 0.25);
  border-left: 3px solid var(--pg-success);
  border-radius: var(--radius-sm);
  padding: 14px 16px;
  margin-bottom: 20px;
  list-style: none;
  font-size: 14px;
  color: var(--pg-success);
}

/* ---- Mobile: stack to single column ---- */
@media (max-width: 720px) {
  .pg-login-page--split {
    grid-template-columns: 1fr;
    max-width: 480px;
    gap: 20px 0;
  }

  /* Reset explicit grid-column / grid-row placements so all items stack */
  .pg-login-page--split .woocommerce-notices-wrapper,
  .pg-login-page--split .pg-login-col--login,
  .pg-login-page--split .pg-login-col--register,
  .pg-login-page--split .pg-login-footer {
    grid-column: 1;
    grid-row: auto;
  }

  /* Hide the centre-line pseudo on mobile */
  .pg-login-page--split .pg-login-col--login::after {
    display: none;
  }

  .pg-login-card {
    border-radius: 16px;
  }

  .pg-login-remember-row {
    flex-direction: column;
    align-items: flex-start;
  }
}

@media (max-width: 520px) {
  body.woocommerce-account:not(.logged-in) .pg-wc-page-wrapper {
    padding: 80px 0 60px;
  }
}
