/* ═══════════════════════════════════════════════════════════
   Comenaranjas – Mi Cuenta Premium
   Estética mediterránea natural
   ═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,500;0,600;0,700;1,400&family=Nunito:wght@300;400;500;600;700&display=swap');

/* ── VARIABLES ─────────────────────────────────────────── */
:root {
    --cn-olive:      #4a5e2f;
    --cn-olive-lt:   #6b7f4a;
    --cn-grove:      #2d3d1a;
    --cn-cream:      #faf6ee;
    --cn-cream-dk:   #f0e9d8;
    --cn-sand:       #e2d5be;
    --cn-terra:      #b5602a;
    --cn-orange:     #e57200;
    --cn-citrus:     #f5a623;
    --cn-text:       #2c2416;
    --cn-muted:      #8a7a62;
    --cn-white:      #ffffff;
    --cn-red:        #c0392b;
    --cn-green:      #27643a;

    --cn-r-xl:  24px;
    --cn-r-lg:  18px;
    --cn-r-md:  12px;
    --cn-r-sm:  8px;

    --cn-shadow:    0 2px 20px rgba(74,94,47,.09);
    --cn-shadow-lg: 0 6px 40px rgba(74,94,47,.14);

    --cn-transition: .22s cubic-bezier(.4,0,.2,1);
}

/* ── RESET WITHIN SCOPE ────────────────────────────────── */
.cnma-wrap *, .cnma-wrap *::before, .cnma-wrap *::after {
    box-sizing: border-box;
}
.cnma-wrap {
    font-family: 'Nunito', system-ui, sans-serif;
    color: var(--cn-text);
}

/* ── LAYOUT ────────────────────────────────────────────── */
.cnma-wrap {
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 28px;
    max-width: 1100px;
    margin: 0 auto;
    padding: 32px 20px 60px;
    align-items: start;
}

@media (max-width: 860px) {
    .cnma-wrap { grid-template-columns: 1fr; }
}

.cnma-content {
    min-width: 0;
}

/* ── NAVIGATION SIDEBAR ────────────────────────────────── */
.cnma-nav {
    background: var(--cn-white);
    border: 1px solid var(--cn-sand);
    border-radius: var(--cn-r-xl);
    overflow: hidden;
    box-shadow: var(--cn-shadow);
    position: sticky;
    top: 24px;
}

