/* PortKao professional finance polish layer.
   Loaded last to consolidate the visible UI into a restrained finance desk. */

:root {
  --pk-radius: 8px;
  --pk-radius-sm: 6px;
  --pk-shadow: 0 8px 22px rgba(var(--shadow-rgb), .10);
  --pk-shadow-strong: 0 16px 34px rgba(var(--shadow-rgb), .14);
  --pk-control-h: 44px;
}

html,
body {
  letter-spacing: 0 !important;
}

body {
  background:
    linear-gradient(180deg, rgba(var(--accent-rgb), .045), transparent 260px),
    linear-gradient(90deg, rgba(var(--ov), .028) 0 1px, transparent 1px),
    var(--bg) !important;
  background-size: auto, 80px 80px, auto !important;
}

.bg-fx,
.bg-grid,
.bg-neural,
.cosmic-orb,
.nebula,
.vignette,
#bgCanvas {
  display: none !important;
}

:where(.card, #formCard, .decision-tile, .dash-kpi, .risk-guard-card, .trust-card,
  .committee-workspace, .agent-workbench, .wb-card, .msg-card, .content-card,
  .market-section, .verdict-section, .chart-section, .ws-card, .modal-box,
  .news-card, .hist-card, .wl-card, .metric-card, .dash-card, .quote-card) {
  border-radius: var(--pk-radius) !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--pk-shadow) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

:where(.card, #formCard, .decision-tile, .committee-workspace, .agent-workbench,
  .market-section, .verdict-section, .chart-section, .ws-card)::before,
:where(.card, #formCard, .decision-tile, .committee-workspace, .agent-workbench,
  .market-section, .verdict-section, .chart-section, .ws-card)::after {
  display: none !important;
}

.setup-banner {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 12px;
  padding: 12px 14px;
  border: 1px solid rgba(154, 116, 38, .30);
  border-left: 3px solid var(--gold);
  border-radius: var(--pk-radius);
  background: rgba(154, 116, 38, .07);
  color: var(--text);
  font-size: 13px;
}

.setup-banner.is-hidden {
  display: none !important;
}

.setup-banner-copy {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  min-width: 0;
  line-height: 1.45;
}

.setup-banner-icon,
.setup-banner-icon svg {
  width: 17px;
  height: 17px;
  flex: 0 0 auto;
}

.setup-banner-action {
  margin-left: auto;
  min-height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 12px;
  border: 1px solid rgba(154, 116, 38, .35);
  border-radius: var(--pk-radius-sm);
  color: var(--gold);
  text-decoration: none;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.setup-banner-close {
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: var(--pk-radius-sm);
  background: transparent;
  color: var(--faint);
  cursor: pointer;
  font: inherit;
  font-size: 18px;
  line-height: 1;
}

.setup-banner-close:hover {
  background: rgba(var(--ov), .06);
  color: var(--text);
}

#formCard {
  border-top: 3px solid var(--accent) !important;
  padding: clamp(18px, 2.1vw, 26px) !important;
}

.form-eyebrow {
  color: var(--accent) !important;
  font-size: 10.5px !important;
  letter-spacing: .06em !important;
}

.form-title {
  color: var(--text) !important;
  font-size: clamp(22px, 2vw, 28px) !important;
  line-height: 1.15 !important;
}

.form-status-pills span {
  min-height: 28px !important;
  border-radius: var(--pk-radius-sm) !important;
  border-color: var(--border) !important;
  background: rgba(var(--ov), .045) !important;
  color: var(--muted) !important;
  box-shadow: none !important;
}

#formCard .search-box,
#formCard input,
#formCard select,
#formCard textarea,
.qchip,
.btn-go,
.form-primary-action {
  border-radius: var(--pk-radius) !important;
}

#formCard .search-box {
  min-height: var(--pk-control-h);
  border: 1px solid var(--border-hi) !important;
  background: var(--surface-solid) !important;
}

