body {
        margin: 0;
        min-height: 100vh;
        background:
          radial-gradient(circle at top left, rgba(87, 166, 255, 0.15), transparent 28rem),
          linear-gradient(180deg, #0c121d 0%, var(--bg) 42%, #070a10 100%);
        color: var(--text);
        font-family:
          Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
          "Noto Sans TC", sans-serif;
        letter-spacing: 0;
      }

.top-actions {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
        margin-top: 14px;
      }

.pill,
      .link-button,
      button {
        min-height: 44px;
        border: 1px solid var(--line);
        border-radius: 8px;
        padding: 10px 12px;
        background: rgba(18, 26, 38, 0.82);
        color: var(--text);
        font: inherit;
        text-decoration: none;
      }

.link-button,
      button {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-weight: 800;
      }

button {
        width: 100%;
        border-color: rgba(49, 215, 199, 0.55);
        background: rgba(49, 215, 199, 0.12);
      }

button[disabled] {
        color: var(--muted);
        border-color: var(--line);
        background: rgba(23, 34, 50, 0.66);
      }

.secondary-button {
        border-color: var(--line);
        background: rgba(23, 34, 50, 0.72);
      }

.section,
      .card {
        border: 1px solid rgba(76, 99, 132, 0.58);
        border-radius: 8px;
        background: rgba(18, 26, 38, 0.9);
        box-shadow: 0 12px 28px rgba(0, 0, 0, 0.28);
      }

.admin-flow {
        margin-bottom: 14px;
      }

.flow-step {
        min-height: 96px;
        border: 1px solid rgba(76, 99, 132, 0.58);
        border-radius: 8px;
        padding: 12px;
        background: rgba(23, 34, 50, 0.82);
      }

.flow-index {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 32px;
        height: 32px;
        border-radius: 999px;
        background: rgba(87, 166, 255, 0.14);
        color: var(--blue);
        font-weight: 900;
      }

.summary-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 12px;
      }

.transaction-summary-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
        margin-bottom: 14px;
      }

.position-summary-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
        margin-bottom: 14px;
      }

.reconciliation-summary-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
        margin-bottom: 14px;
      }

.research-summary-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
        margin-bottom: 14px;
      }

.review-summary-grid {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
        margin-bottom: 14px;
      }

.research-form {
        display: grid;
        gap: 10px;
        margin-bottom: 14px;
      }

.transaction-filter-grid {
        display: grid;
        gap: 10px;
        margin-bottom: 14px;
      }

.transaction-filter-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
        align-items: end;
      }

.card {
        min-height: 98px;
        padding: 14px;
      }

.card-label {
        color: var(--muted);
        font-size: 14px;
      }

.card-value {
        margin-top: 9px;
        color: var(--cyan);
        font-size: 30px;
        font-weight: 850;
        line-height: 1;
      }

.transaction-summary-card .card-value {
        font-size: 26px;
      }

.position-summary-card .card-value {
        font-size: 26px;
      }

.reconciliation-summary-card .card-value {
        font-size: 26px;
      }

.section-head {
        display: flex;
        justify-content: space-between;
        gap: 12px;
        margin-bottom: 14px;
      }

.form-grid {
        display: grid;
        gap: 12px;
      }

label {
        display: grid;
        gap: 7px;
        color: var(--muted);
        font-size: 14px;
      }

input,
      select {
        width: 100%;
        min-height: 46px;
        border: 1px solid var(--line);
        border-radius: 8px;
        padding: 10px 12px;
        background: var(--panel-2);
        color: var(--text);
        font: inherit;
      }

input[type="file"] {
        color: var(--muted);
      }

.hint {
        margin-top: 10px;
        color: var(--muted);
        font-size: 14px;
        line-height: 1.5;
      }

.command {
        margin-top: 10px;
        overflow-x: auto;
        border-radius: 8px;
        padding: 12px;
        background: #07101a;
        color: var(--gold);
        font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
        font-size: 14px;
        white-space: nowrap;
      }

.snapshot-list,
      .portfolio-list,
      .transaction-list,
      .transaction-position-list,
      .reconciliation-list,
      .research-list,
      .review-list,
      .setting-list,
      .safety-list {
        display: grid;
        gap: 10px;
      }

