/* ===== Dashboard v2 Tokens ===== */
.brokerage-v2 {
  --paper:     oklch(96.5% 0.018 85);
  --paper-2:   oklch(93.5% 0.024 82);
  --paper-3:   oklch(90% 0.03 80);
  --ink:       oklch(17% 0.025 50);
  --ink-soft:  oklch(34% 0.022 50);
  --ink-mute:  oklch(54% 0.018 55);
  --rule:      oklch(74% 0.025 60);
  --rule-soft: oklch(85% 0.02 60);
  --up:        oklch(52% 0.22 28);
  --up-bg:     oklch(52% 0.22 28 / 0.08);
  --down:      oklch(40% 0.16 250);
  --down-bg:   oklch(40% 0.16 250 / 0.08);
  --gold:      oklch(68% 0.13 78);

  --display: 'Fraunces', 'Noto Serif KR', serif;
  --body:    'Newsreader', 'Noto Serif KR', serif;
  --mono:    'JetBrains Mono', ui-monospace, monospace;

  font-family: var(--body);
  color: var(--ink);
  background: var(--paper);
  font-feature-settings: "ss01", "lnum", "tnum", "kern";
}

.brokerage-v2 .v2-mono {
  font-family: var(--mono);
  font-feature-settings: "tnum", "lnum", "zero";
  letter-spacing: -0.01em;
}

.brokerage-v2 .v2-display {
  font-family: var(--display);
}

.brokerage-v2 .v2-eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

/* ===== Layout ===== */
.brokerage-v2 .v2-container {
  max-width: 680px;
  margin: 0 auto;
  padding: 0 clamp(16px, 3vw, 32px);
}

.brokerage-v2 .v2-card {
  background: var(--paper-2);
  border: 1px solid var(--rule-soft);
  border-radius: 2px;
  padding: 20px;
}

.brokerage-v2 .v2-card + .v2-card {
  margin-top: 12px;
}

/* ===== Masthead ===== */
.brokerage-v2 .v2-masthead {
  border-bottom: 1.5px solid var(--ink);
  padding-bottom: 14px;
  margin-bottom: 28px;
}

.brokerage-v2 .v2-title {
  font-family: var(--display);
  font-weight: 400;
  font-size: clamp(28px, 4vw, 40px);
  line-height: 0.95;
  letter-spacing: -0.035em;
  color: var(--ink);
  margin: 0;
}

.brokerage-v2 .v2-subtitle {
  font-family: var(--body);
  font-size: 14px;
  color: var(--ink-mute);
  margin-top: 6px;
}

/* ===== Badge ===== */
.brokerage-v2 .v2-badge {
  display: inline-flex;
  align-items: center;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 2px;
  border: 1px solid;
}

.brokerage-v2 .v2-badge--paper {
  background: var(--up-bg);
  color: var(--up);
  border-color: var(--up);
}

.brokerage-v2 .v2-badge--on {
  background: oklch(52% 0.22 28 / 0.08);
  color: var(--up);
  border-color: var(--up);
}

.brokerage-v2 .v2-badge--off {
  background: oklch(54% 0.018 55 / 0.08);
  color: var(--ink-mute);
  border-color: var(--rule);
}

/* ===== Account row ===== */
.brokerage-v2 .v2-account-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.brokerage-v2 .v2-account-name {
  font-family: var(--display);
  font-weight: 400;
  font-size: 18px;
  color: var(--ink);
  margin: 0;
}

.brokerage-v2 .v2-account-meta {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--ink-mute);
  margin-top: 4px;
}

.brokerage-v2 .v2-account-cano {
  font-family: var(--mono);
  font-size: 13px;
  color: var(--ink-soft);
  letter-spacing: 0.04em;
}

/* ===== Buttons ===== */
.brokerage-v2 .v2-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 10px 20px;
  border-radius: 2px;
  border: 1.5px solid var(--ink);
  background: var(--ink);
  color: var(--paper);
  cursor: pointer;
  transition: background 0.25s, color 0.25s;
}

.brokerage-v2 .v2-btn:hover {
  background: var(--paper);
  color: var(--ink);
}

.brokerage-v2 .v2-btn--ghost {
  background: transparent;
  color: var(--ink);
  border-color: var(--rule);
}

.brokerage-v2 .v2-btn--ghost:hover {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

.brokerage-v2 .v2-btn--full {
  width: 100%;
}

/* ===== Form ===== */
.brokerage-v2 .v2-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.brokerage-v2 .v2-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.brokerage-v2 .v2-label {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

.brokerage-v2 .v2-input {
  font-family: var(--mono);
  font-size: 14px;
  padding: 10px 12px;
  border: 1px solid var(--rule);
  border-radius: 2px;
  background: var(--paper);
  color: var(--ink);
  outline: none;
  transition: border-color 0.2s;
}

.brokerage-v2 .v2-input:focus {
  border-color: var(--up);
}

.brokerage-v2 .v2-input::placeholder {
  color: var(--ink-mute);
  opacity: 0.6;
}

.brokerage-v2 .v2-hint {
  font-family: var(--body);
  font-size: 12px;
  color: var(--ink-mute);
  margin-top: 2px;
}

/* ===== Errors ===== */
.brokerage-v2 .v2-errors {
  background: oklch(40% 0.16 250 / 0.06);
  border: 1px solid var(--down);
  border-radius: 2px;
  padding: 14px 16px;
}

.brokerage-v2 .v2-errors ul {
  margin: 0;
  padding-left: 18px;
  font-family: var(--body);
  font-size: 13px;
  color: var(--down);
}

/* ===== Empty state ===== */
.brokerage-v2 .v2-empty {
  text-align: center;
  padding: 48px 20px;
  border: 1px dashed var(--rule);
  border-radius: 2px;
}

.brokerage-v2 .v2-empty p {
  font-family: var(--body);
  font-size: 15px;
  color: var(--ink-mute);
  margin: 0;
}

/* ===== Back link ===== */
.brokerage-v2 .v2-back {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--ink-mute);
  text-decoration: none;
  transition: color 0.25s;
}

.brokerage-v2 .v2-back:hover {
  color: var(--up);
}

/* ===== Divider ===== */
.brokerage-v2 .v2-divider {
  border: 0;
  border-top: 1px solid var(--rule-soft);
  margin: 24px 0;
}