/* User card */
.cnma-nav__user {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 22px 20px 18px;
    background: linear-gradient(135deg, var(--cn-grove) 0%, #3d5220 100%);
    position: relative;
    overflow: hidden;
}
.cnma-nav__user::after {
    content: '🍊';
    position: absolute;
    right: -8px; bottom: -14px;
    font-size: 64px;
    opacity: .07;
    pointer-events: none;
}

.cnma-nav__avatar {
    width: 46px; height: 46px;
    border-radius: 50%;
    overflow: hidden;
    border: 2px solid rgba(255,255,255,.25);
    flex-shrink: 0;
    background: rgba(255,255,255,.15);
    display: flex; align-items: center; justify-content: center;
    font-family: 'Lora', serif;
    font-size: 20px; font-weight: 700;
    color: #fff;
}
.cnma-nav__avatar img { width: 100%; height: 100%; object-fit: cover; }

.cnma-nav__name {
    font-weight: 700;
    font-size: 14px;
    color: #fff;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.cnma-nav__email {
    font-size: 11px;
    color: rgba(255,255,255,.55);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Points pill in nav */
.cnma-nav__points {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 13px 18px;
    background: linear-gradient(135deg, #f7f2e8, #efe8d4);
    border-bottom: 1px solid var(--cn-sand);
    text-decoration: none;
    transition: background var(--cn-transition);
}
.cnma-nav__points:hover,
.cnma-nav__points.active { background: linear-gradient(135deg, #eef5e8, #deebd4); }

.cnma-nav__points-icon { font-size: 20px; flex-shrink: 0; }
.cnma-nav__points-val {
    font-family: 'Lora', serif;
    font-size: 15px; font-weight: 700;
    color: var(--cn-olive);
    line-height: 1.2;
}
.cnma-nav__points-lbl { font-size: 10px; color: var(--cn-muted); }
.cnma-nav__points-arrow { margin-left: auto; color: var(--cn-olive-lt); flex-shrink: 0; }

/* Nav list */
.cnma-nav__list {
    list-style: none;
    padding: 8px 0;
    margin: 0;
}

.cnma-nav__item { margin: 0; }
.cnma-nav__item--logout { border-top: 1px solid var(--cn-cream-dk); margin-top: 4px; padding-top: 4px; }

.cnma-nav__link {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 11px 18px;
    text-decoration: none;
    color: var(--cn-muted);
    font-size: 14px;
    font-weight: 500;
    transition: all var(--cn-transition);
    border-radius: 0;
    position: relative;
}
.cnma-nav__link:hover {
    color: var(--cn-olive);
    background: var(--cn-cream);
}
.cnma-nav__item--active .cnma-nav__link {
    color: var(--cn-olive);
    background: linear-gradient(90deg, rgba(74,94,47,.08), transparent);
    font-weight: 700;
}
.cnma-nav__item--active .cnma-nav__link::before {
    content: '';
    position: absolute;
    left: 0; top: 6px; bottom: 6px;
    width: 3px;
    background: var(--cn-olive);
    border-radius: 0 3px 3px 0;
}

.cnma-nav__link-icon { color: var(--cn-olive-lt); flex-shrink: 0; opacity: .8; }
.cnma-nav__item--active .cnma-nav__link-icon { opacity: 1; }
.cnma-nav__link-text { flex: 1; }
.cnma-nav__link-arrow { margin-left: auto; opacity: .35; flex-shrink: 0; }
.cnma-nav__link:hover .cnma-nav__link-arrow { opacity: .7; }

.cnma-nav__item--logout .cnma-nav__link { color: #a04040; }
.cnma-nav__item--logout .cnma-nav__link:hover { background: #fff5f5; color: var(--cn-red); }
.cnma-nav__item--logout .cnma-nav__link-icon { color: #c04040; }

/* Mobile nav toggle - handled in responsive section below */

/* ── PAGE HEADER ───────────────────────────────────────── */
.cnma-page-header {
    margin-bottom: 24px;
}
.cnma-page-title {
    font-family: 'Lora', Georgia, serif;
    font-size: 26px; font-weight: 700;
    color: var(--cn-grove);
    margin: 0 0 4px;
    line-height: 1.2;
}
.cnma-page-subtitle {
    font-size: 14px;
    color: var(--cn-muted);
    margin: 0;
}

/* ── DASHBOARD ─────────────────────────────────────────── */
.cnma-dashboard__welcome {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 24px;
    flex-wrap: wrap;
}
.cnma-dashboard__greeting {
    font-size: 13px;
    color: var(--cn-muted);
    text-transform: uppercase;
    letter-spacing: .08em;
    margin-bottom: 4px;
}
.cnma-dashboard__name {
    font-family: 'Lora', serif;
    font-size: 28px; font-weight: 700;
    color: var(--cn-grove);
    margin: 0;
}

.cnma-dashboard__last-order {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    background: var(--cn-cream);
    border: 1px solid var(--cn-sand);
    border-radius: var(--cn-r-lg);
    text-decoration: none;
    transition: all var(--cn-transition);
    flex-shrink: 0;
}
.cnma-dashboard__last-order:hover {
    border-color: var(--cn-olive-lt);
    box-shadow: var(--cn-shadow);
}
.cnma-dashboard__last-order-label { font-size: 11px; color: var(--cn-muted); }
.cnma-dashboard__last-order-num { font-size: 14px; font-weight: 700; color: var(--cn-olive); }

/* Stats row */
.cnma-dashboard__stats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
    margin-bottom: 28px;
}
@media (max-width: 500px) { .cnma-dashboard__stats { grid-template-columns: 1fr 1fr; } }

.cnma-dashboard__stat {
    background: var(--cn-white);
    border: 1px solid var(--cn-sand);
    border-radius: var(--cn-r-lg);
    padding: 18px 16px;
    text-align: center;
    box-shadow: var(--cn-shadow);
    transition: transform var(--cn-transition), box-shadow var(--cn-transition);
}
.cnma-dashboard__stat:hover {
    transform: translateY(-3px);
    box-shadow: var(--cn-shadow-lg);
}
.cnma-dashboard__stat-icon { font-size: 24px; margin-bottom: 8px; display: block; }
.cnma-dashboard__stat-val {
    font-family: 'Lora', serif;
    font-size: 24px; font-weight: 700;
    color: var(--cn-olive);
    line-height: 1;
    margin-bottom: 4px;
}
.cnma-dashboard__stat-lbl { font-size: 11px; color: var(--cn-muted); font-weight: 600; letter-spacing: .04em; text-transform: uppercase; }

/* Points CTA banner */
.cnma-points-cta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 22px;
    background: linear-gradient(135deg, #f0f7e8, #e4f0d4);
    border: 1.5px solid #c8dfc0;
    border-radius: var(--cn-r-lg);
    text-decoration: none;
    margin-bottom: 28px;
    transition: all var(--cn-transition);
    color: var(--cn-grove);
}
.cnma-points-cta:hover {
    border-color: var(--cn-olive);
    box-shadow: 0 4px 20px rgba(74,94,47,.14);
    transform: translateY(-2px);
}
.cnma-points-cta__left { display: flex; align-items: center; gap: 14px; }
.cnma-points-cta__icon { font-size: 32px; flex-shrink: 0; }
.cnma-points-cta__title { font-size: 15px; font-weight: 700; color: var(--cn-grove); margin-bottom: 2px; }
.cnma-points-cta__sub { font-size: 13px; color: var(--cn-olive-lt); }

/* Quick links */
.cnma-quicklinks {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}
.cnma-quicklink {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 16px;
    background: var(--cn-cream);
    border: 1px solid var(--cn-sand);
    border-radius: var(--cn-r-md);
    text-decoration: none;
    font-size: 14px; font-weight: 600;
    color: var(--cn-text);
    transition: all var(--cn-transition);
}
.cnma-quicklink:hover {
    background: var(--cn-white);
    border-color: var(--cn-olive-lt);
    color: var(--cn-olive);
    transform: translateY(-2px);
    box-shadow: var(--cn-shadow);
}
.cnma-quicklink__icon { font-size: 20px; }

/* ── SECTIONS ──────────────────────────────────────────── */
.cnma-section { margin-bottom: 28px; }
.cnma-section__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
}
.cnma-section__title {
    font-family: 'Lora', serif;
    font-size: 18px; font-weight: 700;
    color: var(--cn-grove);
    margin: 0;
}
.cnma-section__more {
    font-size: 13px;
    color: var(--cn-olive);
    text-decoration: none;
    font-weight: 600;
}
.cnma-section__more:hover { text-decoration: underline; }

/* ── ORDERS LIST ───────────────────────────────────────── */
.cnma-orders-list { display: flex; flex-direction: column; gap: 10px; }

/* Compact row (dashboard) */
.cnma-order-row {
    display: grid;
    grid-template-columns: auto 1fr auto auto auto;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    background: var(--cn-white);
    border: 1px solid var(--cn-sand);
    border-radius: var(--cn-r-md);
    text-decoration: none;
    color: var(--cn-text);
    transition: all var(--cn-transition);
}
.cnma-order-row:hover {
    border-color: var(--cn-olive-lt);
    box-shadow: var(--cn-shadow);
    transform: translateX(4px);
}
.cnma-order-row__label { font-size: 10px; color: var(--cn-muted); text-transform: uppercase; letter-spacing: .06em; }
.cnma-order-row__val { font-size: 15px; font-weight: 700; color: var(--cn-olive); }
.cnma-order-row__date { font-size: 13px; color: var(--cn-muted); }
.cnma-order-row__total { font-size: 15px; font-weight: 700; color: var(--cn-text); }
.cnma-order-row__arrow { color: var(--cn-muted); opacity: .5; }

/* Full order card */
.cnma-order-card {
    background: var(--cn-white);
    border: 1px solid var(--cn-sand);
    border-radius: var(--cn-r-lg);
    overflow: hidden;
    box-shadow: var(--cn-shadow);
    transition: box-shadow var(--cn-transition);
}
.cnma-order-card:hover { box-shadow: var(--cn-shadow-lg); }

.cnma-order-card__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    background: var(--cn-cream);
    border-bottom: 1px solid var(--cn-sand);
    gap: 12px;
    flex-wrap: wrap;
}
.cnma-order-card__num { font-family: 'Lora', serif; font-size: 16px; font-weight: 700; color: var(--cn-grove); margin-right: 10px; }
.cnma-order-card__date { font-size: 13px; color: var(--cn-muted); }

.cnma-order-card__items {
    display: flex;
    gap: 14px;
    padding: 16px 20px;
    overflow-x: auto;
    border-bottom: 1px solid var(--cn-cream-dk);
}
.cnma-order-card__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
    max-width: 80px;
}
.cnma-order-card__item-img {
    width: 60px; height: 60px;
    object-fit: cover;
    border-radius: var(--cn-r-sm);
    border: 1px solid var(--cn-sand);
}
.cnma-order-card__item-name { font-size: 11px; color: var(--cn-muted); text-align: center; line-height: 1.3; }
.cnma-order-card__item-qty { font-size: 11px; font-weight: 700; color: var(--cn-olive); }

.cnma-order-card__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px;
    gap: 12px;
    flex-wrap: wrap;
}
.cnma-order-card__total { font-size: 15px; color: var(--cn-muted); }
.cnma-order-card__total strong { color: var(--cn-text); font-weight: 700; }
.cnma-order-card__actions { display: flex; gap: 8px; }

/* ── ADDRESSES ─────────────────────────────────────────── */
.cnma-addresses-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
}
@media (max-width: 600px) { .cnma-addresses-grid { grid-template-columns: 1fr; } }

.cnma-address-card {
    background: var(--cn-white);
    border: 1px solid var(--cn-sand);
    border-radius: var(--cn-r-lg);
    padding: 22px;
    box-shadow: var(--cn-shadow);
}
.cnma-address-card__header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 16px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--cn-cream-dk);
}
.cnma-address-card__icon { font-size: 22px; }
.cnma-address-card__title {
    font-family: 'Lora', serif;
    font-size: 16px; font-weight: 700;
    color: var(--cn-grove);
    flex: 1;
    margin: 0;
}
.cnma-address-card__edit {
    display: flex; align-items: center; gap: 5px;
    font-size: 13px; font-weight: 600;
    color: var(--cn-olive);
    text-decoration: none;
    padding: 5px 12px;
    border: 1px solid var(--cn-olive-lt);
    border-radius: 99px;
    transition: all var(--cn-transition);
}
.cnma-address-card__edit:hover { background: var(--cn-olive); color: #fff; border-color: var(--cn-olive); }

.cnma-address-card__addr {
    font-size: 14px;
    color: var(--cn-muted);
    font-style: normal;
    line-height: 1.8;
}
.cnma-address-card__empty { color: var(--cn-sand); font-style: italic; }

/* ── PAYMENT METHODS ───────────────────────────────────── */
.cnma-payment-list { display: flex; flex-direction: column; gap: 12px; }

.cnma-payment-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 22px;
    background: var(--cn-white);
    border: 1.5px solid var(--cn-sand);
    border-radius: var(--cn-r-lg);
    box-shadow: var(--cn-shadow);
    flex-wrap: wrap;
}
.cnma-payment-card--default { border-color: var(--cn-olive-lt); }
.cnma-payment-card__info { display: flex; align-items: center; gap: 14px; }
.cnma-payment-card__icon { font-size: 28px; }
.cnma-payment-card__name { font-size: 15px; font-weight: 700; color: var(--cn-text); margin-bottom: 2px; }
.cnma-payment-card__exp { font-size: 12px; color: var(--cn-muted); }
.cnma-payment-card__actions { display: flex; gap: 8px; }

