/* ChemBioSynth — My Account / Login / Register page polish.
   Loaded only on is_account_page().
   Layout strategy:
     - Default = logged-in 2-col (sidebar + content card)
     - When #customer_login is present (logged out), :has() switches to a
       single-column centered login/register grid. */

/* ---------- Outer container ---------- */
body.woocommerce-account .page-content,
body.woocommerce-account main .page-content{
  max-width:1140px!important;
  padding:24px 24px 80px!important;
  margin:0 auto!important;
}
.woocommerce-account .wc-page-wrap{
  max-width:1140px!important;
  padding:0!important;margin:0 auto!important;
}
.woocommerce-account .wc-page-wrap > h1{
  text-align:left!important;
  font-family:var(--serif)!important;font-size:clamp(28px,3.2vw,40px)!important;
  font-weight:600!important;letter-spacing:-.02em!important;line-height:1.05!important;
  margin:0 0 24px!important;color:var(--ink)!important;
}

/* ============================================================
 * DEFAULT: 2-column layout for logged-in pages
 * (Dashboard / Orders / Downloads / Addresses / Account details)
 * ============================================================ */
.woocommerce-account .woocommerce{
  display:grid!important;
  grid-template-columns:240px minmax(0, 1fr)!important;
  column-gap:32px!important;row-gap:0!important;
  align-items:start!important;
  text-align:left!important;
  width:100%!important;max-width:none!important;
  margin:0!important;
}

/* Force explicit grid placement so the nav is always col 1 (left)
   and the content is always col 2 (right), regardless of DOM order
   or any plugin that may reorder them. */
.woocommerce-account .woocommerce-MyAccount-navigation{
  grid-column:1!important;grid-row:1!important;
}
.woocommerce-account .woocommerce-MyAccount-content{
  grid-column:2!important;grid-row:1!important;
}