#formCard .search-box .icon,
#formCard .search-box .icon svg,
.form-primary-action .ico svg,
.qchip .ico svg {
  width: 17px;
  height: 17px;
}

.form-primary-action {
  min-height: var(--pk-control-h);
  background: var(--accent) !important;
  border: 1px solid rgba(var(--accent-rgb), .65) !important;
  color: #fff !important;
  box-shadow: none !important;
}

.form-primary-action:hover {
  filter: brightness(1.04);
  transform: translateY(-1px);
}

.qchip {
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.decision-launcher {
  gap: 10px !important;
}

.decision-tile {
  min-height: 74px;
  align-items: center !important;
  gap: 12px !important;
  padding: 13px 14px !important;
  border-left: 3px solid transparent !important;
  background: var(--surface) !important;
}

.decision-tile.urgent {
  border-left-color: var(--gold) !important;
  background: linear-gradient(90deg, rgba(154, 116, 38, .10), var(--surface) 44%) !important;
}

.decision-icon {
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--pk-radius-sm) !important;
  background: rgba(var(--accent-rgb), .10) !important;
  color: var(--accent) !important;
}

.decision-icon svg {
  width: 19px;
  height: 19px;
}

.decision-tile b {
  color: var(--text);
  font-size: 13px !important;
  line-height: 1.3;
}

.decision-tile small {
  color: var(--muted) !important;
  font-size: 11px !important;
}

.ws-title {
  gap: 8px;
}

.ws-title .ico,
.ws-title .ico svg,
.bn-icon,
.bn-icon svg,
.ck-icon .ico,
.ck-icon svg {
  width: 18px;
  height: 18px;
}

.bottom-nav-inner {
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 4px !important;
}

.bnav-btn {
  min-width: 0 !important;
  gap: 3px !important;
}

.bnav-btn > span:last-child {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.bnav-more-menu {
  border-radius: var(--pk-radius) !important;
  box-shadow: var(--pk-shadow-strong) !important;
}

.cmdk-item .ck-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
}

.cmdk-item .ck-icon .ico {
  display: inline-flex;
}

@media (max-width: 760px) {
  body {
    background-size: auto, 56px 56px, auto !important;
  }

  .container {
    padding: 12px 12px calc(92px + env(safe-area-inset-bottom)) !important;
  }

  #formCard {
    padding: 16px !important;
  }

  .form-card-head {
    gap: 12px !important;
  }

  .form-title {
    font-size: 22px !important;
  }

  .form-status-pills {
    gap: 6px !important;
  }

  .form-status-pills span {
    min-height: 26px !important;
    padding: 5px 8px !important;
    font-size: 11px !important;
  }

  .decision-launcher {
    grid-template-columns: 1fr !important;
  }

  .decision-tile {
    min-height: 64px;
  }

  .setup-banner {
    align-items: flex-start;
  }

  .setup-banner-action {
    margin-left: 26px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .tape-track,
  .ticker-track,
  .decision-tile,
  .form-primary-action {
    animation: none !important;
    transition: none !important;
  }
}

