/* ============================================================
   BWH Alumni Membership - Front-End Styles
   ============================================================ */

:root {
    --bwh-primary:   #1a3a5c;
    --bwh-accent:    #c9a84c;
    --bwh-light:     #f4f7fa;
    --bwh-border:    #dce3ea;
    --bwh-text:      #2d3748;
    --bwh-muted:     #718096;
    --bwh-success:   #38a169;
    --bwh-warning:   #d69e2e;
    --bwh-error:     #e53e3e;
    --bwh-radius:    8px;
    --bwh-shadow:    0 2px 12px rgba(0,0,0,.08);
}

.bwh-wrap { max-width: 900px; margin: 0 auto; padding: 20px; font-family: inherit; color: var(--bwh-text); }

/* ---- Cards ---- */
.bwh-card {
    background: #fff;
    border: 1px solid var(--bwh-border);
    border-radius: var(--bwh-radius);
    padding: 28px 32px;
    margin-bottom: 24px;
    box-shadow: var(--bwh-shadow);
}
.bwh-card h3 { margin-top: 0; color: var(--bwh-primary); }

/* ---- Notices ---- */
.bwh-notice {
    padding: 14px 18px;
    border-radius: var(--bwh-radius);
    margin: 14px 0;
    font-size: 14px;
    line-height: 1.5;
}
.bwh-notice-info    { background: #ebf8ff; border-left: 4px solid #3182ce; color: #2c5282; }
.bwh-notice-success { background: #f0fff4; border-left: 4px solid var(--bwh-success); color: #276749; }
.bwh-notice-error   { background: #fff5f5; border-left: 4px solid var(--bwh-error); color: #9b2c2c; }
.bwh-notice-warning { background: #fffbeb; border-left: 4px solid var(--bwh-warning); color: #7b341e; }

/* ---- Buttons ---- */
.bwh-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 22px;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
    cursor: pointer;
    border: 2px solid transparent;
    transition: all .2s;
    white-space: nowrap;
}
.bwh-btn-primary  { background: var(--bwh-primary); color: #fff; border-color: var(--bwh-primary); }
.bwh-btn-primary:hover { background: #12294a; border-color: #12294a; color: #fff; }
.bwh-btn-outline  { background: transparent; color: var(--bwh-primary); border-color: var(--bwh-primary); }
.bwh-btn-outline:hover { background: var(--bwh-primary); color: #fff; }
.bwh-btn-danger   { background: var(--bwh-error); color: #fff; border-color: var(--bwh-error); }
.bwh-btn-sm       { padding: 6px 14px; font-size: 13px; }
.bwh-btn-lg       { padding: 14px 28px; font-size: 16px; }
.bwh-full-width   { width: 100%; }

/* ---- Forms ---- */
.bwh-form { max-width: 600px; }
.bwh-form-group { margin-bottom: 18px; }
.bwh-form-group label { display: block; font-weight: 600; font-size: 13px; margin-bottom: 6px; color: var(--bwh-primary); }
.bwh-form-group input[type=text],
.bwh-form-group input[type=email],
.bwh-form-group input[type=password],
.bwh-form-group input[type=number],
.bwh-form-group input[type=url],
.bwh-form-group select,
.bwh-form-group textarea {
    width: 100%;
    padding: 10px 14px;
    border: 1.5px solid var(--bwh-border);
    border-radius: 6px;
    font-size: 15px;
    background: #fff;
    transition: border-color .2s;
    box-sizing: border-box;
}
.bwh-form-group input:focus,
.bwh-form-group select:focus,
.bwh-form-group textarea:focus { border-color: var(--bwh-primary); outline: none; box-shadow: 0 0 0 3px rgba(26,58,92,.1); }
.bwh-form-row.bwh-two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.bwh-form-inline { margin-bottom: 18px; }
.bwh-form-inline label { font-size: 14px; cursor: pointer; }
.bwh-register-footer { margin-top: 16px; font-size: 13px; text-align: center; color: var(--bwh-muted); }
.bwh-register-footer a { color: var(--bwh-primary); }

/* ---- Tier Selector (register) ---- */
.bwh-tier-select { display: flex; flex-direction: column; gap: 10px; }
.bwh-tier-option { display: flex; align-items: flex-start; gap: 12px; padding: 14px 16px; border: 2px solid var(--bwh-border); border-radius: var(--bwh-radius); cursor: pointer; transition: border-color .2s, background .2s; }
.bwh-tier-option:hover { border-color: var(--bwh-primary); background: var(--bwh-light); }
.bwh-tier-option input[type=radio] { margin-top: 3px; accent-color: var(--bwh-primary); }
.bwh-tier-option input[type=radio]:checked + .bwh-tier-label { color: var(--bwh-primary); }
.bwh-tier-option:has(input:checked) { border-color: var(--bwh-primary); background: #eef4fb; }
.bwh-tier-label { display: flex; flex-direction: column; gap: 3px; }
.bwh-tier-label strong { font-size: 15px; }
.bwh-tier-price { font-size: 18px; font-weight: 700; color: var(--bwh-accent); }
.bwh-tier-feats { font-size: 12px; color: var(--bwh-muted); }

/* ---- Tier Cards (logged-in checkout) ---- */
.bwh-tier-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 20px; }
.bwh-tier-card { background: #fff; border: 2px solid var(--bwh-border); border-radius: var(--bwh-radius); padding: 28px 24px; text-align: center; box-shadow: var(--bwh-shadow); }
.bwh-tier-card h3 { margin: 0 0 8px; color: var(--bwh-primary); }
.bwh-price-big { font-size: 36px; font-weight: 800; color: var(--bwh-accent); margin: 12px 0; }
.bwh-price-big small { font-size: 14px; color: var(--bwh-muted); font-weight: 400; }

/* ---- Pricing Table ---- */
.bwh-pricing-wrap { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 24px; padding: 20px 0; }
.bwh-pricing-card { background: #fff; border: 2px solid var(--bwh-border); border-radius: var(--bwh-radius); padding: 32px 28px; text-align: center; position: relative; box-shadow: var(--bwh-shadow); transition: transform .2s; }
.bwh-pricing-card:hover { transform: translateY(-4px); }
.bwh-pricing-card.bwh-featured { border-color: var(--bwh-primary); }
.bwh-badge { background: var(--bwh-primary); color: #fff; font-size: 11px; font-weight: 700; padding: 4px 14px; border-radius: 20px; display: inline-block; margin-bottom: 10px; text-transform: uppercase; letter-spacing: .5px; }
.bwh-pricing-card h3 { font-size: 22px; margin: 0 0 8px; color: var(--bwh-primary); }
.bwh-price-desc { font-size: 13px; color: var(--bwh-muted); margin: 0 0 16px; }
.bwh-price { margin: 16px 0 24px; }
.bwh-amount { font-size: 48px; font-weight: 800; color: var(--bwh-primary); }
.bwh-period { font-size: 14px; color: var(--bwh-muted); }
.bwh-features { list-style: none; padding: 0; margin: 0 0 28px; text-align: left; }
.bwh-features li { padding: 8px 0; border-bottom: 1px solid var(--bwh-light); font-size: 14px; color: var(--bwh-text); }
.bwh-features li:last-child { border-bottom: none; }

/* ---- Dashboard ---- */
.bwh-dashboard-wrap .bwh-dashboard-header {
    display: flex;
    align-items: center;
    gap: 20px;
    background: var(--bwh-primary);
    color: #fff;
    padding: 24px 28px;
    border-radius: var(--bwh-radius);
    margin-bottom: 24px;
}
.bwh-member-header-info { flex: 1; }
.bwh-member-header-info h2 { margin: 0 0 8px; color: #fff; font-size: 22px; }
.bwh-member-header-avatar img, .bwh-member-header-avatar .avatar { border-radius: 50%; border: 3px solid var(--bwh-accent); }

/* ---- Tabs ---- */
.bwh-tabs { display: flex; gap: 0; border-bottom: 2px solid var(--bwh-border); margin-bottom: 24px; }
.bwh-tab { padding: 12px 20px; text-decoration: none; color: var(--bwh-muted); font-weight: 600; font-size: 14px; border-bottom: 3px solid transparent; margin-bottom: -2px; transition: all .2s; }
.bwh-tab:hover { color: var(--bwh-primary); }
.bwh-tab.active { color: var(--bwh-primary); border-bottom-color: var(--bwh-primary); }

/* ---- Overview Grid ---- */
.bwh-overview-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.bwh-detail-table { width: 100%; border-collapse: collapse; }
.bwh-detail-table th, .bwh-detail-table td { padding: 10px 12px; border-bottom: 1px solid var(--bwh-light); font-size: 14px; }
.bwh-detail-table th { width: 40%; color: var(--bwh-muted); font-weight: 600; }
.bwh-quick-links { list-style: none; padding: 0; margin: 0; }
.bwh-quick-links li { padding: 10px 0; border-bottom: 1px solid var(--bwh-light); }
.bwh-quick-links a { color: var(--bwh-primary); text-decoration: none; font-weight: 500; }
.bwh-quick-links a:hover { text-decoration: underline; }

/* ---- Status Badges ---- */
.bwh-status-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.bwh-status-active    { background: #c6f6d5; color: #22543d; }
.bwh-status-pending   { background: #feebc8; color: #7b341e; }
.bwh-status-expired   { background: #fed7d7; color: #9b2c2c; }
.bwh-status-cancelled { background: #e2e8f0; color: #4a5568; }
.bwh-status-banned    { background: #1a202c; color: #fff; }
.bwh-status-paid      { background: #c6f6d5; color: #22543d; }
.bwh-status-failed    { background: #fed7d7; color: #9b2c2c; }

.bwh-tier-badge { display: inline-block; background: var(--bwh-accent); color: #fff; padding: 3px 10px; border-radius: 20px; font-size: 11px; font-weight: 700; margin-left: 8px; }

/* ---- Payments Table ---- */
.bwh-table { width: 100%; border-collapse: collapse; margin-top: 12px; font-size: 14px; }
.bwh-table th { background: var(--bwh-light); padding: 10px 14px; text-align: left; font-size: 12px; text-transform: uppercase; letter-spacing: .5px; color: var(--bwh-muted); border-bottom: 2px solid var(--bwh-border); }
.bwh-table td { padding: 12px 14px; border-bottom: 1px solid var(--bwh-light); }

/* ---- Directory ---- */
.bwh-directory-wrap h2 { margin-bottom: 20px; color: var(--bwh-primary); }
.bwh-directory-filters { margin-bottom: 20px; }
.bwh-filter-row { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.bwh-filter-row input[type=text], .bwh-filter-row select { padding: 9px 14px; border: 1.5px solid var(--bwh-border); border-radius: 6px; font-size: 14px; }
.bwh-count { color: var(--bwh-muted); font-size: 13px; margin: 0 0 16px; }
.bwh-directory-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 20px; }
.bwh-member-card { background: #fff; border: 1px solid var(--bwh-border); border-radius: var(--bwh-radius); padding: 20px; display: flex; gap: 16px; box-shadow: var(--bwh-shadow); transition: box-shadow .2s; }
.bwh-member-card:hover { box-shadow: 0 4px 20px rgba(0,0,0,.12); }
.bwh-member-card-avatar img, .bwh-member-card-avatar .avatar { border-radius: 50%; border: 2px solid var(--bwh-border); }
.bwh-member-card-info h4 { margin: 0 0 4px; font-size: 15px; color: var(--bwh-primary); }
.bwh-member-title { font-size: 13px; color: var(--bwh-muted); margin: 0 0 8px; }
.bwh-member-tag { display: inline-block; background: var(--bwh-light); color: var(--bwh-primary); padding: 2px 8px; border-radius: 4px; font-size: 11px; font-weight: 600; margin: 2px 2px 2px 0; }
.bwh-member-location { font-size: 12px; color: var(--bwh-muted); margin: 6px 0 0; }
.bwh-linkedin-btn { display: inline-block; margin-top: 8px; background: #0077b5; color: #fff; padding: 4px 10px; border-radius: 4px; font-size: 12px; font-weight: 600; text-decoration: none; }
.bwh-linkedin-btn:hover { background: #005885; color: #fff; }
.bwh-empty { text-align: center; padding: 40px 0; color: var(--bwh-muted); }

/* ---- Pagination ---- */
.bwh-pagination { margin-top: 28px; display: flex; gap: 6px; justify-content: center; flex-wrap: wrap; }
.bwh-page-btn { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 6px; border: 1.5px solid var(--bwh-border); color: var(--bwh-primary); text-decoration: none; font-weight: 600; font-size: 14px; transition: all .2s; }
.bwh-page-btn.active, .bwh-page-btn:hover { background: var(--bwh-primary); color: #fff; border-color: var(--bwh-primary); }

/* ---- Restricted Gate ---- */
.bwh-restricted-gate { text-align: center; padding: 50px 30px; border: 2px dashed var(--bwh-border); border-radius: var(--bwh-radius); background: var(--bwh-light); }
.bwh-gate-icon { font-size: 48px; margin-bottom: 16px; }
.bwh-restricted-gate h3 { color: var(--bwh-primary); margin: 0 0 12px; font-size: 22px; }
.bwh-restricted-gate p { color: var(--bwh-muted); margin: 0 0 24px; }
.bwh-gate-actions { display: flex; gap: 12px; justify-content: center; }

/* ---- Success ---- */
.bwh-success-wrap { text-align: center; padding: 50px 30px; }
.bwh-success-icon { font-size: 64px; margin-bottom: 20px; }
.bwh-success-wrap h2 { color: var(--bwh-primary); font-size: 28px; margin: 0 0 12px; }

/* ---- Login ---- */
.bwh-login-wrap { max-width: 440px; margin: 0 auto; }
.bwh-login-wrap .bwh-form { max-width: 100%; }
.bwh-login-wrap h2 { text-align: center; color: var(--bwh-primary); margin-bottom: 28px; }

/* ---- Register ---- */
.bwh-register-wrap h2 { color: var(--bwh-primary); margin-bottom: 24px; }

/* ---- Avatar Preview ---- */
.bwh-avatar-preview { margin-top: 10px; }
.bwh-avatar-preview img { border-radius: 50%; }

/* ---- Responsive ---- */
@media (max-width: 680px) {
    .bwh-form-row.bwh-two-col { grid-template-columns: 1fr; }
    .bwh-overview-grid { grid-template-columns: 1fr; }
    .bwh-dashboard-header { flex-direction: column; text-align: center; }
    .bwh-tabs { overflow-x: auto; }
    .bwh-pricing-wrap, .bwh-tier-cards { grid-template-columns: 1fr; }
    .bwh-gate-actions { flex-direction: column; align-items: center; }
    .bwh-filter-row { flex-direction: column; }
    .bwh-filter-row input, .bwh-filter-row select { width: 100%; }
}

/* ============================================================
   DONATE FORM
   ============================================================ */
.bwh-donate-wrap { max-width: 580px; margin: 0 auto; }
.bwh-donate-header { text-align: center; margin-bottom: 32px; }
.bwh-donate-icon { font-size: 52px; margin-bottom: 12px; }
.bwh-donate-header h2 { color: var(--bwh-primary); margin: 0 0 10px; font-size: 28px; }
.bwh-donate-header p  { color: var(--bwh-muted); font-size: 15px; margin: 0; }

.bwh-donate-form { background: #fff; border: 1px solid var(--bwh-border); border-radius: var(--bwh-radius); padding: 32px; box-shadow: var(--bwh-shadow); }

/* Amount grid */
.bwh-amount-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.bwh-amount-btn {
    padding: 14px 10px;
    border: 2px solid var(--bwh-border);
    border-radius: var(--bwh-radius);
    background: #fff;
    font-size: 18px;
    font-weight: 700;
    color: var(--bwh-primary);
    cursor: pointer;
    transition: all .2s;
    text-align: center;
}
.bwh-amount-btn:hover  { border-color: var(--bwh-primary); background: var(--bwh-light); }
.bwh-amount-btn.selected { border-color: var(--bwh-primary); background: var(--bwh-primary); color: #fff; }
.bwh-amount-custom { font-size: 15px; font-weight: 600; }

/* Prefix input */
.bwh-input-prefix-wrap { position: relative; }
.bwh-input-prefix { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: var(--bwh-muted); font-size: 16px; font-weight: 600; pointer-events: none; }
.bwh-input-prefix-wrap input { padding-left: 28px !important; font-size: 20px; font-weight: 700; }

/* Checkbox label */
.bwh-checkbox-label { display: flex; align-items: flex-start; gap: 10px; cursor: pointer; font-size: 14px; font-weight: 400; color: var(--bwh-text); }
.bwh-checkbox-label input { margin-top: 2px; accent-color: var(--bwh-primary); flex-shrink: 0; }

/* Donate button */
.bwh-donate-submit { margin-top: 8px; gap: 8px; }
.bwh-donate-secure { text-align: center; font-size: 12px; color: var(--bwh-muted); margin: 12px 0 0; }

/* Success */
.bwh-donation-success { text-align: center; padding: 50px 30px; max-width: 520px; margin: 0 auto; }
.bwh-success-actions  { display: flex; gap: 12px; justify-content: center; margin-top: 24px; flex-wrap: wrap; }

/* Admin gold stat */
.bwh-stat-gold .bwh-stat-num { color: #b7791f; }

/* ============================================================
   BWH PayPal Donation Cards  –  [bwh_paypal_donate]
   ============================================================ */

/* ── Section wrapper ── */
.bwh-pp-section {
    max-width: 960px;
    margin: 0 auto;
    padding: 0 0 48px;
    font-family: inherit;
}

/* ── Header ── */
.bwh-pp-header {
    text-align: center;
    margin-bottom: 44px;
    position: relative;
    padding-top: 8px;
}
.bwh-pp-header-accent {
    width: 56px;
    height: 4px;
    background: linear-gradient(90deg, var(--bwh-accent), #e8c96e);
    border-radius: 2px;
    margin: 0 auto 20px;
}
.bwh-pp-title {
    font-family: 'Georgia', 'Times New Roman', serif;
    font-size: clamp(1.5rem, 3vw, 2.1rem);
    font-weight: 700;
    color: var(--bwh-primary);
    margin: 0 0 12px;
    line-height: 1.25;
    letter-spacing: -0.3px;
}
.bwh-pp-subtitle {
    font-size: 15px;
    color: var(--bwh-muted);
    margin: 0;
    max-width: 480px;
    margin: 0 auto;
    line-height: 1.6;
}

/* ── Grid ── */
.bwh-pp-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 20px;
}

/* ── Card base ── */
.bwh-pp-card {
    position: relative;
    display: flex;
    flex-direction: column;
    background: #ffffff;
    border: 1.5px solid var(--bwh-border);
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(26, 58, 92, 0.07);
    transition: transform 0.22s cubic-bezier(.34,1.56,.64,1),
                box-shadow 0.22s ease,
                border-color 0.2s ease;
    animation: bwh-pp-fadein 0.5s ease both;
    animation-delay: calc(var(--card-index, 0) * 60ms);
}
.bwh-pp-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--bwh-primary) 0%, var(--bwh-accent) 100%);
    opacity: 0;
    transition: opacity 0.2s;
}
.bwh-pp-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 32px rgba(26, 58, 92, 0.14);
    border-color: transparent;
}
.bwh-pp-card:hover::before { opacity: 1; }

/* ── Featured card ── */
.bwh-pp-card--featured {
    border-color: var(--bwh-accent);
    background: linear-gradient(160deg, #fff 60%, #fffbef 100%);
    box-shadow: 0 4px 24px rgba(201, 168, 76, 0.18);
}
.bwh-pp-card--featured::before { opacity: 1; }

/* ── Ribbon on featured ── */
.bwh-pp-ribbon {
    position: absolute;
    top: 14px; right: -28px;
    background: var(--bwh-accent);
    color: #fff;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 1px;
    text-transform: uppercase;
    padding: 4px 36px;
    transform: rotate(35deg);
    transform-origin: top right;
    white-space: nowrap;
    box-shadow: 0 2px 6px rgba(0,0,0,.15);
}

/* ── Icon ── */
.bwh-pp-card-icon {
    font-size: 32px;
    padding: 24px 24px 0;
    line-height: 1;
    filter: drop-shadow(0 2px 4px rgba(0,0,0,0.06));
}

/* ── Card body ── */
.bwh-pp-card-body {
    padding: 16px 24px 12px;
    flex: 1;
}
.bwh-pp-fund-name {
    font-size: 17px;
    font-weight: 700;
    color: var(--bwh-primary);
    margin: 0 0 10px;
    line-height: 1.35;
}
.bwh-pp-amount-badge {
    display: inline-flex;
    align-items: center;
    background: linear-gradient(135deg, #fff8e7 0%, #fef3cd 100%);
    border: 1px solid #e8c96e;
    color: #7a5c00;
    font-size: 13px;
    font-weight: 700;
    padding: 4px 12px;
    border-radius: 20px;
    letter-spacing: 0.2px;
}

/* ── Card footer / button zone ── */
.bwh-pp-card-footer {
    padding: 16px 24px 22px;
    border-top: 1px solid var(--bwh-light);
    background: #fafbfc;
}

/* ── Donate button ── */
.bwh-pp-donate-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 11px 20px;
    background: linear-gradient(135deg, #003087 0%, #009cde 100%);
    color: #ffffff;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.4px;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    text-decoration: none;
    transition: filter 0.18s, transform 0.15s, box-shadow 0.18s;
    box-shadow: 0 3px 10px rgba(0, 48, 135, 0.28);
    position: relative;
    overflow: hidden;
}
.bwh-pp-donate-btn::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(255,255,255,0.12) 0%, transparent 60%);
    pointer-events: none;
}
.bwh-pp-donate-btn:hover {
    filter: brightness(1.1);
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(0, 48, 135, 0.36);
    color: #ffffff;
    text-decoration: none;
}
.bwh-pp-donate-btn:active {
    transform: translateY(0);
    filter: brightness(0.97);
}

/* PP logo SVG colour */
.bwh-pp-btn-pp-logo {
    display: flex;
    align-items: center;
    opacity: 0.9;
    flex-shrink: 0;
}

/* Image variant */
.bwh-pp-donate-btn--img {
    background: transparent;
    padding: 0;
    box-shadow: none;
    border-radius: 0;
}
.bwh-pp-donate-btn--img:hover { filter: none; box-shadow: none; transform: none; }
.bwh-pp-custom-img { max-height: 44px; width: auto; display: block; }

/* PayPal form reset */
.bwh-pp-form { margin: 0; padding: 0; }

/* Secure note */
.bwh-pp-secure-note {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    font-size: 11px;
    color: var(--bwh-muted);
    margin: 10px 0 0;
    opacity: 0.8;
}

/* ── Fade-in keyframe ── */
@keyframes bwh-pp-fadein {
    from { opacity: 0; transform: translateY(14px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ── Responsive ── */
@media (max-width: 600px) {
    .bwh-pp-grid {
        grid-template-columns: 1fr 1fr;
        gap: 14px;
    }
    .bwh-pp-card-icon { font-size: 26px; padding: 18px 18px 0; }
    .bwh-pp-card-body { padding: 12px 18px 10px; }
    .bwh-pp-fund-name { font-size: 14px; }
    .bwh-pp-card-footer { padding: 12px 18px 18px; }
}
@media (max-width: 400px) {
    .bwh-pp-grid { grid-template-columns: 1fr; }
}
