/* ═══════════════════════════════════════════════════════════════════════
   VividHome — My Account (WooCommerce)
   Login / Register / Dashboard / Orders / Addresses / Edit Account
   ═══════════════════════════════════════════════════════════════════════ */


/* ── Page layout ── */

.woocommerce-account .s-page-content {
  padding-bottom: var(--vh-space-16);
}

.woocommerce-account .s-entry-content {
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
}

.woocommerce-account .s-page-title {
  text-align: center;
  font-family: var(--vh-font-heading), system-ui, sans-serif;
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--vh-ink);
  margin-bottom: var(--vh-space-8);
}


/* ── Notices ── */

.woocommerce-notices-wrapper {
  margin-bottom: var(--vh-space-4);
}

.woocommerce-error,
.woocommerce-message,
.woocommerce-info {
  font-family: 'Onest', var(--vh-font-body), system-ui, sans-serif;
  font-size: 14px;
  line-height: 1.5;
  padding: 14px 18px;
  border-radius: 10px;
  margin-bottom: var(--vh-space-4);
  list-style: none;
}

.woocommerce-error {
  background: #FEF2F2;
  border: 1px solid #FECACA;
  color: #991B1B;
}

.woocommerce-message {
  background: #F0FDF4;
  border: 1px solid #BBF7D0;
  color: #166534;
}

.woocommerce-info {
  background: #EFF6FF;
  border: 1px solid #BFDBFE;
  color: #1E40AF;
}


/* ── Login form heading ── */

.woocommerce-account .woocommerce h2 {
  font-family: var(--vh-font-heading), system-ui, sans-serif;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--vh-ink);
  text-align: center;
  margin: 0 0 var(--vh-space-6);
}


/* ── Form card wrapper ── */

.woocommerce-account .woocommerce form.login,
.woocommerce-account .woocommerce form.register {
  background: #fff;
  border: 1px solid var(--vh-sand);
  border-radius: 16px;
  padding: var(--vh-space-8);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}


/* ── Form rows ── */

.woocommerce-account .form-row {
  margin-bottom: var(--vh-space-4);
}

.woocommerce-account .form-row label {
  display: block;
  font-family: 'Onest', var(--vh-font-body), system-ui, sans-serif;
  font-size: 13px;
  font-weight: 600;
  color: var(--vh-charcoal);
  margin-bottom: 6px;
  letter-spacing: 0.01em;
}

.woocommerce-account .form-row label .required {
  color: #DB2777;
}


/* ── Input fields ── */

.woocommerce-account .woocommerce-Input,
.woocommerce-account .input-text,
.woocommerce-account select {
  width: 100%;
  box-sizing: border-box;
  padding: 12px 16px;
  font-family: 'Onest', var(--vh-font-body), system-ui, sans-serif;
  font-size: 15px;
  color: var(--vh-ink);
  background: var(--vh-ivory);
  border: 1.5px solid var(--vh-sand);
  border-radius: 10px;
  outline: none;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  -webkit-appearance: none;
  appearance: none;
}

.woocommerce-account .woocommerce-Input:focus,
.woocommerce-account .input-text:focus,
.woocommerce-account select:focus {
  border-color: #1B3A8C;
  box-shadow: 0 0 0 3px rgba(27, 58, 140, 0.1);
  background: #fff;
}

.woocommerce-account .woocommerce-Input::placeholder,
.woocommerce-account .input-text::placeholder {
  color: var(--vh-stone);
}


/* ── Password toggle (show/hide) ── */

.woocommerce-account .password-input {
  position: relative;
  display: block;
}

.woocommerce-account .show-password-input {
  position: absolute;
  top: 50%;
  right: 14px;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  padding: 0;
  border: none;
  border-radius: 8px;
  background: transparent;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--vh-stone);
  transition: color 0.2s ease, background 0.2s ease;
}

.woocommerce-account .show-password-input:hover {
  color: var(--vh-ink);
  background: var(--vh-sand);
}

.woocommerce-account .show-password-input.display-password {
  color: #1B3A8C;
}

.woocommerce-account .show-password-input::after {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M1 12s4-8 11-8 11 8 11 8-4 8-11 8-11-8-11-8z'/%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
}

.woocommerce-account .show-password-input.display-password::after {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231B3A8C' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M17.94 17.94A10.07 10.07 0 0 1 12 20c-7 0-11-8-11-8a18.45 18.45 0 0 1 5.06-5.94M9.9 4.24A9.12 9.12 0 0 1 12 4c7 0 11 8 11 8a18.5 18.5 0 0 1-2.16 3.19m-6.72-1.07a3 3 0 1 1-4.24-4.24'/%3E%3Cline x1='1' y1='1' x2='23' y2='23'/%3E%3C/svg%3E");
}