/* Sidebar nav (left col) */
.woocommerce-account .woocommerce-MyAccount-navigation{
  width:100%!important;float:none!important;margin:0!important;padding:0!important;
  position:sticky;top:24px;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul{
  list-style:none!important;
  padding:0!important;margin:0!important;
  background:#fff!important;
  border:1px solid var(--line)!important;
  border-radius:14px!important;
  overflow:hidden;
}
.woocommerce-account .woocommerce-MyAccount-navigation li{
  margin:0!important;padding:0!important;
  border-bottom:1px solid var(--line)!important;
  list-style:none;
}
.woocommerce-account .woocommerce-MyAccount-navigation li:last-child{border-bottom:none!important}
.woocommerce-account .woocommerce-MyAccount-navigation li a{
  display:block!important;
  padding:13px 18px!important;
  font-size:13.5px!important;font-weight:600!important;
  color:var(--ink)!important;
  text-decoration:none!important;
  transition:background .15s, color .15s;
}
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover{
  background:var(--paper-warm)!important;color:var(--copper)!important;
}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--is-active a{
  background:var(--ink)!important;color:var(--paper)!important;
}

/* Content card (right col) */
.woocommerce-account .woocommerce-MyAccount-content{
  width:100%!important;float:none!important;margin:0!important;
  background:#fff!important;
  border:1px solid var(--line)!important;
  border-radius:18px!important;
  padding:32px!important;
  box-shadow:0 18px 36px -22px rgba(26,34,56,.08);
  min-width:0;
}
.woocommerce-account .woocommerce-MyAccount-content h1,
.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-MyAccount-content h3{
  font-family:var(--serif)!important;
  font-weight:600!important;letter-spacing:-.01em!important;
  color:var(--ink);
}
.woocommerce-account .woocommerce-MyAccount-content h2{font-size:22px;margin:0 0 14px}
.woocommerce-account .woocommerce-MyAccount-content h3{font-size:18px;margin:18px 0 10px}
.woocommerce-account .woocommerce-MyAccount-content p{
  font-size:14px;line-height:1.7;color:var(--ink-soft);
}
.woocommerce-account .woocommerce-MyAccount-content a{color:var(--copper);text-decoration:underline}
.woocommerce-account .woocommerce-MyAccount-content a:hover{color:var(--copper-deep)}

/* Orders table */
.woocommerce-account table.shop_table_responsive,
.woocommerce-account table.my_account_orders{
  width:100%!important;
  background:transparent!important;
  border:1px solid var(--line)!important;
  border-radius:14px!important;
  border-collapse:separate!important;border-spacing:0;
  overflow:hidden;margin:0;
}
.woocommerce-account table.my_account_orders thead{background:var(--paper-warm)}
.woocommerce-account table.my_account_orders thead th{
  padding:14px 16px!important;
  font-size:11px;font-weight:700;letter-spacing:.06em;
  text-transform:uppercase;color:var(--ink);
  background:transparent;border:none;text-align:left;
}
.woocommerce-account table.my_account_orders tbody td{
  padding:16px!important;
  border-top:1px solid var(--line)!important;
  font-size:14px;color:var(--ink);
}
.woocommerce-account table.my_account_orders .button{
  background:var(--ink)!important;color:var(--paper)!important;
  padding:8px 14px!important;border-radius:999px!important;
  font-size:12px!important;font-weight:600!important;
  text-decoration:none;display:inline-block;
}
.woocommerce-account table.my_account_orders .button:hover{background:var(--copper)!important}

/* Order status pills */
.woocommerce-account .order-status{
  display:inline-block;padding:4px 10px;border-radius:999px;
  font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
}
.woocommerce-account .order-status.status-completed{background:rgba(79,106,74,.15);color:var(--moss)}
.woocommerce-account .order-status.status-processing{background:rgba(184,111,63,.15);color:var(--copper-deep)}
.woocommerce-account .order-status.status-on-hold,
.woocommerce-account .order-status.status-pending{background:rgba(184,111,63,.08);color:var(--copper-deep)}
.woocommerce-account .order-status.status-cancelled,
.woocommerce-account .order-status.status-failed,
.woocommerce-account .order-status.status-refunded{background:rgba(196,69,69,.1);color:var(--critical)}

/* Addresses screen */
.woocommerce-account .woocommerce-Addresses{
  display:grid!important;grid-template-columns:1fr 1fr;gap:18px;
  margin-top:14px;
}
.woocommerce-account .woocommerce-Address{
  background:var(--paper-warm)!important;
  border:1px solid var(--line)!important;
  border-radius:14px!important;
  padding:22px!important;width:auto!important;float:none!important;
}
.woocommerce-account .woocommerce-Address-title{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--line);
}
.woocommerce-account .woocommerce-Address-title h2,
.woocommerce-account .woocommerce-Address-title h3{
  margin:0!important;font-size:16px!important;
}
.woocommerce-account .woocommerce-Address-title .edit{
  font-size:12px;font-weight:600;color:var(--copper);
  text-decoration:underline;
}
.woocommerce-account .woocommerce-Address address{
  font-size:13px;line-height:1.65;color:var(--ink-soft);font-style:normal;
}

/* ============================================================
 * Inner forms — Edit Account / Edit Address / Lost Password
 * Match the checkout's input styling so everything feels consistent.
 * ============================================================ */
.woocommerce-account .woocommerce-MyAccount-content form.woocommerce-EditAccountForm,
.woocommerce-account .woocommerce-MyAccount-content form.woocommerce-address-form,
.woocommerce-account .woocommerce-MyAccount-content form.edit-account,
.woocommerce-account .woocommerce-MyAccount-content form{
  margin:0!important;padding:0!important;background:transparent!important;border:none!important;
}
.woocommerce-account .woocommerce-MyAccount-content form fieldset{
  border:1px solid var(--line)!important;
  border-radius:14px!important;
  padding:18px 22px!important;
  margin:22px 0 0!important;
}
.woocommerce-account .woocommerce-MyAccount-content form fieldset legend{
  font-family:var(--serif)!important;font-size:16px!important;
  font-weight:600!important;letter-spacing:-.01em!important;
  padding:0 10px!important;color:var(--ink)!important;
}

