/*
 * Project-specific UI tweaks.
 *
 * Keep this file for overrides instead of editing vendor/theme CSS.
 */

/* ========================================================================
 * Brand palette (Phase 2 visual rebrand).
 *
 * Calm enterprise theme: slate-900 base, indigo accent, generous whitespace,
 * conservative border-radius. Replaces Soft UI Dashboard's magenta/purple
 * accent without forking the vendor stylesheet.
 * ======================================================================== */
:root {
  --brand-bg: #f8fafc;
  --brand-surface: #ffffff;
  --brand-surface-2: #f1f5f9;
  --brand-border: #e2e8f0;
  --brand-border-strong: #cbd5e1;
  --brand-ink: #0f172a;          /* slate-900 — primary text */
  --brand-ink-2: #1e293b;        /* slate-800 — secondary text */
  --brand-muted: #475569;        /* slate-600 — muted text  */
  --brand-muted-2: #64748b;      /* slate-500 — meta text */

  --brand-primary: #1e293b;      /* slate-800 — buttons & links */
  --brand-primary-2: #0f172a;
  --brand-accent: #4f46e5;       /* indigo-600 — accent */
  --brand-accent-2: #6366f1;     /* indigo-500 */

  --brand-danger: #b91c1c;       /* red-700 */
  --brand-warning: #b45309;      /* amber-700 */
  --brand-success: #047857;      /* emerald-700 */

  --brand-radius: 6px;
  --brand-radius-lg: 10px;
  --brand-shadow: 0 1px 2px rgba(15, 23, 42, 0.06), 0 8px 24px rgba(15, 23, 42, 0.06);
  --brand-shadow-lg: 0 4px 8px rgba(15, 23, 42, 0.08), 0 16px 40px rgba(15, 23, 42, 0.12);
}

/* Override Soft UI's magenta→pink gradient everywhere it's used: navbar,
 * login hero, primary buttons. */
.bg-gradient-primary {
  background-image: linear-gradient(135deg, var(--brand-primary-2) 0%, var(--brand-primary) 60%, var(--brand-accent) 100%) !important;
}

/* Primary buttons: keep them flat and high-contrast, no flashy glow */
.btn.bg-gradient-primary,
.btn-primary {
  background-image: none !important;
  background-color: var(--brand-primary) !important;
  border-color: var(--brand-primary) !important;
  color: #ffffff !important;
  font-weight: 600;
  letter-spacing: 0.01em;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.12);
}

.btn.bg-gradient-primary:hover,
.btn-primary:hover {
  background-color: var(--brand-accent) !important;
  border-color: var(--brand-accent) !important;
  box-shadow: 0 2px 8px rgba(79, 70, 229, 0.32);
}

.btn.bg-gradient-primary:focus,
.btn-primary:focus {
  box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.24) !important;
}

/* Outline + dark variants in the same family */
.btn-outline-primary {
  color: var(--brand-primary) !important;
  border-color: var(--brand-primary) !important;
}
.btn-outline-primary:hover {
  background-color: var(--brand-primary) !important;
  color: #ffffff !important;
}

.bg-gradient-dark {
  background-image: linear-gradient(135deg, #0f172a 0%, #334155 100%) !important;
}

.bg-gradient-warning {
  background-image: linear-gradient(135deg, #b45309 0%, #ea580c 100%) !important;
}

/* Reduce the navbar's playful pill shape — keep the rounded corners but
 * tighten them and drop the deep shadow. */
.navbar.navbar-expand-lg.navbar-primary.bg-gradient-primary {
  border-radius: var(--brand-radius-lg) !important;
  box-shadow: var(--brand-shadow);
}

/* Page body */
body.bg-gray-100 {
  background-color: var(--brand-bg) !important;
}

/* Cards and panels — flatten the look */
.enterprise-panel {
  background: var(--brand-surface);
  border: 1px solid var(--brand-border);
  border-radius: var(--brand-radius-lg);
  box-shadow: var(--brand-shadow);
}

.card {
  border-radius: var(--brand-radius-lg);
  box-shadow: var(--brand-shadow);
}

/* Alerts — calm down the Soft UI gradient backgrounds */
.alert.alert-danger {
  background: #fef2f2 !important;
  background-image: none !important;
  color: var(--brand-danger) !important;
  border: 1px solid #fecaca !important;
}
.alert.alert-danger .alert-text {
  color: var(--brand-danger) !important;
}
.alert.alert-danger strong {
  color: var(--brand-danger) !important;
}
.alert.alert-success {
  background: #ecfdf5 !important;
  background-image: none !important;
  color: var(--brand-success) !important;
  border: 1px solid #a7f3d0 !important;
}
.alert.alert-warning {
  background: #fffbeb !important;
  background-image: none !important;
  color: var(--brand-warning) !important;
  border: 1px solid #fde68a !important;
}
.alert.alert-info {
  background: #eff6ff !important;
  background-image: none !important;
  color: #1d4ed8 !important;
  border: 1px solid #bfdbfe !important;
}

/* The btn-close on alerts: hide the white X icon since text is now dark */
.alert.alert-danger .btn-close,
.alert.alert-warning .btn-close,
.alert.alert-success .btn-close,
.alert.alert-info .btn-close {
  filter: none;
}

/* Override the focus ring color so it matches the new accent */
.form-control:focus,
.form-select:focus {
  border-color: var(--brand-accent) !important;
  box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.20) !important;
}

/* Search-command-panel — keep dark hero but use the new palette */
.search-command-panel {
  background:
    linear-gradient(135deg, rgba(15, 23, 42, 0.94), rgba(30, 41, 59, 0.94)),
    url("/assets/img/office-dark.jpg") center/cover !important;
  border-color: #0f172a !important;
  border-radius: var(--brand-radius-lg) !important;
}

/* Sign-in side panel on the login page */
.login-hero {
  background: linear-gradient(135deg, var(--brand-primary-2), var(--brand-accent)) !important;
  background-image: linear-gradient(135deg, var(--brand-primary-2), var(--brand-accent)) !important;
}

/* ------- Radius search page ------- */
.radius-command-panel {
  background: var(--brand-surface);
  border-color: var(--brand-border);
  color: var(--brand-ink);
}

.radius-command-panel .section-kicker {
  color: var(--brand-muted) !important;
}

.poi-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.35rem 0.7rem;
  border: 1px solid var(--brand-border);
  border-radius: 999px;
  font-size: 0.82rem;
  cursor: pointer;
  background: var(--brand-surface);
  color: var(--brand-ink-2);
  user-select: none;
  transition: background 120ms ease, border-color 120ms ease, color 120ms ease;
}
.poi-pill input { display: none; }
.poi-pill:hover {
  border-color: var(--brand-accent);
  color: var(--brand-accent);
}
.poi-pill input:checked + span {
  font-weight: 600;
}
.poi-pill:has(input:checked) {
  background: rgba(79, 70, 229, 0.08);
  border-color: var(--brand-accent);
  color: var(--brand-accent);
}

/* Leaflet popup styling — match the rest of the system */
.leaflet-popup-content-wrapper {
  border-radius: var(--brand-radius);
  box-shadow: var(--brand-shadow);
  font-size: 0.82rem;
}

/* ------- Responsive pass ------- */
/* Tablet and below */
@media (max-width: 992px) {
  .navbar.navbar-expand-lg {
    margin-left: 1rem !important;
    margin-right: 1rem !important;
  }
  .search-title { font-size: 1.5rem; }

  /* Result rows: stop the avatar pushing content off-screen */
  .result-row {
    flex-direction: row;
    align-items: flex-start;
    flex-wrap: wrap;
  }
  .result-row .result-meta {
    width: 100%;
    flex: 1 1 100%;
  }

  /* Tables become horizontally scrollable in a card */
  .table-responsive {
    border: 1px solid var(--brand-border);
    border-radius: var(--brand-radius);
  }

  /* Radius map: drop the height a bit so it fits without scroll */
  #radius-map { height: 480px !important; }
}

/* Phone */
@media (max-width: 576px) {
  body.bg-gray-100 {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .navbar.navbar-expand-lg {
    margin: 0.5rem !important;
    padding: 0.5rem 0.75rem !important;
  }

  .enterprise-panel { padding: 0.85rem; }
  .search-title { font-size: 1.15rem; }
  .panel-title { font-size: 1rem; }

  #radius-map { height: 380px !important; }

  /* Stack the radius form */
  .radius-form .col-lg-2, .radius-form .col-lg-3, .radius-form .col-lg-7 {
    flex: 0 0 100%;
    max-width: 100%;
  }

  /* Wrap POI pills nicely */
  .poi-pill { flex: 0 0 auto; }

  /* Metric values: tighten the typography */
  .metric-value { font-size: 1.4rem; }
  .metric-label { font-size: 0.7rem; }

  /* Demo rows on phone: stack the label/value with smaller gap */
  .demo-row { gap: 0.5rem; font-size: 0.85rem; padding: 0.35rem 0; }
}

/* Very small (<= 360px) */
@media (max-width: 360px) {
  .navbar-nav .nav-link { padding: 0.35rem 0.5rem; }
  .btn { font-size: 0.85rem; }
}

/* End of Phase 2 rebrand */


/* Make Choices.js single-select match Soft UI's .form-control-lg vertical padding. */
.choices.choices-lg .choices__inner {
  padding: 0.75rem 0.75rem;
}

/* Vertically center the dropdown caret for the larger padding variant. */
.choices.choices-lg[data-type*='select-one']:after {
  top: 50%;
  margin-top: -7px;
}

/*
 * Search form: make the input/select outlines match the primary button outline.
 * This is scoped to forms that include the `.search-form` class.
 */
.search-form .form-control {
  border-color: var(--bs-primary);
}

.search-form .form-control:focus {
  border-color: var(--bs-primary);
  box-shadow: 0 0 0 2px rgba(var(--bs-primary-rgb), 0.25);
}

.search-form .choices__inner {
  border-color: var(--bs-primary);
}

.search-form .is-focused .choices__inner,
.search-form .is-open .choices__inner {
  border-color: var(--bs-primary);
  box-shadow: 0 0 0 2px rgba(var(--bs-primary-rgb), 0.25);
}

/*
 * Toggle switch "input-group" on Home/Search pages:
 * make it look like a single outlined control (same outline style as .form-control).
 */
.toggle-input-group {
  border: 1px solid #d2d6da;
  border-radius: 0.5rem;
  overflow: hidden;
}

.toggle-input-group .input-group-text {
  border: 0;
  border-right: 1px solid #d2d6da;
  border-radius: 0;
}

.toggle-input-group .input-group-text:last-child {
  border-right: 0;
}

/* Match the theme's .form-control:focus outline when toggles are focused. */
.toggle-input-group:focus-within {
  border-color: #e293d3;
  box-shadow: 0 0 0 2px #e9aede;
}

.toggle-input-group:focus-within .input-group-text {
  border-right-color: #e293d3;
}

/*
 * Admin + Transactions: slightly smaller table typography.
 * (This covers the tables and the Simple-DataTables controls like search/pagination.)
 */
.admin-page table,
.admin-page .dataTable-wrapper,
.transactions-page table,
.transactions-page .dataTable-wrapper {
  font-size: 0.8125rem; /* ~13px */
}
.search-page table,
.search-page .dataTable-wrapper {
  font-size: 0.8125rem; /* ~13px */
}

.admin-page .dataTable-input,
.admin-page .dataTable-selector,
.admin-page .dataTable-pagination a,
.transactions-page .dataTable-input,
.transactions-page .dataTable-selector,
.transactions-page .dataTable-pagination a {
  font-size: 0.8125rem;
}
.search-page .dataTable-input,
.search-page .dataTable-selector {
  font-size: 0.8125rem;
}
/*
 * Admin secondary navbar:
 * make the active pill look like the primary outline button (same color as
 * `.btn.btn-outline-primary`).
 */
.admin-secondary-nav .nav-link {
  border: 1px solid transparent;
  border-radius: 0.5rem;
  padding: 0.5rem 0.75rem;
  line-height: 1.25;
  box-shadow: none !important;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  font-weight: 600;
  font-size: 0.875rem;
  letter-spacing: 0.02em;
}

.admin-secondary-nav .nav-link.active {
  background-color: #fff !important;
  border-color: var(--bs-primary) !important;
  color: var(--bs-primary) !important;
  box-shadow: none !important;
}

.admin-secondary-nav .nav-link.active span {
  border-color: rgba(var(--bs-primary-rgb), 0.25);
}

.admin-page table .form-switch .form-check-input {
  font-size: 1rem;
}

.admin-page table .form-switch .form-check-input:after {
  top: 2px;
}

/* Google-style search suggestions dropdown */
.search-suggest-wrapper {
    width: 100%;
}

.search-suggest-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 2000;
    background: #ffffff;
    border: 1px solid rgba(0, 0, 0, 0.12);
    border-radius: 0.75rem;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.12);
    margin-top: 0.35rem;
    overflow: hidden;
}

.search-suggest-dropdown .list-group {
    border-radius: 0.75rem;
}

.search-suggest-dropdown .list-group-item {
    border: 0;
    padding: 0.75rem 1rem;
    font-size: 0.95rem;
    background: transparent;
}

.search-suggest-dropdown .list-group-item.active {
    background: rgba(203, 12, 159, 0.08);
    color: inherit;
}

.search-suggest-dropdown .suggest-icon {
    display: inline-block;
    width: 1.5rem;
    opacity: 0.6;
}

/* Enterprise search workspace */
.search-page {
  color: #202833;
}

.enterprise-panel {
  background: #ffffff;
  border: 1px solid #d9e0e8;
  border-radius: 8px;
  box-shadow: 0 12px 32px rgba(22, 31, 43, 0.08);
  padding: 1.25rem;
}

.search-command-panel {
  background:
    linear-gradient(135deg, rgba(12, 28, 44, 0.96), rgba(35, 68, 78, 0.95)),
    url("/assets/img/office-dark.jpg") center/cover;
  border-color: #1e3643;
  color: #ffffff;
}

.search-command-panel .text-muted,
.search-command-panel .section-kicker {
  color: rgba(255, 255, 255, 0.72) !important;
}

.section-kicker {
  color: #64748b;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.search-title,
.panel-title,
.profile-name {
  color: inherit;
  font-weight: 700;
  letter-spacing: 0;
}

.search-title {
  font-size: 1.65rem;
}

.panel-title,
.profile-name {
  font-size: 1.25rem;
}

.enterprise-input {
  border-color: #cbd5e1;
  border-radius: 6px;
  min-height: 48px;
}

.search-form .enterprise-input:focus,
.search-form .is-focused .choices__inner,
.search-form .is-open .choices__inner {
  border-color: #38bdf8;
  box-shadow: 0 0 0 2px rgba(56, 189, 248, 0.24);
}

/*
 * The .search-command-panel sets `color: #ffffff` on its dark hero. That cascades
 * into the Choices.js dropdown popup that renders as a child of the panel, making
 * option text white-on-white. Force the popup back to dark, readable text.
 */
.search-command-panel .choices__list--dropdown,
.search-command-panel .choices__list[aria-expanded] {
  color: #1f2937;
  background: #ffffff;
  border: 1px solid #d9e0e8;
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.16);
}