/* Login page: align authentication with the institutional app shell. */
.login-professional {
  --bg: #f4f6f8;
  --card-bg: #ffffff;
  --text: #152033;
  --muted: #59687a;
  --faint: #8a97a8;
  --blue: #0e9b73;
  --cyan: #0e9b73;
  --green: #128a5e;
  --red: #bf3636;
  --gold: #9a7426;
  --grad: linear-gradient(135deg, #0e9b73 0%, #2dd4a7 60%, #15333b 100%);
  background:
    linear-gradient(180deg, rgba(14, 155, 115, .07), transparent 260px),
    linear-gradient(90deg, rgba(21, 35, 58, .045) 0 1px, transparent 1px),
    var(--bg) !important;
  background-size: auto, 80px 80px, auto !important;
  color: var(--text) !important;
}

.login-professional #bgCanvas,
.login-professional .nebula,
.login-professional .cosmic-orb,
.login-professional .vignette {
  display: none !important;
}

.login-professional .ticker-strip {
  background: #15333b !important;
  border-bottom: 1px solid #0e2229 !important;
  backdrop-filter: none !important;
}

.login-professional .tk,
.login-professional .brand-tagline,
.login-professional .card-sub,
.login-professional .helper,
.login-professional .hint,
.login-professional .card-footer {
  color: var(--muted) !important;
}

.login-professional .tk b,
.login-professional .brand-name,
.login-professional .card-title {
  color: var(--text) !important;
}

.login-professional .ticker-strip .tk,
.login-professional .ticker-strip .tk b {
  color: #eaf3f1 !important;
}

.login-professional .page {
  justify-content: center !important;
  padding-top: calc(var(--login-ticker-h) + 30px + env(safe-area-inset-top)) !important;
}

.login-professional .brand {
  margin-bottom: 20px !important;
}

.login-professional .brand-mark {
  width: 58px !important;
  height: 58px !important;
  border-radius: 12px !important;
  background: #15333b !important;
  border: 1px solid rgba(14, 155, 115, .28) !important;
  box-shadow: var(--pk-shadow) !important;
  animation: none !important;
}

.login-professional .brand-mark::after {
  display: none !important;
}

.login-professional .brand-name {
  background: none !important;
  -webkit-text-fill-color: var(--text) !important;
  letter-spacing: 0 !important;
}

.login-professional .card {
  background: #fff !important;
  border: 1px solid rgba(21, 35, 58, .14) !important;
  border-radius: 10px !important;
  box-shadow: 0 18px 34px rgba(21, 35, 58, .10) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.login-professional .card::before,
.login-professional .card::after,
.login-professional .card-shadow {
  display: none !important;
}

.login-professional .badge,
.login-professional .sec-badge {
  border-radius: var(--pk-radius-sm) !important;
  border-color: rgba(14, 155, 115, .22) !important;
  background: rgba(14, 155, 115, .08) !important;
  color: #0e7d60 !important;
}

.login-professional .field input,
.login-professional .otp-inputs input,
.login-professional .modal-input,
.login-professional select {
  background: #f8fafc !important;
  border: 1px solid rgba(21, 35, 58, .16) !important;
  border-radius: var(--pk-radius) !important;
  color: var(--text) !important;
  box-shadow: none !important;
}

.login-professional .field input:focus,
.login-professional .otp-inputs input:focus,
.login-professional .modal-input:focus {
  border-color: rgba(14, 155, 115, .55) !important;
  box-shadow: 0 0 0 3px rgba(14, 155, 115, .12) !important;
}

.login-professional .field-icon {
  color: var(--muted) !important;
  font-size: 0 !important;
}

.login-professional .field-icon::before {
  content: "";
  display: block;
  width: 14px;
  height: 14px;
  border: 1.8px solid currentColor;
  border-radius: 4px;
}

.login-professional .pw-eye {
  color: var(--muted) !important;
  font-size: 0 !important;
}

.login-professional .pw-eye::before {
  content: "";
  display: block;
  width: 16px;
  height: 10px;
  border: 1.8px solid currentColor;
  border-radius: 999px;
}

.login-professional .btn-submit,
.login-professional .google-btn {
  border-radius: var(--pk-radius) !important;
  box-shadow: none !important;
}

.login-professional .btn-submit {
  background: #0e9b73 !important;
  color: #fff !important;
}

.login-professional .btn-submit:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 10px 24px rgba(14, 155, 115, .18) !important;
}

.login-professional .google-btn {
  background: #fff !important;
  border: 1px solid rgba(21, 35, 58, .16) !important;
  color: var(--text) !important;
}

@media (max-width: 520px) {
  .login-professional .page {
    padding-inline: 14px !important;
  }

  .login-professional .card {
    padding: 22px 18px 20px !important;
  }
}