/* ==========================================================================
 * 桌面端银行卡管理页面样式
 * Desktop Bank Cards Page Styles
 * ========================================================================== */

/* 页面 Hero 区域 - 与职业认证页面保持一致 */
.bank-cards-hero {
  background: linear-gradient(135deg, var(--color-gray-900) 0%, var(--color-gray-800) 55%, var(--color-indigo-500) 100%);
  color: var(--color-gray-200);
  border-radius: var(--radius-lg);
  padding: var(--spacing-lg);
  display: flex;
  justify-content: space-between;
  gap: var(--spacing-md);
}

.bank-cards-hero h1 {
  margin: 0 0 var(--spacing-sm);
  font-size: 1.75rem;
}

.bank-cards-hero p {
  margin: 0;
  color: var(--color-gray-300);
}

/* 使 KYC 未通过提示与职业认证页面的状态卡片尺寸保持一致 */
#kycRequired {
  padding: 1.75rem;
  border-radius: var(--radius-lg);
  text-align: center;
}

#kycRequired .card-title { margin: 0 0 0.5rem; }
#kycRequired .muted { margin: 0; }

@media (max-width: 56.25rem) {
  .bank-cards-hero {
    flex-direction: column;
  }
}

/* 银行卡表单 */
.bank-form {
  max-width: 37.5rem;
}

.bank-form__section {
  margin-bottom: var(--spacing-xl);
}

.bank-form__section-title {
  font-size: var(--font-size-base);
  font-weight: 600;
  color: var(--text-muted);
  margin-bottom: var(--spacing-md);
  padding-bottom: var(--spacing-sm);
  border-bottom: var(--border-width-sm) solid var(--border-base);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.bank-form__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-md);
}

@media (max-width: 37.5rem) {
  .bank-form__row {
    grid-template-columns: 1fr;
  }
}

.bank-form__group {
  margin-bottom: var(--spacing-md);
}

.bank-form__label {
  display: block;
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  margin-bottom: var(--spacing-xs);
}

.bank-form__label--required::after {
  content: " *";
  color: var(--color-error);
}

.bank-form__input {
  width: 100%;
  padding: var(--spacing-sm) var(--spacing-md);
  border: var(--border-width-sm) solid var(--border-base);
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  background: var(--bg-surface);
  color: var(--text-base);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.bank-form__input:focus {
  outline: none;
  border-color: var(--color-brand);
  box-shadow: 0 0 0 3px var(--color-focus-ring);
}

.bank-form__input--error {
  border-color: var(--color-error);
}

/* 只读输入框样式（用于从KYC获取的字段） */
.bank-form__input--readonly {
  background: var(--bg-surface-muted);
  color: var(--text-muted);
  cursor: not-allowed;
  border-color: var(--border-subtle);
}

.bank-form__input--readonly:focus {
  border-color: var(--border-subtle);
  box-shadow: none;
}

.bank-form__select {
  width: 100%;
  padding: var(--spacing-sm) var(--spacing-md);
  border: var(--border-width-sm) solid var(--border-base);
  border-radius: var(--radius-md);
  font-size: var(--font-size-base);
  background: var(--bg-surface);
  color: var(--text-base);
}

.bank-form__hint {
  font-size: var(--font-size-xs);
  color: var(--text-subtle);
  margin-top: var(--spacing-xs);
}

/* 信息提示样式（用于KYC来源说明） */
.bank-form__hint--info {
  background: var(--bg-info-subtle);
  color: var(--text-info);
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: var(--radius-md);
  border-left: var(--border-width-lg) solid var(--color-info);
  margin-bottom: var(--spacing-md);
}

/* 条件字段 */
.bank-form__conditional {
  display: none;
}

.bank-form__conditional.is-visible {
  display: block;
}

/* 图片上传 */
.bank-form__upload-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-lg);
}

.bank-form__upload-item {
  text-align: center;
}

.bank-form__upload-box {
  width: 100%;
  aspect-ratio: 16/10;
  border: var(--border-width-md) dashed var(--border-base);
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: border-color var(--transition-fast), background var(--transition-fast);
  background: var(--bg-surface-soft);
  overflow: hidden;
}

.bank-form__upload-box:hover {
  border-color: var(--color-brand);
  background: var(--bg-surface-muted);
}

.bank-form__upload-box--has-image {
  border-style: solid;
}

.bank-form__upload-icon {
  font-size: 2rem;
  margin-bottom: var(--spacing-xs);
}

.bank-form__upload-text {
  font-size: var(--font-size-sm);
  color: var(--text-subtle);
}

.bank-form__upload-preview {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.bank-form__upload-label {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  margin-top: var(--spacing-sm);
}

/* 银行卡网格 */
.bank-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(20rem, 1fr));
  gap: var(--spacing-lg);
}