.snapshot-card,
      .portfolio-card,
      .transaction-card,
      .transaction-position-card,
      .reconciliation-card,
      .research-card,
      .review-card,
      .setting-row,
      .safety-row {
        border-radius: 8px;
        padding: 12px;
        background: rgba(23, 34, 50, 0.82);
      }

.snapshot-top,
      .portfolio-top,
      .transaction-top,
      .transaction-position-top,
      .reconciliation-top,
      .research-top,
      .review-top,
      .setting-row,
      .safety-row {
        display: grid;
        grid-template-columns: 1fr auto;
        gap: 10px;
        align-items: center;
      }

.snapshot-title strong,
      .portfolio-title strong,
      .transaction-title strong,
      .transaction-position-title strong,
      .reconciliation-title strong,
      .research-title strong,
      .review-title strong {
        display: block;
        font-size: 17px;
      }

.snapshot-title span,
      .portfolio-title span,
      .transaction-title span,
      .transaction-position-title span,
      .reconciliation-title span,
      .research-title span,
      .review-title span,
      .portfolio-note,
      .research-note,
      .research-risk,
      .review-note span,
      .portfolio-details span,
      .transaction-details span,
      .transaction-position-details span,
      .reconciliation-details span,
      .research-details span,
      .review-details span,
      .setting-row span,
      .safety-row span,
      .top-holdings {
        color: var(--muted);
        font-size: 14px;
      }

.side-badge {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: 999px;
        padding: 6px 10px;
        font-size: 13px;
        font-weight: 900;
      }

.side-badge.buy {
        background: rgba(49, 215, 199, 0.12);
        color: var(--cyan);
      }

.side-badge.sell {
        background: rgba(255, 159, 67, 0.12);
        color: var(--orange);
      }

.position-status {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: 999px;
        padding: 6px 10px;
        font-size: 12px;
        font-weight: 900;
      }

.position-status.active {
        background: rgba(49, 215, 199, 0.12);
        color: var(--cyan);
      }

.position-status.closed {
        background: rgba(148, 163, 184, 0.14);
        color: var(--muted);
      }

.position-status.warning {
        background: rgba(255, 159, 67, 0.12);
        color: var(--orange);
      }

.reconciliation-status {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: 999px;
        padding: 6px 10px;
        font-size: 12px;
        font-weight: 900;
        white-space: nowrap;
      }

.reconciliation-status.match {
        background: rgba(49, 215, 199, 0.12);
        color: var(--cyan);
      }

.reconciliation-status.diff {
        background: rgba(255, 211, 105, 0.14);
        color: var(--gold);
      }

.reconciliation-status.missing {
        background: rgba(255, 159, 67, 0.12);
        color: var(--orange);
      }

.reconciliation-status.transaction-only {
        background: rgba(87, 166, 255, 0.14);
        color: var(--blue);
      }

.reconciliation-status.warning {
        background: rgba(255, 92, 92, 0.14);
        color: #ff7b7b;
      }

.snapshot-weight,
      .portfolio-progress {
        color: var(--cyan);
        font-size: 18px;
        font-weight: 850;
        text-align: right;
      }

.research-score {
        color: var(--gold);
        font-size: 20px;
        font-weight: 900;
        text-align: right;
      }

.decision-action {
        border-radius: 999px;
        padding: 6px 10px;
        font-size: 12px;
        font-weight: 900;
        text-align: center;
        white-space: nowrap;
      }

.decision-action.accumulate {
        background: rgba(49, 215, 199, 0.12);
        color: var(--cyan);
      }

.decision-action.hold {
        background: rgba(87, 166, 255, 0.14);
        color: var(--blue);
      }

.decision-action.reduce {
        background: rgba(255, 159, 67, 0.12);
        color: var(--orange);
      }

.review-result {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: 999px;
        padding: 6px 10px;
        font-size: 12px;
        font-weight: 900;
        text-align: center;
        white-space: nowrap;
      }

.review-result.success {
        background: rgba(49, 215, 199, 0.12);
        color: var(--cyan);
      }

.review-result.in-progress {
        background: rgba(87, 166, 255, 0.14);
        color: var(--blue);
      }

.review-result.partial {
        background: rgba(255, 211, 105, 0.14);
        color: var(--gold);
      }

.review-result.fail {
        background: rgba(255, 92, 92, 0.14);
        color: #ff7b7b;
      }

.transaction-details {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 9px;
        margin-top: 12px;
      }