/* Form rows in account screens */
.woocommerce-account .woocommerce-MyAccount-content .form-row,
.woocommerce-account .woocommerce-MyAccount-content p.form-row{
  margin:0 0 14px!important;padding:0!important;
}
.woocommerce-account .woocommerce-MyAccount-content .form-row.form-row-first,
.woocommerce-account .woocommerce-MyAccount-content .form-row.form-row-last{
  width:calc(50% - 8px)!important;display:inline-block;margin-right:0!important;
}
.woocommerce-account .woocommerce-MyAccount-content .form-row.form-row-first{margin-right:14px!important}
.woocommerce-account .woocommerce-MyAccount-content .form-row.form-row-wide{width:100%!important;display:block}

.woocommerce-account .woocommerce-MyAccount-content .form-row label{
  display:block!important;
  font-size:12px!important;font-weight:600!important;
  color:var(--ink)!important;margin-bottom:6px!important;
  letter-spacing:0!important;text-transform:none!important;
}
.woocommerce-account .woocommerce-MyAccount-content .form-row label .required{
  color:var(--critical);text-decoration:none;font-weight:600;border:none;
}
.woocommerce-account .woocommerce-MyAccount-content .form-row label .optional{
  color:var(--ink-soft);
}

/* Inputs (text / email / password / select / textarea) */
.woocommerce-account .woocommerce-MyAccount-content .form-row input.input-text,
.woocommerce-account .woocommerce-MyAccount-content .form-row input[type=text],
.woocommerce-account .woocommerce-MyAccount-content .form-row input[type=email],
.woocommerce-account .woocommerce-MyAccount-content .form-row input[type=password],
.woocommerce-account .woocommerce-MyAccount-content .form-row input[type=tel],
.woocommerce-account .woocommerce-MyAccount-content .form-row textarea,
.woocommerce-account .woocommerce-MyAccount-content .form-row select{
  width:100%!important;
  padding:11px 14px!important;
  border:1px solid var(--line)!important;
  border-radius:10px!important;
  background:#fff!important;
  font-size:14px!important;color:var(--ink)!important;
  font-family:var(--sans)!important;
  transition:border-color .2s, box-shadow .2s;
  box-shadow:none!important;
  height:auto;
}
.woocommerce-account .woocommerce-MyAccount-content .form-row input:focus,
.woocommerce-account .woocommerce-MyAccount-content .form-row textarea:focus,
.woocommerce-account .woocommerce-MyAccount-content .form-row select:focus{
  outline:none!important;
  border-color:var(--ink)!important;
  box-shadow:0 0 0 3px rgba(26,34,56,.08)!important;
}
.woocommerce-account .woocommerce-MyAccount-content .form-row textarea{min-height:90px;resize:vertical}

/* Select2 (country / state) inside account forms */
.woocommerce-account .woocommerce-MyAccount-content .select2-container .select2-selection--single{
  height:46px!important;
  border:1px solid var(--line)!important;
  border-radius:10px!important;
  background:#fff!important;
  outline:none!important;box-shadow:none!important;
}
.woocommerce-account .woocommerce-MyAccount-content .select2-container .select2-selection--single .select2-selection__rendered{
  line-height:44px!important;color:var(--ink);font-size:14px;padding-left:14px;
}
.woocommerce-account .woocommerce-MyAccount-content .select2-container .select2-selection__arrow{
  height:44px!important;right:8px!important;
}

/* Show-password eye icon */
.woocommerce-account .woocommerce-MyAccount-content .password-input{position:relative;display:block;width:100%}
.woocommerce-account .woocommerce-MyAccount-content .show-password-input{
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  color:var(--ink-soft);cursor:pointer;
  width:22px;height:22px;display:grid;place-items:center;
  background:transparent;border:none;
}