.woocommerce-account .password-input .woocommerce-Input {
  padding-right: 52px;
}


/* ── Remember me ── */

.woocommerce-form-login__rememberme {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  font-family: 'Onest', var(--vh-font-body), system-ui, sans-serif;
  font-size: 14px;
  color: var(--vh-slate);
  cursor: pointer;
}

.woocommerce-form-login__rememberme input[type="checkbox"] {
  width: 18px;
  height: 18px;
  border: 1.5px solid var(--vh-sand);
  border-radius: 5px;
  background: var(--vh-ivory);
  cursor: pointer;
  accent-color: #1B3A8C;
}


/* ── Submit button ── */

.woocommerce-account .woocommerce-button,
.woocommerce-account .button {
  display: block;
  width: 100%;
  padding: 14px 24px;
  font-family: 'Onest', var(--vh-font-body), system-ui, sans-serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.01em;
  color: #fff;
  background: linear-gradient(135deg, #1B3A8C 0%, #7B2D8E 50%, #D41B6B 100%);
  background-size: 200% 200%;
  background-position: 0% 50%;
  border: none;
  border-radius: 50px;
  cursor: pointer;
  text-align: center;
  box-shadow: 0 4px 16px rgba(123, 45, 142, 0.2), 0 1px 3px rgba(0, 0, 0, 0.08);
  transition: background-position 0.4s ease, transform 0.2s ease, box-shadow 0.3s ease;
  margin-top: var(--vh-space-2);
}

.woocommerce-account .woocommerce-button:hover,
.woocommerce-account .button:hover {
  background-position: 100% 50%;
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(123, 45, 142, 0.3), 0 2px 6px rgba(0, 0, 0, 0.1);
}

.woocommerce-account .woocommerce-button:active,
.woocommerce-account .button:active {
  transform: translateY(0);
}


/* ── Lost password link ── */

.woocommerce-LostPassword {
  text-align: center;
  margin-top: var(--vh-space-4);
}

.woocommerce-LostPassword a {
  font-family: 'Onest', var(--vh-font-body), system-ui, sans-serif;
  font-size: 14px;
  color: var(--vh-slate);
  text-decoration: none;
  transition: color 0.2s ease;
}

.woocommerce-LostPassword a:hover {
  color: #1B3A8C;
}


/* ═══════════════════════════════════════════════════════════════════════
   Dashboard (logged-in state)
   ═══════════════════════════════════════════════════════════════════════ */

.woocommerce-account .s-entry-content:has(.woocommerce-MyAccount-navigation) {
  max-width: 960px;
}

.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: var(--vh-space-8);
  align-items: start;
}


/* ── Sidebar navigation ── */

.woocommerce-MyAccount-navigation {
  background: #fff;
  border: 1px solid var(--vh-sand);
  border-radius: 14px;
  padding: 8px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.woocommerce-MyAccount-navigation ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.woocommerce-MyAccount-navigation ul li {
  margin: 0;
}

.woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 10px 16px;
  font-family: 'Onest', var(--vh-font-body), system-ui, sans-serif;
  font-size: 14px;
  font-weight: 500;
  color: var(--vh-slate);
  text-decoration: none;
  border-radius: 8px;
  transition: background 0.15s ease, color 0.15s ease;
}

.woocommerce-MyAccount-navigation ul li a:hover {
  background: var(--vh-ivory);
  color: var(--vh-ink);
}

.woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--dashboard.is-active a {
  background: var(--vh-ink);
  color: #fff;
  font-weight: 600;
}

/* WooCommerce uses body classes for active state */
.woocommerce-account.woocommerce-page .woocommerce-MyAccount-navigation-link--dashboard a,
.woocommerce-account.woocommerce-page .woocommerce-MyAccount-navigation-link--orders a,
.woocommerce-account.woocommerce-page .woocommerce-MyAccount-navigation-link--downloads a,
.woocommerce-account.woocommerce-page .woocommerce-MyAccount-navigation-link--edit-address a,
.woocommerce-account.woocommerce-page .woocommerce-MyAccount-navigation-link--edit-account a,
.woocommerce-account.woocommerce-page .woocommerce-MyAccount-navigation-link--customer-logout a {
  /* default state — not active */
}


/* ── Content area ── */

.woocommerce-MyAccount-content {
  background: #fff;
  border: 1px solid var(--vh-sand);
  border-radius: 14px;
  padding: var(--vh-space-6) var(--vh-space-8);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
  min-height: 300px;
}

.woocommerce-MyAccount-content p {
  font-family: 'Onest', var(--vh-font-body), system-ui, sans-serif;
  font-size: 15px;
  line-height: 1.7;
  color: var(--vh-charcoal);
}

.woocommerce-MyAccount-content a {
  color: #1B3A8C;
  text-decoration: none;
  font-weight: 600;
  transition: color 0.2s ease;
}

