/*
 * PeptaLux — Checkout form-field styling (Style C).
 *
 * Matches the Phase 5a acknowledgment-card aesthetic without touching any
 * .plx-ack-* selectors — those are owned by mu-plugins/peptalux-checkout-ack.php
 * and must not be restyled here.
 *
 * Only loaded on is_checkout() && !order-received && !order-pay.
 */

/* Labels above inputs */
.woocommerce-checkout .form-row label,
.woocommerce-checkout-payment label {
  font-size: var(--plx-text-sm, 13px);
  font-weight: var(--plx-weight-medium, 500);
  color: var(--plx-body-light, #475569);
  margin-bottom: 6px;
  display: block;
}

/* Text-style inputs and textareas */
.woocommerce-checkout input[type="text"],
.woocommerce-checkout input[type="email"],
.woocommerce-checkout input[type="tel"],
.woocommerce-checkout input[type="password"],
.woocommerce-checkout input[type="number"],
.woocommerce-checkout textarea {
  background: var(--plx-bg-surface, #FFFFFF);
  border: 1.5px solid var(--plx-border, #E1E5EB);
  border-radius: var(--plx-radius, 8px);
  padding: 14px 14px;
  font-size: 15px;
  line-height: var(--plx-leading-normal, 1.5);
  color: var(--plx-body, #1A1A1A);
  transition: border-color var(--plx-transition, 150ms ease),
              box-shadow var(--plx-transition, 150ms ease);
  width: 100%;
  box-sizing: border-box;
}

.woocommerce-checkout input[type="text"]:hover,
.woocommerce-checkout input[type="email"]:hover,
.woocommerce-checkout input[type="tel"]:hover,
.woocommerce-checkout input[type="password"]:hover,
.woocommerce-checkout input[type="number"]:hover,
.woocommerce-checkout textarea:hover {
  border-color: var(--plx-border-hover, #C8D4E8);
}

.woocommerce-checkout input[type="text"]:focus,
.woocommerce-checkout input[type="email"]:focus,
.woocommerce-checkout input[type="tel"]:focus,
.woocommerce-checkout input[type="password"]:focus,
.woocommerce-checkout input[type="number"]:focus,
.woocommerce-checkout textarea:focus {
  border-color: var(--plx-border-focus, #1E50A0);
  box-shadow: 0 0 0 3px var(--plx-focus-ring, rgba(30, 80, 160, 0.1));
  outline: none;
}

/* Select2-rendered country/state dropdowns — match the input look exactly */
.woocommerce-checkout .select2-container--default .select2-selection--single {
  background: var(--plx-bg-surface, #FFFFFF);
  border: 1.5px solid var(--plx-border, #E1E5EB);
  border-radius: var(--plx-radius, 8px);
  height: auto;
  min-height: 50px;
  padding: 12px 14px;
  transition: border-color var(--plx-transition, 150ms ease),
              box-shadow var(--plx-transition, 150ms ease);
  width: 100%;
  box-sizing: border-box;
}
.woocommerce-checkout .select2-container { width: 100% !important; box-sizing: border-box; }
.woocommerce-checkout .select2-container--default .select2-selection--single:hover {
  border-color: var(--plx-border-hover, #C8D4E8);
}
.woocommerce-checkout .select2-container--default.select2-container--focus .select2-selection--single,
.woocommerce-checkout .select2-container--default.select2-container--open .select2-selection--single {
  border-color: var(--plx-border-focus, #1E50A0);
  box-shadow: 0 0 0 3px var(--plx-focus-ring, rgba(30, 80, 160, 0.1));
}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
  font-size: 15px;
  line-height: var(--plx-leading-normal, 1.5);
  color: var(--plx-body, #1A1A1A);
  padding: 0;
}
.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
  height: 100%;
  right: 12px;
}

/* Checkbox/radio rows — mild restyle so they don't fight the new input frames
   (excludes .plx-ack-check — Phase 5a styles those explicitly) */
.woocommerce-checkout .form-row .woocommerce-form__input-checkbox {
  accent-color: var(--plx-primary, #1E50A0);
}

/* Place Order button — let Phase 5a's #place_order.plx-ack-locked rule lead
   on the disabled visual; here we just ensure base spacing matches the
   new field heights so it doesn't look squat against the cards. */
.woocommerce-checkout #place_order {
  padding: 14px 24px;
  font-size: 15px;
  font-weight: var(--plx-weight-semibold, 600);
  border-radius: var(--plx-radius, 8px);
  box-sizing: border-box;
}

/* ─── Two-column layout for #customer_details ────────────────────────────
 * Parent dequeues all WC default stylesheets via:
 *   add_filter('woocommerce_enqueue_styles', '__return_empty_array')
 * (theme-active/functions.php:350), so woocommerce-layout.css — which
 * normally floats .col-1 + .col-2 side-by-side — never loads. Before this
 * commit's field-width changes, the columns happened to render side-by-side
 * via accidental box-model leniency; once inputs became width:100% with
 * box-sizing:border-box, that fragility collapsed and .col-2 dropped below
 * .col-1.
 *
 * Fix: explicit grid layout. Desktop (≥769px) uses a 58/42 split per
 * launch-spec; below 769px stacks naturally (single column).
 */
@media (min-width: 769px) {
  .woocommerce-checkout #customer_details.col2-set {
    display: grid;
    grid-template-columns: 58fr 42fr;
    gap: 24px;
  }
  .woocommerce-checkout #customer_details.col2-set > .col-1,
  .woocommerce-checkout #customer_details.col2-set > .col-2 {
    width: auto;
    float: none;
    min-width: 0;
    margin: 0;
  }
}
@media (max-width: 768px) {
  .woocommerce-checkout #customer_details.col2-set > .col-1,
  .woocommerce-checkout #customer_details.col2-set > .col-2 {
    width: 100%;
    float: none;
    margin-bottom: 24px;
  }
}

/* WC's paired fields (e.g. First Name / Last Name) are floated via
   .form-row-first / .form-row-last with 47% widths in WC's removed default
   stylesheet. Restore explicit widths so they pair on the same row. */
.woocommerce-checkout .form-row {
  box-sizing: border-box;
}
.woocommerce-checkout .form-row-first,
.woocommerce-checkout .form-row-last {
  width: calc(50% - 8px);
  float: left;
}
.woocommerce-checkout .form-row-first { margin-right: 16px; }
.woocommerce-checkout .form-row-wide { width: 100%; clear: both; }
.woocommerce-checkout .form-row::after { content: ""; display: table; clear: both; }
@media (max-width: 480px) {
  .woocommerce-checkout .form-row-first,
  .woocommerce-checkout .form-row-last {
    width: 100%;
    float: none;
    margin-right: 0;
  }
}

/* ─── Checkout login / register (guest-checkout-off path) ───────────────────
 * When guest checkout is disabled WooCommerce renders its native
 * checkout/form-login.php (and the register form) on /checkout/. The theme
 * strips WC's default stylesheet, so without these rules that login surface
 * renders unstyled. Styled here to match the .plx-auth / My Account login look.
 * Text/email/password inputs are already covered by the .woocommerce-checkout
 * input rules above. */

/* "Returning customer? Click here to login" toggle notice */
.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info {
  background: var(--plx-bg-soft, #F5F7FA);
  border: 1.5px solid var(--plx-border, #E1E5EB);
  border-left: 3px solid var(--plx-primary, #1E50A0);
  border-radius: var(--plx-radius, 8px);
  padding: 14px 16px;
  font-size: var(--plx-text-sm, 13px);
  color: var(--plx-body, #1A1A1A);
}
.woocommerce-checkout .woocommerce-form-login-toggle .woocommerce-info a,
.woocommerce-checkout .showlogin {
  color: var(--plx-primary, #1E50A0);
  font-weight: var(--plx-weight-medium, 500);
  text-decoration: underline;
}

/* Login / register form card */
.woocommerce-checkout .woocommerce-form-login,
.woocommerce-checkout .woocommerce-form-register {
  background: var(--plx-bg-surface, #FFFFFF);
  border: 1.5px solid var(--plx-border, #E1E5EB);
  border-radius: var(--plx-radius-lg, 10px);
  padding: 24px;
  margin: 14px 0 24px;
}

/* Remember-me row */
.woocommerce-checkout .woocommerce-form-login__rememberme {
  display: block;
  margin: 4px 0 16px;
  font-size: var(--plx-text-sm, 13px);
  color: var(--plx-body-light, #475569);
}

/* Submit buttons (Login / Register) — brand-blue primary */
.woocommerce-checkout .woocommerce-form-login button[type="submit"],
.woocommerce-checkout .woocommerce-form-login .woocommerce-form-login__submit,
.woocommerce-checkout .woocommerce-form-register button[type="submit"] {
  background: var(--plx-primary, #1E50A0);
  color: #fff;
  border: none;
  border-radius: var(--plx-radius, 8px);
  padding: 13px 22px;
  font-size: 15px;
  font-weight: var(--plx-weight-semibold, 600);
  cursor: pointer;
  transition: background var(--plx-transition, 150ms ease),
              box-shadow var(--plx-transition, 150ms ease);
}
.woocommerce-checkout .woocommerce-form-login button[type="submit"]:hover,
.woocommerce-checkout .woocommerce-form-login .woocommerce-form-login__submit:hover,
.woocommerce-checkout .woocommerce-form-register button[type="submit"]:hover {
  background: var(--plx-primary-dark, #0F2D6B);
  box-shadow: 0 8px 20px rgba(30, 80, 160, .2);
}

/* "Lost your password?" link */
.woocommerce-checkout .woocommerce-form-login .woocommerce-LostPassword a {
  color: var(--plx-primary, #1E50A0);
  font-size: var(--plx-text-sm, 13px);
  text-decoration: underline;
}

/* "You must be logged in to checkout." fallback message */
.woocommerce-checkout .woocommerce-info,
.woocommerce-checkout .wc-must-login-notice {
  border-radius: var(--plx-radius, 8px);
}