/* Submit row */
.woocommerce-account .woocommerce-MyAccount-content p:last-child:has(button[type=submit]),
.woocommerce-account .woocommerce-MyAccount-content .form-row:last-child{
  margin-top:18px!important;
}
.woocommerce-account .woocommerce-MyAccount-content button[type=submit],
.woocommerce-account .woocommerce-MyAccount-content input[type=submit]{
  background:var(--ink)!important;
  color:var(--paper)!important;
  padding:12px 24px!important;
  border-radius:10px!important;
  font-weight:700!important;font-size:14px!important;
  border:none!important;cursor:pointer;
  text-shadow:none!important;
  transition:background .2s;
  letter-spacing:.02em;
}
.woocommerce-account .woocommerce-MyAccount-content button[type=submit]:hover,
.woocommerce-account .woocommerce-MyAccount-content input[type=submit]:hover{
  background:var(--copper)!important;
}

/* Section spacing in dashboard */
.woocommerce-account .woocommerce-MyAccount-content > p,
.woocommerce-account .woocommerce-MyAccount-content > h2,
.woocommerce-account .woocommerce-MyAccount-content > h3{
  margin-bottom:18px;
}
.woocommerce-account .woocommerce-MyAccount-content > p:first-child{margin-top:0}

/* Description text on edit-address landing screen */
.woocommerce-account .woocommerce-MyAccount-content .myaccount-address-description,
.woocommerce-account .woocommerce-MyAccount-content > .u-columns + p{
  font-size:14px;color:var(--ink-soft);margin:0 0 18px;
}

/* "Recent orders" within dashboard / orders endpoint */
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-orders-table__cell-order-actions{
  text-align:right;
}

/* ============================================================
 * LOGGED-OUT — Login + Register layout (override the grid above)
 * Detected by the presence of #customer_login (CSS :has()).
 * ============================================================ */
.woocommerce-account .woocommerce:has(#customer_login){
  display:block!important;
  grid-template-columns:none!important;
  max-width:920px;
  margin:0 auto!important;
}

/* The 2-col login/register block */
.woocommerce-account #customer_login,
.woocommerce-account .u-columns.col2-set{
  display:grid!important;
  grid-template-columns:1fr 1fr;
  gap:24px;
  width:100%!important;
  margin:0!important;
}
.woocommerce-account #customer_login::before,
.woocommerce-account #customer_login::after,
.woocommerce-account .u-columns::before,
.woocommerce-account .u-columns::after{display:none!important;content:none!important}

.woocommerce-account #customer_login .u-column1,
.woocommerce-account #customer_login .u-column2,
.woocommerce-account #customer_login .col-1,
.woocommerce-account #customer_login .col-2{
  width:auto!important;float:none!important;
  background:#fff!important;
  border:1px solid var(--line)!important;
  border-radius:18px!important;
  padding:32px 28px!important;
  margin:0!important;
  box-shadow:0 18px 36px -22px rgba(26,34,56,.08);
}

/* Section headings */
.woocommerce-account #customer_login h2{
  font-family:var(--serif)!important;
  font-size:24px!important;font-weight:600!important;
  letter-spacing:-.01em!important;
  margin:0 0 18px!important;color:var(--ink);
  padding-bottom:14px;border-bottom:1px solid var(--line);
}