/* ── FORM ──────────────────────────────────────────────── */
.cnma-form { max-width: 580px; }
.cnma-form__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}
@media (max-width: 500px) { .cnma-form__grid { grid-template-columns: 1fr; } }

.cnma-form__field {
    margin-bottom: 18px;
}
.cnma-form__field label {
    display: block;
    font-size: 11px; font-weight: 700;
    text-transform: uppercase; letter-spacing: .09em;
    color: var(--cn-muted);
    margin-bottom: 7px;
}
.cnma-form__req { color: var(--cn-terra); }

.cnma-input {
    width: 100%;
    padding: 13px 16px;
    background: var(--cn-cream);
    border: 1.5px solid var(--cn-sand);
    border-radius: var(--cn-r-sm);
    font-family: 'Nunito', sans-serif;
    font-size: 15px;
    color: var(--cn-text);
    outline: none;
    transition: border-color var(--cn-transition), box-shadow var(--cn-transition), background var(--cn-transition);
    -webkit-appearance: none;
    appearance: none;
}
.cnma-input:focus {
    border-color: var(--cn-olive-lt);
    background: var(--cn-white);
    box-shadow: 0 0 0 4px rgba(107,127,74,.12);
}
.cnma-form__hint { font-size: 12px; color: var(--cn-muted); margin-top: 5px; }

