/**
 * WP Moz — My Account Dashboard
 * File: assets/css/page-account.css
 *
 * ── USAGE ──────────────────────────────────────────────────────────
 * This file provides structural CSS for every BEM class emitted by
 * the account template-parts. It is intentionally unopinionated about
 * colours, fonts, or decorative styling — those come from your theme's
 * existing design tokens / variables.
 *
 * Override any rule in a child theme or by adding declarations after
 * the @import of your main stylesheet.
 *
 * ── BEM GLOSSARY ───────────────────────────────────────────────────
 *   .wpmoz-account            → Root two-column wrapper
 *   .wpmoz-account__sidebar   → Left navigation panel
 *   .wpmoz-account__content   → Right main content area
 *   .wpmoz-avatar             → Avatar container
 *   .wpmoz-account__nav       → <nav> element
 *   .wpmoz-account-dashboard  → Dashboard overview section
 *   .wpmoz-account-stats      → Stats strip (orders / total / downloads)
 *   .wpmoz-account-panel      → Reusable card panel
 *   .wpmoz-orders-table       → Orders <table>
 *   .wpmoz-order-badge        → Status pill
 *   .wpmoz-downloads-list     → <ul> of download rows
 *   .wpmoz-address-grid       → Two-column address cards
 *   .wpmoz-address-card       → Single address card
 *   .wpmoz-account-form       → Edit-account / edit-address forms
 *   .wpmoz-pagination         → Page number strip
 *   .wpmoz-btn                → Generic button
 *   .wpmoz-account-empty      → Empty-state block
 * ────────────────────────────────────────────────────────────────── */

/* ══════════════════════════════════════════════════════════════════
   ROOT LAYOUT
   ══════════════════════════════════════════════════════════════════ */

.wpmoz-account {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: var(--wpmoz-account-gap, 2rem);
    align-items: start;
    max-width: var(--wpmoz-account-max-width, 1200px);
    margin-inline: auto;
    padding: var(--wpmoz-account-padding, 2rem 1.5rem);
}

@media (max-width: 900px) {
    .wpmoz-account {
        grid-template-columns: 1fr;
    }
}

/* ══════════════════════════════════════════════════════════════════
   SIDEBAR
   ══════════════════════════════════════════════════════════════════ */