/* Form rows + inputs (login + register + lost password) */
.woocommerce-account form.login,
.woocommerce-account form.register,
.woocommerce-account form.lost_reset_password{
  background:transparent!important;border:none!important;
  border-radius:0!important;padding:0!important;margin:0!important;
}
.woocommerce-account form .form-row{margin:0 0 14px}
.woocommerce-account form .form-row label{
  display:block;
  font-size:12px!important;font-weight:600!important;
  color:var(--ink)!important;margin-bottom:6px!important;
  letter-spacing:0!important;text-transform:none!important;
}
.woocommerce-account form .form-row label .required{
  color:var(--critical);text-decoration:none;font-weight:600;border:none;
}
.woocommerce-account form .form-row input.input-text,
.woocommerce-account form .form-row input[type=text],
.woocommerce-account form .form-row input[type=email],
.woocommerce-account form .form-row input[type=password]{
  width:100%!important;
  padding:12px 14px!important;
  border:1px solid var(--line)!important;
  border-radius:10px!important;
  background:#fff!important;
  font-size:14px!important;color:var(--ink)!important;
  font-family:var(--sans)!important;
  transition:border-color .2s, box-shadow .2s;
  box-shadow:none!important;
}
.woocommerce-account form .form-row input:focus{
  outline:none!important;
  border-color:var(--ink)!important;
  box-shadow:0 0 0 3px rgba(26,34,56,.08)!important;
}

/* Show-password toggle */
.woocommerce-account .password-input{position:relative;display:block;width:100%}
.woocommerce-account .show-password-input{
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  color:var(--ink-soft);cursor:pointer;
  width:22px;height:22px;display:grid;place-items:center;
  background:transparent;border:none;
}

/* Remember me */
.woocommerce-account label.woocommerce-form-login__rememberme{
  display:inline-flex!important;align-items:center;gap:8px;
  font-size:13px;font-weight:500;color:var(--ink);
  cursor:pointer;margin:0!important;
}
.woocommerce-account .woocommerce-form__input-checkbox,
.woocommerce-account input[type=checkbox]{
  width:16px;height:16px;margin:0!important;accent-color:var(--ink);
}

/* Submit buttons (Log in, Register, Reset, Save) */
.woocommerce-account form.login button[type=submit],
.woocommerce-account form.register button[type=submit],
.woocommerce-account form.lost_reset_password button[type=submit],
.woocommerce-account form.woocommerce-EditAccountForm button[type=submit],
.woocommerce-account button.woocommerce-Button,
.woocommerce-account .woocommerce-Button{
  background:var(--ink)!important;
  color:var(--paper)!important;
  padding:12px 24px!important;
  border-radius:10px!important;
  font-weight:700!important;font-size:14px!important;
  border:none!important;cursor:pointer;
  text-shadow:none!important;
  transition:background .2s;
  letter-spacing:.02em;
}
.woocommerce-account form.login button[type=submit]:hover,
.woocommerce-account form.register button[type=submit]:hover,
.woocommerce-account form.lost_reset_password button[type=submit]:hover,
.woocommerce-account form.woocommerce-EditAccountForm button[type=submit]:hover,
.woocommerce-account button.woocommerce-Button:hover{
  background:var(--copper)!important;color:var(--paper)!important;
}

/* Lost-password link */
.woocommerce-account form.login p.lost_password{margin-top:4px}
.woocommerce-account form.login p.lost_password a{
  font-size:13px;font-weight:600;color:var(--copper);
  text-decoration:underline;text-underline-offset:3px;
}

/* Privacy / register helper text */
.woocommerce-account form.register p:not(.form-row){
  font-size:12px;color:var(--ink-soft);line-height:1.55;margin:14px 0;
}
.woocommerce-account form.register p a{color:var(--copper);text-decoration:underline}

/* ============================================================
 * Fallback for browsers without :has() — rely on body class
 * ============================================================ */
body.woocommerce-account:not(.logged-in) .woocommerce{
  display:block!important;
  grid-template-columns:none!important;
  max-width:920px;margin:0 auto!important;
}

/* ---------- Responsive ---------- */
@media(max-width:780px){
  .woocommerce-account .woocommerce{
    grid-template-columns:1fr!important;
  }
  .woocommerce-account .woocommerce-MyAccount-navigation{position:static}
  .woocommerce-account #customer_login,
  .woocommerce-account .u-columns.col2-set{
    grid-template-columns:1fr!important;
  }
  .woocommerce-account .woocommerce-Addresses{grid-template-columns:1fr!important}
}