.cnma-form__divider {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 28px 0 20px;
    font-size: 12px; font-weight: 700;
    text-transform: uppercase; letter-spacing: .1em;
    color: var(--cn-muted);
}
.cnma-form__divider::before, .cnma-form__divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--cn-sand);
}

.cnma-form__footer { margin-top: 28px; }

/* ── BUTTONS ───────────────────────────────────────────── */
.cnma-btn-primary,
button.cnma-btn-primary,
input[type="submit"].cnma-btn-primary {
    display: inline-flex;
    align-items: center;
    padding: 14px 28px;
    background: linear-gradient(135deg, var(--cn-olive), var(--cn-olive-lt));
    color: var(--cn-white) !important;
    border: none;
    border-radius: var(--cn-r-sm);
    font-family: 'Nunito', sans-serif;
    font-size: 15px; font-weight: 700;
    cursor: pointer;
    text-decoration: none;
    transition: all var(--cn-transition);
    letter-spacing: .02em;
    box-shadow: 0 4px 16px rgba(74,94,47,.22);
}
.cnma-btn-primary:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(74,94,47,.32);
}

.cnma-btn-sm {
    display: inline-flex;
    align-items: center;
    padding: 7px 14px;
    border-radius: var(--cn-r-sm);
    font-family: 'Nunito', sans-serif;
    font-size: 13px; font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    transition: all var(--cn-transition);
}
.cnma-btn-sm--primary {
    background: var(--cn-olive);
    color: #fff !important;
    border: 1px solid var(--cn-olive);
}
.cnma-btn-sm--primary:hover { background: var(--cn-grove); border-color: var(--cn-grove); }
.cnma-btn-sm--ghost {
    background: transparent;
    color: var(--cn-muted) !important;
    border: 1px solid var(--cn-sand);
}
.cnma-btn-sm--ghost:hover { border-color: var(--cn-muted); color: var(--cn-text) !important; }
.cnma-btn-sm--danger {
    background: transparent;
    color: var(--cn-red) !important;
    border: 1px solid #eac0bb;
}
.cnma-btn-sm--danger:hover { background: #fff0ee; }

/* ── STATUS BADGES ─────────────────────────────────────── */
.cnma-status {
    display: inline-flex;
    align-items: center;
    padding: 3px 10px;
    border-radius: 99px;
    font-size: 11px; font-weight: 700;
    text-transform: uppercase; letter-spacing: .06em;
    white-space: nowrap;
}
.cnma-status--completed   { background: #e8f5e9; color: var(--cn-green); }
.cnma-status--processing  { background: #fff8e1; color: #8a6200; }
.cnma-status--on-hold     { background: #e3f2fd; color: #1565c0; }
.cnma-status--pending     { background: #fce4ec; color: #880e4f; }
.cnma-status--cancelled   { background: #f3e5f5; color: #6a1b9a; }
.cnma-status--refunded    { background: #e8eaf6; color: #283593; }
.cnma-status--failed      { background: #ffebee; color: var(--cn-red); }

/* ── BADGE ─────────────────────────────────────────────── */
.cnma-badge {
    display: inline-flex; padding: 3px 10px;
    border-radius: 99px; font-size: 11px; font-weight: 700;
    text-transform: uppercase; letter-spacing: .06em;
}
.cnma-badge--green { background: #e8f5e9; color: var(--cn-green); }

/* ── EMPTY STATE ───────────────────────────────────────── */
.cnma-empty-state {
    text-align: center;
    padding: 60px 20px;
    background: var(--cn-white);
    border: 1.5px dashed var(--cn-sand);
    border-radius: var(--cn-r-xl);
}
.cnma-empty-state__icon { font-size: 52px; display: block; margin-bottom: 16px; opacity: .6; }
.cnma-empty-state h3 { font-family: 'Lora', serif; font-size: 20px; font-weight: 700; color: var(--cn-grove); margin: 0 0 8px; }
.cnma-empty-state p { font-size: 14px; color: var(--cn-muted); margin: 0 0 24px; }

/* ── PAGINATION ────────────────────────────────────────── */
.cnma-pagination {
    display: flex;
    justify-content: center;
    gap: 6px;
    margin-top: 24px;
}
.cnma-pagination__btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px;
    border: 1.5px solid var(--cn-sand);
    border-radius: var(--cn-r-sm);
    font-size: 14px; font-weight: 600;
    color: var(--cn-muted);
    text-decoration: none;
    transition: all var(--cn-transition);
}
.cnma-pagination__btn:hover { border-color: var(--cn-olive); color: var(--cn-olive); }
.cnma-pagination__btn--active { background: var(--cn-olive); border-color: var(--cn-olive); color: #fff; }

/* ── WOOCOMMERCE NOTICES ───────────────────────────────── */
.cnma-content .woocommerce-message,
.cnma-content .woocommerce-error,
.cnma-content .woocommerce-info {
    border-radius: var(--cn-r-md) !important;
    padding: 14px 18px !important;
    font-family: 'Nunito', sans-serif !important;
    font-size: 14px !important;
    list-style: none !important;
    margin: 0 0 20px !important;
    border-top: none !important;
}
.cnma-content .woocommerce-message { background: #f0f7ee !important; border-left: 4px solid var(--cn-olive) !important; }
.cnma-content .woocommerce-error   { background: #fff0f0 !important; border-left: 4px solid var(--cn-red) !important; }
.cnma-content .woocommerce-info    { background: #f0f4ff !important; border-left: 4px solid #3d67c0 !important; }

/* WC form field overrides inside cnma */
.cnma-content .woocommerce-address-fields .form-row label,
.cnma-content .woocommerce-EditAccountForm .form-row label {
    font-size: 11px !important; font-weight: 700 !important;
    text-transform: uppercase !important; letter-spacing: .09em !important;
    color: var(--cn-muted) !important;
}
.cnma-content .woocommerce-address-fields .form-row input,
.cnma-content .woocommerce-address-fields .form-row select,
.cnma-content .woocommerce-EditAccountForm .form-row input {
    border: 1.5px solid var(--cn-sand) !important;
    border-radius: var(--cn-r-sm) !important;
    padding: 11px 14px !important;
    background: var(--cn-cream) !important;
    font-family: 'Nunito', sans-serif !important;
    font-size: 15px !important;
    transition: border-color var(--cn-transition), box-shadow var(--cn-transition) !important;
}
.cnma-content .woocommerce-address-fields .form-row input:focus,
.cnma-content .woocommerce-address-fields .form-row select:focus,
.cnma-content .woocommerce-EditAccountForm .form-row input:focus {
    border-color: var(--cn-olive-lt) !important;
    box-shadow: 0 0 0 4px rgba(107,127,74,.12) !important;
    background: #fff !important;
    outline: none !important;
}
.cnma-content .woocommerce-Button,
.cnma-content button[type="submit"],
.cnma-content input[type="submit"] {
    background: linear-gradient(135deg, var(--cn-olive), var(--cn-olive-lt)) !important;
    color: #fff !important;
    border: none !important;
    border-radius: var(--cn-r-sm) !important;
    font-family: 'Nunito', sans-serif !important;
    font-size: 15px !important; font-weight: 700 !important;
    padding: 13px 26px !important;
    cursor: pointer !important;
    transition: all var(--cn-transition) !important;
    box-shadow: 0 4px 16px rgba(74,94,47,.22) !important;
    letter-spacing: .02em !important;
}
.cnma-content .woocommerce-Button:hover,
.cnma-content button[type="submit"]:hover,
.cnma-content input[type="submit"]:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 24px rgba(74,94,47,.32) !important;
}

/* ── ANIMATIONS ────────────────────────────────────────── */
@keyframes cnma-rise {
    from { opacity: 0; transform: translateY(16px); }
    to   { opacity: 1; transform: translateY(0); }
}
.cnma-content > * { animation: cnma-rise .4s ease both; }
.cnma-dashboard__stats .cnma-dashboard__stat:nth-child(1) { animation-delay: .06s; }
.cnma-dashboard__stats .cnma-dashboard__stat:nth-child(2) { animation-delay: .12s; }
.cnma-dashboard__stats .cnma-dashboard__stat:nth-child(3) { animation-delay: .18s; }

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
   Desktop ≥ 1024px  (default, ya definido arriba)
   Tablet  768–1023px
   Móvil   ≤ 767px
   Móvil S ≤ 400px
   ══════════════════════════════════════════════════════════ */

/* ── TABLET (768–1023px) ────────────────────────────────── */
@media (max-width: 1023px) {
    .cnma-wrap {
        grid-template-columns: 220px 1fr;
        gap: 20px;
        padding: 24px 16px 48px;
    }

    /* Nav más compacta */
    .cnma-nav__user { padding: 16px 14px; }
    .cnma-nav__avatar { width: 38px; height: 38px; font-size: 16px; }
    .cnma-nav__name { font-size: 13px; }
    .cnma-nav__link { padding: 10px 14px; font-size: 13px; }

    /* Dashboard */
    .cnma-dashboard__name { font-size: 24px; }
    .cnma-dashboard__stat-val { font-size: 20px; }

    /* Pedidos */
    .cnma-order-row { gap: 10px; }
    .cnma-order-card__items { gap: 10px; }

    /* Formularios */
    .cnma-form { max-width: 100%; }
}

/* ── MÓVIL (≤ 767px) ────────────────────────────────────── */
@media (max-width: 767px) {

    /* Layout: sidebar encima, contenido debajo */
    .cnma-wrap {
        grid-template-columns: 1fr;
        gap: 0;
        padding: 0 0 40px;
    }

    /* ── NAV MÓVIL: acordeón horizontal con scroll ─────── */
    .cnma-nav {
        position: static;
        border-radius: 0;
        border-left: none;
        border-right: none;
        border-top: none;
        box-shadow: 0 2px 12px rgba(0,0,0,.08);
    }

    /* User card más compacta */
    .cnma-nav__user {
        padding: 14px 16px;
    }
    .cnma-nav__user::after { display: none; }

    /* Pill de puntos */
    .cnma-nav__points { padding: 10px 16px; }
    .cnma-nav__points-icon { font-size: 18px; }

    /* Nav horizontal con scroll */
    .cnma-nav__list {
        display: flex;
        flex-direction: row;
        overflow-x: auto;
        overflow-y: hidden;
        padding: 6px 8px;
        gap: 4px;
        scrollbar-width: none;
        -ms-overflow-style: none;
        border-top: 1px solid var(--cn-cream-dk);
    }
    .cnma-nav__list::-webkit-scrollbar { display: none; }

    .cnma-nav__item { flex-shrink: 0; }
    .cnma-nav__item--logout { border-top: none; margin-top: 0; padding-top: 0; margin-left: auto; }

    .cnma-nav__link {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 4px;
        padding: 8px 12px;
        border-radius: var(--cn-r-sm);
        font-size: 11px;
        white-space: nowrap;
    }
    .cnma-nav__link-arrow { display: none; }
    .cnma-nav__link-icon { opacity: 1; }

    .cnma-nav__item--active .cnma-nav__link::before { display: none; }
    .cnma-nav__item--active .cnma-nav__link {
        background: var(--cn-olive);
        color: #fff;
    }
    .cnma-nav__item--active .cnma-nav__link-icon { color: #fff; }
    .cnma-nav__item--logout .cnma-nav__link { color: var(--cn-red); }
    .cnma-nav__item--logout .cnma-nav__link:hover { background: #fff0f0; }
    .cnma-nav__item--active.cnma-nav__item--logout .cnma-nav__link { background: var(--cn-red); color: #fff; }

    /* Contenido */
    .cnma-content {
        padding: 20px 16px 0;
    }

    /* ── DASHBOARD MÓVIL ─────────────────────────────────── */
    .cnma-dashboard__welcome {
        flex-direction: column;
        gap: 12px;
        margin-bottom: 18px;
    }
    .cnma-dashboard__name { font-size: 22px; }
    .cnma-dashboard__last-order { align-self: flex-start; }

    .cnma-dashboard__stats {
        grid-template-columns: 1fr 1fr;
    }
    .cnma-dashboard__stat { padding: 14px 12px; }
    .cnma-dashboard__stat-icon { font-size: 20px; margin-bottom: 6px; }
    .cnma-dashboard__stat-val { font-size: 20px; }

    .cnma-points-cta { padding: 14px 16px; gap: 12px; }
    .cnma-points-cta__icon { font-size: 26px; }
    .cnma-points-cta__title { font-size: 14px; }
    .cnma-points-cta__sub { font-size: 12px; }

    .cnma-quicklinks { grid-template-columns: 1fr 1fr; }
    .cnma-quicklink { padding: 12px; font-size: 13px; }

    /* ── PEDIDOS MÓVIL ───────────────────────────────────── */
    .cnma-order-row {
        grid-template-columns: 1fr auto;
        padding: 12px 14px;
    }
    .cnma-order-row__date { display: none; }
    .cnma-order-row__arrow { display: none; }
    .cnma-order-row__num { display: flex; flex-direction: column; }

    .cnma-order-card__header { flex-wrap: wrap; padding: 14px 16px; }
    .cnma-order-card__items { padding: 12px 16px; gap: 10px; }
    .cnma-order-card__item-img { width: 50px; height: 50px; }
    .cnma-order-card__footer { flex-direction: column; align-items: flex-start; padding: 12px 16px; gap: 10px; }
    .cnma-order-card__actions { flex-wrap: wrap; }

    /* ── DIRECCIONES MÓVIL ───────────────────────────────── */
    .cnma-addresses-grid { grid-template-columns: 1fr; gap: 14px; }

    /* ── FORMULARIO MÓVIL ────────────────────────────────── */
    .cnma-form__grid { grid-template-columns: 1fr; gap: 0; }
    .cnma-form { max-width: 100%; }
    .cnma-input { font-size: 16px; } /* evita zoom en iOS */

    /* ── PAGINACIÓN MÓVIL ────────────────────────────────── */
    .cnma-pagination__btn { width: 32px; height: 32px; font-size: 13px; }

    /* ── PAGE HEADER MÓVIL ───────────────────────────────── */
    .cnma-page-title { font-size: 22px; }
}

/* ── MÓVIL PEQUEÑO (≤ 400px) ────────────────────────────── */
@media (max-width: 400px) {
    .cnma-nav__link { padding: 8px 9px; font-size: 10px; }
    .cnma-dashboard__stats { grid-template-columns: 1fr 1fr; }
    .cnma-quicklinks { grid-template-columns: 1fr; }
    .cnma-points-cta { flex-direction: column; align-items: flex-start; }
    .cnma-order-card__actions { flex-direction: column; }
    .cnma-btn-sm { width: 100%; justify-content: center; }
}

/* ── WC PAYMENT METHODS TABLE (native WC HTML) ─────────── */
.cnma-content table.woocommerce-MyAccount-paymentMethods {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0 10px;
    font-family: 'Nunito', sans-serif;
    font-size: 14px;
}
.cnma-content table.woocommerce-MyAccount-paymentMethods thead th {
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .09em;
    color: var(--cn-muted);
    padding: 0 16px 6px;
    border-bottom: 1.5px solid var(--cn-sand);
}
.cnma-content table.woocommerce-MyAccount-paymentMethods tbody tr {
    background: var(--cn-white);
    border: 1px solid var(--cn-sand);
    border-radius: var(--cn-r-md);
    box-shadow: var(--cn-shadow);
    transition: box-shadow var(--cn-transition);
}
.cnma-content table.woocommerce-MyAccount-paymentMethods tbody tr:hover {
    box-shadow: var(--cn-shadow-lg);
}
.cnma-content table.woocommerce-MyAccount-paymentMethods tbody td {
    padding: 14px 16px;
    vertical-align: middle;
}
.cnma-content table.woocommerce-MyAccount-paymentMethods tbody td:first-child {
    border-radius: var(--cn-r-md) 0 0 var(--cn-r-md);
    font-weight: 700;
    color: var(--cn-grove);
}
.cnma-content table.woocommerce-MyAccount-paymentMethods tbody td:last-child {
    border-radius: 0 var(--cn-r-md) var(--cn-r-md) 0;
}
.cnma-content table.woocommerce-MyAccount-paymentMethods .button {
    display: inline-flex;
    align-items: center;
    padding: 6px 14px !important;
    border-radius: var(--cn-r-sm) !important;
    font-family: 'Nunito', sans-serif !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    text-decoration: none;
    margin-right: 6px;
    transition: all var(--cn-transition) !important;
    box-shadow: none !important;
    transform: none !important;
}
.cnma-content .woocommerce-MyAccount-paymentMethods .button:not(.delete) {
    background: transparent !important;
    color: var(--cn-olive) !important;
    border: 1.5px solid var(--cn-olive-lt) !important;
}
.cnma-content .woocommerce-MyAccount-paymentMethods .button:not(.delete):hover {
    background: var(--cn-olive) !important;
    color: #fff !important;
}
.cnma-content .woocommerce-MyAccount-paymentMethods .button.delete {
    background: transparent !important;
    color: var(--cn-red) !important;
    border: 1.5px solid #eac0bb !important;
}
.cnma-content .woocommerce-MyAccount-paymentMethods .button.delete:hover {
    background: #fff0ee !important;
}