.search-command-panel .choices__list--dropdown .choices__item,
.search-command-panel .choices__list[aria-expanded] .choices__item {
  color: #1f2937;
  background-color: transparent;
}

.search-command-panel .choices__list--dropdown .choices__item--selectable.is-highlighted,
.search-command-panel .choices__list[aria-expanded] .choices__item--selectable.is-highlighted {
  background-color: #f1f5f9;
  color: #0f172a;
}

/* The "Press to select" affordance: keep it visible against the white popup */
.search-command-panel .choices__list--dropdown .choices__item--selectable:after {
  color: #475569;
}

/* Native <select> popup, in case Choices.js fails to attach */
.search-command-panel select option {
  color: #1f2937;
  background: #ffffff;
}

/* Selected value shown on the closed control — readable on the dark hero */
.search-command-panel .choices__inner,
.search-command-panel .choices__list--single .choices__item {
  color: #0f172a;
  background-color: #ffffff;
}

.enterprise-action {
  min-height: 48px;
  border-radius: 6px;
}

.search-metrics {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.search-metrics span {
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 999px;
  padding: 0.45rem 0.7rem;
  color: rgba(255, 255, 255, 0.86);
  font-size: 0.82rem;
}

.search-options {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.option-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  border: 1px solid rgba(255, 255, 255, 0.24);
  border-radius: 999px;
  padding: 0.5rem 0.75rem;
  color: rgba(255, 255, 255, 0.9);
  margin: 0;
  font-size: 0.84rem;
  line-height: 1;
}

.option-pill input {
  accent-color: #38bdf8;
}

.radius-form {
  border-top: 1px solid rgba(255, 255, 255, 0.16);
  padding-top: 1rem;
}

.result-row {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}

.result-avatar,
.profile-avatar,
.avatar-initials {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  background: linear-gradient(135deg, #0f766e, #2563eb);
  color: #ffffff;
  font-weight: 800;
  letter-spacing: 0;
  overflow: hidden;
}

.result-avatar {
  width: 52px;
  height: 52px;
  border-radius: 8px;
  text-decoration: none;
}

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

.result-main {
  min-width: 0;
}

.result-name {
  font-size: 1rem;
}

.result-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-top: 0.55rem;
}

.result-tags span {
  background: #eef6f5;
  border: 1px solid #cde7e2;
  border-radius: 999px;
  color: #175e59;
  font-size: 0.76rem;
  padding: 0.22rem 0.5rem;
}

.result-divider {
  border: 0;
  border-top: 1px solid #e5eaf0;
  margin: 1rem 0;
}

.profile-avatar {
  width: 72px;
  height: 72px;
  border-radius: 10px;
  font-size: 1.25rem;
}

.profile-avatar-large {
  width: 160px;
  height: 160px;
  font-size: 2.75rem;
}

.profile-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  color: #64748b;
}

.profile-meta span {
  background: #f1f5f9;
  border-radius: 999px;
  padding: 0.35rem 0.65rem;
}

.google-map-panel,
.empty-map-panel {
  width: 100%;
  min-height: 420px;
  border: 1px solid #d9e0e8;
  border-radius: 8px;
  overflow: hidden;
}

.empty-map-panel {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #64748b;
  background: #f8fafc;
  padding: 1rem;
  text-align: center;
}

.metric-stack {
  min-width: 120px;
  text-align: right;
}

.metric-value {
  color: #0f172a;
  font-size: 1.8rem;
  font-weight: 800;
  line-height: 1;
}

.metric-label {
  color: #64748b;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.demographic-grid {
  display: grid;
  gap: 1rem;
}

.demo-row {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  border-bottom: 1px solid #e5eaf0;
  padding: 0.45rem 0;
  color: #475569;
}

.demo-row strong {
  color: #0f172a;
}

.avatar-sm {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  font-size: 0.72rem;
}

@media (max-width: 768px) {
  .enterprise-panel {
    padding: 1rem;
  }

  .result-row {
    gap: 0.75rem;
  }

  .result-avatar {
    width: 44px;
    height: 44px;
  }

  .metric-stack {
    text-align: left;
  }
}

/*
 * Dropdown popup width and word-wrap: the "Mobile Number" option was wrapping
 * mid-word ("Mobile Num\nber") because the popup inherited the narrow select
 * width AND used aggressive word-break. Constrain word-break to between-words
 * only, give the popup a min-width, and allow it to widen past the trigger.
 */
.choices__list--dropdown,
.choices__list[aria-expanded] {
  min-width: 220px;
  width: max-content;
  max-width: 320px;
}

.choices__list--dropdown .choices__item,
.choices__list[aria-expanded] .choices__item {
  white-space: normal;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}

/*
 * Mobile (<= 576px) — tighten the search workspace so the form doesn't overflow
 * the viewport. Stack the search input / field selector / button vertically and
 * shrink the title.
 */
@media (max-width: 576px) {
  .search-page {
    padding-left: 0.25rem;
    padding-right: 0.25rem;
  }

  .search-command-panel {
    padding: 1rem;
  }

  .search-title {
    font-size: 1.25rem;
  }

  .search-form .row > [class*="col-"] {
    flex: 0 0 100%;
    max-width: 100%;
  }

  .search-options {
    flex-wrap: wrap;
    gap: 0.5rem;
  }

  .option-pill {
    flex: 1 1 auto;
    min-width: 0;
    white-space: nowrap;
  }

  /* Result rows — let cells wrap instead of overflowing */
  .result-row,
  .result-row * {
    overflow-wrap: anywhere;
    word-break: normal;
  }

  /* Tables on phones: enable horizontal scroll instead of squashing */
  .search-page .table-responsive,
  .admin-page .table-responsive {
    -webkit-overflow-scrolling: touch;
  }
}


/* ========================================================================
 * INVESTIGATIVE INTELLIGENCE THEME
 *
 * A distinctive design language for the people-intelligence product.
 * No generic AI gradient template — IBM Plex family typography, warm
 * near-black + off-white surfaces, single amber signal colour, sharp
 * geometry, motion that earns its keep.
 *
 * Inspired by: Bloomberg terminal density, Stripe docs typography,
 * intelligence dashboards. Built to look like a tool used by people
 * who do serious work.
 * ======================================================================== */

/* Manrope is loaded from Google Fonts in the layout <head>. We declare a
 * single-typeface system (Manrope for everything) so the entire app feels
 * cohesive — geometric sans in the Aeonik/Revolut tradition. IBM Plex Mono
 * stays for IDs / tabular numerics where monospace alignment matters. */

:root {
  /* Typography */
  --font-sans: "Manrope", -apple-system, BlinkMacSystemFont,
               "Segoe UI", "Helvetica Neue", sans-serif;
  --font-serif: "Manrope", -apple-system, BlinkMacSystemFont,
               "Segoe UI", "Helvetica Neue", sans-serif;
  --font-display: "Manrope", -apple-system, BlinkMacSystemFont,
               "Segoe UI", "Helvetica Neue", sans-serif;
  --font-mono: "IBM Plex Mono", ui-monospace, SFMono-Regular,
               "JetBrains Mono", Menlo, Consolas, monospace;

  /* Type scale — slightly tighter than Linear-clone defaults */
  --t-2xs: 0.6875rem;   /* 11px — captions, footnotes */
  --t-xs:  0.75rem;     /* 12px — metadata */
  --t-sm:  0.8125rem;   /* 13px — secondary body */
  --t-base:0.875rem;    /* 14px — body */
  --t-md:  1rem;        /* 16px — large body */
  --t-lg:  1.125rem;    /* 18px — h4 */
  --t-xl:  1.375rem;    /* 22px — h2 */
  --t-2xl: 1.75rem;     /* 28px — h1 */
  --t-3xl: 2.25rem;     /* 36px — display */

  /* Palette — warm, not slate. Off-white #fafaf7 reads as paper, not screen. */
  --paper:        #fafaf7;
  --paper-2:      #f3f2ed;   /* secondary surface */
  --paper-3:      #e8e6df;   /* tertiary surface */
  --line:         #d9d6cd;   /* default border */
  --line-strong:  #b8b4a8;   /* heavier border */
  --ink:          #0d0d0f;   /* near-black — primary text */
  --ink-2:        #1f1f23;   /* secondary text */
  --ink-3:        #43434a;   /* tertiary text */
  --mute:         #7a7770;   /* muted */
  --mute-2:       #9a9790;   /* extra-muted */

  /* Single signal colour — amber. Used sparingly for emphasis. */
  --signal:       #b45309;          /* amber-700 — primary signal */
  --signal-2:     #92400e;          /* amber-800 — hover */
  --signal-bg:    rgba(180, 83, 9, 0.08);
  --signal-line:  rgba(180, 83, 9, 0.28);

  /* Status colors — restrained */
  --danger: #b91c1c;
  --warn:   #b45309;
  --ok:     #15803d;
  --info:   #1d4ed8;

  /* Geometry — sharper than the template defaults */
  --r-sm: 2px;
  --r:    3px;
  --r-lg: 4px;
  --r-pill: 999px;

  /* Shadows — almost imperceptible, just enough to create depth */
  --shadow-1: 0 1px 0 rgba(13, 13, 15, 0.04);
  --shadow-2: 0 1px 2px rgba(13, 13, 15, 0.06), 0 1px 0 rgba(13, 13, 15, 0.04);
  --shadow-3: 0 4px 12px rgba(13, 13, 15, 0.08), 0 1px 0 rgba(13, 13, 15, 0.04);

  /* Motion */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-snap: cubic-bezier(0.4, 0, 0.2, 1);

  /* Legacy aliases so the older custom.css blocks above still resolve */
  --brand-bg: var(--paper);
  --brand-surface: #ffffff;
  --brand-surface-2: var(--paper-2);
  --brand-border: var(--line);
  --brand-border-strong: var(--line-strong);
  --brand-ink: var(--ink);
  --brand-ink-2: var(--ink-2);
  --brand-muted: var(--ink-3);
  --brand-muted-2: var(--mute);
  --brand-primary: var(--ink);
  --brand-primary-2: var(--ink-2);
  --brand-accent: var(--signal);
  --brand-accent-2: var(--signal-2);
  --brand-radius: var(--r);
  --brand-radius-lg: var(--r-lg);
}

/* ------------------------------------------------------------------------
 * Reset playful Soft UI defaults
 * ------------------------------------------------------------------------ */

html, body, button, input, select, textarea {
  font-family: var(--font-sans) !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: "ss01", "cv01", "cv11";
}

body.bg-gray-100 {
  background: var(--paper) !important;
  color: var(--ink);
  font-size: var(--t-base);
  line-height: 1.5;
  letter-spacing: -0.005em;
  padding: 0 !important;
}

/* Subtle paper grain — gives the off-white surface a texture beyond flat colour */
body.bg-gray-100::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.4;
  background-image: radial-gradient(rgba(13, 13, 15, 0.025) 1px, transparent 1px);
  background-size: 24px 24px;
}
main.main-content,
.navbar,
.modal { position: relative; z-index: 1; }

/* ------------------------------------------------------------------------
 * Typography — distinct from generic Inter/Roboto template look
 * ------------------------------------------------------------------------ */

h1, .h1, h2, .h2 {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -0.028em;
  color: var(--ink);
  line-height: 1.1;
}
h1, .h1 { font-size: var(--t-2xl); }
h2, .h2 { font-size: var(--t-xl); }
h3, .h3, h4, .h4 {
  font-family: var(--font-sans);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--ink);
}
h3, .h3 { font-size: var(--t-lg); line-height: 1.3; }
h4, .h4 { font-size: var(--t-md); line-height: 1.35; }
h5, .h5 { font-size: var(--t-base); font-weight: 600; }
h6, .h6 {
  font-size: var(--t-2xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--mute);
}

.search-title {
  font-family: var(--font-display) !important;
  font-size: var(--t-2xl) !important;
  font-weight: 700 !important;
  letter-spacing: -0.028em !important;
  color: var(--ink) !important;
}
.search-command-panel .search-title { color: var(--paper) !important; }

.section-kicker {
  font-family: var(--font-mono) !important;
  font-size: var(--t-2xs) !important;
  font-weight: 500 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.14em !important;
  color: var(--signal) !important;
}
.search-command-panel .section-kicker {
  color: rgba(180, 83, 9, 0.85) !important;
}

.text-muted, p.text-muted { color: var(--mute) !important; }
.font-weight-bolder, .font-weight-bold { font-weight: 600 !important; }

/* Tabular nums on IDs, scores, counts */
.id-mono, .tabular, td.numeric, .metric-value, .demo-row strong,
.search-page .table td.numeric {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum", "zero";
}

/* ------------------------------------------------------------------------
 * Navbar — top-bar editorial, not a floating pill
 * ------------------------------------------------------------------------ */

.navbar.navbar-expand-lg.bg-gradient-primary {
  background: var(--ink) !important;
  background-image: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
  padding: 0 1.5rem !important;
  border-bottom: 1px solid #2a2a2e;
  box-shadow: var(--shadow-2);
  min-height: 56px;
}

.navbar-nav .nav-link {
  font-family: var(--font-sans) !important;
  font-size: var(--t-sm) !important;
  font-weight: 500 !important;
  letter-spacing: 0;
  padding: 1rem 0 !important;
  margin: 0 0.85rem !important;
  color: rgba(250, 250, 247, 0.7) !important;
  border-bottom: 2px solid transparent;
  border-radius: 0 !important;
  transition: color 120ms var(--ease-out), border-color 120ms var(--ease-out);
}
.navbar-nav .nav-link:hover {
  color: var(--paper) !important;
  background: transparent !important;
  border-bottom-color: var(--signal);
}
.navbar-nav .nav-link.active,
.navbar-nav .nav-link[aria-current="page"] {
  color: var(--paper) !important;
  border-bottom-color: var(--signal);
}

/* User badge on the right */
.navbar-nav.ms-auto .nav-link {
  color: rgba(250, 250, 247, 0.55) !important;
  border-bottom: none;
}
.navbar-nav.ms-auto .nav-item:last-child .nav-link {
  color: rgba(250, 250, 247, 0.8) !important;
}
.navbar-nav.ms-auto .nav-item:last-child .nav-link:hover {
  color: var(--signal) !important;
}

main.main-content { margin-top: 2rem !important; }

/* ------------------------------------------------------------------------
 * Cards / panels — sharper, with editorial hairlines
 * ------------------------------------------------------------------------ */

.enterprise-panel {
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: var(--r);
  box-shadow: none;
  padding: 1.5rem;
}
.card, .card-body { border-radius: var(--r) !important; }

/* ------------------------------------------------------------------------
 * Buttons — sharp, monochrome by default, amber for primary actions
 * ------------------------------------------------------------------------ */