.transaction-position-details {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 9px;
        margin-top: 12px;
      }

.reconciliation-details {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 9px;
        margin-top: 12px;
      }

.research-details {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 9px;
        margin-top: 12px;
      }

.review-details {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 9px;
        margin-top: 12px;
      }

.transaction-details div,
      .transaction-position-details div,
      .reconciliation-details div,
      .research-details div,
      .review-details div {
        border-radius: 8px;
        padding: 10px;
        background: rgba(11, 17, 26, 0.48);
      }

.transaction-details strong,
      .transaction-position-details strong,
      .reconciliation-details strong,
      .research-details strong,
      .review-details strong {
        display: block;
        margin-top: 5px;
        font-size: 16px;
      }

.portfolio-details {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 9px;
        margin-top: 12px;
      }

.portfolio-details div {
        border-radius: 8px;
        padding: 10px;
        background: rgba(11, 17, 26, 0.48);
      }

.portfolio-details strong {
        display: block;
        margin-top: 5px;
        font-size: 16px;
      }

.portfolio-note {
        margin-top: 10px;
        line-height: 1.5;
      }

.research-note,
.research-risk,
.review-note {
        margin-top: 10px;
        line-height: 1.5;
      }

.review-note strong,
.review-note span {
        display: block;
      }

.position-master-actions {
        display: grid;
        gap: 8px;
        justify-items: end;
      }

.position-master-edit-button {
        width: auto;
        min-height: 34px;
        padding: 6px 10px;
        font-size: 13px;
      }

.position-master-edit-form {
        display: grid;
        gap: 10px;
        margin-top: 12px;
        border-radius: 8px;
        padding: 12px;
        background: rgba(11, 17, 26, 0.56);
      }

.position-master-form-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
      }

.top-holdings {
        margin-top: 10px;
        line-height: 1.55;
      }

.status {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border-radius: 999px;
        padding: 6px 9px;
        background: rgba(255, 159, 67, 0.12);
        color: var(--orange);
        font-size: 13px;
        font-weight: 800;
      }

.status.ok {
        background: rgba(49, 215, 199, 0.12);
        color: var(--cyan);
      }

footer {
        margin-top: 18px;
        padding: 16px;
        color: var(--muted);
        font-size: 14px;
        line-height: 1.55;
      }

@media (min-width: 620px) {
        main {
          padding-top: 26px;
        }

        h1 {
          font-size: 40px;
        }

        .summary-grid {
          grid-template-columns: repeat(5, minmax(0, 1fr));
        }

        .transaction-summary-grid {
          grid-template-columns: repeat(5, minmax(0, 1fr));
        }

        .position-summary-grid {
          grid-template-columns: repeat(5, minmax(0, 1fr));
        }

        .reconciliation-summary-grid {
          grid-template-columns: repeat(5, minmax(0, 1fr));
        }

        .research-summary-grid {
          grid-template-columns: repeat(4, minmax(0, 1fr));
        }

        .review-summary-grid {
          grid-template-columns: repeat(4, minmax(0, 1fr));
        }

        .flow-grid {
          grid-template-columns: repeat(4, minmax(0, 1fr));
        }

        .form-grid {
          grid-template-columns: repeat(2, minmax(0, 1fr));
        }

        .research-form {
          grid-template-columns: repeat(4, minmax(0, 1fr));
        }

        .research-form .full {
          grid-column: 1 / -1;
        }

        .transaction-filter-grid {
          grid-template-columns: 1.2fr 1fr 1fr auto;
          align-items: end;
        }

        .transaction-filter-actions {
          min-width: 180px;
        }

        .transaction-details {
          grid-template-columns: repeat(6, minmax(0, 1fr));
        }

        .transaction-position-details {
          grid-template-columns: repeat(6, minmax(0, 1fr));
        }

        .reconciliation-details {
          grid-template-columns: repeat(6, minmax(0, 1fr));
        }

        .research-details {
          grid-template-columns: repeat(4, minmax(0, 1fr));
        }

        .review-details {
          grid-template-columns: repeat(4, minmax(0, 1fr));
        }

        .position-master-edit-form {
          grid-template-columns: repeat(4, minmax(0, 1fr));
        }

        .position-master-note-field,
        .position-master-form-actions {
          grid-column: 1 / -1;
        }

        .form-grid .full {
          grid-column: 1 / -1;
        }
      }