/* 银行卡卡片 - 中文版（品牌色渐变） */
.bank-card-item {
  background: linear-gradient(135deg, var(--color-brand) 0%, var(--color-brand-dark) 100%);
  border-radius: var(--radius-lg);
  padding: var(--spacing-lg);
  color: var(--color-brand-contrast);
  position: relative;
  min-height: 11.25rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

/* 英文版国际银行卡（蓝色渐变 - 使用 info 色系） */
.bank-card-item--international {
  background: linear-gradient(135deg, var(--color-info-dark) 0%, var(--color-info) 100%);
}

.bank-card-item--pending {
  background: linear-gradient(135deg, var(--color-warning) 0%, var(--color-warning-dark) 100%);
}

.bank-card-item--rejected {
  background: linear-gradient(135deg, var(--color-error) 0%, var(--color-error-dark) 100%);
}

.bank-card-item__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.bank-card-item__bank {
  font-size: var(--font-size-lg);
  font-weight: 600;
}

.bank-card-item__badge {
  font-size: var(--font-size-xs);
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--radius-full);
  background: var(--overlay-light);
}

.bank-card-item__details {
  font-size: var(--font-size-sm);
  opacity: 0.9;
  margin: var(--spacing-sm) 0;
}

.bank-card-item__number {
  font-family: 'Courier New', monospace;
  font-size: var(--font-size-xl);
  letter-spacing: 0.1875rem;
  margin: var(--spacing-md) 0;
}

.bank-card-item__account {
  font-family: monospace;
  font-size: var(--font-size-lg);
  letter-spacing: 0.125rem;
}

.bank-card-item__footer {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}

.bank-card-item__holder {
  font-size: var(--font-size-sm);
  opacity: 0.9;
}

.bank-card-item__status {
  font-size: var(--font-size-xs);
  padding: var(--spacing-2xs) var(--spacing-sm);
  border-radius: var(--radius-sm);
  background: var(--overlay-light);
}

.bank-card-item__actions {
  position: absolute;
  top: var(--spacing-sm);
  right: var(--spacing-sm);
  display: flex;
  gap: var(--spacing-xs);
  opacity: 0;
  transition: opacity var(--transition-fast);
}

.bank-card-item:hover .bank-card-item__actions {
  opacity: 1;
}

.bank-card-item__action {
  width: 1.75rem;
  height: 1.75rem;
  border-radius: var(--radius-full);
  background: var(--overlay-light);
  border: none;
  color: inherit;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.875rem;
}

.bank-card-item__action:hover {
  background: var(--overlay-light);
}

/* 添加卡片按钮 */
.bank-card-add {
  background: var(--bg-surface-soft);
  border: var(--border-width-md) dashed var(--border-base);
  border-radius: var(--radius-lg);
  min-height: 11.25rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: border-color var(--transition-fast), background var(--transition-fast);
}

.bank-card-add:hover {
  border-color: var(--color-brand);
  background: var(--bg-surface-muted);
}

.bank-card-add__icon {
  font-size: 3rem;
  margin-bottom: var(--spacing-sm);
}

.bank-card-add__text {
  color: var(--text-muted);
}

/* 页面通知区域 */
.bank-cards-page__notice {
  margin-top: var(--spacing-lg);
}

/* 表单提示间距变体 */
.bank-form__hint--spaced {
  margin-bottom: var(--spacing-md);
}

/* 输入框大写变体 */
.bank-form__input--uppercase {
  text-transform: uppercase;
}

/* 拒绝原因显示 */
.bank-card-item__fail-reason {
  margin-top: var(--spacing-sm);
  padding: var(--spacing-sm);
  background: var(--overlay-light);
  border-radius: var(--radius-sm);
  font-size: var(--font-size-xs);
  display: flex;
  align-items: flex-start;
  gap: var(--spacing-xs);
}

.bank-card-item__fail-icon {
  flex-shrink: 0;
}

/* 补传图片按钮 */
.bank-card-item__upload-action {
  margin-top: var(--spacing-sm);
  text-align: center;
}

.bank-card-item__upload-action .btn--small {
  font-size: var(--font-size-xs);
  padding: var(--spacing-xs) var(--spacing-sm);
}

/* 图片上传弹窗 */
.bank-upload-modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: var(--z-nav);
  display: flex;
  align-items: center;
  justify-content: center;
}

.bank-upload-modal__overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--bg-overlay);
}

.bank-upload-modal__content {
  position: relative;
  background: var(--bg-surface);
  border-radius: var(--radius-lg);
  padding: var(--spacing-xl);
  max-width: 31.25rem;
  width: 90%;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: var(--shadow-lg);
}

.bank-upload-modal__title {
  font-size: var(--font-size-lg);
  font-weight: 600;
  margin-bottom: var(--spacing-sm);
  color: var(--text-base);
}

.bank-upload-modal__hint {
  font-size: var(--font-size-sm);
  color: var(--text-muted);
  margin-bottom: var(--spacing-lg);
}

.bank-upload-modal__actions {
  display: flex;
  justify-content: flex-end;
  gap: var(--spacing-md);
  margin-top: var(--spacing-lg);
}