.btn {
  font-family: var(--font-sans) !important;
  font-size: var(--t-sm) !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  border-radius: var(--r) !important;
  border-width: 1px !important;
  padding: 0.5rem 1rem !important;
  transition: background-color 120ms var(--ease-out),
              border-color 120ms var(--ease-out),
              color 120ms var(--ease-out),
              transform 80ms var(--ease-out);
}
.btn-lg {
  font-size: var(--t-base) !important;
  padding: 0.65rem 1.25rem !important;
}
.btn:active { transform: translateY(1px); }

/* Primary — the ONE place amber actually appears as a fill */
.btn.bg-gradient-primary,
.btn-primary {
  background: var(--signal) !important;
  background-image: none !important;
  border-color: var(--signal) !important;
  color: #ffffff !important;
}
.btn.bg-gradient-primary:hover,
.btn-primary:hover {
  background: var(--signal-2) !important;
  border-color: var(--signal-2) !important;
  color: #ffffff !important;
}

/* Secondary / dark — used for "Search" etc */
.btn-dark {
  background: var(--ink) !important;
  border-color: var(--ink) !important;
  color: var(--paper) !important;
}
.btn-dark:hover {
  background: var(--ink-2) !important;
  border-color: var(--ink-2) !important;
}

/* Outline variants */
.btn-outline-dark, .btn-outline-primary {
  background: transparent !important;
  border-color: var(--ink) !important;
  color: var(--ink) !important;
}
.btn-outline-dark:hover, .btn-outline-primary:hover {
  background: var(--ink) !important;
  color: var(--paper) !important;
}

.btn-outline-light {
  border-color: rgba(250, 250, 247, 0.4) !important;
  color: var(--paper) !important;
}
.btn-outline-light:hover {
  background: rgba(250, 250, 247, 0.08) !important;
  border-color: var(--paper) !important;
}

/* ------------------------------------------------------------------------
 * Forms — flatter, with monospace placeholders for fields that accept codes
 * ------------------------------------------------------------------------ */

.form-control, .form-select {
  font-family: var(--font-sans) !important;
  font-size: var(--t-base) !important;
  color: var(--ink) !important;
  background: #ffffff !important;
  border: 1px solid var(--line) !important;
  border-radius: var(--r) !important;
  padding: 0.55rem 0.75rem !important;
  min-height: 40px;
  box-shadow: none !important;
  transition: border-color 120ms var(--ease-out),
              box-shadow 120ms var(--ease-out);
}
.form-control-lg {
  font-size: var(--t-base) !important;
  padding: 0.7rem 0.9rem !important;
  min-height: 46px;
}
.form-control:focus, .form-select:focus {
  border-color: var(--ink) !important;
  box-shadow: 0 0 0 3px rgba(13, 13, 15, 0.08) !important;
  outline: none !important;
}
.form-control::placeholder { color: var(--mute-2); }

/* ------------------------------------------------------------------------
 * Tables — editorial density, monospace numerics
 * ------------------------------------------------------------------------ */

.table {
  font-size: var(--t-sm);
  color: var(--ink);
  margin: 0;
}
.table > thead > tr > th {
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mute) !important;
  background: transparent !important;
  border-bottom: 1px solid var(--line-strong) !important;
  border-top: 0 !important;
  padding: 0.65rem 0.85rem;
}
.table > tbody > tr > td {
  padding: 0.7rem 0.85rem;
  border-top: 0 !important;
  border-bottom: 1px solid var(--line) !important;
  color: var(--ink);
  vertical-align: middle;
}
.table > tbody > tr:last-child > td { border-bottom: 0 !important; }
.table > tbody > tr { transition: background-color 100ms var(--ease-out); }
.table > tbody > tr:hover > td { background: var(--paper-2); }

.table td.numeric, .table th.numeric {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-family: var(--font-mono);
}
.table .id-mono { font-family: var(--font-mono); color: var(--ink-3); }

/* ------------------------------------------------------------------------
 * Search command panel — editorial dark hero
 * ------------------------------------------------------------------------ */

.search-command-panel {
  background: var(--ink) !important;
  background-image:
    radial-gradient(ellipse at top right, rgba(180, 83, 9, 0.18), transparent 50%),
    radial-gradient(ellipse at bottom left, rgba(180, 83, 9, 0.06), transparent 60%) !important;
  background-color: var(--ink) !important;
  border: 1px solid #2a2a2e !important;
  border-radius: var(--r) !important;
  padding: 1.75rem 1.75rem !important;
  color: var(--paper);
  position: relative;
  overflow: hidden;
}

/* A subtle horizontal scanline at the top for an "instrument panel" feel */
.search-command-panel::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--signal) 50%, transparent);
  opacity: 0.6;
}

.search-command-panel .text-muted {
  color: rgba(250, 250, 247, 0.55) !important;
}

.search-metrics {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.search-metrics span {
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: transparent;
  color: rgba(250, 250, 247, 0.9);
  border: 1px solid rgba(250, 250, 247, 0.18);
  padding: 0.35rem 0.7rem;
  border-radius: var(--r);
}

.search-options { display: flex; flex-wrap: wrap; gap: 0.4rem; align-items: center; }
.option-pill {
  font-family: var(--font-sans);
  font-size: var(--t-sm);
  font-weight: 500;
  letter-spacing: 0;
  background: transparent;
  border: 1px solid rgba(250, 250, 247, 0.18);
  color: rgba(250, 250, 247, 0.8);
  padding: 0.3rem 0.75rem;
  border-radius: var(--r);
  cursor: pointer;
  user-select: none;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  transition: background 120ms var(--ease-out),
              border-color 120ms var(--ease-out),
              color 120ms var(--ease-out);
}
.option-pill input { display: none; }
.option-pill:hover {
  background: rgba(250, 250, 247, 0.04);
  border-color: rgba(250, 250, 247, 0.32);
  color: var(--paper);
}
.option-pill:has(input:checked) {
  background: var(--signal-bg);
  border-color: var(--signal);
  color: var(--paper);
}
.option-pill:has(input:checked)::before {
  content: "●";
  color: var(--signal);
  font-size: 0.6em;
}

/* ------------------------------------------------------------------------
 * Search results — editorial grid, single accent bar on row hover
 * ------------------------------------------------------------------------ */

.results-panel {
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: var(--r);
  overflow: hidden;
}

.results-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.85rem 1.5rem;
  border-bottom: 1px solid var(--line);
  background: var(--paper-2);
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--mute);
}
.results-header strong {
  font-family: var(--font-mono);
  font-weight: 600;
  color: var(--ink);
  font-size: var(--t-sm);
}

.result-row {
  display: grid;
  grid-template-columns: 4px 44px 1fr auto;
  gap: 0;
  padding: 0;
  align-items: stretch;
  border-bottom: 1px solid var(--line);
  text-decoration: none !important;
  position: relative;
  cursor: pointer;
  animation: row-in 320ms var(--ease-out) backwards;
}
.result-row:nth-child(1) { animation-delay: 0ms; }
.result-row:nth-child(2) { animation-delay: 30ms; }
.result-row:nth-child(3) { animation-delay: 60ms; }
.result-row:nth-child(4) { animation-delay: 90ms; }
.result-row:nth-child(5) { animation-delay: 120ms; }
.result-row:nth-child(n+6) { animation-delay: 150ms; }

@keyframes row-in {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}

.result-row::before {
  content: "";
  background: transparent;
  transition: background 140ms var(--ease-out);
}
.result-row:hover::before { background: var(--signal); }
.result-row:hover { background: var(--paper-2); }
.result-row:last-child { border-bottom: 0; }

.result-row > .result-avatar {
  margin: 1rem 0.85rem 1rem 1rem;
  align-self: center;
}
.result-row > .result-main {
  padding: 1rem 1rem 1rem 0;
  min-width: 0;
}
.result-row > .result-score {
  padding: 1rem 1.5rem 1rem 1rem;
  align-self: center;
}

.result-avatar {
  width: 44px;
  height: 44px;
  border-radius: var(--r);
  overflow: hidden;
  background: var(--ink);
  color: var(--paper);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: var(--t-sm);
  font-weight: 500;
  letter-spacing: 0.04em;
  text-decoration: none;
  flex-shrink: 0;
}
.result-avatar img { width: 100%; height: 100%; object-fit: cover; }

.result-name {
  font-family: var(--font-serif) !important;
  font-size: var(--t-md) !important;
  font-weight: 600 !important;
  color: var(--ink) !important;
  margin: 0 0 0.2rem !important;
  letter-spacing: -0.012em;
  line-height: 1.25;
}
.result-row:hover .result-name { color: var(--ink); }
.result-name a { color: inherit !important; text-decoration: none; }

.result-meta {
  font-family: var(--font-sans);
  font-size: var(--t-sm);
  color: var(--ink-3);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.result-meta .sep {
  color: var(--line-strong);
  padding: 0 0.55rem;
  font-weight: 300;
}
.result-meta .id-mono {
  font-family: var(--font-mono);
  font-size: var(--t-sm);
  color: var(--ink-2);
  font-variant-numeric: tabular-nums;
}
.result-meta .text-muted { color: var(--mute) !important; }

.result-divider { display: none !important; }

.result-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  margin-top: 0.5rem;
}
.result-tags span {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  font-weight: 500;
  color: var(--ink-3);
  background: var(--paper-2);
  border: 1px solid var(--line);
  padding: 0.15rem 0.55rem;
  border-radius: var(--r-sm);
  letter-spacing: 0.02em;
}

.result-score {
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  font-weight: 500;
  color: var(--mute);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* ------------------------------------------------------------------------
 * Pagination
 * ------------------------------------------------------------------------ */

.pagination { gap: 0.2rem; }
.pagination .page-link {
  font-family: var(--font-mono);
  font-size: var(--t-2xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ink-2);
  background: #ffffff !important;
  border: 1px solid var(--line) !important;
  border-radius: var(--r) !important;
  padding: 0.45rem 0.75rem;
  transition: all 120ms var(--ease-out);
}
.pagination .page-link:hover {
  background: var(--paper-2) !important;
  border-color: var(--line-strong) !important;
  color: var(--ink) !important;
}
.pagination .page-item.active .page-link {
  background: var(--ink) !important;
  border-color: var(--ink) !important;
  color: var(--paper) !important;
}
.pagination .page-item.disabled .page-link {
  color: var(--mute-2);
  background: #ffffff !important;
  border-color: var(--line) !important;
  opacity: 0.55;
}

/* ------------------------------------------------------------------------
 * Alerts — minimal, single accent stripe on the left
 * ------------------------------------------------------------------------ */

.alert {
  font-family: var(--font-sans) !important;
  font-size: var(--t-sm) !important;
  font-weight: 500 !important;
  background: #ffffff !important;
  background-image: none !important;
  border: 1px solid var(--line) !important;
  border-left: 3px solid var(--mute) !important;
  border-radius: var(--r) !important;
  color: var(--ink) !important;
  padding: 0.75rem 1rem !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: 0.6rem !important;
  box-shadow: var(--shadow-1);
}
.alert strong { font-weight: 600 !important; }
.alert .alert-text { color: inherit !important; }

.alert.alert-danger  { border-left-color: var(--danger) !important; color: var(--ink) !important; }
.alert.alert-warning { border-left-color: var(--warn) !important;   color: var(--ink) !important; }
.alert.alert-success { border-left-color: var(--ok) !important;     color: var(--ink) !important; }
.alert.alert-info    { border-left-color: var(--info) !important;   color: var(--ink) !important; }

.alert .btn-close {
  margin-left: auto !important;
  filter: none !important;
  opacity: 0.5;
}
.alert .btn-close:hover { opacity: 1; }

/* ========================================================================
 * LOGIN PAGE — Revolut-grade B&W split-screen.
 *
 * Pure black/white palette. No chromatic accents. The right panel is the
 * statement; the left is a quiet, well-engineered form. Locked viewport
 * (no scroll). Manrope display weights carry the editorial tone.
 * ======================================================================== */

/* Hard lock the page to the viewport — no scrollbar, no page-grain. */
body.login-page {
  overflow: hidden !important;
  height: 100vh !important;
  background: #ffffff !important;
  padding: 0 !important;
  margin: 0 !important;
}
body.login-page::before { display: none !important; }

.login-shell {
  display: grid;
  grid-template-columns: minmax(440px, 1fr) 1.15fr;
  height: 100vh;
  width: 100vw;
  background: #ffffff;
  color: #0a0a0a;
  font-family: var(--font-sans);
}

/* ---- LEFT: form column ------------------------------------------------- */

.login-form-col {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 2.25rem 3.5rem 2rem;
  background: #ffffff;
  position: relative;
}

.login-brand {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-family: var(--font-sans);
}
.login-brand-mark {
  font-weight: 800;
  font-size: 1.125rem;
  letter-spacing: -0.04em;
  color: #0a0a0a;
}
.login-brand-divider {
  width: 1px;
  height: 14px;
  background: #cfcfcf;
}
.login-brand-tag {
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #6e6e6e;
  text-transform: uppercase;
}

.login-card {
  max-width: 380px;
  width: 100%;
  margin: auto 0;
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
}

.login-eyebrow {
  font-family: var(--font-mono);
  font-size: 0.6875rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #6e6e6e;
  margin: 0 0 1rem;
}

.login-headline {
  font-family: var(--font-display);
  font-size: 2.5rem;
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.05;
  color: #0a0a0a;
  margin: 0 0 0.75rem;
}

.login-subtitle {
  font-size: 0.95rem;
  color: #4a4a4a;
  line-height: 1.5;
  margin: 0 0 2rem;
}

.login-alert {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.75rem 0.9rem;
  margin: 0 0 1.25rem;
  background: #0a0a0a;
  color: #ffffff;
  font-size: 0.85rem;
  border-radius: 6px;
}
.login-alert-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #ffffff;
  animation: login-alert-pulse 1.4s infinite;
}
@keyframes login-alert-pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.35; }
}

.login-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.login-field {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}

.login-field-label {
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: #0a0a0a;
}