.woocommerce-MyAccount-content a:hover {
  color: #7B2D8E;
}


/* ── Orders table ── */

.woocommerce-orders-table {
  width: 100%;
  border-collapse: collapse;
  font-family: 'Onest', var(--vh-font-body), system-ui, sans-serif;
  font-size: 14px;
}

.woocommerce-orders-table thead th {
  text-align: left;
  padding: 10px 12px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--vh-slate);
  border-bottom: 2px solid var(--vh-sand);
}

.woocommerce-orders-table tbody td {
  padding: 12px;
  border-bottom: 1px solid var(--vh-sand);
  color: var(--vh-charcoal);
  vertical-align: middle;
}

.woocommerce-orders-table tbody tr:last-child td {
  border-bottom: none;
}

.woocommerce-orders-table .woocommerce-button {
  display: inline-block;
  width: auto;
  padding: 8px 16px;
  font-size: 12px;
  border-radius: 8px;
  background: var(--vh-ink);
  box-shadow: none;
}

.woocommerce-orders-table .woocommerce-button:hover {
  background: #333;
}


/* ── No orders message ── */

.woocommerce-message--info,
.woocommerce-MyAccount-content .woocommerce-info {
  text-align: center;
  padding: var(--vh-space-8);
}


/* ── Address cards ── */

.woocommerce-Addresses {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--vh-space-4);
}

.woocommerce-Addresses .woocommerce-Address {
  background: var(--vh-ivory);
  border: 1px solid var(--vh-sand);
  border-radius: 12px;
  padding: var(--vh-space-5);
}

.woocommerce-Addresses .woocommerce-Address-title h3 {
  font-family: var(--vh-font-heading), system-ui, sans-serif;
  font-size: 1rem;
  font-weight: 700;
  color: var(--vh-ink);
  margin: 0 0 4px;
}

.woocommerce-Addresses .woocommerce-Address-title a {
  font-size: 13px;
}

.woocommerce-Addresses address {
  font-family: 'Onest', var(--vh-font-body), system-ui, sans-serif;
  font-size: 14px;
  line-height: 1.7;
  color: var(--vh-slate);
  font-style: normal;
}


/* ── Edit account form ── */

.woocommerce-EditAccountForm {
  max-width: 100%;
}

.woocommerce-EditAccountForm fieldset {
  border: 1px solid var(--vh-sand);
  border-radius: 12px;
  padding: var(--vh-space-5);
  margin: var(--vh-space-6) 0;
}

.woocommerce-EditAccountForm fieldset legend {
  font-family: 'Onest', var(--vh-font-body), system-ui, sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--vh-ink);
  padding: 0 8px;
}

.woocommerce-EditAccountForm .form-row-first,
.woocommerce-EditAccountForm .form-row-last {
  display: inline-block;
  width: calc(50% - 8px);
}

.woocommerce-EditAccountForm .form-row-first {
  margin-right: 12px;
}

.woocommerce-EditAccountForm .button {
  width: auto;
  padding: 14px 40px;
}


/* ═══════════════════════════════════════════════════════════════════════
   Responsive
   ═══════════════════════════════════════════════════════════════════════ */

@media (max-width: 767px) {
  .woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) {
    grid-template-columns: 1fr;
    gap: var(--vh-space-4);
  }

  .woocommerce-MyAccount-navigation ul {
    display: flex;
    overflow-x: auto;
    gap: 4px;
    -webkit-overflow-scrolling: touch;
  }

  .woocommerce-MyAccount-navigation ul li a {
    white-space: nowrap;
    padding: 8px 14px;
    font-size: 13px;
  }

  .woocommerce-MyAccount-content {
    padding: var(--vh-space-4) var(--vh-space-5);
  }

  .woocommerce-account form.login,
  .woocommerce-account form.register {
    padding: var(--vh-space-6);
  }

  .woocommerce-Addresses {
    grid-template-columns: 1fr;
  }

  .woocommerce-EditAccountForm .form-row-first,
  .woocommerce-EditAccountForm .form-row-last {
    display: block;
    width: 100%;
    margin-right: 0;
  }

  /* Orders table → card layout */
  .woocommerce-orders-table thead {
    display: none;
  }

  .woocommerce-orders-table tbody tr {
    display: block;
    padding: 12px 0;
    border-bottom: 1px solid var(--vh-sand);
  }

  .woocommerce-orders-table tbody td {
    display: flex;
    justify-content: space-between;
    padding: 4px 0;
    border-bottom: none;
    font-size: 13px;
  }

  .woocommerce-orders-table tbody td::before {
    content: attr(data-title);
    font-weight: 600;
    color: var(--vh-ink);
    margin-right: 12px;
  }
}
