:root {
  --bg: #eef2f6;
  --panel: #ffffff;
  --panel-soft: #f3f7fb;
  --panel-ink: #162235;
  --ink: #162235;
  --ink-soft: #64748b;
  --card: #ffffff;
  --line: #d9e1ea;
  --line-soft: #ebf0f5;
  --accent: #0f766e;
  --accent-strong: #0b5e57;
  --accent-soft: #d6f3ee;
  --warm: #fff6e8;
  --danger: #b42318;
  --danger-soft: #fde7e5;
  --shadow: 0 20px 44px rgba(15, 23, 42, 0.08);
  --body-bg:
    radial-gradient(circle at top left, #f7fbff 0, transparent 22%),
    linear-gradient(180deg, #f5f8fb 0, var(--bg) 100%);
  --sidebar-bg:
    linear-gradient(180deg, rgba(255,255,255,0.03), transparent 20%),
    linear-gradient(180deg, var(--light-sidebar-bg, #0f172a) 0, color-mix(in srgb, var(--light-sidebar-bg, #0f172a) 88%, black 12%) 100%);
  --sidebar-brand-ink: var(--light-sidebar-brand-ink, #ffffff);
  --sidebar-subbrand: var(--light-sidebar-subbrand, rgba(219, 231, 245, 0.72));
  --sidebar-card-bg: var(--light-sidebar-card-bg, rgba(255, 255, 255, 0.05));
  --sidebar-card-border: var(--light-sidebar-card-border, rgba(255, 255, 255, 0.1));
  --sidebar-avatar-bg: var(--light-sidebar-avatar-bg, rgba(255, 255, 255, 0.16));
  --sidebar-nav-label: var(--light-sidebar-nav-label, rgba(219, 231, 245, 0.45));
  --sidebar-nav-ink-soft: var(--light-sidebar-nav-ink-soft, rgba(219, 231, 245, 0.82));
  --sidebar-nav-hover-bg: var(--light-sidebar-nav-hover-bg, rgba(255, 255, 255, 0.08));
  --sidebar-nav-active-bg: var(--light-sidebar-nav-active-bg, rgba(255, 255, 255, 0.12));
  --sidebar-nav-active-border: var(--light-sidebar-nav-active-border, rgba(255,255,255,0.08));
  --topbar-control-bg: rgba(255, 255, 255, 0.96);
  --topbar-control-border: var(--line);
  --menu-bg: rgba(255, 255, 255, 0.98);
  --menu-border: var(--line);
  --surface-hover: #f5fbfa;
  --public-header-bg: rgba(255, 255, 255, 0.84);
  --public-header-border: rgba(15, 23, 42, 0.08);
  --public-header-ink: #09111f;
  --public-header-muted: rgba(71, 85, 105, 0.76);
  --shop-header-bg: rgba(255, 255, 255, 0.86);
  --shop-header-border: rgba(15, 23, 42, 0.08);
  --shop-brand-ink: #09111f;
  --auth-card-bg: rgba(255, 255, 255, 0.98);
  --auth-captcha-bg: linear-gradient(180deg, #fbfefd 0, #f4faf8 100%);
}

[data-theme="dark"] {
  --bg: #08111f;
  --panel: #0f172a;
  --panel-soft: #1e293b;
  --panel-ink: #dbe7f5;
  --ink: #e5edf8;
  --ink-soft: #94a3b8;
  --card: #101a2b;
  --line: #22324a;
  --line-soft: #192639;
  --accent: #5eead4;
  --accent-strong: #99f6e4;
  --accent-soft: rgba(45, 212, 191, 0.16);
  --warm: #2b2416;
  --danger-soft: rgba(180, 35, 24, 0.16);
  --shadow: 0 20px 44px rgba(2, 6, 23, 0.42);
  --body-bg:
    radial-gradient(circle at top left, rgba(37, 99, 235, 0.15) 0, transparent 22%),
    linear-gradient(180deg, #09111f 0, #060c17 100%);
  --sidebar-bg:
    linear-gradient(180deg, rgba(255,255,255,0.03), transparent 20%),
    linear-gradient(180deg, var(--panel) 0, #111827 100%);
  --sidebar-brand-ink: #ffffff;
  --sidebar-subbrand: rgba(219, 231, 245, 0.72);
  --sidebar-card-bg: rgba(255, 255, 255, 0.05);
  --sidebar-card-border: rgba(255, 255, 255, 0.1);
  --sidebar-avatar-bg: rgba(255, 255, 255, 0.16);
  --sidebar-nav-label: rgba(219, 231, 245, 0.45);
  --sidebar-nav-ink-soft: rgba(219, 231, 245, 0.82);
  --sidebar-nav-hover-bg: rgba(255, 255, 255, 0.08);
  --sidebar-nav-active-bg: rgba(255, 255, 255, 0.12);
  --sidebar-nav-active-border: rgba(255,255,255,0.08);
  --topbar-control-bg: rgba(16, 26, 43, 0.96);
  --topbar-control-border: var(--line);
  --menu-bg: rgba(10, 18, 31, 0.98);
  --menu-border: var(--line);
  --surface-hover: rgba(45, 212, 191, 0.08);
  --public-header-bg: rgba(9, 15, 26, 0.88);
  --public-header-border: rgba(255, 255, 255, 0.08);
  --public-header-ink: #f8fbff;
  --public-header-muted: rgba(219, 231, 245, 0.72);
  --shop-header-bg: rgba(9, 15, 26, 0.9);
  --shop-header-border: rgba(255, 255, 255, 0.08);
  --shop-brand-ink: #ffffff;
  --auth-card-bg: rgba(12, 20, 34, 0.96);
  --auth-captcha-bg: linear-gradient(180deg, #101b2d 0, #0b1423 100%);
}

[data-theme="dark"] {
  color-scheme: dark;
}

* { box-sizing: border-box; }

html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

body {
  margin: 0;
  font-family: "Avenir Next", "Segoe UI", sans-serif;
  background: var(--body-bg);
  color: var(--ink);
}

body.mobile-nav-open {
  overflow: hidden;
}

a { color: inherit; text-decoration: none; }
a:hover { color: var(--accent-strong); }

.app-shell {
  min-height: 100vh;
  padding-left: 280px;
}

.mobile-nav-backdrop,
.mobile-nav-toggle {
  display: none;
}

.sidebar {
  background: var(--sidebar-bg);
  color: var(--panel-ink);
  padding: 28px 22px;
  position: fixed;
  inset: 0 auto 0 0;
  width: 280px;
  height: 100vh;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  gap: 26px;
  overflow: hidden;
  z-index: 30;
}

.sidebar-brand .brand {
  display: inline-flex;
  align-items: center;
  font-size: 30px;
  font-weight: 800;
  letter-spacing: -0.05em;
  color: var(--sidebar-brand-ink);
}

.subbrand {
  margin-top: 6px;
  color: var(--sidebar-subbrand);
  font-size: 14px;
}

.brand-logo-wrap {
  display: inline-flex;
  align-items: center;
  min-height: 40px;
}

.brand-logo {
  display: block;
  max-height: 42px;
  width: auto;
  max-width: 100%;
}

.brand-logo-dark {
  display: none;
}

[data-theme="dark"] .brand-logo-light {
  display: none;
}

[data-theme="dark"] .brand-logo-dark {
  display: block;
}

.brand-logo-wrap-public .brand-logo,
.brand-logo-wrap-portal .brand-logo {
  max-height: 38px;
}

.brand-logo-wrap-auth .brand-logo {
  max-height: 46px;
}

.sidebar-profile-card {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 12px;
  border: 1px solid var(--sidebar-card-border);
  border-radius: 16px;
  background: var(--sidebar-card-bg);
  color: var(--sidebar-brand-ink);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.03);
}

.sidebar-profile-card:hover {
  background: var(--sidebar-nav-hover-bg);
  color: var(--sidebar-brand-ink);
}

.sidebar-profile-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--sidebar-avatar-bg);
  color: var(--sidebar-brand-ink);
  font-weight: 800;
  font-size: 18px;
}

.sidebar-profile-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sidebar-profile-copy {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.sidebar-profile-copy strong,
.sidebar-profile-copy span,
.sidebar-profile-copy em {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sidebar-profile-copy strong {
  font-size: 15px;
  font-weight: 800;
}

.sidebar-profile-copy span {
  font-size: 13px;
  color: var(--sidebar-subbrand);
}

.sidebar-profile-copy em {
  font-style: normal;
  font-size: 12px;
  font-weight: 700;
  color: var(--sidebar-brand-ink);
}

.side-nav {
  display: grid;
  gap: 18px;
}

.sidebar-scroll {
  flex: 1 1 0;
  min-height: 0;
  overflow-y: auto;
  padding-right: 4px;
  overscroll-behavior: contain;
}

.sidebar-scroll::-webkit-scrollbar {
  width: 10px;
}

.sidebar-scroll::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.12);
  border-radius: 999px;
}

.sidebar-scroll::-webkit-scrollbar-track {
  background: transparent;
}

.nav-group {
  display: grid;
  gap: 6px;
}

.nav-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--sidebar-nav-label);
  font-weight: 800;
}

.nav-toggle {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 4px;
  padding: 0;
  background: transparent;
  border: 0;
  cursor: pointer;
  text-align: left;
}

.nav-toggle:hover {
  color: var(--sidebar-brand-ink);
}

.nav-chevron {
  font-size: 12px;
  line-height: 1;
  transition: transform 120ms ease;
}

.nav-items {
  display: grid;
  gap: 6px;
}

.nav-group:not(.is-open) .nav-items {
  display: none;
}

.nav-group:not(.is-open) .nav-chevron {
  transform: rotate(-90deg);
}

.side-nav a {
  display: block;
  padding: 11px 14px;
  border-radius: 14px;
  color: var(--sidebar-nav-ink-soft);
  transition: background 120ms ease, transform 120ms ease;
}

.side-nav a:hover {
  background: var(--sidebar-nav-hover-bg);
  color: var(--sidebar-brand-ink);
  transform: translateX(2px);
}

.side-nav a.active {
  background: var(--sidebar-nav-active-bg);
  color: var(--sidebar-brand-ink);
  box-shadow: inset 0 0 0 1px var(--sidebar-nav-active-border);
}

.side-submenu {
  display: grid;
  gap: 6px;
}

.submenu-parent {
  font-weight: 700;
}

.submenu-items {
  display: grid;
  gap: 6px;
  padding-left: 14px;
}

.submenu-items a {
  font-size: 14px;
  padding-top: 9px;
  padding-bottom: 9px;
  color: var(--sidebar-nav-ink-soft);
}

.submenu-items a.active {
  background: var(--sidebar-nav-hover-bg);
}

.sidebar-logout {
  margin-top: auto;
  padding-top: 4px;
  flex: 0 0 auto;
}

.workspace-main {
  min-width: 0;
  min-height: 100vh;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: visible;
}

.workspace-topbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 26px 32px 12px;
}

.topbar-main {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.topbar-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.topbar-user-menu {
  position: relative;
}

.topbar-user-chip {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-height: 48px;
  padding: 8px 14px;
  border-radius: 20px;
  border: 1px solid var(--topbar-control-border);
  background: var(--topbar-control-bg);
  box-shadow: var(--shadow);
  color: var(--ink);
}

.topbar-user-chip:hover,
.topbar-user-menu:hover .topbar-user-chip,
.topbar-user-menu:focus-within .topbar-user-chip {
  background: var(--surface-hover);
  transform: translateY(-1px);
}

.topbar-user-avatar {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--line-soft);
  color: var(--ink);
  font-size: 20px;
  font-weight: 800;
  line-height: 1;
  flex: 0 0 auto;
}

.topbar-user-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.topbar-user-copy {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.topbar-user-copy strong,
.topbar-user-copy span {
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.topbar-user-copy strong {
  font-size: 15px;
  line-height: 1.1;
}

.topbar-user-copy span {
  font-size: 13px;
  color: var(--ink-soft);
  line-height: 1.1;
}

.topbar-user-dropdown {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  min-width: 200px;
  padding: 10px;
  border-radius: 18px;
  border: 1px solid var(--menu-border);
  background: var(--menu-bg);
  box-shadow: 0 24px 44px rgba(15, 23, 42, 0.14);
  display: none;
  z-index: 70;
}

.topbar-user-menu:hover .topbar-user-dropdown,
.topbar-user-menu:focus-within .topbar-user-dropdown {
  display: grid;
  gap: 8px;
}

.topbar-user-dropdown form {
  margin: 0;
}

.topbar-user-dropdown-link {
  width: 100%;
  display: block;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--line-soft);
  background: var(--card);
  color: var(--ink);
  font-weight: 700;
  text-align: left;
}

.topbar-user-dropdown-link:hover {
  background: var(--surface-hover);
  color: var(--ink);
}

button.topbar-user-dropdown-link {
  cursor: pointer;
}

.topbar-user-dropdown-link.danger {
  color: var(--danger);
}

.theme-toggle {
  width: 46px;
  height: 46px;
  min-height: 46px;
  border-radius: 16px;
  border: 1px solid var(--topbar-control-border);
  background: var(--topbar-control-bg);
  color: var(--ink);
  box-shadow: var(--shadow);
  display: inline-grid;
  place-items: center;
  align-items: center;
  padding: 0;
  cursor: pointer;
  flex: 0 0 auto;
}

.theme-toggle:hover {
  background: var(--surface-hover);
  transform: translateY(-1px);
}

.theme-toggle-icon {
  font-size: 18px;
  line-height: 1;
}

.theme-toggle-label {
  display: none;
}

.theme-toggle-floating {
  position: fixed;
  top: 18px;
  right: 18px;
  z-index: 80;
}

.topbar-workspace-switcher {
  position: relative;
}

.topbar-workspace-shell {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.topbar-workspace-shell::after {
  content: "";
  position: absolute;
  right: 17px;
  top: 50%;
  width: 10px;
  height: 10px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: translateY(-65%) rotate(45deg);
  color: rgba(71, 84, 103, 0.82);
  pointer-events: none;
}

.topbar-workspace-switcher select {
  min-width: 280px;
  height: 48px;
  border-radius: 18px;
  border: 1px solid var(--topbar-control-border);
  background: linear-gradient(180deg, color-mix(in srgb, var(--topbar-control-bg) 92%, white 8%) 0%, var(--topbar-control-bg) 100%);
  color: var(--ink);
  box-shadow: var(--shadow), inset 0 1px 0 rgba(255, 255, 255, 0.26);
  font-weight: 800;
  padding: 0 46px 0 18px;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  cursor: pointer;
  letter-spacing: -0.01em;
}

.topbar-workspace-switcher select:hover {
  background: color-mix(in srgb, var(--topbar-control-bg) 88%, var(--surface-hover) 12%);
  transform: translateY(-1px);
}

.topbar-workspace-switcher select:focus {
  outline: none;
  border-color: rgba(115, 207, 196, 0.5);
  box-shadow: 0 0 0 4px rgba(82, 170, 157, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.12);
}

.topbar-notifications {
  position: relative;
}

.topbar-notifications-toggle {
  list-style: none;
  width: 46px;
  height: 46px;
  border-radius: 16px;
  border: 1px solid var(--topbar-control-border);
  background: var(--topbar-control-bg);
  color: var(--ink);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: var(--shadow);
  position: relative;
}

.topbar-notifications-toggle:hover {
  background: var(--surface-hover);
  transform: translateY(-1px);
}

.topbar-notifications-toggle::-webkit-details-marker {
  display: none;
}

.topbar-notifications-icon {
  font-size: 18px;
}

.topbar-notifications-badge {
  position: absolute;
  top: -7px;
  right: -7px;
  min-width: 24px;
  height: 24px;
  padding: 0 7px;
  border-radius: 999px;
  background: #2563eb;
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--card);
  box-shadow: 0 8px 18px rgba(37, 99, 235, 0.24);
}

.topbar-notifications-menu {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  width: min(420px, calc(100vw - 48px));
  padding: 12px;
  border: 1px solid var(--menu-border);
  border-radius: 20px;
  background: var(--menu-bg);
  box-shadow: 0 24px 44px rgba(15, 23, 42, 0.14);
  display: grid;
  gap: 12px;
  z-index: 60;
}

.topbar-notifications-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.topbar-notifications-head strong {
  display: block;
  font-size: 16px;
}

.topbar-notifications-head span {
  color: var(--ink-soft);
  font-size: 13px;
}

.topbar-notifications-readall {
  white-space: nowrap;
}

.topbar-notifications-list {
  display: grid;
  gap: 8px;
  max-height: 420px;
  overflow-y: auto;
}

.topbar-notification-item,
.topbar-notifications-empty {
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid var(--line-soft);
  background: var(--card);
}

.topbar-notification-item:hover {
  border-color: #cbd5e1;
  background: var(--surface-hover);
}

.topbar-notification-item.is-unread {
  border-color: rgba(37, 99, 235, 0.26);
  background: linear-gradient(180deg, #f5f9ff 0%, #ffffff 100%);
}

.topbar-notification-type {
  color: #2563eb;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.topbar-notification-item strong {
  font-size: 14px;
}

.topbar-notification-item span,
.topbar-notifications-empty {
  color: var(--ink-soft);
  font-size: 13px;
}

.topbar-notification-item em {
  color: var(--ink-soft);
  font-size: 12px;
  font-style: normal;
}

.topbar-kicker {
  color: var(--ink-soft);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 12px;
  font-weight: 800;
}

.topbar-title {
  margin-top: 6px;
  font-size: 34px;
  font-weight: 800;
  letter-spacing: -0.05em;
}

.page-shell {
  width: min(1480px, calc(100% - 30px));
  margin: 0 auto 48px;
  min-width: 0;
}

.dev-mode-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.85rem;
  margin-bottom: 1rem;
  padding: 0.9rem 1rem;
  border: 1px solid rgba(213, 131, 35, 0.28);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(255, 245, 219, 0.98), rgba(255, 236, 196, 0.98));
  color: #7c4a00;
  box-shadow: 0 10px 30px rgba(210, 158, 60, 0.12);
}

.dev-mode-banner strong {
  color: #8a4d00;
  font-size: 0.96rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.dev-mode-banner span {
  color: #7a5a21;
  font-weight: 600;
}

.page-shell-wide {
  width: min(1720px, calc(100% - 26px));
}

.card {
  background: color-mix(in srgb, var(--card) 96%, transparent);
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 24px;
  box-shadow: var(--shadow);
}

.hero {
  background:
    radial-gradient(circle at top right, rgba(15,118,110,0.16), transparent 34%),
    linear-gradient(135deg, #ffffff 0, #f6fbf9 100%);
}

[data-theme="dark"] .hero {
  background:
    radial-gradient(circle at top right, rgba(45, 212, 191, 0.18), transparent 28%),
    linear-gradient(135deg, rgba(16, 26, 43, 0.98) 0, rgba(11, 19, 33, 0.98) 100%);
  border-color: rgba(148, 163, 184, 0.14);
  box-shadow: 0 22px 48px rgba(2, 6, 23, 0.36);
}

.hero.compact {
  padding: 30px;
}

.eyebrow {
  margin: 0 0 10px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--accent-strong);
}

h1, h2 {
  margin: 0;
  letter-spacing: -0.05em;
}

h1 {
  font-size: clamp(36px, 5vw, 58px);
}

h2 {
  font-size: 28px;
}

.lede,
.muted {
  color: var(--ink-soft);
}

.lede {
  max-width: 920px;
  font-size: 19px;
  line-height: 1.55;
}

.section-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 18px;
  margin-bottom: 18px;
}

.stats-grid,
.info-grid,
.split-grid {
  display: grid;
  gap: 16px;
}

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

.compact-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 18px;
}

.info-grid {
  margin-top: 16px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.split-grid {
  grid-template-columns: 1.2fr 1fr;
}

.stat-block {
  background: linear-gradient(180deg, #ffffff 0, #f8fbfd 100%);
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  padding: 18px;
}

.stat-label {
  color: var(--ink-soft);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.stat-value {
  margin-top: 10px;
  font-size: 31px;
  font-weight: 800;
  letter-spacing: -0.04em;
}

.stat-money {
  font-size: 26px;
}

.stat-small {
  font-size: 18px;
  line-height: 1.35;
  letter-spacing: -0.02em;
}

[data-theme="dark"] .stat-block {
  background: linear-gradient(180deg, rgba(18, 26, 47, 0.96) 0%, rgba(14, 21, 39, 0.98) 100%);
  border-color: rgba(132, 154, 191, 0.18);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

[data-theme="dark"] .stat-label {
  color: rgba(161, 181, 214, 0.76);
}

[data-theme="dark"] .stat-value {
  color: #eef4ff;
}

.top-gap {
  margin-top: 18px;
}

.top-gap-sm {
  margin-top: 10px;
}

.signal-list {
  display: grid;
  gap: 12px;
}

.signal-row {
  display: grid;
  gap: 6px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--line-soft);
}

.signal-row:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.signal-link {
  transition: transform 120ms ease, background 120ms ease, border-color 120ms ease;
  border-radius: 16px;
  padding: 12px 14px;
  margin: 0 -14px;
}

.signal-link:hover {
  background: var(--surface-hover);
  transform: translateX(2px);
}

.auth-shell {
  min-height: calc(100vh - 140px);
  position: relative;
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: 32px;
  isolation: isolate;
  background:
    radial-gradient(circle at top left, color-mix(in srgb, var(--accent) 16%, transparent), transparent 24%),
    linear-gradient(135deg, color-mix(in srgb, var(--card) 88%, white) 0%, color-mix(in srgb, var(--bg) 92%, white) 52%, color-mix(in srgb, var(--bg) 100%, black 6%) 100%);
}

.auth-shell-page {
  min-height: 100vh;
  min-height: 100svh;
  width: 100vw;
  max-width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  border-radius: 0;
  padding: 32px 24px;
}

.auth-shell.has-background {
  background:
    linear-gradient(rgba(15, 23, 42, 0.34), rgba(15, 23, 42, 0.58)),
    var(--login-bg-image) center/cover no-repeat;
}

.auth-shell-generic {
  background:
    radial-gradient(circle at 18% 22%, color-mix(in srgb, var(--accent) 12%, transparent), transparent 20%),
    radial-gradient(circle at 84% 18%, rgba(37, 99, 235, 0.10), transparent 22%),
    linear-gradient(135deg, color-mix(in srgb, var(--card) 92%, white) 0%, color-mix(in srgb, var(--bg) 92%, white) 45%, color-mix(in srgb, var(--bg) 100%, black 6%) 100%);
}

.auth-shell-backdrop {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.02));
  z-index: 0;
}

.auth-card {
  position: relative;
  z-index: 1;
  width: min(480px, 100%);
  background: var(--auth-card-bg);
  border: 1px solid var(--line);
  border-radius: 28px;
  padding: 32px;
  box-shadow: var(--shadow);
}

.auth-shell-page .auth-card {
  max-width: 480px;
}

.auth-brand {
  margin-bottom: 14px;
}

.stack-form {
  display: grid;
  gap: 14px;
}

.auth-captcha {
  display: grid;
  gap: 12px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: var(--auth-captcha-bg);
}

.auth-captcha-head {
  display: grid;
  gap: 4px;
}

.auth-captcha-head strong {
  font-size: 15px;
}

.auth-captcha-head span {
  color: var(--ink-soft);
  font-size: 13px;
}

.auth-captcha-puzzle {
  display: grid;
  gap: 12px;
}

.auth-captcha-track {
  position: relative;
  height: 60px;
  border-radius: 18px;
  border: 1px solid #dbe5ef;
  background:
    radial-gradient(circle at 18% 30%, rgba(15, 118, 110, 0.08), transparent 18%),
    radial-gradient(circle at 76% 58%, rgba(37, 99, 235, 0.08), transparent 18%),
    linear-gradient(180deg, #ffffff 0, #f3f7fb 100%);
  overflow: hidden;
}

.auth-captcha-fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: 0;
  background: linear-gradient(90deg, rgba(15, 118, 110, 0.18), rgba(15, 118, 110, 0.06));
}

.auth-captcha-slot,
.auth-captcha-piece {
  position: absolute;
  top: 50%;
  width: 36px;
  height: 36px;
  margin-top: -18px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.auth-captcha-slot {
  border: 2px dashed rgba(15, 118, 110, 0.35);
  background: rgba(15, 118, 110, 0.08);
  color: rgba(15, 118, 110, 0.45);
}

.auth-captcha-piece {
  left: -18px;
  background: #0f172a;
  color: #fff;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.18);
  transition: background 120ms ease, transform 120ms ease;
}

.auth-captcha-slider {
  width: 100%;
  accent-color: var(--accent);
}

.auth-captcha.is-verified {
  border-color: #94d8c7;
  background: linear-gradient(180deg, #f8fffc 0, #eefbf6 100%);
}

.auth-captcha.is-verified .auth-captcha-piece {
  background: var(--accent);
  transform: scale(1.03);
}

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

label {
  display: grid;
  gap: 8px;
  font-weight: 700;
}

input,
textarea,
select {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 13px 15px;
  font: inherit;
  background: #fff;
}

input:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: #7dc6bc;
  box-shadow: 0 0 0 4px rgba(15, 118, 110, 0.08);
}

.button-row {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
}

.primary-btn,
.ghost-btn,
.secondary-btn {
  border-radius: 999px;
  padding: 12px 18px;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}

.primary-btn {
  border: 0;
  background: var(--accent);
  color: #fff;
}

.secondary-btn {
  border: 0;
  background: #ddeff0;
  color: var(--accent-strong);
}

.ghost-btn {
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
}

[data-theme="dark"] input,
[data-theme="dark"] textarea,
[data-theme="dark"] select {
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.96) 0%, rgba(10, 17, 30, 0.96) 100%);
  border-color: rgba(148, 163, 184, 0.18);
  color: var(--ink);
}

[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder {
  color: rgba(148, 163, 184, 0.72);
}

[data-theme="dark"] .primary-btn {
  background: color-mix(in srgb, var(--accent) 82%, white 18%);
  color: #07131f;
}

[data-theme="dark"] .secondary-btn {
  background: rgba(94, 234, 212, 0.14);
  color: var(--accent-strong);
}

[data-theme="dark"] .ghost-btn {
  background: rgba(15, 23, 42, 0.84);
  border-color: rgba(148, 163, 184, 0.16);
  color: var(--ink);
}

.flash-stack {
  display: grid;
  gap: 10px;
  margin-bottom: 16px;
}

.shop-toast-stack {
  position: fixed;
  top: 88px;
  right: 24px;
  z-index: 80;
  display: grid;
  gap: 10px;
  width: min(420px, calc(100vw - 24px));
  pointer-events: none;
}

.shop-toast {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: #ffffff;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.12);
  transform: translateY(-8px);
  opacity: 0;
  transition: opacity 160ms ease, transform 160ms ease;
  pointer-events: auto;
}

.shop-toast.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.shop-toast span {
  font-weight: 700;
  color: var(--ink);
}

.shop-toast button {
  border: 0;
  background: transparent;
  color: var(--ink-soft);
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
}

.shop-toast-success {
  border-color: #b7e2d3;
  background: #effbf5;
}

.shop-toast-info {
  border-color: #acd9d2;
  background: #f4fbfa;
}

.shop-toast-warning {
  border-color: #f2d1a6;
  background: #fff8ee;
}

.shop-toast-error {
  border-color: #f3b3ad;
  background: var(--danger-soft);
}

.breadcrumb-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 14px;
  color: var(--ink-soft);
  font-size: 13px;
}

.breadcrumb-link {
  color: var(--ink-soft);
}

.breadcrumb-current {
  color: var(--ink);
  font-weight: 700;
}

.breadcrumb-sep {
  color: #a2afbf;
}

.flash {
  border-radius: 16px;
  padding: 14px 16px;
  border: 1px solid var(--line);
  background: #fff;
}

.flash-error {
  border-color: #f3b3ad;
  background: var(--danger-soft);
}

.flash-success {
  border-color: #b7e2d3;
  background: #effbf5;
  color: #166534;
}

.flash-info {
  border-color: #acd9d2;
  background: #f4fbfa;
}

[data-theme="dark"] .flash {
  color: #e5edf8;
  border-color: rgba(148, 163, 184, 0.2);
  background: rgba(15, 23, 42, 0.92);
}

[data-theme="dark"] .flash-info {
  border-color: rgba(94, 234, 212, 0.28);
  background: rgba(13, 61, 57, 0.78);
  color: #d9fbf5;
}

[data-theme="dark"] .flash-error {
  border-color: rgba(244, 114, 114, 0.28);
  background: rgba(92, 30, 30, 0.72);
  color: #fee2e2;
}

[data-theme="dark"] .flash-success {
  border-color: rgba(74, 222, 128, 0.28);
  background: rgba(20, 83, 45, 0.78);
  color: #dcfce7;
}

[data-theme="dark"] .shop-toast {
  border-color: rgba(148, 163, 184, 0.18);
  background: rgba(15, 23, 42, 0.96);
  box-shadow: 0 20px 48px rgba(2, 6, 23, 0.46);
}

[data-theme="dark"] .shop-toast span {
  color: #f8fafc;
}

[data-theme="dark"] .shop-toast button {
  color: rgba(219, 231, 245, 0.72);
}

[data-theme="dark"] .shop-toast-success {
  border-color: rgba(94, 234, 212, 0.28);
  background: rgba(13, 61, 57, 0.84);
}

[data-theme="dark"] .shop-toast-info {
  border-color: rgba(125, 211, 252, 0.24);
  background: rgba(19, 49, 73, 0.82);
}

[data-theme="dark"] .shop-toast-warning {
  border-color: rgba(251, 191, 36, 0.24);
  background: rgba(71, 48, 13, 0.82);
}

[data-theme="dark"] .shop-toast-error {
  border-color: rgba(248, 113, 113, 0.28);
  background: rgba(92, 30, 30, 0.8);
}

.table-wrap {
  overflow-x: auto;
}

.dense-table {
  margin-top: 6px;
}

table {
  width: 100%;
  border-collapse: collapse;
}

th, td {
  text-align: left;
  padding: 14px 12px;
  border-bottom: 1px solid var(--line-soft);
  vertical-align: top;
}

th {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ink-soft);
}

.report-sort-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: inherit;
  text-decoration: none;
  font: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
}

.report-sort-link:hover {
  color: var(--ink);
}

.report-sort-link.is-active {
  color: var(--accent-strong);
}

.report-sort-link.is-active::after {
  content: "•";
  font-size: 12px;
  line-height: 1;
}

.dense-table th,
.dense-table td {
  padding: 11px 10px;
}

.row-highlight {
  background: linear-gradient(180deg, #fff7ea 0, #fffdf7 100%);
}

.table-action-cell {
  text-align: right;
  white-space: nowrap;
}

.table-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.table-link-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 74px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: #fff;
  font-size: 13px;
  font-weight: 700;
}

[data-theme="dark"] .table-link-btn {
  border-color: rgba(148, 163, 184, 0.16);
  background: rgba(148, 163, 184, 0.08);
  color: var(--ink);
}

.empty-state {
  background: linear-gradient(180deg, #ffffff 0, #f9fbfd 100%);
  border: 1px dashed var(--line);
  border-radius: 18px;
  padding: 22px;
}

.empty-state h3 {
  margin: 0 0 8px;
  font-size: 22px;
}

[data-theme="dark"] .empty-state {
  background: linear-gradient(180deg, rgba(18, 26, 47, 0.96) 0%, rgba(14, 21, 39, 0.98) 100%);
  border-color: rgba(132, 154, 191, 0.2);
  color: rgba(181, 194, 219, 0.82);
}

[data-theme="dark"] .empty-state h2,
[data-theme="dark"] .empty-state h3,
[data-theme="dark"] .empty-state strong {
  color: #eef4ff;
}

.workspace-two-column {
  display: grid;
  grid-template-columns: minmax(340px, 0.95fr) minmax(420px, 1.25fr);
  gap: 20px;
}

.workspace-stack {
  display: grid;
  gap: 20px;
}

.soft-card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.soft-card {
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, #ffffff 0, #f8fbff 100%);
}

.soft-card span {
  display: block;
  margin-bottom: 6px;
  color: var(--ink-soft);
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.soft-card strong {
  font-size: 22px;
  color: var(--ink);
}

[data-theme="dark"] .soft-card {
  background: linear-gradient(180deg, rgba(18, 26, 47, 0.96) 0%, rgba(14, 21, 39, 0.98) 100%);
  border-color: rgba(132, 154, 191, 0.18);
}

[data-theme="dark"] .soft-card span {
  color: rgba(161, 181, 214, 0.76);
}

[data-theme="dark"] .soft-card strong {
  color: #eef4ff;
}

.table-inline-form .form-row {
  align-items: center;
}

.table-inline-form input,
.table-inline-form select {
  min-width: 0;
}

.html-preview,
.code-block,
.note-block,
.filter-bar {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 18px;
}

.filter-bar {
  margin-top: 16px;
}

[data-theme="dark"] .filter-bar {
  background: linear-gradient(180deg, rgba(18, 26, 47, 0.96) 0%, rgba(14, 21, 39, 0.98) 100%);
  border-color: rgba(132, 154, 191, 0.18);
}

.product-nav {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}

.product-nav-link {
  display: inline-flex;
  align-items: center;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.82);
  border: 1px solid var(--line);
  color: var(--ink-soft);
  font-size: 13px;
  font-weight: 700;
}

@media (max-width: 1100px) {
  .workspace-two-column,
  .workspace-stack,
  .soft-card-grid,
  .saas-hero-split,
  .saas-feature-grid {
    grid-template-columns: 1fr;
  }
}

.product-nav-link.active {
  background: #182235;
  border-color: #182235;
  color: #fff;
  box-shadow: 0 10px 24px rgba(24, 34, 53, 0.16);
}

[data-theme="dark"] .product-nav-link.active {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(148, 163, 184, 0.18);
  color: #fff;
  box-shadow: none;
}

.table-product {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.table-thumb {
  width: 56px;
  height: 56px;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--line-soft);
  background: linear-gradient(180deg, #f8fbfd 0, #edf4f8 100%);
  display: grid;
  place-items: center;
  font-size: 10px;
  color: var(--ink-soft);
  text-align: center;
}

.table-thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.table-subline {
  margin-top: 4px;
  color: var(--ink-soft);
  font-size: 13px;
  line-height: 1.4;
}

.table-link-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}

.table-issues {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.pill-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: var(--accent-soft);
  color: var(--accent-strong);
  font-weight: 700;
  font-size: 13px;
}

.pill.pill-warm {
  background: var(--warm);
  color: #9a5b00;
}

.pill.pill-danger {
  background: var(--danger-soft);
  color: var(--danger);
}

.pill.subtle {
  background: #eef4f8;
  color: var(--ink-soft);
}

.queue-list {
  display: grid;
  gap: 12px;
}

.queue-card {
  display: grid;
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 18px;
  background: linear-gradient(180deg, #ffffff 0, #fbfdff 100%);
}

.queue-top {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: start;
}

.queue-title {
  font-size: 20px;
  font-weight: 800;
  letter-spacing: -0.03em;
}

.queue-meta {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

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

.queue-cell {
  background: #f8fbfd;
  border: 1px solid var(--line-soft);
  border-radius: 14px;
  padding: 12px;
}

.queue-cell-label {
  color: var(--ink-soft);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 800;
}

.queue-cell-value {
  margin-top: 6px;
  font-weight: 700;
}

.code-block {
  white-space: pre-wrap;
  word-break: break-word;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 13px;
}

.soft-list {
  display: grid;
  gap: 10px;
}

.compact-form {
  gap: 12px;
}

.soft-list-row {
  padding: 12px 14px;
  border-radius: 14px;
  background: #f8fbfd;
  border: 1px solid var(--line-soft);
}

.help-article-layout {
  display: grid;
  grid-template-columns: minmax(240px, 300px) minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.help-article-toc {
  position: sticky;
  top: 108px;
}

.help-article-toc-groups {
  display: grid;
  gap: 16px;
}

.help-article-toc-group h3 {
  margin: 0 0 10px;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

.help-article-toc-links {
  display: grid;
  gap: 8px;
}

.help-article-toc-link {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--line-soft);
  background: #f8fbfd;
  color: var(--ink);
  font-weight: 700;
  text-decoration: none;
}

.help-article-toc-link:hover {
  border-color: rgba(84, 133, 255, 0.3);
  background: #ffffff;
}

.help-article-toc-link.is-active {
  border-color: rgba(53, 143, 129, 0.35);
  background: linear-gradient(180deg, #f4fbfa 0%, #eef8f7 100%);
  box-shadow: 0 10px 24px rgba(53, 143, 129, 0.1);
}

.help-article-main {
  min-width: 0;
}

.help-article-shell {
  border-radius: 20px;
  background: #ffffff;
}

.help-article-entry {
  padding: 24px 28px;
  font-size: 18px;
  line-height: 1.7;
}

.help-article-entry p:first-child {
  margin-top: 0;
}

.help-article-entry ol,
.help-article-entry ul {
  padding-left: 1.4rem;
}

.help-article-entry li + li {
  margin-top: 12px;
}

.help-article-support-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

[data-theme="dark"] .help-article-toc-link,
[data-theme="dark"] .help-article-shell,
[data-theme="dark"] .help-article-support .card {
  background: rgba(18, 26, 47, 0.96);
  border-color: rgba(132, 154, 191, 0.18);
}

[data-theme="dark"] .help-article-toc-link:hover {
  background: rgba(22, 31, 55, 0.98);
}

[data-theme="dark"] .help-article-toc-link.is-active {
  background: linear-gradient(180deg, rgba(22, 48, 58, 0.96) 0%, rgba(17, 39, 47, 0.98) 100%);
  border-color: rgba(100, 196, 175, 0.34);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.22);
}

.message-detail-grid {
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
  align-items: start;
}

.message-detail-meta-card,
.message-detail-body-card {
  min-width: 0;
}

.message-detail-body-card h2 {
  margin-bottom: 12px;
}

.message-html-preview {
  overflow: auto;
}

.message-html-preview > *:first-child {
  margin-top: 0;
}

.message-html-preview table {
  width: 100% !important;
  max-width: 100%;
  table-layout: auto;
  border-collapse: collapse;
  display: block;
  overflow-x: auto;
}

.message-html-preview th,
.message-html-preview td {
  padding: 10px 12px;
  border-bottom: 1px solid #e5e7eb;
  vertical-align: top;
  word-break: break-word;
  white-space: normal;
}

.message-html-preview img {
  max-width: 100%;
  height: auto;
}

.message-html-preview p,
.message-html-preview li,
.message-html-preview div,
.message-html-preview span {
  overflow-wrap: anywhere;
}

.insights-grid {
  grid-template-columns: 1fr 1.15fr;
}

.insights-panel {
  padding: 22px;
}

.insights-filter-bar {
  display: flex;
  align-items: end;
  gap: 14px;
  flex-wrap: wrap;
}

.insights-filter-bar label {
  min-width: 160px;
}

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

.insights-ranked-list {
  margin: 12px 0 0;
  padding-left: 22px;
  display: grid;
  gap: 8px;
}

.insights-ranked-list li {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 8px 0;
  border-bottom: 1px solid var(--line-soft);
}

.insights-ranked-list li:last-child {
  border-bottom: 0;
}

.insights-chart-list {
  display: grid;
  gap: 12px;
}

.insights-chart-row {
  display: grid;
  gap: 8px;
}

.insights-chart-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
}

.insights-chart-head strong {
  font-size: 14px;
  color: #111827;
}

.insights-chart-head span {
  font-size: 14px;
  font-weight: 700;
  color: #334155;
}

.insights-chart-track {
  width: 100%;
  height: 12px;
  border-radius: 999px;
  background: #edf2f7;
  overflow: hidden;
}

.insights-chart-track.compact {
  height: 8px;
}

.insights-chart-fill {
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #4f7cff 0%, #7294ff 100%);
}

.insights-chart-fill.alt {
  background: linear-gradient(90deg, #0f766e 0%, #14b8a6 100%);
}

.insights-ranked-bars {
  padding-left: 0;
  list-style: none;
}

.insights-ranked-bars li {
  display: grid;
  gap: 8px;
}

.insights-ranked-main {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
}

.insights-ranked-main span {
  line-height: 1.45;
}

.insights-year-bars {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 16px;
  align-items: end;
}

.insights-year-bar-card {
  display: grid;
  gap: 10px;
  padding: 14px 14px 10px;
  border: 1px solid #e4e7ec;
  border-radius: 16px;
  background: #fbfcfe;
}

.insights-year-bar-value {
  font-size: 13px;
  font-weight: 700;
  color: #334155;
}

.insights-year-bar-track {
  height: 140px;
  display: flex;
  align-items: end;
  border-radius: 12px;
  background: linear-gradient(180deg, #f8fafc 0%, #eef2f7 100%);
  padding: 8px;
}

.insights-year-bar-fill {
  width: 100%;
  border-radius: 10px 10px 6px 6px;
  min-height: 8px;
  background: linear-gradient(180deg, #0f766e 0%, #14b8a6 100%);
}

.insights-year-bar-label {
  text-align: center;
  font-size: 13px;
  font-weight: 700;
  color: #475467;
}

.customer-file-upload {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.file-dropzone {
  min-height: 120px;
  flex: 1 1 420px;
  border: 2px dashed var(--line);
  border-radius: 18px;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 18px;
  color: var(--ink-soft);
  font-weight: 700;
  background: #fbfdff;
  cursor: pointer;
}

.file-dropzone input {
  display: none;
}

.customer-map-grid {
  grid-template-columns: 380px minmax(0, 1fr);
}

.map-preview iframe {
  width: 100%;
  min-height: 420px;
  border: 0;
  border-radius: 18px;
  background: #f4f7fb;
}

.product-search-combobox {
  position: relative;
}

.product-search-results {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  z-index: 30;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: 0 16px 32px rgba(15, 23, 42, 0.12);
  max-height: 320px;
  overflow: auto;
}

.product-search-option,
.product-search-result {
  width: 100%;
  display: block;
  text-align: left;
  padding: 12px 14px;
  border: 0;
  border-bottom: 1px solid var(--line-soft);
  background: #fff;
  font: inherit;
  cursor: pointer;
}

.product-search-option:last-child,
.product-search-result:last-child {
  border-bottom: 0;
}

.product-search-option:hover,
.product-search-result:hover {
  background: #f5f8ff;
}

.product-search-empty {
  padding: 12px 14px;
  color: var(--ink-soft);
}

.table-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.check-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: #fff;
  font-weight: 700;
}

.check-pill input {
  width: auto;
  margin: 0;
}

.perfex-filter-form .check-pill,
.perfex-actions-row .check-pill,
.table-issues .check-pill {
  flex: 0 0 auto;
  min-width: 0;
  white-space: nowrap;
}

.perfex-filter-form .check-pill input,
.perfex-actions-row .check-pill input,
.table-issues .check-pill input {
  flex: 0 0 auto;
  min-width: 16px;
  width: 16px;
  height: 16px;
}

[data-theme="dark"] .check-pill {
  background: linear-gradient(180deg, rgba(20, 29, 51, 0.96) 0%, rgba(13, 20, 36, 0.98) 100%);
  border-color: rgba(148, 163, 184, 0.18);
  color: #e5edf9;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

[data-theme="dark"] .check-pill input {
  accent-color: #8ce7db;
}

.row-expanded td {
  background: #fbfdff;
}

.inline-edit-form {
  gap: 12px;
}

.catalog-admin-grid,
.catalog-grid,
.featured-strip,
.media-strip,
.property-grid,
.category-summary-grid,
.backlog-grid,
.product-admin-meta,
.product-admin-pricing,
.product-admin-actions,
.issue-list,
.category-summary-metrics {
  display: grid;
  gap: 16px;
}

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

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

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

.featured-strip {
  margin-top: 18px;
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.featured-card,
.catalog-card,
.product-admin-card {
  background: rgba(255,255,255,0.98);
  border: 1px solid var(--line);
  border-radius: 22px;
  overflow: hidden;
  box-shadow: var(--shadow);
}

.featured-card {
  display: grid;
  grid-template-rows: 180px auto;
}

.featured-card-image,
.catalog-card-image,
.product-thumb,
.product-main-image,
.catalog-detail-main {
  background: #fff;
  display: grid;
  place-items: center;
}

.featured-card-image img,
.catalog-card-image img,
.product-thumb img,
.product-main-image img,
.catalog-detail-main img,
.media-thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.featured-card-image.is-empty,
.catalog-card-image.is-empty,
.product-thumb.is-empty,
.product-main-image.is-empty,
.catalog-detail-main.is-empty {
  color: var(--ink-soft);
  font-weight: 700;
}

.featured-card-body,
.catalog-card-body,
.product-admin-body {
  padding: 16px 18px 18px;
}

.catalog-card {
  display: grid;
  grid-template-rows: 250px auto;
}

.catalog-card.compact-card {
  grid-template-rows: 180px auto;
}

.catalog-card-topline,
.product-admin-topline,
.catalog-card-pricing {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}

.catalog-card h3,
.product-admin-card h3 {
  margin: 10px 0 8px;
  font-size: 20px;
  letter-spacing: -0.03em;
}

.catalog-card-pricing strong {
  font-size: 20px;
}

.product-admin-card {
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr);
}

.product-thumb {
  min-height: 240px;
}

.product-admin-meta {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  color: var(--ink-soft);
  font-size: 13px;
}

.product-admin-pricing {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 14px;
}

.product-admin-pricing span,
.property-grid span,
.catalog-pricing-band span {
  display: block;
}

.product-admin-actions {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 14px;
}

.issue-list {
  grid-template-columns: repeat(auto-fit, minmax(150px, max-content));
  gap: 8px;
  margin-top: 12px;
}

.issue-pill {
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: #eef4f8;
  border: 1px solid var(--line);
  color: var(--ink);
  font-size: 12px;
  font-weight: 700;
}

.issue-pill.ok {
  background: var(--accent-soft);
  color: var(--accent-strong);
  border-color: rgba(15,118,110,0.18);
}

.issue-pill.danger {
  background: var(--danger-soft);
  color: var(--danger);
  border-color: rgba(180,35,24,0.16);
}

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

.category-summary-card {
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  padding: 16px;
  background: #f9fbfd;
}

.category-summary-card strong {
  display: block;
  font-size: 17px;
  letter-spacing: -0.02em;
}

.category-summary-metrics {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 12px;
  gap: 8px;
}

.category-summary-metrics span {
  font-size: 12px;
  color: var(--ink-soft);
}

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

.product-hero,
.catalog-detail-hero {
  display: grid;
  grid-template-columns: 420px minmax(0, 1fr);
  gap: 24px;
}

.product-main-image,
.catalog-detail-main {
  min-height: 420px;
  border-radius: 20px;
  border: 1px solid var(--line-soft);
  overflow: hidden;
}

.media-strip {
  grid-template-columns: repeat(6, minmax(0, 1fr));
  margin-top: 14px;
}

.media-thumb {
  height: 78px;
  border-radius: 14px;
  border: 1px solid var(--line-soft);
  overflow: hidden;
  background: #fff;
}

.product-description {
  font-size: 16px;
}

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

.property-grid div,
.catalog-pricing-band div {
  background: #f8fbfd;
  border: 1px solid var(--line-soft);
  border-radius: 16px;
  padding: 14px;
}

.property-grid strong,
.catalog-pricing-band strong {
  margin-top: 6px;
  display: block;
  font-size: 17px;
}

.catalog-pricing-band {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}

.hero-actions {
  display: flex;
  gap: 10px;
  align-items: center;
}

.product-editor-page {
  padding: 24px;
}

.product-editor-card-head {
  margin: -22px -22px 18px;
  padding: 16px 22px;
  border-bottom: 1px solid var(--line-soft);
  font-size: 1rem;
  font-weight: 800;
  color: #344054;
}

.product-editor-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.85fr) minmax(260px, 0.72fr);
  gap: 22px;
  align-items: start;
}

.product-editor-main,
.product-editor-side {
  display: grid;
  gap: 18px;
}

.product-editor-card,
.product-editor-media-card,
.product-editor-status-card {
  padding: 22px;
}

.product-editor-sheet {
  display: grid;
  gap: 18px;
}

.product-editor-top-grid {
  display: grid;
  gap: 0;
}

.product-editor-top-grid label span,
.product-editor-meta-grid label span,
.product-editor-quad-grid label span {
  display: block;
  margin-bottom: 8px;
  color: #475467;
  font-size: 0.92rem;
  font-weight: 800;
}

.product-editor-top-grid label span em,
.product-editor-meta-grid label span em,
.product-editor-price-grid label span em {
  font-style: normal;
  color: #ef4444;
}

.product-editor-name input {
  font-size: 1.05rem;
}

.product-editor-meta-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.product-editor-block-title {
  font-size: 0.95rem;
  font-weight: 800;
  color: #475467;
}

.product-editor-quad-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.product-editor-price-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px 16px;
  align-items: end;
}

.product-editor-price-grid > label:nth-child(5),
.product-editor-price-grid > label:nth-child(6),
.product-editor-price-grid > label:nth-child(7) {
  grid-column: span 1;
}

.product-editor-boolean {
  align-content: start;
}

.product-editor-boolean input[type="checkbox"] {
  width: 20px;
  height: 20px;
  margin-top: 12px;
}

.product-editor-check-card {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.product-editor-check-card span {
  margin-bottom: 8px;
}

.product-editor-check-card input[type="checkbox"] {
  margin-top: 0;
}

.product-editor-chip-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.product-editor-toggle-stack {
  display: grid;
  gap: 14px;
}

.product-editor-toggle-field {
  display: grid;
  gap: 8px;
  max-width: 390px;
}

.product-editor-toggle-field span {
  font-size: 0.92rem;
  font-weight: 800;
  color: #475467;
}

.product-editor-toggle-panel {
  border: 1px solid var(--line-soft);
  border-radius: 16px;
  padding: 14px;
  background: #fff;
}

.product-editor-toggle-panel.is-hidden {
  display: none;
}

.product-editor-helper {
  color: #475467;
  font-size: 0.93rem;
  line-height: 1.55;
}

.product-editor-divider {
  border-top: 1px solid var(--line-soft);
}

.product-rule-editor {
  display: grid;
  gap: 10px;
}

.product-rule-editor h3 {
  margin: 0;
  font-size: 1rem;
}

.product-rule-table {
  display: grid;
  gap: 10px;
}

.product-rule-header,
.product-rule-row {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) 150px 140px;
  gap: 10px;
  align-items: center;
}

.product-rule-header {
  color: #667085;
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.product-rule-row-qty,
.product-rule-header-qty {
  grid-template-columns: 120px 120px 150px 140px;
}

.product-rule-header-with-action {
  align-items: center;
}

.product-rule-header-action {
  justify-self: end;
}

.product-rule-row-visibility,
.product-rule-header-visibility {
  grid-template-columns: minmax(0, 1.5fr) 160px 170px 140px;
}

.product-rule-row-actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
}

.product-rule-row-discount-condition,
.product-rule-header.product-rule-row-discount-condition {
  grid-template-columns: 180px 150px minmax(0, 1fr) 120px;
}

.product-rule-row-discount-tier,
.product-rule-header.product-rule-row-discount-tier {
  grid-template-columns: 110px 110px 180px minmax(0, 1fr) 120px;
}

.product-rule-editor select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  min-height: 50px;
  padding-right: 42px;
  border-radius: 16px;
  border-color: #d7e0ea;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0, #f8fbff 100%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 18 18' fill='none'%3E%3Cpath d='M4.5 6.75L9 11.25L13.5 6.75' stroke='%2364748b' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat, no-repeat;
  background-position: 0 0, right 14px center;
  background-size: auto, 18px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
  color: var(--ink);
  font-weight: 700;
}

.product-rule-editor select:hover {
  border-color: #bfd3e4;
}

[data-theme="dark"] .product-rule-header {
  color: rgba(191, 204, 226, 0.72);
}

[data-theme="dark"] .product-rule-editor select,
[data-theme="dark"] .product-rule-editor input[type="text"],
[data-theme="dark"] .product-rule-editor input[type="number"],
[data-theme="dark"] .product-rule-editor textarea {
  border-color: rgba(148, 163, 184, 0.18);
  background: linear-gradient(180deg, rgba(21, 31, 55, 0.98) 0%, rgba(13, 21, 39, 0.98) 100%);
  color: #e7eefb;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

[data-theme="dark"] .product-rule-editor select {
  background:
    linear-gradient(180deg, rgba(21, 31, 55, 0.98) 0%, rgba(13, 21, 39, 0.98) 100%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 18 18' fill='none'%3E%3Cpath d='M4.5 6.75L9 11.25L13.5 6.75' stroke='%23b9c7db' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat, no-repeat;
  background-position: 0 0, right 14px center;
  background-size: auto, 18px;
}

[data-theme="dark"] .product-rule-editor input::placeholder,
[data-theme="dark"] .product-rule-editor textarea::placeholder {
  color: rgba(191, 204, 226, 0.44);
}

[data-theme="dark"] .product-rule-editor .light-btn {
  background: linear-gradient(180deg, rgba(24, 33, 57, 0.96) 0%, rgba(14, 21, 37, 0.98) 100%);
  border-color: rgba(148, 163, 184, 0.18);
  color: #edf3ff;
}

[data-theme="dark"] .product-rule-editor .light-btn:hover {
  background: rgba(148, 163, 184, 0.1);
}

[data-theme="dark"] .mini-chip.mini-chip-muted {
  background: rgba(148, 163, 184, 0.12);
  border-color: rgba(148, 163, 184, 0.18);
  color: #d9e4f5;
}

.product-rule-editor input[type="number"],
.product-rule-editor input[type="text"] {
  min-height: 50px;
  border-radius: 16px;
}

.product-pricing-matrix {
  display: grid;
  gap: 10px;
}

.product-pricing-matrix-head,
.product-pricing-matrix-row {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) minmax(240px, 1.2fr) minmax(180px, 0.8fr) minmax(220px, 1fr);
  gap: 14px;
}

.product-pricing-matrix-head {
  color: #667085;
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.product-pricing-matrix-row {
  padding: 14px 16px;
  border: 1px solid var(--line-soft);
  border-radius: 16px;
  background: #fbfcfe;
  align-items: start;
}

.product-pricing-matrix-row.is-match {
  border-color: rgba(34, 197, 94, 0.28);
  background: linear-gradient(180deg, rgba(240, 253, 244, 0.92) 0%, #ffffff 100%);
}

.product-pricing-matrix-cell {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.product-inherited-tier-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.product-editor-readonly-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.product-editor-readonly-grid div {
  background: #f8fbfd;
  border: 1px solid var(--line-soft);
  border-radius: 16px;
  padding: 14px;
}

.product-editor-readonly-grid strong {
  display: block;
  margin-top: 6px;
  font-size: 1rem;
}

.product-editor-side {
  position: sticky;
  top: 18px;
}

.product-editor-side-head {
  margin-bottom: 14px;
  font-size: 0.98rem;
  font-weight: 800;
  color: #1f2937;
  text-align: center;
}

.product-editor-media-actions {
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

.product-editor-gallery {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.product-editor-gallery-item {
  display: grid;
  gap: 8px;
  align-content: start;
  padding: 10px;
  border: 1px solid var(--line-soft);
  border-radius: 14px;
  background: #fff;
  min-height: 0;
  cursor: grab;
}

.product-editor-gallery-item.is-dragging {
  opacity: 0.6;
  border-color: rgba(37, 99, 235, 0.28);
  box-shadow: 0 8px 22px rgba(37, 99, 235, 0.12);
}

.product-editor-gallery-item-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.product-editor-gallery-handle {
  border: 0;
  background: transparent;
  color: #98a2b3;
  font-size: 15px;
  letter-spacing: -0.05em;
  cursor: grab;
  padding: 0;
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  touch-action: none;
  user-select: none;
  border-radius: 8px;
}

.product-editor-gallery-title {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  background: #eef3fb;
  color: #475467;
  font-size: 0.72rem;
  font-weight: 800;
  line-height: 1.2;
}

.product-editor-gallery-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  align-items: center;
}

.product-editor-gallery-item .product-thumb {
  width: 100%;
  aspect-ratio: 1 / 1;
  height: auto;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--line-soft);
  background: #f7fafc;
}

.product-editor-gallery-actions .ghost-btn,
.product-editor-gallery-actions .danger-btn {
  min-height: 28px;
  padding: 0.35rem 0.55rem;
  font-size: 0.72rem;
  line-height: 1.1;
  border-radius: 8px;
  white-space: nowrap;
}

.product-editor-gallery-actions .ghost-btn {
  flex: 1 1 auto;
}

.product-editor-gallery-actions .danger-btn {
  flex: 0 0 auto;
}

.product-editor-side .table-subline {
  line-height: 1.3;
}

@media (max-width: 1480px) {
  .product-editor-gallery {
    grid-template-columns: 1fr;
  }
}

.product-editor-upload-box {
  display: grid;
  gap: 10px;
}

.product-editor-upload-drop {
  min-height: 126px;
  border: 2px dashed #d6deea;
  border-radius: 16px;
  display: grid;
  place-items: center;
  color: #667085;
  text-align: center;
  padding: 18px;
  background: #fff;
}

.product-editor-drive-btn {
  justify-self: end;
}

.product-editor-recurring-grid,
.product-editor-promo-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  align-items: start;
}

.product-editor-stack-flag {
  min-height: 100%;
}

.product-editor-flag-copy {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-top: 8px;
  color: #475467;
  line-height: 1.4;
}

.product-editor-flag-copy strong {
  font-size: 0.93rem;
  font-weight: 700;
}

.product-editor-rule-summary {
  display: grid;
  gap: 12px;
}

.product-related-picker {
  display: grid;
  gap: 10px;
  padding: 16px;
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  background: #fbfcfe;
  position: relative;
}

.product-related-picker-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 16px;
}

.product-related-search {
  display: grid;
  gap: 8px;
  min-width: 0;
  flex: 1;
}

.product-related-search span {
  font-size: 0.92rem;
  font-weight: 800;
  color: #475467;
}

.product-related-picker-dropdown {
  display: none;
  gap: 0;
  position: absolute;
  top: calc(100% - 2px);
  left: 16px;
  right: 16px;
  z-index: 20;
  max-height: 260px;
  overflow: auto;
  padding: 0;
  border: 1px solid var(--line-soft);
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.08);
  overflow-x: hidden;
}

.product-related-picker.is-open .product-related-picker-dropdown {
  display: grid;
}

.product-related-picker-hidden {
  display: none;
}

.product-related-dropdown-option {
  display: grid;
  gap: 4px;
  width: 100%;
  padding: 12px 14px;
  border: 0;
  border-bottom: 1px solid #eef2f7;
  background: #fff;
  text-align: left;
  cursor: pointer;
}

.product-related-dropdown-option:last-child {
  border-bottom: 0;
}

.product-related-dropdown-option:hover,
.product-related-dropdown-option:focus-visible {
  background: #f8fbff;
  outline: 0;
}

.product-related-dropdown-option strong {
  color: #1f2937;
  font-size: 0.94rem;
  line-height: 1.35;
}

.product-related-dropdown-option span {
  color: #667085;
  font-size: 0.82rem;
}

.product-related-dropdown-option.is-selected {
  background: #eef5ff;
}

.product-related-dropdown-option.is-selected strong::after {
  content: " Selected";
  color: #2563eb;
  font-weight: 700;
}

.product-related-token-field {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid var(--line-soft);
  border-radius: 14px;
  background: #fff;
  min-height: 62px;
}

.product-related-token-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.product-related-token {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border: 1px solid #d6deea;
  border-radius: 10px;
  background: #eef2f6;
  color: #243246;
  font: inherit;
  font-weight: 700;
  padding: 0.45rem 0.7rem;
  cursor: pointer;
  max-width: 100%;
}

.product-related-token span {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.product-related-token strong {
  font-size: 1rem;
  line-height: 1;
  color: #667085;
}

.product-related-token-field input[type="search"] {
  flex: 1 1 220px;
  min-width: 220px;
  border: 0;
  padding: 0;
  min-height: 28px;
  background: transparent;
  box-shadow: none;
}

.product-related-token-field input[type="search"]:focus {
  outline: none;
}

.product-related-token-field:focus-within {
  border-color: #7dc6bc;
  box-shadow: 0 0 0 4px rgba(15, 118, 110, 0.08);
}

@media (max-width: 1480px) {
  .product-editor-meta-grid,
  .product-editor-quad-grid,
  .product-editor-readonly-grid,
  .product-editor-price-grid,
  .product-editor-recurring-grid,
  .product-editor-promo-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .product-editor-layout {
    grid-template-columns: minmax(0, 1fr) minmax(280px, 0.72fr);
  }
}

.compact-empty h3 {
  font-size: 1rem;
}

.compact-empty p {
  font-size: 0.92rem;
}

@media (max-width: 1320px) {
  .product-editor-layout {
    grid-template-columns: 1fr;
  }

  .product-editor-side {
    position: static;
  }
}

@media (max-width: 1180px) {
  .product-editor-layout,
  .product-editor-meta-grid,
  .product-editor-quad-grid,
  .product-editor-readonly-grid,
  .product-editor-price-grid,
  .product-editor-recurring-grid,
  .product-editor-promo-grid {
    grid-template-columns: 1fr;
  }

  .product-rule-header,
  .product-rule-row,
  .product-rule-header-qty,
  .product-rule-row-qty,
  .product-rule-header-visibility,
  .product-rule-row-visibility,
  .product-rule-row-discount-condition,
  .product-rule-row-discount-tier,
  .product-pricing-matrix-head,
  .product-pricing-matrix-row {
    grid-template-columns: 1fr;
  }

  .product-rule-header-action,
  .product-rule-row-actions {
    justify-self: start;
  }

  .product-editor-side {
    position: static;
  }

  .product-related-picker-head {
    flex-direction: column;
    align-items: stretch;
  }

  .product-related-picker-list {
    left: 12px;
    right: 12px;
  }

  .product-related-option {
    grid-template-columns: 1fr;
    align-items: start;
  }
}

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

.table-subline strong {
  color: var(--ink);
}

.po-entry-actions {
  display: grid;
  gap: 12px;
}

.po-entry-panel {
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  background: linear-gradient(180deg, #ffffff 0, #f8fbff 100%);
  padding: 0 16px 16px;
}

.po-entry-panel summary {
  cursor: pointer;
  list-style: none;
  padding: 16px 0;
  font-weight: 800;
  color: var(--ink);
}

.po-entry-panel summary::-webkit-details-marker {
  display: none;
}

.po-entry-panel[open] summary {
  border-bottom: 1px solid var(--line-soft);
  margin-bottom: 14px;
}

.settings-tabbar {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.menu-map {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.menu-map-group {
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  padding: 16px;
  background: #f8fbfd;
}

.menu-map-group strong {
  display: block;
  margin-bottom: 12px;
  font-size: 16px;
}

.menu-map-group ol {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 10px;
}

.setup-menu-shell {
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.setup-menu-sidebar {
  padding: 0;
  overflow: hidden;
}

[data-theme="dark"] .setup-menu-sidebar,
[data-theme="dark"] .setup-menu-content > .info-grid > .card,
[data-theme="dark"] .setup-menu-content > .setup-saas-stage,
[data-theme="dark"] .setup-menu-content > .setup-system-templates-stage,
[data-theme="dark"] .setup-menu-content > .menu-builder-stage,
[data-theme="dark"] .setup-system-template-group,
[data-theme="dark"] .perfex-card {
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.98) 0, rgba(10, 17, 30, 0.98) 100%);
  border-color: rgba(148, 163, 184, 0.16);
  box-shadow: 0 20px 44px rgba(2, 6, 23, 0.34);
}

.setup-menu-title {
  padding: 14px 16px;
  font-weight: 800;
  border-bottom: 1px solid var(--line-soft);
}

.setup-menu-nav {
  display: grid;
}

.setup-menu-nav > a,
.setup-nav-parent,
.setup-nav-children a {
  display: block;
  padding: 11px 14px;
  border-bottom: 1px solid var(--line-soft);
  color: var(--ink);
  font-weight: 600;
}

.setup-menu-nav > a.setup-menu-private {
  background: rgba(15, 118, 110, 0.08);
  color: var(--accent-strong);
  border-left: 4px solid rgba(15, 118, 110, 0.65);
  padding-left: 18px;
}

[data-theme="dark"] .setup-menu-nav > a,
[data-theme="dark"] .setup-nav-parent,
[data-theme="dark"] .setup-nav-children a {
  border-bottom-color: rgba(148, 163, 184, 0.12);
}

[data-theme="dark"] .setup-menu-nav > a.setup-menu-private {
  background: rgba(45, 212, 191, 0.08);
  border-left-color: rgba(94, 234, 212, 0.38);
}

.setup-menu-nav > a.setup-menu-private.active {
  background: linear-gradient(90deg, rgba(15, 118, 110, 0.16), rgba(15, 118, 110, 0.08));
  color: var(--accent-strong);
}

[data-theme="dark"] .setup-menu-nav > a.setup-menu-private.active {
  background: linear-gradient(90deg, rgba(45, 212, 191, 0.18), rgba(45, 212, 191, 0.06));
}

.setup-nav-group.is-open {
  display: grid;
}

.setup-nav-parent.active,
.setup-nav-children a.active {
  background: #f6f8fb;
}

[data-theme="dark"] .setup-nav-parent.active,
[data-theme="dark"] .setup-nav-children a.active {
  background: rgba(148, 163, 184, 0.1);
}

.setup-nav-children {
  display: grid;
}

.setup-nav-children a {
  padding-left: 24px;
  font-weight: 700;
}

.setup-system-template-stack {
  display: grid;
  gap: 18px;
}

.setup-system-templates-stage,
.setup-menu-content {
  min-width: 0;
}

.setup-menu-content {
  display: grid;
  gap: 18px;
  align-content: start;
}

.setup-menu-content > section,
.setup-menu-content > article {
  min-width: 0;
}

.setup-menu-content > .info-grid > :only-child {
  grid-column: 1 / -1;
}

.setup-menu-content > .info-grid > .setup-backups-history-card {
  grid-column: 1 / -1;
}

.setup-backup-workspace-grid {
  display: grid;
  gap: 10px;
  margin-top: 10px;
}

.setup-backup-workspace-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid var(--line-soft);
  border-radius: 14px;
  background: #fbfdff;
}

[data-theme="dark"] .setup-backup-workspace-row {
  background: rgba(15, 23, 42, 0.72);
  border-color: rgba(148, 163, 184, 0.16);
}

.setup-backup-cell {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.setup-menu-content > .info-grid > .card,
.setup-menu-content > .setup-saas-stage,
.setup-menu-content > .setup-system-templates-stage,
.setup-menu-content > .menu-builder-stage {
  width: 100%;
}

.setup-system-templates-card {
  width: 100%;
}

.setup-system-templates-card > .section-head {
  align-items: start;
}

.setup-system-template-group {
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
}

.setup-system-template-group-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 18px 0;
}

.importer-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}

.importer-card {
  display: grid;
  gap: 8px;
  padding: 18px;
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  background: #fff;
  color: inherit;
  text-decoration: none;
  transition: border-color 140ms ease, box-shadow 140ms ease, transform 140ms ease;
}

.importer-card:hover,
.importer-card.active {
  border-color: var(--accent);
  box-shadow: 0 12px 28px rgba(27, 39, 66, 0.08);
  transform: translateY(-1px);
}

.importer-card p {
  margin: 0;
  color: var(--ink-soft);
}

.importer-card-head {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.import-mapping-grid {
  display: grid;
  gap: 12px;
}

.import-mapping-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(240px, 320px);
  gap: 14px;
  align-items: center;
  padding: 14px 16px;
  border: 1px solid var(--line-soft);
  border-radius: 16px;
  background: var(--surface-soft);
}

.import-mapping-source {
  font-weight: 700;
  color: var(--ink);
  word-break: break-word;
}

.import-preview-shell {
  display: grid;
  gap: 12px;
}

.table-shell {
  overflow-x: auto;
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  background: #fff;
}

.line-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 720px;
}

.line-table th,
.line-table td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--line-soft);
  text-align: left;
  vertical-align: top;
}

.line-table thead th {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
  background: var(--surface-soft);
}

.line-table tbody tr:last-child td {
  border-bottom: 0;
}

.setup-saas-stage {
  display: grid;
  gap: 18px;
}

.setup-saas-subnav {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--line-soft);
}

.setup-saas-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.setup-saas-plan-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.setup-saas-summary-card,
.setup-saas-workspace-card,
.setup-saas-plan-card {
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  background: #fff;
}

.setup-saas-summary-card {
  padding: 18px;
}

.setup-saas-summary-card span,
.setup-saas-metadata-grid span {
  display: block;
  margin-bottom: 6px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.setup-saas-summary-card strong {
  display: block;
  font-size: 32px;
  line-height: 1;
}

.setup-saas-summary-card p,
.setup-saas-metadata-grid p,
.setup-saas-workspace-head p,
.setup-saas-workspace-foot {
  color: var(--muted);
}

.setup-saas-workspace-list {
  display: grid;
  gap: 16px;
}

.setup-saas-plan-card {
  padding: 20px;
  position: relative;
}

.setup-saas-plan-card form {
  display: grid;
  gap: 14px;
}

.setup-saas-field-stack {
  display: grid;
  gap: 8px;
}

.setup-saas-plan-list-shell {
  display: grid;
  gap: 12px;
}

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

.setup-saas-quota-grid label,
.setup-saas-field-stack label {
  min-width: 0;
}

.setup-saas-feature-block,
.setup-saas-plan-preview {
  border: 1px solid var(--line-soft);
  border-radius: 16px;
  background: #f8fbff;
  padding: 16px;
}

.setup-saas-feature-head {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 12px;
}

.setup-saas-feature-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.setup-saas-plan-bullets {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 6px;
}

.setup-saas-plan-card.is-featured {
  border-color: rgba(74, 123, 246, 0.45);
  box-shadow: 0 18px 40px rgba(74, 123, 246, 0.08);
}

.setup-saas-plan-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}

.setup-saas-plan-head span:first-child {
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
}

.setup-saas-plan-card h3 {
  margin: 0 0 8px;
  font-size: 24px;
}

.setup-saas-plan-price {
  margin-bottom: 16px;
  color: #4a7bf6;
  font-size: 42px;
  font-weight: 800;
  line-height: 1;
}

.setup-saas-plan-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.setup-saas-plan-list li {
  position: relative;
  padding-left: 20px;
  color: var(--ink-soft);
  font-weight: 600;
}

.setup-saas-plan-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 9px;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #4a7bf6;
 }

.setup-saas-workspace-card {
  padding: 18px;
  display: grid;
  gap: 16px;
}

.setup-saas-workspace-head,
.setup-saas-workspace-foot {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.setup-saas-workspace-head h3 {
  margin: 0 0 4px;
}

.setup-saas-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}

.setup-saas-metadata-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.setup-saas-metadata-grid > div {
  padding: 14px;
  border-radius: 16px;
  background: #f8fbff;
  border: 1px solid var(--line-soft);
}

.setup-saas-metadata-grid strong {
  display: block;
  margin-bottom: 4px;
  font-size: 18px;
}

.saas-marketing-shell {
  max-width: 1240px;
  margin: 0 auto;
  display: grid;
  gap: 24px;
  position: relative;
}

.saas-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(10px);
  pointer-events: none;
  opacity: 0.55;
}

.saas-orb-one {
  width: 280px;
  height: 280px;
  top: -50px;
  right: 4%;
  background: radial-gradient(circle, rgba(13, 148, 136, 0.18), rgba(13, 148, 136, 0));
}

.saas-orb-two {
  width: 220px;
  height: 220px;
  top: 320px;
  left: -40px;
  background: radial-gradient(circle, rgba(59, 130, 246, 0.16), rgba(59, 130, 246, 0));
}

.saas-hero-card,
.saas-signup-card,
.saas-success-card {
  overflow: hidden;
}

.saas-hero-card {
  background:
    radial-gradient(circle at top right, rgba(15, 118, 110, 0.13), transparent 34%),
    radial-gradient(circle at bottom left, rgba(59, 130, 246, 0.08), transparent 30%),
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(250,252,255,0.98));
  box-shadow: 0 28px 70px rgba(31, 41, 55, 0.08);
}

.saas-marketing-home {
  gap: 28px;
}

.saas-page-nav {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 14px 22px;
  padding: 18px 28px;
  position: sticky;
  top: 16px;
  z-index: 8;
  background: rgba(255, 255, 255, 0.82);
  backdrop-filter: blur(14px);
}

.saas-page-nav a {
  color: var(--ink-soft);
  font-weight: 700;
  text-decoration: none;
}

.saas-page-nav a:hover {
  color: var(--ink);
}

.saas-page-nav .saas-page-nav-cta {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  padding: 0 30px;
  border-radius: 999px;
  background: linear-gradient(135deg, #0f766e 0%, #147d74 55%, #0f766e 100%);
  color: #f8fffe;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -0.01em;
  box-shadow: 0 18px 38px rgba(15, 118, 110, 0.22);
  text-decoration: none;
  transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease;
}

.saas-page-nav .saas-page-nav-cta:hover {
  color: #ffffff;
  background: linear-gradient(135deg, #0d6e67 0%, #16877d 55%, #0d6e67 100%);
  box-shadow: 0 22px 44px rgba(15, 118, 110, 0.28);
  transform: translateY(-1px);
}

.saas-hero-clean {
  display: grid;
  gap: 30px;
  padding: 42px 42px 36px;
}

.saas-hero-split {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(340px, 0.95fr);
  gap: 28px;
  align-items: center;
}

.saas-hero-copy {
  display: grid;
  gap: 18px;
}

.saas-hero-copy-centered {
  justify-items: center;
  text-align: center;
  max-width: 860px;
  margin: 0 auto;
}

.saas-hero-copy h1 {
  margin: 0;
  font-size: clamp(40px, 5vw, 66px);
  line-height: 0.95;
  letter-spacing: -0.04em;
}

.saas-hero-copy .lede {
  max-width: 60ch;
  font-size: 18px;
}

.saas-hero-copy-centered .lede {
  max-width: 54ch;
}

.saas-hero-actions {
  justify-content: center;
}

.saas-hero-points {
  display: grid;
  gap: 14px;
}

.saas-hero-points > div {
  padding: 14px 16px;
  border: 1px solid #dce6f2;
  border-radius: 18px;
  background: rgba(255,255,255,0.82);
}

.saas-hero-points strong {
  display: block;
  margin-bottom: 6px;
  font-size: 15px;
}

.saas-hero-points span {
  color: var(--ink-soft);
  line-height: 1.55;
}

.saas-hero-note-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.saas-hero-note-strip > div {
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,0.74);
  border: 1px solid #dce6f2;
  display: grid;
  gap: 4px;
}

.saas-hero-note-strip span {
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 800;
  color: #0f766e;
}

.saas-hero-note-strip strong {
  font-size: 14px;
}

.saas-hero-media {
  display: grid;
  gap: 10px;
  position: relative;
}

.saas-video-frame {
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid #dce6f2;
  background: #0c111d;
  box-shadow: 0 20px 60px rgba(15, 23, 42, 0.16);
}

.saas-hero-video-stage {
  display: grid;
  gap: 12px;
  max-width: 980px;
  width: 100%;
  margin: 0 auto;
}

.saas-video-frame-clean {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  position: relative;
  overflow: hidden;
  min-height: 320px;
}

.saas-video-sound-toggle {
  position: absolute;
  top: 18px;
  right: 18px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border: 1px solid rgba(15, 23, 42, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  color: #132238;
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.16);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.02em;
  cursor: pointer;
  backdrop-filter: blur(14px);
}

.saas-video-sound-toggle:hover {
  transform: translateY(-1px);
}

.saas-video-sound-toggle-icon {
  font-size: 14px;
  line-height: 1;
}

.saas-video-frame-clean.has-poster::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(246, 249, 253, 0.96), rgba(246, 249, 253, 0.96)),
    var(--saas-video-poster) center / cover no-repeat;
  transition: opacity 200ms ease;
}

.saas-video-frame-clean.is-ready::before {
  opacity: 0;
}

.saas-video-frame video {
  display: block;
  width: 100%;
  height: auto;
}

.saas-video-frame-clean video {
  border-radius: 0;
  opacity: 0;
  transition: opacity 220ms ease;
}

.saas-video-frame-clean.is-ready video {
  opacity: 1;
}

@media (max-width: 720px) {
  .saas-video-sound-toggle {
    top: 12px;
    right: 12px;
    padding: 9px 12px;
    font-size: 12px;
  }
}

.saas-hero-caption {
  color: var(--ink-soft);
  font-size: 13px;
  text-align: center;
}

.saas-feature-band,
.saas-proof-band {
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(247,250,253,0.98));
}

.saas-bottom-cta {
  display: grid;
  gap: 20px;
  justify-items: center;
  padding: 36px 32px;
  text-align: center;
  background:
    radial-gradient(circle at top center, rgba(15, 118, 110, 0.12), transparent 38%),
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(247,250,253,0.98));
}

.saas-bottom-cta-copy {
  display: grid;
  gap: 10px;
  max-width: 760px;
}

.saas-bottom-cta-copy h2 {
  margin: 0;
  font-size: clamp(30px, 4.2vw, 48px);
  line-height: 1.02;
  letter-spacing: -0.04em;
}

.saas-bottom-cta-actions {
  justify-content: center;
}

[data-theme="dark"] .saas-page-nav {
  background: rgba(10, 17, 30, 0.82);
  border-color: rgba(148, 163, 184, 0.16);
}

[data-theme="dark"] .saas-page-nav a {
  color: rgba(220, 230, 245, 0.78);
}

[data-theme="dark"] .saas-page-nav a:hover {
  color: #f5f8ff;
}

[data-theme="dark"] .saas-bottom-cta {
  background:
    radial-gradient(circle at top center, rgba(45, 212, 191, 0.12), transparent 38%),
    linear-gradient(180deg, rgba(15, 23, 42, 0.98), rgba(10, 17, 30, 0.98));
}

.saas-feature-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.saas-feature-card {
  padding: 20px;
  border-radius: 20px;
  border: 1px solid #dce6f2;
  background: linear-gradient(180deg, #ffffff 0, #fbfdff 100%);
  min-height: 240px;
  display: grid;
  gap: 12px;
  align-content: start;
}

.saas-feature-card h3 {
  margin: 0;
  font-size: 22px;
}

.saas-feature-card p {
  margin: 0;
  color: var(--ink-soft);
  line-height: 1.65;
}

.saas-feature-card-art {
  margin-top: auto;
}

.saas-feature-card-media {
  width: 92px;
  height: 92px;
  border-radius: 22px;
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, #f6fbff, #eef6ff);
  border: 1px solid #dce6f2;
  overflow: hidden;
}

.saas-feature-card-media img {
  width: 72px;
  height: 72px;
  object-fit: contain;
  display: block;
}

.saas-proof-card {
  position: relative;
  overflow: hidden;
}

.saas-proof-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  gap: 24px;
  align-items: start;
}

.saas-proof-story {
  display: grid;
  gap: 14px;
}

.saas-proof-story h2 {
  font-size: 38px;
  line-height: 1.04;
}

.saas-proof-story .lede {
  font-size: 17px;
}

.saas-proof-counters {
  display: grid;
  gap: 12px;
}

.saas-proof-counters > div {
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid #dce6f2;
  background: #fff;
  display: grid;
  gap: 5px;
}

.saas-proof-counters strong {
  font-size: 16px;
}

.saas-proof-counters span {
  color: var(--ink-soft);
  line-height: 1.55;
}

.saas-proof-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.saas-proof-band-simple {
  padding-top: 28px;
}

.saas-proof-grid-simple .saas-proof-card {
  min-height: 0;
}

.saas-plan-microcopy {
  margin-top: -6px;
  color: var(--ink-soft);
  font-size: 13px;
}

.menu-builder-stage {
  padding: 28px;
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(246, 250, 255, 0.98) 100%);
}

.menu-builder-panel {
  display: grid;
  gap: 14px;
  margin-top: 20px;
}

.menu-builder-scope-tabs {
  display: inline-flex;
  gap: 10px;
  margin-top: 18px;
}

.menu-builder-scope-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 92px;
  height: 40px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: rgba(248, 250, 252, 0.82);
  color: var(--ink-soft);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.menu-builder-scope-tab.is-active {
  background: #0f172a;
  color: #fff;
  border-color: #0f172a;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.16);
}

[data-theme="dark"] .menu-builder-scope-tab {
  background: rgba(15, 23, 42, 0.82);
  border-color: rgba(148, 163, 184, 0.2);
  color: #c8d3e6;
}

.menu-builder-save {
  display: flex;
  align-items: center;
}

.menu-builder-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 18px;
}

.menu-builder-canvas {
  display: grid;
  gap: 12px;
}

.menu-builder-row {
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr) auto;
  align-items: center;
  gap: 16px;
  min-height: 76px;
  padding: 0 18px;
  border: 1px solid rgba(148, 163, 184, 0.16);
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 1) 0%, rgba(248, 251, 255, 1) 100%);
  cursor: grab;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.05);
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.menu-builder-row-checkable {
  grid-template-columns: 32px minmax(0, 1fr) auto;
}

.menu-builder-row:hover {
  transform: translateY(-1px);
  box-shadow: 0 16px 36px rgba(15, 23, 42, 0.08);
  border-color: rgba(45, 104, 250, 0.18);
}

.menu-builder-row-main {
  display: grid;
  gap: 4px;
}

.menu-builder-row-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.menu-builder-row-main strong {
  font-size: 15px;
  font-weight: 800;
  color: var(--ink-strong);
}

.menu-builder-row-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 58px;
  height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(45, 104, 250, 0.08);
  color: #335baf;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.menu-builder-row-meta {
  color: var(--ink-soft);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.02em;
  line-height: 1.4;
}

[data-theme="dark"] .menu-builder-row {
  background: linear-gradient(180deg, rgba(20, 29, 51, 0.96) 0%, rgba(12, 18, 32, 0.98) 100%);
  border-color: rgba(148, 163, 184, 0.18);
  color: #e7eefb;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

[data-theme="dark"] .menu-builder-stage {
  background:
    linear-gradient(180deg, rgba(17, 24, 39, 0.98) 0%, rgba(9, 13, 23, 0.98) 100%);
}

[data-theme="dark"] .menu-builder-row-main strong {
  color: #f8fbff;
}

[data-theme="dark"] .menu-builder-row-badge {
  background: rgba(128, 176, 255, 0.14);
  color: #bfd4ff;
}

.menu-builder-row.is-dragging {
  opacity: 0.55;
}

.menu-builder-grip {
  color: var(--ink-soft);
  text-align: center;
  font-size: 18px;
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: rgba(148, 163, 184, 0.08);
}

[data-theme="dark"] .menu-builder-grip {
  color: rgba(191, 204, 226, 0.72);
}

.menu-builder-visibility,
.menu-visibility-toggle {
  justify-self: end;
  min-width: 102px;
  height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid var(--line-soft);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: #f8fafc;
  color: var(--ink-soft);
  font-weight: 700;
}

.menu-builder-visibility.is-visible,
.menu-visibility-toggle:not(.is-hidden) {
  color: #0f766e;
  background: rgba(20, 184, 166, 0.12);
  border-color: rgba(20, 184, 166, 0.28);
}

.menu-visibility-toggle {
  cursor: pointer;
}

.menu-visibility-toggle input {
  display: none;
}

.menu-visibility-toggle.is-hidden {
  color: #94a3b8;
  background: #fff;
}

[data-theme="dark"] .menu-builder-visibility,
[data-theme="dark"] .menu-visibility-toggle {
  background: rgba(15, 23, 42, 0.68);
  border-color: rgba(148, 163, 184, 0.2);
}

.menu-visibility-icon {
  font-size: 16px;
  line-height: 1;
}

.menu-builder-visibility-text,
.menu-visibility-text {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.02em;
}

[data-theme="dark"] .menu-builder-visibility,
[data-theme="dark"] .menu-visibility-toggle {
  background: rgba(15, 23, 42, 0.72);
  border-color: rgba(148, 163, 184, 0.18);
  color: rgba(191, 204, 226, 0.72);
}

[data-theme="dark"] .menu-builder-visibility.is-visible,
[data-theme="dark"] .menu-visibility-toggle:not(.is-hidden) {
  color: #8fe3d9;
  background: rgba(20, 184, 166, 0.12);
  border-color: rgba(20, 184, 166, 0.24);
}

.settings-tab {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  background: #f4f7fb;
  border: 1px solid var(--line-soft);
  color: var(--ink);
  font-weight: 700;
}

.settings-tab.active {
  background: #0f172a;
  color: #fff;
  border-color: #0f172a;
}

/* Shop / buyer portal */
.shop-body {
  background: var(--body-bg);
}

.shop-header {
  position: sticky;
  top: 0;
  z-index: 40;
  backdrop-filter: blur(16px);
  background: var(--shop-header-bg);
  border-bottom: 1px solid var(--shop-header-border);
}

.shop-header.portal-header {
  background: var(--shop-header-bg);
  border-bottom: 1px solid var(--shop-header-border);
}

.shop-header-inner {
  width: min(1440px, calc(100% - 36px));
  margin: 0 auto;
  padding: 14px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.shop-header-actions {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex: 0 0 auto;
}

.shop-header-cart {
  position: relative;
  width: 46px;
  height: 46px;
  border-radius: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line-soft);
  background: rgba(255, 255, 255, 0.92);
  color: #1e293b;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
  transition: transform 140ms ease, box-shadow 140ms ease, border-color 140ms ease, background 140ms ease;
}

.shop-header-cart:hover,
.shop-header-cart:focus-visible {
  transform: translateY(-1px);
  border-color: #cbd5e1;
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.12);
  background: #ffffff;
}

.shop-header-cart-icon {
  width: 20px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.shop-header-cart-icon svg {
  width: 20px;
  height: 20px;
  fill: currentColor;
}

.shop-header-cart-badge {
  position: absolute;
  top: -6px;
  right: -6px;
  min-width: 21px;
  height: 21px;
  padding: 0 6px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #0f766e 0, #14b8a6 100%);
  color: #ffffff;
  font-size: 11px;
  font-weight: 800;
  box-shadow: 0 8px 18px rgba(15, 118, 110, 0.24);
}

.shop-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: var(--shop-brand-ink);
}

.portal-header .shop-brand {
  color: var(--shop-brand-ink);
}

.shop-brand-mark {
  width: 46px;
  height: 46px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #7dd3fc 0, #60a5fa 100%);
  color: #09111f;
  font-weight: 900;
  letter-spacing: -0.04em;
}

.shop-brand-copy {
  display: grid;
  gap: 2px;
  line-height: 1.05;
}

.shop-brand-copy strong {
  font-size: 18px;
  letter-spacing: -0.04em;
}

.shop-brand-copy span {
  font-size: 12px;
  color: var(--public-header-muted);
}

.portal-header .shop-brand-copy span {
  color: var(--public-header-muted);
}

.shop-nav {
  display: flex;
  gap: 6px;
  flex-wrap: nowrap;
  justify-content: flex-end;
  align-items: center;
  min-width: 0;
}

.shop-nav a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 8px 12px;
  border-radius: 999px;
  color: rgba(219, 231, 245, 0.92);
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid transparent;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: -0.01em;
  white-space: nowrap;
}

.shop-nav a.active {
  background: #fff;
  color: #09111f;
}

.portal-header .shop-nav a {
  color: #61738d;
  background: transparent;
  border-color: transparent;
  font-weight: 800;
}

.portal-header .shop-nav a.active {
  background: #eef2f8;
  color: #09111f;
}

.portal-header .shop-nav a:hover,
.portal-header .shop-nav a:focus-visible {
  background: #f4f7fb;
  color: #1c2940;
}

.portal-utility-strip {
  display: flex;
  justify-content: flex-end;
  gap: 0.9rem;
  flex-wrap: wrap;
  margin: 1.1rem 0 0;
}

.portal-utility-link {
  color: var(--ink-soft);
  font-weight: 700;
}

.portal-header .shop-nav {
  flex: 1 1 auto;
  justify-content: center;
  gap: 18px;
  margin: 0 10px 0 18px;
}

.portal-header .shop-nav a {
  min-height: auto;
  padding: 10px 0 12px;
  border-radius: 0;
  position: relative;
  font-size: 14px;
  letter-spacing: -0.015em;
}

.portal-header .shop-nav a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 1px;
  height: 2px;
  border-radius: 999px;
  background: transparent;
  transform: scaleX(0.35);
  transition: background 140ms ease, transform 140ms ease;
}

.portal-header .shop-nav a.active::after {
  background: color-mix(in srgb, var(--accent) 86%, white 14%);
  transform: scaleX(1);
}

.portal-header .shop-nav a:hover::after,
.portal-header .shop-nav a:focus-visible::after {
  background: rgba(15, 118, 110, 0.24);
  transform: scaleX(0.85);
}

.shop-nav-toggle {
  display: none;
  width: 42px;
  height: 42px;
  border-radius: 14px;
  border: 1px solid var(--line-soft);
  background: rgba(255, 255, 255, 0.9);
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 4px;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
  color: #1e293b;
}

.shop-nav-toggle span {
  width: 16px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
}

.shop-header-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 999px;
  background: linear-gradient(135deg, #0f172a 0, #1e293b 100%);
  color: #f8fafc;
  font-weight: 800;
  letter-spacing: -0.02em;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.16);
}

.shop-header-cta:hover,
.shop-header-cta:focus-visible {
  background: linear-gradient(135deg, #111827 0, #0f172a 100%);
  color: #ffffff;
  transform: translateY(-1px);
}

.shop-header-cta-login {
  background: linear-gradient(135deg, #0f766e 0, #0f9f8c 100%);
  box-shadow: 0 14px 32px rgba(15, 118, 110, 0.2);
}

.shop-header-cta-login:hover,
.shop-header-cta-login:focus-visible {
  background: linear-gradient(135deg, #115e59 0, #0f766e 100%);
}

.portal-home-hero {
  background: linear-gradient(180deg, #ffffff 0, #f8fbff 100%);
}

.portal-home-grid {
  align-items: start;
}

.portal-home-panel {
  display: grid;
  gap: 0.75rem;
}

.portal-link-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

.portal-link-card {
  display: grid;
  gap: 0.45rem;
  padding: 1rem 1.05rem;
  border: 1px solid var(--line-soft);
  border-radius: 1.05rem;
  background: linear-gradient(180deg, #ffffff 0, #f7fbff 100%);
  color: var(--ink);
  transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;
}

.portal-link-card:hover {
  transform: translateY(-1px);
  border-color: #cdd8e6;
  box-shadow: 0 12px 26px rgba(15, 23, 42, 0.08);
}

.portal-link-card strong {
  font-size: 1.02rem;
}

.portal-link-card span {
  color: var(--ink-soft);
}

[data-theme="dark"] .portal-utility-link {
  color: rgba(219, 231, 245, 0.82);
}

[data-theme="dark"] .portal-utility-link:hover,
[data-theme="dark"] .portal-utility-link:focus-visible {
  color: #f8fafc;
}

[data-theme="dark"] .portal-user-chip {
  color: #dbe7f5;
  background: rgba(15, 23, 42, 0.92);
  border-color: rgba(148, 163, 184, 0.18);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.24);
}

[data-theme="dark"] .shop-nav-toggle {
  background: rgba(15, 23, 42, 0.92);
  border-color: rgba(148, 163, 184, 0.18);
  color: #e5edf8;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.24);
}

[data-theme="dark"] .shop-header-cart {
  background: rgba(15, 23, 42, 0.92);
  border-color: rgba(148, 163, 184, 0.18);
  color: #e5edf8;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.24);
}

[data-theme="dark"] .shop-header-cart:hover,
[data-theme="dark"] .shop-header-cart:focus-visible {
  background: rgba(30, 41, 59, 0.98);
  border-color: rgba(148, 163, 184, 0.28);
}

[data-theme="dark"] .portal-user-chip:hover,
[data-theme="dark"] .portal-user-menu[open] .portal-user-chip {
  background: rgba(30, 41, 59, 0.98);
  border-color: rgba(148, 163, 184, 0.28);
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.28);
}

[data-theme="dark"] .portal-user-avatar {
  background: rgba(226, 232, 240, 0.14);
  color: #f8fafc;
}

[data-theme="dark"] .portal-user-caret {
  color: rgba(219, 231, 245, 0.72);
}

[data-theme="dark"] .portal-user-menu-panel {
  background: rgba(15, 23, 42, 0.96);
  border-color: rgba(148, 163, 184, 0.18);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.32);
}

[data-theme="dark"] .portal-user-menu-link,
[data-theme="dark"] .portal-user-menu-button {
  color: #e5edf8;
}

[data-theme="dark"] .portal-user-menu-link:hover,
[data-theme="dark"] .portal-user-menu-link:focus-visible,
[data-theme="dark"] .portal-user-menu-button:hover,
[data-theme="dark"] .portal-user-menu-button:focus-visible {
  background: rgba(255, 255, 255, 0.06);
}

[data-theme="dark"] .portal-home-hero,
[data-theme="dark"] .portal-link-card {
  background: rgba(15, 23, 42, 0.92);
  border-color: rgba(148, 163, 184, 0.18);
}

[data-theme="dark"] .portal-link-card:hover {
  border-color: rgba(148, 163, 184, 0.28);
  box-shadow: 0 12px 26px rgba(0, 0, 0, 0.26);
}

[data-theme="dark"] .portal-link-card strong {
  color: #f8fafc;
}

[data-theme="dark"] .portal-link-card span {
  color: rgba(219, 231, 245, 0.76);
}

.shop-nav-count {
  display: inline-grid;
  place-items: center;
  min-width: 22px;
  height: 22px;
  padding: 0 7px;
  border-radius: 999px;
  background: rgba(15, 118, 110, 0.16);
  color: var(--accent-strong);
  font-size: 12px;
  font-weight: 800;
}

.shop-shell {
  width: min(1440px, calc(100% - 36px));
  margin: 22px auto 56px;
  display: grid;
  gap: 18px;
}

.portal-user-menu {
  position: relative;
}

.portal-user-menu summary {
  list-style: none;
}

.portal-user-menu summary::-webkit-details-marker {
  display: none;
}

.portal-user-menu:hover .portal-user-menu-panel,
.portal-user-menu:focus-within .portal-user-menu-panel {
  display: grid;
}

.portal-user-menu {
  position: relative;
  flex: 0 0 auto;
}

.portal-user-chip {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-height: 46px;
  padding: 8px 12px 8px 8px;
  border-radius: 18px;
  cursor: pointer;
  color: #243247;
  border: 1px solid rgba(203, 213, 225, 0.9);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
  transition: background 140ms ease, box-shadow 140ms ease, border-color 140ms ease, transform 140ms ease;
}

.portal-user-chip:hover,
.portal-user-menu[open] .portal-user-chip {
  background: #ffffff;
  border-color: #cbd5e1;
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.12);
  transform: translateY(-1px);
}

.portal-user-chip strong,
.portal-user-chip > div > span {
  display: block;
}

.portal-user-chip strong {
  font-size: 14px;
  line-height: 1.05;
  letter-spacing: -0.02em;
}

.portal-user-chip > div > span {
  font-size: 12px;
  color: #64748b;
}

.portal-user-avatar {
  width: 38px;
  height: 38px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 38px;
  line-height: 1;
  background: #e2e8f0;
  color: #1e293b;
  font-weight: 800;
}

.portal-user-caret {
  color: #64748b;
  font-size: 14px;
  line-height: 1;
}

.portal-user-menu-panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  min-width: 220px;
  padding: 10px;
  border-radius: 18px;
  border: 1px solid var(--line-soft);
  background: #fff;
  box-shadow: 0 18px 36px rgba(15, 23, 42, 0.12);
  display: none;
  gap: 6px;
  z-index: 40;
}

.portal-user-menu-link,
.portal-user-menu-button {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: flex-start;
  min-height: 44px;
  padding: 0 14px;
  border-radius: 14px;
  border: 0;
  background: transparent;
  color: var(--ink);
  font-weight: 700;
  text-align: left;
}

.portal-user-menu-link:hover,
.portal-user-menu-link:focus-visible,
.portal-user-menu-button:hover,
.portal-user-menu-button:focus-visible {
  background: #f4f7fb;
}

.portal-switch-modal {
  width: min(620px, calc(100vw - 28px));
}

.portal-switch-list {
  display: grid;
  gap: 10px;
  max-height: min(56vh, 460px);
  overflow: auto;
}

.portal-switch-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 12px;
  align-items: center;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid var(--line-soft);
  background: var(--panel);
}

.portal-switch-row strong {
  display: block;
}

.portal-switch-reset {
  padding-top: 6px;
}

.portal-profile-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(280px, 0.8fr);
  gap: 24px;
}

.portal-profile-panel {
  padding: 20px;
  border-radius: 24px;
  border: 1px solid var(--line-soft);
  background: var(--panel);
  display: grid;
  gap: 18px;
}

.portal-profile-panel h3 {
  margin: 0;
  font-size: 18px;
}

.portal-profile-panel--password {
  align-content: start;
}

.portal-profile-avatar-editor {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.portal-profile-avatar-preview {
  width: 96px;
  height: 96px;
  border-radius: 24px;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #eef2ff;
  color: #1e293b;
  font-size: 36px;
  font-weight: 800;
  border: 1px solid var(--line-soft);
}

.portal-profile-avatar-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.portal-profile-avatar-fields {
  display: grid;
  gap: 10px;
}

.portal-profile-check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  font-weight: 600;
  color: var(--muted);
}

.portal-profile-panel .primary-btn {
  justify-self: start;
}

[data-theme="dark"] .portal-profile-avatar-preview {
  background: rgba(148, 163, 184, 0.12);
  color: #f8fafc;
}

@media (max-width: 960px) {
  .portal-profile-layout {
    grid-template-columns: 1fr;
  }

  .portal-profile-avatar-editor {
    grid-template-columns: 1fr;
  }
}

.portal-section-card {
  padding: 28px 30px;
}

.portal-record-list {
  display: grid;
  gap: 14px;
}

.portal-record-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(240px, 0.85fr) auto;
  gap: 18px;
  align-items: center;
  padding: 18px 20px;
  border-radius: 22px;
  border: 1px solid var(--line-soft);
  background: linear-gradient(180deg, #ffffff 0, #f8fbff 100%);
}

.portal-record-topline {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.portal-record-topline strong {
  font-size: 18px;
}

.portal-record-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.portal-record-meta span {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 800;
  color: var(--ink-soft);
}

.portal-record-meta strong {
  display: block;
  margin-top: 6px;
  font-size: 15px;
}

.portal-record-actions {
  justify-self: end;
  text-align: right;
}

.portal-login-hero {
  min-height: calc(100vh - 120px);
  border-radius: 30px;
  overflow: hidden;
  background:
    linear-gradient(rgba(15, 23, 42, 0.45), rgba(15, 23, 42, 0.68)),
    url("https://images.unsplash.com/photo-1511379938547-c1f69419868d?auto=format&fit=crop&w=1800&q=80") center/cover no-repeat;
}

.portal-login-hero.has-background {
  background:
    linear-gradient(rgba(15, 23, 42, 0.45), rgba(15, 23, 42, 0.68)),
    var(--portal-login-bg-image) center/cover no-repeat;
}

.portal-login-overlay {
  min-height: calc(100vh - 120px);
  display: grid;
  place-items: center;
  padding: 40px 20px;
}

.portal-login-card {
  width: min(360px, 100%);
  background: rgba(255, 255, 255, 0.98);
  border-radius: 18px;
  padding: 24px;
  box-shadow: 0 32px 80px rgba(15, 23, 42, 0.22);
}

.portal-login-card h1 {
  margin: 0;
  text-align: center;
  font-size: 2rem;
}

.portal-login-submit {
  width: 100%;
}

.portal-login-links {
  margin-top: 16px;
  text-align: center;
  color: #64748b;
}

[data-theme="dark"] .portal-login-hero {
  background:
    linear-gradient(rgba(2, 6, 23, 0.58), rgba(2, 6, 23, 0.82)),
    url("https://images.unsplash.com/photo-1511379938547-c1f69419868d?auto=format&fit=crop&w=1800&q=80") center/cover no-repeat;
}

[data-theme="dark"] .portal-login-hero.has-background {
  background:
    linear-gradient(rgba(2, 6, 23, 0.58), rgba(2, 6, 23, 0.82)),
    var(--portal-login-bg-image) center/cover no-repeat;
}

[data-theme="dark"] .portal-login-card {
  background: rgba(15, 23, 42, 0.92);
  border: 1px solid rgba(148, 163, 184, 0.18);
  box-shadow: 0 32px 80px rgba(2, 6, 23, 0.42);
  color: #e5edf8;
}

[data-theme="dark"] .portal-login-card h1,
[data-theme="dark"] .portal-login-card label {
  color: #f8fafc;
}

[data-theme="dark"] .portal-login-card input[type="email"],
[data-theme="dark"] .portal-login-card input[type="password"] {
  background: rgba(15, 23, 42, 0.96);
  border-color: rgba(148, 163, 184, 0.2);
  color: #f8fafc;
}

[data-theme="dark"] .portal-login-card input[type="email"]::placeholder,
[data-theme="dark"] .portal-login-card input[type="password"]::placeholder {
  color: #94a3b8;
}

[data-theme="dark"] .portal-login-card .checkline {
  color: #dbe7f5;
}

[data-theme="dark"] .portal-login-links {
  color: #cbd5e1;
}

[data-theme="dark"] .portal-login-links a {
  color: #93c5fd;
}

.shop-shell > .card {
  border-radius: 30px;
}

.shop-context {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at top right, rgba(96, 165, 250, 0.14), transparent 32%),
    linear-gradient(135deg, #ffffff 0, #f8fbfd 100%);
}

.shop-context-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(320px, 0.9fr);
  gap: 24px;
  align-items: stretch;
}

.shop-context-copy h1 {
  max-width: 14ch;
}

.shop-context-copy .lede {
  max-width: 58ch;
}

.shop-context-panel {
  border-radius: 24px;
  border: 1px solid rgba(125, 198, 188, 0.24);
  background: linear-gradient(180deg, #0f172a 0, #111d30 100%);
  color: #fff;
  padding: 22px;
  display: grid;
  gap: 16px;
}

.shop-context-panel .muted {
  color: rgba(219, 231, 245, 0.72);
}

.shop-context-panel .pill {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
}

.shop-context-panel .pill.pill-warm {
  background: rgba(251, 191, 36, 0.16);
  color: #fed7aa;
}

.shop-context-panel-head,
.shop-hero-panel-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: start;
}

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

.shop-account-form select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  width: 100%;
  min-height: 52px;
  padding: 0 48px 0 16px;
  border-radius: 16px;
  border: 1px solid rgba(217, 225, 234, 0.9);
  background:
    linear-gradient(45deg, transparent 50%, #64748b 50%) calc(100% - 22px) calc(50% - 2px) / 8px 8px no-repeat,
    linear-gradient(135deg, #64748b 50%, transparent 50%) calc(100% - 16px) calc(50% - 2px) / 8px 8px no-repeat,
    rgba(255, 255, 255, 0.98);
  color: var(--ink);
  font-size: 15px;
  font-weight: 700;
}

.shop-account-summary {
  display: grid;
  gap: 12px;
}

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

.shop-address-card {
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.shop-address-card span,
.shop-address-card strong {
  color: rgba(255, 255, 255, 0.88);
}

.shop-address-card .shop-address-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgba(219, 231, 245, 0.72);
  font-weight: 800;
}

.shop-context-note {
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.08);
}

.shop-kpis,
.shop-hero-metrics,
.shop-cart-summary,
.shop-checkout-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.shop-kpi {
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid rgba(217, 225, 234, 0.9);
}

.shop-context-panel .shop-kpi {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.08);
}

.shop-kpi span {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 800;
  color: var(--ink-soft);
}

.shop-context-panel .shop-kpi span {
  color: rgba(219, 231, 245, 0.7);
}

.shop-kpi strong {
  display: block;
  margin-top: 6px;
  font-size: 18px;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--ink);
}

.shop-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(340px, 0.75fr);
  gap: 20px;
  align-items: stretch;
}

.shop-hero-panel {
  border-radius: 24px;
  border: 1px solid rgba(96, 165, 250, 0.16);
  background: linear-gradient(180deg, #ffffff 0, #f6fbff 100%);
  padding: 20px;
  display: grid;
  gap: 16px;
}

.catalog-hero .shop-hero-grid {
  align-items: start;
}

.shop-hero-panel .pill {
  align-self: start;
}

[data-theme="dark"] .shop-context {
  background:
    radial-gradient(circle at top right, rgba(96, 165, 250, 0.12), transparent 32%),
    linear-gradient(135deg, rgba(15, 23, 42, 0.98) 0, rgba(9, 15, 26, 0.98) 100%);
}

[data-theme="dark"] .shop-context-copy h1,
[data-theme="dark"] .shop-context-copy .lede,
[data-theme="dark"] .shop-context-copy .eyebrow,
[data-theme="dark"] .shop-kpi strong,
[data-theme="dark"] .shop-kpi span {
  color: #f8fafc;
}

[data-theme="dark"] .shop-kpi {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(148, 163, 184, 0.16);
}

[data-theme="dark"] .shop-context-copy .lede {
  color: rgba(219, 231, 245, 0.82);
}

[data-theme="dark"] .shop-account-form select {
  border-color: rgba(148, 163, 184, 0.18);
  background:
    linear-gradient(45deg, transparent 50%, rgba(219, 231, 245, 0.82) 50%) calc(100% - 22px) calc(50% - 2px) / 8px 8px no-repeat,
    linear-gradient(135deg, rgba(219, 231, 245, 0.82) 50%, transparent 50%) calc(100% - 16px) calc(50% - 2px) / 8px 8px no-repeat,
    rgba(255, 255, 255, 0.08);
  color: #f8fafc;
}

[data-theme="dark"] .shop-hero-panel {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.04) 0, rgba(255, 255, 255, 0.02) 100%);
  border-color: rgba(148, 163, 184, 0.16);
}

[data-theme="dark"] .shop-hero-panel .shop-kpi {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(148, 163, 184, 0.16);
}

[data-theme="dark"] .shop-hero-panel .pill {
  background: rgba(251, 191, 36, 0.18);
  color: #fcd34d;
}

.shop-context-compact {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 18px 22px;
  border-radius: 24px;
  background:
    radial-gradient(circle at top right, rgba(96, 165, 250, 0.1), transparent 32%),
    linear-gradient(135deg, #ffffff 0, #f8fbfd 100%);
}

.shop-context-compact-main {
  display: flex;
  align-items: center;
  gap: 20px;
  min-width: 0;
  flex: 1 1 auto;
}

.shop-context-compact-copy {
  min-width: 0;
}

.shop-context-compact-copy h1 {
  margin: 0;
  font-size: clamp(1.75rem, 3vw, 2.4rem);
  line-height: 1.02;
}

.shop-context-compact-copy .muted {
  margin-top: 8px;
  max-width: 56ch;
}

.shop-context-compact-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(120px, 1fr));
  gap: 10px;
  flex: 1 1 auto;
}

.shop-context-compact .mini-stat {
  padding: 12px 14px;
  border-radius: 18px;
  border: 1px solid rgba(217, 225, 234, 0.9);
  background: rgba(255, 255, 255, 0.9);
}

.shop-context-compact .mini-stat span {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 800;
  color: var(--ink-soft);
}

.shop-context-compact .mini-stat strong {
  display: block;
  margin-top: 4px;
  font-size: 1rem;
  font-weight: 800;
  color: var(--ink);
}

.shop-context-compact-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}

[data-theme="dark"] .shop-context-compact {
  background:
    radial-gradient(circle at top right, rgba(96, 165, 250, 0.1), transparent 32%),
    linear-gradient(135deg, rgba(15, 23, 42, 0.98) 0, rgba(9, 15, 26, 0.98) 100%);
}

[data-theme="dark"] .shop-context-compact-copy h1,
[data-theme="dark"] .shop-context-compact-copy .eyebrow,
[data-theme="dark"] .shop-context-compact .mini-stat strong,
[data-theme="dark"] .shop-context-compact .mini-stat span {
  color: #f8fafc;
}

[data-theme="dark"] .shop-context-compact-copy .muted {
  color: rgba(219, 231, 245, 0.82);
}

[data-theme="dark"] .shop-context-compact .mini-stat {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(148, 163, 184, 0.16);
}

[data-theme="dark"] .shop-product-stage,
[data-theme="dark"] .shop-product-purchase-card,
[data-theme="dark"] .shop-product-specs > div,
[data-theme="dark"] .portal-insights-hero,
[data-theme="dark"] .portal-files-hero,
[data-theme="dark"] .portal-po-hero {
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.96) 0, rgba(9, 15, 26, 0.98) 100%);
  border-color: rgba(148, 163, 184, 0.18);
}

[data-theme="dark"] .shop-product-copy h1,
[data-theme="dark"] .shop-product-topline span,
[data-theme="dark"] .shop-product-price-primary strong,
[data-theme="dark"] .shop-product-price-meta strong,
[data-theme="dark"] .shop-product-specs strong {
  color: #f8fafc;
}

[data-theme="dark"] .shop-product-topline,
[data-theme="dark"] .shop-product-price-primary span,
[data-theme="dark"] .shop-product-price-meta span,
[data-theme="dark"] .shop-product-specs span {
  color: rgba(219, 231, 245, 0.72);
}

[data-theme="dark"] .shop-product-thumb {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(148, 163, 184, 0.18);
}

[data-theme="dark"] .shop-detail-tab {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(148, 163, 184, 0.18);
  color: #e5edf8;
}

[data-theme="dark"] .shop-detail-tab.active {
  background: #f8fafc;
  border-color: #f8fafc;
  color: #09111f;
}

.shop-fast-order-strip {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(280px, 0.85fr);
  gap: 16px;
  align-items: start;
}

.shop-quick-order-form {
  display: grid;
  gap: 12px;
  padding: 16px 18px;
  border-radius: 20px;
  border: 1px solid var(--line-soft);
  background: rgba(255, 255, 255, 0.72);
}

.shop-quick-order-form h3,
.shop-reorder-card h3 {
  margin: 4px 0 2px;
  font-size: 18px;
}

.shop-quick-order-form textarea {
  min-height: 110px;
  resize: vertical;
}

.shop-reorder-card {
  display: grid;
  gap: 12px;
  padding: 16px 18px;
  border-radius: 20px;
  border: 1px solid var(--line-soft);
  background: linear-gradient(180deg, #ffffff 0, #f7fbff 100%);
}

.shop-reorder-list {
  display: grid;
  gap: 10px;
}

.shop-reorder-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid var(--line-soft);
  background: rgba(255, 255, 255, 0.84);
}

.shop-reorder-row strong {
  display: block;
}

.shop-step-strip {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.shop-step {
  display: inline-grid;
  grid-template-columns: 32px auto;
  gap: 10px;
  align-items: center;
  padding: 10px 14px;
  border-radius: 16px;
  background: #f4f7fb;
  border: 1px solid var(--line-soft);
}

.shop-step span {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: #fff;
  border: 1px solid var(--line-soft);
  font-size: 12px;
  font-weight: 800;
}

.shop-step strong {
  font-size: 13px;
}

.shop-step.is-active {
  background: #0f172a;
  border-color: #0f172a;
  color: #fff;
}

.shop-step.is-active span {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.15);
  color: #fff;
}

.shop-step.is-complete {
  background: rgba(15, 118, 110, 0.08);
  border-color: rgba(15, 118, 110, 0.16);
}

.shop-filter-bar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 18px 20px;
  border-radius: 28px;
  border: 1px solid var(--line-soft);
  background: linear-gradient(180deg, #fbfdff 0, #f6fafe 100%);
}

.filter-main {
  display: grid;
  grid-template-columns: minmax(260px, 1.35fr) minmax(190px, 0.65fr) minmax(210px, 0.75fr);
  gap: 12px;
  align-items: center;
}

.shop-filter-bar input,
.shop-filter-bar select {
  min-height: 68px;
  padding: 0 20px;
  border-radius: 22px;
  border: 1px solid #d7e3f0;
  background: #fff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
  font-size: 18px;
  font-weight: 700;
  color: var(--ink);
}

.shop-filter-bar input::placeholder {
  color: #9aa7b7;
  font-weight: 600;
}

.shop-filter-bar select {
  appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, #506176 50%),
    linear-gradient(135deg, #506176 50%, transparent 50%);
  background-position:
    calc(100% - 26px) calc(50% - 4px),
    calc(100% - 18px) calc(50% - 4px);
  background-size: 8px 8px, 8px 8px;
  background-repeat: no-repeat;
  padding-right: 52px;
}

.filter-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: nowrap;
  justify-content: flex-end;
}

.shop-filter-bar .filter-actions .primary-btn {
  min-height: 68px;
  padding: 0 28px;
  border-radius: 22px;
  font-size: 18px;
}

.shop-filter-bar .filter-actions .muted {
  font-size: 16px;
  font-weight: 700;
  white-space: nowrap;
}

.shop-catalog-toolbar {
  margin-top: 16px;
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}

.shop-catalog-toolbar-group {
  display: inline-flex;
  align-items: end;
  gap: 10px;
}

.shop-catalog-toolbar-group label {
  display: grid;
  gap: 6px;
}

.shop-catalog-toolbar-group label span {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
  font-weight: 800;
}

.shop-catalog-toolbar-group select {
  min-height: 48px;
  padding: 0 16px;
  border-radius: 16px;
  border: 1px solid #d7e3f0;
  background: #fff;
  color: var(--ink);
  font-weight: 700;
}

.shop-view-mode-group {
  align-items: center;
  padding: 4px;
  border-radius: 20px;
  border: 1px solid #d9e4f0;
  background: linear-gradient(180deg, #ffffff 0, #f4f8ff 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.shop-view-toggle {
  width: 52px;
  min-width: 52px;
  min-height: 46px;
  padding: 0;
  border: 0;
  border-radius: 16px;
  background: transparent;
  color: var(--ink-soft);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 140ms ease, color 140ms ease, box-shadow 140ms ease, transform 140ms ease;
}

.shop-view-toggle svg {
  width: 22px;
  height: 22px;
  display: block;
  fill: currentColor;
}

.shop-view-toggle:hover {
  color: var(--ink);
  background: rgba(15, 118, 110, 0.08);
}

.shop-view-toggle.is-active {
  background: linear-gradient(180deg, #f5f1ff 0, #e8e5ff 100%);
  color: #5648d8;
  box-shadow: 0 6px 16px rgba(86, 72, 216, 0.18);
}

.shop-catalog-toolbar-summary {
  color: var(--ink-soft);
  font-weight: 700;
}

.shop-category-strip {
  background: linear-gradient(180deg, #ffffff 0, #f7fbff 100%);
}

.shop-category-pills {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.shop-active-filters {
  margin-top: 14px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

.category-pill {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  background: #f4f7fb;
  border: 1px solid var(--line-soft);
  color: var(--ink);
  font-weight: 700;
}

.category-pill.active {
  background: #0f172a;
  color: #fff;
  border-color: #0f172a;
}

.catalog-meta-row {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin: 8px 0 10px;
  color: var(--ink-soft);
  font-size: 12px;
}

.catalog-meta-row span {
  padding: 6px 9px;
  border-radius: 999px;
  background: #f3f7fb;
  border: 1px solid var(--line-soft);
}

.shop-card-action {
  display: inline-flex;
  justify-content: center;
  width: 100%;
  margin-top: 12px;
}

.shop-card-icon-action {
  width: 52px;
  min-width: 52px;
  padding: 0;
  aspect-ratio: 1;
  justify-self: end;
}

.shop-card-quickview-corner {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 2;
  width: 48px;
  min-width: 48px;
  min-height: 48px;
  margin-top: 0;
  border-radius: 16px;
  border-color: rgba(210, 220, 232, 0.95);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
}

.shop-card-icon-eye {
  width: 22px;
  height: 22px;
  display: inline-flex;
}

.shop-card-icon-eye svg {
  width: 100%;
  height: 100%;
  fill: currentColor;
}

.catalog-list {
  grid-template-columns: 1fr;
}

.catalog-list .catalog-card {
  grid-template-columns: 240px minmax(0, 1fr);
  grid-template-rows: none;
}

.catalog-list .catalog-card-image {
  min-height: 100%;
}

.catalog-list .catalog-card-body {
  display: grid;
  align-content: start;
}

.shop-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
}

.shop-pagination-pages {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.shop-pagination-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  min-height: 44px;
  padding: 0 12px;
  border-radius: 14px;
  border: 1px solid var(--line-soft);
  background: #fff;
  color: var(--ink);
  font-weight: 800;
}

.shop-pagination-link.is-active {
  background: #0f172a;
  border-color: #0f172a;
  color: #fff;
}

.shop-pagination-ellipsis {
  color: var(--ink-soft);
  font-weight: 800;
}

.ghost-btn.is-disabled {
  pointer-events: none;
  opacity: 0.45;
}

.catalog-card {
  border-radius: 24px;
  overflow: hidden;
  background: linear-gradient(180deg, #ffffff 0, #f9fbff 100%);
  border: 1px solid var(--line-soft);
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.05);
  position: relative;
  display: grid;
  grid-template-rows: auto 1fr;
}

.catalog-card-image-shell {
  position: relative;
  min-height: 220px;
}

.catalog-card-image {
  min-height: 220px;
  max-height: 220px;
  background: #fff;
  overflow: hidden;
  align-items: center;
  justify-items: center;
  padding: 18px;
}

.catalog-card-image img {
  display: block;
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 180px;
  object-fit: contain;
  object-position: center center;
  margin: auto;
}

.catalog-card-body {
  padding: 18px 18px 20px;
  display: grid;
  gap: 10px;
  align-content: start;
  position: relative;
  z-index: 1;
}

.catalog-card-body h3 {
  margin: 0;
  font-size: 22px;
  line-height: 1.08;
}

.catalog-card-pricing strong {
  font-size: 24px;
  letter-spacing: -0.04em;
}

.shop-card-buy-row {
  display: grid;
  grid-template-columns: 110px minmax(0, 1fr);
  gap: 10px;
  align-items: end;
}

.shop-related-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.shop-related-card {
  display: grid;
  grid-template-rows: 210px auto;
  border: 1px solid var(--line-soft);
  border-radius: 24px;
  overflow: hidden;
  background: linear-gradient(180deg, #ffffff 0, #f9fbff 100%);
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.05);
}

.shop-related-image {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 22px;
  background: #fff;
  min-height: 210px;
  overflow: hidden;
}

.shop-related-image img {
  display: block;
  width: auto;
  height: auto;
  max-width: 84%;
  max-height: 84%;
  object-fit: contain;
  object-position: center center;
  margin: auto;
  flex: 0 0 auto;
}

.shop-related-image.is-empty {
  color: var(--ink-soft);
  font-weight: 700;
}

.shop-related-body {
  display: grid;
  gap: 8px;
  padding: 16px 18px 18px;
  align-content: start;
}

.shop-related-brand {
  margin: 0;
  color: #0f766e;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.shop-related-body h3 {
  margin: 0;
  font-size: 18px;
  line-height: 1.18;
}

.shop-related-body h3 a {
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.shop-related-meta {
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  color: var(--ink-soft);
  font-size: 13px;
  font-weight: 700;
}

.shop-related-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: #f4f7fb;
}

@media (max-width: 1200px) {
  .shop-related-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .shop-related-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .shop-related-grid {
    grid-template-columns: 1fr;
  }
}

.inline-field {
  display: grid;
  gap: 6px;
}

.inline-field .form-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
  font-weight: 800;
}

.shop-product-hero {
  align-items: start;
}

.shop-product-page {
  padding: 28px 30px;
}

.shop-product-breadcrumbs {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  color: var(--ink-soft);
  font-weight: 700;
}

.shop-product-breadcrumbs strong {
  color: var(--ink);
}

.shop-product-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.98fr) minmax(340px, 0.82fr);
  gap: 28px;
  align-items: start;
}

.shop-product-gallery,
.shop-product-copy {
  display: grid;
  gap: 16px;
}

.shop-product-toolbar {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.shop-product-stage {
  min-height: 520px;
  padding: 28px;
  border-radius: 28px;
  border: 1px solid var(--line-soft);
  background: #fff;
  display: grid;
  place-items: center;
}

.shop-product-stage-link {
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center;
}

.shop-product-stage img {
  width: 100%;
  max-height: 460px;
  object-fit: contain;
}

.shop-product-stage.is-empty {
  color: var(--ink-soft);
}

.shop-product-thumb-strip {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.shop-product-thumb {
  width: 82px;
  height: 82px;
  padding: 0;
  border-radius: 18px;
  border: 1px solid var(--line-soft);
  background: #fff;
  overflow: hidden;
  display: grid;
  place-items: center;
  cursor: pointer;
}

.shop-product-thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.shop-product-thumb.is-active {
  border-color: rgba(15, 118, 110, 0.3);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
}

.shop-product-copy h1 {
  margin: 0;
  font-size: clamp(36px, 4vw, 56px);
  line-height: 0.98;
  letter-spacing: -0.05em;
}

.shop-product-topline {
  margin: -4px 0 2px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  color: var(--ink-soft);
  font-weight: 700;
}

.shop-product-topline span {
  color: var(--ink);
}

.shop-product-purchase-card {
  display: grid;
  gap: 14px;
  padding: 20px 22px;
  border-radius: 24px;
  border: 1px solid var(--line-soft);
  background: linear-gradient(180deg, #ffffff 0, #f8fbff 100%);
  position: sticky;
  top: 104px;
}

.shop-product-price-stack {
  display: grid;
  gap: 14px;
}

.shop-product-price-primary span,
.shop-product-price-meta span,
.shop-product-specs span {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  font-weight: 800;
  color: var(--ink-soft);
}

.shop-product-price-primary strong {
  display: block;
  margin-top: 6px;
  font-size: 40px;
  line-height: 1;
  letter-spacing: -0.05em;
}

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

.shop-product-price-meta strong,
.shop-product-specs strong {
  display: block;
  margin-top: 5px;
  color: var(--ink);
}

.shop-product-price-rule {
  padding-top: 2px;
}

.shop-product-price-rule span {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  font-weight: 800;
  color: var(--ink-soft);
}

.shop-product-price-rule strong {
  display: block;
  margin-top: 5px;
  color: var(--ink);
  font-size: 18px;
  line-height: 1.35;
}

.shop-product-specs {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.shop-product-specs > div {
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid var(--line-soft);
  background: rgba(255, 255, 255, 0.72);
}

.shop-detail-tabs {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.shop-detail-tab {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid var(--line-soft);
  background: #f4f7fb;
  color: var(--ink);
  font-weight: 700;
}

.shop-detail-tab.active {
  background: #0f172a;
  border-color: #0f172a;
  color: #fff;
}

.portal-insights-hero,
.portal-files-hero,
.portal-po-hero {
  background:
    radial-gradient(circle at top right, rgba(96, 165, 250, 0.08), transparent 34%),
    linear-gradient(180deg, #ffffff 0, #f8fbff 100%);
}

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

.portal-po-head-actions {
  align-items: center;
}

.portal-po-items-table td {
  vertical-align: top;
}

.portal-po-item-action {
  width: 1%;
  white-space: nowrap;
  text-align: right;
}

.portal-po-reorder-btn {
  min-width: 116px;
  justify-content: center;
}

.shop-kpi.shop-kpi-success {
  background: linear-gradient(180deg, #effaf2 0, #e5f7ea 100%);
}

.shop-kpi.shop-kpi-success strong,
.shop-kpi.shop-kpi-success span {
  color: #1f7a38;
}

.shop-kpi.shop-kpi-info {
  background: linear-gradient(180deg, #eef5ff 0, #e6f0ff 100%);
}

.shop-kpi.shop-kpi-info strong,
.shop-kpi.shop-kpi-info span {
  color: #1d4ed8;
}

.shop-kpi.shop-kpi-warm {
  background: linear-gradient(180deg, #fff7ec 0, #fff1dd 100%);
}

.shop-kpi.shop-kpi-warm strong,
.shop-kpi.shop-kpi-warm span {
  color: #b45309;
}

.shop-kpi.shop-kpi-danger {
  background: linear-gradient(180deg, #fff0ef 0, #fee9e7 100%);
}

.shop-kpi.shop-kpi-danger strong,
.shop-kpi.shop-kpi-danger span {
  color: #b42318;
}

.portal-inline-filters {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(110px, 150px) auto;
  gap: 12px;
  align-items: end;
}

.portal-inline-filter {
  display: grid;
  gap: 8px;
}

.portal-inline-filter span {
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
}

.portal-po-link {
  font-weight: 800;
}

.portal-two-column {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(300px, 0.65fr);
  gap: 18px;
  align-items: start;
}

.portal-record-meta.portal-record-meta-stack {
  grid-template-columns: repeat(1, minmax(0, 1fr));
}

.portal-record-list-tight {
  gap: 12px;
}

.portal-po-summary-grid {
  gap: 14px;
}

.portal-po-summary-grid > div {
  padding: 12px 14px;
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  background: #fbfdff;
}

.portal-po-summary-grid > div strong {
  display: block;
  margin-top: 4px;
}

[data-theme="dark"] .shop-kpi.shop-kpi-success {
  background: rgba(34, 197, 94, 0.14);
}

[data-theme="dark"] .shop-kpi.shop-kpi-success strong,
[data-theme="dark"] .shop-kpi.shop-kpi-success span {
  color: #86efac;
}

[data-theme="dark"] .shop-kpi.shop-kpi-info {
  background: rgba(59, 130, 246, 0.16);
}

[data-theme="dark"] .shop-kpi.shop-kpi-info strong,
[data-theme="dark"] .shop-kpi.shop-kpi-info span {
  color: #93c5fd;
}

[data-theme="dark"] .shop-kpi.shop-kpi-warm {
  background: rgba(245, 158, 11, 0.16);
}

[data-theme="dark"] .shop-kpi.shop-kpi-warm strong,
[data-theme="dark"] .shop-kpi.shop-kpi-warm span {
  color: #fcd34d;
}

[data-theme="dark"] .shop-kpi.shop-kpi-danger {
  background: rgba(239, 68, 68, 0.15);
}

[data-theme="dark"] .shop-kpi.shop-kpi-danger strong,
[data-theme="dark"] .shop-kpi.shop-kpi-danger span {
  color: #fca5a5;
}

[data-theme="dark"] .portal-inline-filter span {
  color: rgba(226, 232, 240, 0.7);
}

[data-theme="dark"] .portal-po-summary-grid > div {
  background: rgba(15, 23, 42, 0.58);
  border-color: rgba(148, 163, 184, 0.22);
}

[data-theme="dark"] .shop-filter-bar {
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.82) 0, rgba(15, 23, 42, 0.68) 100%);
  border-color: rgba(148, 163, 184, 0.16);
}

[data-theme="dark"] .shop-filter-bar input,
[data-theme="dark"] .shop-filter-bar select {
  background-color: rgba(15, 23, 42, 0.92);
  border-color: rgba(148, 163, 184, 0.18);
  color: #e5edf8;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

[data-theme="dark"] .shop-filter-bar input::placeholder {
  color: rgba(203, 213, 225, 0.62);
}

[data-theme="dark"] .shop-filter-bar select {
  background-image:
    linear-gradient(45deg, transparent 50%, #c9d5e6 50%),
    linear-gradient(135deg, #c9d5e6 50%, transparent 50%);
}

[data-theme="dark"] .shop-catalog-toolbar-group select,
[data-theme="dark"] .shop-pagination-link {
  background: rgba(15, 23, 42, 0.88);
  border-color: rgba(148, 163, 184, 0.18);
  color: #e5edf8;
}

[data-theme="dark"] .shop-view-mode-group {
  background: rgba(255, 255, 255, 0.04);
  border-color: rgba(148, 163, 184, 0.18);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

[data-theme="dark"] .shop-view-toggle {
  color: rgba(219, 231, 245, 0.78);
}

[data-theme="dark"] .shop-view-toggle:hover {
  color: #fff;
  background: rgba(142, 227, 214, 0.12);
}

[data-theme="dark"] .shop-view-toggle.is-active,
[data-theme="dark"] .shop-pagination-link.is-active {
  background: #8ee3d6;
  border-color: #8ee3d6;
  color: #10203f;
}

.shop-product-badges {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin: 14px 0;
}

.shop-product-summary {
  margin-top: 0;
}

.shop-public-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

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

.shop-buying-note {
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid var(--line-soft);
  background: rgba(255, 255, 255, 0.76);
}

.shop-buying-note span {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 800;
  color: var(--ink-soft);
}

.shop-buying-note strong {
  display: block;
  margin-top: 6px;
  font-size: 15px;
}

.shop-buy-box {
  display: grid;
  grid-template-columns: minmax(150px, 180px) minmax(0, 1fr);
  gap: 12px;
  align-items: end;
}

.shop-buy-box .form-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
  font-weight: 800;
}

.shop-product-description {
  background: linear-gradient(180deg, #ffffff 0, #fafcff 100%);
}

.shop-cart-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(340px, 0.75fr);
  gap: 20px;
  align-items: stretch;
}

.shop-cart-hero--single {
  grid-template-columns: 1fr;
}

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

.shop-checklist {
  display: grid;
  gap: 10px;
  margin-bottom: 16px;
}

.shop-checklist-item {
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid var(--line-soft);
}

.shop-checklist-item strong {
  font-size: 13px;
}

.shop-checklist-item span {
  color: var(--ink-soft);
  font-size: 13px;
}

.shop-checklist-item.done {
  background: rgba(15, 118, 110, 0.08);
  border-color: rgba(15, 118, 110, 0.16);
}

.shop-cart-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
  gap: 18px;
  align-items: start;
}

.shop-cart-accelerators {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.9fr);
  gap: 18px;
  align-items: start;
}

.shop-checkout-panel {
  position: sticky;
  top: 92px;
}

.shop-order-sheet {
  display: grid;
  gap: 18px;
}

.shop-order-sheet > .section-head {
  margin-bottom: -2px;
}

.cart-line-list {
  display: grid;
  gap: 14px;
}

.cart-line-list--sheet {
  gap: 12px;
}

.cart-line {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(280px, 0.85fr);
  gap: 16px;
  padding: 16px;
  border: 1px solid var(--line-soft);
  border-radius: 22px;
  background: linear-gradient(180deg, #ffffff 0, #f9fcff 100%);
  box-shadow: 0 14px 26px rgba(15, 23, 42, 0.05);
}

.cart-line-main {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.cart-line-image {
  height: 92px;
  border-radius: 18px;
  border: 1px solid var(--line-soft);
  overflow: hidden;
  background:
    radial-gradient(circle at top left, rgba(15,118,110,0.12), transparent 30%),
    linear-gradient(180deg, #f9fcfe 0, #edf4f8 100%);
  display: grid;
  place-items: center;
}

.cart-line-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.cart-line-copy h3 {
  margin: 0 0 6px;
  font-size: 19px;
}

.cart-line-meta {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 10px;
}

.cart-line-side {
  display: grid;
  gap: 12px;
  align-content: start;
}

.cart-price-stack {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.cart-price-stack div {
  padding: 12px 14px;
  border-radius: 16px;
  background: #f8fbfd;
  border: 1px solid var(--line-soft);
}

.cart-price-stack span {
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
  font-weight: 800;
}

.cart-price-stack strong {
  display: block;
  margin-top: 6px;
  font-size: 17px;
}

.cart-line-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: end;
}

.cart-line-remove {
  justify-self: start;
}

.shop-checkout-panel {
  background:
    radial-gradient(circle at top right, rgba(96, 165, 250, 0.14), transparent 28%),
    linear-gradient(180deg, #ffffff 0, #f8fbff 100%);
}

.shop-order-table .cart-line-image {
  width: 72px;
  height: 72px;
}

.shop-order-qty-form {
  display: grid;
  grid-template-columns: 92px auto;
  gap: 8px;
  align-items: center;
}

.shop-order-item-copy {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.shop-order-item-copy strong,
.shop-order-item-copy a {
  color: var(--ink);
  text-decoration: none;
}

.shop-order-item-copy a:hover {
  text-decoration: underline;
}

.shop-order-remove-form {
  display: flex;
  justify-content: flex-end;
}

.shop-order-totals {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.shop-order-sheet-summary {
  width: min(100%, 640px);
  margin-left: auto;
  display: grid;
  gap: 0;
  padding-top: 4px;
}

.shop-order-sheet-summary-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 14px 0;
  border-top: 1px solid var(--line-soft);
}

.shop-order-sheet-summary-row:first-child {
  border-top: 0;
}

.shop-order-sheet-summary-row span {
  font-size: 16px;
  color: var(--ink-soft);
  font-weight: 600;
}

.shop-order-sheet-summary-row strong {
  font-size: 24px;
  color: var(--ink);
}

.shop-order-sheet-summary-row--total span,
.shop-order-sheet-summary-row--total strong {
  color: #cf3b2c;
  font-weight: 800;
}

.shop-checkout-sections {
  display: grid;
  gap: 14px;
}

.shop-checkout-sections--full {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.shop-checkout-block {
  display: grid;
  gap: 12px;
  padding: 16px;
  border-radius: 18px;
  border: 1px solid var(--line-soft);
  background: rgba(255, 255, 255, 0.72);
}

.shop-checkout-block h3 {
  margin: 0;
  font-size: 16px;
}

.shop-checkout-sheet-block {
  padding: 0 0 4px;
}

.shop-checkout-sheet-block h3 {
  margin: 0;
  font-size: 1.45rem;
}

.shop-checkout-sheet-actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding-top: 8px;
}

[data-theme="dark"] .shop-quick-order-form,
[data-theme="dark"] .shop-reorder-card,
[data-theme="dark"] .shop-reorder-row,
[data-theme="dark"] .catalog-card,
[data-theme="dark"] .portal-record-card,
[data-theme="dark"] .soft-list-row,
[data-theme="dark"] .shop-buying-note,
[data-theme="dark"] .cart-line {
  background: rgba(15, 23, 42, 0.92);
  border-color: rgba(148, 163, 184, 0.18);
}

[data-theme="dark"] .shop-reorder-row strong {
  color: #f8fafc;
}

[data-theme="dark"] .portal-record-topline strong,
[data-theme="dark"] .portal-record-meta strong,
[data-theme="dark"] .shop-product-breadcrumbs strong,
[data-theme="dark"] .catalog-card-body h3,
[data-theme="dark"] .catalog-card-pricing strong,
[data-theme="dark"] .shop-buying-note strong {
  color: #f8fafc;
}

[data-theme="dark"] .portal-record-meta span,
[data-theme="dark"] .soft-list-row .table-subline,
[data-theme="dark"] .shop-product-breadcrumbs,
[data-theme="dark"] .shop-buying-note span {
  color: rgba(219, 231, 245, 0.72);
}

[data-theme="dark"] .soft-list-row strong,
[data-theme="dark"] .soft-list-row .mini-chip,
[data-theme="dark"] .soft-list-row .text-right {
  color: #f8fafc;
}

[data-theme="dark"] .catalog-card-image,
[data-theme="dark"] .shop-checklist-item,
[data-theme="dark"] .shop-checkout-block,
[data-theme="dark"] .cart-price-stack div {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(148, 163, 184, 0.16);
}

[data-theme="dark"] .catalog-meta-row span {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(148, 163, 184, 0.16);
  color: rgba(219, 231, 245, 0.82);
}

[data-theme="dark"] .shop-order-sheet-summary-row {
  border-color: rgba(148, 163, 184, 0.16);
}

[data-theme="dark"] .shop-order-sheet-summary-row span {
  color: rgba(219, 231, 245, 0.76);
}

[data-theme="dark"] .shop-order-sheet-summary-row strong {
  color: #f8fafc;
}

[data-theme="dark"] .shop-order-sheet-summary-row--total span,
[data-theme="dark"] .shop-order-sheet-summary-row--total strong {
  color: #fca5a5;
}

[data-theme="dark"] .shop-order-item-copy strong,
[data-theme="dark"] .shop-order-item-copy a {
  color: #f8fafc;
}

.shop-quick-view-modal {
  width: min(980px, calc(100vw - 1rem));
  max-height: none;
  margin: auto 0;
  overflow: visible;
}

.shop-quick-view-modal .perfex-modal-body {
  overflow: visible;
  max-height: none;
}

.shop-quick-view-modal.is-public .shop-quick-view-cart-form {
  display: none !important;
}

.shop-quick-view-grid {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(320px, 1fr);
  gap: 1.5rem;
  align-items: start;
}

.shop-quick-view-image {
  min-height: 320px;
  border: 1px solid var(--line-soft);
  border-radius: 22px;
  background: #ffffff;
  display: grid;
  place-items: center;
  overflow: hidden;
  padding: 1.25rem;
}

.shop-quick-view-image img {
  width: 100%;
  height: 100%;
  max-height: 420px;
  object-fit: contain;
  display: block;
}

.shop-quick-view-image.is-empty {
  color: var(--ink-soft);
  background: #ffffff;
}

.shop-quick-view-thumbs {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 14px;
}

.shop-quick-view-thumb {
  width: 68px;
  height: 68px;
  border-radius: 16px;
  border: 1px solid var(--line-soft);
  background: #fff;
  display: grid;
  place-items: center;
  padding: 8px;
  cursor: pointer;
  transition: transform 140ms ease, border-color 140ms ease, box-shadow 140ms ease;
}

.shop-quick-view-thumb:hover,
.shop-quick-view-thumb.is-active {
  border-color: rgba(31, 126, 114, 0.45);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
  transform: translateY(-1px);
}

.shop-quick-view-thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

.shop-quick-view-copy {
  display: grid;
  gap: 1rem;
  align-content: start;
}

.shop-quick-view-summary {
  max-width: 34ch;
  font-size: 1.02rem;
  line-height: 1.7;
}

.shop-quick-view-tools {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.shop-quick-view-guest-note {
  display: grid;
  gap: 12px;
  align-content: start;
}

.shop-quick-view-price {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.shop-quick-view-price strong {
  font-size: 2.35rem;
  line-height: 1;
  color: var(--ink);
}

.shop-quick-view-price span {
  color: var(--ink-soft);
  font-weight: 700;
}

.shop-quick-view-cart-form {
  display: flex;
  align-items: end;
  gap: 1rem;
  flex-wrap: wrap;
}

.shop-quick-view-cart-form[hidden],
.shop-quick-view-guest-note[hidden] {
  display: none !important;
}

.shop-quick-view-cart-form .inline-field {
  min-width: 120px;
}

[data-theme="dark"] .shop-quick-view-image {
  background: #ffffff;
  border-color: rgba(148, 163, 184, 0.18);
}

[data-theme="dark"] .shop-quick-view-thumb {
  background: #ffffff;
  border-color: rgba(148, 163, 184, 0.18);
}

[data-theme="dark"] .shop-card-quickview-corner {
  background: rgba(15, 23, 42, 0.9);
  border-color: rgba(148, 163, 184, 0.2);
  color: #e2e8f0;
}

[data-theme="dark"] .shop-quick-view-price strong {
  color: #f8fafc;
}

@media (max-width: 900px) {
  .perfex-modal-shell {
    padding: 12px 10px;
  }

  .shop-quick-view-grid {
    grid-template-columns: 1fr;
  }

  .shop-product-toolbar,
  .shop-quick-view-tools,
  .catalog-card-actions {
    justify-content: stretch;
  }

  .shop-quick-view-image {
    min-height: 240px;
  }

  .shop-quick-view-price strong {
    font-size: 1.75rem;
  }

  .portal-record-card,
  .portal-record-meta,
  .shop-buying-notes,
  .shop-product-specs,
  .shop-product-price-meta,
  .cart-price-stack {
    grid-template-columns: 1fr;
  }

  .shop-order-qty-form {
    grid-template-columns: 1fr;
  }

  .portal-record-actions {
    justify-self: start;
    text-align: left;
  }
}

@media (max-width: 1180px) {
  .app-shell {
    padding-left: 0;
  }

  .mobile-nav-backdrop {
    display: block;
    position: fixed;
    inset: 0;
    border: 0;
    padding: 0;
    background: rgba(15, 23, 42, 0.48);
    opacity: 0;
    pointer-events: none;
    transition: opacity 160ms ease;
    z-index: 34;
  }

  .mobile-nav-toggle {
    width: 48px;
    height: 48px;
    border-radius: 16px;
    border: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.96);
    box-shadow: var(--shadow);
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    cursor: pointer;
    flex: 0 0 auto;
  }

  .mobile-nav-toggle span {
    width: 18px;
    height: 2px;
    border-radius: 999px;
    background: var(--ink);
  }

  .sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    width: min(82vw, 320px);
    height: 100vh;
    min-height: 100vh;
    z-index: 35;
    padding: 22px 18px;
    gap: 18px;
    transform: translateX(-104%);
    transition: transform 180ms ease;
    box-shadow: 0 28px 56px rgba(15, 23, 42, 0.28);
  }

  .sidebar-scroll {
    overflow-y: auto;
    overscroll-behavior: contain;
    padding-right: 0;
  }

  .app-shell.mobile-nav-open .mobile-nav-backdrop {
    opacity: 1;
    pointer-events: auto;
  }

  .app-shell.mobile-nav-open .sidebar {
    transform: translateX(0);
  }

  .workspace-topbar {
    padding-top: 18px;
  }
}

@media (max-width: 900px) {
  .page-shell {
    width: min(100% - 18px, 1380px);
  }

  .stats-grid,
  .compact-grid,
  .info-grid,
  .split-grid,
  .help-article-layout,
  .help-article-support-grid,
  .form-row,
  .queue-grid,
  .catalog-admin-grid,
  .catalog-grid,
  .catalog-grid.compact,
  .featured-strip,
  .media-strip,
  .property-grid,
  .catalog-pricing-band,
  .product-admin-pricing,
  .product-admin-meta,
  .product-admin-actions,
  .category-summary-grid,
  .backlog-grid,
  .product-hero,
  .catalog-detail-hero,
  .product-admin-card,
  .shop-context-grid,
  .shop-hero-grid,
  .shop-context-compact-main,
  .shop-fast-order-strip,
  .shop-filter-bar,
  .filter-main,
  .shop-catalog-toolbar,
  .shop-product-layout,
  .shop-step-strip,
  .shop-card-buy-row,
  .shop-buy-box,
  .shop-cart-hero,
  .shop-cart-layout,
  .shop-cart-accelerators,
  .shop-address-grid,
  .shop-product-price-meta,
  .shop-product-specs,
  .cart-line,
  .cart-line-main,
  .cart-price-stack,
  .cart-line-form,
  .shop-order-totals,
  .shop-kpis,
  .portal-po-kpis,
  .shop-hero-metrics,
  .shop-context-compact-stats,
  .shop-cart-summary,
  .shop-checkout-summary {
    grid-template-columns: 1fr;
  }

  .shop-checkout-sections--full,
  .shop-checkout-sheet-actions {
    grid-template-columns: 1fr;
  }

  .shop-header-inner,
  .shop-context-panel-head,
  .shop-hero-panel-head,
  .section-head,
  .filter-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .shop-nav {
    justify-content: flex-start;
  }

  .filter-main {
    grid-template-columns: 1fr;
  }

  .shop-context-compact {
    flex-direction: column;
    align-items: stretch;
  }

  .shop-context-compact-actions {
    justify-content: flex-start;
  }

  .portal-po-item-action {
    text-align: left;
  }

  .shop-shell {
    width: min(100% - 18px, 1440px);
  }

  .workspace-topbar {
    padding: 18px 18px 10px;
    gap: 12px;
  }

  .topbar-title {
    font-size: 28px;
  }

  .shop-checkout-panel {
    position: static;
  }

  .setup-menu-shell {
    grid-template-columns: 1fr;
  }

  .setup-menu-sidebar {
    border-radius: 20px;
  }

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

  .setup-menu-nav > a {
    min-height: 54px;
    display: flex;
    align-items: center;
  }

  .setup-system-templates-card > .section-head,
  .setup-system-template-group-head {
    flex-direction: column;
    align-items: stretch;
  }

  .setup-system-templates-card > .section-head .button-row,
  .setup-system-template-group-head .button-row {
    flex-wrap: wrap;
  }

  .setup-system-template-group .perfex-table {
    min-width: 760px;
  }

  .setup-saas-summary-grid,
  .setup-saas-plan-grid,
  .setup-saas-metadata-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .setup-saas-quota-grid {
    grid-template-columns: 1fr;
  }

  .catalog-list .catalog-card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .card {
    padding: 18px;
    border-radius: 18px;
  }

  .mobile-nav-toggle {
    width: 44px;
    height: 44px;
    border-radius: 14px;
  }

  .sidebar {
    width: min(88vw, 300px);
    padding: 20px 16px;
  }

  .hero.compact {
    padding: 22px;
  }

  .sidebar-brand .brand {
    font-size: 26px;
  }

  .subbrand {
    font-size: 13px;
  }

  .sidebar-profile-card {
    grid-template-columns: 40px minmax(0, 1fr);
    gap: 10px;
    padding: 10px;
  }

  .sidebar-profile-avatar {
    width: 40px;
    height: 40px;
    font-size: 16px;
  }

  .setup-menu-nav {
    grid-template-columns: 1fr;
  }

  .topbar-main {
    gap: 12px;
  }

  .setup-menu-nav > a,
  .setup-nav-parent,
  .setup-nav-children a {
    padding: 12px 14px;
  }

  .setup-system-template-group-head {
    padding: 16px 16px 0;
  }

  .setup-system-templates-card > .section-head .button-row > *,
  .setup-system-template-group-head .button-row > * {
    flex: 1 1 180px;
  }

  .button-row {
    flex-wrap: wrap;
  }

  .button-row > .light-btn,
  .button-row > .dark-btn,
  .button-row > .primary-btn,
  .button-row > .ghost-btn {
    width: 100%;
    justify-content: center;
  }

  .setup-system-template-group .perfex-table {
    min-width: 680px;
  }

  .setup-saas-summary-grid,
  .setup-saas-plan-grid,
  .setup-saas-metadata-grid {
    grid-template-columns: 1fr;
  }

  .setup-saas-quota-grid {
    grid-template-columns: 1fr;
  }

  .setup-saas-workspace-head,
  .setup-saas-workspace-foot {
    flex-direction: column;
  }

  .setup-saas-badges {
    justify-content: flex-start;
  }

  .perfex-page-head {
    flex-direction: column;
    align-items: stretch;
  }
}

.perfex-page {
  display: grid;
  gap: 16px;
  min-width: 0;
  max-width: 100%;
}

.perfex-page-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 16px;
}

.perfex-page-head h1,
.customer-detail-head {
  margin: 0;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.03em;
}

.perfex-page-link {
  display: inline-block;
  margin-top: 6px;
  color: #3b82f6;
  font-size: 15px;
}

[data-theme="dark"] .perfex-page-link {
  color: color-mix(in srgb, var(--accent-strong) 88%, white 12%);
}

.perfex-stats-row {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
}

.compact-three-stats {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

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

.compact-six-stats {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.perfex-stat {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 16px 18px;
  color: #667085;
  font-size: 14px;
  box-shadow: 0 6px 20px rgba(15, 23, 42, 0.05);
}

.perfex-stat strong {
  color: #111827;
  margin-right: 4px;
}

[data-theme="dark"] .perfex-stat {
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.96) 0, rgba(10, 17, 30, 0.96) 100%);
  border-color: rgba(148, 163, 184, 0.16);
  color: var(--ink-soft);
  box-shadow: 0 12px 28px rgba(2, 6, 23, 0.2);
}

[data-theme="dark"] .perfex-stat strong {
  color: var(--ink);
}

.perfex-stat-success strong { color: #15803d; }
.perfex-stat-danger strong { color: #dc2626; }
.perfex-stat-info strong { color: #2563eb; }

.perfex-actions-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.perfex-primary-actions,
.perfex-toolbar,
.perfex-toolbar-left,
.perfex-toolbar-right {
  display: flex;
  align-items: center;
  gap: 10px;
}

.perfex-toolbar {
  justify-content: space-between;
  flex-wrap: wrap;
  min-width: 0;
  max-width: 100%;
}

.perfex-toolbar-left {
  flex: 0 0 auto;
  flex-wrap: wrap;
  min-width: 0;
  max-width: 100%;
}

.perfex-toolbar-right {
  flex: 1 1 auto;
  justify-content: flex-end;
  min-width: 0;
  max-width: 100%;
  flex-wrap: wrap;
}

.perfex-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 18px 20px;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.05);
  min-width: 0;
  max-width: 100%;
}

[data-theme="dark"] .perfex-card {
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.98) 0, rgba(9, 15, 26, 0.98) 100%);
  border-color: rgba(148, 163, 184, 0.16);
  box-shadow: 0 18px 38px rgba(2, 6, 23, 0.28);
}

.messaging-split-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 14px;
}

.campaign-overview-tabs {
  display: inline-flex;
  gap: 0.7rem;
  padding: 0.35rem;
  border: 1px solid #dbe5f1;
  border-radius: 999px;
  background: #f7fbff;
}

[data-theme="dark"] .campaign-overview-tabs {
  border-color: rgba(148, 163, 184, 0.14);
  background: rgba(148, 163, 184, 0.08);
}

.campaign-overview-tabs a {
  padding: 0.7rem 1rem;
  border-radius: 999px;
  color: #4f6075;
  font-weight: 700;
  text-decoration: none;
}

[data-theme="dark"] .campaign-overview-tabs a {
  color: rgba(219, 231, 245, 0.82);
}

.campaign-overview-tabs a.is-active {
  background: #182235;
  color: #fff;
}

[data-theme="dark"] .campaign-overview-tabs a.is-active {
  background: rgba(255, 255, 255, 0.1);
  color: #fff;
}

.campaign-overview-focus-campaigns {
  grid-template-columns: minmax(320px, 0.8fr) minmax(0, 1.2fr);
}

.campaign-overview-focus-lists {
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
}

.messaging-pane {
  min-width: 0;
}

.messaging-pane-head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 12px;
  margin-bottom: 8px;
}

.messaging-pane-head h2 {
  font-size: 20px;
}

.slim-pagination {
  margin-top: 12px;
}

.po-filter-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px 24px;
}

.po-filter-actions {
  display: flex;
  gap: 10px;
  align-items: end;
}

.po-search-form {
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  gap: 10px;
  width: 100%;
}

.po-detail-form,
.po-left-grid,
.po-right-grid {
  display: grid;
  gap: 16px;
}

.po-detail-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 26px 36px;
}

.po-address-preview {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.po-address-select-hidden {
  display: none !important;
}

.po-number-grid {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 10px;
}

.po-items-toolbar {
  display: grid;
  gap: 14px;
}

.po-items-topline {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 16px;
}

.po-item-picker-row {
  grid-template-columns: minmax(260px, 1fr) auto minmax(260px, 1fr) auto;
  align-items: end;
}

.po-item-picker-buttons {
  align-self: end;
}

.po-quantity-toggle {
  text-align: center;
  color: var(--ink-soft);
  font-size: 14px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
}

.po-quantity-toggle label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.po-items-table textarea,
.po-items-table input {
  width: 100%;
  min-width: 0;
}

.po-main-item-row td {
  background: #fafbfd;
}

.po-dragger {
  width: 28px;
  color: #98a2b3;
  text-align: center;
  white-space: nowrap;
}

.po-item-row-form {
  display: contents;
}

.po-item-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}

.po-icon-btn {
  min-width: 42px;
  padding-inline: 0;
}

.po-amount-cell {
  font-weight: 700;
  white-space: nowrap;
}

.po-totals-grid {
  margin-top: 20px;
  display: grid;
  grid-template-columns: 1fr minmax(320px, 420px);
  gap: 24px;
}

.po-totals-card {
  display: grid;
  gap: 14px;
}

.po-total-row {
  display: grid;
  grid-template-columns: minmax(140px, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 10px 0;
  border-top: 1px solid var(--line-soft);
}

.po-total-edit {
  grid-template-columns: minmax(140px, 1fr) minmax(120px, 180px) auto;
}

.po-total-grand {
  font-size: 18px;
  font-weight: 800;
}

.po-inline-inputs {
  display: grid;
  grid-template-columns: 1fr 60px;
  gap: 8px;
}

.dark-btn,
.light-btn,
.icon-btn {
  border-radius: 10px;
  border: 1px solid transparent;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
}

.dark-btn {
  background: #1f2937;
  color: #fff;
  padding: 11px 16px;
}

.light-btn,
.icon-btn {
  background: #fff;
  color: #344054;
  border-color: var(--line);
  padding: 10px 14px;
}

[data-theme="dark"] .dark-btn {
  background: color-mix(in srgb, var(--accent) 72%, #0f172a 28%);
  color: #07131f;
}

[data-theme="dark"] .light-btn,
[data-theme="dark"] .icon-btn {
  background: rgba(15, 23, 42, 0.9);
  color: var(--ink);
  border-color: rgba(148, 163, 184, 0.16);
}

.icon-btn {
  min-width: 40px;
  text-align: center;
}

.perfex-inline-form select,
.perfex-filter-form input,
.perfex-filter-form select,
.po-search-form input,
.po-search-form select,
.po-filter-grid select,
.perfex-modal-body select,
.profile-form-grid input,
.profile-form-grid select,
.profile-form-grid textarea {
  width: 100%;
  min-height: 48px;
  padding: 11px 14px;
  border: 1px solid #d0d5dd;
  border-radius: 14px;
  background: linear-gradient(180deg, #ffffff 0%, #fcfdff 100%);
  box-shadow: inset 0 1px 2px rgba(16, 24, 40, 0.04);
  font: inherit;
  color: #111827;
}

[data-theme="dark"] .perfex-inline-form select,
[data-theme="dark"] .perfex-filter-form input,
[data-theme="dark"] .perfex-filter-form select,
[data-theme="dark"] .po-search-form input,
[data-theme="dark"] .po-search-form select,
[data-theme="dark"] .po-filter-grid select,
[data-theme="dark"] .perfex-modal-body select,
[data-theme="dark"] .profile-form-grid input,
[data-theme="dark"] .profile-form-grid select,
[data-theme="dark"] .profile-form-grid textarea {
  border-color: rgba(148, 163, 184, 0.18);
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.96) 0%, rgba(10, 17, 30, 0.96) 100%);
  box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.28);
  color: var(--ink);
}

.perfex-inline-form select,
.perfex-filter-form select,
.po-search-form select,
.po-filter-grid select,
.perfex-modal-body select,
.profile-form-grid select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  padding-right: 40px;
  background-image:
    linear-gradient(180deg, #ffffff 0%, #fcfdff 100%),
    linear-gradient(45deg, transparent 50%, #475467 50%),
    linear-gradient(135deg, #475467 50%, transparent 50%);
  background-repeat: no-repeat, no-repeat, no-repeat;
  background-position: 0 0, calc(100% - 18px) 21px, calc(100% - 12px) 21px;
  background-size: auto, 6px 6px, 6px 6px;
}

[data-theme="dark"] .perfex-inline-form select,
[data-theme="dark"] .perfex-filter-form select,
[data-theme="dark"] .po-search-form select,
[data-theme="dark"] .po-filter-grid select,
[data-theme="dark"] .perfex-modal-body select,
[data-theme="dark"] .profile-form-grid select {
  background-image:
    linear-gradient(180deg, rgba(15, 23, 42, 0.96) 0%, rgba(10, 17, 30, 0.96) 100%),
    linear-gradient(45deg, transparent 50%, rgba(219, 231, 245, 0.72) 50%),
    linear-gradient(135deg, rgba(219, 231, 245, 0.72) 50%, transparent 50%);
}

.perfex-filter-form input::placeholder,
.po-search-form input::placeholder {
  color: #98a2b3;
}

[data-theme="dark"] .perfex-filter-form input::placeholder,
[data-theme="dark"] .po-search-form input::placeholder {
  color: rgba(148, 163, 184, 0.72);
}

.form-multiselect {
  position: relative;
  border: 1px solid #d0d5dd;
  border-radius: 10px;
  background: #fff;
}

[data-theme="dark"] .form-multiselect {
  background: rgba(15, 23, 42, 0.92);
  border-color: rgba(148, 163, 184, 0.18);
}

.form-multiselect summary {
  list-style: none;
  cursor: pointer;
  padding: 10px 12px;
  color: #111827;
}

[data-theme="dark"] .form-multiselect summary {
  color: var(--ink);
}

.form-multiselect summary::-webkit-details-marker {
  display: none;
}

.form-multiselect-menu {
  border-top: 1px solid #eaecf0;
  padding: 10px 12px;
  display: grid;
  gap: 8px;
  max-height: 220px;
  overflow-y: auto;
}

[data-theme="dark"] .form-multiselect-menu {
  border-top-color: rgba(148, 163, 184, 0.16);
}

.form-multiselect-menu .checkline {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 10px;
  background: #f8fafc;
  color: #334155;
  font-size: 14px;
  font-weight: 600;
}

[data-theme="dark"] .form-multiselect-menu .checkline {
  background: rgba(148, 163, 184, 0.08);
  color: var(--ink);
}

.form-multiselect-menu .checkline input {
  width: 16px;
  height: 16px;
  margin: 0;
}

.perfex-filter-form {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 10px;
  width: 100%;
  max-width: none;
  min-width: 0;
}

.perfex-filter-form-wide {
  display: grid;
  grid-template-columns: minmax(260px, 1.45fr) repeat(2, minmax(180px, 0.7fr)) auto;
  align-items: end;
  gap: 14px 16px;
}

.perfex-filter-form-wide label {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.perfex-filter-form-wide input,
.perfex-filter-form-wide select {
  min-width: 0;
}

.perfex-filter-actions-row {
  justify-content: flex-start;
  align-self: end;
  gap: 10px;
}

.perfex-filter-form input {
  flex: 1 1 240px;
  min-width: 180px;
}

.perfex-filter-form select,
.po-search-form select {
  flex: 0 1 170px;
  min-width: 140px;
}

.perfex-filter-form .icon-btn,
.perfex-filter-form .light-btn,
.po-search-form .icon-btn,
.po-search-form .light-btn {
  flex: 0 0 auto;
}

.perfex-filter-dropdown {
  position: relative;
}

.perfex-filter-menu {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  min-width: 300px;
  display: none;
  z-index: 40;
  background: #fff;
  border: 1px solid #d0d5dd;
  border-radius: 18px;
  box-shadow: 0 16px 40px rgba(15, 23, 42, 0.16);
  overflow: hidden;
}

[data-theme="dark"] .perfex-filter-menu {
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.98) 0%, rgba(10, 17, 30, 0.98) 100%);
  border-color: rgba(148, 163, 184, 0.18);
  box-shadow: 0 20px 42px rgba(2, 6, 23, 0.34);
}

.perfex-filter-menu.is-open {
  display: block;
}

.perfex-filter-menu-link {
  display: block;
  padding: 16px 20px;
  font-size: 15px;
  font-weight: 600;
  color: #1f2937;
  border-bottom: 1px solid #eef2f6;
}

[data-theme="dark"] .perfex-filter-menu-link {
  color: var(--ink);
  border-bottom-color: rgba(148, 163, 184, 0.12);
}

.perfex-filter-menu-link:last-child {
  border-bottom: 0;
}

.perfex-filter-menu-link:hover {
  background: #f8fafc;
  color: #3559d5;
}

[data-theme="dark"] .perfex-filter-menu-link:hover {
  background: rgba(148, 163, 184, 0.08);
  color: var(--accent-strong);
}

.perfex-filter-menu-button {
  width: 100%;
  border: 0;
  background: #fff;
  text-align: left;
  cursor: pointer;
}

[data-theme="dark"] .perfex-filter-menu-button {
  background: transparent;
}

.perfex-filter-menu-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: stretch;
  border-bottom: 1px solid #eef2f6;
}

[data-theme="dark"] .perfex-filter-menu-row {
  border-bottom-color: rgba(148, 163, 184, 0.12);
}

.perfex-filter-menu-row:last-child {
  border-bottom: 0;
}

.perfex-filter-menu-row .perfex-filter-menu-link {
  border-bottom: 0;
}

.perfex-export-menu {
  min-width: 180px;
}

.perfex-filter-edit-btn {
  min-width: 46px;
  border: 0;
  border-left: 1px solid #eef2f6;
  border-radius: 0;
  background: #fff;
}

[data-theme="dark"] .perfex-filter-edit-btn {
  background: transparent;
  color: var(--ink);
  border-left-color: rgba(148, 163, 184, 0.12);
}

.accounts-filter-modal-actions {
  justify-content: space-between;
}

.perfex-table-wrap {
  margin-top: 14px;
  overflow-x: auto;
  max-width: 100%;
  -webkit-overflow-scrolling: touch;
}

[data-theme="dark"] .perfex-table-wrap {
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, 0.12);
}

.perfex-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

.sortable-header {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  color: #344054;
}

[data-theme="dark"] .sortable-header {
  color: var(--ink);
}

.sortable-header span {
  color: #667085;
  font-size: 12px;
}

[data-theme="dark"] .sortable-header span {
  color: rgba(148, 163, 184, 0.82);
}

.column-picker-modal {
  width: min(720px, calc(100% - 32px));
}

.column-picker-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px 28px;
}

.column-picker-list {
  margin-top: 12px;
  display: grid;
  gap: 10px;
}

.perfex-table th,
.perfex-table td {
  padding: 12px 10px;
  border-top: 1px solid #eaecf0;
  text-align: left;
  vertical-align: top;
}

[data-theme="dark"] .perfex-table th,
[data-theme="dark"] .perfex-table td {
  border-top-color: rgba(148, 163, 184, 0.12);
}

.perfex-table thead th {
  color: #475467;
  font-size: 13px;
  font-weight: 700;
  background: #f8fafc;
  border-top: 0;
}

[data-theme="dark"] .perfex-table thead th {
  color: rgba(219, 231, 245, 0.86);
  background: rgba(148, 163, 184, 0.08);
}

.checkbox-col {
  width: 52px;
  text-align: center;
}

.perfex-table input[type="checkbox"] {
  width: 20px;
  height: 20px;
  margin: 0;
  accent-color: #4f7cff;
  cursor: pointer;
}

.table-row-actions {
  margin-top: 4px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  color: #667085;
}

[data-theme="dark"] .table-row-actions,
[data-theme="dark"] .table-row-actions a,
[data-theme="dark"] .table-action-link,
[data-theme="dark"] .perfex-row-actions {
  color: rgba(148, 163, 184, 0.82);
}

.table-row-actions a,
.table-action-link {
  color: #667085;
  font-size: 12px;
  line-height: 1.3;
}

.table-action-link {
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  font-family: inherit;
}

.table-row-actions a:hover,
.table-action-link:hover {
  color: var(--accent-strong);
}

.perfex-record-link {
  font-weight: 700;
  color: #101828;
}

[data-theme="dark"] .perfex-record-link {
  color: var(--ink);
}

.perfex-row-actions {
  margin-top: 6px;
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  font-size: 11px;
  line-height: 1.25;
  color: #667085;
}

.status-toggle {
  display: inline-block;
  width: 36px;
  height: 20px;
  border-radius: 999px;
  background: #e4e7ec;
  position: relative;
}

.status-toggle::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.18);
}

.status-toggle.on {
  background: #4f7cff;
}

.status-toggle.on::after {
  left: 18px;
}

[data-theme="dark"] .status-toggle {
  background: rgba(148, 163, 184, 0.28);
}

.mini-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 5px 11px;
  margin: 0 6px 6px 0;
  border-radius: 999px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: #f7f9fc;
  color: #344054;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.01em;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

[data-theme="dark"] .mini-chip {
  border-color: rgba(148, 163, 184, 0.18);
  background: rgba(148, 163, 184, 0.12);
  color: var(--ink);
}

.lead-status-chip {
  border: 1px solid color-mix(in srgb, var(--lead-status-color, #3b82f6) 24%, white);
  background: color-mix(in srgb, var(--lead-status-color, #3b82f6) 12%, white);
  color: color-mix(in srgb, var(--lead-status-color, #3b82f6) 72%, black);
  margin: 0;
}

.lead-status-picker {
  position: relative;
  display: inline-block;
}

.lead-status-picker summary {
  list-style: none;
  cursor: pointer;
}

.lead-status-picker summary::-webkit-details-marker {
  display: none;
}

.lead-status-picker[open] .lead-status-chip {
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.12);
}

.lead-status-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  z-index: 40;
  min-width: 180px;
  padding: 8px;
  border: 1px solid var(--line-soft);
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.12);
  display: grid;
  gap: 6px;
}

.lead-status-option {
  display: flex;
  justify-content: flex-start;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
}

.lead-status-option .lead-status-chip {
  width: 100%;
  justify-content: center;
  padding: 8px 10px;
}

.lead-status-option.is-active .lead-status-chip {
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--lead-status-color, #3b82f6) 32%, black);
}

.mini-chip-success {
  border-color: rgba(47, 158, 68, 0.18);
  background: #eaf7ec;
  color: #23753a;
}

.mini-chip-warm {
  border-color: rgba(178, 95, 0, 0.18);
  background: #fff4e5;
  color: #b25f00;
}

.mini-chip-info {
  border-color: rgba(29, 78, 216, 0.18);
  background: #e8f1ff;
  color: #1d4ed8;
}

.mini-chip-imported {
  border-color: rgba(37, 99, 235, 0.16);
  background: linear-gradient(180deg, #eef4ff 0%, #e2ecff 100%);
  color: #2453cf;
}

.mini-chip-new {
  border-color: rgba(14, 116, 144, 0.18);
  background: linear-gradient(180deg, #ebfbff 0%, #dff7ff 100%);
  color: #0f627a;
}

.mini-chip-paused {
  border-color: rgba(180, 83, 9, 0.18);
  background: linear-gradient(180deg, #fff5e8 0%, #ffedcf 100%);
  color: #a04a08;
}

.mini-chip-scheduled {
  border-color: rgba(109, 40, 217, 0.18);
  background: linear-gradient(180deg, #f2ebff 0%, #eadfff 100%);
  color: #6d28d9;
}

.po-email-queue-actions {
  display: flex;
  flex-direction: column;
  gap: 6px;
  align-items: flex-start;
}

.intake-view-document {
  display: grid;
  gap: 18px;
}

.intake-header-meta {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.well-card {
  border: 1px solid var(--line-soft);
  border-radius: 16px;
  padding: 16px;
  background: #f8fbfd;
}

.intake-review-customer-card {
  border-color: #9abdf8;
  box-shadow: inset 0 0 0 1px rgba(59, 130, 246, 0.18);
}

.intake-review-select-block {
  gap: 10px;
}

.intake-review-select-block > span {
  color: #3157df;
  font-size: 0.96rem;
  font-weight: 800;
}

.intake-review-customer-actions {
  display: flex;
  justify-content: flex-end;
}

.intake-review-shell {
  padding: 24px;
}

.intake-review-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.intake-review-title h2 {
  margin: 0;
  font-size: 1.85rem;
}

.intake-review-toolbar {
  justify-content: flex-end;
}

.intake-page-head-actions {
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-end;
}

.intake-page-head-actions > * {
  flex: 0 0 auto;
}

.intake-review-controls {
  margin-top: 18px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.intake-review-controls label span {
  color: #344054;
  font-size: 0.95rem;
  font-weight: 800;
}

.intake-review-address-grid {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  align-items: start;
}

.intake-review-well {
  min-height: 170px;
  background: #f7f9fc;
}

.intake-review-table-wrap {
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  overflow: hidden;
}

.intake-review-table {
  min-width: 1040px;
}

.intake-review-table th {
  background: #f8fafc;
  font-size: 12px;
  letter-spacing: 0.05em;
}

.intake-review-table td {
  vertical-align: top;
}

.intake-review-table tbody tr:nth-child(odd) {
  background: #fffaf9;
}

.intake-review-table tbody tr.review-row-match {
  background: #eefaf1;
}

.intake-review-table tbody tr.review-row-discrepancy {
  background: #fff4f1;
}

.intake-review-table td:nth-child(1) {
  width: 140px;
}

.intake-review-table td:nth-child(2) {
  width: 320px;
}

.intake-review-table td:nth-child(3) {
  width: 70px;
}

.intake-review-table td:nth-child(4),
.intake-review-table td:nth-child(5) {
  width: 120px;
}

.intake-review-table td:nth-child(6) {
  width: 160px;
}

.intake-review-table .intake-discount-chip {
  display: inline-flex;
  align-items: center;
  border-radius: 12px;
  padding: 10px 14px;
  line-height: 1.25;
}

.intake-match-cell {
  display: grid;
  gap: 10px;
}

.intake-match-cell .light-btn {
  white-space: nowrap;
  min-width: 132px;
  justify-content: center;
  align-self: start;
}

.warn-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  padding: 10px 16px;
  border: 1px solid #d4a03b;
  background: #d4a03b;
  color: #fff;
  font-weight: 700;
}

.warn-btn:hover {
  filter: brightness(0.96);
}

.po-review-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

@media (max-width: 1180px) {
  .intake-review-controls,
  .intake-review-address-grid {
    grid-template-columns: 1fr;
  }

  .intake-review-head {
    align-items: stretch;
  }

  .intake-review-toolbar {
    justify-content: flex-start;
  }
}

.perfex-pagination {
  margin-top: 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  color: #667085;
  font-size: 14px;
}

.perfex-pagination-extended {
  display: grid;
  gap: 16px;
  align-items: stretch;
  width: 100%;
  border-top: 1px solid #eaecf0;
  padding-top: 18px;
  margin-top: 18px;
}

.standard-pagination-bar {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) auto;
  align-items: end;
  gap: 18px;
  width: 100%;
}

.standard-pagination-form {
  display: flex;
  align-items: end;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.standard-pagination-form label {
  display: grid;
  gap: 6px;
  min-width: 110px;
}

.standard-pagination-form select,
.standard-pagination-form input {
  min-width: 84px;
  width: 100%;
  padding: 10px 12px;
  border: 1px solid #d0d5dd;
  border-radius: 14px;
  background: #fff;
}

.standard-pagination-links {
  justify-content: flex-start;
  width: 100%;
  flex-wrap: wrap;
}

.standard-pagination-links .ghost-btn.active {
  border-color: #1d4ed8;
  color: #1d4ed8;
  box-shadow: inset 0 0 0 1px #1d4ed8;
}

[data-theme="dark"] .perfex-pagination {
  color: rgba(181, 194, 219, 0.8);
}

[data-theme="dark"] .perfex-pagination-extended {
  border-top-color: rgba(148, 163, 184, 0.12);
}

[data-theme="dark"] .standard-pagination-form select,
[data-theme="dark"] .standard-pagination-form input {
  background: rgba(16, 24, 43, 0.96);
  border-color: rgba(132, 154, 191, 0.2);
  color: #eef4ff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

[data-theme="dark"] .standard-pagination-form select:focus,
[data-theme="dark"] .standard-pagination-form input:focus {
  border-color: rgba(110, 168, 255, 0.7);
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.16);
  outline: none;
}

[data-theme="dark"] .standard-pagination-links .ghost-btn {
  background: rgba(16, 24, 43, 0.92);
  border-color: rgba(132, 154, 191, 0.2);
  color: #e8eefc;
}

[data-theme="dark"] .standard-pagination-links .ghost-btn:hover {
  background: rgba(24, 35, 61, 0.96);
}

[data-theme="dark"] .standard-pagination-links .ghost-btn.active {
  background: rgba(31, 67, 173, 0.18);
  border-color: rgba(98, 142, 255, 0.82);
  color: #cfe0ff;
  box-shadow: inset 0 0 0 1px rgba(98, 142, 255, 0.72);
}

@media (max-width: 980px) {
  .standard-pagination-bar {
    grid-template-columns: 1fr;
  }

  .standard-pagination-form {
    justify-content: flex-start;
  }
}

.perfex-modal-shell {
  position: fixed;
  inset: 0;
  display: none;
  align-items: flex-start;
  justify-content: center;
  z-index: 30;
  overflow-y: auto;
  padding: 20px 16px;
}

.perfex-modal-shell.is-open {
  display: flex;
}

.perfex-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
}

.perfex-modal {
  position: relative;
  width: min(650px, calc(100% - 32px));
  max-height: calc(100vh - 40px);
  background: #fff;
  border-radius: 20px;
  border: 1px solid #e4e7ec;
  box-shadow: 0 30px 80px rgba(15, 23, 42, 0.2);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.bulk-actions-modal {
  width: min(760px, calc(100% - 32px));
  max-height: min(760px, calc(100vh - 40px));
}

.perfex-modal-head,
.perfex-modal-header,
.perfex-modal-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 22px;
}

.perfex-modal-head,
.perfex-modal-header {
  border-bottom: 1px solid #eaecf0;
}

.perfex-modal-head h2,
.perfex-modal-header h2 {
  margin: 0;
  font-size: 18px;
}

.perfex-modal-head > div,
.perfex-modal-header > div {
  min-width: 0;
}

.perfex-modal-head .table-subline,
.perfex-modal-header .table-subline {
  margin-bottom: 6px;
}

.perfex-modal-body {
  padding: 22px;
  display: grid;
  gap: 18px;
  overflow-y: auto;
  min-height: 0;
}

.bulk-actions-modal .perfex-modal-body {
  padding-bottom: 14px;
}

.bulk-actions-modal .perfex-modal-actions {
  margin-top: 0;
  border-top: 1px solid #eaecf0;
  background: #fff;
  position: sticky;
  bottom: 0;
  z-index: 1;
}

.bulk-actions-modal .perfex-modal-row {
  gap: 10px;
}

.perfex-modal-row {
  display: grid;
  gap: 8px;
}

.form-help {
  margin: 0;
  font-size: 13px;
  color: #667085;
}

.form-help-danger {
  color: #ef4444;
}

.modal-close {
  border: 0;
  background: transparent;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  color: #667085;
  flex: 0 0 auto;
  align-self: flex-start;
  padding: 0;
}

.customer-detail-shell {
  display: grid;
  gap: 16px;
}

.customer-detail-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}

.customer-detail-id {
  font-size: 16px;
  font-weight: 700;
  color: #101828;
}

.customer-detail-meta,
.customer-head-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.mini-chip-danger {
  background: #fee4e2;
  color: #b42318;
}

.customer-alert,
.perfex-alert {
  border-radius: 12px;
  border: 1px solid #fed7aa;
  background: #fff7ed;
  color: #9a3412;
  padding: 13px 16px;
  font-size: 14px;
}

.perfex-alert.compact {
  padding: 10px 12px;
  font-size: 13px;
  line-height: 1.45;
}

.customer-detail-grid {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 18px;
}

.customer-detail-sidebar {
  align-self: start;
}

.customer-sidebar-title {
  margin-bottom: 12px;
  font-size: 16px;
  font-weight: 700;
  color: #1d2939;
}

.customer-side-nav {
  display: grid;
  gap: 4px;
}

.customer-side-nav a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 12px;
  border-radius: 10px;
  color: #475467;
  font-weight: 500;
}

.customer-side-nav a.active {
  background: #eff4ff;
  color: #3157df;
  font-weight: 700;
}

.customer-detail-main {
  min-width: 0;
}

.profile-head {
  margin-bottom: 12px;
}

.customer-profile-group-heading {
  margin: 0;
  font-size: 18px;
  font-weight: 700;
  color: #101828;
}

.reports-shell {
  display: grid;
  gap: 18px;
}

.reports-hero {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  padding: 20px 22px;
}

.reports-hero h2,
.sku-opportunity-shell h2 {
  margin: 0;
}

.reports-hero p,
.sku-opportunity-shell p {
  margin: 8px 0 0;
  color: var(--muted-ink);
  max-width: 760px;
}

.reports-tabs {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.reports-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  font-weight: 700;
}

.reports-tab.active {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}

.reports-filter-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 14px;
}

.reports-filter-grid .wide {
  grid-column: span 2;
}

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

.report-summary-card {
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 16px 18px;
  background: #fff;
}

.report-summary-card .eyebrow {
  margin-bottom: 8px;
}

.report-summary-card strong {
  display: block;
  font-size: 30px;
  line-height: 1;
}

.reports-two-column {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 18px;
}

.report-chart-list {
  display: grid;
  gap: 12px;
}

.report-chart-row {
  display: grid;
  gap: 6px;
}

.report-chart-label {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  font-size: 14px;
  font-weight: 700;
}

.report-chart-bar {
  height: 10px;
  border-radius: 999px;
  background: #edf2f7;
  overflow: hidden;
}

.report-chart-fill {
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #4f8cff 0%, #8fb3ff 100%);
}

.report-table {
  width: 100%;
  border-collapse: collapse;
}

.report-table th,
.report-table td {
  padding: 12px 10px;
  border-bottom: 1px solid var(--line);
  vertical-align: top;
  text-align: left;
}

.report-table th {
  background: #f8fafc;
  font-size: 13px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.report-table .numeric {
  text-align: right;
}

.report-table-wrapper {
  overflow-x: auto;
}

.sku-opportunity-shell {
  display: grid;
  gap: 18px;
}

.sku-opportunity-hero {
  position: relative;
  overflow: hidden;
  padding: 28px 30px;
  background:
    linear-gradient(135deg, #223d50 0%, #294b60 54%, #f8f5eb 54%, #f8f5eb 100%);
  color: #fff;
}

.sku-opportunity-hero h2 {
  margin: 0;
  font-size: 2.1rem;
  color: #fff;
}

.sku-opportunity-hero p {
  margin: 12px 0 0;
  max-width: 680px;
  color: rgba(255, 255, 255, 0.88);
  font-size: 1.05rem;
}

.sku-report-controls {
  padding: 18px 20px;
}

.sku-filter-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1.2fr 1.6fr;
  gap: 16px;
  align-items: start;
}

.sku-filter-grid > label,
.sku-filter-grid > .wide {
  align-self: start;
  align-content: start;
  min-height: 0;
}

.sku-filter-picker,
.sku-group-picker {
  position: relative;
  overflow: visible;
  min-height: 56px;
}

.sku-report-actions {
  margin-top: 14px;
}

.success-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 12px;
  background: #46b35b;
  color: #fff;
  font-weight: 700;
}

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

.sku-summary-card {
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 16px 18px;
  background: #fff;
}

.sku-summary-card .value {
  display: block;
  margin-top: 6px;
  font-size: 28px;
  line-height: 1;
  font-weight: 800;
}

.sku-summary-card p {
  margin: 10px 0 0;
  color: #667085;
}

.sku-result-shell {
  padding: 18px 18px 10px;
}

.sku-result-tabs {
  display: inline-flex;
  gap: 10px;
  padding: 6px;
  border-radius: 999px;
  background: #eef2f6;
  margin-bottom: 18px;
}

.sku-result-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 20px;
  border-radius: 999px;
  color: #475467;
  font-weight: 800;
}

.sku-result-tab.active {
  background: #1f314e;
  color: #fff;
}

.sku-table-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin-bottom: 10px;
}

.sku-table-toolbar-left {
  display: flex;
  align-items: center;
  gap: 8px;
}

.sku-table-limit select {
  min-height: 38px;
  min-width: 78px;
  border-radius: 10px;
  border: 1px solid #d6dde6;
  background: #fff;
  padding: 0 10px;
  font: inherit;
}

.sku-table-search {
  margin-left: auto;
}

.sku-table-search input {
  min-height: 38px;
  min-width: 240px;
  border-radius: 10px;
  border: 1px solid #d6dde6;
  background: #fff;
  padding: 0 12px;
  font: inherit;
}

.sku-main-table.hidden,
.hidden {
  display: none;
}

.sku-main-table th:last-child,
.sku-main-table td:last-child {
  text-align: right;
}

.sku-queue-list {
  display: grid;
  gap: 12px;
}

.sku-queue-card {
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 16px 18px;
  background: #fff;
}

.sku-queue-card h4 {
  margin: 0 0 8px;
}

.sku-queue-meta {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}

.sku-pill {
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 0 10px;
  border-radius: 999px;
  background: #eff4ff;
  color: #3659b8;
  font-size: 12px;
  font-weight: 700;
}

.sku-outreach-card {
  padding-top: 16px;
}

.sku-outreach-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(360px, 0.95fr);
  gap: 18px;
  align-items: start;
}

.sku-outreach-head {
  align-items: center;
}

.sku-outreach-table tr.selected {
  background: #f6f9ff;
}

.sku-recipient-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.sku-recipient-cell {
  display: grid;
  gap: 8px;
  min-width: 200px;
}

.sku-recipient-select,
.sku-recipient-input,
.sku-group-search {
  width: 100%;
  min-height: 38px;
  padding: 8px 10px;
  border: 1px solid #d0d5dd;
  border-radius: 10px;
  background: #fff;
  font: inherit;
  color: #344054;
}

.sku-recipient-chip {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border: 1px solid #d7deea;
  border-radius: 10px;
  background: #fff;
  font-size: 12px;
  font-weight: 700;
  color: #344054;
}

.sku-action-cell {
  white-space: nowrap;
}

.sku-action-cell .ghost-btn.active {
  border-color: #1d4ed8;
  color: #1d4ed8;
  box-shadow: inset 0 0 0 1px #1d4ed8;
}

.inline-form {
  display: inline-flex;
}

.primary-btn.slim,
.ghost-btn.slim {
  min-height: 36px;
  padding: 0 12px;
  border-radius: 10px;
  font-size: 13px;
}

.sku-email-preview-card {
  padding: 16px 18px 18px;
}

.sku-preview-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.sku-preview-render {
  margin-top: 8px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
}

.sku-preview-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 14px;
}

.sku-preview-table th,
.sku-preview-table td {
  padding: 10px 12px;
  border: 1px solid #e4e7ec;
  text-align: left;
  vertical-align: top;
}

.sku-preview-table th {
  background: #f8fafc;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #667085;
}

.sku-queue-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.sku-mini-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.sku-mini-row {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 12px;
  padding-top: 8px;
  border-top: 1px solid #edf0f3;
}

.sku-group-trigger {
  width: 100%;
  min-height: 56px;
  border: 1px solid #d7e1eb;
  border-radius: 20px;
  background: #fff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
  padding: 0 46px 0 18px;
  text-align: left;
  font: inherit;
  font-weight: 700;
  color: #1f2a44;
  cursor: pointer;
  position: relative;
}

.sku-group-trigger::after {
  content: "▾";
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: #667085;
  font-size: 15px;
}

.sku-group-trigger-text {
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sku-filter-picker.is-open .sku-group-trigger,
.sku-group-picker.is-open .sku-group-trigger {
  border-color: #7bc9c3;
  box-shadow: 0 0 0 3px rgba(123, 201, 195, 0.16);
}

.sku-filter-menu,
.sku-group-picker .form-multiselect-menu {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 8px);
  max-height: 300px;
  border: 1px solid #dbe5f0;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 18px 38px rgba(15, 23, 42, 0.14);
  z-index: 25;
  padding: 14px;
  box-sizing: border-box;
}

.sku-filter-menu[hidden],
.sku-group-picker .form-multiselect-menu[hidden] {
  display: none !important;
}

.sku-filter-picker.is-open .sku-filter-menu,
.sku-group-picker.is-open .form-multiselect-menu {
  display: grid;
  gap: 10px;
}

.sku-filter-menu {
  gap: 8px;
}

.sku-filter-option {
  width: 100%;
  border: 1px solid #e7edf5;
  border-radius: 14px;
  background: #f8fbff;
  padding: 12px 14px;
  text-align: left;
  font: inherit;
  font-weight: 700;
  color: #22304a;
  cursor: pointer;
  transition: background 120ms ease, border-color 120ms ease, box-shadow 120ms ease;
}

.sku-filter-option:hover,
.sku-filter-option:focus-visible {
  border-color: #c8d8ec;
  background: #ffffff;
}

.sku-filter-option.is-selected {
  border-color: #7bc9c3;
  background: #edf9f7;
  color: #165e58;
}

[data-theme="dark"] .sku-opportunity-hero {
  background: linear-gradient(135deg, rgba(34, 61, 80, 0.92) 0%, rgba(43, 71, 92, 0.92) 56%, rgba(15, 23, 42, 0.98) 56%, rgba(15, 23, 42, 0.98) 100%);
}

[data-theme="dark"] .sku-summary-card,
[data-theme="dark"] .sku-result-shell,
[data-theme="dark"] .sku-outreach-card,
[data-theme="dark"] .sku-email-preview-card {
  border-color: rgba(132, 154, 191, 0.18);
  background: linear-gradient(180deg, rgba(18, 26, 47, 0.96) 0%, rgba(14, 21, 39, 0.98) 100%);
}

[data-theme="dark"] .sku-summary-card p,
[data-theme="dark"] .sku-opportunity-shell p,
[data-theme="dark"] .sku-group-trigger-text,
[data-theme="dark"] .sku-table-search input::placeholder,
[data-theme="dark"] .sku-recipient-input::placeholder,
[data-theme="dark"] .sku-group-search::placeholder {
  color: rgba(181, 194, 219, 0.76);
}

[data-theme="dark"] .sku-summary-card .value,
[data-theme="dark"] .sku-pill,
[data-theme="dark"] .sku-result-tab.active,
[data-theme="dark"] .sku-opportunity-shell h3,
[data-theme="dark"] .sku-opportunity-shell strong {
  color: #eef4ff;
}

[data-theme="dark"] .sku-result-tabs {
  background: rgba(148, 163, 184, 0.08);
}

[data-theme="dark"] .sku-result-tab {
  color: rgba(181, 194, 219, 0.8);
}

[data-theme="dark"] .sku-result-tab.active {
  background: rgba(31, 49, 78, 0.96);
}

[data-theme="dark"] .sku-table-limit select,
[data-theme="dark"] .sku-table-search input,
[data-theme="dark"] .sku-recipient-select,
[data-theme="dark"] .sku-recipient-input,
[data-theme="dark"] .sku-group-search,
[data-theme="dark"] .sku-group-trigger {
  border-color: rgba(132, 154, 191, 0.2);
  background: rgba(16, 24, 43, 0.96);
  color: #eef4ff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

[data-theme="dark"] .sku-group-trigger::after {
  color: rgba(219, 231, 245, 0.72);
}

[data-theme="dark"] .sku-filter-menu,
[data-theme="dark"] .sku-group-picker .form-multiselect-menu {
  border-color: rgba(132, 154, 191, 0.18);
  background: rgba(14, 21, 39, 0.98);
  box-shadow: 0 18px 38px rgba(2, 6, 23, 0.36);
}

[data-theme="dark"] .sku-filter-option {
  border-color: rgba(132, 154, 191, 0.14);
  background: rgba(148, 163, 184, 0.08);
  color: #e8eefc;
}

[data-theme="dark"] .sku-filter-option:hover,
[data-theme="dark"] .sku-filter-option:focus-visible {
  border-color: rgba(132, 154, 191, 0.22);
  background: rgba(148, 163, 184, 0.12);
}

[data-theme="dark"] .sku-filter-option.is-selected {
  border-color: rgba(115, 207, 196, 0.55);
  background: rgba(82, 170, 157, 0.16);
  color: #bdf3eb;
}

[data-theme="dark"] .sku-group-picker .form-multiselect-menu .checkline {
  background: rgba(148, 163, 184, 0.06);
  border-color: rgba(132, 154, 191, 0.12);
  color: #e8eefc;
}

[data-theme="dark"] .sku-group-picker .form-multiselect-menu .checkline:hover {
  background: rgba(148, 163, 184, 0.1);
}

[data-theme="dark"] .sku-preview-render {
  border-color: rgba(132, 154, 191, 0.18);
  background: linear-gradient(180deg, rgba(18, 26, 47, 0.96) 0%, rgba(14, 21, 39, 0.98) 100%);
}

[data-theme="dark"] .sku-preview-render .message-html-content {
  color: #e8eefc;
}

[data-theme="dark"] .sku-preview-table th {
  background: rgba(148, 163, 184, 0.08);
  color: rgba(181, 194, 219, 0.8);
}

[data-theme="dark"] .sku-preview-table th,
[data-theme="dark"] .sku-preview-table td,
[data-theme="dark"] .report-table th,
[data-theme="dark"] .report-table td {
  border-color: rgba(132, 154, 191, 0.14);
}

[data-theme="dark"] .report-table th {
  background: rgba(148, 163, 184, 0.08);
  color: rgba(181, 194, 219, 0.8);
}

[data-theme="dark"] .sku-outreach-table tr.selected {
  background: rgba(50, 86, 188, 0.16);
}

.sku-group-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.sku-group-options {
  display: grid;
  gap: 8px;
  max-height: 180px;
  overflow: auto;
  padding-right: 4px;
}

.sku-group-options .checkline {
  margin: 0;
  padding: 12px 14px;
  border: 1px solid #e7edf5;
  border-radius: 14px;
  background: #f8fbff;
}

.bulk-group-picker {
  position: relative;
}

.bulk-group-picker-trigger {
  width: 100%;
  min-height: 52px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 16px;
  border: 1px solid #dbe5f0;
  border-radius: 16px;
  background: #fbfdff;
  font: inherit;
  color: var(--ink);
  text-align: left;
  cursor: pointer;
}

.bulk-group-picker-caret {
  color: var(--ink-soft);
  font-size: 18px;
  transition: transform 0.16s ease;
}

.bulk-group-picker.is-open .bulk-group-picker-caret {
  transform: rotate(180deg);
}

.bulk-group-picker-panel {
  position: relative;
  margin-top: 8px;
  z-index: 1;
  display: grid;
  gap: 12px;
  padding: 12px;
  border: 1px solid #dbe5f0;
  border-radius: 16px;
  background: #fbfdff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.8);
}

.bulk-group-picker-head {
  display: grid;
  gap: 10px;
}

.bulk-group-picker-options {
  display: grid;
  gap: 8px;
  max-height: 168px;
  overflow: auto;
  padding-right: 4px;
}

.bulk-group-picker-options .checkline {
  margin: 0;
  padding: 12px 14px;
  border: 1px solid #e7edf5;
  border-radius: 14px;
  background: #f8fbff;
}

.bulk-actions-modal .form-help-danger {
  margin-top: 2px;
}

.sku-group-search {
  min-height: 46px;
  border-radius: 14px;
  border: 1px solid #dbe5f0;
  padding: 0 14px;
  font: inherit;
}

@media (max-width: 1200px) {
  .reports-filter-grid,
  .reports-summary-grid,
  .sku-summary-grid,
  .reports-two-column,
  .sku-filter-grid {
    grid-template-columns: 1fr;
  }

  .reports-filter-grid .wide {
    grid-column: span 1;
  }

  .sku-outreach-layout,
  .sku-preview-grid {
    grid-template-columns: 1fr;
  }
}

.customer-group-heading-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.customer-group-section {
  display: grid;
  gap: 14px;
}

.profile-tabs {
  display: flex;
  align-items: center;
  gap: 22px;
  padding-top: 0;
  padding-bottom: 0;
}

.profile-tabs a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 16px 0 14px;
  border-bottom: 2px solid transparent;
  color: #475467;
  font-weight: 600;
}

.profile-tabs a.active {
  color: #101828;
  border-bottom-color: #344054;
}

.tab-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  background: #f2f4f7;
  font-size: 12px;
}

.profile-card {
  padding-top: 22px;
}

.profile-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 20px;
}

.profile-form-grid label {
  display: grid;
  gap: 8px;
  color: #344054;
  font-size: 14px;
  font-weight: 600;
}

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

.profile-inline-toggle {
  padding-bottom: 8px;
}

.checkline {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #344054;
  font-weight: 600;
  cursor: pointer;
}

.checkline input {
  width: 22px;
  height: 22px;
  margin: 0;
  flex: 0 0 22px;
  cursor: pointer;
  accent-color: var(--accent);
}

.checkline-stack {
  display: grid;
  gap: 10px;
  padding-top: 10px;
}

.document-toggle {
  gap: 14px;
  min-height: 32px;
}

.document-toggle span {
  line-height: 1.35;
}

.profile-actions {
  display: flex;
  justify-content: flex-start;
  padding-top: 8px;
}

.empty-block,
.subpanel {
  padding: 8px 0;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.customer-admin-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
}

.customer-admin-picker {
  min-width: 260px;
}

.admin-staff-cell {
  display: flex;
  align-items: center;
  gap: 12px;
}

.admin-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #e8eefc;
  color: #3559d5;
  font-weight: 700;
  overflow: hidden;
}

.admin-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.table-avatar-person {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.table-avatar-person-compact {
  display: inline-flex;
  gap: 0;
}

.table-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  overflow: hidden;
  background: #e8eefc;
  color: #3559d5;
  font-size: 13px;
  font-weight: 800;
}

.table-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.table-avatar-meta {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.table-avatar-meta strong,
.table-avatar-meta span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.table-avatar-meta strong {
  font-size: 14px;
}

.table-avatar-meta span {
  color: #667085;
  font-size: 12px;
}

.staff-permission-stack {
  display: grid;
  gap: 10px;
}

.staff-permission-list,
.staff-capability-list,
.mini-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.staff-permission-row td {
  padding-top: 0;
  background: #f8fafc;
}

.staff-permission-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  padding: 12px 0 4px;
}

.staff-permission-card {
  border: 1px solid #dbe3f1;
  border-radius: 14px;
  background: #fff;
  padding: 12px 14px;
  display: grid;
  gap: 10px;
}

.mini-chip-muted {
  background: #eef2f7;
  color: #455468;
}

.po-view-card {
  padding: 0;
  overflow: hidden;
  position: sticky;
  top: 18px;
  max-height: calc(100vh - 36px);
  display: flex;
  flex-direction: column;
  border: 1px solid #dbe4ef;
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.08);
  background: linear-gradient(180deg, #ffffff 0%, #fcfdff 100%);
}

.po-view-tabs {
  display: flex;
  gap: 22px;
  flex-wrap: wrap;
  padding: 0 22px;
  min-height: 56px;
  align-items: center;
  border-bottom: 1px solid #eaecf0;
  color: #667085;
  font-size: 13px;
  font-weight: 700;
  background: #fbfcfe;
}

.po-view-tabs a,
.po-view-tabs span,
.po-view-tabs button {
  display: inline-flex;
  align-items: center;
  height: 56px;
  border-bottom: 2px solid transparent;
  appearance: none;
  border-left: 0;
  border-right: 0;
  border-top: 0;
  background: transparent;
  color: inherit;
  font: inherit;
  cursor: pointer;
  padding: 0;
}

.po-view-tabs .active {
  color: #111827;
  border-bottom-color: #344054;
}

.po-view-document {
  padding: 20px 22px 24px;
  overflow-y: auto;
}

.po-view-document[hidden],
.po-tab-pane[hidden] {
  display: none !important;
}

.po-tab-pane {
  padding: 20px 22px 24px;
  overflow-y: auto;
  display: grid;
  gap: 16px;
}

.po-pane-section {
  border: 1px solid #e4e7ec;
  border-radius: 18px;
  padding: 18px;
  background: #fff;
}

.po-pane-section h3 {
  margin: 0 0 14px;
  font-size: 18px;
  color: #101828;
}

.po-inline-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 16px;
}

.po-inline-form-grid label {
  display: grid;
  gap: 6px;
  color: #344054;
  font-size: 14px;
  font-weight: 600;
}

.po-inline-form-grid input,
.po-inline-form-grid select,
.po-inline-form-grid textarea {
  width: 100%;
}

.po-full-width {
  grid-column: 1 / -1;
}

.po-form-actions {
  grid-column: 1 / -1;
  display: flex;
  justify-content: flex-end;
}

.po-linked-list {
  display: grid;
  gap: 12px;
}

.po-linked-card {
  border: 1px solid #e4e7ec;
  border-radius: 16px;
  padding: 14px 16px;
  background: linear-gradient(180deg, #fff 0%, #fbfcff 100%);
}

.po-linked-card p {
  margin: 10px 0 0;
}

.po-linked-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.po-linked-card-meta {
  margin-top: 8px;
  color: #667085;
  font-size: 13px;
  line-height: 1.45;
}

.po-view-header {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(240px, 300px);
  gap: 24px;
  align-items: start;
}

.po-view-number {
  font-size: clamp(20px, 1.55vw, 28px);
  font-weight: 800;
  color: #2f4fe3;
  line-height: 1.02;
  letter-spacing: -0.03em;
  overflow-wrap: anywhere;
  max-width: 18ch;
  margin-bottom: 8px;
}

.po-view-address {
  color: #667085;
  font-size: 14px;
  line-height: 1.5;
}

.po-view-address strong {
  display: inline-block;
  margin-bottom: 4px;
  color: #101828;
  font-size: 16px;
}

.po-view-meta {
  max-width: 300px;
  margin-left: auto;
  text-align: right;
  color: #475467;
  font-size: 14px;
  line-height: 1.45;
}

.po-view-meta strong {
  display: inline-block;
  margin-bottom: 4px;
  color: #101828;
  font-size: 14px;
}

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

.po-view-summary > div {
  overflow-wrap: anywhere;
  padding: 10px 12px;
  border: 1px solid #e6ebf2;
  border-radius: 12px;
  background: #fbfcfe;
  color: #475467;
  font-size: 13px;
  line-height: 1.45;
}

.po-view-summary > div strong {
  color: #101828;
}

.po-view-card .perfex-table-wrap {
  margin-top: 0;
  border: 1px solid #e7edf5;
  border-radius: 14px;
  overflow: hidden;
}

.po-view-card .perfex-table th,
.po-view-card .perfex-table td {
  padding: 11px 10px;
  font-size: 12.5px;
  line-height: 1.4;
}

.po-view-card .perfex-table th {
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #667085;
  background: #f8fafc;
}

.po-view-totals,
.print-totals {
  margin-left: auto;
  width: min(100%, 320px);
  display: grid;
  gap: 10px;
  margin-top: 24px;
}

.print-shell {
  background: #fff;
}

.print-document {
  max-width: 980px;
  margin: 0 auto;
  padding: 32px 28px 48px;
}

.print-head,
.print-address-grid,
.print-meta-grid,
.print-table,
.print-totals {
  color: #111827;
}

.print-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 24px;
}

.print-po-number {
  font-size: 24px;
  font-weight: 800;
}

.print-status {
  font-weight: 700;
}

.print-address-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-bottom: 20px;
}

.print-meta-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px 20px;
  margin-bottom: 20px;
}

.print-meta-grid > div,
.print-totals > div,
.po-total-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
}

.print-table {
  width: 100%;
  border-collapse: collapse;
}

.print-table th,
.print-table td {
  padding: 10px 8px;
  border-top: 1px solid #d0d5dd;
  text-align: left;
  vertical-align: top;
}

.print-totals .grand {
  border-top: 1px solid #d0d5dd;
  padding-top: 10px;
  font-size: 18px;
}

.perfex-print-po {
  max-width: 900px;
}

.print-po-topbar {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 36px;
}

.print-brandmark {
  max-width: 220px;
}

.print-brandmark img {
  max-width: 220px;
  max-height: 58px;
  object-fit: contain;
}

.print-brandmark-fallback {
  display: inline-block;
  background: #111827;
  color: #fff;
  padding: 10px 14px;
  font-weight: 800;
  letter-spacing: 0.03em;
}

.print-po-title {
  text-align: right;
}

.print-po-title h1 {
  margin: 0;
  font-size: 28px;
  letter-spacing: 0.02em;
}

.print-po-title div {
  margin-top: 4px;
  font-weight: 700;
}

.print-po-address-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 26px;
}

.print-po-box {
  border: 1px solid #d0d5dd;
  padding: 14px 16px;
  min-height: 128px;
}

.top-gap-xs {
  margin-top: 8px;
}

.print-po-meta {
  display: grid;
  justify-content: end;
  gap: 6px;
  margin-bottom: 18px;
  text-align: right;
}

.perfex-po-table thead th {
  background: #222733;
  color: #fff;
  font-size: 13px;
  font-weight: 700;
}

.perfex-po-table th,
.perfex-po-table td {
  border-top: 1px solid #d8dde6;
}

.perfex-po-totals {
  margin-left: auto;
  width: 280px;
  margin-top: 26px;
}

.po-workspace-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(460px, 0.92fr);
  gap: 14px;
  align-items: start;
}

.po-workspace-grid.is-collapsed {
  grid-template-columns: minmax(0, 1fr);
}

.po-workspace-grid .perfex-card {
  min-width: 0;
}

.po-queue-card .perfex-toolbar {
  justify-content: space-between;
  align-items: center;
  flex-wrap: nowrap;
  gap: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid #edf2f7;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: thin;
}

.po-queue-card .perfex-toolbar-left {
  flex-wrap: nowrap;
  flex: 0 0 auto;
  min-width: 0;
}

.po-queue-card .perfex-toolbar-right {
  flex: 0 0 auto;
  min-width: 0;
  margin-left: 0;
}

.page-shell-po .po-queue-card {
  border: 1px solid #dbe4ef;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.05);
}

.po-queue-table {
  table-layout: fixed;
  min-width: 980px;
}

.po-queue-table th {
  white-space: nowrap;
}

.po-queue-table td {
  line-height: 1.3;
}

.page-shell-po .po-search-form {
  width: auto;
  max-width: none;
  justify-content: flex-start;
  flex-wrap: nowrap;
}

.page-shell-po .po-search-form input {
  flex: 0 0 220px;
  min-width: 220px;
}

.page-shell-po .po-queue-table th:nth-child(2),
.page-shell-po .po-queue-table td:nth-child(2) {
  width: 27%;
}

.page-shell-po .po-queue-table th:nth-child(3),
.page-shell-po .po-queue-table td:nth-child(3) {
  width: 11%;
}

.page-shell-po .po-queue-table th:nth-child(4),
.page-shell-po .po-queue-table td:nth-child(4) {
  width: 15%;
}

.page-shell-po .po-queue-table th:nth-child(5),
.page-shell-po .po-queue-table td:nth-child(5) {
  width: 13%;
}

.page-shell-po .po-queue-table th:nth-child(6),
.page-shell-po .po-queue-table td:nth-child(6) {
  width: 12%;
}

.page-shell-po .po-queue-table th:nth-child(7),
.page-shell-po .po-queue-table td:nth-child(7) {
  width: 14%;
}

.page-shell-po .po-queue-table th:nth-child(8),
.page-shell-po .po-queue-table td:nth-child(8) {
  width: 64px;
}

.po-queue-table th:nth-child(2),
.po-queue-table td:nth-child(2) {
  width: 26%;
}

.po-queue-table th:nth-child(3),
.po-queue-table td:nth-child(3) {
  width: 11%;
}

.po-queue-table th:nth-child(4),
.po-queue-table td:nth-child(4) {
  width: 16%;
}

.po-queue-table th:nth-child(5),
.po-queue-table td:nth-child(5) {
  width: 12%;
}

.po-queue-table th:nth-child(6),
.po-queue-table td:nth-child(6) {
  width: 13%;
}

.po-queue-table th:nth-child(7),
.po-queue-table td:nth-child(7) {
  width: 12%;
}

.po-queue-table th:nth-child(8),
.po-queue-table td:nth-child(8) {
  width: 58px;
  text-align: center;
}

.po-queue-table .perfex-record-link {
  display: inline-block;
  max-width: 100%;
  overflow-wrap: anywhere;
}

.po-queue-table td:nth-child(4),
.po-queue-table td:nth-child(7) {
  overflow-wrap: anywhere;
}

.page-shell-po .po-queue-table th,
.page-shell-po .po-queue-table td {
  padding: 11px 8px;
  font-size: 13px;
}

.page-shell-po .po-queue-table .perfex-row-actions {
  font-size: 10px;
  color: #98a2b3;
}

.perfex-table tr.is-selected td {
  background: #eef4ff;
}

.po-view-header-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
  padding: 12px 22px 14px;
  padding-bottom: 14px;
  border-bottom: 1px solid #edf2f7;
}

.po-view-header-actions .button-row {
  flex-wrap: wrap;
  justify-content: flex-end;
}

.po-more-menu {
  position: relative;
}

.po-more-menu-panel {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  z-index: 30;
  width: 280px;
  padding: 10px 0;
  border: 1px solid #d7dee8;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.16);
}

.po-more-menu-panel a,
.po-more-menu-panel button {
  display: block;
  width: 100%;
  padding: 10px 16px;
  border: 0;
  background: transparent;
  color: #101828;
  font: inherit;
  text-align: left;
  text-decoration: none;
  cursor: pointer;
}

.po-more-menu-panel a:hover,
.po-more-menu-panel button:hover {
  background: #f8fafc;
}

.po-more-menu-panel .danger-text {
  color: #dc2626;
}

.po-send-modal {
  width: min(760px, calc(100vw - 48px));
  max-height: calc(100vh - 48px);
}

.po-send-form .perfex-modal-body {
  display: grid;
  gap: 14px;
  overflow-y: auto;
  overscroll-behavior: contain;
  max-height: calc(100vh - 220px);
  padding-right: 18px;
}

.po-send-form select[multiple] {
  min-height: 128px;
  padding: 10px 12px;
}

.po-recipient-picker {
  position: relative;
}

.po-recipient-picker-trigger {
  width: 100%;
  min-height: 56px;
  padding: 14px 16px;
  border: 1px solid #d7dee8;
  border-radius: 14px;
  background: #fff;
  color: #111827;
  font: inherit;
  text-align: left;
  cursor: pointer;
  box-shadow: inset 0 0 0 1px transparent;
}

.po-recipient-picker-trigger[aria-expanded="true"] {
  border-color: #84cccf;
  box-shadow: 0 0 0 3px rgba(132, 204, 207, 0.16);
}

.po-recipient-picker-panel {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  z-index: 25;
  border: 1px solid #d7dee8;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 24px 48px rgba(15, 23, 42, 0.16);
  padding: 12px;
  display: grid;
  gap: 10px;
}

.po-recipient-picker-panel[hidden] {
  display: none !important;
}

.po-recipient-picker-search {
  width: 100%;
  min-height: 46px;
  padding: 10px 14px;
  border: 1px solid #d7dee8;
  border-radius: 12px;
  background: #fff;
  color: #111827;
  font: inherit;
}

.po-recipient-picker-options {
  display: grid;
  gap: 8px;
  max-height: 280px;
  overflow-y: auto;
}

.po-recipient-option {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 12px;
  background: #f8fafc;
  cursor: pointer;
}

.po-recipient-option:hover {
  background: #eef2ff;
}

.po-recipient-option input[type="checkbox"] {
  appearance: auto;
  -webkit-appearance: checkbox;
  -moz-appearance: checkbox;
  width: 18px;
  min-width: 18px;
  max-width: 18px;
  height: 18px;
  min-height: 18px;
  margin: 2px 0 0;
  padding: 0;
  border: 0;
  border-radius: 4px;
  background: transparent;
  box-shadow: none;
  flex: 0 0 18px;
  accent-color: #0f766e;
}

.po-recipient-option-copy {
  display: grid;
  gap: 2px;
  min-width: 0;
  flex: 1 1 auto;
}

.po-recipient-option-primary {
  display: block;
  color: #111827;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.35;
  word-break: break-word;
}

.po-recipient-option-secondary {
  display: block;
  color: #64748b;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.35;
  word-break: break-word;
}

.po-send-form {
  display: flex;
  flex: 1 1 auto;
  min-height: 0;
  flex-direction: column;
}

.po-send-modal .perfex-modal-actions {
  margin-top: auto;
  flex-shrink: 0;
}

[data-theme="dark"] .po-recipient-picker-trigger,
[data-theme="dark"] .po-recipient-picker-panel,
[data-theme="dark"] .po-recipient-picker-search {
  background: #111827;
  border-color: rgba(148, 163, 184, 0.22);
  color: #f8fafc;
}

[data-theme="dark"] .po-recipient-option {
  background: rgba(148, 163, 184, 0.08);
}

[data-theme="dark"] .po-recipient-option:hover {
  background: rgba(132, 204, 207, 0.12);
}

[data-theme="dark"] .po-recipient-option-primary {
  color: #f8fafc;
}

[data-theme="dark"] .po-recipient-option-secondary {
  color: #cbd5e1;
}

.simple-rich-editor {
  display: grid;
  gap: 10px;
  border: 1px solid #d7dee8;
  border-radius: 14px;
  background: #fff;
  padding: 12px;
}

.simple-rich-editor-tabs,
.simple-rich-editor-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.simple-rich-editor-tabs .light-btn.is-active {
  border-color: #2f855a;
  color: #fff;
  background: #2f855a;
}

.simple-rich-editor-surface,
.simple-rich-editor-html {
  min-height: 220px;
  border: 1px solid #d7dee8;
  border-radius: 12px;
  background: #fff;
  padding: 14px 16px;
  font-size: 14px;
  line-height: 1.6;
}

.simple-rich-editor-surface:focus,
.simple-rich-editor-html:focus {
  outline: 2px solid rgba(47, 133, 90, 0.18);
  border-color: #2f855a;
}

.simple-rich-editor-html {
  width: 100%;
  resize: vertical;
}

.page-shell-po .light-btn,
.page-shell-po .icon-btn,
.page-shell-po .dark-btn,
.page-shell-po .ghost-btn {
  border-radius: 10px;
}

.page-shell-po .po-filter-grid {
  gap: 16px;
}

.page-shell-po .po-filter-grid label {
  gap: 8px;
  color: #344054;
  font-size: 13px;
  font-weight: 700;
}

.page-shell-po .po-filter-grid select,
.page-shell-po .po-search-form select,
.page-shell-po .po-search-form input {
  min-height: 40px;
  border-radius: 12px;
  border-color: #d7dee8;
  background: #fff;
}

.page-shell-po .po-search-form {
  gap: 8px;
  flex-wrap: nowrap;
}

.page-shell-po .po-search-form select {
  flex: 0 0 122px;
  min-width: 122px;
}

.page-shell-po .po-search-form input {
  flex: 0 0 168px;
  min-width: 168px;
}

.page-shell-po .po-queue-card .perfex-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid #edf2f7;
  overflow: visible;
}

.page-shell-po .po-queue-card .perfex-toolbar-left {
  flex: 1 1 auto;
  min-width: 0;
  gap: 8px;
  flex-wrap: nowrap;
  overflow: hidden;
}

.page-shell-po .po-queue-card .perfex-toolbar-right {
  flex: 0 0 auto;
  min-width: 0;
  margin-left: auto;
  justify-self: end;
}

.page-shell-po .po-queue-card .light-btn,
.page-shell-po .po-queue-card .icon-btn {
  min-height: 38px;
  padding: 8px 11px;
  font-size: 13px;
  white-space: nowrap;
}

.page-shell-po .po-queue-card .icon-btn {
  min-width: 38px;
  padding-inline: 10px;
}

.page-shell-po .po-queue-card .perfex-inline-form select {
  min-height: 38px;
  width: 88px;
  min-width: 88px;
  padding: 8px 10px;
}

.page-shell-po .po-queue-card .perfex-toolbar-left .light-btn,
.page-shell-po .po-queue-card .perfex-toolbar-left .dark-btn,
.page-shell-po .po-queue-card .perfex-toolbar-left .ghost-btn,
.page-shell-po .po-queue-card .perfex-toolbar-left .po-toolbar-menu-trigger {
  min-width: 0;
}

.po-toolbar-menu {
  flex: 0 0 auto;
}

.po-toolbar-menu-trigger {
  white-space: nowrap;
}

.po-toolbar-menu-panel {
  width: 170px;
  left: 0;
  right: auto;
}

.page-shell-po .perfex-stat {
  border-color: #dbe4ef;
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.04);
}

[data-theme="dark"] .page-shell-po .po-filter-grid label {
  color: rgba(191, 205, 230, 0.82);
}

[data-theme="dark"] .page-shell-po .po-filter-grid select,
[data-theme="dark"] .page-shell-po .po-search-form select,
[data-theme="dark"] .page-shell-po .po-search-form input,
[data-theme="dark"] .page-shell-po .po-queue-card .perfex-inline-form select {
  border-color: rgba(132, 154, 191, 0.2);
  background-color: rgba(16, 24, 43, 0.96);
  color: #eef4ff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

[data-theme="dark"] .page-shell-po .po-queue-card {
  border-color: rgba(132, 154, 191, 0.18);
  box-shadow: 0 16px 34px rgba(2, 6, 23, 0.22);
}

[data-theme="dark"] .po-queue-card .perfex-toolbar {
  border-bottom-color: rgba(132, 154, 191, 0.14);
}

[data-theme="dark"] .perfex-table tr.is-selected td {
  background: rgba(50, 86, 188, 0.16);
}

[data-theme="dark"] .po-view-card {
  border-color: rgba(132, 154, 191, 0.18);
  box-shadow: 0 18px 38px rgba(2, 6, 23, 0.26);
  background: linear-gradient(180deg, rgba(12, 18, 34, 0.98) 0%, rgba(10, 16, 30, 0.98) 100%);
}

[data-theme="dark"] .po-view-tabs {
  background: rgba(148, 163, 184, 0.08);
  border-bottom-color: rgba(132, 154, 191, 0.14);
  color: rgba(181, 194, 219, 0.78);
}

[data-theme="dark"] .po-view-tabs .active {
  color: #f5f8ff;
  border-bottom-color: rgba(111, 168, 255, 0.9);
}

[data-theme="dark"] .po-view-header-actions {
  border-bottom-color: rgba(132, 154, 191, 0.14);
}

[data-theme="dark"] .po-view-address,
[data-theme="dark"] .po-view-meta,
[data-theme="dark"] .po-linked-card-meta {
  color: rgba(181, 194, 219, 0.78);
}

[data-theme="dark"] .po-view-address strong,
[data-theme="dark"] .po-view-meta strong,
[data-theme="dark"] .po-pane-section h3 {
  color: #f5f8ff;
}

[data-theme="dark"] .po-view-summary > div,
[data-theme="dark"] .po-pane-section,
[data-theme="dark"] .po-linked-card,
[data-theme="dark"] .po-totals-card {
  background: linear-gradient(180deg, rgba(18, 26, 47, 0.96) 0%, rgba(14, 21, 39, 0.98) 100%);
  border-color: rgba(132, 154, 191, 0.18);
  color: rgba(181, 194, 219, 0.82);
}

[data-theme="dark"] .po-view-summary > div strong,
[data-theme="dark"] .po-total-row strong {
  color: #eef4ff;
}

[data-theme="dark"] .po-view-card .perfex-table-wrap {
  border-color: rgba(132, 154, 191, 0.18);
}

[data-theme="dark"] .po-view-card .perfex-table th {
  color: rgba(181, 194, 219, 0.74);
  background: rgba(148, 163, 184, 0.08);
}

[data-theme="dark"] .po-more-menu-panel {
  border-color: rgba(132, 154, 191, 0.18);
  background: rgba(14, 21, 39, 0.98);
  box-shadow: 0 18px 40px rgba(2, 6, 23, 0.36);
}

[data-theme="dark"] .po-more-menu-panel a,
[data-theme="dark"] .po-more-menu-panel button {
  color: #eef4ff;
}

[data-theme="dark"] .po-more-menu-panel a:hover,
[data-theme="dark"] .po-more-menu-panel button:hover {
  background: rgba(148, 163, 184, 0.08);
}

@media print {
  .print-shell {
    background: #fff;
  }
}

.contact-section-head {
  margin-bottom: 10px;
}

.contact-modal {
  width: min(760px, calc(100% - 32px));
}

#campaign-test-email-modal .perfex-modal {
  width: min(760px, calc(100vw - 48px));
}

#campaign-test-email-modal .perfex-modal-header {
  align-items: flex-start;
  padding: 22px 30px 18px;
}

#campaign-test-email-modal .perfex-modal-body {
  gap: 20px;
  padding: 26px 30px 30px;
}

#campaign-test-email-modal .stack-form > p {
  margin: 0;
  max-width: 60ch;
}

#campaign-test-email-modal label {
  display: grid;
  gap: 10px;
  color: #172335;
  font-weight: 700;
}

#campaign-test-email-modal input[type="email"] {
  min-height: 56px;
  padding: 14px 18px;
  border-radius: 18px;
}

#campaign-test-email-modal .button-row {
  justify-content: flex-start;
  gap: 14px;
}

.contact-modal form {
  display: flex;
  flex: 1 1 auto;
  min-height: 0;
  flex-direction: column;
}

.contact-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 18px;
}

.contact-form-grid label {
  display: grid;
  gap: 8px;
  color: #344054;
  font-size: 14px;
  font-weight: 600;
}

.portal-password-field {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.portal-password-field .light-btn {
  min-height: 46px;
  white-space: nowrap;
}

.checkbox-row {
  display: flex !important;
  align-items: center;
  gap: 10px !important;
  font-weight: 600;
}

.checkbox-row input {
  width: 18px;
  height: 18px;
}

@media (max-height: 860px) {
  .perfex-modal-shell {
    padding-top: 12px;
    padding-bottom: 12px;
  }

  .perfex-modal {
    max-height: calc(100vh - 24px);
  }

  .perfex-modal-head,
  .perfex-modal-actions {
    padding-top: 14px;
    padding-bottom: 14px;
  }

  .perfex-modal-body {
    padding-top: 18px;
    padding-bottom: 18px;
  }
}

.staff-direct-permissions {
  grid-column: 1 / -1;
  display: grid;
  gap: 10px;
}

.staff-direct-permissions-title {
  font-size: 14px;
  font-weight: 700;
  color: #344054;
}

.staff-direct-permissions-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 14px;
  max-height: 220px;
  overflow: auto;
  padding: 12px;
  border: 1px solid #d0d5dd;
  border-radius: 12px;
  background: #fafbfc;
}

.staff-detail-shell {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}

.staff-profile-stats {
  grid-column: 1 / -1;
}

.staff-avatar-editor {
  display: grid;
  gap: 14px;
  margin-bottom: 18px;
  padding: 18px;
  border: 1px solid #dbe3f1;
  border-radius: 18px;
  background: linear-gradient(180deg, #fbfdff 0%, #f6f9fc 100%);
}

.staff-avatar-editor-preview {
  display: flex;
  align-items: center;
  gap: 16px;
}

.staff-avatar-editor-actions {
  display: flex;
  justify-content: flex-start;
}

.staff-avatar-editor-avatar {
  width: 72px;
  height: 72px;
  font-size: 28px;
  flex: 0 0 auto;
}

.staff-smtp-shell {
  display: grid;
  gap: 14px;
  margin-bottom: 18px;
  padding: 18px;
  border: 1px solid #dbe3f1;
  border-radius: 18px;
  background: #fbfdff;
}

.staff-signature-shell {
  display: grid;
  gap: 14px;
  margin-bottom: 18px;
  padding: 18px;
  border: 1px solid #dbe3f1;
  border-radius: 18px;
  background: #fbfdff;
}

.staff-signature-editor-shell {
  border-radius: 18px;
}

.staff-signature-editor-shell .product-wysiwyg-toolbar {
  border-bottom: 1px solid #e8eef5;
}

.staff-signature-editor {
  min-height: 220px;
}

.section-head.compact {
  margin-bottom: 0;
}

.compose-email-form {
  gap: 14px;
}

.compose-email-panel {
  display: grid;
  gap: 8px;
  padding: 16px 18px;
  border: 1px solid #dbe3f1;
  border-radius: 16px;
  background: linear-gradient(180deg, #fbfdff 0%, #f6f9fc 100%);
}

.compose-email-panel-label {
  color: #475467;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.compose-email-sender {
  font-size: 16px;
  font-weight: 700;
  color: #101828;
}

.compose-email-panel select {
  min-height: 48px;
}

.compose-email-form select[multiple] {
  min-height: 220px;
  padding: 12px;
}

.smtp-shared-senders-list {
  display: grid;
  gap: 14px;
}

.smtp-shared-sender-card {
  display: grid;
  gap: 12px;
  padding: 16px;
  border: 1px solid #dbe3f1;
  border-radius: 16px;
  background: #ffffff;
}

.smtp-shared-sender-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.staff-permission-summary {
  margin-bottom: 6px;
}

.staff-role-editor-stack {
  display: grid;
  gap: 18px;
}

.staff-role-toolbar {
  display: grid;
  grid-template-columns: minmax(280px, 420px) minmax(320px, 1fr);
  gap: 16px;
  margin-bottom: 18px;
  align-items: end;
}

.staff-role-selector-form,
.staff-role-create-form {
  display: grid;
  gap: 10px;
}

.staff-role-create-form {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
}

.staff-role-create-form label {
  margin: 0;
}

.staff-role-editor-card {
  display: grid;
  gap: 12px;
  padding: 16px 18px;
  border: 1px solid #dbe3f1;
  border-radius: 18px;
  background: #fff;
}

.staff-role-editor-card .section-head {
  margin-bottom: 2px;
}

.staff-role-editor-card .section-head h3 {
  margin-bottom: 4px;
}

.staff-role-editor-card > label {
  max-width: 420px;
}

@media (max-width: 980px) {
  .staff-role-toolbar,
  .staff-role-create-form {
    grid-template-columns: 1fr;
  }
}

.staff-permission-matrix {
  display: grid;
  gap: 10px;
}

.staff-permission-matrix-row {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 14px;
  padding: 12px 0;
  border-top: 1px solid #edf2f7;
}

.staff-permission-matrix-row:first-child {
  border-top: 0;
  padding-top: 0;
}

.staff-permission-feature {
  align-self: start;
  font-size: 15px;
  font-weight: 800;
  color: #22304a;
}

.staff-permission-capabilities {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 10px;
  align-items: flex-start;
}

.staff-capability-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 40px;
  padding: 8px 12px;
  border: 1px solid #dbe3f1;
  border-radius: 12px;
  background: #f8fbff;
  font-weight: 700;
  color: #22304a;
}

.staff-capability-toggle input {
  width: 18px;
  height: 18px;
  margin: 0;
  flex: 0 0 auto;
}

.staff-capability-toggle span {
  line-height: 1.2;
}

.staff-capability-toggle em {
  margin-left: 4px;
  font-size: 12px;
  font-style: normal;
  font-weight: 700;
  color: #4f46e5;
}

.staff-capability-toggle.is-inherited {
  background: #eef4ff;
  border-color: #cddaf9;
}

.staff-capability-toggle.is-denied {
  background: #fff5f5;
  border-color: #f3c7c7;
}

.staff-capability-toggle.is-denied em {
  color: #c1121f;
}

@media (max-width: 1100px) {
  .staff-detail-shell,
  .staff-permission-matrix-row {
    grid-template-columns: 1fr;
  }
}

.danger-link {
  color: #c1121f;
}

.status-toggle-button {
  border: 0;
  padding: 0;
  background: transparent;
  cursor: pointer;
}

.compact-contact-stats {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 12px;
}

.contact-filter-toolbar {
  justify-content: space-between;
  margin-bottom: 12px;
}

.contact-toolbar-right {
  width: min(100%, 640px);
  justify-content: flex-end;
}

.contact-warning {
  margin-bottom: 12px;
}

.contact-name-cell {
  display: flex;
  align-items: center;
  gap: 12px;
}

.contact-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  flex: 0 0 40px;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #e8eefc;
  color: #3559d5;
  font-weight: 700;
}

.contact-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.contact-toolbar-right input,
.contact-toolbar-right select {
  min-width: 0;
}

.address-panel {
  display: grid;
  gap: 12px;
}

.address-panel label {
  display: grid;
  gap: 8px;
  font-size: 14px;
  font-weight: 600;
  color: #344054;
}

.address-panel-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.extra-addresses-panel {
  margin-top: 18px;
  border: 1px solid #e4e7ec;
  border-radius: 18px;
  background: #fbfdff;
  padding: 18px;
}

.extra-addresses-panel .section-head {
  margin-bottom: 14px;
}

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

.notes-form textarea {
  width: 100%;
  padding: 12px;
  border: 1px solid #d0d5dd;
  border-radius: 12px;
  font: inherit;
}

.note-stream {
  display: grid;
  gap: 10px;
}

.note-entry {
  padding: 14px 16px;
  border: 1px solid #e4e7ec;
  border-radius: 14px;
  background: #fafbfc;
  white-space: pre-wrap;
  color: #344054;
}

.lead-filter-card {
  display: none;
  margin-bottom: 18px;
}

.lead-filter-card.is-open {
  display: block;
}

.lead-filter-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px 18px;
}

.lead-filter-grid label {
  display: grid;
  gap: 8px;
  color: #344054;
  font-size: 14px;
  font-weight: 600;
}

.lead-filter-actions {
  display: flex;
  align-items: end;
  gap: 10px;
}

.perfex-view-toggle {
  display: inline-flex;
  gap: 8px;
}

.perfex-view-toggle .light-btn.is-active {
  background: #1f2937;
  color: #fff;
  border-color: #1f2937;
}

.lead-toolbar-summary {
  color: #667085;
  font-weight: 600;
}

.lead-board {
  display: flex;
  flex-wrap: nowrap;
  gap: 14px;
  align-items: flex-start;
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 10px;
  scrollbar-width: thin;
  overscroll-behavior-x: contain;
}

.lead-column {
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid #dbe3ee;
  border-radius: 14px;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.05);
  display: grid;
  flex: 0 0 390px;
  width: 390px;
  max-width: 390px;
  min-height: 340px;
  overflow: hidden;
  transition: border-color 140ms ease, box-shadow 140ms ease, transform 140ms ease, background 140ms ease;
}

.lead-column-head {
  padding: 12px 14px;
  color: #fff;
}

.lead-column-head.is-blue {
  background: #4f7cff;
}

.lead-column-head.is-teal {
  background: #48a7a2;
}

.lead-column-head.is-green {
  background: #37a15a;
}

.lead-column-head.is-slate {
  background: #6b7280;
}

.lead-column-head.is-amber {
  background: #d97706;
}

.lead-column-head h3 {
  margin: 0;
  font-size: 16px;
  color: #fff;
}

.lead-column-meta {
  margin-top: 2px;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.9);
}

.lead-column-body {
  padding: 12px;
  display: grid;
  gap: 10px;
  align-content: start;
  min-height: 250px;
  background: #f3f6fb;
  position: relative;
  transition: background 140ms ease;
}

.lead-column-body.is-drop-target {
  background: linear-gradient(180deg, #eef4ff 0%, #f7faff 100%);
}

.lead-column.is-drop-zone-active {
  border-color: #5b7cff;
  box-shadow: 0 18px 36px rgba(67, 97, 238, 0.14), 0 0 0 2px rgba(91, 124, 255, 0.12);
}

.lead-column.is-drop-zone-active .lead-column-head {
  box-shadow: inset 0 -2px 0 rgba(255, 255, 255, 0.25);
}

.lead-column-body.is-drop-target::before {
  content: "Drop lead here";
  position: absolute;
  inset: 10px;
  border: 2px dashed rgba(91, 124, 255, 0.35);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #3559d5;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: rgba(255, 255, 255, 0.72);
  pointer-events: none;
  z-index: 1;
}

.lead-column-empty {
  border: 1px dashed #d0d5dd;
  border-radius: 14px;
  padding: 18px;
  color: #98a2b3;
  text-align: center;
  background: #fbfcfe;
}

.lead-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid #dde4ee;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.04);
  transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;
}

.lead-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.07);
  border-color: #c8d6ea;
}

.lead-card.is-active {
  border-color: #5b7cff;
  box-shadow: 0 0 0 2px rgba(91, 124, 255, 0.12);
}

.lead-card.is-dragging {
  opacity: 0.38;
  transform: rotate(1.5deg) scale(0.985);
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.16);
  border-color: #7c95ff;
}

body.is-dragging-lead .lead-card:not(.is-dragging) {
  opacity: 0.92;
}

.lead-card-top {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: start;
}

.task-board {
  margin-top: 2px;
}

.task-column {
  min-height: 300px;
}

.task-column-head {
  background: #475467;
}

.task-card {
  text-decoration: none;
  color: inherit;
}

.task-card .lead-card-title,
.task-card .lead-card-company,
.task-card .lead-card-meta,
.task-card .lead-card-footer,
.task-card .mini-chip-row {
  color: inherit;
}

.lead-card-title {
  font-size: 14px;
  font-weight: 800;
  color: #101828;
  line-height: 1.35;
}

.lead-card-company {
  margin-top: 2px;
  color: #667085;
  font-size: 12px;
  line-height: 1.4;
}

.lead-avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #e8eefc;
  color: #3559d5;
  font-weight: 800;
  flex: 0 0 auto;
  overflow: hidden;
}

.lead-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.saas-home-builder {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 20px;
  align-items: start;
}

.saas-home-builder-list,
.saas-home-builder-preview-shell,
.saas-home-builder-editor {
  background: #f8fbff;
  border: 1px solid #dbe7f5;
  border-radius: 24px;
  padding: 18px;
}

.saas-home-builder-main {
  display: grid;
  gap: 18px;
}

.saas-home-builder-list,
.saas-home-builder-editor {
  position: sticky;
  top: 24px;
}

.saas-home-builder-list-inner {
  display: grid;
  gap: 10px;
}

.saas-home-section-card {
  border: 1px solid #dbe7f5;
  border-radius: 18px;
  background: #fff;
  padding: 12px;
  display: grid;
  gap: 10px;
}

.saas-home-section-card.is-active {
  border-color: #88aef9;
  box-shadow: 0 0 0 3px rgba(88, 132, 255, 0.12);
}

.saas-home-section-select {
  border: 0;
  background: transparent;
  text-align: left;
  display: grid;
  gap: 4px;
  padding: 0;
  color: #13203a;
  width: 100%;
}

.saas-home-section-select span {
  color: #6f7f98;
  font-size: 0.92rem;
}

.saas-home-section-controls {
  display: flex;
  gap: 8px;
}

.saas-home-preview-head {
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.saas-home-preview-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.saas-home-preview-devices {
  display: flex;
  gap: 6px;
}

.saas-home-preview-devices .tiny.is-active {
  background: #1d2436;
  color: #fff;
  border-color: #1d2436;
}

.light-btn.tiny {
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
}

.saas-home-builder-preview {
  min-height: 900px;
}

.saas-home-preview-stage {
  background: linear-gradient(180deg, #edf4fb 0%, #f8fbff 100%);
  border: 1px solid #dbe7f5;
  border-radius: 28px;
  padding: 20px;
  min-height: 860px;
  overflow: auto;
}

.saas-home-preview-canvas {
  width: min(100%, 1060px);
  margin: 0 auto;
  display: grid;
  gap: 18px;
}

.saas-home-builder-preview[data-preview-device="tablet"] .saas-home-preview-canvas {
  width: min(100%, 820px);
}

.saas-home-builder-preview[data-preview-device="mobile"] .saas-home-preview-canvas {
  width: min(100%, 430px);
}

.saas-home-preview-card {
  background: #fff;
  border: 1px solid #dbe7f5;
  border-radius: 24px;
  padding: 24px;
  display: grid;
  gap: 12px;
}

.saas-home-preview-hero {
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
  gap: 22px;
  align-items: stretch;
}

.saas-home-builder-preview[data-preview-device="mobile"] .saas-home-preview-hero,
.saas-home-builder-preview[data-preview-device="tablet"] .saas-home-preview-hero {
  grid-template-columns: 1fr;
}

.saas-home-preview-hero-copy {
  display: grid;
  gap: 14px;
}

.saas-home-preview-hero-copy h2 {
  font-size: clamp(2rem, 4vw, 4rem);
  line-height: 0.98;
  margin: 0;
}

.saas-home-preview-hero-media {
  display: grid;
  gap: 10px;
}

.saas-home-preview-video {
  min-height: 320px;
  border-radius: 26px;
  background: linear-gradient(180deg, #111625 0%, #141b2d 100%);
  position: relative;
  overflow: hidden;
}

.saas-home-preview-video::before {
  content: "";
  position: absolute;
  inset: 18% 12%;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(243,247,252,0.98));
  box-shadow: 0 24px 50px rgba(26, 36, 56, 0.18);
}

.saas-home-preview-video::after {
  content: "";
  position: absolute;
  inset: 32% 24%;
  border-radius: 12px;
  border: 2px solid #d9e4f2;
  box-shadow: 0 -44px 0 0 #fff, 0 -40px 0 0 #dfe8f5;
}

.saas-home-preview-hero-media span {
  color: #6f7f98;
  font-size: 0.9rem;
}

.saas-home-preview-mini-list {
  display: grid;
  gap: 10px;
}

.saas-home-preview-mini-list > div {
  background: #fbfdff;
  border: 1px solid #dbe7f5;
  border-radius: 18px;
  padding: 14px 16px;
  display: grid;
  gap: 6px;
}

.saas-home-preview-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
}

.saas-home-preview-grid > div {
  background: #f8fbff;
  border: 1px solid #dbe7f5;
  border-radius: 18px;
  padding: 14px;
  display: grid;
  gap: 6px;
}

.saas-home-preview-grid span {
  color: #6f7f98;
  font-size: 0.92rem;
}

.saas-home-preview-pricing {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.saas-home-preview-pricing > div {
  background: #f8fbff;
  border: 1px solid #dbe7f5;
  border-radius: 18px;
  padding: 16px;
  display: grid;
  gap: 6px;
}

.saas-home-preview-pricing span {
  color: #6f7f98;
}

.saas-home-builder-editor {
  display: grid;
  gap: 12px;
}

.saas-home-editor-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.public-marketing-body {
  background: linear-gradient(180deg, color-mix(in srgb, var(--bg) 92%, white) 0%, color-mix(in srgb, var(--card) 92%, transparent) 100%);
  min-height: 100vh;
}

.public-page-shell {
  max-width: 1400px;
  margin: 0 auto;
  padding: 28px;
}

.public-site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(18px);
  background: var(--public-header-bg);
  border-bottom: 1px solid var(--public-header-border);
}

.public-site-header-inner {
  width: min(1400px, calc(100% - 40px));
  margin: 0 auto;
  min-height: 78px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.public-site-brand {
  display: inline-flex;
  align-items: center;
  color: var(--public-header-ink);
}

.public-site-brand strong {
  font-size: 24px;
  letter-spacing: -0.05em;
}

.saas-home-builder-editor label {
  display: grid;
  gap: 6px;
}

.saas-home-editor-subcard {
  background: #fff;
  border: 1px solid #dbe7f5;
  border-radius: 18px;
  padding: 14px;
  display: grid;
  gap: 10px;
}

@media (max-width: 1180px) {
  .saas-feature-grid,
  .saas-proof-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .saas-proof-layout {
    grid-template-columns: 1fr;
  }

  .saas-home-builder {
    grid-template-columns: 1fr;
  }

  .saas-home-builder-list,
  .saas-home-builder-editor {
    position: static;
  }

  .saas-feature-card.is-wide {
    grid-column: auto;
  }
}

@media (max-width: 760px) {
  .saas-hero-split,
  .saas-feature-grid,
  .saas-proof-grid,
  .setup-saas-plan-grid {
    grid-template-columns: 1fr;
  }

  .saas-hero-copy h1,
  .saas-proof-story h2,
  .saas-feature-card h3 {
    font-size: clamp(32px, 10vw, 44px);
  }

  .saas-hero-clean {
    padding: 30px 22px 26px;
  }

  .saas-page-nav {
    justify-content: flex-start;
    padding: 16px 18px;
    top: 10px;
  }

  .saas-page-nav .saas-page-nav-cta {
    margin-left: 0;
  }
}

.lead-card-meta {
  display: grid;
  gap: 6px;
}

.lead-card-meta-row,
.lead-overview-grid > div {
  display: grid;
  gap: 6px;
  align-items: start;
}

.lead-card-meta strong,
.lead-overview-grid strong,
.lead-description-block strong {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #667085;
}

.lead-card-meta span,
.lead-overview-grid span {
  color: #101828;
  line-height: 1.4;
  min-width: 0;
}

.lead-card-footer {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding-top: 6px;
  border-top: 1px solid #eef2f6;
  color: #667085;
  font-size: 12px;
  font-weight: 600;
}

.lead-kanban-toolbar-card {
  padding: 14px 18px;
}

.lead-kanban-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
}

.lead-kanban-sortline {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  color: #667085;
  font-size: 14px;
}

.lead-kanban-sortline a {
  color: #3157df;
  font-weight: 600;
}

.lead-kanban-search {
  width: min(100%, 280px);
}

.lead-kanban-search input {
  width: 100%;
}

.lead-workspace-modal {
  width: min(1120px, calc(100% - 36px));
}

.lead-labels-modal-card {
  width: min(1160px, calc(100% - 40px));
}

.lead-labels-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 18px;
}

.lead-labels-summary-card {
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  padding: 16px 18px;
  display: grid;
  gap: 4px;
}

.lead-labels-summary-card strong {
  font-size: 24px;
  line-height: 1;
  color: #111827;
}

.lead-labels-summary-card span {
  color: #667085;
  font-size: 13px;
  font-weight: 600;
}

.lead-labels-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 20px;
  align-items: start;
}

.lead-labels-section {
  border: 1px solid #e5e7eb;
  border-radius: 20px;
  background: #fbfcfe;
  padding: 18px;
  min-width: 0;
}

.lead-labels-section-head {
  margin-bottom: 14px;
}

.lead-labels-section-head h3 {
  margin: 0 0 4px;
  font-size: 20px;
  color: #111827;
}

.lead-label-list {
  display: grid;
  gap: 12px;
}

.lead-label-row {
  display: grid;
  grid-template-columns: minmax(150px, 170px) minmax(0, 1fr) 112px;
  gap: 14px;
  align-items: end;
  padding: 14px;
  border: 1px solid #dbe4ef;
  border-radius: 16px;
  background: #fff;
}

.lead-source-row {
  grid-template-columns: minmax(150px, 170px) minmax(0, 1fr);
}

.lead-label-row-new {
  border-style: dashed;
  background: #f8fbff;
}

.lead-label-meta {
  display: grid;
  gap: 8px;
  align-self: center;
}

.lead-code-pill,
.lead-usage-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.02em;
}

.lead-code-pill {
  border: 1px solid #cdd7e3;
  background: #f8fafc;
  color: #334155;
}

.lead-code-pill-new {
  border-color: #b7c6da;
  background: #eef4ff;
  color: #3157df;
}

.lead-usage-pill {
  border: 1px solid #d9f0e5;
  background: #f0faf5;
  color: #18794e;
}

.lead-label-field,
.lead-color-field {
  display: grid;
  gap: 8px;
}

.lead-label-field span,
.lead-color-field span {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #667085;
}

.lead-label-field-code {
  max-width: 180px;
}

.lead-label-row input[type="text"] {
  width: 100%;
}

.lead-color-field {
  justify-items: start;
}

.lead-color-field input[type="color"] {
  width: 72px;
  height: 52px;
  border: 1px solid #d0d5dd;
  border-radius: 14px;
  padding: 6px;
  background: #fff;
  cursor: pointer;
}

.lead-label-actions {
  justify-content: flex-start;
  padding: 16px 0 0;
  border-top: 0;
}

.email-log-table {
  min-width: 1480px;
}

.email-log-table th:nth-child(1),
.email-log-table td:nth-child(1) {
  width: 72px;
}

.email-log-table th:nth-child(2),
.email-log-table td:nth-child(2) {
  width: 96px;
}

.email-log-table th:nth-child(3),
.email-log-table td:nth-child(3) {
  width: 240px;
}

.email-log-table th:nth-child(4),
.email-log-table td:nth-child(4) {
  width: 260px;
}

.email-log-table th:nth-child(5),
.email-log-table td:nth-child(5) {
  width: 340px;
}

.email-log-table th:nth-child(6),
.email-log-table td:nth-child(6) {
  width: 150px;
}

.email-log-table th:nth-child(7),
.email-log-table td:nth-child(7) {
  width: 380px;
}

.email-log-table th:nth-child(8),
.email-log-table td:nth-child(8) {
  width: 170px;
}

.email-log-table th:nth-child(9),
.email-log-table td:nth-child(9) {
  width: 110px;
}

.email-log-table th:nth-child(10),
.email-log-table td:nth-child(10) {
  width: 84px;
  text-align: center;
}

.email-log-table .sortable-header {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: max-content;
  white-space: nowrap;
}

.email-log-table th:nth-child(10) .sortable-header {
  justify-content: center;
}

.category-directory-page .perfex-page-head-inline {
  margin-bottom: 12px;
}

.category-directory-table th:nth-child(1),
.category-directory-table td:nth-child(1) {
  width: 30%;
}

.category-directory-table th:nth-child(2),
.category-directory-table td:nth-child(2) {
  width: 48%;
}

.category-directory-table th:nth-child(3),
.category-directory-table td:nth-child(3) {
  width: 12%;
}

.category-directory-table th:nth-child(4),
.category-directory-table td:nth-child(4) {
  width: 10%;
}

.subcategory-directory-table th:nth-child(1),
.subcategory-directory-table td:nth-child(1) {
  width: 30%;
}

.subcategory-directory-table th:nth-child(2),
.subcategory-directory-table td:nth-child(2) {
  width: 22%;
}

.subcategory-directory-table th:nth-child(3),
.subcategory-directory-table td:nth-child(3) {
  width: 30%;
}

.subcategory-directory-table th:nth-child(4),
.subcategory-directory-table td:nth-child(4) {
  width: 8%;
}

.subcategory-directory-table th:nth-child(5),
.subcategory-directory-table td:nth-child(5) {
  width: 10%;
}

.category-directory-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

.category-directory-actions form {
  margin: 0;
}

.category-directory-meta {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding-top: 14px;
  color: #667085;
  font-size: 14px;
  font-weight: 600;
}

.category-edit-modal {
  width: min(640px, calc(100% - 32px));
}

.radio-row {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  align-items: center;
}

.lead-modal-tabs {
  display: flex;
  gap: 20px;
  padding: 14px 22px;
  border-bottom: 1px solid #eaecf0;
  font-size: 14px;
  font-weight: 700;
  color: #667085;
}

.lead-modal-tabs .active {
  color: #111827;
}

.lead-workspace-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
  gap: 20px;
}

.lead-overview-panel,
.lead-side-card {
  border: 1px solid #e5e7eb;
  border-radius: 18px;
  background: #fff;
  padding: 18px;
}

.lead-overview-top {
  display: flex;
  gap: 8px;
  margin-bottom: 16px;
  flex-wrap: wrap;
  align-items: center;
}

.lead-overview-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px 18px;
}

.lead-overview-grid > div {
  padding: 14px 16px;
  border: 1px solid #eef2f6;
  border-radius: 14px;
  background: linear-gradient(180deg, #fbfcfe 0%, #f8fafc 100%);
}

.lead-description-block {
  margin-top: 18px;
  display: grid;
  gap: 8px;
  padding: 16px 18px;
  border: 1px solid #eef2f6;
  border-radius: 16px;
  background: linear-gradient(180deg, #fcfdff 0%, #f7fafc 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.lead-description-block p {
  margin: 0;
  color: #344054;
  line-height: 1.6;
  white-space: pre-wrap;
}

.lead-profile-lower-grid {
  margin-top: 18px;
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(260px, 0.65fr);
  gap: 16px;
  align-items: start;
}

.lead-profile-main-stack,
.lead-profile-aside-stack {
  display: grid;
  gap: 16px;
}

.lead-profile-lower-grid .lead-description-block {
  margin-top: 0;
}

.lead-description-block-accent {
  background:
    radial-gradient(circle at top right, rgba(59, 130, 246, 0.08), transparent 38%),
    linear-gradient(180deg, #fcfdff 0%, #f6f9ff 100%);
}

.lead-marketing-status-list {
  display: grid;
  gap: 10px;
}

.lead-marketing-status-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid #e6ecf2;
}

.lead-marketing-status-item span:first-child {
  color: #101828;
  font-weight: 600;
}

.lead-status-picker-inline .lead-status-chip {
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 700;
}

.lead-side-panel {
  display: grid;
  gap: 16px;
}

.custom-field-manager-cell {
  padding: 18px 20px;
}

.custom-field-manager-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(120px, 1fr));
  gap: 14px;
  align-items: start;
}

@media (max-width: 1100px) {
  .lead-labels-grid {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 760px) {
  .lead-labels-summary {
    grid-template-columns: minmax(0, 1fr);
  }

  .lead-label-row,
  .lead-source-row {
    grid-template-columns: minmax(0, 1fr);
  }

  .lead-label-field-code {
    max-width: none;
  }
}

.custom-field-manager-grid .full-span {
  grid-column: 1 / -1;
}

.compact-checkline {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
}

.inline-delete-form {
  margin-top: 10px;
}

.danger-link-btn {
  color: #b42318;
  border-color: #fda29b;
}

.lead-side-card h3 {
  margin: 0 0 12px;
  font-size: 18px;
}

.lead-side-list {
  display: grid;
  gap: 12px;
}

.lead-side-list-item {
  display: grid;
  gap: 6px;
  padding: 14px 16px;
  border-radius: 16px;
  background: linear-gradient(180deg, #fcfdff 0%, #f8fafc 100%);
  border: 1px solid #e6ecf2;
  transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.lead-side-list-item:hover {
  border-color: #d4dce5;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
  transform: translateY(-1px);
}

.lead-side-list-item strong {
  color: #101828;
}

.lead-side-list-item span {
  color: #667085;
  font-size: 13px;
  line-height: 1.5;
}

.lead-side-card-emphasis {
  padding: 20px;
  background:
    radial-gradient(circle at top right, rgba(15, 118, 110, 0.06), transparent 36%),
    #fff;
}

.lead-side-card-emphasis h3,
.lead-side-card-emphasis .section-head {
  padding-bottom: 12px;
  border-bottom: 1px solid #eef2f6;
  margin-bottom: 14px;
}

.shared-files-shell {
  padding: 0;
  overflow: hidden;
}

.shared-files-head {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 16px;
  padding: 22px 24px;
  border-bottom: 1px solid #eaecf0;
  background: linear-gradient(180deg, #f8fafc 0, #ffffff 100%);
}

.shared-files-provider {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 800;
  color: #64748b;
  margin-bottom: 8px;
}

.shared-files-head h2 {
  margin: 0;
  font-size: 26px;
}

.shared-files-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

.shared-files-embed {
  background: #fff;
  min-height: 640px;
}

.shared-files-embed iframe {
  width: 100%;
  min-height: 640px;
  border: 0;
  display: block;
  background: #fff;
}

.shared-files-raw-html {
  padding: 18px;
}

.shared-files-raw-html iframe {
  width: 100%;
  min-height: 640px;
  border: 0;
  display: block;
}

.shared-files-dropbox-container {
  min-height: 640px;
  padding: 18px;
  background: #fff;
}

.shared-files-dropbox-container iframe {
  width: 100%;
  min-height: 600px;
  border: 0;
  display: block;
}

.shared-files-unavailable {
  padding: 28px 24px 30px;
  display: grid;
  gap: 14px;
}

.shared-files-unavailable h3 {
  margin: 0;
  font-size: 22px;
}

.shared-files-unavailable p {
  margin: 0;
  max-width: 760px;
  color: #667085;
  line-height: 1.6;
}

.compact-products-shell {
  display: grid;
  gap: 14px;
}

.products-filter-panel {
  display: grid;
  gap: 14px;
  padding: 18px;
  background: linear-gradient(180deg, #ffffff 0, #fbfdff 100%);
  border-color: #d8e2ee;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

[data-theme="dark"] .products-filter-panel {
  background: linear-gradient(180deg, rgba(18, 26, 47, 0.96) 0%, rgba(14, 21, 39, 0.98) 100%);
  border-color: rgba(132, 154, 191, 0.18);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

.products-filter-grid label {
  display: grid;
  gap: 8px;
}

.products-filter-grid label span {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #64748b;
}

[data-theme="dark"] .products-filter-grid label span {
  color: rgba(161, 181, 214, 0.76);
}

.products-filter-grid select {
  width: 100%;
  min-height: 52px;
  padding: 0 16px;
  border: 1px solid #cfdae7;
  border-radius: 16px;
  background: #fff;
  color: #1f2937;
  font-size: 15px;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

[data-theme="dark"] .products-filter-grid select {
  border-color: rgba(132, 154, 191, 0.2);
  background: rgba(16, 24, 43, 0.96);
  color: #eef4ff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

.products-filter-grid select:focus {
  outline: none;
  border-color: rgba(15, 118, 110, 0.45);
  box-shadow: 0 0 0 4px rgba(15, 118, 110, 0.08);
}

[data-theme="dark"] .products-filter-grid select:focus {
  border-color: rgba(115, 207, 196, 0.55);
  box-shadow: 0 0 0 4px rgba(82, 170, 157, 0.14);
}

.products-filter-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.products-filter-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: flex-start;
}

.products-filter-actions .ghost-btn,
.products-filter-actions .primary-btn {
  min-height: 46px;
}

.products-table-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.products-table-head .button-row {
  align-items: center;
  flex-wrap: wrap;
}

.products-table-search {
  min-width: min(380px, 100%);
}

.products-table-search input {
  width: 100%;
  min-height: 46px;
  padding: 0 16px;
  border: 1px solid #cfdae7;
  border-radius: 16px;
  background: #fff;
  color: #1f2937;
  font-size: 15px;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.products-table-search input:focus {
  outline: none;
  border-color: rgba(15, 118, 110, 0.45);
  box-shadow: 0 0 0 4px rgba(15, 118, 110, 0.08);
}

.products-admin-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}

.products-topline-meta {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  flex-wrap: wrap;
}

.products-table-head {
  margin-bottom: 12px;
}

.products-slide-panel {
  display: none;
  margin-bottom: 16px;
  padding: 16px;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  background: #fbfcfe;
}

.products-slide-panel.is-open {
  display: block;
}

.products-table-wrap th:first-child,
.products-table-wrap td:first-child {
  width: 56px;
  padding-inline: 16px;
  text-align: center;
  vertical-align: middle;
}

.products-table-wrap input[type="checkbox"] {
  width: 28px;
  height: 28px;
  margin: 0;
  accent-color: #4f7cff;
  cursor: pointer;
}

.products-pagination-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.products-pagination-form {
  display: flex;
  align-items: end;
  gap: 12px;
  flex-wrap: wrap;
}

.products-pagination-form label {
  display: grid;
  gap: 6px;
}

.products-pagination-form select,
.products-pagination-form input {
  min-width: 84px;
  padding: 10px 12px;
  border: 1px solid #d0d5dd;
  border-radius: 10px;
  background: #fff;
  font: inherit;
  color: #111827;
}

.products-pagination-form input {
  width: 110px;
}

.products-pagination-links {
  flex-wrap: wrap;
}

@media (max-width: 1080px) {
  .products-filter-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .products-table-search {
    min-width: 100%;
  }
}

@media (max-width: 1200px) {
  .perfex-stats-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .messaging-split-grid {
    grid-template-columns: 1fr;
  }

  .po-detail-grid,
  .po-filter-grid,
  .po-totals-grid,
  .po-workspace-grid,
  .lead-filter-grid,
  .lead-workspace-grid,
  .lead-overview-grid,
  .lead-profile-lower-grid {
    grid-template-columns: 1fr;
  }

  .customer-detail-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1480px) {
  .po-workspace-grid {
    grid-template-columns: minmax(0, 1fr) minmax(380px, 440px);
  }
}

@media (max-width: 820px) {
  .perfex-stats-row,
  .profile-form-grid,
  .perfex-filter-form,
  .po-search-form {
    grid-template-columns: 1fr;
  }

  .perfex-filter-form,
  .po-search-form {
    flex-direction: column;
    align-items: stretch;
  }

  .perfex-filter-form input,
  .perfex-filter-form select,
  .po-search-form input,
  .po-search-form select {
    min-width: 0;
  }

  .perfex-filter-form-wide {
    grid-template-columns: 1fr;
  }

  .perfex-actions-row,
  .perfex-toolbar,
  .perfex-toolbar-left,
  .perfex-toolbar-right,
  .customer-detail-head,
  .profile-tabs,
  .perfex-pagination,
  .lead-filter-actions,
  .lead-stage-form,
  .shared-files-head {
    flex-direction: column;
    align-items: stretch;
  }

  .po-item-picker-row,
  .po-address-preview,
  .po-total-row,
  .po-total-edit,
  .po-number-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 980px) {
  .po-view-card {
    position: static;
    max-height: none;
  }

  .po-view-document,
  .po-tab-pane {
    overflow-y: visible;
  }

  .po-view-header {
    grid-template-columns: 1fr;
  }

  .po-view-meta {
    max-width: none;
    margin-left: 0;
    text-align: left;
  }

  .po-view-number {
    max-width: none;
  }

  .po-view-summary {
    grid-template-columns: 1fr;
  }

  .po-inline-form-grid {
    grid-template-columns: 1fr;
  }

  .page-shell-po .po-search-form {
    justify-content: stretch;
  }
}

.module-shell {
  display: grid;
  gap: 1.25rem;
}

.module-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.module-head__title h1 {
  margin: 0 0 0.3rem;
  font-size: 2rem;
}

.module-head__title p {
  margin: 0;
  color: #667085;
}

.module-head__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.module-head__actions .ghost-btn.active {
  background: #20273a;
  color: #fff;
}

.perfex-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

.perfex-stat-card {
  background: #fff;
  border: 1px solid #e4e7ec;
  border-radius: 16px;
  padding: 1rem 1.1rem;
}

.perfex-stat-card span {
  display: block;
  margin-bottom: 0.35rem;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #667085;
}

.perfex-stat-card strong {
  font-size: 1.35rem;
}

.perfex-stat-card.alert {
  border-color: rgba(199, 62, 62, 0.35);
}

.perfex-panel {
  padding: 1.1rem;
}

.perfex-filter-grid {
  display: grid;
  grid-template-columns: minmax(220px, 2fr) repeat(4, minmax(140px, 1fr)) auto auto;
  gap: 0.75rem;
  align-items: center;
  width: 100%;
}

.inline-create-panel {
  min-width: 360px;
}

.inline-create-panel > summary {
  list-style: none;
  cursor: pointer;
}

.inline-create-panel > summary::-webkit-details-marker {
  display: none;
}

.perfex-table th,
.perfex-table td {
  vertical-align: top;
}

.trip-day-card textarea {
  min-height: 10rem;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
}

.trip-appointment-table {
  display: grid;
  gap: 14px;
}

.trip-appointment-head,
.trip-appointment-row {
  display: grid;
  grid-template-columns: 160px minmax(220px, 1.2fr) minmax(220px, 1fr) minmax(240px, 1.1fr) 56px;
  gap: 14px;
  align-items: start;
}

.trip-appointment-head {
  padding: 0 2px;
  color: #667085;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.trip-appointment-list {
  display: grid;
  gap: 14px;
}

.trip-appointment-row {
  padding: 16px;
  border: 1px dashed #d8e1ec;
  border-radius: 16px;
  background: #fbfdff;
}

.trip-native-control {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 1px;
  height: 1px;
}

.trip-search-picker,
.trip-contact-picker {
  position: relative;
  display: grid;
}

.trip-search-shell {
  min-height: 56px;
  border: 1px solid #d7dfeb;
  border-radius: 22px;
  background: #fff;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px 8px 16px;
  transition: border-color 0.16s ease, box-shadow 0.16s ease;
}

.trip-search-picker.is-open .trip-search-shell,
.trip-contact-picker.is-open .trip-search-shell {
  border-color: #7ac8be;
  box-shadow: 0 0 0 4px rgba(60, 168, 157, 0.12);
}

.trip-search-shell input[type="search"] {
  width: 100%;
  border: 0;
  background: transparent;
  padding: 0;
  min-width: 0;
  box-shadow: none;
}

.trip-search-shell input[type="search"]:focus {
  outline: none;
  box-shadow: none;
}

.trip-search-shell input[type="search"]::-webkit-search-cancel-button {
  display: none;
}

.trip-picker-toggle {
  width: 36px;
  height: 36px;
  border: 0;
  border-radius: 12px;
  background: transparent;
  color: #667085;
  font-size: 0.92rem;
  cursor: pointer;
  flex: 0 0 auto;
}

.trip-picker-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  z-index: 20;
  display: none;
  max-height: 280px;
  overflow: auto;
  border: 1px solid #d7dfeb;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 18px 36px rgba(15, 23, 42, 0.12);
  padding: 8px;
}

.trip-search-picker.is-open .trip-picker-menu,
.trip-contact-picker.is-open .trip-picker-menu {
  display: grid;
}

.trip-picker-option,
.trip-check-option {
  width: 100%;
  border: 0;
  background: transparent;
  color: #1f2937;
  text-align: left;
  border-radius: 12px;
}

.trip-picker-option {
  padding: 11px 12px;
  cursor: pointer;
  font: inherit;
}

.trip-picker-option:hover,
.trip-picker-option.is-selected,
.trip-check-option:hover {
  background: #f2f7fb;
}

.trip-picker-empty {
  padding: 12px 14px;
  color: #667085;
  font-size: 0.94rem;
}

.trip-multi-shell {
  flex-wrap: wrap;
  align-items: center;
  row-gap: 8px;
  column-gap: 8px;
  padding-right: 8px;
}

.trip-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  flex: 1 1 auto;
  min-width: 0;
}

.trip-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: #eef3fb;
  color: #1f2937;
  font-size: 0.95rem;
  font-weight: 600;
}

.trip-chip button {
  border: 0;
  background: transparent;
  color: #475467;
  cursor: pointer;
  font-size: 1rem;
  line-height: 1;
  padding: 0;
}

.trip-multi-shell input[type="search"] {
  flex: 1 1 120px;
  min-width: 120px;
}

.trip-picker-menu--checks {
  gap: 2px;
}

.trip-check-option {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 12px;
  cursor: pointer;
}

.trip-check-option input[type="checkbox"] {
  width: 20px;
  height: 20px;
  margin: 0;
  flex: 0 0 auto;
}

.trip-check-option span {
  min-width: 0;
  line-height: 1.35;
}

.trip-row-delete {
  min-height: 48px;
  align-self: center;
}

.trip-print-body {
  margin: 0;
  background: #eef2f7;
  color: #253046;
  font-family: "Avenir Next", "Segoe UI", sans-serif;
}

.trip-print-sheet {
  width: 980px;
  margin: 18px auto;
  background: #fff;
  border-radius: 12px;
  padding: 26px 28px 30px;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
}

.trip-print-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 20px;
  padding-bottom: 10px;
}

.trip-print-brand-block {
  display: grid;
  gap: 4px;
}

.trip-print-kicker {
  color: #8ca0bf;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.trip-print-logo {
  font-size: 20px;
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #2f3d59;
}

.trip-print-date-range {
  color: #6b7280;
  font-size: 12px;
  font-weight: 600;
}

.trip-print-badge {
  padding: 10px 18px;
  background: #0f1320;
  color: #fff;
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.04em;
}

.trip-print-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 10px;
  border: 1px solid #dce3ef;
}

.trip-print-summary-cell {
  min-height: 64px;
  padding: 10px 12px;
  border-right: 1px solid #dce3ef;
  border-bottom: 1px solid #dce3ef;
  background: #fff;
}

.trip-print-summary-cell:nth-child(4n) {
  border-right: 0;
}

.trip-print-summary-cell span {
  display: block;
  color: #8a94a8;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.trip-print-summary-cell strong {
  display: block;
  margin-top: 6px;
  color: #2f3d59;
  font-size: 14px;
  line-height: 1.35;
}

.trip-print-block {
  border: 1px solid #dce3ef;
}

.trip-print-section-bar {
  padding: 6px 12px;
  background: #38435c;
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.trip-print-section-bar--success {
  background: #4f7a63;
}

.trip-print-section-body {
  padding: 12px;
  background: #fff;
  font-size: 14px;
  line-height: 1.45;
}

.trip-print-section-body > div + div {
  margin-top: 4px;
}

.trip-print-meetings {
  padding: 0 0 8px;
  background: #fff;
}

.trip-print-day {
  margin-top: 0;
}

.trip-print-day-head {
  padding: 10px 12px 6px;
  color: #3a4762;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.trip-print-table {
  width: 100%;
  border-collapse: collapse;
  border: 0;
}

.trip-print-table thead th {
  background: #dfe7fb;
  color: #4a5877;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 8px 12px;
  text-align: left;
  border-top: 1px solid #dce3ef;
  border-bottom: 1px solid #dce3ef;
}

.trip-print-table td {
  padding: 8px 12px;
  border-top: 1px solid #e9eef6;
  vertical-align: top;
  font-size: 13px;
  line-height: 1.35;
}

.trip-print-table tbody tr:nth-child(even) {
  background: #fbfcff;
}

.trip-visit-sheet {
  width: 980px;
  min-height: 1340px;
  margin: 18px auto;
  background: #fff;
  padding: 18px 22px 28px;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08);
  page-break-before: always;
  break-before: page;
}

.trip-visit-header {
  display: grid;
  gap: 2px;
  margin-bottom: 12px;
}

.trip-visit-title {
  color: #31415f;
  font-size: 17px;
  font-weight: 800;
}

.trip-visit-subtitle {
  color: #67748b;
  font-size: 11px;
}

.trip-visit-meta {
  display: grid;
  grid-template-columns: 2fr 1fr 1.2fr;
  border: 1px solid #dde5f1;
  margin-bottom: 12px;
}

.trip-visit-meta-cell {
  min-height: 52px;
  padding: 7px 10px 8px;
  border-right: 1px solid #dde5f1;
}

.trip-visit-meta-cell:last-child {
  border-right: 0;
}

.trip-visit-meta-cell span,
.trip-visit-label {
  display: block;
  color: #6f7f98;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.trip-visit-meta-cell strong {
  display: block;
  margin-top: 5px;
  color: #2f3d59;
  font-size: 12px;
  font-weight: 700;
}

.trip-visit-block {
  margin-bottom: 10px;
  border: 1px solid #dde5f1;
}

.trip-visit-label {
  padding: 6px 10px;
  background: #eef3fb;
  border-bottom: 1px solid #dde5f1;
}

.trip-visit-label--plain {
  background: transparent;
  border-bottom: 0;
  padding: 0 0 10px;
}

.trip-visit-body {
  min-height: 56px;
  padding: 9px 10px 10px;
  color: #2f3d59;
  font-size: 12px;
  line-height: 1.4;
}

.trip-visit-body strong {
  display: block;
  margin-bottom: 2px;
}

.trip-visit-contact + .trip-visit-contact {
  margin-top: 10px;
}

.trip-visit-notes-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 12px;
}

.trip-visit-notes-box {
  border: 1px solid #dde5f1;
  padding: 12px 12px 10px;
}

.trip-visit-lines {
  display: grid;
  gap: 10px;
}

.trip-visit-lines div {
  border-bottom: 1px solid #d8e0ee;
  min-height: 10px;
}

@media print {
  .trip-print-body {
    background: #fff;
  }

  .trip-print-sheet,
  .trip-visit-sheet {
    box-shadow: none;
    margin: 0;
    width: auto;
  }
}

@media (max-width: 1180px) {
  .trip-appointment-head,
  .trip-appointment-row {
    grid-template-columns: 1fr;
  }
}

.asset-modal {
  width: min(880px, calc(100% - 32px));
}

.asset-create-form {
  gap: 16px;
}

.asset-create-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.asset-create-form label {
  display: grid;
  gap: 8px;
}

.asset-product-picker {
  display: grid;
  gap: 8px;
  position: relative;
}

.asset-product-picker-native {
  display: none;
}

.asset-product-picker-shell {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid var(--line-soft);
  border-radius: 14px;
  background: #fff;
  min-height: 52px;
}

.asset-product-picker-shell:focus-within {
  border-color: #7dc6bc;
  box-shadow: 0 0 0 4px rgba(15, 118, 110, 0.08);
}

.asset-product-picker-selected {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.asset-product-picker-shell input[type="search"] {
  flex: 1 1 220px;
  min-width: 160px;
  border: 0;
  padding: 0;
  min-height: 28px;
  background: transparent;
  box-shadow: none;
}

.asset-product-picker-shell input[type="search"]:focus {
  outline: none;
}

.asset-product-picker-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  z-index: 30;
  max-height: 260px;
  overflow: auto;
  border: 1px solid var(--line-soft);
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.08);
}

.asset-product-picker.is-open .asset-product-picker-dropdown {
  display: grid;
}

.asset-product-option,
.asset-product-empty {
  padding: 12px 14px;
  border: 0;
  border-bottom: 1px solid #eef2f7;
  background: #fff;
  text-align: left;
}

.asset-product-option:last-child,
.asset-product-empty:last-child {
  border-bottom: 0;
}

.asset-product-option {
  cursor: pointer;
  font: inherit;
  color: #1f2937;
}

.asset-product-option:hover,
.asset-product-option:focus-visible {
  background: #f8fbff;
  outline: 0;
}

.asset-product-empty {
  color: #667085;
  font-size: 0.9rem;
}

.asset-product-chip {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border: 1px solid #d6deea;
  border-radius: 10px;
  background: #eef2f6;
  color: #243246;
  font: inherit;
  font-weight: 700;
  padding: 0.45rem 0.7rem;
  cursor: pointer;
  max-width: 100%;
}

.asset-product-chip span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.asset-product-chip strong {
  font-size: 1rem;
  line-height: 1;
  color: #667085;
}

.loan-product-picker .asset-product-picker-shell {
  min-height: 44px;
  padding: 8px 10px;
}

.loan-product-picker .asset-product-picker-shell input[type="search"] {
  flex-basis: 140px;
  min-width: 120px;
}

.asset-history-card {
  border: 1px solid #d0d5dd;
  border-radius: 14px;
  padding: 14px 16px;
  background: #f8fafc;
  display: grid;
  gap: 8px;
}

.asset-history-card__label {
  color: #667085;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.asset-history-card__body {
  color: #101828;
  font-size: 14px;
  line-height: 1.6;
}

.table-action-stack {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.loan-form-sheet .section-head {
  margin-bottom: 12px;
}

.loan-items-table input,
.loan-items-table select {
  width: 100%;
}

.icon-btn.danger {
  border: 1px solid #fca5a5;
  background: #fff5f5;
  color: #b42318;
  border-radius: 10px;
  width: 38px;
  height: 38px;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
}

.loan-view-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 24px;
}

.loan-view-meta {
  display: grid;
  gap: 18px;
  text-align: right;
}

.loan-view-meta span {
  display: block;
  color: #667085;
  font-size: 13px;
  margin-bottom: 4px;
}

.loan-view-totals {
  margin-left: auto;
  width: min(100%, 320px);
  display: grid;
  gap: 10px;
  margin-top: 18px;
}

.loan-view-totals > div {
  display: flex;
  justify-content: space-between;
  gap: 16px;
}

.loan-view-totals .grand {
  border-top: 1px solid #d0d5dd;
  padding-top: 10px;
  font-size: 18px;
}

.loan-history-list {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 8px;
}

.table-link-button {
  background: none;
  border: 0;
  padding: 0;
  color: #455468;
  cursor: pointer;
  font: inherit;
}

.inline-form {
  display: inline;
}

@media (max-width: 1200px) {
  .perfex-stats-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

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

  .loan-view-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .module-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .perfex-stats-grid,
  .perfex-filter-grid {
    grid-template-columns: 1fr;
  }

  .intake-header-meta {
    grid-template-columns: 1fr;
  }

  .asset-create-grid {
    grid-template-columns: 1fr;
  }

  .inline-create-panel {
    min-width: 0;
    width: 100%;
  }
}

.reports-module {
  display: grid;
  gap: 1.4rem;
}

.report-tab-shell {
  padding: 0;
  overflow: hidden;
}

.report-main-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  border-bottom: 1px solid #e4e7ec;
  background: #fff;
}

.report-main-tab {
  border: 0;
  border-right: 1px solid #e4e7ec;
  background: #fff;
  color: #344054;
  font: inherit;
  font-weight: 700;
  padding: 1rem 1.2rem;
  cursor: pointer;
}

.report-main-tab.is-active {
  box-shadow: inset 0 -3px 0 #20273a;
  color: #101828;
}

[data-theme="dark"] .report-tab-shell,
[data-theme="dark"] .chart-card,
[data-theme="dark"] .report-summary-card {
  border-color: rgba(132, 154, 191, 0.18);
  background: linear-gradient(180deg, rgba(18, 26, 47, 0.96) 0%, rgba(14, 21, 39, 0.98) 100%);
}

[data-theme="dark"] .report-main-tabs {
  border-bottom-color: rgba(132, 154, 191, 0.16);
  background: rgba(148, 163, 184, 0.08);
}

[data-theme="dark"] .report-main-tab {
  border-right-color: rgba(132, 154, 191, 0.16);
  background: transparent;
  color: rgba(181, 194, 219, 0.82);
}

[data-theme="dark"] .report-main-tab.is-active {
  color: #f5f8ff;
  box-shadow: inset 0 -3px 0 rgba(111, 168, 255, 0.92);
}

[data-theme="dark"] .report-summary-card strong,
[data-theme="dark"] .chart-head h3 {
  color: #eef4ff;
}

[data-theme="dark"] .pie-chart {
  border-color: rgba(255, 255, 255, 0.96);
  box-shadow: inset 0 0 0 1px rgba(132, 154, 191, 0.16);
}

[data-theme="dark"] .pie-legend-row:hover {
  background: rgba(148, 163, 184, 0.08);
}

[data-theme="dark"] .pie-legend-row,
[data-theme="dark"] .stacked-legend-item,
[data-theme="dark"] .pie-legend-value {
  color: rgba(181, 194, 219, 0.82);
}

.reports-filter-form {
  padding: 1.2rem;
}

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

.report-pane {
  display: none;
}

.report-pane.is-active {
  display: grid;
  gap: 1.4rem;
}

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

.report-summary-card-accent {
  min-height: 108px;
}

.reports-two-column-equal {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.chart-card {
  padding: 1.2rem;
  overflow: hidden;
}

.chart-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
}

.chart-head h3 {
  margin: 0;
  font-size: 1.35rem;
}

.pie-chart-shell {
  display: grid;
  grid-template-columns: minmax(260px, 360px) 1fr;
  gap: 1.4rem;
  align-items: center;
}

.pie-chart {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 999px;
  border: 14px solid #fff;
  box-shadow: inset 0 0 0 1px #e4e7ec;
}

.pie-chart-legend {
  display: grid;
  gap: 0.75rem;
}

.pie-legend-row,
.stacked-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  color: #344054;
}

.swatch {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  flex: 0 0 12px;
}

.pie-legend-row {
  display: grid;
  grid-template-columns: 12px 1fr auto;
  padding: 0.35rem 0.5rem;
  border-radius: 10px;
  transition: background 0.18s ease, transform 0.18s ease;
}

.pie-legend-row:hover {
  background: #f8fafc;
  transform: translateY(-1px);
}

.pie-legend-label {
  font-weight: 600;
}

.pie-legend-value {
  color: #667085;
}

.report-bar-list {
  display: grid;
  gap: 0.85rem;
}

.report-bar-list-comfy .report-bar-meta {
  font-size: 1rem;
}

.report-bar-list-comfy .report-bar-track {
  height: 18px;
}

.report-bar-row {
  display: grid;
  gap: 0.4rem;
  padding: 0.35rem 0.45rem;
  border-radius: 12px;
  transition: background 0.18s ease, transform 0.18s ease;
}

.report-bar-row:hover {
  background: #f8fafc;
  transform: translateY(-1px);
}

.report-bar-meta {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  font-size: 0.96rem;
  font-weight: 600;
}

.report-bar-track {
  height: 14px;
  border-radius: 999px;
  background: #edf2f7;
  overflow: hidden;
}

.report-bar-fill {
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #7da6d9 0%, #2f6fdf 100%);
}

.report-vertical-bars {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(92px, 1fr));
  gap: 1rem;
  align-items: end;
}

.report-vertical-bars-tight {
  grid-template-columns: repeat(auto-fit, minmax(56px, 1fr));
}

.vertical-bar-item {
  display: grid;
  gap: 0.45rem;
  align-items: end;
}

.vertical-bar-canvas {
  height: 260px;
  border-radius: 16px;
  background: linear-gradient(180deg, #f8fafc 0%, #eef2f6 100%);
  display: flex;
  align-items: end;
  justify-content: center;
  padding: 0.5rem;
}

.vertical-bar-fill {
  width: 100%;
  border-radius: 12px 12px 6px 6px;
  background: linear-gradient(180deg, #99bae5 0%, #7da6d9 100%);
}

.vertical-bar-fill-accent {
  background: linear-gradient(180deg, #7a34dc 0%, #4866d4 100%);
}

.vertical-bar-fill-accent-alt {
  background: linear-gradient(180deg, #8f2bdd 0%, #54c0a5 100%);
}

.vertical-bar-value {
  font-size: 0.82rem;
  font-weight: 700;
  text-align: center;
}

.vertical-bar-label {
  font-size: 0.82rem;
  line-height: 1.3;
  text-align: center;
  word-break: break-word;
  color: #475467;
}

.stacked-columns {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 1rem;
  align-items: end;
}

.stacked-columns-wide {
  grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
}

.stacked-column-item {
  display: grid;
  gap: 0.5rem;
  align-items: end;
}

.stacked-column-canvas {
  height: 300px;
  border-radius: 16px;
  background: linear-gradient(180deg, #f8fafc 0%, #eef2f6 100%);
  display: flex;
  flex-direction: column;
  justify-content: end;
  overflow: hidden;
}

.stacked-column-segment {
  width: 100%;
  transition: filter 0.18s ease, opacity 0.18s ease;
}

.stacked-column-segment:hover {
  filter: brightness(1.04);
  opacity: 0.96;
}

.stacked-column-total {
  font-size: 0.84rem;
  font-weight: 800;
  text-align: center;
}

.stacked-column-label {
  font-size: 0.82rem;
  line-height: 1.3;
  text-align: center;
  word-break: break-word;
  color: #475467;
}

.stacked-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem 1rem;
  margin-top: 1rem;
}

.stacked-rows {
  display: grid;
  gap: 0.9rem;
}

.stacked-row-card {
  display: grid;
  gap: 0.55rem;
  padding: 0.9rem 1rem;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, #fff 0%, #fbfdff 100%);
  color: inherit;
  text-decoration: none;
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.04);
}

.stacked-row-card:hover {
  border-color: rgba(47, 111, 223, 0.25);
  box-shadow: 0 12px 26px rgba(47, 111, 223, 0.08);
}

.stacked-row-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
}

.stacked-row-head strong {
  font-size: 0.98rem;
  line-height: 1.3;
}

.stacked-row-head span {
  font-weight: 800;
  color: #0f172a;
  white-space: nowrap;
}

.stacked-row-track {
  height: 26px;
  border-radius: 999px;
  background: linear-gradient(180deg, #f8fafc 0%, #eef2f6 100%);
  overflow: hidden;
  display: flex;
  align-items: center;
}

.stacked-row-width {
  height: 100%;
  display: flex;
  overflow: hidden;
  border-radius: 999px;
}

.stacked-row-segment {
  height: 100%;
  display: block;
  min-width: 10px;
  transition: filter 0.18s ease, opacity 0.18s ease;
}

.stacked-row-segment:hover {
  filter: brightness(1.04);
  opacity: 0.96;
}

.svg-line-chart {
  display: grid;
  gap: 0.8rem;
}

.svg-line-chart svg {
  width: 100%;
  height: auto;
  aspect-ratio: var(--chart-width) / var(--chart-height);
  min-height: 280px;
  overflow: visible;
  shape-rendering: geometricPrecision;
  text-rendering: geometricPrecision;
}

.svg-line-chart-compact svg {
  min-height: 240px;
}

.chart-grid-line {
  stroke: #e4e7ec;
  stroke-width: 1;
}

.chart-line {
  fill: none;
  stroke: #7da6d9;
  stroke-width: 4;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.chart-dot {
  fill: #ffffff;
  stroke: #2f6fdf;
  stroke-width: 3;
}

.chart-dot-interactive {
  cursor: pointer;
  transition: transform 0.16s ease, filter 0.16s ease;
}

.chart-dot-interactive:hover {
  filter: drop-shadow(0 4px 8px rgba(47, 111, 223, 0.22));
}

.chart-axis-label {
  fill: #98a2b3;
  font-size: 12px;
  font-weight: 600;
}

.svg-line-labels {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(48px, 1fr));
  gap: 0.35rem;
  font-size: 0.78rem;
  color: #667085;
  text-align: center;
}

.report-page-tooltip {
  position: fixed;
  z-index: 9999;
  pointer-events: none;
  padding: 0.7rem 0.85rem;
  border-radius: 12px;
  background: rgba(15, 23, 42, 0.96);
  color: #f8fafc;
  font-size: 0.9rem;
  line-height: 1.35;
  box-shadow: 0 16px 30px rgba(15, 23, 42, 0.24);
  border: 1px solid rgba(148, 163, 184, 0.2);
  white-space: normal;
  max-width: 320px;
}

@media (max-width: 1100px) {
  .reports-filter-grid-wide,
  .reports-summary-grid-2up,
  .reports-two-column-equal,
  .pie-chart-shell {
    grid-template-columns: 1fr;
  }
}

.task-workspace {
  display: grid;
}

.task-workspace-shell {
  padding: 1.1rem;
  border: 1px solid #d9e2ec;
  border-radius: 22px;
  background: linear-gradient(180deg, #ffffff 0%, #fbfcfe 100%);
}

[data-theme="dark"] .task-workspace-shell {
  border-color: rgba(148, 163, 184, 0.16);
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.98) 0%, rgba(9, 15, 26, 0.98) 100%);
  box-shadow: 0 20px 42px rgba(2, 6, 23, 0.28);
}

.task-workspace-header {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: flex-start;
  margin-bottom: 1rem;
  padding-bottom: 0.95rem;
  border-bottom: 1px solid #e8edf3;
}

[data-theme="dark"] .task-workspace-header {
  border-bottom-color: rgba(148, 163, 184, 0.12);
}

.task-title-row {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  flex-wrap: wrap;
}

.task-title-row h1 {
  margin: 0;
  font-size: 1.6rem;
  line-height: 1.15;
}

.task-subline {
  display: flex;
  gap: 0.45rem;
  flex-wrap: wrap;
  color: #667085;
  margin-top: 0.35rem;
  font-size: 0.94rem;
}

[data-theme="dark"] .task-subline {
  color: rgba(148, 163, 184, 0.82);
}

.task-workspace-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(290px, 0.78fr);
  gap: 1rem;
  align-items: start;
}

.task-main-column,
.task-side-column {
  display: grid;
  gap: 1rem;
  align-content: start;
  align-items: start;
}

.task-form-card {
  padding: 1rem;
  border: 1px solid #dde5ef;
  border-radius: 18px;
  background: #fff;
}

[data-theme="dark"] .task-form-card,
[data-theme="dark"] .task-side-card {
  border-color: rgba(148, 163, 184, 0.16);
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.96) 0%, rgba(10, 17, 30, 0.96) 100%);
}

.task-toggle-row {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-top: 0.35rem;
}

.task-chip-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.55rem;
}

.task-user-check {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: center;
  gap: 0.6rem;
  border: 1px solid #e4e7ec;
  border-radius: 12px;
  padding: 0.65rem 0.8rem;
  background: #fff;
  min-width: 0;
}

[data-theme="dark"] .task-user-check {
  border-color: rgba(148, 163, 184, 0.16);
  background: rgba(148, 163, 184, 0.08);
}

.task-user-check input[type="checkbox"] {
  width: 1.15rem;
  height: 1.15rem;
  margin: 0;
}

.task-user-check span {
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
  line-height: 1.25;
}

.task-progress {
  height: 12px;
  border-radius: 999px;
  background: #edf2f7;
  overflow: hidden;
  margin-bottom: 0.9rem;
}

[data-theme="dark"] .task-progress {
  background: rgba(148, 163, 184, 0.12);
}

.task-progress-bar {
  height: 100%;
  background: linear-gradient(90deg, #7ad67a 0%, #2ea44f 100%);
}

.task-inline-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.75rem;
  margin-bottom: 1rem;
}

.task-checklist {
  display: grid;
  gap: 0.8rem;
}

.task-checklist-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 0.8rem;
  align-items: center;
  border: 1px solid #dfe6ee;
  border-radius: 14px;
  padding: 0.72rem 0.85rem;
  background: linear-gradient(180deg, #ffffff 0%, #fbfcfe 100%);
}

[data-theme="dark"] .task-checklist-item {
  border-color: rgba(148, 163, 184, 0.14);
  background: linear-gradient(180deg, rgba(15, 23, 42, 0.94) 0%, rgba(10, 17, 30, 0.94) 100%);
}

.task-checklist-item.is-complete {
  background: #f6fcf7;
}

[data-theme="dark"] .task-checklist-item.is-complete {
  background: linear-gradient(180deg, rgba(22, 101, 52, 0.24) 0%, rgba(15, 23, 42, 0.94) 100%);
}

.task-checklist-toggle {
  width: 1.9rem;
  height: 1.9rem;
  border: 1px solid #d6dde6;
  border-radius: 999px;
  background: #fff;
  color: #667085;
  font-weight: 800;
  cursor: pointer;
}

[data-theme="dark"] .task-checklist-toggle {
  border-color: rgba(148, 163, 184, 0.18);
  background: rgba(15, 23, 42, 0.9);
  color: rgba(219, 231, 245, 0.78);
}

.task-checklist-item.is-complete .task-checklist-toggle {
  background: #2ea44f;
  border-color: #2ea44f;
  color: #fff;
}

.task-checklist-title {
  font-weight: 700;
  color: #1f2937;
}

[data-theme="dark"] .task-checklist-title {
  color: var(--ink);
}

.task-checklist-meta {
  font-size: 0.86rem;
  color: #667085;
  margin-top: 0.15rem;
}

[data-theme="dark"] .task-checklist-meta {
  color: rgba(148, 163, 184, 0.82);
}

.task-side-card {
  padding: 0.95rem 1rem;
  border: 1px solid #dde5ef;
  border-radius: 18px;
  background: #fff;
}

.task-side-card h3,
.task-side-card h4 {
  margin: 0 0 0.7rem;
}

.task-reminder-list {
  display: grid;
  gap: 0.7rem;
  margin-top: 1rem;
}

.task-reminder-item {
  border: 1px solid #e4e7ec;
  border-radius: 12px;
  padding: 0.75rem 0.85rem;
  display: grid;
  gap: 0.2rem;
  color: #475467;
}

[data-theme="dark"] .task-reminder-item,
[data-theme="dark"] .task-person-row {
  border-color: rgba(148, 163, 184, 0.14);
  background: rgba(148, 163, 184, 0.08);
  color: var(--ink);
}

.task-state-chip {
  font-size: 12px;
  font-weight: 800;
}

.task-state-chip-open,
.task-state-chip-in-progress,
.task-state-chip-review {
  background: #eef4ff;
  color: #385898;
}

.task-state-chip-complete {
  background: #ebf9ed;
  color: #2f9e44;
}

.task-state-chip-cancelled {
  background: #fff1f3;
  color: #c92a2a;
}

.task-summary-card {
  display: grid;
  gap: 1rem;
  align-content: start;
}

.task-summary-meta {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
  align-items: start;
}

.task-summary-meta-item {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 0.35rem;
  min-height: 0;
  padding: 0.8rem 0.9rem 0.9rem;
  border: 1px solid #e8edf3;
  border-radius: 14px;
  background: #fbfcfe;
}

[data-theme="dark"] .task-summary-meta-item {
  border-color: rgba(148, 163, 184, 0.14);
  background: rgba(148, 163, 184, 0.08);
}

.task-summary-meta-item strong {
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #667085;
}

[data-theme="dark"] .task-summary-meta-item strong {
  color: rgba(148, 163, 184, 0.82);
}

.task-summary-meta-item span {
  color: #101828;
  font-weight: 700;
  line-height: 1.35;
}

[data-theme="dark"] .task-summary-meta-item span {
  color: var(--ink);
}

.task-description-panel {
  display: grid;
  gap: 0.5rem;
  padding: 0.9rem 1rem;
  border: 1px solid #e8edf3;
  border-radius: 16px;
  background: #fff;
}

[data-theme="dark"] .task-description-panel {
  border-color: rgba(148, 163, 184, 0.14);
  background: rgba(148, 163, 184, 0.06);
}

.task-description-copy {
  color: #344054;
  line-height: 1.65;
  white-space: pre-wrap;
}

[data-theme="dark"] .task-description-copy {
  color: rgba(219, 231, 245, 0.88);
}

.task-edit-panel {
  display: grid;
  justify-items: start;
  gap: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  overflow: visible;
}

.task-edit-panel summary {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  cursor: pointer;
  list-style: none;
  padding: 0.78rem 1rem;
  font-weight: 800;
  color: #1f2937;
  border: 1px solid #dbe4ee;
  border-radius: 14px;
  background: #f7fafc;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.65);
}

[data-theme="dark"] .task-edit-panel summary {
  color: var(--ink);
  border-color: rgba(148, 163, 184, 0.16);
  background: rgba(148, 163, 184, 0.08);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

.task-edit-panel summary::-webkit-details-marker {
  display: none;
}

.task-edit-panel summary::after {
  content: "+";
  font-size: 1rem;
  line-height: 1;
  color: #667085;
}

[data-theme="dark"] .task-edit-panel summary::after {
  color: rgba(148, 163, 184, 0.82);
}

.task-edit-panel[open] {
  padding: 0.95rem 1rem 1rem;
  border: 1px solid #e1e8f0;
  border-radius: 16px;
  background: #f9fbfd;
}

[data-theme="dark"] .task-edit-panel[open] {
  border-color: rgba(148, 163, 184, 0.14);
  background: rgba(148, 163, 184, 0.05);
}

.task-edit-panel[open] summary {
  margin-bottom: 0.9rem;
}

.task-edit-panel[open] summary::after {
  content: "−";
}

.task-edit-form {
  width: 100%;
  padding: 0;
}

.task-edit-sidecards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.9rem;
  margin-top: 0.75rem;
}

.task-priority-high,
.task-priority-urgent {
  color: #c92a2a;
}

.task-priority-medium {
  color: #b25f00;
}

.task-priority-low {
  color: #2b8a3e;
}

.task-people-list {
  display: grid;
  gap: 0.55rem;
}

.task-person-row {
  padding: 0.72rem 0.8rem;
  border: 1px solid #e4e7ec;
  border-radius: 12px;
  background: #fbfcfe;
  color: #344054;
  font-weight: 600;
}

@media (max-width: 1100px) {
  .task-workspace-grid {
    grid-template-columns: 1fr;
  }

  .task-chip-grid {
    grid-template-columns: 1fr;
  }

  .task-summary-meta,
  .task-edit-sidecards {
    grid-template-columns: 1fr;
  }
}

.campaign-report-tabs,
.campaign-log-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  border-bottom: 1px solid #dbe2f0;
  padding-bottom: 0.85rem;
}

.campaign-report-tabs a,
.campaign-log-tabs a {
  color: #52607a;
  font-weight: 700;
  padding: 0.25rem 0;
  border-bottom: 3px solid transparent;
}

.campaign-report-tabs a.is-active,
.campaign-log-tabs a.is-active {
  color: #111827;
  border-color: #1aa6a2;
}

.campaign-meta-card {
  padding: 1.35rem 1.5rem;
}

.campaign-meta-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
}

.campaign-meta-column {
  display: grid;
  gap: 0.75rem;
}

.campaign-meta-row {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.65rem 0;
  border-bottom: 1px solid #e6ebf4;
}

.campaign-meta-row span {
  color: #6b7280;
  font-size: 0.88rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.campaign-meta-row strong {
  text-align: right;
  font-size: 0.98rem;
  color: #111827;
}

.campaign-overview-grid,
.campaign-rate-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
  gap: 1.5rem;
}

.campaign-stat-bars {
  display: grid;
  gap: 0.85rem;
  margin-top: 1rem;
}

.campaign-stat-bar-row {
  display: grid;
  grid-template-columns: 110px minmax(0, 1fr) 60px;
  gap: 0.75rem;
  align-items: center;
}

.campaign-stat-bar-label,
.campaign-stat-bar-count {
  font-size: 0.92rem;
  font-weight: 700;
  color: #1f2937;
}

.campaign-stat-bar-track,
.campaign-rate-track {
  height: 14px;
  background: #edf2f9;
  border-radius: 999px;
  overflow: hidden;
}

.campaign-stat-bar-fill,
.campaign-rate-fill {
  height: 100%;
  border-radius: 999px;
}

.campaign-stat-bar-fill.is-muted { background: #94a3b8; }
.campaign-stat-bar-fill.is-info { background: #5b8def; }
.campaign-stat-bar-fill.is-success { background: #7bc89b; }
.campaign-stat-bar-fill.is-warm { background: #c98a6c; }
.campaign-stat-bar-fill.is-danger { background: #dc7d86; }

.campaign-pill-metrics {
  display: grid;
  gap: 0.85rem;
  margin-top: 1rem;
}

.campaign-pill-row {
  display: grid;
  grid-template-columns: 90px minmax(0, 1fr) auto;
  gap: 0.9rem;
  align-items: center;
  padding: 0.85rem 0.95rem;
  border: 1px solid #e4eaf3;
  border-radius: 18px;
  background: #fff;
}

[data-theme="dark"] .campaign-pill-row {
  border-color: rgba(148, 163, 184, 0.14);
  background: rgba(148, 163, 184, 0.08);
}

.campaign-list-pane .messaging-pane-head h2 {
  font-size: 1.95rem;
}

.campaign-table td {
  padding-top: 18px;
  padding-bottom: 18px;
  vertical-align: top;
}

.campaign-cell-main {
  align-items: center;
  gap: 0.7rem;
}

.campaign-table .perfex-record-link {
  font-size: 1.28rem;
  line-height: 1.18;
  font-weight: 800;
}

.campaign-subline {
  margin-top: 0.5rem;
  font-size: 1.06rem;
  line-height: 1.42;
  font-weight: 500;
}

.campaign-row-actions {
  margin-top: 0.7rem;
  font-size: 1.06rem;
  font-weight: 700;
  gap: 0.6rem;
  align-items: center;
  flex-wrap: wrap;
}

.campaign-row-actions .table-link-btn,
.campaign-action-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0.58rem 1.1rem;
  border-radius: 999px;
  font-size: 0.98rem;
  font-weight: 800;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--ink);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.03);
  transition: transform 120ms ease, background 120ms ease, border-color 120ms ease, color 120ms ease, box-shadow 120ms ease;
}

.campaign-row-actions .table-link-btn:hover,
.campaign-action-link:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.08);
}

.campaign-action-link-neutral {
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  border-color: #d6e0ea;
  color: #334155;
}

.campaign-action-link-stats {
  background: linear-gradient(180deg, #eef5ff 0%, #e2efff 100%);
  border-color: #bfdbfe;
  color: #2155c8;
}

.campaign-action-btn-duplicate {
  background: linear-gradient(180deg, #f1f7ff 0%, #e7f0ff 100%);
  border-color: #c7d9f8;
  color: #1d4db8;
}

.campaign-action-btn-delete {
  background: linear-gradient(180deg, #fff3f3 0%, #ffe7e7 100%);
  border-color: #f5c4c4;
  color: #b42318;
}

.campaign-row-actions span {
  opacity: 0.46;
}

.campaign-table td:nth-child(2),
.campaign-table td:nth-child(3),
.campaign-table td:nth-child(4),
.campaign-table td:nth-child(5) {
  font-size: 1.14rem;
  font-weight: 700;
  color: #243247;
}

.campaign-table th:nth-child(2),
.campaign-table th:nth-child(3),
.campaign-table th:nth-child(4),
.campaign-table th:nth-child(5),
.campaign-table td:nth-child(2),
.campaign-table td:nth-child(3),
.campaign-table td:nth-child(4),
.campaign-table td:nth-child(5) {
  white-space: nowrap;
}

[data-theme="dark"] .campaign-subline {
  color: rgba(181, 194, 219, 0.82);
}

[data-theme="dark"] .campaign-table .perfex-record-link {
  color: #f5f8ff;
}

[data-theme="dark"] .campaign-table td:nth-child(2),
[data-theme="dark"] .campaign-table td:nth-child(3),
[data-theme="dark"] .campaign-table td:nth-child(4),
[data-theme="dark"] .campaign-table td:nth-child(5) {
  color: #f3f7ff;
}

[data-theme="dark"] .campaign-row-actions .table-link-btn,
[data-theme="dark"] .campaign-action-link {
  background: rgba(16, 26, 43, 0.88);
  border-color: rgba(148, 163, 184, 0.18);
  color: #e5edf8;
}

[data-theme="dark"] .campaign-action-link-neutral {
  background: rgba(30, 41, 59, 0.92);
  color: #dbe7f5;
}

[data-theme="dark"] .campaign-action-link-stats {
  background: rgba(37, 99, 235, 0.16);
  border-color: rgba(96, 165, 250, 0.3);
  color: #93c5fd;
}

[data-theme="dark"] .campaign-action-btn-duplicate {
  background: rgba(59, 130, 246, 0.16);
  border-color: rgba(96, 165, 250, 0.22);
  color: #bfdbfe;
}

[data-theme="dark"] .campaign-action-btn-delete {
  background: rgba(220, 38, 38, 0.14);
  border-color: rgba(248, 113, 113, 0.24);
  color: #fca5a5;
}

[data-theme="dark"] .mini-chip-imported {
  border-color: rgba(96, 165, 250, 0.22);
  background: rgba(37, 99, 235, 0.18);
  color: #bfdbfe;
}

[data-theme="dark"] .mini-chip-new {
  border-color: rgba(34, 211, 238, 0.2);
  background: rgba(8, 145, 178, 0.18);
  color: #a5f3fc;
}

[data-theme="dark"] .mini-chip-paused {
  border-color: rgba(251, 191, 36, 0.2);
  background: rgba(180, 83, 9, 0.2);
  color: #fde68a;
}

[data-theme="dark"] .mini-chip-scheduled {
  border-color: rgba(167, 139, 250, 0.22);
  background: rgba(109, 40, 217, 0.18);
  color: #ddd6fe;
}

.campaign-pill-percent {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  min-width: 74px;
  padding: 0.35rem 0.6rem;
  border-radius: 999px;
  font-weight: 800;
  color: #fff;
}

.campaign-pill-row.is-success .campaign-pill-percent { background: #6aa67f; }
.campaign-pill-row.is-warning .campaign-pill-percent { background: #c47d71; }
.campaign-pill-row.is-info .campaign-pill-percent { background: #6a7fd6; }
.campaign-pill-row.is-danger .campaign-pill-percent { background: #bd6a6a; }
.campaign-pill-row.is-muted .campaign-pill-percent { background: #8074a8; }

.campaign-pill-text {
  color: #1f2937;
  font-weight: 600;
}

[data-theme="dark"] .campaign-pill-text {
  color: var(--ink);
}

.campaign-pill-link {
  color: #c07a2d;
  font-weight: 700;
  white-space: nowrap;
}

[data-theme="dark"] .campaign-pill-link {
  color: color-mix(in srgb, #c07a2d 76%, white 24%);
}

.campaign-rate-card {
  padding: 1.35rem 1.5rem;
}

.campaign-rate-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: baseline;
  margin-bottom: 1rem;
}

.campaign-rate-head strong {
  font-size: 2rem;
  color: #111827;
}

.campaign-rate-fill.is-success { background: linear-gradient(90deg, #90d1a7, #7cbf92); }
.campaign-rate-fill.is-warm { background: linear-gradient(90deg, #d48cb4, #c76a90); }

.campaign-rate-list {
  display: grid;
  gap: 0.85rem;
  margin-top: 1rem;
}

.campaign-rate-list div {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid #e8edf5;
}

.campaign-rate-list span {
  color: #4b5563;
}

@media (max-width: 1100px) {
  .campaign-overview-grid,
  .campaign-rate-grid,
  .campaign-meta-grid {
    grid-template-columns: 1fr;
  }

  .campaign-pill-row {
    grid-template-columns: 1fr;
  }
}

.inline-form {
  display: inline;
  margin: 0;
}

.row-link-btn {
  border: 0;
  background: transparent;
  color: #6f7b8d;
  font: inherit;
  padding: 0;
  cursor: pointer;
}

.row-link-btn:hover,
.row-link-btn:focus-visible {
  color: #1c2434;
}

.danger-link:hover,
.danger-link:focus-visible {
  color: #b44848;
}

.switch {
  position: relative;
  display: inline-flex;
  width: 54px;
  height: 30px;
}

.switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.slider {
  position: absolute;
  inset: 0;
  cursor: pointer;
  background: #d7dee9;
  border-radius: 999px;
  transition: background .18s ease;
}

.slider::before {
  content: "";
  position: absolute;
  height: 22px;
  width: 22px;
  left: 4px;
  top: 4px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.18);
  transition: transform .18s ease;
}

.switch input:checked + .slider {
  background: #5d8df6;
}

.switch input:checked + .slider::before {
  transform: translateX(24px);
}

.template-form-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(300px, 0.8fr);
  gap: 1.5rem;
}

.template-editor-card {
  display: grid;
  gap: 1rem;
}

.template-top-fields {
  display: grid;
  grid-template-columns: minmax(240px, 360px) minmax(0, 1fr);
  gap: 1rem 1.5rem;
  align-items: start;
  margin-bottom: 1.25rem;
}

.template-top-fields label {
  display: grid;
  gap: 0.45rem;
  min-width: 220px;
}

.template-related-type {
  align-self: start;
}

.template-visibility-shell {
  display: grid;
  gap: 0.65rem;
  min-width: 0;
}

.template-visibility-label {
  color: #475467;
  font-size: 0.92rem;
  font-weight: 800;
}

.template-visibility-options {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
}

.template-top-fields .template-check {
  min-width: auto;
  display: inline-flex;
  align-items: flex-start;
  gap: 0.75rem;
}

.template-check-card {
  min-width: 220px;
  padding: 0.9rem 1rem;
  border: 1px solid #d6e2ef;
  border-radius: 16px;
  background: #fbfcfe;
}

.template-check-card input {
  width: 18px;
  height: 18px;
  margin-top: 0.2rem;
}

.template-check-card span {
  display: grid;
  gap: 0.18rem;
}

.template-check-card strong {
  color: #243246;
  font-size: 0.98rem;
  font-weight: 800;
}

.template-check-card small {
  color: #667085;
  font-size: 0.84rem;
  line-height: 1.4;
}

.template-edit-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem 1.25rem;
}

.template-edit-grid.single-column {
  grid-template-columns: 1fr;
  margin-top: 1rem;
}

.template-edit-grid label {
  display: grid;
  gap: 0.45rem;
}

.template-field-help {
  color: #667085;
  font-size: 0.9rem;
}

.template-editor-shell {
  border: 1px solid #d6e2ef;
  border-radius: 18px;
  overflow: hidden;
  background: #fff;
}

.template-editor-menu-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.2rem;
  padding: 0.55rem 0.7rem 0;
  background: #fff;
}

.template-menu-btn {
  border: 0;
  background: transparent;
  color: #243246;
  font: inherit;
  font-size: 0.95rem;
  padding: 0.55rem 0.75rem;
  border-radius: 10px;
  cursor: pointer;
}

.template-menu-btn:hover,
.template-menu-dropdown[open] > summary.template-menu-btn {
  background: #edf2f8;
}

.template-menu-dropdown {
  position: relative;
}

.template-menu-dropdown > summary {
  list-style: none;
}

.template-menu-dropdown > summary::-webkit-details-marker {
  display: none;
}

.template-menu-panel {
  position: absolute;
  top: calc(100% + 0.4rem);
  left: 0;
  z-index: 15;
  min-width: 220px;
  display: grid;
  gap: 0.1rem;
  padding: 0.45rem;
  border: 1px solid #d6e2ef;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 20px 45px rgba(15, 23, 42, 0.12);
}

.template-menu-item {
  border: 0;
  background: transparent;
  color: #223047;
  font: inherit;
  font-size: 0.95rem;
  text-align: left;
  padding: 0.8rem 0.9rem;
  border-radius: 10px;
  cursor: pointer;
}

.template-menu-item:hover {
  background: #eef5ff;
}

.template-editor-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 0.8rem 1rem;
  border-top: 1px solid #e8eef5;
  border-bottom: 1px solid #e8eef5;
  background: #fbfcfe;
}

.template-toolbar-select,
.template-toolbar-btn {
  border: 1px solid #d6e2ef;
  border-radius: 10px;
  background: #fff;
  color: #1f2d40;
  font: inherit;
  padding: 0.6rem 0.85rem;
  cursor: pointer;
}

.template-toolbar-select {
  color: #475467;
  cursor: default;
}

.template-toolbar-btn:hover {
  background: #eef5ff;
}

.template-body-editor {
  min-height: 560px;
  padding: 1.15rem 1.2rem;
  font-size: 0.99rem;
  line-height: 1.75;
  background: #fff;
  outline: none;
}

.template-body-editor:empty::before {
  content: "Write your email template here...";
  color: #98a2b3;
}

.template-body-editor p,
.template-body-editor ul,
.template-body-editor ol {
  margin: 0 0 1rem;
}

.template-body-source {
  min-height: 560px;
  width: 100%;
  border: 0;
  padding: 1.15rem 1.2rem;
  background: #fff;
  color: #192638;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 13px;
  line-height: 1.65;
  resize: vertical;
}

.template-merge-fields {
  align-self: start;
  position: sticky;
  top: 1.5rem;
}

.merge-field-list {
  display: grid;
  gap: 0.7rem;
  margin-top: 1rem;
}

.merge-field-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.75rem;
  align-items: start;
  padding-bottom: 0.65rem;
  border-bottom: 1px solid #ebf0f7;
  width: 100%;
  text-align: left;
  background: transparent;
  border-left: 0;
  border-right: 0;
  border-top: 0;
  cursor: pointer;
}

.merge-field-row span {
  color: #425066;
  font-weight: 600;
}

.merge-field-row code {
  font-size: 0.9rem;
  color: #2f67d8;
  background: #eef4ff;
  border-radius: 10px;
  padding: 0.22rem 0.45rem;
}

.merge-field-row:hover {
  background: #f8fbff;
}

.merge-target-active {
  border-color: #5d8df6 !important;
  box-shadow: 0 0 0 3px rgba(93, 141, 246, 0.12);
}

@media (max-width: 1100px) {
  .template-form-layout,
  .template-edit-grid {
    grid-template-columns: 1fr;
  }

  .template-top-fields {
    grid-template-columns: 1fr;
  }

  .template-merge-fields {
    position: static;
  }
}

.campaign-wizard-shell {
  display: grid;
  gap: 1.5rem;
}

.campaign-wizard-header {
  display: grid;
  gap: 0.55rem;
}

.campaign-wizard-header h1 {
  margin: 0;
  font-size: 2.5rem;
  line-height: 1.05;
}

.campaign-wizard-header p {
  margin: 0;
  max-width: 900px;
  color: #657286;
  font-size: 1.05rem;
}

.campaign-builder-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  align-items: center;
}

.campaign-type-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
}

.campaign-type-card {
  display: grid;
  gap: 0.9rem;
  padding: 1.6rem;
  border: 1px solid #dde5f1;
  border-radius: 22px;
  background: linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
  box-shadow: 0 14px 40px rgba(20, 35, 70, 0.06);
}

.campaign-type-card h2,
.campaign-builder-panel-head h2,
.builder-card h3 {
  margin: 0;
}

.campaign-type-card p,
.campaign-builder-panel-head p,
.builder-card p {
  margin: 0;
  color: #657286;
}

.campaign-type-icon {
  display: inline-flex;
  width: fit-content;
  padding: 0.4rem 0.7rem;
  border-radius: 999px;
  background: #eef4ff;
  color: #2f67d8;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.campaign-stepbar {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.85rem;
}

.campaign-step {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.95rem 1rem;
  border: 1px solid #d9e2ef;
  border-radius: 18px;
  background: #fff;
  color: #314154;
  font-weight: 700;
  text-decoration: none;
}

.campaign-step-index {
  display: inline-flex;
  width: 30px;
  height: 30px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #eef2f8;
  color: #526071;
  font-size: 0.9rem;
}

.campaign-step.is-active {
  border-color: #2f67d8;
  box-shadow: 0 10px 24px rgba(47, 103, 216, 0.14);
}

.campaign-step.is-active .campaign-step-index,
.campaign-step.is-complete .campaign-step-index {
  background: #2f67d8;
  color: #fff;
}

.campaign-builder-stage,
.campaign-builder-panel {
  display: grid;
  gap: 1.25rem;
}

.campaign-builder-panel {
  padding: 1.5rem;
  border: 1px solid #dde5f1;
  border-radius: 24px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(15, 23, 42, 0.06);
}

.campaign-builder-grid {
  display: grid;
  gap: 1.25rem;
}

.campaign-builder-grid.two-col {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.campaign-builder-grid label {
  display: grid;
  gap: 0.45rem;
  font-weight: 700;
  color: #2d3b4f;
}

.campaign-builder-grid label.full-span {
  grid-column: 1 / -1;
}

.builder-card {
  display: grid;
  gap: 0.9rem;
  padding: 1.15rem;
  border: 1px solid #e7edf6;
  border-radius: 18px;
  background: #fbfdff;
  align-content: start;
}

.builder-checklist {
  display: grid;
  gap: 0.75rem;
}

.builder-list-option {
  display: flex;
  gap: 0.85rem;
  align-items: flex-start;
  padding: 0.9rem;
  border: 1px solid #e1e8f2;
  border-radius: 16px;
  background: #fff;
}

.builder-list-option input[type="checkbox"],
.toggle-pill input[type="checkbox"] {
  margin-top: 0.15rem;
  width: 18px;
  height: 18px;
}

.builder-list-option span {
  display: grid;
  gap: 0.15rem;
}

.builder-list-option small {
  color: #6b7688;
}

.builder-multiselect {
  border-radius: 16px;
  border-color: #e1e8f2;
  background: #fff;
}

.builder-multiselect summary {
  padding: 0.95rem 1rem;
  color: #182739;
  font-weight: 700;
}

.builder-multiselect .form-multiselect-menu {
  gap: 0.75rem;
  max-height: 280px;
}

.builder-checkline-rich {
  display: flex;
  align-items: flex-start;
  gap: 0.85rem;
  padding: 0.9rem !important;
  border: 1px solid #e1e8f2;
  border-radius: 16px !important;
  background: #fff !important;
}

.builder-checkline-rich input[type="checkbox"] {
  margin-top: 0.15rem !important;
  width: 18px !important;
  height: 18px !important;
}

.builder-checkline-rich span {
  display: grid;
  gap: 0.15rem;
}

.builder-checkline-rich small {
  color: #6b7688;
}

.wizard-stat-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.9rem;
  align-items: stretch;
}

.wizard-stat {
  display: grid;
  gap: 0.35rem;
  padding: 1rem;
  border-radius: 16px;
  border: 1px solid #e3eaf5;
  background: #fff;
}

.wizard-stat span {
  color: #6a7688;
  font-size: 0.88rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.wizard-stat strong {
  font-size: 1.55rem;
  color: #101828;
}

.builder-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

.campaign-selected-lists-card {
  display: grid;
  gap: 0.85rem;
  padding: 1rem;
  border: 1px solid #e3eaf5;
  border-radius: 16px;
  background: #fff;
}

.campaign-targeting-section {
  display: grid;
  gap: 0.8rem;
  padding: 0.95rem 1rem;
  border: 1px solid #e6edf6;
  border-radius: 16px;
  background: #fbfdff;
}

.campaign-targeting-filters {
  background: linear-gradient(180deg, #fcfdff 0%, #f7fbff 100%);
}

.campaign-search-feedback {
  display: grid;
  gap: 0.55rem;
  padding: 0.85rem 0.95rem;
  border: 1px solid #dfe9f6;
  border-radius: 14px;
  background: #ffffff;
}

.campaign-search-feedback strong {
  color: #18324d;
  font-size: 0.95rem;
}

.campaign-search-result-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.campaign-selected-contact-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.campaign-search-chip,
.campaign-contact-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.campaign-search-chip {
  cursor: pointer;
  border: 0;
}

.chip-remove-btn {
  border: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font-weight: 800;
  line-height: 1;
  padding: 0;
}

.builder-chip-checklist {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.builder-chip-option {
  position: relative;
}

.builder-chip-option input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.builder-chip-option span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0.6rem 0.9rem;
  border: 1px solid #dbe5f1;
  border-radius: 999px;
  background: #fff;
  color: #1c2a3a;
  font-weight: 700;
  cursor: pointer;
}

.builder-chip-option input:checked + span {
  border-color: #b8cff6;
  background: #edf4ff;
  color: #214f9f;
}

.campaign-exclusion-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.8rem;
}

.campaign-exclusion-grid div {
  display: grid;
  gap: 0.2rem;
  padding: 0.8rem 0.9rem;
  border: 1px solid #e6edf6;
  border-radius: 14px;
  background: #fbfdff;
}

.campaign-exclusion-grid strong {
  font-size: 1.2rem;
  color: #142235;
}

.campaign-exclusion-grid span {
  color: #66758a;
  font-size: 0.92rem;
}

.campaign-selected-lists-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
}

.campaign-toggle-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

.toggle-pill {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.9rem 1rem;
  border: 1px solid #e1e9f4;
  border-radius: 16px;
  background: #f8fbff;
  font-weight: 700;
}

.designer-layout {
  grid-template-columns: minmax(0, 1.45fr) minmax(300px, 0.75fr);
  align-items: start;
}

.designer-canvas-card,
.designer-sidebar-card {
  display: grid;
  gap: 1rem;
  padding: 1rem;
  border: 1px solid #e4ebf4;
  border-radius: 18px;
  background: #fff;
  min-width: 0;
}

.designer-canvas-card {
  overflow: hidden;
}

.campaign-template-stage-head {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
  padding: 1rem 1.15rem;
  border: 1px solid #e4ebf4;
  border-radius: 18px;
  background: linear-gradient(180deg, #fdfefe 0%, #f5f9fd 100%);
}

.campaign-template-current {
  display: grid;
  gap: 0.25rem;
}

.campaign-template-current strong {
  font-size: 1.1rem;
  color: #172335;
}

.designer-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: end;
}

.designer-toolbar > label {
  min-width: 220px;
}

.designer-toolbar-template-select {
  opacity: 0.001;
  pointer-events: none;
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.designer-toolbar-actions {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.9rem;
  align-items: center;
  width: 100%;
}

.designer-toolbar-copy {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
}

.designer-preview-modes {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.28rem;
  border: 1px solid #d9e3ef;
  border-radius: 999px;
  background: #ffffff;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

.designer-preview-modes button {
  border: 0;
  background: transparent;
  color: #607086;
  font: inherit;
  font-weight: 700;
  padding: 0.55rem 0.9rem;
  border-radius: 999px;
  cursor: pointer;
}

.designer-preview-modes button.is-active {
  background: #1b2433;
  color: #ffffff;
}

.campaign-template-library-modal {
  width: min(1120px, calc(100vw - 40px));
}

#campaign-template-library-modal,
#campaign-test-email-modal {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  min-height: 100vh !important;
  display: none;
  align-items: flex-start;
  justify-content: center;
  z-index: 2000;
  overflow-y: auto;
  padding: 20px 16px;
}

#campaign-template-library-modal[hidden],
#campaign-test-email-modal[hidden] {
  display: none !important;
}

#campaign-template-library-modal.is-open,
#campaign-test-email-modal.is-open {
  display: flex !important;
}

#campaign-template-library-modal > .perfex-modal-backdrop,
#campaign-test-email-modal > .perfex-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
}

#campaign-template-library-modal > .perfex-modal,
#campaign-test-email-modal > .perfex-modal {
  position: relative;
  z-index: 1;
  margin: 0 auto;
}

body.campaign-modal-open {
  overflow: hidden;
}

.campaign-template-library-shell {
  display: grid;
  gap: 1rem;
}

.campaign-template-library-tabs {
  display: flex;
  gap: 1rem;
  border-bottom: 1px solid #dbe5f1;
  padding-bottom: 0.65rem;
}

.campaign-template-library-tabs button {
  border: 0;
  background: transparent;
  color: #5f7086;
  font: inherit;
  font-weight: 700;
  padding: 0 0 0.45rem;
  cursor: pointer;
}

.campaign-template-library-tabs button.is-active {
  color: #182235;
  box-shadow: inset 0 -2px 0 #2f67d8;
}

.campaign-template-library-search input {
  width: min(420px, 100%);
}

.campaign-template-library-panel {
  display: none;
}

.campaign-template-library-panel.is-active {
  display: block;
}

.campaign-template-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 1rem;
}

.campaign-template-card {
  display: grid;
  gap: 0.7rem;
  padding: 1rem;
  border: 1px solid #dbe5f1;
  border-radius: 18px;
  background: #fff;
  text-align: left;
  cursor: pointer;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.05);
}

.campaign-template-card.is-hidden {
  display: none;
}

.campaign-template-card-featured {
  background: linear-gradient(180deg, #fffef9 0%, #f9fbff 100%);
}

.campaign-template-thumb {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 68px;
  height: 88px;
  border-radius: 14px;
  background: linear-gradient(180deg, #ffffff 0%, #edf3fb 100%);
  border: 1px solid #dbe5f1;
  color: #2f67d8;
  font-weight: 800;
}

.campaign-template-card strong {
  color: #182235;
}

.campaign-template-card small {
  color: #6c788b;
}

.designer-inline-check {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
}

.designer-canvas-settings-grid label input[type="color"] {
  width: 100%;
  min-height: 54px;
  padding: 0.35rem;
}

.designer-import-card {
  border: 1px solid #e4ebf4;
  border-radius: 18px;
  background: #fbfdff;
  overflow: hidden;
}

.designer-import-card summary {
  padding: 1rem 1.1rem;
  cursor: pointer;
  font-weight: 800;
  color: #1d2b3c;
  list-style: none;
}

.designer-import-card summary::-webkit-details-marker {
  display: none;
}

.designer-import-card-body {
  display: grid;
  gap: 0.9rem;
  padding: 0 1.1rem 1.1rem;
}

.designer-canvas-surface {
  border: 1px solid #e5edf7;
  border-radius: 20px;
  background: linear-gradient(180deg, #f8fbff 0%, #eef4fb 100%);
  padding: 1rem;
  overflow: hidden;
}

.designer-canvas-shell {
  border: 1px dashed #cfe0f2;
  border-radius: 18px;
  padding: 1rem;
  transition: background 0.2s ease;
  overflow: hidden;
}

.designer-canvas-shell.is-desktop .designer-canvas {
  max-width: 740px;
}

.designer-canvas-shell.is-tablet .designer-canvas {
  max-width: 680px;
}

.designer-canvas-shell.is-mobile .designer-canvas {
  max-width: 420px;
}

.designer-canvas {
  display: grid;
  gap: 1rem;
  max-width: 740px;
  margin: 0 auto;
  position: relative;
  min-width: 0;
}

.designer-canvas.is-drop-target::after {
  content: "";
  position: absolute;
  left: -8px;
  right: -8px;
  border-top: 2px dashed #4c8bf5;
  opacity: 0;
  transition: opacity 120ms ease;
  pointer-events: none;
}

.designer-canvas.is-drop-target.is-drop-before-first::after {
  top: -8px;
  opacity: 1;
}

.designer-canvas.is-drop-target.is-drop-after-last::after {
  bottom: -8px;
  opacity: 1;
}

.campaign-email-block {
  display: grid;
  gap: 0.9rem;
  padding: 1rem;
  border: 1px solid #dfe8f3;
  border-radius: 18px;
  background: #ffffff;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.05);
  min-width: 0;
  box-sizing: border-box;
}

.campaign-email-block.is-preview {
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  cursor: pointer;
  overflow: hidden;
}

.campaign-email-block.is-active {
  border-color: #6ca7ff;
  box-shadow: 0 0 0 4px rgba(76, 139, 245, 0.14);
}

.campaign-email-block.is-dragging {
  opacity: 0.45;
}

.campaign-email-block.is-drop-target-before {
  position: relative;
}

.campaign-email-block.is-drop-target-before::before {
  content: "";
  position: absolute;
  left: -8px;
  right: -8px;
  top: -10px;
  border-top: 2px dashed #4c8bf5;
  pointer-events: none;
}

.campaign-email-block-head {
  display: flex;
  justify-content: space-between;
  gap: 0.9rem;
  align-items: center;
}

.campaign-email-block-meta {
  display: flex;
  gap: 0.7rem;
  align-items: center;
}

.campaign-email-block-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  padding: 0.35rem 0.6rem;
  border-radius: 999px;
  background: #eef5ff;
  color: #2f67d8;
  font-weight: 800;
  font-size: 0.82rem;
}

.campaign-email-drag {
  border: 1px solid #d8e2ee;
  border-radius: 12px;
  background: #fff;
  color: #4c5e76;
  font: inherit;
  font-weight: 800;
  padding: 0.35rem 0.55rem;
  cursor: grab;
}

.campaign-email-block-actions {
  display: flex;
  gap: 0.65rem;
  align-items: center;
}

.danger-outline-btn {
  color: #b42318;
  border-color: #f3c7c3;
}

.campaign-email-block-body {
  display: grid;
  gap: 0.9rem;
  min-width: 0;
}

.campaign-email-block-preview {
  display: grid;
  gap: 0.75rem;
  padding: 0.35rem 0;
  min-width: 0;
  overflow: hidden;
}

.campaign-email-block.is-preview .campaign-email-block-preview {
  border-radius: 18px;
  padding: 1rem 1.1rem;
  transition: background 140ms ease, box-shadow 140ms ease;
}

.campaign-email-block.is-preview:hover .campaign-email-block-preview {
  background: rgba(246, 249, 253, 0.92);
  box-shadow: inset 0 0 0 1px #dbe5f0;
}

.designer-canvas.is-preview-mode .campaign-email-block.is-preview .campaign-email-block-preview {
  background: transparent;
  box-shadow: none;
  padding: 0.2rem 0;
  border-radius: 0;
}

.campaign-email-block-preview > div,
.campaign-email-block-preview > table,
.campaign-email-block-preview > hr {
  margin: 0;
  max-width: 100%;
}

.campaign-email-block-preview * {
  max-width: 100%;
  box-sizing: border-box;
}

.campaign-email-block-preview a {
  pointer-events: none;
}

.campaign-email-block-preview table {
  display: block;
  overflow-x: auto;
}

.campaign-email-block-preview iframe,
.campaign-email-block-preview img {
  display: block;
  max-width: 100%;
}

.campaign-email-block-empty {
  padding: 1rem;
  border: 1px dashed #dbe5f0;
  border-radius: 14px;
  color: #7b8798;
  background: #fbfdff;
}

.campaign-email-block-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.campaign-email-rich-block {
  min-height: 120px;
  padding: 0.95rem 1rem;
  border: 1px solid #dbe5f0;
  border-radius: 16px;
  background: #fff;
  color: #1b2a3b;
  line-height: 1.7;
  outline: none;
  min-width: 0;
  overflow-wrap: anywhere;
}

.campaign-email-rich-block:empty::before {
  content: "Write here...";
  color: #8894a7;
}

.campaign-email-import-surface {
  min-height: 180px;
}

.campaign-email-import-surface:empty::before {
  content: "Write here...";
}

.campaign-email-rich-block table {
  width: 100%;
  border-collapse: collapse;
}

.campaign-email-rich-block td,
.campaign-email-rich-block th {
  border: 1px solid #dbe5f0;
  padding: 0.55rem 0.7rem;
}

.campaign-email-inline-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

.campaign-email-image-preview {
  padding: 1rem;
  border: 1px solid #e2eaf5;
  border-radius: 16px;
  background: #f8fbff;
}

.campaign-email-image-preview img {
  display: block;
  max-width: 100%;
  height: auto;
}

.campaign-email-upload-box {
  display: grid;
  gap: 8px;
  align-content: start;
}

.campaign-email-image-settings-stack {
  display: grid;
  gap: 0.9rem;
}

.campaign-email-image-settings-row {
  display: grid;
  grid-template-columns: minmax(0, 220px) minmax(0, 1fr);
  gap: 0.9rem;
  align-items: end;
}

.campaign-email-slider-field {
  display: grid;
  gap: 0.45rem;
}

.campaign-email-slider-field input[type="range"] {
  width: 100%;
}

.campaign-email-slider-value {
  font-size: 0.92rem;
  font-weight: 700;
  color: #516076;
}

.campaign-email-upload-box-wide {
  padding: 0.95rem 1rem;
  border: 1px solid #e2eaf5;
  border-radius: 16px;
  background: linear-gradient(180deg, #fbfdff 0%, #f6faff 100%);
}

.campaign-email-upload-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.8rem;
}

.campaign-email-upload-head strong {
  font-size: 0.98rem;
}

.campaign-email-upload-box .button-row {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.campaign-email-button-preview {
  padding: 0.4rem 0;
}

.campaign-email-block-preview-html {
  padding: 0;
  background: transparent;
}

.campaign-email-html-preview,
.campaign-email-html-preview-wrap {
  display: grid;
  min-width: 0;
}

.campaign-email-html-preview-frame {
  width: 100%;
  min-height: 480px;
  border: 1px solid #e2eaf5;
  border-radius: 18px;
  background: #ffffff;
  overflow: auto;
}

.designer-selected-block-card {
  display: grid;
  gap: 0.45rem;
  padding: 1rem;
  border: 1px solid #e4ebf4;
  border-radius: 16px;
  background: #f8fbff;
}

.designer-selected-block-card p {
  margin: 0;
  color: #6c788b;
}

.designer-block-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.designer-block {
  display: grid;
  gap: 0.35rem;
  padding: 0.9rem;
  border: 1px solid #e4ebf4;
  border-radius: 14px;
  background: #fbfdff;
  text-align: left;
  cursor: pointer;
  transition: border-color 120ms ease, box-shadow 120ms ease, transform 120ms ease;
}

.designer-block:hover,
.designer-block:focus-visible {
  border-color: #c8daf5;
  box-shadow: 0 10px 20px rgba(47, 111, 223, 0.08);
}

body.is-dragging-builder-block .designer-canvas-surface {
  border-color: #c8daf5;
  background: linear-gradient(180deg, #f5f9ff 0%, #ecf4ff 100%);
}

.designer-block small {
  color: #6c788b;
}

.designer-sidebar-section {
  display: grid;
  gap: 0.8rem;
}

.merge-field-group {
  display: grid;
  gap: 0.45rem;
}

.merge-field-group strong {
  color: #192638;
}

.merge-field-group ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.45rem;
}

.merge-field-group li {
  display: block;
}

.merge-field-group .merge-field-row {
  width: 100%;
  justify-content: space-between;
}

.campaign-confirm-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.campaign-confirm-list {
  margin: 0;
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr);
  gap: 0.65rem 1rem;
}

.campaign-confirm-list dt {
  font-weight: 700;
  color: #506074;
}

.campaign-confirm-list dd {
  margin: 0;
  color: #101828;
}

.confirm-actions-row,
.campaign-builder-footer {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
}

.campaign-builder-footer-right {
  display: flex;
  gap: 0.75rem;
  align-items: center;
}

@media (max-width: 1200px) {
  .campaign-overview-focus-campaigns,
  .campaign-overview-focus-lists,
  .campaign-stepbar,
  .wizard-stat-grid,
  .campaign-builder-grid.two-col,
  .campaign-confirm-grid,
  .campaign-toggle-grid,
  .designer-layout,
  .campaign-type-grid {
    grid-template-columns: 1fr;
  }

  .campaign-email-inline-grid {
    grid-template-columns: 1fr;
  }

  .campaign-exclusion-grid {
    grid-template-columns: 1fr;
  }

  .designer-block-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 760px) {
  .campaign-template-stage-head {
    display: grid;
  }

  .campaign-wizard-header h1 {
    font-size: 2rem;
  }

  .campaign-step {
    padding: 0.8rem 0.9rem;
  }

  .designer-block-grid,
  .campaign-builder-footer,
  .confirm-actions-row {
    grid-template-columns: 1fr;
    display: grid;
  }

  .campaign-builder-footer-right {
    width: 100%;
    justify-content: stretch;
    display: grid;
  }

  .designer-toolbar-actions {
    display: grid;
    width: 100%;
  }

  .designer-preview-modes {
    width: 100%;
    justify-content: space-between;
  }

  .designer-preview-modes button {
    flex: 1 1 0;
    text-align: center;
  }
}

.wysiwyg-shell {
  border: 1px solid #d6e2ef;
  border-radius: 16px;
  background: #fbfdff;
  overflow: hidden;
}

.product-wysiwyg-shell {
  border-radius: 20px;
  background: #ffffff;
}

.product-wysiwyg-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.55rem 0.8rem 0;
  background: #ffffff;
}

.product-wysiwyg-menu-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.2rem;
}

.product-wysiwyg-menu-btn {
  border: 0;
  background: transparent;
  color: #243246;
  font: inherit;
  font-size: 0.95rem;
  padding: 0.55rem 0.7rem;
  border-radius: 10px;
  cursor: default;
}

.product-wysiwyg-mode-bar {
  padding: 0;
  flex-shrink: 0;
}

.wysiwyg-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  padding: 0.9rem;
  border-bottom: 1px solid #e4ebf4;
  background: #f4f8fc;
}

.rich-editor-toolbar {
  gap: 0.45rem;
  align-items: center;
}

.rich-editor-select,
.rich-editor-button,
.rich-editor-color {
  border: 1px solid #d6e2ef;
  border-radius: 10px;
  background: #ffffff;
  color: #1f2d40;
  font: inherit;
  min-height: 40px;
}

.rich-editor-select {
  min-width: 116px;
  padding: 0.55rem 0.8rem;
}

.rich-editor-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  padding: 0.55rem 0.75rem;
  font-size: 0.92rem;
  font-weight: 700;
  cursor: pointer;
}

.rich-editor-button.is-wide {
  min-width: 56px;
}

.rich-editor-color {
  width: 44px;
  padding: 0.2rem;
  cursor: pointer;
}

.rich-editor-button:hover,
.rich-editor-select:hover,
.rich-editor-color:hover {
  background: #edf2f8;
}

.rich-editor-divider {
  width: 1px;
  min-height: 32px;
  background: #dbe4ef;
  margin: 0 0.1rem;
}

.campaign-email-block-controls-compact {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border: 1px solid #dbe4f0;
  border-radius: 12px 12px 0 0;
  background: linear-gradient(180deg, #f9fbfd 0%, #f2f6fa 100%);
}

.campaign-rich-format-select {
  min-width: 130px;
  min-height: 36px;
  padding: 0.45rem 0.65rem;
  border: 1px solid #d3deea;
  border-radius: 9px;
  background: #fff;
  color: #344054;
  font: inherit;
  font-size: 0.92rem;
  font-weight: 600;
}

.campaign-email-block-controls-compact .rich-editor-select {
  min-height: 36px;
  min-width: 112px;
  padding: 0.42rem 0.62rem;
  font-size: 0.88rem;
}

.campaign-email-block-controls-compact .rich-editor-button {
  min-width: 36px;
  min-height: 36px;
  padding: 0.42rem 0.58rem;
  font-size: 0.82rem;
}

.campaign-email-block-controls-compact .rich-editor-color {
  width: 36px;
  min-height: 36px;
}

.campaign-email-block-controls-compact .rich-editor-divider {
  min-height: 26px;
}

.wysiwyg-btn-compact {
  min-width: 36px;
  min-height: 36px;
  padding: 0.45rem 0.6rem;
  border: 1px solid #d3deea;
  border-radius: 9px;
  background: #fff;
  color: #22304a;
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
}

.wysiwyg-btn-compact:hover {
  background: #eef3f8;
}

.campaign-email-block-controls-compact + .campaign-email-rich-block {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.product-wysiwyg-toolbar {
  gap: 0.35rem;
  align-items: center;
  padding: 0.75rem 0.9rem;
  background: #fbfcfe;
}

.product-wysiwyg-select,
.product-wysiwyg-icon-btn {
  border: 1px solid #d6e2ef;
  border-radius: 10px;
  background: #ffffff;
  color: #1f2d40;
  font: inherit;
  min-height: 42px;
}

.product-wysiwyg-select {
  padding: 0.55rem 0.8rem;
  min-width: 124px;
  color: #475467;
}

.product-wysiwyg-size {
  min-width: 88px;
}

.product-wysiwyg-icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  padding: 0.55rem 0.75rem;
  font-size: 0.95rem;
  font-weight: 700;
  cursor: pointer;
}

.product-wysiwyg-icon-btn:hover,
.product-wysiwyg-menu-btn:hover {
  background: #edf2f8;
}

.wysiwyg-mode-bar {
  display: flex;
  gap: 10px;
  padding: 0.9rem 0.9rem 0;
  background: #fbfdff;
}

.wysiwyg-mode-btn {
  border: 1px solid #d6e2ef;
  border-radius: 999px;
  background: #ffffff;
  color: #445469;
  font: inherit;
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1;
  padding: 0.65rem 0.95rem;
  cursor: pointer;
}

.wysiwyg-mode-btn.is-active {
  background: #1f2937;
  border-color: #1f2937;
  color: #ffffff;
}

.wysiwyg-btn {
  border: 1px solid #d6e2ef;
  border-radius: 999px;
  background: #ffffff;
  color: #192638;
  font: inherit;
  font-size: 0.92rem;
  font-weight: 700;
  line-height: 1;
  padding: 0.65rem 0.9rem;
  cursor: pointer;
}

.wysiwyg-btn:hover {
  background: #eef5ff;
}

.wysiwyg-editor {
  min-height: 360px;
  padding: 1rem 1.1rem;
  color: #192638;
  line-height: 1.65;
  background: #ffffff;
  outline: none;
}

.product-wysiwyg-shell .wysiwyg-editor {
  min-height: 420px;
  border-top: 1px solid #e8eef5;
  font-size: 1rem;
  line-height: 1.75;
}

.product-wysiwyg-shell .wysiwyg-raw {
  min-height: 420px;
  border-top: 1px solid #e8eef5;
}

.wysiwyg-editor:empty::before {
  content: "Write the product description here...";
  color: #7a8699;
}

.wysiwyg-editor h1,
.wysiwyg-editor h2,
.wysiwyg-editor h3 {
  margin: 0 0 0.8rem;
}

.wysiwyg-editor p,
.wysiwyg-editor ul,
.wysiwyg-editor ol {
  margin: 0 0 0.9rem;
}

.wysiwyg-raw {
  min-height: 360px;
  padding: 1rem 1.1rem;
  border: 0;
  border-top: 1px solid #e4ebf4;
  border-radius: 0;
  background: #ffffff;
  color: #192638;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 13px;
  line-height: 1.6;
  resize: vertical;
}

.branding-asset-field {
  display: grid;
  gap: 0.8rem;
}

.branding-asset-header strong {
  display: block;
  font-size: 1.02rem;
  font-weight: 800;
  color: #1b2940;
}

.branding-asset-tools {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.7rem;
}

.branding-upload-filename {
  color: #718198;
  font-size: 0.92rem;
  font-weight: 600;
}

.branding-file-input {
  display: inline-flex;
  max-width: 100%;
  min-height: 44px;
  padding: 0.55rem 0.8rem;
  border: 1px solid #d7e2ee;
  border-radius: 14px;
  background: #fff;
  color: #1f2b3d;
  font: inherit;
}

.branding-file-input::file-selector-button {
  margin-right: 0.8rem;
  padding: 0.55rem 1rem;
  border: 1px solid #d7e2ee;
  border-radius: 12px;
  background: #fff;
  color: #1f2b3d;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
}

.branding-clear-btn {
  color: #9f2436;
}

.branding-inline-actions {
  display: flex;
  align-items: center;
  gap: 0.7rem;
}

.branding-asset-url-toggle {
  width: 100%;
}

.branding-asset-url-toggle summary {
  cursor: pointer;
  color: #5b6880;
  font-weight: 700;
  list-style: none;
}

.branding-asset-url-toggle summary::-webkit-details-marker {
  display: none;
}

.branding-asset-url-toggle[open] summary {
  margin-bottom: 0.7rem;
}

.branding-asset-preview {
  display: grid;
  gap: 0.55rem;
}

.branding-asset-preview-frame {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 108px;
  padding: 1rem;
  border: 1px solid #dce6f1;
  border-radius: 22px;
  background:
    linear-gradient(45deg, #eef4fa 25%, transparent 25%, transparent 75%, #eef4fa 75%, #eef4fa),
    linear-gradient(45deg, #eef4fa 25%, transparent 25%, transparent 75%, #eef4fa 75%, #eef4fa),
    linear-gradient(180deg, #fbfdff 0%, #f4f8fc 100%);
  background-position: 0 0, 12px 12px, 0 0;
  background-size: 24px 24px, 24px 24px, 100% 100%;
}

.branding-asset-preview-frame img {
  max-width: 100%;
  max-height: 72px;
  object-fit: contain;
}

.branding-asset-preview-frame.is-hidden,
.branding-asset-preview .table-subline.is-hidden,
.branding-asset-preview-empty.is-hidden {
  display: none;
}

.branding-asset-preview-empty {
  min-height: 108px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  border: 1px dashed #d6e2ef;
  border-radius: 22px;
  background: #fafcff;
  color: #7a8699;
  font-weight: 600;
  text-align: center;
}

@media (max-width: 720px) {
  .products-filter-grid {
    grid-template-columns: 1fr;
  }

  .products-filter-actions {
    flex-wrap: wrap;
  }
}

@media (max-width: 1220px) {
  .shop-header-inner {
    flex-wrap: wrap;
    align-items: center;
  }

  .shop-brand {
    order: 1;
  }

  .shop-nav-toggle {
    display: inline-flex;
    order: 2;
    margin-left: auto;
  }

  .shop-header-actions {
    order: 3;
    margin-left: 0;
  }

  .portal-header .shop-nav {
    display: none;
    order: 4;
    width: 100%;
    padding: 10px;
    border: 1px solid var(--line-soft);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.88);
    box-shadow: 0 16px 34px rgba(15, 23, 42, 0.08);
    justify-content: flex-start;
    flex-wrap: wrap;
    margin: 0;
    gap: 8px;
  }

  .portal-header .shop-nav.is-open {
    display: flex;
  }

  [data-theme="dark"] .portal-header .shop-nav {
    background: rgba(15, 23, 42, 0.96);
    border-color: rgba(148, 163, 184, 0.18);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.24);
  }

  .portal-header .shop-nav a {
    min-height: 38px;
    padding: 8px 12px;
    border-radius: 999px;
    background: transparent;
  }

  .portal-header .shop-nav a::after {
    display: none;
  }

.portal-user-menu {
    order: 5;
    margin-left: auto;
  }
}

.calendar-page {
  display: grid;
  gap: 24px;
}

.calendar-hero {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  padding: 28px 32px;
}

.calendar-kicker {
  margin: 0 0 6px;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-strong);
}

.calendar-hero h1,
.calendar-toolbar-title h2,
.calendar-agenda-head h2 {
  margin: 0;
}

.calendar-copy {
  max-width: 720px;
  margin: 10px 0 0;
  font-size: 1.05rem;
  color: var(--ink-subtle);
}

.calendar-hero-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(160px, 1fr));
  gap: 12px;
  min-width: 420px;
}

.calendar-hero-stat {
  display: grid;
  gap: 6px;
  padding: 18px 20px;
  border: 1px solid var(--line-soft);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.82);
}

.calendar-hero-stat span {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--ink-subtle);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.calendar-hero-stat strong {
  font-size: 1.45rem;
  line-height: 1.1;
}

.calendar-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.75fr) minmax(320px, 0.9fr);
  gap: 24px;
  align-items: start;
}

.calendar-grid-card,
.calendar-agenda-card {
  padding: 24px;
}

.calendar-toolbar,
.calendar-agenda-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  margin-bottom: 20px;
}

.calendar-toolbar-title p {
  margin: 8px 0 0;
  color: var(--ink-subtle);
}

.calendar-toolbar-actions {
  flex-wrap: wrap;
  justify-content: flex-end;
}

.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 10px;
}

.calendar-grid-head {
  padding: 0 6px 8px;
  font-size: 0.82rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--ink-subtle);
}

.calendar-day {
  min-height: 152px;
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.7);
}

.calendar-day.is-muted {
  opacity: 0.6;
}

.calendar-day.is-today {
  border-color: rgba(16, 185, 129, 0.45);
  box-shadow: 0 0 0 2px rgba(16, 185, 129, 0.08);
}

.calendar-day-top {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: baseline;
}

.calendar-day-number {
  font-size: 1rem;
  font-weight: 800;
}

.calendar-day-count {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--ink-subtle);
}

.calendar-day-items {
  display: grid;
  gap: 8px;
  align-content: start;
}

.calendar-chip {
  display: grid;
  gap: 2px;
  padding: 8px 10px;
  border-radius: 14px;
  text-decoration: none;
  background: rgba(15, 23, 42, 0.04);
  color: var(--ink-strong);
}

.calendar-chip strong {
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.calendar-chip span {
  font-size: 0.83rem;
  line-height: 1.25;
}

.calendar-chip.is-task {
  background: rgba(59, 130, 246, 0.1);
}

.calendar-chip.is-reminder {
  background: rgba(245, 158, 11, 0.12);
}

.calendar-day-more {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--ink-subtle);
}

.calendar-agenda-list {
  display: grid;
  gap: 12px;
}

.calendar-agenda-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 14px 16px;
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  text-decoration: none;
  color: inherit;
  background: rgba(255, 255, 255, 0.7);
}

.calendar-agenda-icon {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  font-weight: 900;
}

.calendar-agenda-icon.is-task {
  background: rgba(59, 130, 246, 0.12);
  color: #2563eb;
}

.calendar-agenda-icon.is-reminder {
  background: rgba(245, 158, 11, 0.14);
  color: #b45309;
}

.calendar-agenda-copy {
  display: grid;
  gap: 4px;
}

.calendar-agenda-copy strong {
  font-size: 1rem;
}

.calendar-agenda-copy span,
.calendar-agenda-copy em {
  color: var(--ink-subtle);
  font-style: normal;
}

.calendar-empty-state {
  display: grid;
  gap: 6px;
  padding: 24px 8px;
  color: var(--ink-subtle);
}

[data-theme="dark"] .calendar-hero-stat,
[data-theme="dark"] .calendar-day,
[data-theme="dark"] .calendar-agenda-item {
  background: rgba(15, 23, 42, 0.74);
}

@media (max-width: 1180px) {
  .calendar-hero,
  .calendar-toolbar,
  .calendar-agenda-head {
    flex-direction: column;
  }

  .calendar-hero-meta,
  .calendar-shell {
    grid-template-columns: 1fr;
    min-width: 0;
  }
}

@media (max-width: 820px) {
  .calendar-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .calendar-grid-head {
    display: none;
  }

  .calendar-day {
    min-height: 132px;
  }

  .calendar-hero {
    padding: 22px;
  }
}