.login-input {
  appearance: none;
  width: 100%;
  height: 48px;
  padding: 0 1rem;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 500;
  color: #0a0a0a;
  background: #ffffff;
  border: 1px solid #d4d4d4;
  border-radius: 8px;
  transition: border-color 140ms var(--ease-out), box-shadow 140ms var(--ease-out);
}
.login-input::placeholder { color: #a0a0a0; font-weight: 400; }
.login-input:hover { border-color: #0a0a0a; }
.login-input:focus {
  outline: none;
  border-color: #0a0a0a;
  box-shadow: 0 0 0 3px rgba(10, 10, 10, 0.08);
}

.login-submit {
  appearance: none;
  margin-top: 0.5rem;
  height: 52px;
  padding: 0 1.25rem;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: -0.005em;
  color: #ffffff;
  background: #0a0a0a;
  border: 1px solid #0a0a0a;
  border-radius: 8px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  transition: background 140ms var(--ease-out), transform 140ms var(--ease-out);
}
.login-submit:hover { background: #2a2a2a; }
.login-submit:active { transform: translateY(1px); }
.login-submit:focus-visible {
  outline: 2px solid #0a0a0a !important;
  outline-offset: 3px;
}
.login-submit svg {
  transition: transform 200ms var(--ease-out);
}
.login-submit:hover svg { transform: translateX(3px); }

.login-foot {
  font-size: 0.75rem;
  color: #6e6e6e;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  letter-spacing: 0.01em;
}
.login-foot-sep { color: #c0c0c0; }

/* ---- RIGHT: editorial stage ------------------------------------------- */

.login-stage {
  position: relative;
  background: #0a0a0a;
  color: #f5f5f5;
  padding: 3.25rem 3.75rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
}

.login-stage-grid {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(to right, rgba(255, 255, 255, 0.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255, 255, 255, 0.04) 1px, transparent 1px);
  background-size: 64px 64px;
  background-position: -1px -1px;
  mask-image: radial-gradient(ellipse at center, #000 30%, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse at center, #000 30%, transparent 80%);
}

.login-stage-inner {
  position: relative;
  z-index: 1;
  max-width: 580px;
}

.login-stage-eyebrow {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #ffffff;
  opacity: 0.55;
  margin: 0 0 2rem;
}

.login-stage-display {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 4.6vw, 4.25rem);
  font-weight: 700;
  letter-spacing: -0.04em;
  line-height: 1.02;
  color: #ffffff;
  margin: 0 0 1.5rem;
}
.login-stage-display em {
  font-style: italic;
  font-weight: 700;
  color: #ffffff;
  position: relative;
}
.login-stage-display em::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0.04em;
  height: 2px;
  background: #ffffff;
  opacity: 0.9;
}

.login-stage-body {
  font-size: 1.0625rem;
  color: rgba(255, 255, 255, 0.7);
  line-height: 1.55;
  max-width: 460px;
  margin: 0 0 3rem;
}

.login-stage-stats {
  list-style: none;
  margin: 0;
  padding: 1.75rem 0 0;
  display: grid;
  grid-template-columns: repeat(3, max-content);
  gap: 2.75rem;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}
.login-stage-stats li {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}
.login-stat-value {
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 700;
  letter-spacing: -0.025em;
  color: #ffffff;
  font-variant-numeric: tabular-nums;
}
.login-stat-label {
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.5);
  font-weight: 500;
}

.login-stage-corner {
  position: absolute;
  left: 3.75rem;
  right: 3.75rem;
  bottom: 2.25rem;
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  color: rgba(255, 255, 255, 0.4);
  text-transform: uppercase;
  z-index: 1;
}

/* ---- Responsive: collapse to single column under 980px ---------------- */

@media (max-width: 980px) {
  body.login-page { overflow: auto !important; height: auto !important; }
  .login-shell {
    grid-template-columns: 1fr;
    height: auto;
    min-height: 100vh;
  }
  .login-stage { display: none; }
  .login-form-col {
    padding: 1.75rem 1.5rem;
    min-height: 100vh;
  }
}

/* ------------------------------------------------------------------------
 * Focus rings — consistent across the system, no template-glow
 * ------------------------------------------------------------------------ */

a:focus-visible,
button:focus-visible,
.btn:focus-visible,
.form-control:focus-visible,
.form-select:focus-visible,
.page-link:focus-visible,
[tabindex]:focus-visible {
  outline: 2px solid var(--ink) !important;
  outline-offset: 2px;
  box-shadow: none !important;
}

/* ------------------------------------------------------------------------
 * Motion — global timing function (overrides the bouncy Soft UI cubic)
 * ------------------------------------------------------------------------ */

* { transition-timing-function: var(--ease-out) !important; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 50ms !important;
  }
}

/* ------------------------------------------------------------------------
 * Radius page — match the editorial language
 * ------------------------------------------------------------------------ */

.radius-command-panel {
  background: #ffffff !important;
  border: 1px solid var(--line) !important;
  border-radius: var(--r);
}
.radius-command-panel .section-kicker { color: var(--signal) !important; }
.radius-command-panel .search-title { color: var(--ink) !important; }
.radius-command-panel p code {
  font-family: var(--font-mono);
  background: var(--paper-2);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  padding: 0.05rem 0.4rem;
  color: var(--ink-2);
  font-size: 0.92em;
}

.poi-pill {
  font-family: var(--font-sans);
  font-size: var(--t-sm);
  font-weight: 500;
  background: #ffffff;
  border: 1px solid var(--line);
  color: var(--ink-2);
  border-radius: var(--r);
  padding: 0.35rem 0.7rem;
  cursor: pointer;
  user-select: none;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  transition: all 120ms var(--ease-out);
}
.poi-pill:hover {
  border-color: var(--ink);
  color: var(--ink);
}
.poi-pill:has(input:checked) {
  background: var(--signal-bg);
  border-color: var(--signal);
  color: var(--signal-2);
}
.poi-pill input { display: none; }

/* Leaflet popup styling */
.leaflet-popup-content-wrapper {
  border-radius: var(--r) !important;
  box-shadow: var(--shadow-3) !important;
  font-family: var(--font-sans);
  font-size: var(--t-sm);
}
.leaflet-popup-content b { font-family: var(--font-serif); font-weight: 600; }

/* ------------------------------------------------------------------------
 * Responsive — keep editorial restraint on small screens
 * ------------------------------------------------------------------------ */

@media (max-width: 992px) {
  main.main-content { margin-top: 1.25rem !important; }
  .search-title { font-size: var(--t-xl) !important; }
  #radius-map { height: 480px !important; }
}

@media (max-width: 576px) {
  .navbar.navbar-expand-lg.bg-gradient-primary { padding: 0 1rem !important; }
  .navbar-nav .nav-link { padding: 0.85rem 0 !important; margin: 0 0.65rem !important; }
  .enterprise-panel { padding: 1rem; }
  .search-command-panel { padding: 1.25rem !important; }
  .results-header { padding: 0.65rem 1rem; }
  .result-row > .result-avatar { margin: 0.85rem 0.65rem 0.85rem 0.85rem; }
  .result-row > .result-main { padding: 0.85rem 0.85rem 0.85rem 0; }
  .result-row > .result-score { padding: 0.85rem 1rem 0.85rem 0.5rem; }
  .result-name { font-size: var(--t-base) !important; }
  .result-meta { white-space: normal; }
  .search-title { font-size: var(--t-lg) !important; }
  #radius-map { height: 360px !important; }
  .pagination .page-link { padding: 0.4rem 0.6rem; }
}

/* End of investigative theme */

/* ========================================================================
 * SEARCH PAGE POLISH — Revolut-grade B&W refinement.
 *
 * Strips amber accents from the existing investigative theme on the
 * authenticated pages so they match the new login look. Single typeface
 * (Manrope), pure black/white palette, sharper hairlines, restrained
 * motion. Loads LAST so it wins specificity battles without us having
 * to refactor everything above.
 * ======================================================================== */

/* ---- Layout: roomier top spacing, calmer container ---------------- */
body.bg-gray-100 main.main-content,
body.bg-gray-100 .container-fluid.py-4 {
  padding-top: 1.5rem !important;
  padding-bottom: 2.5rem !important;
}

/* ---- Search hero: pure black + faint white grid (no amber) -------- */
.search-command-panel {
  background: #0a0a0a !important;
  background-image: none !important;
  border: 1px solid #1f1f23 !important;
  border-radius: 8px !important;
  padding: 1.85rem 2rem !important;
  position: relative;
  overflow: hidden;
}
.search-command-panel::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  top: 0 !important;
  height: auto !important;
  background-image:
    linear-gradient(to right, rgba(255, 255, 255, 0.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255, 255, 255, 0.04) 1px, transparent 1px) !important;
  background-size: 64px 64px !important;
  background-position: -1px -1px !important;
  -webkit-mask-image: radial-gradient(ellipse at center, #000 35%, transparent 85%) !important;
          mask-image: radial-gradient(ellipse at center, #000 35%, transparent 85%) !important;
  opacity: 1 !important;
  pointer-events: none !important;
  z-index: 0;
}
.search-command-panel > * { position: relative; z-index: 1; }

.search-command-panel .section-kicker {
  color: rgba(255, 255, 255, 0.55) !important;
  font-family: var(--font-mono) !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.16em !important;
}
.search-command-panel .search-title {
  font-family: var(--font-display) !important;
  font-weight: 700 !important;
  letter-spacing: -0.03em !important;
  color: #ffffff !important;
}

/* ---- Search metrics chips: clean mono badges --------------------- */
.search-command-panel .search-metrics span {
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
  color: rgba(255, 255, 255, 0.85) !important;
  font-family: var(--font-mono) !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.08em !important;
  padding: 0.4rem 0.7rem !important;
  border-radius: 4px !important;
}

/* ---- Inputs & buttons inside the hero ---------------------------- */
.enterprise-input.form-control,
.search-command-panel .form-control,
.search-command-panel .choices__inner {
  height: 48px !important;
  background: rgba(255, 255, 255, 0.05) !important;
  border: 1px solid rgba(255, 255, 255, 0.16) !important;
  color: #ffffff !important;
  border-radius: 8px !important;
  font-family: var(--font-sans) !important;
  font-size: 0.95rem !important;
  font-weight: 500 !important;
  padding: 0 1rem !important;
  transition: border-color 140ms var(--ease-out), box-shadow 140ms var(--ease-out), background 140ms var(--ease-out);
}
.search-command-panel .form-control::placeholder { color: rgba(255, 255, 255, 0.45); font-weight: 400; }
.search-command-panel .form-control:hover,
.search-command-panel .choices__inner:hover {
  border-color: rgba(255, 255, 255, 0.32) !important;
}
.search-command-panel .form-control:focus,
.search-command-panel .choices:focus-within .choices__inner {
  outline: none !important;
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: #ffffff !important;
  box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.12) !important;
}

/* Choices.js select-trigger inside the hero */
.search-command-panel .choices__list--single .choices__item {
  color: #ffffff !important;
}
.search-command-panel .choices[data-type*=select-one]::after {
  border-color: rgba(255, 255, 255, 0.6) transparent transparent transparent !important;
}

/* Search button — solid white-on-black like login */
.enterprise-action.btn-dark,
.search-command-panel .btn-dark {
  height: 48px !important;
  background: #ffffff !important;
  border: 1px solid #ffffff !important;
  color: #0a0a0a !important;
  font-family: var(--font-sans) !important;
  font-weight: 600 !important;
  font-size: 0.9rem !important;
  letter-spacing: -0.005em !important;
  border-radius: 8px !important;
  text-transform: none !important;
  box-shadow: none !important;
  transition: background 140ms var(--ease-out), color 140ms var(--ease-out), transform 140ms var(--ease-out);
}
.enterprise-action.btn-dark:hover,
.search-command-panel .btn-dark:hover {
  background: #e8e8e8 !important;
  border-color: #e8e8e8 !important;
  color: #0a0a0a !important;
  transform: none !important;
}

/* CSV / outline button — ghost white */
.enterprise-action.btn-outline-dark,
.search-command-panel .btn-outline-dark {
  height: 48px !important;
  background: transparent !important;
  border: 1px solid rgba(255, 255, 255, 0.32) !important;
  color: #ffffff !important;
  font-family: var(--font-sans) !important;
  font-weight: 600 !important;
  font-size: 0.9rem !important;
  border-radius: 8px !important;
  text-transform: none !important;
  box-shadow: none !important;
}
.enterprise-action.btn-outline-dark:hover {
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: #ffffff !important;
  color: #ffffff !important;
}

/* ---- Option pills: pure B&W, no amber ---------------------------- */
.search-command-panel .option-pill {
  background: transparent !important;
  border: 1px solid rgba(255, 255, 255, 0.18) !important;
  color: rgba(255, 255, 255, 0.8) !important;
  border-radius: 999px !important;
  padding: 0.4rem 0.85rem !important;
  font-size: 0.82rem !important;
  font-weight: 500 !important;
}
.search-command-panel .option-pill:hover {
  background: rgba(255, 255, 255, 0.06) !important;
  border-color: rgba(255, 255, 255, 0.4) !important;
  color: #ffffff !important;
}
.search-command-panel .option-pill:has(input:checked) {
  background: #ffffff !important;
  border-color: #ffffff !important;
  color: #0a0a0a !important;
}
.search-command-panel .option-pill:has(input:checked)::before {
  content: "" !important;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #0a0a0a !important;
  display: inline-block;
  font-size: 0 !important;
  margin-right: 0.15rem;
}

/* ---- Results panel + rows: kill amber, refine hover -------------- */
.results-panel {
  border-radius: 8px !important;
  border: 1px solid #e6e6e6 !important;
  background: #ffffff !important;
  box-shadow: 0 1px 0 rgba(10, 10, 10, 0.02);
}
.results-header {
  background: #fafafa !important;
  border-bottom: 1px solid #e6e6e6 !important;
  padding: 0.9rem 1.5rem !important;
  font-family: var(--font-mono) !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: #6e6e6e !important;
}
.results-header strong {
  font-family: var(--font-mono) !important;
  color: #0a0a0a !important;
  font-size: 0.85rem !important;
}

.result-row {
  border-bottom: 1px solid #ececec !important;
  transition: background 140ms var(--ease-out);
}
.result-row:last-child { border-bottom: 0 !important; }
.result-row::before { background: transparent !important; }
.result-row:hover { background: #fafafa !important; }
.result-row:hover::before { background: #0a0a0a !important; }

.result-avatar {
  background: #0a0a0a !important;
  color: #ffffff !important;
  border-radius: 6px !important;
  font-family: var(--font-mono) !important;
  font-weight: 600 !important;
  letter-spacing: 0.02em !important;
}

.result-name {
  font-family: var(--font-display) !important;
  font-weight: 700 !important;
  letter-spacing: -0.015em !important;
  color: #0a0a0a !important;
  font-size: 1rem !important;
}
.result-meta {
  font-family: var(--font-sans);
  color: #5a5a5a !important;
  font-size: 0.85rem !important;
}
.result-meta .id-mono {
  font-family: var(--font-mono) !important;
  color: #0a0a0a !important;
  font-weight: 500 !important;
}
.result-meta .sep { color: #c8c8c8 !important; padding: 0 0.5rem !important; }

.result-tags {
  margin-top: 0.45rem;
  display: flex;
  gap: 0.35rem;
  flex-wrap: wrap;
}
.result-tags span {
  background: #f0f0f0 !important;
  color: #4a4a4a !important;
  border: 1px solid transparent !important;
  font-family: var(--font-mono) !important;
  font-size: 0.68rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  padding: 0.18rem 0.5rem !important;
  border-radius: 3px !important;
}

.result-score {
  font-family: var(--font-mono) !important;
  font-size: 0.7rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.1em !important;
  color: #6e6e6e !important;
  background: #fafafa !important;
  border: 1px solid #ececec !important;
  border-radius: 4px !important;
  padding: 0.3rem 0.6rem !important;
  align-self: center;
  margin-right: 1rem;
}

/* ---- Empty state card ------------------------------------------- */
.search-page .card {
  border: 1px solid #e6e6e6 !important;
  border-radius: 8px !important;
  box-shadow: none !important;
  background: #ffffff !important;
}
.search-page .card .card-body {
  padding: 2rem !important;
  color: #4a4a4a;
  font-size: 0.95rem;
}

/* ---- Person hero panel ------------------------------------------ */
.person-hero {
  background: #ffffff !important;
  border: 1px solid #e6e6e6 !important;
  border-radius: 8px !important;
  padding: 1.75rem 2rem !important;
  box-shadow: none !important;
}
.profile-name {
  font-family: var(--font-display) !important;
  font-weight: 700 !important;
  letter-spacing: -0.025em !important;
  color: #0a0a0a !important;
  font-size: 1.75rem !important;
}
.profile-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1.25rem;
  margin-top: 0.5rem;
  font-family: var(--font-sans);
  color: #5a5a5a;
  font-size: 0.875rem;
}
.profile-avatar {
  width: 72px;
  height: 72px;
  border-radius: 8px;
  background: #0a0a0a;
  color: #ffffff;
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: 1.25rem;
  letter-spacing: 0.04em;
}

/* ---- Accordion (details/summary) refinement --------------------- */
.search-page details.accordion.card,
.search-page details.card {
  background: #ffffff !important;
  border: 1px solid #e6e6e6 !important;
  border-radius: 8px !important;
  box-shadow: none !important;
  overflow: hidden;
  padding: 0 !important;
}
.search-page details > summary {
  list-style: none;
  cursor: pointer;
  padding: 1rem 1.5rem;
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 0.95rem;
  letter-spacing: -0.005em;
  color: #0a0a0a;
  background: #fafafa;
  border-bottom: 1px solid transparent;
  transition: background 120ms var(--ease-out);
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.search-page details > summary::-webkit-details-marker { display: none; }
.search-page details > summary::marker { content: ""; }
.search-page details > summary::before {
  content: "+";
  font-family: var(--font-mono);
  font-size: 1rem;
  font-weight: 500;
  color: #6e6e6e;
  width: 14px;
  display: inline-block;
  transition: transform 160ms var(--ease-out), color 160ms var(--ease-out);
}
.search-page details[open] > summary::before {
  content: "−";
  color: #0a0a0a;
}
.search-page details[open] > summary {
  background: #ffffff;
  border-bottom: 1px solid #ececec;
}
.search-page details > div {
  padding: 1rem 1.5rem 1.25rem;
}

/* ---- Pagination -------------------------------------------------- */
.pagination .page-link {
  border: 1px solid #e6e6e6 !important;
  color: #0a0a0a !important;
  background: #ffffff !important;
  font-family: var(--font-sans) !important;
  font-weight: 500 !important;
  font-size: 0.85rem !important;
  border-radius: 6px !important;
  margin: 0 2px;
  padding: 0.4rem 0.75rem !important;
  box-shadow: none !important;
}
.pagination .page-link:hover {
  background: #fafafa !important;
  border-color: #0a0a0a !important;
}
.pagination .page-item.disabled .page-link {
  color: #b0b0b0 !important;
  background: #f5f5f5 !important;
  border-color: #ececec !important;
}

/* ---- Inline error alert on the search page --------------------- */
.search-page .alert.alert-danger {
  background: #0a0a0a !important;
  border: none !important;
  border-radius: 8px !important;
  color: #ffffff !important;
  padding: 0.85rem 1rem !important;
}
.search-page .alert.alert-danger strong,
.search-page .alert.alert-danger .alert-text { color: #ffffff !important; }
.search-page .alert.alert-danger .btn-close { filter: invert(1); opacity: 0.7; }

/* ---- Table polish inside accordion ----------------------------- */
.search-page .table > thead > tr > th {
  font-family: var(--font-mono) !important;
  font-size: 0.68rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: #6e6e6e !important;
  background: #fafafa !important;
  border-bottom: 1px solid #ececec !important;
  padding: 0.7rem 0.9rem !important;
}
.search-page .table > tbody > tr > td {
  padding: 0.75rem 0.9rem !important;
  border-bottom: 1px solid #f0f0f0 !important;
  color: #0a0a0a !important;
  font-size: 0.875rem !important;
}
.search-page .table > tbody > tr:hover > td { background: #fafafa !important; }

/* ---- Suggest dropdown — clean B&W ------------------------------ */
.search-suggest-dropdown {
  background: #ffffff !important;
  border: 1px solid #d4d4d4 !important;
  border-radius: 8px !important;
  box-shadow: 0 8px 24px rgba(10, 10, 10, 0.12) !important;
  margin-top: 6px;
}
.search-suggest-dropdown .list-group-item {
  font-family: var(--font-sans);
  color: #0a0a0a !important;
  border: 0 !important;
  background: transparent !important;
}
.search-suggest-dropdown .list-group-item.active,
.search-suggest-dropdown .list-group-item:hover {
  background: #fafafa !important;
  color: #0a0a0a !important;
}

/* ---- Choices.js dropdown menu (when used outside the dark hero) - */
.choices__list--dropdown,
.choices__list[aria-expanded] {
  border: 1px solid #d4d4d4 !important;
  border-radius: 8px !important;
  box-shadow: 0 8px 24px rgba(10, 10, 10, 0.12) !important;
}
.choices__list--dropdown .choices__item--selectable.is-highlighted {
  background: #fafafa !important;
  color: #0a0a0a !important;
}

/* ---- Responsive tightening for search hero --------------------- */
@media (max-width: 768px) {
  .search-command-panel {
    padding: 1.25rem !important;
  }
  .search-command-panel .search-title { font-size: 1.25rem !important; }
}

/* End of search-page polish */

/* ========================================================================
 * BUG-FIX PASS — issues raised against the search workspace.
 *
 *  1. Navbar must align with the cards underneath (not full-bleed).
 *  2. Suggest dropdown was being clipped by the dark hero's overflow.
 *  3. Choices.js dropdown was being clipped for the same reason.
 *  4. Choices trigger showed an empty grey box; "Any field" was hidden,
 *     and there was no label explaining the dropdown's purpose.
 *  5. Avatar overlapped the result name (grid column too narrow).
 * ======================================================================== */

/* (1) Constrain the top-level layout to a centred max-width so the
 *     navbar and the page content share the same left/right edges. */
body.bg-gray-100 > nav.navbar.navbar-expand-lg.bg-gradient-primary,
body.bg-gray-100 > main.main-content {
  max-width: 1400px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 1.25rem !important;
  padding-right: 1.25rem !important;
  width: auto !important;
  box-sizing: border-box;
}

/* Navbar — keep the dark fill but stop it bleeding edge-to-edge,
 * give it the same 8px corners as the cards under it. */
body.bg-gray-100 > nav.navbar.navbar-expand-lg.bg-gradient-primary {
  margin-top: 1rem !important;
  border-radius: 8px !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

/* The inner container-fluid Bootstrap uses inside the navbar should
 * not double-pad — we already pad on the nav itself. */
body.bg-gray-100 > nav.navbar.navbar-expand-lg.bg-gradient-primary
  .container-fluid {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Main content inner container-fluid: drop its own px so the cards
 * align with the navbar exactly. */
body.bg-gray-100 > main.main-content .container-fluid {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* (2)+(3) The hero panel was clipping its own children (suggest +
 *  Choices dropdowns). Switch to visible overflow and keep the grid
 *  pattern contained by clipping ::before alone. */
.search-command-panel {
  overflow: visible !important;
}
.search-command-panel::before {
  clip-path: inset(0 0 0 0 round 8px);
}

/* Suggest dropdown — float it above the panel, away from the input. */
.search-suggest-wrapper { position: relative; }
.search-suggest-dropdown {
  position: absolute !important;
  top: calc(100% + 6px) !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 1080 !important;
  max-height: 320px;
  overflow-y: auto;
}

/* Choices.js dropdown popup — render above the panel boundaries. */
.search-command-panel .choices { position: relative; z-index: 1; }
.search-command-panel .choices.is-open { z-index: 1090; }
.search-command-panel .choices__list--dropdown,
.search-command-panel .choices__list[aria-expanded] {
  z-index: 1090 !important;
  margin-top: 4px;
}

/* (4) Make the Choices trigger show its selected label clearly, and
 *     give every field a visible label above it. */
.search-command-panel .choices__inner {
  display: flex !important;
  align-items: center !important;
  min-height: 48px !important;
  padding: 0 2.25rem 0 1rem !important;
}
.search-command-panel .choices__list--single {
  padding: 0 !important;
  width: 100%;
}
.search-command-panel .choices__list--single .choices__item,
.search-command-panel .choices__placeholder {
  color: #ffffff !important;
  opacity: 1 !important;
  font-family: var(--font-sans) !important;
  font-size: 0.95rem !important;
  font-weight: 500 !important;
  background: transparent !important;
}
.search-command-panel .choices[data-type*=select-one]::after {
  border-color: rgba(255, 255, 255, 0.7) transparent transparent transparent !important;
  right: 14px !important;
}

/* Field label — small mono kicker above each control */
.field-label {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
  margin-bottom: 0.4rem;
}

/* Search button + CSV button align with the controls (which now have
 * labels above) — push them down by the label's height. */
.search-controls-row .col-6 > .enterprise-action,
.search-controls-row .col-md-4 > .enterprise-action,
.search-controls-row .col-xl-2 > .enterprise-action {
  margin-top: 0;
}

/* (5) Result row grid: avatar column too narrow, margin pushed avatar
 *     into the name column. Widen the avatar column and centre the
 *     avatar inside it; .result-main no longer needs left padding. */
.result-row {
  grid-template-columns: 4px 76px 1fr auto !important;
}
.result-row > .result-avatar {
  margin: 0 !important;
  place-self: center !important;
}
.result-row > .result-main {
  padding: 1rem 1rem 1rem 0 !important;
  min-width: 0;
}
.result-row > .result-score {
  margin-right: 1.5rem !important;
}

@media (max-width: 768px) {
  .result-row {
    grid-template-columns: 3px 58px 1fr auto !important;
  }
  .result-row > .result-score {
    margin-right: 1rem !important;
  }
  .field-label { font-size: 0.6rem; }
}

/* End of bug-fix pass */

/* ========================================================================
 * ALIGNMENT — exact navbar / card edge match
 *
 * The navbar's black fill sits at the main padding edge (1.25rem from
 * the 1400px box), but the search card sits inside a .col-12 inside a
 * .row, both of which add their own Bootstrap gutter padding (~12px
 * total on each side). That made the navbar look ~12px wider than the
 * card. Zero the row gutter + col padding on the search page so the
 * card edges line up with the navbar edges exactly.
 * ======================================================================== */
body.bg-gray-100 > main.main-content .search-page > .row,
body.bg-gray-100 > main.main-content .search-page .row {
  --bs-gutter-x: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}
body.bg-gray-100 > main.main-content .search-page > .row > [class*="col-"],
body.bg-gray-100 > main.main-content .search-page .row > [class*="col-"] {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* The Bootstrap row INSIDE the search-command-panel (the field controls
 * row) should keep its gutters — only zero the page-level row. */
.search-command-panel .row {
  --bs-gutter-x: 1rem !important;
}
.search-command-panel .row > [class*="col-"] {
  padding-left: 0.5rem !important;
  padding-right: 0.5rem !important;
}
/* End of alignment fix */

/* ========================================================================
 * NAV/CARD EXACT WIDTH PARITY (round 2)
 *
 * The previous attempt left main with 1.25rem horizontal padding while
 * the navbar's black fill extended to the full 1400px box edges,
 * which made the card render ~40px narrower than the navbar. Zero
 * main's horizontal padding so the card and the navbar share exactly
 * the same outer-box edges; keep the navbar's internal padding so its
 * menu items still inset from the rounded corners.
 * ======================================================================== */
body.bg-gray-100 > main.main-content {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Navbar inner padding moves from the navbar element to its internal
 * .container-fluid so it doesn't affect the bg-fill width. */
body.bg-gray-100 > nav.navbar.navbar-expand-lg.bg-gradient-primary {
  padding-left: 0 !important;
  padding-right: 0 !important;
}
body.bg-gray-100 > nav.navbar.navbar-expand-lg.bg-gradient-primary
  .container-fluid {
  padding-left: 1.5rem !important;
  padding-right: 1.5rem !important;
}

/* The search-command-panel keeps its own internal padding. */

/* ========================================================================
 * PAGINATION REWRITE — clean, no Soft-UI cascade, no wrapping.
 * ======================================================================== */
.page-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.25rem;
  flex-wrap: wrap;
  margin-top: 1.5rem;
  padding: 0.85rem 1.25rem;
  background: #ffffff;
  border: 1px solid #e6e6e6;
  border-radius: 8px;
}

.page-nav-info {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #6e6e6e;
}

.page-nav-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: nowrap;
  white-space: nowrap;
}

.page-nav-btn {
  display: inline-flex !important;
  align-items: center;
  gap: 0.4rem;
  height: 34px;
  padding: 0 0.85rem !important;
  font-family: var(--font-sans) !important;
  font-size: 0.825rem !important;
  font-weight: 600 !important;
  letter-spacing: -0.005em !important;
  text-transform: none !important;
  color: #0a0a0a !important;
  background: #ffffff !important;
  border: 1px solid #d4d4d4 !important;
  border-radius: 6px !important;
  text-decoration: none !important;
  white-space: nowrap;
  cursor: pointer;
  transition: background 120ms var(--ease-out), border-color 120ms var(--ease-out), color 120ms var(--ease-out);
  box-shadow: none !important;
}
.page-nav-btn:hover {
  background: #0a0a0a !important;
  border-color: #0a0a0a !important;
  color: #ffffff !important;
}
.page-nav-btn.is-disabled {
  color: #b0b0b0 !important;
  background: #f5f5f5 !important;
  border-color: #ececec !important;
  cursor: not-allowed;
  pointer-events: none;
}
.page-nav-btn svg { flex-shrink: 0; }

.page-nav-indicator {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #4a4a4a;
  padding: 0 0.65rem;
  white-space: nowrap;
}

/* Suppress the old Bootstrap pagination styles inside search-page (the
 * markup we now emit doesn't use .pagination at all, but defensive). */
.search-page .pagination .page-link {
  text-transform: none !important;
  white-space: nowrap;
  min-width: 0;
}

@media (max-width: 576px) {
  .page-nav { padding: 0.7rem 0.9rem; gap: 0.6rem; }
  .page-nav-info { font-size: 0.65rem; }
  .page-nav-btn { height: 32px; padding: 0 0.7rem !important; font-size: 0.78rem !important; }
  .page-nav-indicator { font-size: 0.72rem; padding: 0 0.4rem; }
}

/* ========================================================================
 * PREDICTED COST CHIP
 * ======================================================================== */
.predicted-cost-chip {
  font-family: var(--font-mono) !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
  color: rgba(255, 255, 255, 0.85) !important;
  padding: 0.4rem 0.7rem !important;
  border-radius: 4px !important;
  display: inline-flex;
  align-items: baseline;
  gap: 0.25rem;
  transition: background 160ms var(--ease-out), border-color 160ms var(--ease-out), color 160ms var(--ease-out);
}
.predicted-cost-chip [data-predicted-cost] {
  font-family: var(--font-mono) !important;
  font-size: 0.85rem;
  font-weight: 600;
  color: #ffffff !important;
  letter-spacing: 0.02em;
  font-variant-numeric: tabular-nums;
  transition: color 160ms var(--ease-out);
}
.predicted-cost-chip.is-bumped {
  background: rgba(255, 255, 255, 0.12) !important;
  border-color: rgba(255, 255, 255, 0.3) !important;
}
/* End of pagination + cost-chip block */

/* ========================================================================
 * RADIUS WORKSPACE — Revolut B&W polish.
 *
 * The page reuses .search-command-panel for its dark hero so the form
 * looks identical to the people-search hero. The rest of the page
 * (map card, POI bar, side panel, demographics, empty state) gets a
 * dedicated language that matches the rest of the app.
 * ======================================================================== */

/* Subtitle under the radius display title */
.search-hero-sub {
  margin: 0.65rem 0 0;
  max-width: 580px;
  color: rgba(255, 255, 255, 0.65);
  font-size: 0.95rem;
  line-height: 1.5;
}
.search-hero-sub code {
  font-family: var(--font-mono);
  font-size: 0.85em;
  color: rgba(255, 255, 255, 0.85);
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 4px;
  padding: 0.05rem 0.4rem;
}

/* ---- Map card --------------------------------------------------------- */
.radius-map-card {
  background: #ffffff;
  border: 1px solid #e6e6e6;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 1px 0 rgba(10, 10, 10, 0.02);
}
#radius-map {
  height: 620px;
  width: 100%;
  background: #f5f5f0;
}
.leaflet-container {
  font-family: var(--font-sans) !important;
}
.leaflet-popup-content-wrapper {
  border-radius: 6px !important;
  font-family: var(--font-sans);
  font-size: 0.85rem;
  color: #0a0a0a;
  box-shadow: 0 8px 24px rgba(10, 10, 10, 0.18) !important;
}
.leaflet-popup-content b {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: -0.015em;
  color: #0a0a0a;
}
.leaflet-popup-tip { background: #ffffff !important; }
.leaflet-bar a, .leaflet-bar a:hover {
  background: #ffffff !important;
  color: #0a0a0a !important;
  border-color: #d4d4d4 !important;
}
.leaflet-bar a:hover { background: #fafafa !important; }
.leaflet-control-attribution {
  background: rgba(255, 255, 255, 0.85) !important;
  font-family: var(--font-mono) !important;
  font-size: 0.65rem !important;
  color: #6e6e6e !important;
}
.leaflet-control-attribution a { color: #0a0a0a !important; }

/* ---- POI bar under the map ------------------------------------------- */
.radius-poi-bar {
  background: #fafafa;
  border-top: 1px solid #ececec;
  padding: 0.9rem 1.25rem 1rem;
}
.radius-poi-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.65rem;
}
.radius-poi-head .section-kicker {
  color: #6e6e6e !important;
  font-family: var(--font-mono) !important;
  font-size: 0.65rem !important;
  letter-spacing: 0.16em !important;
}
.radius-poi-status {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  color: #6e6e6e;
  letter-spacing: 0.04em;
}
.radius-poi-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

/* Override the existing .poi-pill so the radius page matches the
 * option-pill black/white treatment used on the search page. */
.radius-poi-bar .poi-pill {
  position: relative;
  display: inline-flex !important;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.85rem !important;
  font-family: var(--font-sans) !important;
  font-size: 0.8rem !important;
  font-weight: 500 !important;
  color: #2a2a2a !important;
  background: #ffffff !important;
  border: 1px solid #d4d4d4 !important;
  border-radius: 999px !important;
  cursor: pointer;
  user-select: none;
  transition: background 120ms var(--ease-out), color 120ms var(--ease-out), border-color 120ms var(--ease-out);
}
.radius-poi-bar .poi-pill input { display: none; }
.radius-poi-bar .poi-pill i {
  font-size: 0.78rem;
  color: #6e6e6e;
  transition: color 120ms var(--ease-out);
}
.radius-poi-bar .poi-pill:hover {
  background: #f3f3f0 !important;
  border-color: #0a0a0a !important;
  color: #0a0a0a !important;
}
.radius-poi-bar .poi-pill:has(input:checked) {
  background: #0a0a0a !important;
  border-color: #0a0a0a !important;
  color: #ffffff !important;
}
.radius-poi-bar .poi-pill:has(input:checked) i { color: #ffffff !important; }

/* ---- Side panel (center / metrics / demographics) -------------------- */
.radius-side-panel {
  background: #ffffff;
  border: 1px solid #e6e6e6;
  border-radius: 8px;
  padding: 1.5rem 1.5rem 1rem;
  box-shadow: 0 1px 0 rgba(10, 10, 10, 0.02);
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.radius-side-head { display: flex; flex-direction: column; gap: 0.4rem; }
.radius-side-head .section-kicker {
  color: #6e6e6e !important;
  font-family: var(--font-mono) !important;
  font-size: 0.65rem !important;
  letter-spacing: 0.16em !important;
}
.radius-center-address {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: -0.015em;
  color: #0a0a0a;
  line-height: 1.35;
}
.radius-center-coords {
  margin: 0;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: #6e6e6e;
  font-variant-numeric: tabular-nums;
}

.radius-metric-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-top: 1px solid #ececec;
  border-bottom: 1px solid #ececec;
}
.radius-metric {
  padding: 1rem 0.5rem;
  text-align: left;
}
.radius-metric + .radius-metric {
  border-left: 1px solid #ececec;
  padding-left: 1rem;
}
.radius-metric-value {
  font-family: var(--font-display);
  font-size: 1.85rem;
  font-weight: 700;
  letter-spacing: -0.028em;
  color: #0a0a0a;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.radius-metric-label {
  margin-top: 0.4rem;
  font-family: var(--font-mono);
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #6e6e6e;
}

.radius-demo {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.radius-demo .section-kicker {
  color: #6e6e6e !important;
  font-family: var(--font-mono) !important;
  font-size: 0.62rem !important;
  letter-spacing: 0.14em !important;
}
.radius-demo-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}
.radius-demo-list li {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.45rem 0;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: #2a2a2a;
  border-bottom: 1px solid #f0f0f0;
}
.radius-demo-list li:last-child { border-bottom: 0; }
.radius-demo-list li strong {
  font-family: var(--font-mono);
  font-weight: 600;
  color: #0a0a0a;
  font-variant-numeric: tabular-nums;
  font-size: 0.875rem;
}

/* ---- Empty / failed-geocode state ------------------------------------ */
.radius-empty-state {
  background: #ffffff;
  border: 1px solid #e6e6e6;
  border-radius: 8px;
  padding: 1.75rem 2rem;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  box-shadow: 0 1px 0 rgba(10, 10, 10, 0.02);
}
.radius-empty-state .section-kicker {
  color: #6e6e6e !important;
  font-family: var(--font-mono) !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.16em !important;
}
.radius-empty-state p {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  color: #4a4a4a;
  line-height: 1.55;
  max-width: 640px;
}
.radius-empty-state code {
  font-family: var(--font-mono);
  font-size: 0.85em;
  background: #f5f5f0;
  border: 1px solid #ececec;
  border-radius: 3px;
  padding: 0.05rem 0.35rem;
  color: #0a0a0a;
}

/* ---- Responsive ----------------------------------------------------- */
@media (max-width: 992px) {
  #radius-map { height: 480px; }
  .radius-side-panel { padding: 1.25rem; gap: 1.25rem; }
  .radius-metric-value { font-size: 1.5rem; }
}
@media (max-width: 576px) {
  #radius-map { height: 360px; }
  .radius-poi-bar { padding: 0.75rem 0.9rem 0.9rem; }
  .radius-poi-head { flex-wrap: wrap; }
  .radius-poi-bar .poi-pill { padding: 0.35rem 0.65rem !important; font-size: 0.75rem !important; }
}
/* End of radius polish */

/* ========================================================================
 * TRANSACTIONS PAGE — Revolut B&W polish.
 *
 * Reuses .search-command-panel for the dark filter hero. Adds polish
 * for the Simple-DataTables shell (search box + per-page selector +
 * pagination + info line) and styles transaction-row cells with
 * tabular numerics for credits/balance.
 * ======================================================================== */

/* Inline label for the include-toggle row on the transactions hero */
.search-options-label {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
  margin-right: 0.5rem;
  align-self: center;
}
.search-options-clear {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
  text-decoration: none;
  margin-left: auto;
  padding: 0.3rem 0.55rem;
  border: 1px solid transparent;
  border-radius: 999px;
  transition: color 120ms var(--ease-out), border-color 120ms var(--ease-out);
}
.search-options-clear:hover {
  color: #ffffff;
  border-color: rgba(255, 255, 255, 0.28);
}

/* Results header — meta on right */
.results-header-meta {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #9a9a9a;
}

/* ---- Date inputs on the dark hero --------------------------------------
 * Native date picker icons render in their default black, invisible on
 * a dark background. Invert them, and set color-scheme:dark so Chrome /
 * Edge / Safari render the popup calendar in dark mode automatically. */
.search-command-panel { color-scheme: dark; }
.search-command-panel input[type="date"],
.search-command-panel input[type="time"],
.search-command-panel input[type="datetime-local"],
.search-command-panel input[type="month"],
.search-command-panel input[type="week"] {
  color-scheme: dark;
  color: #ffffff !important;
}
.search-command-panel input[type="date"]::-webkit-calendar-picker-indicator,
.search-command-panel input[type="time"]::-webkit-calendar-picker-indicator,
.search-command-panel input[type="datetime-local"]::-webkit-calendar-picker-indicator,
.search-command-panel input[type="month"]::-webkit-calendar-picker-indicator,
.search-command-panel input[type="week"]::-webkit-calendar-picker-indicator {
  filter: invert(1);
  opacity: 0.7;
  cursor: pointer;
  padding: 0.2rem;
  transition: opacity 120ms var(--ease-out);
}
.search-command-panel input[type="date"]::-webkit-calendar-picker-indicator:hover,
.search-command-panel input[type="time"]::-webkit-calendar-picker-indicator:hover {
  opacity: 1;
}
.search-command-panel input[type="date"]::-webkit-datetime-edit-text,
.search-command-panel input[type="date"]::-webkit-datetime-edit-month-field,
.search-command-panel input[type="date"]::-webkit-datetime-edit-day-field,
.search-command-panel input[type="date"]::-webkit-datetime-edit-year-field {
  color: rgba(255, 255, 255, 0.85);
}
.search-command-panel input[type="date"]:not(:focus):invalid::-webkit-datetime-edit {
  color: rgba(255, 255, 255, 0.45);
}

/* ---- Transactions table cells — normalized typography ----------------
 * Every cell uses the same font-size, vertical alignment, padding, and
 * a min-height that gives all rows the same minimum height regardless
 * of cell content. Cells differ only in font-family (sans vs mono) and
 * colour weight, not size or weight. */
.transactions-page .results-panel {
  border-radius: 8px !important;
  border: 1px solid #e6e6e6 !important;
  background: #ffffff !important;
  overflow: hidden;
}
.transactions-table-wrap {
  padding: 0;
}
.transactions-page #datatable-transactions { table-layout: auto; }

.transactions-page .table > tbody > tr > td.tx-cell,
.transactions-page table.dataTable-table > tbody > tr > td.tx-cell {
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  color: #2a2a2a !important;
  vertical-align: middle !important;
  padding: 0.85rem 0.9rem !important;
  border-bottom: 1px solid #f0f0f0 !important;
  background: transparent !important;
  height: 56px;
}
.transactions-page tbody tr { transition: background 100ms var(--ease-out); }
.transactions-page tbody tr:hover > td.tx-cell { background: #fafafa !important; }

.tx-cell-date {
  font-family: var(--font-mono) !important;
  font-variant-numeric: tabular-nums;
  color: #2a2a2a !important;
  white-space: nowrap;
  letter-spacing: 0.01em;
}
.tx-cell-query {
  font-family: var(--font-sans) !important;
  color: #0a0a0a !important;
  max-width: 280px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.tx-cell-match {
  font-family: var(--font-sans) !important;
}
.tx-cell-includes { max-width: 360px; }
.tx-chips {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  align-items: center;
}
.tx-chip {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-mono) !important;
  font-size: 0.65rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: #4a4a4a !important;
  background: #f0f0f0 !important;
  border: 1px solid #e6e6e6 !important;
  border-radius: 3px !important;
  padding: 0.18rem 0.5rem !important;
  white-space: nowrap;
  line-height: 1.2;
}
.tx-chip-more {
  color: #0a0a0a !important;
  background: #ffffff !important;
  border-color: #d4d4d4 !important;
}
.tx-dim {
  color: #b0b0b0 !important;
  font-family: var(--font-mono) !important;
  font-size: 0.9rem;
}
.tx-cell-credits,
.tx-cell-balance {
  font-family: var(--font-mono) !important;
  font-variant-numeric: tabular-nums;
  color: #0a0a0a !important;
  font-weight: 500 !important;
}

/* ---- Simple-DataTables shell polish (search box + per-page + pagination)
 * The plugin wraps the table in .dataTable-wrapper with a top control row
 * (.dataTable-top) and a bottom control row (.dataTable-bottom).
 * ---------------------------------------------------------------------- */
.transactions-page .dataTable-wrapper {
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: #0a0a0a;
}

.transactions-page .dataTable-top,
.transactions-page .dataTable-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  padding: 0.6rem 1.25rem;
  background: #fafafa;
  border-bottom: 1px solid #ececec;
}
.transactions-page .dataTable-bottom {
  border-top: 1px solid #ececec;
  border-bottom: 0;
}

/* Per-page selector */
.transactions-page .dataTable-dropdown,
.transactions-page .dataTable-selector {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-family: var(--font-mono) !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #6e6e6e;
}
.transactions-page select.dataTable-selector {
  height: 30px;
  padding: 0 1.75rem 0 0.6rem !important;
  background: #ffffff !important;
  border: 1px solid #d4d4d4 !important;
  border-radius: 5px !important;
  font-family: var(--font-sans) !important;
  font-size: 0.78rem !important;
  font-weight: 500 !important;
  color: #0a0a0a !important;
  letter-spacing: 0;
  text-transform: none;
  appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, #6e6e6e 50%), linear-gradient(135deg, #6e6e6e 50%, transparent 50%) !important;
  background-position: calc(100% - 14px) 50%, calc(100% - 9px) 50% !important;
  background-size: 5px 5px, 5px 5px !important;
  background-repeat: no-repeat !important;
}

/* Search input */
.transactions-page .dataTable-search input.dataTable-input {
  height: 34px;
  width: 240px;
  padding: 0 0.85rem !important;
  background: #ffffff !important;
  border: 1px solid #d4d4d4 !important;
  border-radius: 6px !important;
  font-family: var(--font-sans) !important;
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  color: #0a0a0a !important;
  letter-spacing: -0.005em;
  transition: border-color 120ms var(--ease-out), box-shadow 120ms var(--ease-out);
}
.transactions-page .dataTable-search input.dataTable-input::placeholder { color: #a0a0a0; font-weight: 400; }
.transactions-page .dataTable-search input.dataTable-input:focus {
  outline: none;
  border-color: #0a0a0a !important;
  box-shadow: 0 0 0 3px rgba(10, 10, 10, 0.08) !important;
}

/* Info line */
.transactions-page .dataTable-info {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #6e6e6e;
}

/* Hide simpleDatatables' built-in info + numbered pagination — we render
 * our own .page-nav element below, identical to the search page. */
.transactions-page .dataTable-bottom { display: none !important; }

/* Custom .page-nav already styled in the search-page block above. The
 * transactions-results scope just ensures it sits flush inside the
 * results-panel without a margin gap. */
.transactions-page .results-panel .page-nav {
  margin: 0 !important;
  border-radius: 0 0 8px 8px !important;
  border-left: 0 !important;
  border-right: 0 !important;
  border-bottom: 0 !important;
  border-top: 1px solid #ececec !important;
}

/* Sort header arrows + clickable headers */
.transactions-page .dataTable-table > thead > tr > th[data-sortable] {
  cursor: pointer;
  user-select: none;
}
.transactions-page .dataTable-sorter {
  display: inline-block;
  position: relative;
  padding-right: 14px;
}
.transactions-page .dataTable-sorter::before,
.transactions-page .dataTable-sorter::after {
  content: "";
  position: absolute;
  right: 2px;
  border: 4px solid transparent;
  opacity: 0.45;
}
.transactions-page .dataTable-sorter::before { bottom: 60%; border-bottom-color: #6e6e6e; }
.transactions-page .dataTable-sorter::after  { top: 60%;    border-top-color: #6e6e6e; }
.transactions-page th.asc .dataTable-sorter::before  { opacity: 1; border-bottom-color: #0a0a0a; }
.transactions-page th.desc .dataTable-sorter::after  { opacity: 1; border-top-color: #0a0a0a; }

/* No-rows row */
.transactions-page .dataTables-empty,
.transactions-page tr.dataTable-empty td {
  text-align: center !important;
  padding: 2rem !important;
  font-family: var(--font-sans);
  color: #6e6e6e;
}

/* Responsive: stack the top/bottom rows under 768px */
@media (max-width: 768px) {
  .transactions-page .dataTable-top,
  .transactions-page .dataTable-bottom {
    flex-direction: column;
    align-items: stretch;
  }
  .transactions-page .dataTable-search input.dataTable-input { width: 100%; }
  .tx-cell-query { max-width: 200px; }
  .tx-cell-includes { max-width: 180px; }
}
/* End of transactions polish */

/* ========================================================================
 * ADMIN WORKSPACE — Revolut B&W polish.
 *
 * admin.php is the densest page in the app and reuses .search-command-panel
 * for its dark hero (same as transactions / radius). This block adds:
 *   1. Light section-kicker variant for use on the dark hero
 *   2. Admin tab strip (replaces the old pill nav)
 *   3. KPI tiles — 4-up stat row at the top of /admin/dashboard
 *   4. Admin "card" container (chart, tables, forms)
 *   5. Form controls inside admin cards
 *   6. Buttons / switches / accordions inside admin
 *   7. Table polish + simpleDatatables shell matching other pages
 * ======================================================================== */

.search-command-panel .section-kicker.section-kicker-light,
.section-kicker-light {
  color: rgba(255, 255, 255, 0.55) !important;
}

/* 1. Admin tab strip — clean underlined tabs */
.admin-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  margin-top: 1.25rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}
.admin-tab {
  position: relative;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: -0.005em;
  color: rgba(255, 255, 255, 0.55);
  text-decoration: none !important;
  padding: 0.85rem 1.1rem 0.95rem;
  margin-bottom: -1px;
  border-bottom: 2px solid transparent;
  transition: color 120ms var(--ease-out), border-color 120ms var(--ease-out);
}
.admin-tab:hover { color: #ffffff; }
.admin-tab.is-active {
  color: #ffffff;
  border-bottom-color: #ffffff;
}

/* Suppress the legacy .admin-secondary-nav pill block */
.admin-secondary-nav { display: none !important; }

/* 2. KPI tiles row */
.admin-kpi-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  background: #ffffff;
  border: 1px solid #e6e6e6;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 1px 0 rgba(10, 10, 10, 0.02);
}
.admin-kpi {
  padding: 1.25rem 1.25rem 1.1rem;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  background: #ffffff;
}
.admin-kpi + .admin-kpi { border-left: 1px solid #ececec; }
.admin-kpi-label {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #6e6e6e;
}
.admin-kpi-value {
  font-family: var(--font-display);
  font-size: 1.85rem;
  font-weight: 700;
  letter-spacing: -0.028em;
  color: #0a0a0a;
  line-height: 1.05;
  font-variant-numeric: tabular-nums;
}
.admin-kpi-value-text {
  font-size: 1.15rem;
  letter-spacing: -0.018em;
  line-height: 1.25;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (max-width: 992px) {
  .admin-kpi-row { grid-template-columns: repeat(2, 1fr); }
  .admin-kpi:nth-child(3) { border-left: 0; border-top: 1px solid #ececec; }
  .admin-kpi:nth-child(4) { border-top: 1px solid #ececec; }
}
@media (max-width: 576px) {
  .admin-kpi-row { grid-template-columns: 1fr; }
  .admin-kpi + .admin-kpi { border-left: 0; border-top: 1px solid #ececec; }
}

/* 3. Admin card container */
.admin-card,
.admin-page .card {
  background: #ffffff !important;
  border: 1px solid #e6e6e6 !important;
  border-radius: 8px !important;
  box-shadow: 0 1px 0 rgba(10, 10, 10, 0.02) !important;
  overflow: hidden;
}
.admin-card-head,
.admin-page .card-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 1rem !important;
  padding: 1rem 1.5rem !important;
  background: #fafafa !important;
  border-bottom: 1px solid #ececec !important;
}
.admin-card-title {
  margin: 0 !important;
  font-family: var(--font-display) !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  letter-spacing: -0.015em !important;
  color: #0a0a0a !important;
}
.admin-card-body,
.admin-page .card-body {
  padding: 1.25rem 1.5rem !important;
  background: #ffffff !important;
}
.admin-page .card h4,
.admin-page .card h5,
.admin-page .card h6 {
  font-family: var(--font-display) !important;
  font-weight: 700 !important;
  letter-spacing: -0.015em !important;
  color: #0a0a0a !important;
  font-size: 1rem !important;
  margin: 0 0 0.5rem !important;
}
.admin-page .card .text-sm.text-muted,
.admin-page .card p.text-muted {
  font-family: var(--font-sans);
  font-size: 0.85rem;
  color: #6e6e6e !important;
  margin: 0 0 1rem;
}

/* Legend */
.admin-legend {
  display: inline-flex;
  align-items: center;
  gap: 1rem;
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.06em;
  color: #6e6e6e;
}
.admin-legend-item { display: inline-flex; align-items: center; gap: 0.4rem; }
.admin-legend-dot { width: 8px; height: 8px; border-radius: 50%; background: #0a0a0a; }
.admin-legend-dot--searches { background: #0a0a0a; }
.admin-legend-dot--credits  { background: #9a9a9a; }
.admin-chart-wrap { height: 320px; position: relative; }

/* 4. Form controls inside admin cards (light-bg) */
.admin-page .card .form-control,
.admin-page .card select {
  height: 40px;
  background: #ffffff !important;
  border: 1px solid #d4d4d4 !important;
  color: #0a0a0a !important;
  font-family: var(--font-sans) !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  border-radius: 6px !important;
  padding: 0 0.85rem !important;
  box-shadow: none !important;
  transition: border-color 120ms var(--ease-out), box-shadow 120ms var(--ease-out);
}
.admin-page .card .form-control::placeholder { color: #a0a0a0; font-weight: 400; }
.admin-page .card .form-control:focus,
.admin-page .card select:focus {
  outline: none !important;
  border-color: #0a0a0a !important;
  box-shadow: 0 0 0 3px rgba(10, 10, 10, 0.08) !important;
}
.admin-page .card label {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #6e6e6e !important;
  margin-bottom: 0.3rem;
}
.admin-page input.form-control[readonly],
.admin-page input.form-control[readonly]:focus {
  background: #fafafa !important;
  color: #2a2a2a !important;
  cursor: not-allowed;
}

/* 5. Buttons inside admin */
.admin-page .btn,
.admin-page a.btn {
  font-family: var(--font-sans) !important;
  font-size: 0.85rem !important;
  font-weight: 600 !important;
  letter-spacing: -0.005em !important;
  text-transform: none !important;
  height: 40px;
  padding: 0 0.95rem !important;
  border-radius: 6px !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  box-shadow: none !important;
  transition: background 120ms var(--ease-out), border-color 120ms var(--ease-out), color 120ms var(--ease-out);
}
.admin-page .btn.btn-primary {
  background: #0a0a0a !important;
  border: 1px solid #0a0a0a !important;
  color: #ffffff !important;
}
.admin-page .btn.btn-primary:hover {
  background: #2a2a2a !important;
  border-color: #2a2a2a !important;
}
.admin-page .btn.btn-outline-primary,
.admin-page .btn.btn-outline-dark,
.admin-page a.btn:not(.btn-primary):not(.btn-outline-danger) {
  background: #ffffff !important;
  border: 1px solid #d4d4d4 !important;
  color: #0a0a0a !important;
}
.admin-page .btn.btn-outline-primary:hover,
.admin-page .btn.btn-outline-dark:hover,
.admin-page a.btn:not(.btn-primary):not(.btn-outline-danger):hover {
  background: #0a0a0a !important;
  border-color: #0a0a0a !important;
  color: #ffffff !important;
}
.admin-page .btn.btn-outline-danger {
  background: #ffffff !important;
  border: 1px solid #d4d4d4 !important;
  color: #b91c1c !important;
}
.admin-page .btn.btn-outline-danger:hover {
  background: #b91c1c !important;
  border-color: #b91c1c !important;
  color: #ffffff !important;
}

/* Switches */
.admin-page .form-check-input {
  border: 1px solid #d4d4d4 !important;
  background-color: #ffffff !important;
  box-shadow: none !important;
  cursor: pointer;
}
.admin-page .form-check-input:checked {
  background-color: #0a0a0a !important;
  border-color: #0a0a0a !important;
}
.admin-page .form-check-input:focus {
  border-color: #0a0a0a !important;
  box-shadow: 0 0 0 3px rgba(10, 10, 10, 0.08) !important;
}

/* Accordion */
.admin-page details.accordion > summary {
  list-style: none;
  cursor: pointer;
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 0.85rem;
  color: #0a0a0a;
  padding: 0.4rem 0;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}
.admin-page details.accordion > summary::-webkit-details-marker { display: none; }
.admin-page details.accordion > summary::marker { content: ""; }
.admin-page details.accordion > summary::before {
  content: "+";
  font-family: var(--font-mono);
  font-weight: 500;
  color: #6e6e6e;
  width: 12px;
  text-align: center;
}
.admin-page details.accordion[open] > summary::before {
  content: "−";
  color: #0a0a0a;
}

/* 6. Tables */
.admin-page table.table { margin: 0; background: transparent !important; }
.admin-page .table > thead > tr > th {
  background: #fafafa !important;
  border-bottom: 1px solid #ececec !important;
  border-top: 0 !important;
  font-family: var(--font-mono) !important;
  font-size: 0.65rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: #6e6e6e !important;
  padding: 0.75rem 0.9rem !important;
}
.admin-page .table > tbody > tr > td {
  border-bottom: 1px solid #f0f0f0 !important;
  border-top: 0 !important;
  padding: 0.75rem 0.9rem !important;
  font-family: var(--font-sans) !important;
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  color: #2a2a2a !important;
  vertical-align: middle !important;
}
.admin-page .table > tbody > tr:last-child > td { border-bottom: 0 !important; }
.admin-page .table > tbody > tr:hover > td { background: #fafafa !important; }

/* 7. simpleDatatables shell + numbered pagination matching .page-nav-btn */
.admin-page .dataTable-wrapper { font-family: var(--font-sans); }
.admin-page .dataTable-top {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; flex-wrap: wrap;
  padding: 0.6rem 1.25rem;
  background: #fafafa; border-bottom: 1px solid #ececec;
}
.admin-page .dataTable-bottom {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; flex-wrap: wrap;
  padding: 0.85rem 1.25rem;
  background: #ffffff; border-top: 1px solid #ececec;
}
.admin-page .dataTable-info {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #6e6e6e;
}
.admin-page .dataTable-dropdown {
  display: inline-flex; align-items: center; gap: 0.5rem;
  font-family: var(--font-mono) !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #6e6e6e;
}
.admin-page select.dataTable-selector {
  height: 30px;
  padding: 0 1.75rem 0 0.6rem !important;
  background: #ffffff !important;
  border: 1px solid #d4d4d4 !important;
  border-radius: 5px !important;
  font-family: var(--font-sans) !important;
  font-size: 0.78rem !important;
  font-weight: 500 !important;
  color: #0a0a0a !important;
  letter-spacing: 0;
  text-transform: none;
  appearance: none;
  background-image: linear-gradient(45deg, transparent 50%, #6e6e6e 50%), linear-gradient(135deg, #6e6e6e 50%, transparent 50%) !important;
  background-position: calc(100% - 14px) 50%, calc(100% - 9px) 50% !important;
  background-size: 5px 5px, 5px 5px !important;
  background-repeat: no-repeat !important;
}
.admin-page .dataTable-search input.dataTable-input {
  height: 34px; width: 240px;
  padding: 0 0.85rem !important;
  background: #ffffff !important;
  border: 1px solid #d4d4d4 !important;
  border-radius: 6px !important;
  font-family: var(--font-sans) !important;
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  color: #0a0a0a !important;
}
.admin-page .dataTable-search input.dataTable-input:focus {
  outline: none;
  border-color: #0a0a0a !important;
  box-shadow: 0 0 0 3px rgba(10, 10, 10, 0.08) !important;
}
.admin-page .dataTable-pagination {
  margin: 0; padding: 0; list-style: none;
  display: inline-flex; align-items: center; gap: 0.4rem;
}
.admin-page .dataTable-pagination li { display: inline-flex; }
.admin-page .dataTable-pagination a {
  display: inline-flex !important;
  align-items: center; justify-content: center;
  min-width: 34px; height: 34px;
  padding: 0 0.85rem !important;
  font-family: var(--font-sans) !important;
  font-size: 0.825rem !important;
  font-weight: 600 !important;
  color: #0a0a0a !important;
  background: #ffffff !important;
  border: 1px solid #d4d4d4 !important;
  border-radius: 6px !important;
  text-decoration: none !important;
  white-space: nowrap;
  box-shadow: none !important;
  transition: background 120ms var(--ease-out), border-color 120ms var(--ease-out), color 120ms var(--ease-out);
}
.admin-page .dataTable-pagination a:hover {
  background: #0a0a0a !important;
  border-color: #0a0a0a !important;
  color: #ffffff !important;
}
.admin-page .dataTable-pagination li.active a {
  background: #0a0a0a !important;
  border-color: #0a0a0a !important;
  color: #ffffff !important;
  font-family: var(--font-mono) !important;
}
.admin-page .dataTable-pagination li.disabled a {
  color: #b0b0b0 !important;
  background: #f5f5f5 !important;
  border-color: #ececec !important;
  cursor: not-allowed;
  pointer-events: none;
}

/* Badges inside admin */
.admin-page .badge {
  background: #f0f0f0 !important;
  color: #4a4a4a !important;
  font-family: var(--font-mono);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border: 1px solid #e6e6e6;
  border-radius: 3px;
  padding: 0.2rem 0.5rem;
  box-shadow: none !important;
}

/* PDF link inside invoices table reads as a button */
.admin-page table a[href*="/admin/invoices/pdf"] {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-family: var(--font-sans);
  font-size: 0.78rem;
  font-weight: 600;
  color: #0a0a0a !important;
  text-decoration: none !important;
  padding: 0.3rem 0.6rem !important;
  border: 1px solid #d4d4d4;
  border-radius: 5px;
  background: #ffffff;
  margin-right: 0.4rem;
  height: auto;
  transition: background 120ms var(--ease-out), border-color 120ms var(--ease-out), color 120ms var(--ease-out);
}
.admin-page table a[href*="/admin/invoices/pdf"]:hover {
  background: #0a0a0a;
  border-color: #0a0a0a;
  color: #ffffff !important;
}

/* End of admin polish */

/* ========================================================================
 * ADMIN — section + form + table-cell + pill + edit-row design system.
 *
 * This second admin block adds the new patterns used by the redesigned
 * Users / Transactions / Billing tabs:
 *   1. .admin-section / .admin-section-head — replaces the Soft UI .card
 *   2. .admin-form / .admin-form-grid — multi-column forms with field-labels
 *   3. .admin-pill — role / status badges, replaces inline toggle switches
 *   4. .admin-action-row / .admin-icon-btn — compact row actions
 *   5. .admin-edit-row — inline expand for edit / password forms
 *   6. .admin-switch — modern toggle inside the edit panel
 *   7. .admin-table-wrap + .admin-table-nav — wrap simpleDatatables and
 *      replace its built-in numbered pagination with .page-nav
 *   8. KPI value variants (text / money / unit)
 * ======================================================================== */

/* Hide simpleDatatables's own bottom row inside the admin page — we
 * render our own .page-nav after each table. */
.admin-page .dataTable-bottom { display: none !important; }

/* 1. Admin section container */
.admin-section {
  background: #ffffff;
  border: 1px solid #e6e6e6;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 1px 0 rgba(10, 10, 10, 0.02);
}
.admin-section-head {
  padding: 1.25rem 1.5rem 1rem;
  border-bottom: 1px solid #ececec;
  background: #ffffff;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.admin-section-head .section-kicker {
  color: #6e6e6e !important;
  font-family: var(--font-mono) !important;
  font-size: 0.65rem !important;
  letter-spacing: 0.14em !important;
  display: block;
  margin-bottom: 0.35rem;
}
.admin-section-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: -0.022em;
  color: #0a0a0a;
  line-height: 1.2;
}
.admin-section-sub {
  margin: 0.4rem 0 0;
  font-family: var(--font-sans);
  font-size: 0.875rem;
  color: #5a5a5a;
  line-height: 1.5;
  max-width: 680px;
}
.admin-inline-code {
  font-family: var(--font-mono);
  font-size: 0.85em;
  background: #f3f3f0;
  border: 1px solid #ececec;
  border-radius: 3px;
  padding: 0.05rem 0.4rem;
  color: #0a0a0a;
}

/* 2. Admin form / grid */
.admin-form {
  padding: 1.25rem 1.5rem 1.5rem;
  background: #ffffff;
}
.admin-form-grid {
  display: grid;
  grid-template-columns: 1.4fr 1.2fr 1.2fr auto;
  gap: 1rem;
  align-items: end;
}
.admin-form-grid-billing {
  grid-template-columns: 0.8fr 1fr 1fr 1.1fr auto;
}
@media (max-width: 992px) {
  .admin-form-grid,
  .admin-form-grid-billing { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 576px) {
  .admin-form-grid,
  .admin-form-grid-billing { grid-template-columns: 1fr; }
}
.admin-field {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  min-width: 0;
}
.admin-field-wide { grid-column: span 2; }
.admin-field-narrow { max-width: 200px; }
.admin-field-action { align-self: end; }
.admin-field-label {
  display: block;
  font-family: var(--font-mono) !important;
  font-size: 0.65rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: #6e6e6e !important;
  margin: 0 !important;
}
.admin-page .admin-form .form-control,
.admin-page .admin-edit-form .form-control {
  height: 42px;
  background: #ffffff !important;
  border: 1px solid #d4d4d4 !important;
  color: #0a0a0a !important;
  font-family: var(--font-sans) !important;
  font-size: 0.9rem !important;
  font-weight: 500 !important;
  border-radius: 6px !important;
  padding: 0 0.85rem !important;
  box-shadow: none !important;
  transition: border-color 120ms var(--ease-out), box-shadow 120ms var(--ease-out);
}
.admin-page .admin-form .form-control:focus,
.admin-page .admin-edit-form .form-control:focus {
  outline: none !important;
  border-color: #0a0a0a !important;
  box-shadow: 0 0 0 3px rgba(10, 10, 10, 0.08) !important;
}
.admin-field-readonly,
.admin-field-readonly:focus {
  background: #fafafa !important;
  color: #2a2a2a !important;
  border-color: #ececec !important;
  cursor: not-allowed;
  font-family: var(--font-mono) !important;
  font-variant-numeric: tabular-nums;
}
.admin-field-readonly--total {
  background: #0a0a0a !important;
  color: #ffffff !important;
  border-color: #0a0a0a !important;
  font-weight: 600 !important;
}
.admin-field-highlight .admin-field-label { color: #0a0a0a !important; }
.admin-btn-block {
  width: 100%;
  min-width: 160px;
  white-space: nowrap;
}

/* 3. Admin pills (role / status badges) */
.admin-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border-radius: 3px;
  padding: 0.22rem 0.55rem;
  white-space: nowrap;
  line-height: 1.2;
}
.admin-pill::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.7;
}
.admin-pill--role-admin {
  background: #0a0a0a;
  color: #ffffff;
}
.admin-pill--role-admin::before { background: #ffffff; opacity: 1; }
.admin-pill--role-user {
  background: #f0f0f0;
  color: #4a4a4a;
}
.admin-pill--status-active {
  background: rgba(21, 128, 61, 0.08);
  color: #166534;
}
.admin-pill--status-active::before { background: #15803d; opacity: 1; }
.admin-pill--status-inactive {
  background: #f0f0f0;
  color: #6e6e6e;
}
.admin-pill--status-deleted {
  background: rgba(185, 28, 28, 0.08);
  color: #b91c1c;
}
.admin-pill--status-paid {
  background: rgba(21, 128, 61, 0.08);
  color: #166534;
}
.admin-pill--status-paid::before { background: #15803d; opacity: 1; }
.admin-pill--status-issued {
  background: #0a0a0a;
  color: #ffffff;
}
.admin-pill--status-issued::before { background: #ffffff; opacity: 1; }
.admin-pill--status-other {
  background: #f0f0f0;
  color: #6e6e6e;
}
.admin-pill-lock {
  margin-left: 0.4rem;
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #a0a0a0;
}

/* 4. Compact action buttons */
.admin-actions-th { text-align: right; white-space: nowrap; }
.admin-actions-td { text-align: right; white-space: nowrap; }
.admin-action-row {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.admin-inline-form {
  display: inline-flex;
  margin: 0;
}
.admin-icon-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  height: 28px;
  padding: 0 0.55rem;
  background: #ffffff;
  border: 1px solid #d4d4d4;
  border-radius: 5px;
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: -0.005em;
  color: #0a0a0a;
  text-decoration: none !important;
  cursor: pointer;
  transition: background 120ms var(--ease-out), border-color 120ms var(--ease-out), color 120ms var(--ease-out);
}
.admin-icon-btn:hover {
  background: #0a0a0a;
  border-color: #0a0a0a;
  color: #ffffff !important;
}
.admin-icon-btn svg { flex-shrink: 0; }
.admin-icon-btn--primary {
  background: #0a0a0a;
  border-color: #0a0a0a;
  color: #ffffff;
}
.admin-icon-btn--primary:hover {
  background: #2a2a2a;
  border-color: #2a2a2a;
  color: #ffffff !important;
}
.admin-icon-btn--danger { color: #b91c1c; }
.admin-icon-btn--danger:hover {
  background: #b91c1c !important;
  border-color: #b91c1c !important;
  color: #ffffff !important;
}

/* 5. Inline edit / password row */
.admin-edit-row > td {
  padding: 0 !important;
  background: #fafafa !important;
  border-bottom: 1px solid #ececec !important;
}
.admin-edit-form {
  padding: 1.25rem 1.5rem;
  background: #fafafa;
  border-left: 3px solid #0a0a0a;
}
.admin-edit-grid {
  display: grid;
  grid-template-columns: 1.4fr 1.4fr 0.5fr 1fr;
  gap: 1rem;
  align-items: end;
}
@media (max-width: 992px) {
  .admin-edit-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 576px) {
  .admin-edit-grid { grid-template-columns: 1fr; }
}
.admin-edit-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid #ececec;
}
.admin-page .admin-edit-actions .btn {
  width: auto !important;
  min-width: 110px;
}
.admin-field-toggle .admin-field-label { margin-bottom: 0.5rem; }

/* 6. Modern toggle switch */
.admin-switch {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  cursor: pointer;
  user-select: none;
}
.admin-switch input { position: absolute; opacity: 0; pointer-events: none; }
.admin-switch-track {
  width: 36px;
  height: 20px;
  background: #d4d4d4;
  border-radius: 999px;
  position: relative;
  transition: background 160ms var(--ease-out);
}
.admin-switch-track::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 16px;
  height: 16px;
  background: #ffffff;
  border-radius: 50%;
  box-shadow: 0 1px 2px rgba(10, 10, 10, 0.18);
  transition: transform 160ms var(--ease-out);
}
.admin-switch input:checked + .admin-switch-track { background: #0a0a0a; }
.admin-switch input:checked + .admin-switch-track::after { transform: translateX(16px); }
.admin-switch input:focus-visible + .admin-switch-track {
  box-shadow: 0 0 0 3px rgba(10, 10, 10, 0.16);
}
.admin-switch-label {
  font-family: var(--font-sans);
  font-size: 0.85rem;
  font-weight: 500;
  color: #2a2a2a;
}

/* 7. Table wrap + pagination */
.admin-table-wrap {
  background: #ffffff;
}
.admin-table-wrap > .table { margin: 0; }
.admin-table-wrap .page-nav.admin-table-nav {
  margin: 0;
  border-radius: 0 0 8px 8px;
  border-left: 0;
  border-right: 0;
  border-bottom: 0;
  border-top: 1px solid #ececec;
}
.admin-page .admin-table-wrap .dataTable-top {
  background: #fafafa;
  border-bottom: 1px solid #ececec;
}

/* Override admin-section bottom edge so the page-nav inside it sits flush */
.admin-section .admin-table-wrap:last-child { border-radius: 0 0 8px 8px; overflow: hidden; }

/* 8. KPI value variants */
.admin-kpi-value-money {
  font-family: var(--font-mono);
  font-size: 1.45rem;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.admin-kpi-unit {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 0.65em;
  color: #6e6e6e;
  margin-left: 0.25rem;
  vertical-align: top;
  letter-spacing: 0;
}

/* ---- Per-table cell tweaks ---- */
.admin-cell-id {
  font-family: var(--font-mono) !important;
  color: #6e6e6e !important;
  font-variant-numeric: tabular-nums;
}
.admin-cell-email {
  font-family: var(--font-sans) !important;
  color: #0a0a0a !important;
  font-weight: 500;
}
.admin-cell-name { color: #2a2a2a !important; }
.admin-cell-ip {
  font-family: var(--font-mono) !important;
  font-variant-numeric: tabular-nums;
  color: #4a4a4a !important;
  font-size: 0.78rem !important;
}
.admin-cell-date {
  font-family: var(--font-mono) !important;
  font-variant-numeric: tabular-nums;
  color: #4a4a4a !important;
  font-size: 0.78rem !important;
  white-space: nowrap;
}
.admin-cell-credits {
  font-family: var(--font-mono) !important;
  font-variant-numeric: tabular-nums;
  color: #0a0a0a !important;
  font-weight: 500 !important;
}
.admin-cell-amount {
  font-family: var(--font-mono) !important;
  font-variant-numeric: tabular-nums;
  color: #0a0a0a !important;
  font-weight: 600 !important;
}
.admin-cell-invoice-no {
  font-family: var(--font-mono) !important;
  color: #0a0a0a !important;
  font-weight: 600;
  font-size: 0.8rem !important;
  letter-spacing: 0.01em;
}
.admin-cell-ua {
  max-width: 360px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-family: var(--font-mono) !important;
  font-size: 0.75rem !important;
  color: #6e6e6e !important;
}
.admin-cell-user-id {
  font-family: var(--font-mono) !important;
  font-variant-numeric: tabular-nums;
  color: #6e6e6e !important;
}
.admin-dim {
  color: #b0b0b0 !important;
  font-family: var(--font-mono) !important;
}

/* Numeric header alignment */
.admin-page .table > thead > tr > th.numeric,
.admin-page .table > tbody > tr > td.numeric { text-align: right; }

/* Make sure the inline edit row isn't picked up by hover state */
.admin-page .table > tbody > tr.admin-edit-row:hover > td { background: #fafafa !important; }

/* On smaller screens, the actions column wraps fine; on really tight
 * screens it's still useful to collapse spacing */
@media (max-width: 768px) {
  .admin-form { padding: 1rem; }
  .admin-edit-form { padding: 1rem; }
  .admin-section-head { padding: 1rem; }
  .admin-icon-btn { padding: 0 0.45rem; }
  .admin-icon-btn span { display: none; }
  .admin-icon-btn svg { width: 16px; height: 16px; }
}

/* End of admin design system */








