/* Account pages — login / register / dashboard */

.account-main {
  padding-top: var(--space-lg);
  padding-bottom: var(--space-xl);
}

.account-card {
  max-width: 640px;
  margin: 0 auto;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
}

.account-card h1 {
  margin-bottom: var(--space-xs);
}

.account-lede {
  color: var(--text-dim);
  margin-bottom: var(--space-md);
}

.account-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.account-form label {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  font-size: 0.9rem;
  color: var(--text-dim);
}

.account-form input,
.account-form select,
.account-form textarea {
  padding: 0.6rem 0.75rem;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  font: inherit;
}

.account-form input:focus,
.account-form select:focus,
.account-form textarea:focus {
  outline: none;
  border-color: var(--accent);
}

.account-form input:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.account-form .hint {
  color: var(--text-dim);
  font-weight: normal;
  font-size: 0.85em;
}

.address-fieldset {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: var(--space-sm);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  margin-top: var(--space-xs);
}

.address-fieldset legend {
  padding: 0 0.5rem;
  color: var(--text-dim);
  font-size: 0.9rem;
}

.account-form .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-sm);
}

@media (max-width: 540px) {
  .account-form .form-row { grid-template-columns: 1fr; }
}

.account-form .cta {
  align-self: flex-start;
  margin-top: var(--space-sm);
}

.account-message {
  padding: 0.6rem 0.85rem;
  border-radius: var(--radius);
  font-size: 0.9rem;
  background: var(--surface-2);
  border: 1px solid var(--border);
  color: var(--text);
}

.account-message.error {
  border-color: #b91c1c;
  color: #fca5a5;
}

.account-message.success {
  border-color: #15803d;
  color: #86efac;
}

.account-foot {
  margin-top: var(--space-md);
  color: var(--text-dim);
  font-size: 0.9rem;
}

.account-foot a { color: var(--accent); }

.account-dash-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
}

.account-section-head {
  margin-top: var(--space-md);
  margin-bottom: var(--space-xs);
  font-size: 1.1rem;
  border-bottom: 1px solid var(--border);
  padding-bottom: 0.35rem;
}

.account-empty {
  color: var(--text-dim);
  font-size: 0.95rem;
  margin-top: var(--space-xs);
}

.cta-secondary {
  background: transparent;
  border: 1px solid var(--accent);
  color: var(--accent);
}

/* Header sign-in widget (shared with index.html via inline placement) */
.account-header-slot {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: 0.9rem;
  color: var(--text-dim);
}

.account-header-slot a {
  color: var(--accent);
  text-decoration: none;
}

.account-header-slot a:hover { text-decoration: underline; }

/* Checkout / order views */

.checkout-items {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface-2);
  margin-bottom: var(--space-sm);
}

.checkout-item {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 0.55rem 0.85rem;
  border-bottom: 1px solid var(--border);
  gap: var(--space-sm);
}
.checkout-item:last-child { border-bottom: none; }

.checkout-item-name { color: var(--text); }
.checkout-item-price { color: var(--text-dim); white-space: nowrap; }

.checkout-totals {
  margin-bottom: var(--space-md);
  padding: var(--space-xs) 0;
}

.checkout-row {
  display: flex;
  justify-content: space-between;
  padding: 0.25rem 0;
  color: var(--text-dim);
}

.checkout-row.total {
  border-top: 1px solid var(--border);
  margin-top: 0.4rem;
  padding-top: 0.6rem;
  color: var(--text);
  font-weight: 600;
  font-size: 1.05rem;
}

.order-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
  font-size: 0.9rem;
}
.order-meta-row { display: inline-flex; gap: 0.45rem; align-items: baseline; }

.order-status {
  display: inline-block;
  padding: 0.15rem 0.55rem;
  border-radius: 999px;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: var(--surface-2);
  border: 1px solid var(--border);
  color: var(--text-dim);
}

.order-status-pending   { color: #fbbf24; border-color: #92400e; }
.order-status-confirmed { color: #60a5fa; border-color: #1e40af; }
.order-status-shipped   { color: #a78bfa; border-color: #5b21b6; }
.order-status-delivered { color: #86efac; border-color: #15803d; }
.order-status-cancelled { color: #fca5a5; border-color: #b91c1c; }

.order-shipping {
  color: var(--text);
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.6rem 0.85rem;
  font-size: 0.95rem;
  white-space: pre-line;
}

.order-notes {
  color: var(--text);
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0.6rem 0.85rem;
  white-space: pre-wrap;
}

.order-list {
  list-style: none;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}

.order-list-item { border-bottom: 1px solid var(--border); }
.order-list-item:last-child { border-bottom: none; }

.order-list-link {
  display: grid;
  grid-template-columns: 1fr auto auto auto;
  gap: var(--space-sm);
  align-items: center;
  padding: 0.6rem 0.85rem;
  background: var(--surface-2);
  color: var(--text);
  text-decoration: none;
}

.order-list-link:hover { background: var(--surface); }

.order-list-id   { font-family: ui-monospace, "SFMono-Regular", Menlo, monospace; font-size: 0.85rem; color: var(--text-dim); }
.order-list-date { color: var(--text-dim); font-size: 0.9rem; }
.order-list-total { font-weight: 600; }
