/* ============================================================
   MPG My Account – Refined Mining Aesthetic
   Fonts: Cormorant Garamond (display) + DM Sans (body)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;600;700&family=DM+Sans:wght@300;400;500;600&display=swap');

:root {
    --mpa-ink:        #0f1923;
    --mpa-gold:       #b8860b;
    --mpa-gold-light: #d4a52a;
    --mpa-gold-pale:  #fdf6e3;
    --mpa-slate:      #1e2d3d;
    --mpa-slate-mid:  #2d4156;
    --mpa-slate-soft: #f0f4f8;
    --mpa-border:     #d8e2ec;
    --mpa-text:       #2c3e50;
    --mpa-muted:      #7a8fa6;
    --mpa-success:    #1d6e3f;
    --mpa-danger:     #9b1c1c;
    --mpa-danger-bg:  #fef2f2;
    --mpa-radius:     14px;
    --mpa-shadow:     0 4px 32px rgba(15,25,35,.10);
    --mpa-shadow-lg:  0 12px 56px rgba(15,25,35,.15);
}

/* ── Wrapper Layout ── */
.mpa-wrap {
    display: grid;
    grid-template-columns: 280px 1fr;
    gap: 28px;
    max-width: 1140px;
    margin: 48px auto;
    padding: 0 20px 60px;
    font-family: 'DM Sans', sans-serif;
    color: var(--mpa-text);
    align-items: start;
}
@media (max-width: 860px) {
    .mpa-wrap { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════
   SIDEBAR
══════════════════════════════════════ */
.mpa-sidebar {
    position: sticky;
    top: 24px;
}

.mpa-profile-card {
    background: var(--mpa-slate);
    border-radius: var(--mpa-radius);
    padding: 32px 24px 24px;
    text-align: center;
    color: #fff;
    box-shadow: var(--mpa-shadow-lg);
    margin-bottom: 12px;
    position: relative;
    overflow: hidden;
}
.mpa-profile-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--mpa-gold), var(--mpa-gold-light), var(--mpa-gold));
}

/* Avatar */
.mpa-avatar-wrap {
    position: relative;
    width: 96px;
    height: 96px;
    margin: 0 auto 16px;
}
.mpa-avatar-img {
    width: 96px; height: 96px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--mpa-gold);
    display: block;
}
.mpa-avatar-initials {
    width: 96px; height: 96px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--mpa-gold) 0%, var(--mpa-gold-light) 100%);
    display: flex; align-items: center; justify-content: center;
    font-family: 'Cormorant Garamond', serif;
    font-size: 2.2em; font-weight: 700;
    color: var(--mpa-slate);
    border: 3px solid var(--mpa-gold-light);
    letter-spacing: 2px;
}
.mpa-avatar-upload-btn {
    position: absolute;
    bottom: 0; right: 0;
    width: 30px; height: 30px;
    background: var(--mpa-gold);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; font-size: .85em;
    box-shadow: 0 2px 8px rgba(0,0,0,.3);
    transition: transform .15s;
    border: 2px solid var(--mpa-slate);
}
.mpa-avatar-upload-btn:hover { transform: scale(1.1); }

.mpa-profile-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.35em; font-weight: 700;
    color: #fff; margin-bottom: 4px; letter-spacing: .3px;
}
.mpa-profile-email {
    font-size: .82em; color: rgba(255,255,255,.6);
    margin-bottom: 12px; word-break: break-all;
}
.mpa-membership-badge {
    display: inline-block;
    padding: 4px 14px;
    border-radius: 20px;
    font-size: .75em; font-weight: 600;
    letter-spacing: .5px; text-transform: uppercase;
    background: rgba(184,134,11,.2);
    color: var(--mpa-gold-light);
    border: 1px solid rgba(184,134,11,.4);
    margin-bottom: 8px;
}
.mpa-status-badge {
    display: block; font-size: .78em;
    color: rgba(255,255,255,.5); margin-bottom: 8px;
}
.mpa-joined {
    font-size: .75em; color: rgba(255,255,255,.35);
    border-top: 1px solid rgba(255,255,255,.08);
    padding-top: 12px; margin-top: 4px;
}

