/* BCB Client Portal — Client Dashboard Styles */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,600;1,400&family=DM+Sans:wght@300;400;500&display=swap');

.bcb-portal { font-family: 'DM Sans', sans-serif; color: #0B1F35; }

/* HEADER */
.bcb-portal-header { background: #0B1F35; padding: 32px 40px; }
.bcb-portal-header-in { max-width: 1100px; margin: 0 auto; display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; }
.bcb-portal-welcome { font-size: 11px; font-weight: 500; letter-spacing: .16em; text-transform: uppercase; color: #4A6880; margin: 0 0 6px; }
.bcb-portal-project-name { font-family: 'Cormorant Garamond', serif; font-size: 2rem; font-weight: 600; color: #fff; margin: 0; line-height: 1.1; }
.bcb-portal-header-right { display: flex; align-items: center; gap: 12px; margin-top: 8px; flex-shrink: 0; }
.bcb-portal-status { display: inline-block; padding: 5px 14px; border-radius: 20px; font-size: 11px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; }
.bcb-portal-status--in-queue    { background: rgba(255,255,255,.08); color: #8BA8C0; }
.bcb-portal-status--in-progress { background: rgba(58,143,202,.2); color: #3A8FCA; }
.bcb-portal-status--review      { background: rgba(196,154,58,.2); color: #C49A3A; }
.bcb-portal-status--complete    { background: rgba(11,107,58,.2); color: #4ADE80; }
.bcb-portal-project-switch select { background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.15); color: #fff; border-radius: 4px; padding: 6px 10px; font-size: 13px; font-family: inherit; cursor: pointer; }

/* NOTICES */
.bcb-portal-notice { max-width: 1100px; margin: 20px auto 0; padding: 14px 20px; border-radius: 6px; font-size: 14px; }
.bcb-portal-notice--success { background: #EAF7F0; border: 1px solid #A8DFC2; color: #0B6B3A; }
.bcb-portal-notice--warning { background: #FFF3CD; border: 1px solid #FFD066; color: #856404; }

/* GRID */
.bcb-portal-grid { max-width: 1100px; margin: 0 auto; padding: 32px 40px; display: grid; grid-template-columns: 1fr 320px; gap: 24px; align-items: start; }

/* CARDS */
.bcb-portal-card { background: #fff; border: 1px solid #D6E4EF; border-radius: 8px; padding: 28px; margin-bottom: 20px; }
.bcb-portal-card:last-child { margin-bottom: 0; }
.bcb-portal-card-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.bcb-portal-card-title { font-family: 'Cormorant Garamond', serif; font-size: 1.375rem; font-weight: 600; color: #0B1F35; margin: 0 0 16px; }
.bcb-portal-card-header .bcb-portal-card-title { margin: 0; }
.bcb-portal-card-sub { font-size: 13px; font-weight: 300; color: #4A6880; margin: -8px 0 16px; line-height: 1.5; }

/* PROGRESS */
.bcb-portal-progress-pct { font-family: 'Cormorant Garamond', serif; font-size: 2rem; font-weight: 600; color: #3A8FCA; }
.bcb-portal-progress-track { height: 10px; background: #EEF4F8; border-radius: 5px; overflow: hidden; margin-bottom: 12px; }
.bcb-portal-progress-fill { height: 100%; background: linear-gradient(90deg, #3A8FCA, #C49A3A); border-radius: 5px; transition: width .5s ease; }
.bcb-portal-progress-milestones { display: flex; justify-content: space-between; }
.bcb-portal-progress-milestones span { font-size: 11px; font-weight: 400; color: #B4C8D8; position: relative; }
.bcb-portal-progress-milestones span.active { color: #3A8FCA; font-weight: 500; }

/* SCREENSHOTS */
.bcb-portal-screenshots { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 12px; }
.bcb-portal-screenshot { display: block; border: 1px solid #D6E4EF; border-radius: 6px; overflow: hidden; text-decoration: none; transition: border-color .2s, transform .2s; }
.bcb-portal-screenshot:hover { border-color: #3A8FCA; transform: translateY(-2px); }
.bcb-portal-screenshot img { width: 100%; aspect-ratio: 16/10; object-fit: cover; display: block; }
.bcb-portal-screenshot-caption { display: block; padding: 6px 10px; font-size: 11px; color: #4A6880; background: #f9fbfd; }

/* NOTES */
.bcb-portal-notes { font-size: 14px; font-weight: 300; color: #4A6880; line-height: 1.75; background: #EEF4F8; border-left: 3px solid #3A8FCA; border-radius: 0 6px 6px 0; padding: 16px 20px; }

/* PAYMENT CARD */
.bcb-portal-payment-card { border-top: 3px solid #C49A3A; }
.bcb-portal-payment-rows { margin-bottom: 20px; }
.bcb-portal-payment-row { display: flex; justify-content: space-between; align-items: center; padding: 9px 0; border-bottom: 1px solid #EEF4F8; font-size: 14px; }
.bcb-portal-payment-row:last-child { border-bottom: none; }
.bcb-portal-payment-row span:first-child { color: #4A6880; font-weight: 300; }
.bcb-portal-payment-row span:last-child { font-weight: 500; color: #0B1F35; }
.bcb-portal-payment-row--total span { font-weight: 600; color: #0B1F35; }

.bcb-portal-deposit-paid { display: flex; align-items: center; gap: 8px; background: #EAF7F0; border: 1px solid #A8DFC2; border-radius: 6px; padding: 12px 16px; color: #0B6B3A; font-size: 14px; font-weight: 500; }
.bcb-portal-deposit-paid svg { width: 18px; height: 18px; stroke: #0B6B3A; flex-shrink: 0; }

.bcb-portal-deposit-pending p { font-size: 14px; font-weight: 300; color: #4A6880; margin: 0 0 14px; line-height: 1.6; }
.bcb-portal-pay-btn { width: 100%; background: #0B1F35; color: #fff; border: none; border-radius: 4px; padding: 14px 24px; font-family: inherit; font-size: 13px; font-weight: 500; letter-spacing: .08em; text-transform: uppercase; cursor: pointer; transition: background .2s; }
.bcb-portal-pay-btn:hover { background: #3A8FCA; }
.bcb-portal-pay-btn:disabled { background: #8BA8C0; cursor: not-allowed; }
.bcb-portal-pay-note { font-size: 11px; color: #8BA8C0; text-align: center; margin: 8px 0 0; }

/* CONTACT */
.bcb-portal-contact-body { font-size: 13px; font-weight: 300; color: #4A6880; line-height: 1.6; margin: -6px 0 16px; }
.bcb-portal-contact-links { display: flex; flex-direction: column; gap: 10px; }
.bcb-portal-contact-link { display: flex; align-items: center; gap: 10px; font-size: 14px; font-weight: 400; color: #0B1F35; text-decoration: none; transition: color .2s; }
.bcb-portal-contact-link:hover { color: #3A8FCA; }
.bcb-portal-contact-link svg { width: 16px; height: 16px; stroke: #3A8FCA; flex-shrink: 0; }

.bcb-portal-logout { display: block; text-align: center; font-size: 12px; color: #8BA8C0; text-decoration: none; margin-top: 8px; transition: color .2s; }
.bcb-portal-logout:hover { color: #4A6880; }

/* LOGIN / EMPTY */
.bcb-portal-login, .bcb-portal-empty { padding: 60px 20px; text-align: center; }
.bcb-portal-login__card, .bcb-portal-empty__card { max-width: 400px; margin: 0 auto; background: #fff; border: 1px solid #D6E4EF; border-radius: 8px; padding: 40px; }
.bcb-portal-login__card h2, .bcb-portal-empty__card h2 { font-family: 'Cormorant Garamond', serif; font-size: 1.75rem; color: #0B1F35; margin: 0 0 10px; }
.bcb-portal-login__card p, .bcb-portal-empty__card p { font-size: 14px; font-weight: 300; color: #4A6880; margin: 0 0 24px; }
.bcb-portal-btn { display: inline-block; background: #0B1F35; color: #fff; padding: 12px 28px; border-radius: 4px; font-size: 13px; font-weight: 500; letter-spacing: .08em; text-transform: uppercase; text-decoration: none; transition: background .2s; }
.bcb-portal-btn:hover { background: #3A8FCA; color: #fff; }

@media (max-width: 800px) {
  .bcb-portal-header { padding: 24px 20px; }
  .bcb-portal-header-in { flex-direction: column; gap: 12px; }
  .bcb-portal-grid { grid-template-columns: 1fr; padding: 20px; }
  .bcb-portal-screenshots { grid-template-columns: 1fr 1fr; }
}

/* ── CUSTOM LOGIN FORM ── */
.bcb-login-wrap {
  min-height: 80vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px 20px;
  background: #EEF4F8;
}

.bcb-login-card {
  background: #fff;
  border: 1px solid #D6E4EF;
  border-radius: 10px;
  padding: 48px 44px;
  width: 100%;
  max-width: 440px;
  position: relative;
  overflow: hidden;
}

.bcb-login-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: #3A8FCA;
}

.bcb-login-logo {
  margin-bottom: 28px;
}

.bcb-login-logo img {
  height: 48px;
  width: auto;
  display: block;
}

.bcb-login-header {
  margin-bottom: 28px;
}

.bcb-login-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2rem;
  font-weight: 600;
  color: #0B1F35;
  margin: 0 0 8px;
  line-height: 1.1;
}

.bcb-login-sub {
  font-size: 13px;
  font-weight: 300;
  color: #4A6880;
  line-height: 1.6;
  margin: 0;
}

.bcb-login-form {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.bcb-login-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.bcb-login-field label {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #0B1F35;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.bcb-login-forgot {
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0;
  text-transform: none;
  color: #3A8FCA;
  text-decoration: none;
}
.bcb-login-forgot:hover { text-decoration: underline; }

.bcb-login-field input {
  font-family: 'DM Sans', sans-serif;
  font-size: 15px;
  font-weight: 300;
  color: #0B1F35;
  background: #fff;
  border: 1px solid #D6E4EF;
  border-radius: 4px;
  padding: 12px 16px;
  width: 100%;
  outline: none;
  transition: border-color .2s;
  -webkit-appearance: none;
}
.bcb-login-field input:focus { border-color: #3A8FCA; }
.bcb-login-field input::placeholder { color: #B4C8D8; }

.bcb-login-pw-wrap {
  position: relative;
}
.bcb-login-pw-wrap input {
  padding-right: 44px;
}
.bcb-login-pw-toggle {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  color: #8BA8C0;
  padding: 4px;
  display: flex;
  align-items: center;
  transition: color .2s;
}
.bcb-login-pw-toggle:hover { color: #0B1F35; }
.bcb-login-pw-toggle svg { width: 18px; height: 18px; }

.bcb-login-error {
  background: #FEF0F0;
  border: 1px solid #F5C2C2;
  border-radius: 4px;
  padding: 12px 16px;
  font-size: 13px;
  font-weight: 400;
  color: #A32D2D;
  line-height: 1.5;
}

.bcb-login-btn {
  font-family: 'DM Sans', sans-serif;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #fff;
  background: #0B1F35;
  border: none;
  border-radius: 3px;
  padding: 15px 24px;
  width: 100%;
  cursor: pointer;
  transition: background .2s, transform .15s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 4px;
}
.bcb-login-btn:hover { background: #3A8FCA; transform: translateY(-1px); }
.bcb-login-btn:disabled { background: #8BA8C0; transform: none; cursor: not-allowed; }

.bcb-login-spinner {
  width: 14px;
  height: 14px;
  border: 2px solid rgba(255,255,255,.3);
  border-top-color: #fff;
  border-radius: 50%;
  display: inline-block;
  animation: bcb-spin .7s linear infinite;
}
@keyframes bcb-spin { to { transform: rotate(360deg); } }

.bcb-login-footer {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid #EEF4F8;
  text-align: center;
}
.bcb-login-footer p {
  font-size: 12px;
  font-weight: 300;
  color: #8BA8C0;
  margin: 0 0 6px;
  line-height: 1.5;
}
.bcb-login-footer p:last-child { margin: 0; }
.bcb-login-footer a { color: #3A8FCA; text-decoration: none; }
.bcb-login-footer a:hover { text-decoration: underline; }

@media (max-width: 480px) {
  .bcb-login-card { padding: 32px 24px; }
}

/* Login success message */
.bcb-login-success {
  background: #EAF7F0;
  border: 1px solid #A8DFC2;
  border-radius: 4px;
  padding: 12px 16px;
  font-size: 13px;
  font-weight: 400;
  color: #0B6B3A;
  line-height: 1.5;
}

/* ── BILLING — CLIENT PORTAL ── */
.bcb-portal-final-card { border-top: 3px solid #C49A3A; }
.bcb-portal-badge { font-size: 10px; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; padding: 4px 12px; border-radius: 20px; }
.bcb-portal-badge--gold { background: rgba(196,154,58,.15); color: #C49A3A; }

.bcb-portal-billing-items { display: flex; flex-direction: column; gap: 8px; margin-bottom: 16px; }
.bcb-portal-billing-item { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; background: #EEF4F8; border-radius: 6px; gap: 12px; flex-wrap: wrap; }
.bcb-portal-billing-item--paid { background: #f4f7fa; opacity: .75; }
.bcb-portal-billing-item-info { display: flex; align-items: center; gap: 12px; flex: 1; }
.bcb-portal-billing-name { font-size: 14px; font-weight: 400; color: #0B1F35; }
.bcb-portal-billing-amount { font-size: 14px; font-weight: 500; color: #3A8FCA; margin-left: auto; white-space: nowrap; }
.bcb-portal-billing-active { font-size: 12px; font-weight: 600; color: #0B6B3A; white-space: nowrap; }
.bcb-portal-billing-pending { font-size: 12px; color: #856404; background: #FFF3CD; padding: 3px 10px; border-radius: 10px; white-space: nowrap; }

.bcb-portal-billing-total { font-size: 14px; font-weight: 600; color: #0B1F35; padding: 12px 0; border-top: 1px solid #D6E4EF; margin-bottom: 16px; }

.bcb-portal-sub-btn { font-family: 'DM Sans', sans-serif; font-size: 12px; font-weight: 500; letter-spacing: .08em; text-transform: uppercase; color: #fff; background: #3A8FCA; border: none; border-radius: 3px; padding: 8px 16px; cursor: pointer; transition: background .2s; white-space: nowrap; }
.bcb-portal-sub-btn:hover { background: #0B1F35; }

.bcb-portal-pay-btn--items { background: #3A8FCA; margin-top: 4px; }
.bcb-portal-pay-btn--items:hover { background: #0B1F35; }

.bcb-portal-billing-manage { font-size: 13px; font-weight: 300; color: #4A6880; background: #EEF4F8; border-radius: 6px; padding: 12px 16px; display: flex; align-items: flex-start; gap: 10px; line-height: 1.6; margin-top: 12px; }
.bcb-portal-billing-manage svg { width: 16px; height: 16px; stroke: #8BA8C0; flex-shrink: 0; margin-top: 2px; }
.bcb-portal-billing-manage a { color: #3A8FCA; text-decoration: none; }

.bcb-portal-paid-items { margin-top: 16px; padding-top: 16px; border-top: 1px solid #EEF4F8; display: flex; flex-direction: column; gap: 6px; }

/* ── MANAGE SUBSCRIPTION BUTTON ── */
.bcb-portal-manage-sub-btn {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 400;
  color: #3A8FCA;
  background: none;
  border: 1px solid #D6E4EF;
  border-radius: 4px;
  padding: 10px 16px;
  cursor: pointer;
  width: 100%;
  text-align: left;
  margin-top: 12px;
  transition: border-color .2s, background .2s;
  display: flex;
  align-items: center;
  gap: 8px;
}
.bcb-portal-manage-sub-btn:hover { background: #EEF4F8; border-color: #3A8FCA; }
.bcb-portal-manage-sub-btn::before { content: '⚙'; font-size: 14px; }

/* ── MODAL OVERLAY ── */
.bcb-sub-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(11,31,53,0.6);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.bcb-sub-modal {
  background: #fff;
  border-radius: 10px;
  width: 100%;
  max-width: 480px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(11,31,53,0.3);
}
.bcb-sub-modal-header {
  background: #0B1F35;
  padding: 20px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.bcb-sub-modal-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.25rem;
  font-weight: 600;
  color: #fff;
  margin: 0;
}
.bcb-sub-modal-close {
  background: none;
  border: none;
  color: #8BA8C0;
  font-size: 24px;
  cursor: pointer;
  line-height: 1;
  padding: 0;
  transition: color .2s;
}
.bcb-sub-modal-close:hover { color: #fff; }
.bcb-sub-modal-body { padding: 24px; }
.bcb-sub-modal-sub { font-size: 14px; font-weight: 300; color: #4A6880; margin: 0 0 20px; line-height: 1.6; }

/* Options */
.bcb-sub-options { display: flex; flex-direction: column; gap: 10px; }
.bcb-sub-option {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px;
  border: 1.5px solid #D6E4EF;
  border-radius: 8px;
  cursor: pointer;
  transition: border-color .2s, background .2s;
}
.bcb-sub-option:hover { border-color: #3A8FCA; background: #EEF4F8; }
.bcb-sub-option-icon {
  width: 40px;
  height: 40px;
  background: #EEF4F8;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.bcb-sub-option-icon svg { width: 18px; height: 18px; stroke: #3A8FCA; }
.bcb-sub-option-title { font-size: 14px; font-weight: 500; color: #0B1F35; margin-bottom: 2px; }
.bcb-sub-option-desc { font-size: 12px; font-weight: 300; color: #4A6880; }

/* Message step */
.bcb-sub-selected-label {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #3A8FCA;
  margin-bottom: 10px;
}
.bcb-sub-message {
  width: 100%;
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  font-weight: 300;
  color: #0B1F35;
  border: 1px solid #D6E4EF;
  border-radius: 6px;
  padding: 12px 16px;
  resize: vertical;
  outline: none;
  transition: border-color .2s;
  line-height: 1.6;
}
.bcb-sub-message:focus { border-color: #3A8FCA; }
.bcb-sub-modal-actions { display: flex; justify-content: space-between; align-items: center; margin-top: 14px; }
.bcb-sub-back-btn { background: none; border: 1px solid #D6E4EF; border-radius: 4px; padding: 10px 16px; font-family: 'DM Sans', sans-serif; font-size: 13px; color: #4A6880; cursor: pointer; transition: border-color .2s; }
.bcb-sub-back-btn:hover { border-color: #8BA8C0; }
.bcb-sub-send-btn { background: #0B1F35; color: #fff; border: none; border-radius: 4px; padding: 10px 24px; font-family: 'DM Sans', sans-serif; font-size: 12px; font-weight: 500; letter-spacing: .1em; text-transform: uppercase; cursor: pointer; transition: background .2s; }
.bcb-sub-send-btn:hover { background: #3A8FCA; }
.bcb-sub-send-btn:disabled { background: #8BA8C0; cursor: not-allowed; }

/* Success step */
.bcb-sub-success-wrap { text-align: center; padding: 20px 0; }
.bcb-sub-success-icon { font-size: 3rem; color: #0B6B3A; line-height: 1; margin-bottom: 12px; }
.bcb-sub-success-title { font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; font-weight: 600; color: #0B1F35; margin-bottom: 8px; }
.bcb-sub-success-body { font-size: 14px; font-weight: 300; color: #4A6880; margin-bottom: 20px; }
.bcb-sub-close-btn { background: #0B1F35; color: #fff; border: none; border-radius: 4px; padding: 10px 28px; font-family: 'DM Sans', sans-serif; font-size: 13px; cursor: pointer; transition: background .2s; }
.bcb-sub-close-btn:hover { background: #3A8FCA; }

/* ── TABS ── */
.bcb-portal-tabs-wrap {
  background: #0B1F35;
  border-bottom: 3px solid #1E3A52;
}
.bcb-portal-tabs {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 40px;
  display: flex;
  gap: 4px;
}
.bcb-portal-tab {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 20px;
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 400;
  color: #8BA8C0;
  text-decoration: none;
  border-bottom: 3px solid transparent;
  margin-bottom: -3px;
  transition: color .2s, border-color .2s;
  position: relative;
}
.bcb-portal-tab svg { width: 15px; height: 15px; stroke: currentColor; flex-shrink: 0; }
.bcb-portal-tab:hover { color: #fff; }
.bcb-portal-tab--active { color: #fff; border-bottom-color: #3A8FCA; font-weight: 500; }
.bcb-tab-badge {
  background: #3A8FCA;
  color: #fff;
  font-size: 10px;
  font-weight: 600;
  border-radius: 10px;
  padding: 1px 6px;
  min-width: 16px;
  text-align: center;
}
.bcb-portal-tab-body {
  background: #f4f7fa;
  min-height: 60vh;
}
.bcb-portal-tab-body .bcb-portal-grid {
  max-width: 1100px;
  margin: 0 auto;
  padding: 32px 40px;
}

/* ── FINAL PAYMENT IN SIDEBAR ── */
.bcb-portal-final-due {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid #EEF4F8;
}
.bcb-portal-final-due-label {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #C49A3A;
  margin: 0 0 4px;
}
.bcb-portal-final-due-amount {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2rem;
  font-weight: 600;
  color: #0B1F35;
  margin: 0 0 12px;
}
.bcb-portal-pay-btn--gold { background: #C49A3A; }
.bcb-portal-pay-btn--gold:hover { background: #0B1F35; }

/* ── RENEWAL LIST ── */
.bcb-portal-renewal-list { display: flex; flex-direction: column; gap: 16px; }
.bcb-portal-renewal-item { padding-bottom: 16px; border-bottom: 1px solid #EEF4F8; }
.bcb-portal-renewal-item:last-child { border-bottom: none; padding-bottom: 0; }
.bcb-portal-renewal-name { font-size: 14px; font-weight: 500; color: #0B1F35; margin-bottom: 6px; }
.bcb-portal-renewal-detail { display: flex; justify-content: space-between; margin-bottom: 2px; }
.bcb-portal-renewal-label { font-size: 11px; font-weight: 400; color: #8BA8C0; }
.bcb-portal-renewal-date { font-size: 12px; font-weight: 400; color: #4A6880; }
.bcb-portal-renewal-next { color: #3A8FCA; font-weight: 500; }
.bcb-portal-renewal-amount { font-size: 13px; font-weight: 500; color: #3A8FCA; margin-top: 6px; }

/* ── PURCHASE HISTORY ── */
.bcb-portal-paid-history { display: flex; flex-direction: column; gap: 10px; }
.bcb-portal-history-item { padding: 10px 0; border-bottom: 1px solid #EEF4F8; }
.bcb-portal-history-item:last-child { border-bottom: none; }
.bcb-portal-history-name { font-size: 13px; font-weight: 400; color: #0B1F35; margin-bottom: 3px; }
.bcb-portal-history-meta { display: flex; justify-content: space-between; font-size: 12px; font-weight: 300; color: #8BA8C0; }

/* ── EMPTY STATE ── */
.bcb-portal-empty-state { text-align: center; padding: 32px; }
.bcb-portal-empty-state p { font-size: 14px; font-weight: 300; color: #8BA8C0; margin: 0 0 8px; }

/* ── MARKETING REQUEST ── */
.bcb-mkt-request-form { display: flex; flex-direction: column; }
.bcb-mkt-request-success { background: #EAF7F0; border: 1px solid #A8DFC2; border-radius: 6px; padding: 14px 18px; margin-top: 12px; }
.bcb-mkt-request-success p { font-size: 14px; color: #0B6B3A; margin: 0; }

/* ── RESPONSIVE ── */
@media (max-width: 800px) {
  .bcb-portal-tabs { padding: 0 20px; gap: 0; }
  .bcb-portal-tab { padding: 12px 14px; font-size: 12px; }
  .bcb-portal-tab-body .bcb-portal-grid { padding: 20px; }
}