.wpmoz-account__sidebar {
    position: sticky;
    top: var(--wpmoz-sidebar-top, 2rem);
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

/* Identity card */
.wpmoz-account__identity {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.wpmoz-avatar {
    flex-shrink: 0;
}

.wpmoz-avatar__img {
    display: block;
    width: 80px;
    height: 80px;
    border-radius: 50%;
    object-fit: cover;
}

.wpmoz-account__identity-name {
    font-weight: 600;
    margin: 0 0 .2rem;
    line-height: 1.2;
}

.wpmoz-account__identity-role {
    margin: 0;
    font-size: .875em;
    opacity: .65;
}

/* Nav list */
.wpmoz-account__nav-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: .25rem;
}

.wpmoz-account__nav-link {
    display: block;
    padding: .6rem .875rem;
    border-radius: var(--wpmoz-radius, 6px);
    text-decoration: none;
    transition: background-color 150ms ease, color 150ms ease;
}

.wpmoz-account__nav-item.is-active .wpmoz-account__nav-link,
.wpmoz-account__nav-link:hover {
    background-color: var(--wpmoz-nav-hover-bg, rgba(0,0,0,.06));
}

/* Sidebar footer */
.wpmoz-account__sidebar-footer {
    margin-top: auto;
}

.wpmoz-account__logout-btn {
    display: inline-block;
    font-size: .875em;
    opacity: .7;
    text-decoration: none;
}

.wpmoz-account__logout-btn:hover {
    opacity: 1;
    text-decoration: underline;
}

/* ══════════════════════════════════════════════════════════════════
   MAIN CONTENT AREA
   ══════════════════════════════════════════════════════════════════ */

.wpmoz-account__content {
    min-width: 0; /* prevent grid blowout */
}

/* ── Section header ── */
.wpmoz-account-section__header {
    margin-block-end: 1.5rem;
}

.wpmoz-account-section__title {
    font-size: clamp(1.25rem, 2vw, 1.75rem);
    margin: 0 0 .25rem;
    line-height: 1.2;
}

.wpmoz-account-section__desc {
    margin: 0;
    opacity: .7;
}

/* ══════════════════════════════════════════════════════════════════
   DASHBOARD
   ══════════════════════════════════════════════════════════════════ */

.wpmoz-account-dashboard {
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

/* Header */
.wpmoz-account-dashboard__header {
    margin-block-end: 0;
}

.wpmoz-account-dashboard__title {
    font-size: clamp(1.4rem, 3vw, 2rem);
    margin: 0 0 .35rem;
}

.wpmoz-account-dashboard__subtitle {
    margin: 0;
    opacity: .65;
}

/* Stats strip */
.wpmoz-account-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

@media (max-width: 600px) {
    .wpmoz-account-stats {
        grid-template-columns: 1fr;
    }
}

.wpmoz-account-stats__item {
    padding: 1.25rem 1rem;
    border-radius: var(--wpmoz-radius, 8px);
    background: var(--wpmoz-stats-bg, rgba(0,0,0,.04));
    display: flex;
    flex-direction: column;
    gap: .25rem;
}

.wpmoz-account-stats__value {
    font-size: 1.75rem;
    font-weight: 700;
    line-height: 1;
}

.wpmoz-account-stats__label {
    font-size: .8125em;
    opacity: .65;
    text-transform: uppercase;
    letter-spacing: .06em;
}

/* ══════════════════════════════════════════════════════════════════
   PANEL (reusable card)
   ══════════════════════════════════════════════════════════════════ */

.wpmoz-account-panel {
    border: 1px solid var(--wpmoz-border-color, rgba(0,0,0,.1));
    border-radius: var(--wpmoz-radius, 8px);
    overflow: hidden;
}

.wpmoz-account-panel__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1rem 1.25rem;
    border-block-end: 1px solid var(--wpmoz-border-color, rgba(0,0,0,.1));
}

.wpmoz-account-panel__title {
    font-size: 1rem;
    font-weight: 600;
    margin: 0;
}

.wpmoz-account-panel__link {
    font-size: .875em;
    text-decoration: none;
}

.wpmoz-account-panel__link:hover {
    text-decoration: underline;
}

/* ══════════════════════════════════════════════════════════════════
   ORDERS TABLE
   ══════════════════════════════════════════════════════════════════ */

.wpmoz-orders-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.wpmoz-orders-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .9375em;
}

.wpmoz-orders-table th,
.wpmoz-orders-table td {
    padding: .75rem 1.25rem;
    text-align: left;
    border-block-end: 1px solid var(--wpmoz-border-color, rgba(0,0,0,.07));
    vertical-align: middle;
}

.wpmoz-orders-table th {
    font-weight: 600;
    font-size: .8125em;
    text-transform: uppercase;
    letter-spacing: .05em;
    opacity: .6;
}

.wpmoz-orders-table tbody tr:last-child td {
    border-block-end: none;
}

.wpmoz-orders-table a {
    text-decoration: none;
}

.wpmoz-orders-table a:hover {
    text-decoration: underline;
}

.wpmoz-orders-table__actions {
    white-space: nowrap;
}

/* ── Order status badge ── */
.wpmoz-order-badge {
    display: inline-block;
    padding: .2rem .6rem;
    border-radius: 2em;
    font-size: .8125em;
    font-weight: 500;
    line-height: 1.4;
    background: var(--wpmoz-badge-bg, rgba(0,0,0,.08));
}