/* ── Sidebar Nav ── */
.mpa-nav {
    background: #fff;
    border-radius: var(--mpa-radius);
    box-shadow: var(--mpa-shadow);
    overflow: hidden;
}
.mpa-nav-item {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 20px;
    text-decoration: none !important;
    color: var(--mpa-text) !important;
    font-size: .9em; font-weight: 500;
    border-left: 3px solid transparent;
    transition: all .18s;
    border-bottom: 1px solid var(--mpa-slate-soft);
}
.mpa-nav-item:last-child { border-bottom: none; }
.mpa-nav-item:hover { background: var(--mpa-slate-soft); color: var(--mpa-ink) !important; }
.mpa-nav-item.active {
    background: var(--mpa-gold-pale);
    border-left-color: var(--mpa-gold);
    color: var(--mpa-gold) !important;
    font-weight: 600;
}
.mpa-nav-icon { font-size: 1em; width: 20px; text-align: center; }
.mpa-nav-danger { color: var(--mpa-danger) !important; }
.mpa-nav-danger:hover { background: var(--mpa-danger-bg) !important; }
.mpa-nav-logout { color: var(--mpa-muted) !important; font-size: .85em; }
.mpa-nav-logout:hover { background: var(--mpa-slate-soft) !important; }

/* ══════════════════════════════════════
   MAIN TABS
══════════════════════════════════════ */
.mpa-main {
    min-height: 500px;
}
.mpa-tab { display: none; }
.mpa-tab.active { display: block; animation: mpaFadeIn .25s ease; }
@keyframes mpaFadeIn { from { opacity:0; transform:translateY(8px) } to { opacity:1; transform:none } }

.mpa-tab-header {
    margin-bottom: 28px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--mpa-border);
}
.mpa-tab-header h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 2em; font-weight: 700;
    color: var(--mpa-slate); margin: 0 0 6px;
    letter-spacing: -.3px;
}
.mpa-tab-header p { color: var(--mpa-muted); margin: 0; }

/* ── Overview grid ── */
.mpa-overview-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 14px;
    margin-bottom: 36px;
}
.mpa-info-card {
    background: #fff;
    border: 1px solid var(--mpa-border);
    border-radius: 10px;
    padding: 16px 18px;
    display: flex; align-items: center; gap: 14px;
    box-shadow: 0 1px 6px rgba(0,0,0,.05);
    transition: box-shadow .2s, transform .15s;
}
.mpa-info-card:hover { box-shadow: var(--mpa-shadow); transform: translateY(-2px); }
.mpa-ic-icon { font-size: 1.5em; flex-shrink: 0; }
.mpa-ic-label { font-size: .75em; text-transform: uppercase; letter-spacing: .6px; color: var(--mpa-muted); margin-bottom: 3px; }
.mpa-ic-value { font-size: .92em; font-weight: 600; color: var(--mpa-ink); }

/* ── Quick actions ── */
.mpa-quick-actions h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.25em; color: var(--mpa-slate); margin: 0 0 14px;
}
.mpa-qa-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: 12px; }
.mpa-qa-card {
    background: #fff;
    border: 1px solid var(--mpa-border);
    border-radius: 10px;
    padding: 18px 16px;
    text-align: center;
    text-decoration: none !important;
    color: var(--mpa-text) !important;
    font-size: .88em; font-weight: 500;
    transition: all .2s;
    display: flex; flex-direction: column; align-items: center; gap: 8px;
}
.mpa-qa-card:hover {
    border-color: var(--mpa-gold);
    background: var(--mpa-gold-pale);
    color: var(--mpa-gold) !important;
    transform: translateY(-3px);
    box-shadow: 0 4px 16px rgba(184,134,11,.12);
}
.mpa-qa-icon { font-size: 1.6em; }

/* ── Forms ── */
.mpa-form { background: #fff; border-radius: var(--mpa-radius); padding: 28px; box-shadow: var(--mpa-shadow); }
.mpa-form-narrow { max-width: 480px; }
.mpa-form-section { margin-bottom: 28px; padding-bottom: 24px; border-bottom: 1px solid var(--mpa-border); }
.mpa-form-section:last-of-type { border-bottom: none; margin-bottom: 0; }
.mpa-form-section h4 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.05em; font-weight: 700;
    color: var(--mpa-slate); margin: 0 0 18px;
    text-transform: uppercase; letter-spacing: .5px;
}
.mpa-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0 18px; }
@media (max-width: 560px) { .mpa-form-row { grid-template-columns: 1fr; } }