/* Status colour modifiers — adjust to your palette */
.wpmoz-order-badge.is-completed  { background: var(--wpmoz-status-completed-bg, #d1fae5); color: var(--wpmoz-status-completed-color, #065f46); }
.wpmoz-order-badge.is-processing { background: var(--wpmoz-status-processing-bg, #dbeafe); color: var(--wpmoz-status-processing-color, #1e40af); }
.wpmoz-order-badge.is-on-hold    { background: var(--wpmoz-status-hold-bg, #fef9c3); color: var(--wpmoz-status-hold-color, #854d0e); }
.wpmoz-order-badge.is-pending    { background: var(--wpmoz-status-pending-bg, #f3f4f6); color: var(--wpmoz-status-pending-color, #374151); }
.wpmoz-order-badge.is-cancelled  { background: var(--wpmoz-status-cancelled-bg, #fee2e2); color: var(--wpmoz-status-cancelled-color, #991b1b); }
.wpmoz-order-badge.is-refunded   { background: var(--wpmoz-status-refunded-bg, #f5f3ff); color: var(--wpmoz-status-refunded-color, #5b21b6); }
.wpmoz-order-badge.is-failed     { background: var(--wpmoz-status-failed-bg, #fee2e2); color: var(--wpmoz-status-failed-color, #7f1d1d); }

/* ══════════════════════════════════════════════════════════════════
   DOWNLOADS LIST
   ══════════════════════════════════════════════════════════════════ */

.wpmoz-downloads-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.wpmoz-downloads-list--full .wpmoz-downloads-list__item {
    border-block-end: 1px solid var(--wpmoz-border-color, rgba(0,0,0,.08));
}

.wpmoz-downloads-list--full .wpmoz-downloads-list__item:last-child {
    border-block-end: none;
}

.wpmoz-downloads-list__item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: .875rem 1.25rem;
}

.wpmoz-downloads-list__info {
    display: flex;
    flex-direction: column;
    gap: .2rem;
    min-width: 0;
}

.wpmoz-downloads-list__name {
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.wpmoz-downloads-list__product,
.wpmoz-downloads-list__meta {
    font-size: .8125em;
    opacity: .65;
}

/* ══════════════════════════════════════════════════════════════════
   ADDRESS GRID
   ══════════════════════════════════════════════════════════════════ */

.wpmoz-address-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
}

@media (max-width: 640px) {
    .wpmoz-address-grid {
        grid-template-columns: 1fr;
    }
}

.wpmoz-address-card {
    border: 1px solid var(--wpmoz-border-color, rgba(0,0,0,.1));
    border-radius: var(--wpmoz-radius, 8px);
    overflow: hidden;
}

.wpmoz-address-card__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: .875rem 1.25rem;
    border-block-end: 1px solid var(--wpmoz-border-color, rgba(0,0,0,.08));
}

.wpmoz-address-card__title {
    font-size: 1rem;
    font-weight: 600;
    margin: 0;
}

.wpmoz-address-card__edit {
    font-size: .875em;
    text-decoration: none;
}

.wpmoz-address-card__edit:hover {
    text-decoration: underline;
}

.wpmoz-address-card__body {
    padding: 1rem 1.25rem;
    font-style: normal;
    line-height: 1.6;
}

.wpmoz-address-card__empty {
    opacity: .55;
    font-style: italic;
}

/* ══════════════════════════════════════════════════════════════════
   ACCOUNT FORMS
   ══════════════════════════════════════════════════════════════════ */

.wpmoz-account-form {
    display: flex;
    flex-direction: column;
    gap: 2rem;
    max-width: 560px;
}

.wpmoz-account-form__fieldset {
    border: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
}

.wpmoz-account-form__legend {
    font-size: 1rem;
    font-weight: 600;
    margin-block-end: .25rem;
    padding: 0;
}

.wpmoz-account-form__row--two-col {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}

@media (max-width: 480px) {
    .wpmoz-account-form__row--two-col {
        grid-template-columns: 1fr;
    }
}

.wpmoz-account-form__field {
    display: flex;
    flex-direction: column;
    gap: .4rem;
}

.wpmoz-account-form__field label {
    font-size: .9375em;
    font-weight: 500;
}

.wpmoz-account-form__input {
    padding: .625rem .875rem;
    border: 1px solid var(--wpmoz-input-border, rgba(0,0,0,.2));
    border-radius: var(--wpmoz-radius, 6px);
    font-size: 1rem;
    width: 100%;
    box-sizing: border-box;
    background: var(--wpmoz-input-bg, #fff);
    color: inherit;
    transition: border-color 150ms ease, box-shadow 150ms ease;
}

.wpmoz-account-form__input:focus {
    outline: none;
    border-color: var(--wpmoz-focus-color, currentColor);
    box-shadow: 0 0 0 3px var(--wpmoz-focus-ring, rgba(0,0,0,.08));
}

.wpmoz-account-form__hint {
    font-size: .8125em;
    opacity: .6;
}

.wpmoz-account-form__actions {
    display: flex;
    align-items: center;
    gap: 1rem;
}

/* ══════════════════════════════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════════════════════════════ */

.wpmoz-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .4em;
    padding: .55rem 1.1rem;
    border: 1px solid var(--wpmoz-btn-border, rgba(0,0,0,.2));
    border-radius: var(--wpmoz-radius, 6px);
    background: var(--wpmoz-btn-bg, transparent);
    color: inherit;
    font-size: .9375em;
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    transition: background-color 150ms ease, border-color 150ms ease, opacity 150ms ease;
    white-space: nowrap;
}

.wpmoz-btn:hover {
    background: var(--wpmoz-btn-hover-bg, rgba(0,0,0,.06));
}

.wpmoz-btn--primary {
    background: var(--wpmoz-btn-primary-bg, #111);
    border-color: var(--wpmoz-btn-primary-bg, #111);
    color: var(--wpmoz-btn-primary-color, #fff);
}

.wpmoz-btn--primary:hover {
    opacity: .85;
}

.wpmoz-btn--sm {
    padding: .35rem .75rem;
    font-size: .875em;
}

/* ══════════════════════════════════════════════════════════════════
   PAGINATION
   ══════════════════════════════════════════════════════════════════ */

.wpmoz-pagination {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin-block-start: 1.5rem;
}

.wpmoz-pagination__item {
    min-width: 2.25rem;
    height: 2.25rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--wpmoz-border-color, rgba(0,0,0,.15));
    border-radius: var(--wpmoz-radius, 6px);
    text-decoration: none;
    font-size: .9375em;
    transition: background-color 150ms ease;
}

.wpmoz-pagination__item.is-current,
.wpmoz-pagination__item:hover {
    background: var(--wpmoz-btn-primary-bg, #111);
    border-color: var(--wpmoz-btn-primary-bg, #111);
    color: var(--wpmoz-btn-primary-color, #fff);
}

/* ══════════════════════════════════════════════════════════════════
   EMPTY STATES
   ══════════════════════════════════════════════════════════════════ */

.wpmoz-account-empty {
    padding: 3rem 1.25rem;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1rem;
}

.wpmoz-account-empty p {
    margin: 0;
    opacity: .65;
}

/* ══════════════════════════════════════════════════════════════════
   BACK LINK
   ══════════════════════════════════════════════════════════════════ */

.wpmoz-back-link {
    display: inline-block;
    font-size: .875em;
    text-decoration: none;
    opacity: .65;
    margin-block-end: .5rem;
}

.wpmoz-back-link:hover {
    opacity: 1;
    text-decoration: underline;
}

/* ══════════════════════════════════════════════════════════════════
   VIEW ORDER: delegate styling to WooCommerce hooks
   (woocommerce_view_order outputs its own HTML; style via
   .wpmoz-account-view-order .woocommerce-order-* selectors)
   ══════════════════════════════════════════════════════════════════ */

.wpmoz-account-view-order .wpmoz-account-section__header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 1rem;
}

.wpmoz-account-view-order .wpmoz-account-section__header-left {
    display: flex;
    flex-direction: column;
}

/* ══════════════════════════════════════════════════════════════════
   WOOCOMMERCE NOTICE OVERRIDES
   (WC outputs .woocommerce-message / .woocommerce-error inside our layout)
   ══════════════════════════════════════════════════════════════════ */

.wpmoz-account__content .woocommerce-message,
.wpmoz-account__content .woocommerce-error,
.wpmoz-account__content .woocommerce-info {
    border-radius: var(--wpmoz-radius, 6px);
    margin-block-end: 1.5rem;
}