.mpa-field { margin-bottom: 16px; }
.mpa-field label {
    display: block; font-size: .83em; font-weight: 600;
    color: var(--mpa-muted); text-transform: uppercase;
    letter-spacing: .4px; margin-bottom: 6px;
}
.mpa-field input[type=text],
.mpa-field input[type=email],
.mpa-field input[type=tel],
.mpa-field input[type=password],
.mpa-field select,
.mpa-field textarea {
    width: 100%; padding: 10px 14px;
    border: 1.5px solid var(--mpa-border);
    border-radius: 8px; font-size: .93em;
    font-family: 'DM Sans', sans-serif;
    color: var(--mpa-ink);
    background: #fff;
    transition: border-color .2s, box-shadow .2s;
    box-sizing: border-box;
}
.mpa-field input:focus, .mpa-field select:focus, .mpa-field textarea:focus {
    border-color: var(--mpa-gold);
    box-shadow: 0 0 0 3px rgba(184,134,11,.12);
    outline: none;
}
.mpa-field small { font-size: .78em; color: var(--mpa-muted); display: block; margin-top: 5px; }
.mpa-req { color: var(--mpa-danger); }

/* Password input wrapper */
.mpa-pw-wrap { position: relative; }
.mpa-pw-wrap input { padding-right: 42px; }
.mpa-pw-toggle {
    position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
    background: none; border: none; cursor: pointer; font-size: 1em; padding: 0;
    color: var(--mpa-muted);
}

/* Password strength */
.mpa-pw-strength { margin-top: 6px; font-size: .78em; font-weight: 600; }
.mpa-pw-match    { margin-top: 6px; font-size: .78em; font-weight: 600; }
.mpa-strength-weak   { color: #c00; }
.mpa-strength-fair   { color: #c87a00; }
.mpa-strength-good   { color: #0080c8; }
.mpa-strength-strong { color: var(--mpa-success); }
.mpa-match-ok   { color: var(--mpa-success); }
.mpa-match-fail { color: var(--mpa-danger); }

.mpa-form-actions { padding-top: 20px; display: flex; gap: 12px; flex-wrap: wrap; }

/* ── Buttons ── */
.mpa-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    padding: 11px 28px; border-radius: 8px; border: 2px solid transparent;
    font-family: 'DM Sans', sans-serif;
    font-size: .92em; font-weight: 600; cursor: pointer;
    text-decoration: none !important;
    transition: all .18s;
}
.mpa-btn:hover { transform: translateY(-1px); }
.mpa-btn-primary { background: var(--mpa-slate); color: #fff; border-color: var(--mpa-slate); }
.mpa-btn-primary:hover { background: var(--mpa-ink); }
.mpa-btn-accent { background: var(--mpa-gold); color: #fff; border-color: var(--mpa-gold); }
.mpa-btn-accent:hover { background: var(--mpa-gold-light); }
.mpa-btn-outline { background: transparent; color: var(--mpa-text); border-color: var(--mpa-border); }
.mpa-btn-outline:hover { border-color: var(--mpa-slate); color: var(--mpa-slate); }
.mpa-btn-danger { background: var(--mpa-danger); color: #fff; border-color: var(--mpa-danger); }
.mpa-btn-danger:hover { background: #7f1d1d; }

/* ── Alerts ── */
.mpa-alert {
    padding: 12px 16px; border-radius: 8px;
    margin-bottom: 20px; font-size: .88em;
}
.mpa-alert-success { background: #ecfdf5; border-left: 3px solid var(--mpa-success); color: #065f46; }
.mpa-alert-error   { background: var(--mpa-danger-bg); border-left: 3px solid var(--mpa-danger); color: #991b1b; }

/* ── Membership card display ── */
.mpa-membership-card-display {
    background: #fff;
    border-radius: var(--mpa-radius);
    box-shadow: var(--mpa-shadow);
    overflow: hidden;
}
.mpa-mc-header {
    background: var(--mpa-slate);
    padding: 28px 32px;
    display: flex; align-items: center; gap: 18px;
    position: relative;
}
.mpa-mc-header::before {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 2px;
    background: linear-gradient(90deg, var(--mpa-gold), transparent);
}
.mpa-mc-icon { font-size: 2.8em; }
.mpa-mc-type { font-family: 'Cormorant Garamond', serif; font-size: 1.5em; font-weight: 700; color: #fff; }
.mpa-mc-status { font-size: .82em; font-weight: 600; margin-top: 4px; }
.mpa-status-approved, .mpa-status-Active { color: #6ee7b7; }
.mpa-status-pending  { color: #fcd34d; }
.mpa-status-rejected { color: #fca5a5; }
.mpa-mc-since { padding: 16px 32px; font-size: .85em; color: var(--mpa-muted); border-bottom: 1px solid var(--mpa-border); }

.mpa-mc-benefits { padding: 24px 32px; }
.mpa-mc-benefits h4 { font-size: .85em; text-transform: uppercase; letter-spacing: .6px; color: var(--mpa-muted); margin: 0 0 14px; }
.mpa-mc-benefits ul { list-style: none; padding: 0; margin: 0; }
.mpa-mc-benefits ul li { padding: 7px 0; font-size: .92em; border-bottom: 1px solid var(--mpa-slate-soft); color: var(--mpa-text); }
.mpa-mc-benefits ul li:last-child { border-bottom: none; }
.mpa-benefit-locked { color: var(--mpa-muted) !important; font-style: italic; }

.mpa-upgrade-cta { background: var(--mpa-gold-pale); padding: 24px 32px; border-top: 1px solid rgba(184,134,11,.2); }
.mpa-upgrade-cta h4 { font-family: 'Cormorant Garamond', serif; font-size: 1.15em; color: var(--mpa-gold); margin: 0 0 8px; }
.mpa-upgrade-cta p { font-size: .88em; color: #6b5300; margin: 0 0 16px; }

/* ── Danger zone ── */
.mpa-danger-card {
    background: #fff;
    border: 1px solid #fecaca;
    border-radius: var(--mpa-radius);
    padding: 28px 32px;
    box-shadow: var(--mpa-shadow);
}
.mpa-danger-card h3 { color: var(--mpa-danger); margin: 0 0 10px; }
.mpa-danger-card p { color: #555; margin: 0 0 20px; font-size: .92em; }

/* Inner modal (delete confirm) */
.mpa-inner-modal {
    position: fixed; inset: 0; z-index: 9999;
    background: rgba(10,20,35,.6);
    display: flex; align-items: center; justify-content: center;
    padding: 20px;
}
.mpa-inner-modal-box {
    background: #fff; border-radius: var(--mpa-radius);
    padding: 36px; max-width: 420px; width: 100%;
    box-shadow: var(--mpa-shadow-lg);
    animation: mpaFadeIn .2s ease;
}
.mpa-inner-modal-box h3 { color: var(--mpa-danger); margin: 0 0 12px; }
.mpa-inner-modal-box p { color: #555; margin: 0 0 20px; font-size: .92em; }

/* ── Toast ── */
.mpa-toast {
    position: fixed; bottom: 28px; right: 28px; z-index: 99999;
    background: var(--mpa-slate); color: #fff;
    padding: 14px 24px; border-radius: 10px;
    font-family: 'DM Sans', sans-serif; font-size: .9em; font-weight: 500;
    box-shadow: 0 8px 32px rgba(0,0,0,.2);
    border-left: 4px solid var(--mpa-gold);
    animation: mpaSlideIn .3s ease;
    max-width: 320px;
}
.mpa-toast.mpa-toast-error { border-left-color: var(--mpa-danger); }
@keyframes mpaSlideIn { from { opacity:0; transform:translateX(20px) } to { opacity:1; transform:none } }

/* ── Login prompt ── */
.mpa-login-prompt {
    display: flex; align-items: center; justify-content: center;
    min-height: 400px; font-family: 'DM Sans', sans-serif;
}
.mpa-lp-inner { text-align: center; max-width: 340px; }
.mpa-lp-icon { font-size: 3em; margin-bottom: 16px; }
.mpa-lp-inner h2 { font-family: 'Cormorant Garamond', serif; color: var(--mpa-slate); }
.mpa-lp-inner p { color: var(--mpa-muted); margin-bottom: 24px; }

/* ── Avatar upload spinner ── */
.mpa-avatar-loading { opacity: .6; pointer-events: none; }
