/* =============================================================================
   EstateSail — Design System v3
   Matching Figma: CIEHLxwABzTfGQxAQJPXGp
   Colors: #155DFC brand blue, #0092B8 brand teal
   ============================================================================= */

/* Quill description editor + public listing HTML (Google Fonts for editor faces; body UI Inter is self-hosted via /assets/css/fonts-inter.css in layout). */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,wght@0,400;0,700;1,400;1,700&family=Lato:ital,wght@0,400;0,700;1,400;1,700&family=Libre+Baskerville:ital,wght@0,400;0,700;1,400&family=Merriweather:ital,wght@0,400;0,700;1,400;1,700&family=Open+Sans:ital,wght@0,400;0,700;1,400;1,700&family=Playfair+Display:ital,wght@0,400;0,700;1,400;1,700&family=Roboto+Slab:wght@400;700&family=Source+Sans+3:ital,wght@0,400;0,700;1,400;1,700&display=swap');

/* ---- Design Tokens --------------------------------------------------------- */
:root {
  /* Brand */
  --brand:           #155DFC;
  --brand-teal:      #0092B8;
  --brand-hover:     #0F52E0;
  --brand-dark:      #0A3DBF;
  --brand-light:     #EFF6FF;
  --brand-gradient:  linear-gradient(90deg, #155DFC, #9810FA);

  /* Neutral palette */
  --n-900: #0F172B;
  --n-800: #1E293B;
  --n-700: #314158;
  --n-600: #45556C;
  --n-500: #62748E;
  --n-400: #90A1B9;
  --n-300: #CBD5E1;
  --n-200: #E2E8F0;
  --n-100: #F1F5F9;
  --n-50:  #F8FAFC;
  --white: #ffffff;

  /* Semantic */
  --primary:      var(--n-900);
  --text:         var(--n-700);
  --text-muted:   var(--n-500);
  --border:       var(--n-200);
  --bg:           var(--n-50);
  --surface:      var(--white);
  --accent:       var(--brand);
  --accent-hover: var(--brand-hover);
  --accent-light: var(--brand-light);

  /* Status */
  --green:        #059669;
  --green-bg:     #ECFDF5;
  --green-border: #A7F3D0;
  --amber:        #F59E0B;
  --amber-bg:     #FFFBEB;
  --red:          #DC2626;
  --red-bg:       #FEF2F2;
  --red-border:   #FCA5A5;

  /* Shadows (flat UI: elevation removed; focus rings use explicit 0 0 0 values in rules) */
  --shadow-xs: none;
  --shadow-sm: none;
  --shadow-md: none;
  --shadow-lg: none;

  /* Radius — single scale: 0.625rem everywhere (use border-radius: 50% for true circles) */
  --r-xs:   0.625rem;
  --r-sm:   0.625rem;
  --r:      0.625rem;
  --r-md:   0.625rem;
  --r-lg:   0.625rem;
  --r-xl:   0.625rem;
  --r-full: 0.625rem;
  --radius-sm: 0.625rem;
  --radius-md: 0.625rem;

  /* Spacing (4px base grid) */
  --sp-1:  0.25rem;
  --sp-2:  0.5rem;
  --sp-3:  0.75rem;
  --sp-4:  1rem;
  --sp-5:  1.25rem;
  --sp-6:  1.5rem;
  --sp-7:  1.75rem;
  --sp-8:  2rem;
  --sp-10: 2.5rem;
  --sp-12: 3rem;
  --sp-16: 4rem;
  --sp-20: 5rem;
  --sp-24: 6rem;

  /* Typography */
  --font: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --text-xs:   0.75rem;
  --text-sm:   0.875rem;
  --text-base: 1rem;
  --text-lg:   1.125rem;
  --text-xl:   1.25rem;
  --text-2xl:  1.5rem;
  --text-3xl:  1.875rem;
  --text-4xl:  2.25rem;

  /* Transitions */
  --ease:   cubic-bezier(0.4, 0, 0.2, 1);
  --dur-sm: 150ms;
  --dur:    200ms;

  /* Layout */
  --container: 79.25rem; /* ~1268px matching Figma canvas */

  /* POS shell / header row width — dashboard form-panels match this column */
  --pos-shell-max-width: 1400px;

  /* Dashboard: primary form-panel max width (same as .pos-shell → .pos-hdr) */
  --dashboard-form-panel-max: var(--pos-shell-max-width);
  --dashboard-settings-lede-max: calc(42rem * 1.2);
  --dashboard-settings-form-max: calc(40rem * 1.2);
}

/* ---- Reset ----------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; }

html {
  min-height: 100%;
  scroll-behavior: smooth;
  /* Prevent rubber-band horizontal scroll on mobile (overflow can extend past body otherwise) */
  overflow-x: hidden;
  max-width: 100%;
}
@supports (overflow: clip) {
  html {
    overflow-x: clip;
  }
}

body {
  /* Sticky footer: short pages still show .site-footer at the bottom of the viewport (not fixed; no overlay) */
  min-height: 100%;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  font-family: var(--font);
  font-size: var(--text-base);
  line-height: 1.6;
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  max-width: 100%;
  position: relative;
}
@supports (overflow: clip) {
  body {
    overflow-x: clip;
  }
}

h1, h2, h3, h4, h5, h6 {
  color: var(--primary);
  line-height: 1.25;
  letter-spacing: -0.02em;
  font-weight: 700;
}
img, svg, video { display: block; max-width: 100%; }
img, video { height: auto; }
a { color: var(--accent); }
/* Long URLs, hashes, and paths in main content — avoid horizontal page scroll */
p, li, dt, dd, th, td, label, .text, .meta, figcaption, address, blockquote, caption {
  overflow-wrap: anywhere;
  word-wrap: break-word;
}
input, select, textarea, button { font-family: inherit; font-size: inherit; }
p { margin: 0; }
ul, ol { padding: 0; margin: 0; list-style: none; }

/* ---- Layout ---------------------------------------------------------------- */
/* Main grows; footer follows and stays at viewport bottom on short pages (not position: fixed) */
body > .site-header,
body > .admin-subnav,
body > footer.site-footer {
  flex-shrink: 0;
}
body > main.main,
body > main.main.shell {
  flex: 1 0 auto;
  min-width: 0;
  width: 100%;
}

.shell {
  max-width: var(--container);
  margin-inline: auto;
  /* Fluid side gutters: comfortable on 320px, same max as Figma on large screens */
  padding-inline: clamp(0.75rem, 4.2vw, 2rem);
  min-width: 0; /* allow flex/grid descendants to shrink within viewport */
}

/* POS (/dashboard/pos*): use full main width, not the dashboard form-panel column */
body.is-pos-shell .main.shell {
  max-width: none;
  width: 100%;
  margin-inline: 0;
  padding-inline: 0;
  padding-block: var(--sp-2) var(--sp-6);
}
body.is-pos-shell .main.shell > .flash {
  margin-inline: clamp(var(--sp-3), 2vw, var(--sp-6));
}

/* Full-bleed helper — breaks out of .main.shell */
.lp-bleed {
  position: relative;
  left: 50%;
  margin-left: -50vw;
  width: 100vw;
}
/* Re-constrains content inside a bleed section */
.lp-wrap {
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: clamp(0.75rem, 4.2vw, 2rem);
}

/* ---- Site Header ---------------------------------------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  /* Background + blur live on ::before so children can use viewport-fixed positioning
     (backdrop-filter on this element creates a containing block for position:fixed). */
  background: transparent;
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow-xs);
}
.site-header::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  pointer-events: none;
}
.site-header > * {
  position: relative;
  z-index: 1;
}
.header-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  min-width: 0;
  min-height: clamp(3.25rem, 9vw, 3.75rem);
  height: auto;
  row-gap: var(--sp-2);
  column-gap: clamp(var(--sp-3), 3.5vw, var(--sp-8));
}

/* Logo + optional sticky home search (reveals on scroll) */
.header-brand-row {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  min-width: 0;
  /* Grow so pinned search can use full width between logo and nav */
  flex: 1 1 0;
}
.header-hero-search {
  display: flex;
  align-items: center;
  gap: 0;
  flex: 1;
  min-width: 0;
  max-width: 0;
  opacity: 0;
  overflow: hidden;
  transform: translateX(-8px);
  pointer-events: none;
  transition:
    max-width 0.45s cubic-bezier(0.4, 0, 0.2, 1),
    opacity 0.35s ease,
    transform 0.45s cubic-bezier(0.4, 0, 0.2, 1);
}
.header-hero-search.is-pinned {
  max-width: 100%;
  opacity: 1;
  transform: translateX(0);
  pointer-events: auto;
}
/* Same fused field + primary button as homepage .lp-search-box (shorter for the header row) */
.header-hero-search .lp-search-box {
  flex: 1 1 auto;
  display: flex;
  align-items: stretch;
  min-width: 0;
  width: 100%;
  max-width: 100%;
}
.header-hero-search .lp-search-input {
  height: 2.25rem;
  min-height: 2.25rem;
  padding: 0 var(--sp-3);
  font-size: var(--text-sm);
  font-weight: 400;
  border: 1.5px solid var(--border);
  border-right: none;
  border-radius: 0;
  border-top-left-radius: var(--r-sm);
  border-bottom-left-radius: var(--r-sm);
  background: var(--white);
}
.header-hero-search .lp-search-input:focus {
  outline: none;
  border-color: var(--border);
  box-shadow: inset 0 0 0 2px var(--brand-light);
}
.header-hero-search .lp-search-btn {
  height: 2.25rem;
  min-height: 2.25rem;
  padding: 0 var(--sp-3);
  font-size: var(--text-sm);
  font-weight: 600;
}
.header-hero-search .lp-search-btn svg {
  display: inline-block;
  flex-shrink: 0;
  vertical-align: middle;
}

.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Logo — gradient text, no icon */
.logo {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-family: Inter, sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 28px;
  letter-spacing: 0;
  text-decoration: none;
  flex-shrink: 0;
  background: var(--brand-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  transition: opacity var(--dur-sm) var(--ease);
}
.logo svg { -webkit-text-fill-color: initial; color: var(--brand); }
.logo:hover { opacity: 0.85; }
/* Override span (needed for gradient to work on full text) */
.logo span { background: inherit; -webkit-background-clip: inherit; -webkit-text-fill-color: transparent; background-clip: inherit; }
/* Mark image sits to the left of the wordmark; keep it out of text/gradient clipping */
.logo .logo-es-mark {
  display: block;
  width: 42px;
  height: 42px;
  object-fit: contain;
  flex-shrink: 0;
  -webkit-text-fill-color: initial;
  background: none;
  -webkit-background-clip: initial;
  background-clip: border-box;
}

/* Nav */
.nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  row-gap: var(--sp-1);
  column-gap: var(--sp-1);
  min-width: 0;
  margin-left: auto;
}
.nav a {
  display: inline-flex;
  align-items: center;
  height: 2.25rem;
  padding-inline: var(--sp-3);
  border-radius: var(--r-sm);
  color: #314158;
  font-size: var(--text-sm);
  font-weight: 500;
  text-decoration: none;
  white-space: nowrap;
  letter-spacing: -0.01em;
  transition: background var(--dur-sm) var(--ease), color var(--dur-sm) var(--ease);
}
.nav a:hover { background: var(--n-100); color: var(--primary); }
.nav a::after { display: none; }

/* CTA button in nav */
.nav-cta {
  gap: var(--sp-2) !important;
  background: var(--brand) !important;
  color: #fff !important;
  font-weight: 600 !important;
  padding-inline: var(--sp-4) !important;
  border-radius: var(--r-sm) !important;
  height: 2.25rem !important;
}
.nav-cta svg {
  display: inline-block;
  flex-shrink: 0;
  vertical-align: middle;
}
.nav-cta:hover {
  background: var(--brand-hover) !important;
  color: #fff !important;
}

/* Logout / link button */
.inline  { display: inline; }
.link-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  height: 2.25rem;
  padding-inline: var(--sp-3);
  border: none;
  border-radius: var(--r-sm);
  background: none;
  color: #314158;
  font-size: var(--text-sm);
  font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--dur-sm) var(--ease);
}
.link-btn:hover { background: var(--n-100); color: var(--primary); }
.link-btn svg {
  display: inline-block;
  flex-shrink: 0;
  vertical-align: middle;
}

/* Header: account avatar + menu (replaces bare Log out in main nav) */
.site-header-account-menu {
  position: relative;
  margin-left: var(--sp-1);
}
.site-header-account-menu__trigger {
  list-style: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  margin: 0;
  border: none;
  border-radius: var(--r);
  background: transparent;
  vertical-align: middle;
}
.site-header-account-menu__trigger::-webkit-details-marker {
  display: none;
}
.site-header-account-menu__trigger:focus {
  outline: none;
}
.site-header-account-menu__trigger:focus-visible {
  box-shadow: 0 0 0 3px var(--brand-light);
}
.site-header-account-menu__avatar-img {
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  border: 1px solid var(--border);
  background: var(--white);
}
.site-header-account-menu__avatar-fallback {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 50%;
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--primary);
  background: var(--n-100);
  border: 1px solid var(--border);
}
.site-header-account-menu__panel {
  position: absolute;
  z-index: 120;
  top: 100%;
  right: 0;
  min-width: 11.5rem;
  margin-top: var(--sp-1);
  padding: var(--sp-2);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  gap: 0;
}
.site-header-account-menu__item {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  width: 100%;
  box-sizing: border-box;
  padding: var(--sp-2) var(--sp-3);
  border: none;
  border-radius: var(--r-xs);
  font: inherit;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--n-600);
  text-decoration: none;
  text-align: left;
  background: transparent;
  cursor: pointer;
  transition: background var(--dur-sm) var(--ease), color var(--dur-sm) var(--ease);
}
.site-header-account-menu__item svg {
  flex-shrink: 0;
}
a.site-header-account-menu__item:hover,
button.site-header-account-menu__item:hover {
  background: var(--n-100);
  color: var(--primary);
}
.site-header-account-menu__rule {
  border: none;
  border-top: 1px solid var(--border);
  margin: var(--sp-1) 0;
}
.site-header-account-menu__logout {
  margin: 0;
  display: block;
  width: 100%;
}
.site-header-account-menu__identity {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
}
.site-header-account-menu--shopper .site-header-account-menu__profile-label {
  display: none;
  font: inherit;
  color: inherit;
}
.site-header-account-menu--shopper .site-header-account-menu__profile-person-glyph {
  display: none;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: currentColor;
}
.site-header-account-menu--shopper .site-header-account-menu__profile-person-glyph svg {
  display: block;
}

/* ---- Sub-nav (state browse bar) ------------------------------------------ */
.sub-nav {
  background: var(--white);
  border-bottom: 1px solid var(--border);
  overflow-x: auto;
  scrollbar-width: none;
}
.sub-nav::-webkit-scrollbar { display: none; }
.sub-nav-inner {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  padding-block: var(--sp-2);
  white-space: nowrap;
  font-size: var(--text-sm);
}
.sub-nav-inner strong {
  color: var(--text-muted);
  font-weight: 600;
  padding-right: var(--sp-3);
  margin-right: var(--sp-2);
  border-right: 1px solid var(--border);
  flex-shrink: 0;
}
.sub-nav a {
  display: inline-flex;
  align-items: center;
  height: 1.75rem;
  padding-inline: var(--sp-2);
  border-radius: var(--r-xs);
  color: var(--n-600);
  text-decoration: none;
  font-weight: 500;
  transition: background var(--dur-sm) var(--ease), color var(--dur-sm) var(--ease);
}
.sub-nav a:hover   { background: var(--brand-light); color: var(--brand); }
.sub-nav a:last-child { color: var(--brand); font-weight: 600; margin-left: var(--sp-2); }

/* ---- Flash messages ------------------------------------------------------- */
.flash {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--r);
  border: 1px solid transparent;
  font-size: var(--text-sm);
  font-weight: 500;
  margin-bottom: var(--sp-6);
  transition:
    opacity var(--dur-md, 0.25s) var(--ease, ease),
    max-height 0.35s var(--ease, ease),
    margin 0.35s var(--ease, ease),
    padding 0.35s var(--ease, ease),
    border-width 0.35s var(--ease, ease);
}
.flash--dismissing {
  opacity: 0;
  max-height: 0;
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
  overflow: hidden;
  border-width: 0;
  pointer-events: none;
}
.flash-error   { background: var(--red-bg);   color: var(--red);   border-color: var(--red-border);   }
.flash-success { background: var(--green-bg); color: var(--green); border-color: var(--green-border); }
.flash-info    { background: var(--brand-light); color: var(--brand); border-color: #BAE6FD; }

/* ---- Main content --------------------------------------------------------- */
.main { padding-block: var(--sp-8) var(--sp-20); min-height: 60vh; }
/* Public marketing + listing pages: contain stray horizontal overflow on narrow viewports */
body.is-public-site-shell .main.shell {
  min-width: 0;
  max-width: 100%;
  overflow-x: clip;
}

/* Scale marketing pages (/features, /pricing, /book-demo, /resources/how-it-works):
   hero is full viewport width and sits flush under the sticky header (no main top padding). */
body.is-public-site-shell main.main.shell.main--scale-marketing-hero-flush {
  max-width: none;
  width: 100%;
  margin-inline: 0;
  padding-inline: 0;
  padding-block: 0 var(--sp-20);
}
body.is-public-site-shell main.main.shell.main--scale-marketing-hero-flush > .flash,
body.is-public-site-shell main.main.shell.main--scale-marketing-hero-flush > .pro-platform-inactive-banner {
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: clamp(0.75rem, 4.2vw, 2rem);
}

/* /login: fill main between header and footer so the split hero (left column) has no gap above footer */
body.is-public-site-shell main.main.shell.main--scale-marketing-hero-flush:has(.lp-shell) {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 0;
  padding-block: 0;
}
body.is-public-site-shell main.main.shell.main--scale-marketing-hero-flush:has(.lp-shell) > .lp-shell {
  flex: 1 1 auto;
  min-height: 0;
  width: 100%;
}

/* Random faint hero photo (same assets as B2B homepage) on Scale marketing heroes */
.ft-hero.scale-hero--photo,
.pr-hero.scale-hero--photo,
.bd-hero.scale-hero--photo,
.hiw-hero.scale-hero--photo {
  background-color: var(--ft-dark, #060a14);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.pr-hero.scale-hero--photo {
  background-color: var(--pr-dark, #060a14);
}
.bd-hero.scale-hero--photo {
  background-color: var(--bd-dark, #060a14);
}
.hiw-hero.scale-hero--photo {
  background-color: var(--hiw-dark, #060a14);
}
.ft-hero.scale-hero--photo::before,
.pr-hero.scale-hero--photo::before,
.bd-hero.scale-hero--photo::before,
.hiw-hero.scale-hero--photo::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: linear-gradient(
    180deg,
    rgba(15, 23, 43, 0.92) 0%,
    rgba(15, 23, 43, 0.75) 45%,
    rgba(15, 23, 43, 0.96) 100%
  );
}
.ft-hero.scale-hero--photo::after,
.pr-hero.scale-hero--photo::after,
.bd-hero.scale-hero--photo::after,
.hiw-hero.scale-hero--photo::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: radial-gradient(ellipse 80% 55% at 50% 55%, rgba(21, 93, 252, 0.15) 0%, transparent 70%);
}
.ft-hero.scale-hero--photo .ft-hero__aurora,
.pr-hero.scale-hero--photo .pr-hero__aurora,
.bd-hero.scale-hero--photo .bd-hero__aurora,
.hiw-hero.scale-hero--photo .hiw-hero__aurora {
  z-index: 1;
}

@supports not (overflow: clip) {
  body.is-public-site-shell .main.shell {
    overflow-x: hidden;
  }
}

/* ---- Utility -------------------------------------------------------------- */
.meta        { font-size: var(--text-sm); color: var(--text-muted); }
.back-link   { display: inline-flex; align-items: center; gap: var(--sp-2); font-size: var(--text-sm); font-weight: 600; color: var(--brand); text-decoration: none; margin-bottom: var(--sp-6); }
.back-link:hover { text-decoration: underline; }

/* ---- Buttons -------------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  height: 2.5rem;
  padding-inline: var(--sp-5);
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--white);
  color: var(--primary);
  font-size: var(--text-sm);
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--dur-sm) var(--ease), border-color var(--dur-sm) var(--ease), box-shadow var(--dur-sm) var(--ease);
}
.btn:hover { background: var(--n-50); border-color: var(--n-300); }

.btn-primary {
  background: var(--brand);
  border-color: var(--brand);
  color: #fff;
}
.btn-primary:hover {
  background: var(--brand-hover);
  border-color: var(--brand-hover);
  color: #fff;
  box-shadow: none;
}
.btn-danger {
  background: var(--red);
  border-color: var(--red);
  color: #fff;
}
.btn-danger:hover {
  background: var(--red);
  border-color: var(--red);
  color: #fff;
  filter: brightness(0.93);
}
.btn-lg  { height: 2.75rem; padding-inline: var(--sp-6); font-size: var(--text-base); }
.btn-sm  { height: 2rem;    padding-inline: var(--sp-3); font-size: var(--text-xs); border-radius: var(--r-xs); }
/* Global `svg { display: block }` breaks icons next to label inside inline-flex buttons */
.btn svg {
  display: inline-block;
  flex-shrink: 0;
  vertical-align: middle;
}

/* ---- Section layout ------------------------------------------------------- */
.section { padding-block: var(--sp-16); }
.section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
}
.section-head h1 { font-size: clamp(var(--text-2xl), 4vw, var(--text-3xl)); margin: 0; }
.section-head h2 { font-size: var(--text-2xl); margin: 0; }
.section-head p  { color: var(--text-muted); font-size: var(--text-sm); margin: 0; }
.section-link { font-size: var(--text-sm); font-weight: 600; color: var(--brand); text-decoration: none; white-space: nowrap; flex-shrink: 0; }
.section-link:hover { text-decoration: underline; }

/* ---- Public error pages (/error/404, router 404, uncaught 500) ------------ */
.error-page__shell {
  max-width: 72rem;
}
.error-page__hero {
  margin-bottom: var(--sp-10);
}
.error-page__code {
  margin: 0 0 var(--sp-2);
  font-size: clamp(3rem, 10vw, 5rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--n-300);
}
.error-page__title {
  margin: 0 0 var(--sp-3);
  font-size: clamp(var(--text-2xl), 4vw, var(--text-3xl));
  font-weight: 700;
  color: var(--n-900);
}
.error-page__message {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-lg);
  color: var(--n-800);
}
.error-page__lead {
  margin: 0 0 var(--sp-6);
  max-width: 40rem;
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.55;
}
.error-page__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  align-items: center;
}
.error-page__listings-head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-bottom: var(--sp-4);
}
.error-page__listings-title {
  margin: 0;
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--n-900);
}
.error-page__listings-status {
  margin: 0;
  flex: 1;
  text-align: right;
  min-width: 12rem;
}
@media (max-width: 640px) {
  .error-page__listings-status {
    flex-basis: 100%;
    text-align: left;
  }
}
.error-page__grid {
  margin-top: var(--sp-2);
}
.error-page__debug {
  margin-top: var(--sp-10);
  padding: var(--sp-4);
  overflow: auto;
  font-size: var(--text-xs);
  line-height: 1.45;
  white-space: pre-wrap;
  word-break: break-word;
  border-radius: var(--r-md);
  border: 1px solid var(--n-200);
  background: var(--n-50);
  color: var(--n-800);
}

/* ---- Homepage maintenance (admin flag) ------------------------------------ */
body.is-maintenance-shell .logo.logo--text-only {
  pointer-events: none;
  text-decoration: none;
  cursor: default;
}
body.is-maintenance-shell .logo.logo--text-only:hover {
  opacity: 1;
}
.site-header--maintenance .header-inner {
  min-height: 3.5rem;
  display: flex;
  align-items: center;
}
.site-footer--maintenance {
  border-top: 1px solid var(--n-200);
  margin-top: auto;
}
.site-footer--maintenance__inner {
  padding: var(--sp-6) 0;
  text-align: center;
}
.site-footer--maintenance__line {
  margin: 0;
  color: var(--text-muted);
  font-size: var(--text-sm);
}
body.is-maintenance-shell {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
body.is-maintenance-shell .main {
  flex: 1;
  display: flex;
  flex-direction: column;
}
body.is-maintenance-shell .main.shell {
  max-width: 100%;
}
body.is-maintenance-shell .maintenance-home .error-page__title {
  font-size: clamp(var(--text-2xl), 4.5vw, 2.5rem);
}

/* ---- Legal / policy pages ------------------------------------------------ */
.terms-doc {
  max-width: 48rem;
  line-height: 1.65;
  color: var(--text-muted);
  font-size: var(--text-sm);
}
.terms-doc > h2 {
  margin: var(--sp-8) 0 var(--sp-3);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--n-900);
}
.terms-doc > h2:first-of-type { margin-top: var(--sp-4); }
.terms-doc p { margin: 0 0 var(--sp-3); }
.terms-doc ul,
.terms-doc ol {
  margin: 0 0 var(--sp-4);
  padding-left: 1.35rem;
}
.terms-doc li { margin-bottom: var(--sp-2); }
.terms-doc .terms-doc__note {
  font-size: var(--text-xs);
  font-style: italic;
  margin-bottom: var(--sp-6);
}
.sla-credit-table {
  width: 100%;
  max-width: 40rem;
  border-collapse: collapse;
  font-size: var(--text-sm);
  margin: var(--sp-4) 0 var(--sp-6);
}
.sla-credit-table th,
.sla-credit-table td {
  border: 1px solid var(--n-200);
  padding: var(--sp-2) var(--sp-3);
  text-align: left;
}
.sla-credit-table th {
  background: var(--n-50);
  font-weight: 600;
  color: var(--n-900);
}

/* ---- CMS marketing pages (/about, /shoppers, /businesses, /pricing, …) ------------ */
.cms-page-section {
  padding-block: var(--sp-12) var(--sp-16);
}
.cms-page-header {
  margin-bottom: var(--sp-8);
  max-width: 48rem;
}
.cms-page-header h1 {
  font-size: clamp(var(--text-2xl), 4vw, var(--text-3xl));
  margin: 0;
  color: var(--n-900);
  letter-spacing: -0.02em;
}
.cms-page.cms-page,
article.cms-page.terms-doc {
  max-width: 48rem;
}
.cms-page.cms-page--wide,
article.cms-page.cms-page--wide.terms-doc {
  max-width: min(72rem, 100%);
}
.cms-page .cms-lead {
  font-size: var(--text-lg);
  line-height: 1.6;
  color: var(--text-muted);
  margin-bottom: var(--sp-8);
}
.cms-page .cms-lead p {
  margin: 0 0 var(--sp-4);
}
.cms-page .cms-h2 {
  margin: var(--sp-10) 0 var(--sp-3);
  font-size: var(--text-lg);
  font-weight: 600;
  color: var(--n-900);
}
.cms-page .cms-h2:first-of-type {
  margin-top: 0;
}
.cms-page .cms-h3 {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--n-900);
}
.cms-page p {
  margin: 0 0 var(--sp-4);
  line-height: 1.65;
}
.cms-page .cms-list {
  margin: 0 0 var(--sp-6);
  padding-left: 1.35rem;
  color: var(--text-muted);
}
.cms-page .cms-list li {
  margin-bottom: var(--sp-2);
}
.cms-page .cms-callout {
  background: var(--n-50);
  border: 1px solid var(--n-200);
  border-radius: var(--r-lg);
  padding: var(--sp-4) var(--sp-5);
  margin: var(--sp-4) 0 var(--sp-8);
}
.cms-page .cms-callout p {
  margin: 0 0 var(--sp-2);
}
.cms-page .cms-callout p:last-child {
  margin-bottom: 0;
}
.cms-contact-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--sp-4);
  margin: var(--sp-6) 0 var(--sp-10);
  align-items: stretch;
}
.cms-page .cms-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  box-shadow: none;
}
.cms-contact-grid .cms-card {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}
.cms-page .cms-card p {
  margin-bottom: var(--sp-3);
}
.cms-contact-grid .cms-card > p:last-child {
  margin-top: auto;
  margin-bottom: 0;
  padding-top: var(--sp-4);
  display: flex;
}
.cms-page .cms-card .btn {
  margin-top: var(--sp-2);
}
.cms-contact-grid .cms-card > p:last-child .btn {
  flex: 1 1 auto;
  width: 100%;
  margin-top: 0;
  justify-content: center;
}

/* ---- CMS landing blocks: shoppers, businesses, pricing (body_html) ------------ */
.cms-shoppers-hero,
.cms-businesses-hero,
.cms-pricing-hero {
  position: relative;
  margin: 0 0 var(--sp-10);
  padding: var(--sp-8) var(--sp-7);
  border: 1px solid var(--n-200);
  border-radius: var(--r-xl);
  background: linear-gradient(145deg, var(--brand-light) 0%, var(--n-50) 45%, var(--white) 100%);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.cms-shoppers-hero::before,
.cms-businesses-hero::before,
.cms-pricing-hero::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  border-radius: var(--r-xl) var(--r-xl) 0 0;
  background: var(--brand-gradient);
}
.cms-page .cms-shoppers-hero p,
.cms-page .cms-businesses-hero p,
.cms-page .cms-pricing-hero p {
  position: relative;
  max-width: 44rem;
}
.cms-shoppers-eyebrow,
.cms-businesses-eyebrow,
.cms-pricing-eyebrow {
  margin: 0 0 var(--sp-3);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brand-teal);
}
.cms-shoppers-tagline,
.cms-businesses-tagline,
.cms-pricing-tagline {
  margin: 0 0 var(--sp-4);
  font-size: clamp(var(--text-xl), 3vw, var(--text-3xl));
  font-weight: 700;
  line-height: 1.2;
  color: var(--n-900);
  letter-spacing: -0.03em;
}
.cms-shoppers-hero-actions,
.cms-businesses-hero-actions,
.cms-pricing-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-top: var(--sp-6);
  margin-bottom: 0;
}
.cms-shoppers-hero-actions .btn,
.cms-businesses-hero-actions .btn,
.cms-pricing-hero-actions .btn {
  margin-top: 0;
}
.cms-shoppers-grid,
.cms-businesses-grid,
.cms-pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(17rem, 1fr));
  gap: var(--sp-4);
  margin: var(--sp-6) 0 var(--sp-10);
}
.cms-shoppers-tile,
.cms-businesses-tile,
.cms-pricing-tile {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-5) var(--sp-5) var(--sp-6);
  box-shadow: none;
  border-top-width: 3px;
  border-top-style: solid;
}
.cms-shoppers-tile--blue,
.cms-businesses-tile--blue,
.cms-pricing-tile--blue {
  border-top-color: var(--brand);
}
.cms-shoppers-tile--teal,
.cms-businesses-tile--teal,
.cms-pricing-tile--teal {
  border-top-color: var(--brand-teal);
}
.cms-page .cms-shoppers-tile p:last-child,
.cms-page .cms-businesses-tile p:last-child,
.cms-page .cms-pricing-tile p:last-child {
  margin-bottom: 0;
}
/* Grid center column: keeps copy + actions aligned regardless of outer layout */
.cms-cta-banner {
  display: grid;
  grid-template-columns: 1fr min(42rem, 100%) 1fr;
  margin: var(--sp-12) 0 var(--sp-2);
  padding: var(--sp-10) var(--sp-6);
  border-radius: var(--r-xl);
  background: linear-gradient(160deg, var(--n-800) 0%, var(--n-900) 55%, #0a1628 100%);
  text-align: center;
  box-shadow: var(--shadow-lg);
}
.cms-cta-banner > * {
  grid-column: 2;
  justify-self: stretch;
  text-align: center;
}
.cms-page .cms-cta-banner p {
  text-align: center;
}
.cms-cta-banner__title {
  margin: 0 0 var(--sp-3);
  font-size: clamp(var(--text-xl), 2.5vw, var(--text-2xl));
  font-weight: 700;
  color: var(--white);
  letter-spacing: -0.02em;
  text-align: center;
}
.cms-cta-banner__lede {
  margin: 0 0 var(--sp-8);
  max-width: none;
  font-size: var(--text-lg);
  line-height: 1.65;
  color: var(--n-300);
  text-align: center;
}
.cms-cta-banner__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  justify-content: center;
  align-items: center;
  margin: 0;
}
.cms-cta-banner__actions .btn {
  margin-top: 0;
}
.cms-cta-banner .btn.cms-cta-banner__ghost {
  background: transparent;
  border-color: rgba(255, 255, 255, 0.35);
  color: var(--white);
}
.cms-cta-banner .btn.cms-cta-banner__ghost:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.55);
  color: var(--white);
}
@media (max-width: 640px) {
  .cms-shoppers-hero,
  .cms-businesses-hero,
  .cms-pricing-hero {
    padding: var(--sp-6) var(--sp-5);
  }
  .cms-cta-banner {
    padding: var(--sp-8) var(--sp-5);
  }
}

/* ---- List a sale: private vs professional (guest) ------------------------- */
.listing-choice-page {
  padding-block: var(--sp-12) var(--sp-16);
  max-width: 72rem;
  margin-inline: auto;
}
.listing-choice-hero {
  text-align: center;
  margin-bottom: var(--sp-10);
}
.listing-choice-hero h1 {
  font-size: clamp(var(--text-2xl), 4vw, var(--text-4xl));
  margin-bottom: var(--sp-4);
}
.listing-choice-lead {
  color: var(--text-muted);
  font-size: var(--text-lg);
  max-width: 40rem;
  margin-inline: auto;
  line-height: 1.55;
}
.listing-choice-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-6);
  align-items: stretch;
}
@media (max-width: 900px) {
  .listing-choice-grid { grid-template-columns: 1fr; }
}
.listing-choice-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  padding: var(--sp-8);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  transition: box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.listing-choice-card:hover {
  box-shadow: var(--shadow-lg);
  border-color: var(--n-300);
}
.listing-choice-card--private { border-top: 4px solid var(--brand-teal); }
.listing-choice-card--pro { border-top: 4px solid var(--brand); }
.listing-choice-card-icon {
  width: 3rem;
  height: 3rem;
  border-radius: var(--r);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--sp-4);
  color: var(--brand);
  background: var(--brand-light);
}
.listing-choice-card--private .listing-choice-card-icon {
  color: var(--brand-teal);
  background: rgba(0, 146, 184, 0.12);
}
.listing-choice-card-title {
  font-size: var(--text-2xl);
  margin-bottom: var(--sp-2);
}
.listing-choice-card-for {
  color: var(--text-muted);
  font-size: var(--text-sm);
  margin-bottom: var(--sp-4);
}
.listing-choice-price {
  margin-bottom: var(--sp-2);
}
.listing-choice-price-amount {
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--primary);
}
.listing-choice-price-unit {
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--text-muted);
}
.listing-choice-subprice {
  font-size: var(--text-sm);
  color: var(--text-muted);
  margin-bottom: var(--sp-5);
  line-height: 1.5;
}

/* Professional card: rotating pitch (list-a-sale) */
.listing-choice-pro-rotate {
  margin-bottom: var(--sp-6);
  flex: 1;
  min-height: 0;
}
.listing-choice-pro-rotate__track {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: minmax(0, auto);
}
.listing-choice-pro-slide {
  grid-area: 1 / 1;
  opacity: 0;
  z-index: 0;
  pointer-events: none;
  transition: opacity 0.45s ease;
}
.listing-choice-pro-slide.is-active {
  opacity: 1;
  z-index: 1;
  pointer-events: auto;
}
.listing-choice-pro-slide .listing-choice-subprice {
  margin-bottom: var(--sp-4);
  font-weight: 600;
  color: var(--text);
}
.listing-choice-pro-slide .listing-choice-features {
  margin-bottom: 0;
}
@media (prefers-reduced-motion: reduce) {
  .listing-choice-pro-slide {
    transition: none;
  }
  .listing-choice-pro-rotate__progress {
    display: none;
  }
}

.listing-choice-pro-rotate__progress {
  width: 100%;
  height: 4px;
  margin-top: var(--sp-5);
  border-radius: var(--r-full);
  background: var(--n-200);
  overflow: hidden;
}
.listing-choice-pro-rotate__progress-fill {
  display: block;
  height: 100%;
  width: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--brand), var(--brand-teal));
  transform-origin: left center;
  transform: scaleX(1);
  will-change: transform;
}

.listing-choice-features {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--sp-6);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.listing-choice-features li {
  position: relative;
  padding-left: 1.5rem;
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--text);
}
.listing-choice-features li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.45em;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background: var(--brand);
}
.listing-choice-card--private .listing-choice-features li::before {
  background: var(--brand-teal);
}
.listing-choice-cta {
  width: 100%;
  justify-content: center;
  text-align: center;
  margin-bottom: var(--sp-4);
}
.listing-choice-footnote {
  font-size: var(--text-xs);
  color: var(--text-muted);
  line-height: 1.45;
  margin: 0;
}
.listing-choice-footnote a {
  color: var(--brand);
  font-weight: 600;
  text-decoration: none;
}
.listing-choice-footnote a:hover { text-decoration: underline; }
.listing-choice-back {
  text-align: center;
  margin-top: var(--sp-10);
  font-size: var(--text-sm);
  color: var(--text-muted);
}
.listing-choice-back a {
  color: var(--brand);
  font-weight: 600;
  text-decoration: none;
}
.listing-choice-back a:hover { text-decoration: underline; }

/* ---- Pro dashboard: /dashboard/marketplace -------------------------------- */
.pro-marketplace {
  max-width: 72rem;
}
.pro-mp-pagehead {
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-5);
  border-bottom: 1px solid var(--border);
}
.pro-mp-pagehead__title {
  margin: 0 0 var(--sp-2);
  font-size: clamp(1.35rem, 3vw, 1.85rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--primary);
}
.pro-mp-pagehead__lede {
  margin: 0;
  max-width: 40rem;
  line-height: 1.55;
}
.pro-mp-stats {
  margin-bottom: var(--sp-6);
}
.pro-mp-stats__grid {
  display: grid;
  gap: var(--sp-4);
  grid-template-columns: 1fr;
}
@media (min-width: 640px) {
  .pro-mp-stats__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sp-4);
  }
}
.pro-mp-stat {
  margin: 0;
  padding: var(--sp-5);
  border-radius: var(--r-lg);
  border: 1px solid var(--border);
  background: var(--surface, var(--white));
  box-shadow: var(--shadow-xs);
}
.pro-mp-stat__head {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  margin: 0 0 var(--sp-2);
}
.pro-mp-stat__icon {
  margin: 0;
  width: 2rem;
  height: 2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  color: var(--primary);
  background: color-mix(in srgb, var(--n-200) 55%, var(--white));
}
.pro-mp-stat--ready .pro-mp-stat__icon {
  color: var(--brand);
  background: color-mix(in srgb, var(--brand) 16%, var(--white));
}
.pro-mp-stat--pending .pro-mp-stat__icon {
  color: var(--n-700);
  background: color-mix(in srgb, var(--n-300) 34%, var(--white));
}
.pro-mp-stat--value .pro-mp-stat__icon {
  color: var(--brand);
  background: color-mix(in srgb, var(--brand) 12%, var(--white));
}
.pro-mp-stat--ready {
  border-color: color-mix(in srgb, var(--brand) 22%, var(--border));
  background: color-mix(in srgb, var(--brand) 5%, var(--white));
}
.pro-mp-stat--pending {
  border-color: color-mix(in srgb, var(--n-400) 35%, var(--border));
  background: var(--n-50, #f8fafc);
}
.pro-mp-stat--value {
  border-color: var(--border);
  background: var(--white);
}
.pro-mp-stat__label {
  margin: 0;
  font-size: var(--text-xs);
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
  line-height: 1.3;
}
.pro-mp-stat__value {
  margin: 0 0 var(--sp-2);
  font-size: clamp(1.75rem, 4vw, 2.25rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.1;
  color: var(--primary);
}
.pro-mp-stat__value--money {
  font-variant-numeric: tabular-nums;
  color: var(--green);
}
.pro-mp-stat__hint {
  margin: 0;
  font-size: var(--text-sm);
  line-height: 1.45;
  color: var(--text-muted);
}
.pro-mp-intel {
  margin: 0 0 var(--sp-6);
  padding: var(--sp-5);
  background: var(--surface, var(--white));
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
}
.pro-mp-intel__head {
  margin: 0 0 var(--sp-3);
}
.pro-mp-intel__title {
  margin: 0 0 var(--sp-2);
  font-size: 1.05rem;
}
.pro-mp-intel__lede {
  margin: 0;
  color: var(--text-muted);
  font-size: var(--text-sm);
  line-height: 1.45;
}
.pro-mp-intel__table-wrap {
  overflow-x: auto;
}
.pro-mp-intel__table {
  width: 100%;
  border-collapse: collapse;
}
.pro-mp-intel__table th,
.pro-mp-intel__table td {
  padding: 0.55rem 0.45rem;
  border-bottom: 1px solid var(--border);
  text-align: left;
  font-size: var(--text-sm);
  vertical-align: top;
}
.pro-mp-intel__table th {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-muted);
}
.pro-mp-intel__empty {
  margin: 0;
}
.pro-mp-legend {
  margin-bottom: var(--sp-6);
  padding: var(--sp-5);
  background: var(--surface, var(--white));
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: none;
}
.pro-mp-legend__grid {
  display: grid;
  gap: var(--sp-4);
}
@media (min-width: 640px) {
  .pro-mp-legend__grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-5);
  }
}
.pro-mp-legend__cell {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--sp-2);
}
.pro-mp-legend__text {
  font-size: var(--text-sm);
  line-height: 1.45;
  color: var(--text-muted);
}
.pro-mp-badge {
  display: inline-block;
  padding: 0.2rem 0.5rem;
  border-radius: var(--r-sm);
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.pro-mp-badge--inline {
  flex-shrink: 0;
}
.pro-mp-badge--listed {
  background: color-mix(in srgb, var(--brand) 12%, transparent);
  color: var(--brand);
  border: 1px solid color-mix(in srgb, var(--brand) 28%, transparent);
}
.pro-mp-badge--ai {
  background: var(--n-100, #f1f5f9);
  color: var(--n-700, #334155);
  border: 1px solid var(--border);
}
.pro-mp-empty {
  padding: var(--sp-10) 0;
  max-width: 34rem;
}
.pro-mp-empty p {
  margin: 0 0 var(--sp-4);
  line-height: 1.6;
  color: var(--text-muted);
}
.pro-mp-listed-form .pl-wizard-analysis-card__mp-toggle,
.pro-mp-listed-form .pro-mp-ai-cb {
  display: none;
}
.pro-mp-sales {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.pro-mp-sale {
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--white);
  overflow: hidden;
  box-shadow: none;
}
.pro-mp-sale__summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3) var(--sp-4);
  padding: var(--sp-4) var(--sp-5);
  font-weight: 600;
  background: linear-gradient(180deg, var(--n-50, #f8fafc) 0%, var(--white) 100%);
  border-bottom: 1px solid transparent;
  transition: background var(--dur-sm) var(--ease, ease);
}
.pro-mp-sale[open] > .pro-mp-sale__summary {
  border-bottom-color: var(--border);
}
.pro-mp-sale__summary::-webkit-details-marker {
  display: none;
}
.pro-mp-sale__summary:hover {
  background: var(--n-50, #f8fafc);
}
.pro-mp-sale__summary-main {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  min-width: 0;
}
.pro-mp-sale__chev {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  flex-shrink: 0;
  color: var(--text-muted);
}
.pro-mp-sale__chev::before {
  content: '';
  display: block;
  width: 0.45rem;
  height: 0.45rem;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(-45deg);
  transition: transform 0.2s ease;
}
.pro-mp-sale[open] .pro-mp-sale__chev::before {
  transform: rotate(45deg);
}
.pro-mp-sale__title {
  font-size: var(--text-base);
  color: var(--primary);
  font-weight: 700;
  letter-spacing: -0.01em;
}
.pro-mp-sale__counts {
  color: var(--text-muted);
  font-weight: 500;
  font-size: var(--text-sm);
}
.pro-mp-sale__body {
  padding: var(--sp-5);
  background: var(--white);
}
.pro-mp-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-5);
  border-bottom: 1px solid var(--border);
}
.pro-mp-toolbar__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}
.pro-mp-toolbar__btn svg {
  flex-shrink: 0;
}
.pro-mp-section-label {
  font-size: var(--text-xs);
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: 0 0 var(--sp-3);
}
.pro-mp-section-label + .pro-mp-bulk-form {
  margin-top: 0;
}
.pro-mp-bulk-form {
  margin-bottom: var(--sp-6);
}
.pro-mp-bulk-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-4);
  margin-bottom: var(--sp-3);
  background: var(--n-50, #f8fafc);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
}
.pro-mp-bulk-bar__select-all {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--primary);
  cursor: pointer;
  margin: 0;
}
.pro-mp-bulk-bar__select-all input {
  width: 1.1rem;
  height: 1.1rem;
  accent-color: var(--brand);
}
.pro-mp-bulk-bar__save {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}
.pro-mp-bulk-hint {
  margin: 0 0 var(--sp-4);
  max-width: 44rem;
  line-height: 1.5;
}
.pro-mp-bulk-hidden-slots {
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
}
.pro-mp-card-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
}
@media (min-width: 640px) {
  .pro-mp-card-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .pro-mp-card-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.pro-mp-card {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--white);
  overflow: hidden;
  box-shadow: none;
  transition: border-color var(--dur-sm) var(--ease, ease), box-shadow var(--dur-sm) var(--ease, ease);
}
.pro-mp-card:hover {
  border-color: color-mix(in srgb, var(--brand) 22%, var(--border));
  box-shadow: none;
}
.pro-mp-card--ai {
  position: relative;
}
.pro-mp-card__check-wrap {
  position: absolute;
  top: var(--sp-3);
  left: var(--sp-3);
  z-index: 2;
  width: 1.35rem;
  height: 1.35rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--white);
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
  box-shadow: none;
}
.pro-mp-card__check-wrap .pro-mp-ai-cb {
  width: 1rem;
  height: 1rem;
  margin: 0;
  accent-color: var(--brand);
  cursor: pointer;
}
/* Isolated/crop media must fill the aspect box; top padding would show as empty strip (post-sale + marketplace) */
.pro-mp-card--ai .pro-mp-card__media:not(.pro-mp-card__media--isolated) {
  padding-top: var(--sp-2);
}
.pro-mp-card__media {
  aspect-ratio: 4 / 3;
  background: var(--n-100, #f1f5f9);
  overflow: hidden;
}
/* Item-isolated preview: contain + center box_1000 inside inset crop frame (see pro-marketplace.js). */
.pro-mp-card__media--isolated {
  --pro-mp-crop-inset: clamp(6px, 2.5%, 12px);
  aspect-ratio: 4 / 3;
  position: relative;
  width: 100%;
  overflow: hidden;
  box-sizing: border-box;
  background: linear-gradient(165deg, var(--n-50, #f8fafc) 0%, var(--n-100, #f1f5f9) 55%, var(--n-150, #e8edf3) 100%);
  box-shadow: none;
}
.pro-mp-card__crop-frame {
  position: absolute;
  left: var(--pro-mp-crop-inset);
  top: var(--pro-mp-crop-inset);
  right: var(--pro-mp-crop-inset);
  bottom: var(--pro-mp-crop-inset);
  width: auto;
  height: auto;
  overflow: hidden;
  background: transparent;
  box-sizing: border-box;
}
/* Dimensions/position from pro-marketplace.js (contain-scale); must beat .pro-mp-card__img. */
.pro-mp-card__crop-frame > .pro-mp-card__img--isolated {
  position: absolute;
  max-width: none;
  width: auto;
  height: auto;
  display: block;
  object-fit: unset;
  margin: 0;
}
.pro-mp-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.pro-mp-card__placeholder {
  width: 100%;
  height: 100%;
  min-height: 8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--n-400, #94a3b8);
  background: linear-gradient(145deg, var(--n-100), var(--n-50, #f8fafc));
}
.pro-mp-card__body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: var(--sp-4);
  gap: var(--sp-2);
  min-height: 0;
}
.pro-mp-card__title-line {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-2);
  min-width: 0;
}
.pro-mp-card__title-line .pro-mp-card__title {
  flex: 1;
  min-width: 0;
}
.pro-mp-inline-text {
  cursor: text;
}
.pro-mp-inline-text:focus,
.pro-mp-inline-text:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--brand) 35%, transparent);
  outline-offset: 2px;
  border-radius: var(--r-xs);
}
.pro-mp-inline-text--desc {
  white-space: pre-wrap;
}
.pro-mp-ai-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 1.75rem;
  height: 1.75rem;
  margin-top: 0.1rem;
  border-radius: var(--r-sm);
  background: color-mix(in srgb, var(--brand) 12%, transparent);
  color: var(--brand);
  border: 1px solid color-mix(in srgb, var(--brand) 22%, transparent);
}
.pro-mp-ai-icon svg {
  display: block;
}
.pro-mp-card__title {
  margin: 0;
  font-size: var(--text-base);
  font-weight: 700;
  line-height: 1.35;
  color: var(--primary);
  letter-spacing: -0.01em;
}
.pro-mp-card__desc {
  margin: 0;
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--text);
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.pro-mp-card__desc--muted {
  color: var(--text-muted);
  font-style: italic;
}
.pro-mp-card__price {
  margin: 0;
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--primary);
}
.pro-mp-card__cond {
  margin: 0;
  font-size: var(--text-xs);
}
.pro-mp-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-top: auto;
  padding-top: var(--sp-2);
}
.pro-mp-card__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  text-decoration: none;
}
.pro-mp-card__btn svg {
  flex-shrink: 0;
}
button.pro-mp-card__btn {
  font: inherit;
  cursor: pointer;
}
.pro-mp-hint {
  margin: calc(-1 * var(--sp-2)) 0 var(--sp-4);
  max-width: 42rem;
  line-height: 1.5;
}
.pro-mp-back {
  margin-top: var(--sp-10);
  padding-top: var(--sp-6);
  border-top: 1px solid var(--border);
}
/* Edit item modal */
.pro-mp-edit-dialog {
  margin: auto;
  padding: 0;
  width: min(36rem, calc(100vw - 1.5rem));
  max-width: min(36rem, calc(100vw - 1.5rem));
  max-height: min(90vh, 44rem);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface, var(--white));
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}
.pro-mp-edit-dialog::backdrop {
  background: rgba(15, 23, 42, 0.45);
}
.pro-mp-edit-dialog__inner {
  display: flex;
  flex-direction: column;
  max-height: min(90vh, 44rem);
}
.pro-mp-edit-dialog__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-4);
  padding: var(--sp-5) var(--sp-5) var(--sp-3);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.pro-mp-edit-dialog__title {
  margin: 0;
  font-size: var(--text-xl);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--primary);
}
.pro-mp-edit-dialog__close {
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  margin: calc(-1 * var(--sp-1)) calc(-1 * var(--sp-1)) 0 0;
  padding: 0;
  border: none;
  border-radius: var(--r-sm);
  background: transparent;
  color: var(--n-500);
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  transition: background var(--dur-sm) var(--ease, ease), color var(--dur-sm) var(--ease, ease);
}
.pro-mp-edit-dialog__close:hover {
  background: var(--n-100);
  color: var(--primary);
}
.pro-mp-edit-dialog__form {
  display: flex;
  flex-direction: column;
  min-height: 0;
  flex: 1;
}
.pro-mp-edit-dialog__body {
  padding: var(--sp-5);
  overflow-y: auto;
  flex: 1;
}
.pro-mp-edit-dialog__footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5) var(--sp-5);
  border-top: 1px solid var(--border);
  flex-shrink: 0;
}
.pro-mp-edit-dialog__footer .btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}
.pro-mp-form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(10.5rem, 1fr));
  gap: var(--sp-4);
}
.pro-mp-field--full {
  grid-column: 1 / -1;
}
.pro-mp-field--check {
  display: flex;
  align-items: flex-end;
}
.pro-mp-check {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--text-sm);
  cursor: pointer;
  margin: 0;
}

/* /sales: “N Sales” (left) + Use my location (right) */
.sales-page__listing-head {
  align-items: center;
}
.sales-page__listing-actions {
  flex-shrink: 0;
}
.sales-page__location-msg {
  margin: 0 0 var(--sp-6);
  min-height: 0;
}

.sales-empty-state-panel {
  padding: var(--sp-12) var(--sp-6);
  text-align: center;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
}

/* ---- Card grid & cards ---------------------------------------------------- */
.card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: var(--sp-5); }
/* Estate sale listing cards: column count follows container width (1 on phones, more when space allows). */
.card-grid.card-grid--listings {
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 20rem), 1fr));
  gap: var(--sp-6);
}
.card-grid.card-grid--listings .sale-listing-card-title { font-size: var(--text-lg); line-height: 1.3; }
@media (min-width: 1025px) {
  .card-grid.card-grid--listings .card-meta {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    column-gap: var(--sp-5);
    row-gap: var(--sp-1);
  }
}
.card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-xs);
  transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.card:hover { box-shadow: none; transform: none; border-color: var(--n-300); }

/* Listing cards: photo slideshow + whole-card navigation */
.sale-listing-card { cursor: pointer; }
.sale-listing-card--entry-pass,
.sale-listing-card--virtual-line {
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}
.sale-listing-card .sale-listing-card-title { color: var(--primary); }
.card-grid.card-grid--listings .sale-listing-card .badge {
  font-size: calc(0.6875rem - 1pt);
}

/* Dashboard home: status tint on listing cards (draft / active / expired) */
.card-grid.card-grid--listings .sale-listing-card--dash-draft,
.card-grid.card-grid--listings .sale-listing-card--dash-expired {
  position: relative;
}
.card-grid.card-grid--listings .sale-listing-card--dash-draft::after,
.card-grid.card-grid--listings .sale-listing-card--dash-expired::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--r-lg);
  pointer-events: none;
  z-index: 3;
}
.card-grid.card-grid--listings .sale-listing-card--dash-draft::after {
  background: rgba(0, 0, 0, 0.1);
}
.card-grid.card-grid--listings .sale-listing-card--dash-expired::after {
  background: rgba(220, 38, 38, 0.1);
}
.sale-card-slideshow {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 10;
  background: var(--n-100);
  border-bottom: 1px solid var(--border);
  overflow: hidden;
  flex-shrink: 0;
}
.sale-card-slide-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 200ms var(--ease), transform 300ms var(--ease);
  pointer-events: none;
}
.sale-card-slide-img.is-active {
  opacity: 1;
  z-index: 1;
}
.sale-listing-card:hover .sale-card-slideshow .sale-card-slide-img.is-active {
  transform: scale(1.04);
}
.sale-card-slideshow-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 4;
  width: 2.25rem;
  height: 2.25rem;
  padding: 0;
  margin: 0;
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  color: var(--primary);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  transition:
    background 0.15s ease,
    border-color 0.15s ease,
    color 0.15s ease,
    transform var(--dur-sm) var(--ease);
}
.sale-card-slideshow-nav:hover {
  background: var(--white);
  border-color: var(--n-300);
  color: var(--brand);
  transform: translateY(-50%) scale(1.05);
}
.sale-card-slideshow-prev { left: var(--sp-2); }
.sale-card-slideshow-next { right: var(--sp-2); }
/* Above image overlays (badges + bottom bar) so prev/next stay clickable */
.sale-listing-card--media-overlays .sale-card-slideshow-nav {
  z-index: 5;
  pointer-events: auto;
}

/* Listing cards (dashboard, home, search, /sales, city/state, company): image overlays + body excerpt */
.sale-listing-card--media-overlays .sale-listing-card__media-overlays {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  pointer-events: none;
}
.sale-listing-card--media-overlays .sale-listing-card__media-overlays-top {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--sp-2);
  padding: var(--sp-2);
}
.sale-listing-card--media-overlays .sale-listing-card__media-overlays-top-right {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: var(--sp-1);
  max-width: 72%;
  min-width: 0;
}
.sale-listing-card--media-overlays .sale-listing-card__media-top-company {
  display: inline-block;
  max-width: 100%;
  padding: 0.22rem 0.5rem;
  border-radius: var(--r-sm);
  font-size: var(--text-xs);
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: 0.01em;
  color: #fff;
  background: rgba(15, 23, 43, 0.82);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
  /* Solid chip reads sharper than white text + heavy text-shadow on photos */
  text-shadow: none;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  -webkit-font-smoothing: antialiased;
}
.sale-listing-card--media-overlays a.sale-listing-card__media-top-company {
  pointer-events: auto;
  color: #fff;
  text-decoration: none;
  transition: background var(--dur-sm) var(--ease), box-shadow var(--dur-sm) var(--ease);
}
.sale-listing-card--media-overlays a.sale-listing-card__media-top-company:hover {
  background: rgba(15, 23, 43, 0.92);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.4);
  text-decoration: none;
}
.sale-listing-card--media-overlays .sale-listing-card__media-overlays-bottom {
  width: 100%;
  background: rgba(0, 0, 0, 0.7);
  padding: var(--sp-2) var(--sp-3);
}
.sale-listing-card--media-overlays .sale-listing-card__media-bar {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-2) var(--sp-4);
}
.sale-listing-card--media-overlays .sale-listing-card__media-bar-loc,
.sale-listing-card--media-overlays .sale-listing-card__media-bar-dates {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: calc(var(--text-xs) - 1pt);
  font-weight: 600;
  color: rgba(255, 255, 255, 0.96);
  line-height: 1.35;
  min-width: 0;
}
.sale-listing-card--media-overlays .sale-listing-card__media-bar-loc {
  justify-content: flex-start;
}
.sale-listing-card--media-overlays .sale-listing-card__media-bar-dates {
  justify-content: flex-end;
  text-align: right;
  margin-left: auto;
}
.sale-listing-card--media-overlays .sale-listing-card__media-bar-loc svg,
.sale-listing-card--media-overlays .sale-listing-card__media-bar-dates svg {
  flex-shrink: 0;
  color: rgba(255, 255, 255, 0.88);
}
@media (max-width: 640px) {
  .sale-listing-card--media-overlays .sale-listing-card__media-overlays-bottom {
    padding: var(--sp-2);
  }
  .sale-listing-card--media-overlays .sale-listing-card__media-bar {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--sp-1);
  }
  .sale-listing-card--media-overlays .sale-listing-card__media-bar-loc,
  .sale-listing-card--media-overlays .sale-listing-card__media-bar-dates {
    width: 100%;
    white-space: normal;
    overflow-wrap: anywhere;
    font-size: calc(var(--text-xs) - 2pt);
    line-height: 1.3;
  }
  .sale-listing-card--media-overlays .sale-listing-card__media-bar-dates {
    justify-content: flex-start;
    text-align: left;
    margin-left: 0;
  }
}

.sale-listing-card--media-overlays .sale-listing-card-title {
  display: flex;
  flex-direction: row;
  align-items: baseline;
  gap: 0.35rem;
  min-width: 0;
  max-width: 100%;
}
.sale-listing-card--media-overlays .sale-listing-card-title__main {
  flex: 1 1 0;
  min-width: 0;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.sale-listing-card--media-overlays .sale-listing-card-title > .meta {
  flex-shrink: 0;
}
.sale-listing-card--media-overlays .sale-listing-card__excerpt {
  margin: 0;
  font-size: var(--text-xs);
  line-height: 1.45;
  font-weight: 500;
  color: #000;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.card-img {
  width: 100%;
  aspect-ratio: 16/10;
  object-fit: cover;
  background: var(--n-100);
  border-bottom: 1px solid var(--border);
  display: block;
  transition: transform 300ms var(--ease);
}
.card:hover .card-img { transform: scale(1.04); }

.card-body { display: flex; flex-direction: column; gap: var(--sp-3); padding: var(--sp-5); flex: 1; }
.card h3 { font-size: var(--text-base); font-weight: 700; line-height: 1.35; color: var(--primary); margin: 0; }
.card h3 a { color: inherit; text-decoration: none; transition: color var(--dur-sm) var(--ease); }
.card h3 a:hover { color: var(--brand); }
.card-meta { display: flex; flex-direction: column; gap: var(--sp-1); }
.meta-item { display: flex; align-items: center; gap: var(--sp-2); font-size: var(--text-xs); color: var(--text-muted); line-height: 1.5; }
.meta-item svg { flex-shrink: 0; }
.card-footer-row { margin-top: auto; padding-top: var(--sp-3); border-top: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); }
/* /dashboard listing cards: Edit / Delete / Copy / Renew always one row (phone / tablet / desktop) */
.card-grid.card-grid--listings .dashboard-listing-actions {
  flex-wrap: nowrap;
  gap: var(--sp-2);
  justify-content: flex-start;
  align-items: stretch;
}
.card-grid.card-grid--listings .dashboard-listing-actions > .btn {
  flex: 1 1 0;
  min-width: 0;
  padding-inline: var(--sp-2);
  font-size: var(--text-xs);
  overflow: hidden;
}
.card-grid.card-grid--listings .dashboard-listing-actions > .btn svg {
  width: 12px;
  height: 12px;
}
@media (max-width: 639px) {
  .card-grid.card-grid--listings .dashboard-listing-actions {
    gap: var(--sp-1);
  }
  .card-grid.card-grid--listings .dashboard-listing-actions > .btn {
    padding-inline: 0.2rem;
    gap: 0.125rem;
  }
}

/* ---- Badges --------------------------------------------------------------- */
.badge { display: inline-flex; align-items: center; padding: 0.2rem 0.6rem; border-radius: var(--r-full); font-size: 0.6875rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; white-space: nowrap; }
.badge-upcoming { background: var(--brand-light);  color: var(--brand); }
.badge-active   { background: var(--green-bg);    color: var(--green); }
.badge-ended    { background: var(--n-100);        color: var(--n-500); }

/* ---- Pills (state browse) ------------------------------------------------- */
.pills { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.pills a { display: inline-flex; align-items: center; height: 2.25rem; padding-inline: var(--sp-4); background: var(--white); border: 1px solid var(--border); border-radius: var(--r-full); font-size: var(--text-sm); font-weight: 500; color: var(--text); text-decoration: none; transition: all var(--dur-sm) var(--ease); box-shadow: var(--shadow-xs); }
.pills a:hover { background: var(--brand); border-color: var(--brand); color: #fff; }

/* ---- Forms ---------------------------------------------------------------- */
.search-filters {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
  box-shadow: var(--shadow-sm);
  margin-bottom: var(--sp-8);
}
.form-panel     { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); padding: var(--sp-8); box-shadow: var(--shadow-md); }

/* Dashboard: centered form panels (Pro placeholders, settings, POS receipt/pay/report) */
.main.shell > .form-panel.pro-dash-placeholder,
.main.shell > .form-panel.config-settings-page {
  max-width: var(--dashboard-form-panel-max);
  width: 100%;
  margin-inline: auto;
}
/* Pro dashboard root panel: no outer .form-panel stroke (staff, config settings, home, etc.) */
.main.shell > .form-panel.pro-dash-placeholder {
  border: none;
  box-shadow: none;
}
/* /dashboard/marketplace — explicit (beats base .form-panel if cascade order shifts) */
body.is-dashboard-shell .main.shell > .form-panel.pro-dash-placeholder.pro-marketplace {
  border: none;
  box-shadow: none;
}

/* Nested cards/forms inside a dashboard panel (e.g. POS receipt actions) */
.main.shell > .form-panel.pro-dash-placeholder > .form-panel,
.main.shell > .form-panel.pro-dash-placeholder form.form-panel {
  width: 100%;
  max-width: none;
  margin-inline: 0;
  box-sizing: border-box;
}

/* Professional dashboard: slightly more air between label, control, and helper copy */
.main.shell > .form-panel.pro-dash-placeholder .form-group {
  gap: 0;
}
.main.shell > .form-panel.pro-dash-placeholder .form-group.form-check {
  gap: var(--sp-2);
}
/* Professional dashboard: space beneath text fields (helper text / next field) */
.main.shell > .form-panel.pro-dash-placeholder .form-group textarea,
.main.shell > .form-panel.pro-dash-placeholder .form-group input.form-control,
.main.shell > .form-panel.pro-dash-placeholder .form-group > input:not([type='checkbox']):not([type='radio']):not([type='file']):not([type='hidden']):not([type='submit']):not([type='button']) {
  margin-bottom: var(--sp-1);
}
/* Breathing room above field labels (not inside side-by-side columns, where alignment handles it) */
.main.shell > .form-panel.pro-dash-placeholder .form-group > label:not(.form-check-label) {
  margin-top: 0;
}
.main.shell > .form-panel.pro-dash-placeholder .form-row > .form-group > label:not(.form-check-label) {
  margin-top: 0;
}
/* City / state / ZIP row: pro-dash only adds margin-bottom to inputs, not to state <select> — keep fields on one line */
.main.shell > .form-panel.pro-dash-placeholder .es-address-fields__locality .form-group > input.form-control,
.main.shell > .form-panel.pro-dash-placeholder .es-address-fields__locality .form-group > select.form-control,
.main.shell > .form-panel.pro-dash-placeholder .cp-locality-row__inner .form-group > input.form-control,
.main.shell > .form-panel.pro-dash-placeholder .cp-locality-row__inner .form-group > select.form-control {
  margin-bottom: 0;
}

.form-panel--auth {
  max-width: 28rem;
  margin-inline: auto;
  width: 100%;
  box-sizing: border-box;
}
.form-panel--reset-password .reset-password__lede {
  margin: 0 0 var(--sp-8);
  font-size: var(--text-base, 1rem);
  font-weight: 400;
  color: var(--text);
  line-height: 1.55;
}
.form-panel--reset-password .reset-password__field + .reset-password__field {
  margin-top: var(--sp-6);
}
.form-panel--reset-password label.keep-field-label {
  display: block;
  margin-bottom: var(--sp-2);
  font-weight: 600;
}
.form-panel--reset-password .reset-password__summary {
  margin: 0 0 var(--sp-2);
  padding: 0;
  font-size: var(--text-xs);
  font-weight: 400;
  color: var(--text-muted);
  line-height: 1.55;
}
.form-panel--reset-password .reset-password__req-list {
  margin: 0 0 var(--sp-4);
  padding-left: 1.35rem;
  font-size: var(--text-xs);
  font-weight: 400;
  color: var(--text-muted);
  line-height: 1.45;
  list-style-type: disc;
}
.form-panel--reset-password .reset-password__req-list li {
  margin: 0.25em 0;
}
.form-panel--reset-password .reset-password__req-list[hidden] {
  display: none !important;
}

.reset-password-strength {
  margin-top: var(--sp-3);
}
.reset-password-strength__track {
  display: flex;
  gap: 4px;
  align-items: stretch;
}
.reset-password-strength__track.is-max .reset-password-strength__seg.is-met {
  background: var(--success, #16a34a);
}
.reset-password-strength__seg {
  flex: 1;
  height: 6px;
  border-radius: var(--r-sm, 4px);
  background: var(--border, #e2e8f0);
  transition: background 0.15s ease;
}
.reset-password-strength__seg.is-met {
  background: linear-gradient(90deg, var(--brand-teal, #14b8a6), var(--brand, #155dfc));
}
.reset-password-strength__label {
  margin: var(--sp-2) 0 0;
  font-size: var(--text-sm);
  font-weight: 400;
  color: var(--text-muted);
  line-height: 1.4;
}
.reset-password-mismatch {
  margin: var(--sp-2) 0 0;
  font-size: var(--text-sm);
  font-weight: 400;
  color: var(--danger, #b91c1c);
  line-height: 1.4;
}
.reset-password-mismatch[hidden] {
  display: none !important;
}
.reset-password-input--invalid {
  border-color: var(--danger, #b91c1c);
}

.form-panel--auth > form > .btn-primary {
  margin-block: var(--sp-6);
}
.form-panel.form-panel--reset-password > form > .btn-primary {
  margin-block: var(--sp-8) var(--sp-6);
}

/* /admin/login — same width as site login; do not use .admin-panel (72rem) here */
.admin-login-form.form-panel--auth > form > .form-group:first-of-type {
  margin-top: var(--sp-6);
}
.admin-login-form.form-panel--auth > form > .form-group + .form-group {
  margin-top: var(--sp-5);
}

/* ---- Login page: form + features pane ----------------------------------- */
.login-page {
  display: grid;
  grid-template-columns: minmax(0, 28rem) minmax(0, 1fr);
  gap: var(--sp-10);
  align-items: start;
  width: 100%;
  max-width: min(72rem, 100%);
  margin-inline: auto;
}

.login-page__form .form-panel--auth {
  margin-inline: 0;
  max-width: none;
}

.login-page__form {
  position: sticky;
  /* Below .header-inner (3.75rem) + small gap */
  top: calc(3.75rem + var(--sp-4));
  align-self: start;
  z-index: 1;
}

.login-page .form-panel--auth > form > .form-group:first-of-type {
  margin-top: var(--sp-6);
}
.login-page .form-panel--auth > form > .form-group + .form-group {
  margin-top: var(--sp-5);
}

.login-oauth {
  margin: 0 0 var(--sp-2);
}
.login-oauth-divider {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin: 0 0 var(--sp-5);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--n-500);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.login-oauth-divider::before,
.login-oauth-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border);
}
.login-oauth-divider span {
  flex-shrink: 0;
}
.btn-google-signin {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  width: 100%;
  box-sizing: border-box;
  min-height: 2.75rem;
  padding: 0 var(--sp-4);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--white);
  color: var(--n-700);
  font-size: var(--text-sm);
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  transition: background var(--dur-sm) var(--ease), border-color var(--dur-sm) var(--ease), color var(--dur-sm) var(--ease);
}
.btn-google-signin:hover {
  background: var(--n-50);
  border-color: var(--n-300);
  color: var(--primary);
}
.btn-google-signin__logo {
  flex-shrink: 0;
}

.login-features-pane {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-md);
  padding: var(--sp-8);
  position: relative;
  overflow: hidden;
}

.login-features-pane::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--brand-gradient);
  pointer-events: none;
}

.login-features-pane__lede {
  font-size: var(--text-sm);
  line-height: 1.6;
  color: var(--text-muted);
  margin: 0 0 var(--sp-8);
}

.login-features-block {
  padding-top: var(--sp-6);
  margin-top: var(--sp-6);
  border-top: 1px solid var(--border);
}

.login-features-block:first-of-type {
  padding-top: 0;
  margin-top: 0;
  border-top: none;
}

.login-features-block__title {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--primary);
  margin: 0 0 var(--sp-1);
  letter-spacing: -0.02em;
}

.login-features-block__title::before {
  content: '';
  width: 4px;
  height: 1.15em;
  border-radius: var(--r-xs);
  flex-shrink: 0;
}

.login-features-block--shoppers .login-features-block__title {
  color: var(--brand-teal);
}

.login-features-block--shoppers .login-features-block__title::before {
  background: var(--brand-teal);
}

.login-features-block--business .login-features-block__title {
  color: var(--brand);
}

.login-features-block--business .login-features-block__title::before {
  background: var(--brand);
}

.login-features-block--private .login-features-block__title {
  color: var(--n-800);
}

.login-features-block--private .login-features-block__title::before {
  background: var(--brand-gradient);
}

.login-features-block__tagline {
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  margin: 0 0 var(--sp-4);
}

.login-features-block__list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.login-features-block__list li {
  position: relative;
  padding-left: var(--sp-6);
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--text);
}

.login-features-block__list li::before {
  content: '';
  position: absolute;
  left: 0.15rem;
  top: 0.55em;
  width: 6px;
  height: 6px;
  border-radius: var(--r-full);
  background: var(--n-300);
}

.login-features-block--shoppers .login-features-block__list li::before {
  background: var(--brand-teal);
  opacity: 0.85;
}

.login-features-block--business .login-features-block__list li::before {
  background: var(--brand);
  opacity: 0.85;
}

.login-features-block--private .login-features-block__list li::before {
  background: var(--brand-teal);
  opacity: 0.7;
}

@media (max-width: 960px) {
  .login-page {
    grid-template-columns: 1fr;
    gap: var(--sp-8);
    max-width: none;
  }

  .login-page__form {
    position: static;
    top: auto;
    z-index: auto;
  }

  .login-page__form .form-panel--auth {
    margin-inline: auto;
    max-width: 28rem;
  }
}

/* ---- Professional registration (multi-step) ------------------------------ */
.register-pro-page {
  display: grid;
  grid-template-columns: minmax(0, min(44rem, 100%)) minmax(0, 1fr);
  grid-template-areas:
    'main aside'
    'login login';
  gap: var(--sp-10);
  align-items: stretch;
  width: 100%;
  max-width: min(104rem, 100%);
  margin-inline: auto;
}
.register-pro-page__main {
  grid-area: main;
  display: flex;
  flex-direction: column;
  min-height: 0;
  z-index: 1;
}
.register-pro-card {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-lg);
  padding: var(--sp-8);
  position: relative;
  overflow: hidden;
}
.register-pro-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--brand-gradient);
  pointer-events: none;
}
.register-pro-card__header {
  margin-bottom: var(--sp-6);
}
.register-pro-card__eyebrow {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--brand);
  margin: 0 0 var(--sp-2);
}
.register-pro-card__title {
  font-size: clamp(1.35rem, 3vw, 1.85rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  margin: 0 0 var(--sp-2);
  color: var(--primary);
}
.register-pro-card__lede {
  margin: 0 0 var(--sp-6);
  font-size: var(--text-sm);
  line-height: 1.55;
  color: var(--text-muted);
}
.register-pro-card__progress-track {
  height: 4px;
  border-radius: var(--r-full);
  background: var(--n-200);
  overflow: hidden;
  margin-bottom: var(--sp-4);
}
.register-pro-card__progress-fill {
  height: 100%;
  width: 25%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--brand), var(--brand-teal));
  transition: width 0.35s ease;
}
@media (prefers-reduced-motion: reduce) {
  .register-pro-card__progress-fill {
    transition: none;
  }
}
.register-pro-card__step-labels {
  display: flex;
  justify-content: space-between;
  gap: var(--sp-2);
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: var(--text-xs);
  color: var(--text-muted);
}
.register-pro-card__step-labels li {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex: 1;
  min-width: 0;
  justify-content: center;
  opacity: 0.55;
  transition: opacity 0.2s ease, color 0.2s ease;
}
.register-pro-card__step-labels li.is-done {
  opacity: 0.9;
  color: var(--text);
}
.register-pro-card__step-labels li.is-current {
  opacity: 1;
  color: var(--primary);
  font-weight: 700;
}
.register-pro-card__step-num {
  flex-shrink: 0;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--n-200);
  font-weight: 700;
  font-size: var(--text-xs);
}
.register-pro-card__step-labels li.is-current .register-pro-card__step-num {
  background: var(--brand-light);
  color: var(--brand);
}
.register-pro-card__step-labels li.is-done .register-pro-card__step-num {
  background: var(--green);
  color: transparent;
  font-size: 0;
}
.register-pro-card__step-labels li.is-done .register-pro-card__step-num::before {
  content: '\2713';
  font-size: 0.625rem;
  font-weight: 700;
  color: var(--white);
  line-height: 1;
}
.register-pro-card__step-text {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.register-pro-card__flash {
  margin-bottom: var(--sp-5);
}
.register-pro-card__form {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.register-pro-card__panels {
  flex: 1 1 auto;
  min-height: 0;
}
.register-pro-panel__heading {
  font-size: var(--text-lg);
  font-weight: 700;
  margin: 0;
  color: var(--primary);
}
.register-pro-panel__hint {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.5;
}
/* Uniform vertical rhythm between headings, hints, field groups, and grids.
   Only the visible step: `display:flex` must not apply to [hidden] panels or it overrides the hidden attribute. */
.register-pro-card__panels .register-pro-panel:not([hidden]) {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}
.register-pro-panel__grid {
  display: grid;
  gap: var(--sp-4);
}
@media (min-width: 640px) {
  .register-pro-panel__grid--2 {
    grid-template-columns: 1fr 1fr;
    align-items: end;
  }
}
/* Grid columns are siblings; avoid stacking margin that shifts the second column down. */
.register-pro-card__form .register-pro-panel__grid > .form-group + .form-group {
  margin-top: 0;
}
.register-pro-panel__legal {
  margin-top: 0;
  margin-bottom: 0;
}

.register-pro-password-inline-hint {
  margin: var(--sp-2) 0 0;
  padding: 0;
  font-size: var(--text-xs);
  font-weight: 400;
  color: var(--danger, #b91c1c);
  line-height: 1.35;
}
.register-pro-password-inline-hint[hidden] {
  display: none !important;
}
.register-pro-password-mismatch {
  margin: var(--sp-2) 0 0;
  font-size: var(--text-xs);
  font-weight: 400;
  color: var(--danger, #b91c1c);
  line-height: 1.4;
}
.register-pro-password-mismatch[hidden] {
  display: none !important;
}
.register-pro-input--invalid {
  border-color: var(--danger, #b91c1c);
}

.register-pro-card__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  margin-top: var(--sp-8);
  padding-top: var(--sp-6);
  border-top: 1px solid var(--border);
}
.register-pro-card__actions-primary {
  margin-left: auto;
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  justify-content: flex-end;
  /* One primary control: Continue xor Create account (.btn overrides [hidden] display). */
  min-height: 2.5rem;
}
.register-pro-card__actions-primary > .btn[hidden] {
  display: none !important;
}
.register-pro-card__back.btn {
  border: 1px solid var(--border);
  background: var(--surface);
}
.register-pro-card__next.btn,
.register-pro-card__submit.btn {
  min-width: 10rem;
}
.register-pro-page__login {
  grid-area: login;
  text-align: center;
  margin-top: 0;
  margin-bottom: 0;
  font-size: var(--text-sm);
  color: var(--text-muted);
}
.register-pro-page__login a {
  color: var(--brand);
  font-weight: 600;
  text-decoration: none;
}
.register-pro-page__login a:hover {
  text-decoration: underline;
}

/* ── Panel slide-in animation ───────────────────────────────────────── */
@keyframes rp-panel-in {
  from { opacity: 0; transform: translateX(1rem); }
  to   { opacity: 1; transform: translateX(0); }
}
.register-pro-card__panels .register-pro-panel:not([hidden]) {
  animation: rp-panel-in 0.22s var(--ease, cubic-bezier(0.4, 0, 0.2, 1)) both;
}
@media (prefers-reduced-motion: reduce) {
  .register-pro-card__panels .register-pro-panel:not([hidden]) {
    animation: none;
  }
}

/* ── Password strength meter ─────────────────────────────────────────── */
.register-pro-strength {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-top: var(--sp-2);
}
.register-pro-strength[hidden] {
  display: none !important;
}
.register-pro-strength__bar {
  flex: 1 1 auto;
  height: 4px;
  background: var(--n-200);
  border-radius: var(--r-full);
  overflow: hidden;
}
.register-pro-strength__fill {
  height: 100%;
  width: 0;
  border-radius: inherit;
  background: var(--n-400);
  transition: width 0.3s ease, background-color 0.3s ease;
}
.register-pro-strength__fill.is-weak      { background: var(--red, #dc2626); }
.register-pro-strength__fill.is-fair      { background: var(--amber, #f59e0b); }
.register-pro-strength__fill.is-good      { background: #84cc16; }
.register-pro-strength__fill.is-strong    { background: var(--green, #059669); }
.register-pro-strength__fill.is-very-strong { background: var(--green, #059669); }
.register-pro-strength__label {
  flex-shrink: 0;
  font-size: var(--text-xs);
  font-weight: 600;
  min-width: 5rem;
  text-align: right;
  color: var(--text-muted);
  transition: color 0.2s ease;
}
.register-pro-strength__label.is-weak      { color: var(--red, #dc2626); }
.register-pro-strength__label.is-fair      { color: var(--amber, #f59e0b); }
.register-pro-strength__label.is-good      { color: #65a30d; }
.register-pro-strength__label.is-strong,
.register-pro-strength__label.is-very-strong { color: var(--green, #059669); }

/* ── Submit loading state ────────────────────────────────────────────── */
.register-pro-card__submit.is-loading {
  opacity: 0.75;
  cursor: not-allowed;
  pointer-events: none;
}

.register-pro-page__aside {
  grid-area: aside;
  display: flex;
  flex-direction: column;
  align-self: flex-start;
  position: sticky;
  top: var(--sp-6);
}
.register-pro-aside {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-md);
  padding: var(--sp-8);
  position: relative;
  overflow: hidden;
}
.register-pro-aside::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--brand-teal), var(--brand));
  pointer-events: none;
}
.register-pro-aside__title {
  font-size: var(--text-lg);
  font-weight: 700;
  margin: 0 0 var(--sp-4);
  color: var(--primary);
}
.register-pro-aside__slides {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  padding-right: var(--sp-2);
  margin-right: calc(var(--sp-2) * -1);
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
}
.register-pro-aside__slide {
  padding-bottom: var(--sp-5);
  border-bottom: 1px solid var(--border);
}
.register-pro-aside__slide:last-of-type {
  padding-bottom: 0;
  border-bottom: none;
}
.register-pro-aside__desc {
  margin: 0 0 var(--sp-3);
  font-size: var(--text-sm);
  font-weight: 600;
  line-height: 1.45;
  color: var(--primary);
}
.register-pro-aside__list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.register-pro-aside__list li {
  position: relative;
  padding-left: var(--sp-6);
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--text);
}
.register-pro-aside__list li::before {
  content: '';
  position: absolute;
  left: 0.15rem;
  top: 0.55em;
  width: 6px;
  height: 6px;
  border-radius: var(--r-full);
  background: var(--brand);
  opacity: 0.85;
}
.register-pro-aside__note {
  margin: var(--sp-6) 0 0;
}

/* ═══════════════════════════════════════════════════════════════
   Register Pro Aside — Animated Slideshow  (rpa-*)
   ═══════════════════════════════════════════════════════════════ */
.rpa {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  background: linear-gradient(145deg, #eff6ff 0%, #eef2ff 100%);
  border: 1px solid #dbeafe;
  color: #1e3a8a;
  padding: var(--sp-5);
  border-radius: var(--r-lg);
  position: relative;
  overflow: hidden;
  outline-offset: 3px;
}
/* Decorative accent blob (very subtle) */
.rpa::before {
  content: '';
  position: absolute;
  top: -3rem;
  right: -3rem;
  width: 10rem;
  height: 10rem;
  border-radius: 50%;
  background: rgba(99, 102, 241, 0.06);
  pointer-events: none;
}
.rpa::after {
  content: none;
}

/* ── Header row ─────────────────────────────────────────────── */
.rpa__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative; /* above ::before circle */
  z-index: 1;
}
.rpa__eyebrow {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #6366f1;
}
.rpa__counter {
  font-size: var(--text-xs);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: #93c5fd;
}

/* ── Slide track ─────────────────────────────────────────────── */
.rpa__track {
  position: relative;
  min-height: 11rem;
  z-index: 1;
}
.rpa__slide {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
  opacity: 0;
  transform: translateY(0.75rem);
  transition: opacity 0.4s ease, transform 0.4s ease;
  pointer-events: none;
}
.rpa__slide.is-active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.rpa__slide.is-exit {
  opacity: 0;
  transform: translateY(-1rem);
  transition: opacity 0.38s ease, transform 0.38s ease;
}

/* ── Slide desc ─────────────────────────────────────────────── */
.rpa__desc {
  margin: 0;
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1.4;
  color: #1e3a8a;
}

/* ── Bullet list with staggered entry ───────────────────────── */
.rpa__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.rpa__list li {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-2);
  font-size: 0.8rem;
  line-height: 1.45;
  color: #374151;
  opacity: 0;
  transform: translateX(-0.75rem);
}
.rpa__slide.is-active .rpa__list li {
  animation: rpa-item-in 0.38s cubic-bezier(0.22, 1, 0.36, 1) both;
  animation-delay: calc(var(--rpa-i, 0) * 85ms + 180ms);
}
@keyframes rpa-item-in {
  from { opacity: 0; transform: translateX(-0.75rem); }
  to   { opacity: 1; transform: translateX(0); }
}

/* ── Check icon ─────────────────────────────────────────────── */
.rpa__check {
  flex-shrink: 0;
  width: 0.95rem;
  height: 0.95rem;
  border-radius: 50%;
  background: rgba(99, 102, 241, 0.1);
  border: 1.5px solid rgba(99, 102, 241, 0.35);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 0.15rem;
}
.rpa__check::before {
  content: '';
  display: block;
  width: 4px;
  height: 2.5px;
  border-left: 1.5px solid #6366f1;
  border-bottom: 1.5px solid #6366f1;
  transform: rotate(-45deg) translate(1px, -1px);
}

/* ── Controls row ───────────────────────────────────────────── */
.rpa__controls {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  z-index: 1;
  position: relative;
}
.rpa__nav-btn {
  flex-shrink: 0;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  border: 1px solid #bfdbfe;
  background: rgba(255, 255, 255, 0.7);
  color: #3b82f6;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
  padding: 0;
}
.rpa__nav-btn:hover {
  background: #fff;
  border-color: #93c5fd;
  color: #1d4ed8;
}
.rpa__nav-btn:focus-visible {
  outline: 2px solid #3b82f6;
  outline-offset: 2px;
}

/* ── Auto-advance progress bar ──────────────────────────────── */
.rpa__progress-bar {
  flex: 1 1 auto;
  height: 2px;
  background: #dbeafe;
  border-radius: 999px;
  overflow: hidden;
}
.rpa__progress-fill {
  height: 100%;
  width: 0;
  background: #3b82f6;
  border-radius: inherit;
}

/* ── Footer note ────────────────────────────────────────────── */
.rpa__note {
  margin: 0;
  font-size: var(--text-xs);
  color: #6b7280;
  position: relative;
  z-index: 1;
}
.rpa__note a {
  color: #3b82f6;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.rpa__note a:hover {
  color: #1d4ed8;
}

/* ── Reduced motion ─────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .rpa__slide,
  .rpa__slide.is-exit {
    transition: none;
  }
  .rpa__slide.is-active .rpa__list li {
    animation: none;
    opacity: 1;
    transform: none;
  }
  .rpa__progress-fill {
    transition: none !important;
  }
}

@media (max-width: 960px) {
  .register-pro-page {
    grid-template-columns: 1fr;
    grid-template-areas:
      'main'
      'login'
      'aside';
    gap: var(--sp-8);
    max-width: none;
  }
  .register-pro-page__main {
    position: static;
    top: auto;
    z-index: auto;
  }
  .register-pro-card__actions-primary {
    margin-left: 0;
    width: 100%;
    justify-content: stretch;
  }
  .register-pro-card__next.btn,
  .register-pro-card__submit.btn {
    flex: 1;
    min-width: 0;
  }
}

.form-panel--register {
  max-width: 32rem;
  margin-inline: auto;
  padding: var(--sp-6) var(--sp-8);
}
.form-panel--register .register-form__intro {
  margin-top: var(--sp-2);
  margin-bottom: var(--sp-6);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.form-panel--register .register-form__intro .meta {
  margin: 0;
  line-height: 1.55;
  max-width: none;
}
.form-panel--register .form-control,
.form-panel--register input.form-control {
  max-width: 100%;
}
.form-panel--register .register-form__password-hint {
  margin-top: var(--sp-2);
}
.form-panel--register #block_terms_private {
  margin-top: var(--sp-6);
}
.form-panel--register .register-form__terms-label {
  text-transform: none;
  letter-spacing: normal;
  font-weight: 500;
  font-size: var(--text-sm);
  line-height: 1.45;
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  cursor: pointer;
}
.form-panel--register .register-form__terms-label input[type='checkbox'] {
  margin-top: 0.2em;
  flex-shrink: 0;
}
.form-panel--register .register-form__submit {
  margin-top: var(--sp-5);
  width: 100%;
}
.form-panel--register .register-form__login {
  margin-top: var(--sp-8);
  margin-bottom: 0;
  text-align: center;
}
.form-row       { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 10rem), 1fr)); gap: var(--sp-4); }
/* /search: keep City / State / ZIP, date range, and distance + status on fixed rows (overrides generic .form-row at narrow widths) */
.search-filters .form-row.search-filters__row--keyword {
  grid-template-columns: minmax(0, 1fr);
}
.search-filters .form-row.search-filters__row--location {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.search-filters .form-row.search-filters__row--dates,
.search-filters .form-row.search-filters__row--distance-status {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.form-group     { display: flex; flex-direction: column; gap: 0; }
/* Field labels: screen-reader only when not wrapping a control; use placeholder on inputs or aria-label. */
.form-group > label:not(:has(input)):not(.register-form__terms-label):not(.keep-field-label),
.form-row > label:not(:has(input)):not(.keep-field-label) {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
  clip-path: inset(50%);
}
.form-group label:has(input[type='checkbox']),
.form-group label:has(input[type='radio']),
.form-group > .register-form__terms-label,
.form-group.estate-contract-execution-page__pill-check > label,
label.keep-field-label {
  position: static;
  width: auto;
  height: auto;
  margin: 0;
  overflow: visible;
  clip: auto;
  white-space: normal;
  clip-path: none;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text);
  text-transform: none;
  letter-spacing: normal;
}
.form-control, input:not([type='submit']):not([type='button']):not([type='checkbox']):not([type='radio']):not([type='range']):not([type='file']):not(.lp-search-input):not(.pos-search-input):not(.pos-custom-select__filter-input):not(.es-custom-select__filter-input):not(.shopper-keyword-tags__input), select { display: block; width: 100%; height: 2.75rem; padding-inline: var(--sp-3); border: 1.5px solid var(--border); border-radius: var(--r-sm); background: var(--white); color: var(--text); font-size: var(--text-sm); appearance: none; transition: border-color var(--dur-sm) var(--ease), box-shadow var(--dur-sm) var(--ease); }
textarea { width: 100%; min-height: 8rem; padding: var(--sp-3); border: 1.5px solid var(--border); border-radius: var(--r-sm); background: var(--white); color: var(--text); font-size: var(--text-sm); resize: vertical; }
.form-control:focus, input:not([type='range']):not([type='file']):not(.pos-search-input):not(.pos-custom-select__filter-input):not(.es-custom-select__filter-input):not(.shopper-keyword-tags__input):focus, select:focus, textarea:focus { outline: none; border-color: var(--brand); box-shadow: 0 0 0 3px var(--brand-light); }
input::placeholder, textarea::placeholder { color: var(--n-400); }
.form-actions { display: flex; justify-content: flex-end; gap: var(--sp-3); padding-top: var(--sp-4); border-top: 1px solid var(--border); margin-top: var(--sp-6); }

/* ---- es-custom-select: HTML5-style combobox (add class js-es-custom-select to <select>) -- */
.es-custom-select {
  position: relative;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
.es-custom-select__native.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
  clip-path: inset(50%);
}
.es-custom-select__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  width: 100%;
  max-width: 100%;
  min-height: 2.75rem;
  padding: 0 var(--sp-3);
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--white);
  color: var(--text);
  font-size: var(--text-sm);
  font-weight: 500;
  font-family: inherit;
  text-align: left;
  cursor: pointer;
  box-sizing: border-box;
  transition: border-color var(--dur-sm) var(--ease), box-shadow var(--dur-sm) var(--ease), background var(--dur-sm) var(--ease);
}
.es-custom-select__trigger:hover:not(:disabled) {
  border-color: var(--n-300);
  background: var(--n-50);
}
.es-custom-select__trigger:focus {
  outline: none;
  border-color: var(--brand);
  box-shadow: 0 0 0 3px var(--brand-light);
}
.es-custom-select__trigger:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  background: var(--n-100);
}
.es-custom-select--open .es-custom-select__trigger {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px var(--brand-light);
}
.es-custom-select--invalid .es-custom-select__trigger {
  border-color: var(--red);
  box-shadow: 0 0 0 3px var(--red-bg);
}
.es-custom-select__value {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.35;
}
.es-custom-select__caret {
  flex-shrink: 0;
  display: flex;
  color: var(--n-500);
  transition: transform var(--dur-sm) var(--ease);
}
.es-custom-select--open .es-custom-select__caret {
  transform: rotate(180deg);
  color: var(--brand);
}
.es-custom-select__dropdown {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 4px);
  z-index: 50;
  max-height: min(18rem, 52vh);
  overflow: hidden;
  border-radius: var(--r-sm);
  border: 1.5px solid var(--border);
  background: var(--surface);
  box-shadow: none;
}
.es-custom-select__dropdown:not([hidden]) {
  display: flex;
  flex-direction: column;
}
.es-custom-select__filter {
  flex-shrink: 0;
  padding: var(--sp-2);
  border-bottom: 1px solid var(--border);
  background: var(--n-50);
}
.es-custom-select__filter-field {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  min-height: 2.25rem;
  padding: 0 var(--sp-2);
  border: 1.5px solid var(--border);
  border-radius: var(--r-xs);
  background: var(--white);
  transition: border-color var(--dur-sm) var(--ease), box-shadow var(--dur-sm) var(--ease);
}
.es-custom-select__filter-field:focus-within {
  border-color: var(--brand);
  box-shadow: 0 0 0 2px var(--brand-light);
}
.es-custom-select__filter-icon {
  display: flex;
  flex-shrink: 0;
  color: var(--n-400);
  pointer-events: none;
}
.es-custom-select__filter-input {
  flex: 1;
  min-width: 0;
  height: 2rem;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  color: var(--primary);
  font-size: var(--text-sm);
  font-weight: 500;
  font-family: inherit;
  appearance: none;
  box-shadow: none;
}
.es-custom-select__filter-input:focus {
  outline: none;
}
.es-custom-select__empty {
  margin: 0;
  padding: var(--sp-3);
  font-size: var(--text-xs);
  color: var(--text-muted);
  text-align: center;
}
.es-custom-select__listbox {
  list-style: none;
  margin: 0;
  padding: var(--sp-1);
  overflow-y: auto;
  flex: 1;
  min-height: 0;
  max-height: min(14rem, 40vh);
  scrollbar-width: thin;
}
.es-custom-select__option {
  margin: 0;
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-xs);
  font-size: var(--text-sm);
  cursor: pointer;
  line-height: 1.35;
}
.es-custom-select__option:hover:not(.es-custom-select__option--disabled) {
  background: var(--n-50);
}
.es-custom-select__option--active:not(.es-custom-select__option--disabled) {
  background: var(--brand-light);
  outline: none;
}

/* POS register: structured pos-sale layout (data-es-option-layout + data-es-* on options) */
.pos-sale-pick-custom-select .es-custom-select__trigger {
  align-items: flex-start;
  min-height: 2.75rem;
  padding-block: var(--sp-2);
}
.pos-sale-pick-custom-select .es-custom-select__caret {
  align-self: flex-start;
  margin-top: 0.15rem;
}
.pos-sale-pick-custom-select .es-custom-select__value.es-custom-select__value--pos-sale {
  display: block;
  width: 100%;
  min-width: 0;
  overflow: hidden;
  white-space: normal;
  text-overflow: unset;
  line-height: 1.4;
  text-align: left;
}
.pos-sale-pick-custom-select .es-custom-select__pos-sale-row1 {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-2);
  width: 100%;
  min-width: 0;
}
.pos-sale-pick-custom-select .es-custom-select__pos-sale-title {
  font-weight: 700;
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pos-sale-pick-custom-select .es-custom-select__pos-sale-est {
  flex: 0 1 auto;
  max-width: 42%;
  text-align: right;
  color: var(--green);
  font-weight: 600;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.pos-sale-pick-custom-select .es-custom-select__pos-sale-meta {
  font-size: var(--text-xs);
  color: var(--text-muted);
  line-height: 1.4;
  margin-top: 0.12rem;
}
.pos-sale-pick-custom-select .es-custom-select__dropdown {
  max-height: min(32rem, 65vh);
}
.pos-sale-pick-custom-select .es-custom-select__listbox {
  max-height: min(28rem, 58vh);
}
.pos-sale-pick-custom-select .es-custom-select__option--pos-sale {
  white-space: normal;
  line-height: 1.4;
  padding-block: var(--sp-3);
  font-size: var(--text-xs);
}

/* POS register: category picker (data-es-option-layout="pos-category") */
.pos-category-pick-custom-select .es-custom-select__trigger {
  align-items: center;
  min-height: 2.75rem;
}
.pos-category-pick-custom-select .es-custom-select__value.es-custom-select__value--pos-category {
  display: block;
  width: 100%;
  min-width: 0;
  overflow: hidden;
  white-space: normal;
  text-overflow: unset;
  line-height: 1.35;
  text-align: left;
}
.pos-category-pick-custom-select .es-custom-select__pos-cat-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  width: 100%;
  min-width: 0;
}
.pos-category-pick-custom-select .es-custom-select__pos-cat-title {
  font-weight: 600;
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pos-category-pick-custom-select .es-custom-select__pos-cat-count {
  flex-shrink: 0;
  color: var(--text-muted);
  font-size: var(--text-sm);
  font-weight: 500;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.pos-category-pick-custom-select .es-custom-select__option--pos-category {
  white-space: normal;
  line-height: 1.4;
  padding-block: var(--sp-2);
}

.es-custom-select__option--disabled {
  opacity: 0.45;
  cursor: not-allowed;
}
.es-custom-select__option[aria-hidden='true'] {
  display: none;
}

/* POS dashboard receipt: breadcrumbs + share row */
.pos-receipt__pagehead {
  margin-bottom: var(--sp-4);
}
.pos-receipt__title-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2) var(--sp-4);
}
.pos-receipt__title {
  margin: 0;
  font-size: clamp(1.35rem, 2.2vw, 1.8rem);
  line-height: 1.2;
}
.pos-receipt__title-row .pos-receipt__share-actions {
  margin-left: auto;
}
.pos__select-sale-breadcrumbs {
  padding: var(--sp-3) var(--sp-5) 0;
  max-width: var(--pos-shell-max-width, 72rem);
  margin-inline: auto;
}
.pos__select-sale-breadcrumbs .config-settings-page__breadcrumbs,
.pos__select-sale-breadcrumbs .dh-breadcrumb {
  margin-bottom: var(--sp-3);
}
.pos-receipt__share-actions {
  display: inline-flex;
  gap: var(--sp-2);
  align-items: center;
}
.pos-receipt__share-btn svg {
  display: block;
}
.pos-receipt__back-link {
  margin: 0 0 var(--sp-4);
}
.pos-receipt__resume-action {
  margin: 0 0 var(--sp-4);
}
.pos-receipt__section {
  margin-top: var(--sp-6);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--border);
}
.pos-receipt__section-title {
  margin: 0 0 var(--sp-4);
  font-size: var(--text-lg);
}
.pos-receipt__kv-grid {
  display: grid;
  gap: var(--sp-2);
  margin: 0;
}
.pos-receipt__kv-row {
  display: grid;
  grid-template-columns: minmax(7.5rem, 11rem) minmax(0, 1fr);
  gap: var(--sp-3);
  align-items: start;
}
.pos-receipt__kv-row dt {
  margin: 0;
  color: var(--n-500);
}
.pos-receipt__kv-row dd {
  margin: 0;
}
.pos-receipt__table-wrap {
  overflow-x: auto;
}
.pos-receipt__totals {
  margin: var(--sp-4) 0 0;
  max-width: 22rem;
}
.pos-receipt__totals-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--sp-3);
  margin: 0 0 var(--sp-2);
}
.pos-receipt__totals-row dt,
.pos-receipt__totals-row dd {
  margin: 0;
}
.pos-receipt__totals-row--grand {
  margin-top: var(--sp-3);
  padding-top: var(--sp-2);
  border-top: 1px solid var(--border);
  font-weight: 700;
}
.pos-receipt__actions-grid {
  display: grid;
  gap: var(--sp-4);
  grid-template-columns: repeat(auto-fit, minmax(18rem, 1fr));
}
.pos-receipt__action-form {
  margin: 0;
}
.pos-receipt__action-form .form-group {
  margin-bottom: var(--sp-3);
}
@media (max-width: 700px) {
  .pos-receipt__kv-row {
    grid-template-columns: 1fr;
    gap: var(--sp-1);
  }
}

/* ---- User sale create/edit (extra vertical rhythm) ------------------------ */
.form-panel.sale-form {
  max-width: 44rem;
}
.main.shell > .form-panel.sale-form {
  max-width: var(--pos-shell-max-width);
}
/* Sale edit: widen panel when photo gallery is present */
.form-panel.sale-form:has(.sale-form__photo-gallery--wide) {
  max-width: min(calc(100vw - 2rem), var(--pos-shell-max-width));
}
.form-panel.sale-form .config-settings-page__breadcrumbs,
.form-panel.sale-form .dh-breadcrumb {
  margin: 0 0 var(--sp-4);
}
.form-panel.sale-form > p.meta {
  margin: 0 0 var(--sp-7);
  line-height: 1.5;
}
.form-panel.sale-form > form > .form-group {
  margin-bottom: var(--sp-7);
  gap: var(--sp-3);
}
.form-panel.sale-form > form > .form-group:last-of-type {
  margin-bottom: var(--sp-5);
}
.form-panel.sale-form > form > .form-row {
  margin-bottom: var(--sp-2);
  gap: var(--sp-5);
  align-items: start;
}
.form-panel.sale-form .form-section .form-group,
.form-panel.sale-form .item-edit-form .form-group {
  margin-bottom: var(--sp-3);
  gap: var(--sp-2);
}
.form-panel.sale-form .form-section {
  margin-top: var(--sp-8);
  padding-top: var(--sp-6);
  border-top: 1px solid var(--border);
}
.form-panel.sale-form .form-section h3,
.form-panel.sale-form .form-section h4 {
  margin-top: var(--sp-5);
  margin-bottom: var(--sp-3);
}
.form-panel.sale-form .item-edit-card {
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-5);
  border-bottom: 1px solid var(--n-100);
}
.form-panel.sale-form .sale-form__photo-gallery {
  margin-top: var(--sp-8);
  padding-top: var(--sp-6);
  border-top: 1px solid var(--border);
}
.form-panel.sale-form > form > .btn-primary,
.form-panel.sale-form > form > .btn[href] {
  margin-top: var(--sp-2);
}
.sale-form__input-overlay-wrap {
  position: relative;
  width: 100%;
}
.sale-form__input-overlay-wrap .form-control {
  padding-inline-end: 2.85rem;
}
.sale-form__input-overlay-wrap--textarea .form-control {
  padding-top: 2.5rem;
}
.sale-form__ai-brain {
  position: absolute;
  z-index: 2;
  right: var(--sp-2);
  top: 50%;
  transform: translateY(-50%);
  width: 2.35rem;
  height: 2.35rem;
  padding: 0;
  margin: 0;
  border: none;
  border-radius: var(--r-sm);
  background: transparent;
  box-shadow: none;
  cursor: pointer;
  font-size: 1.2rem;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--dur-sm) var(--ease), opacity var(--dur-sm) var(--ease);
}
.sale-form__input-overlay-wrap--textarea .sale-form__ai-brain {
  top: var(--sp-2);
  transform: none;
}
.sale-form__ai-brain:hover {
  background: var(--brand-light);
}
.sale-form__ai-brain:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}
.sale-form__ai-brain:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}
.sale-form__ai-progress-wrap {
  margin-top: var(--sp-4);
  max-width: min(28rem, 100%);
}
.sale-form__ai-progress-wrap[hidden] {
  display: none !important;
}
.sale-form__ai-progress-label {
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--n-500);
  margin-bottom: var(--sp-2);
}
.sale-form__ai-progress-track {
  position: relative;
  height: 0.5rem;
  border-radius: var(--r-full);
  background: var(--n-100);
  overflow: hidden;
  box-shadow: none;
}
.sale-form__ai-progress-bar {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 38%;
  border-radius: var(--r-full);
  background: var(--brand-gradient);
  box-shadow: none;
  animation: sale-form-ai-progress-move 1.25s cubic-bezier(0.45, 0, 0.55, 1) infinite;
}
.sale-form__ai-progress-bar--lag {
  width: 32%;
  opacity: 0.55;
  animation-delay: -0.35s;
  filter: saturate(1.1);
}
@keyframes sale-form-ai-progress-move {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(320%);
  }
}
@media (prefers-reduced-motion: reduce) {
  .sale-form__ai-progress-bar {
    animation: none;
    width: 100%;
    opacity: 0.35;
    transform: none;
  }
  .sale-form__ai-progress-bar--lag {
    display: none;
  }
}
.sale-form__ai-status {
  margin: var(--sp-3) 0 0;
  min-height: 1.25em;
  line-height: 1.45;
  color: var(--n-600);
  font-size: var(--text-sm);
}
.sale-form__ai-hint {
  margin: var(--sp-3) 0 0;
  max-width: 40rem;
  line-height: 1.5;
}
.sale-form__ai-hint code {
  font-size: 0.85em;
  padding: 0.1em 0.35em;
  border-radius: var(--r-sm);
  background: var(--n-100);
}

/* ---- Private listing wizard (pl-wizard) ----------------------------------- */
/* Same max width on every step (private + post-sale) — matches dashboard form column */
.pl-wizard {
  max-width: var(--dashboard-form-panel-max);
  width: 100%;
  margin-inline: auto;
  padding: var(--sp-8);
  border-radius: var(--r-xl);
  box-shadow: var(--shadow-lg);
  border: none;
  background: var(--white);
}
/* Listing wizards use visible <label for="…"> or .keep-field-label (see global sr-only labels). Fallback undo if class missing. */
.pl-wizard .form-group > label:not(.pl-wizard__check-label),
.pl-wizard .form-row > label:not(.pl-wizard__check-label) {
  position: static;
  width: auto;
  height: auto;
  padding: 0;
  margin: 0;
  overflow: visible;
  clip: auto;
  white-space: normal;
  clip-path: none;
  border: 0;
  text-transform: none;
  letter-spacing: normal;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--n-700);
}
.pl-wizard label.keep-field-label:not(.pl-wizard__check-label) {
  font-weight: 600;
  color: var(--n-700);
}
.pl-wizard__control-label {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--n-700);
}
.pl-wizard__control-label--spaced {
  margin-top: var(--sp-5);
}
.pl-wizard__header {
  margin-bottom: var(--sp-8);
  padding-bottom: var(--sp-6);
  border-bottom: 1px solid var(--border);
}
.pl-wizard__title {
  font-size: clamp(var(--text-2xl), 3vw, var(--text-3xl));
  margin: 0 0 var(--sp-3);
  letter-spacing: -0.03em;
}
.pl-wizard__lead {
  margin: 0;
  color: var(--text-muted);
  font-size: var(--text-base);
  line-height: 1.55;
}
.pl-wizard__form .form-group {
  margin-bottom: var(--sp-5);
}
.pl-wizard__form .form-group:last-child {
  margin-bottom: 0;
}
.pl-wizard__section {
  margin-bottom: var(--sp-8);
  padding: var(--sp-6);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-xs);
}
.pl-wizard__section-title {
  font-size: var(--text-xs);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--brand);
  margin: 0 0 var(--sp-5);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--n-100);
}
.pl-wizard__fields {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.pl-wizard__input--compact {
  width: min(100%, 7.5rem);
  align-self: flex-start;
}
.pl-wizard__form .form-control.pl-wizard__input--compact {
  width: 7.5rem;
  max-width: 7.5rem;
}
.pl-wizard__row-2 {
  display: grid;
  gap: var(--sp-4);
  grid-template-columns: 1fr;
}
@media (min-width: 640px) {
  .pl-wizard__row-2 {
    grid-template-columns: 1fr 1fr;
  }
}
.pl-wizard__readonly-field {
  background: var(--n-50);
  color: var(--n-700);
  cursor: default;
}

/* Private listing: Quill description (step 2) */
.pl-wysiwyg-label {
  display: block;
  margin-bottom: var(--sp-2);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--n-700);
}
.pl-wysiwyg-wrap .ql-toolbar.ql-snow {
  border: 1px solid var(--border);
  border-radius: var(--r) var(--r) 0 0;
  background: var(--white);
  font-family: inherit;
  flex-wrap: wrap;
}
.pl-wysiwyg-wrap .ql-container.ql-snow {
  border: 1px solid var(--border);
  border-top: none;
  border-radius: 0 0 var(--r) var(--r);
  font-size: var(--text-base);
}
.pl-wysiwyg-wrap .ql-editor {
  min-height: 16rem;
}
/* Quill Snow sets p/h margins to 0; without this, multiple <p> (e.g. from AI) look like one block */
.pl-wysiwyg-wrap .ql-editor p {
  margin: 0 0 var(--sp-4) 0;
}
.pl-wysiwyg-wrap .ql-editor p:last-child {
  margin-bottom: 0;
}
.pl-wysiwyg-wrap .ql-editor h1,
.pl-wysiwyg-wrap .ql-editor h2,
.pl-wysiwyg-wrap .ql-editor h3,
.pl-wysiwyg-wrap .ql-editor h4 {
  margin: 0 0 var(--sp-3) 0;
  font-weight: 600;
}
.pl-wysiwyg-wrap .ql-editor h1:last-child,
.pl-wysiwyg-wrap .ql-editor h2:last-child,
.pl-wysiwyg-wrap .ql-editor h3:last-child,
.pl-wysiwyg-wrap .ql-editor h4:last-child {
  margin-bottom: 0;
}
.pl-wysiwyg-wrap .ql-editor blockquote {
  margin: 0 0 var(--sp-4) 0;
  padding-left: 1em;
  border-left: 3px solid var(--border);
}
.pl-wysiwyg-wrap .ql-editor ol,
.pl-wysiwyg-wrap .ql-editor ul {
  margin: 0 0 var(--sp-4) 0;
  padding-left: 1.25em;
}
.pl-wysiwyg-wrap .ql-editor.ql-blank::before {
  color: var(--n-400);
  font-style: normal;
}
.ql-font-arial { font-family: Arial, Helvetica, sans-serif; }
.ql-font-georgia { font-family: Georgia, 'Times New Roman', serif; }
.ql-font-times-new-roman { font-family: 'Times New Roman', Times, serif; }
.ql-font-verdana { font-family: Verdana, Geneva, sans-serif; }
.ql-font-tahoma { font-family: Tahoma, Geneva, sans-serif; }
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='arial']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='arial']::before {
  content: 'Arial';
  font-family: Arial, Helvetica, sans-serif;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='georgia']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='georgia']::before {
  content: 'Georgia';
  font-family: Georgia, serif;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='times-new-roman']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='times-new-roman']::before {
  content: 'Times New Roman';
  font-family: 'Times New Roman', Times, serif;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='verdana']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='verdana']::before {
  content: 'Verdana';
  font-family: Verdana, Geneva, sans-serif;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='tahoma']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='tahoma']::before {
  content: 'Tahoma';
  font-family: Tahoma, Geneva, sans-serif;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='sans-serif']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='sans-serif']::before {
  content: 'Sans serif';
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='serif']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='serif']::before {
  content: 'Serif';
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='monospace']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='monospace']::before {
  content: 'Monospace';
}

/* Additional Quill font stacks (editor + rendered description_html) */
.ql-font-open-sans { font-family: 'Open Sans', Arial, Helvetica, sans-serif; }
.ql-font-lato { font-family: Lato, Arial, Helvetica, sans-serif; }
.ql-font-source-sans-3 { font-family: 'Source Sans 3', 'Source Sans Pro', Arial, sans-serif; }
.ql-font-dm-sans { font-family: 'DM Sans', Arial, Helvetica, sans-serif; }
.ql-font-merriweather { font-family: Merriweather, Georgia, serif; }
.ql-font-libre-baskerville { font-family: 'Libre Baskerville', Georgia, serif; }
.ql-font-playfair-display { font-family: 'Playfair Display', Georgia, serif; }
.ql-font-roboto-slab { font-family: 'Roboto Slab', Georgia, serif; }
.ql-font-courier-new { font-family: 'Courier New', Courier, monospace; }
.ql-font-trebuchet-ms { font-family: 'Trebuchet MS', Helvetica, sans-serif; }
.ql-font-palatino-linotype { font-family: 'Palatino Linotype', Palatino, 'Book Antiqua', serif; }
.ql-font-impact { font-family: Impact, Haettenschweiler, 'Arial Narrow Bold', sans-serif; }
.ql-font-comic-sans-ms { font-family: 'Comic Sans MS', 'Comic Sans', cursive, sans-serif; }
.ql-font-lucida-sans { font-family: 'Lucida Sans Unicode', 'Lucida Grande', 'Lucida Sans', Geneva, sans-serif; }

.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='open-sans']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='open-sans']::before {
  content: 'Open Sans';
  font-family: 'Open Sans', sans-serif;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='lato']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='lato']::before {
  content: 'Lato';
  font-family: Lato, sans-serif;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='source-sans-3']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='source-sans-3']::before {
  content: 'Source Sans 3';
  font-family: 'Source Sans 3', sans-serif;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='dm-sans']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='dm-sans']::before {
  content: 'DM Sans';
  font-family: 'DM Sans', sans-serif;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='merriweather']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='merriweather']::before {
  content: 'Merriweather';
  font-family: Merriweather, serif;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='libre-baskerville']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='libre-baskerville']::before {
  content: 'Libre Baskerville';
  font-family: 'Libre Baskerville', serif;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='playfair-display']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='playfair-display']::before {
  content: 'Playfair Display';
  font-family: 'Playfair Display', serif;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='roboto-slab']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='roboto-slab']::before {
  content: 'Roboto Slab';
  font-family: 'Roboto Slab', serif;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='courier-new']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='courier-new']::before {
  content: 'Courier New';
  font-family: 'Courier New', monospace;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='trebuchet-ms']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='trebuchet-ms']::before {
  content: 'Trebuchet MS';
  font-family: 'Trebuchet MS', sans-serif;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='palatino-linotype']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='palatino-linotype']::before {
  content: 'Palatino';
  font-family: 'Palatino Linotype', Palatino, serif;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='impact']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='impact']::before {
  content: 'Impact';
  font-family: Impact, sans-serif;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='comic-sans-ms']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='comic-sans-ms']::before {
  content: 'Comic Sans MS';
  font-family: 'Comic Sans MS', cursive;
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value='lucida-sans']::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value='lucida-sans']::before {
  content: 'Lucida Sans';
  font-family: 'Lucida Sans Unicode', 'Lucida Grande', sans-serif;
}

.pl-wizard__hint--tight {
  margin-top: var(--sp-2);
}
.pl-wizard__reveal-max-note {
  display: block;
  margin: var(--sp-2) 0 0;
  font-size: var(--text-xs, 0.75rem);
  line-height: 1.4;
  color: #b91c1c;
}
.pl-wizard__reveal-when {
  display: block;
  margin: var(--sp-2) 0 0;
  max-width: 40rem;
  font-size: var(--text-xs, 0.75rem);
  line-height: 1.45;
  color: #b91c1c;
}
.pl-wizard__day-markdown-note {
  display: block;
  margin: var(--sp-2) 0 0;
  max-width: 40rem;
  font-size: var(--text-xs, 0.75rem);
  line-height: 1.45;
  color: #b91c1c;
}
.pl-wizard__estate-link-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: var(--sp-4) var(--sp-6);
}
.pl-wizard__estate-link-row__field {
  flex: 1 1 12rem;
  min-width: min(100%, 12rem);
}
.pl-wizard__estate-link-row__action {
  flex: 0 0 auto;
  padding-bottom: 0.125rem;
}
.pl-wizard__estate-link-row__action .btn {
  white-space: nowrap;
}
.pl-wizard__estate-link-field-group {
  margin-bottom: 0;
}
.pl-wizard__hint {
  margin: calc(-1 * var(--sp-2)) 0 var(--sp-4);
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.45;
}
.pl-wizard__mp-hint-link {
  display: inline-flex;
  align-items: center;
  gap: 0.25em;
  white-space: nowrap;
  font-weight: 600;
  color: var(--link, var(--primary));
  text-decoration: underline;
  text-underline-offset: 0.12em;
}
.pl-wizard__mp-hint-link svg {
  flex-shrink: 0;
  vertical-align: middle;
}

/* Analysis step: full-screen save overlay (Save and Continue) */
.pl-wizard-saving-overlay {
  position: fixed;
  inset: 0;
  z-index: 20000;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(15, 15, 15, 0.45);
  backdrop-filter: blur(2px);
}
.pl-wizard-saving-overlay[hidden] {
  display: none !important;
}
.pl-wizard-saving-overlay__panel {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-8) var(--sp-10);
  background: var(--white, #fff);
  border: 1px solid var(--border, #e5e5e5);
  border-radius: var(--r, 8px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15);
  max-width: 90vw;
}
.pl-wizard-saving-overlay__text {
  margin: 0;
  font-size: var(--text-base, 1rem);
  font-weight: 600;
  color: var(--text, #0a0a0a);
}
.pl-wizard-saving-spinner {
  display: block;
  width: 2.25rem;
  height: 2.25rem;
  border: 3px solid var(--border, #e5e5e5);
  border-top-color: var(--primary, #2563eb);
  border-radius: 50%;
  animation: pl-wizard-saving-spin 0.75s linear infinite;
}
@keyframes pl-wizard-saving-spin {
  to {
    transform: rotate(360deg);
  }
}
.sale-wizard-title-field__counter {
  margin-top: var(--sp-2);
  margin-bottom: var(--sp-4);
}
.pl-wizard__ai-context-hint {
  margin-top: var(--sp-2);
  margin-bottom: 0;
}
.pl-wizard__checkbox-only {
  margin-bottom: var(--sp-4);
}
.pl-wizard__check-label {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text);
  text-transform: none;
  letter-spacing: normal;
  cursor: pointer;
  line-height: 1.45;
}
.pl-wizard__check-label input {
  margin-top: 0.2em;
  flex-shrink: 0;
  width: 1.1rem;
  height: 1.1rem;
}
.pl-wizard__mp-toggles {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.pl-wizard__conditional {
  padding-top: var(--sp-2);
  margin-bottom: var(--sp-2);
}
.pl-wizard__conditional[hidden] {
  display: none !important;
}
.pl-wizard__textarea.form-control {
  min-height: 6.5rem;
  height: auto;
  padding-block: var(--sp-3);
  line-height: 1.5;
  resize: vertical;
}
.pl-wizard__textarea--tall.form-control {
  min-height: 14rem;
}
.pl-wizard__actions {
  margin-top: var(--sp-8);
  padding-top: var(--sp-6);
  border-top: 1px solid var(--border);
}
.pl-wizard__actions--row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  align-items: center;
}
.pl-wizard__actions--split {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
}
.pl-wizard__actions__right {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  align-items: center;
  justify-content: flex-end;
}
.pl-wizard__actions--three {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: space-between;
  gap: var(--sp-3);
}
.pl-wizard__actions--three > .btn {
  flex: 1 1 10rem;
  justify-content: center;
  text-align: center;
}
.pl-wizard__save-continue--disabled {
  opacity: 0.55;
  filter: saturate(0.65);
}
.pl-wizard__actions--three > form.pl-wizard__inline-form {
  display: flex;
  flex: 1 1 10rem;
  margin: 0;
}
.pl-wizard__actions--three > form.pl-wizard__inline-form .btn {
  flex: 1;
  width: 100%;
  justify-content: center;
}
.pl-wizard__ai-submit-row {
  margin-top: var(--sp-4);
}
.pl-wizard__schedule-add-row {
  display: flex;
  justify-content: flex-end;
  width: 100%;
  margin-top: var(--sp-6);
}
.pl-wizard__schedule-add {
  background: var(--green);
  border-color: var(--green);
  color: #fff;
}
.pl-wizard__schedule-add:hover:not(:disabled) {
  background: #047857;
  border-color: #047857;
  color: #fff;
  box-shadow: none;
}
.pl-wizard__schedule-add:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  box-shadow: none;
}
.pl-wizard-ai-modal {
  position: fixed;
  inset: 0;
  z-index: 10050;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-4);
  box-sizing: border-box;
}
.pl-wizard-ai-modal[hidden] {
  display: none !important;
}
.pl-wizard-ai-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.5);
}
.pl-wizard-ai-modal__panel {
  position: relative;
  z-index: 1;
  max-width: 22rem;
  width: 100%;
  padding: var(--sp-6);
  background: var(--surface);
  border-radius: var(--r-lg);
  box-shadow: none;
  border: 1px solid var(--border);
}
.pl-wizard-ai-modal__title {
  margin: 0 0 var(--sp-4);
  font-size: var(--text-base);
  font-weight: 600;
  line-height: 1.45;
  color: var(--text);
}
.pl-wizard-ai-modal__progress {
  margin: 0;
}
.pl-wizard-ai-modal__progress .sale-form__ai-progress-track {
  max-width: 100%;
}
.pl-wizard__map-section {
  margin-top: var(--sp-10);
  padding-top: var(--sp-8);
  border-top: 1px solid var(--border);
}
/* Map block directly under ZIP (inside location fields) */
.pl-wizard__map-section--in-form {
  margin-top: var(--sp-6);
  padding-top: var(--sp-6);
}
.pl-wizard__map-section .pl-wizard__section-title {
  margin-bottom: var(--sp-4);
  border-bottom: none;
  padding-bottom: 0;
}
/* Google Places: z-index alone cannot sit above native <dialog showModal> (top layer). */
/* Shopper signup reparents .pac-container onto #shopper-signup-dialog and pins it with */
/* position:fixed + street input getBoundingClientRect() in sale/show.php. */
/* Shopper profile modal: same reparent onto #shopper-profile-dialog in shopper-profile-modal.js. */
.pac-container {
  z-index: 2147483647;
}

.pl-wizard__map-section .map-embed {
  display: block;
  width: 100%;
  min-height: 16rem;
  height: 18rem;
  border: 0;
  border-radius: var(--r-md);
  box-shadow: var(--shadow-sm);
}

.pl-wizard-nav {
  margin: calc(-1 * var(--sp-2)) 0 var(--sp-8);
}
/* Stable header: back (start) | title (center) | preview/extra (end) — no flex-wrap stagger */
.pl-wizard-nav__top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  gap: var(--sp-2) var(--sp-3);
  margin-bottom: var(--sp-4);
  min-height: 2.75rem;
}
.pl-wizard-nav__link--back {
  justify-self: start;
  grid-column: 1;
  color: var(--n-600);
}
.pl-wizard-nav__brand {
  grid-column: 2;
  justify-self: center;
  text-align: center;
  max-width: min(100%, 20rem);
  font-size: clamp(1.05rem, 2.2vw, 1.3rem);
  font-weight: 800;
  text-transform: none;
  letter-spacing: -0.02em;
  color: var(--primary);
  line-height: 1.2;
}
.pl-wizard-nav__top > .pl-wizard-nav__link:not(.pl-wizard-nav__link--back) {
  grid-column: 3;
  justify-self: end;
  text-align: right;
}
.pl-wizard-nav__link {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--brand);
  text-decoration: none;
  padding-block: var(--sp-1);
  min-height: 2.25rem;
  display: inline-flex;
  align-items: center;
}
.pl-wizard-nav__link:hover {
  text-decoration: underline;
}
.pl-wizard-progress {
  width: 100%;
}
.pl-wizard-progress__track {
  height: 4px;
  background: var(--n-200);
  border-radius: var(--r-full);
  overflow: hidden;
  margin-bottom: var(--sp-4);
}
.pl-wizard-progress__fill {
  height: 100%;
  background: var(--brand-gradient);
  border-radius: var(--r-full);
  transition: width 280ms var(--ease);
}
/* One even row of six steps — avoids flex-wrap / space-between stagger on phones */
.pl-wizard-steps {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: var(--sp-2) clamp(0.125rem, 1.2vw, var(--sp-3));
  width: 100%;
}
.pl-wizard-steps__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-1);
  min-width: 0;
  text-align: center;
  opacity: 0.45;
}
/* Dim only step labels; keep checkmark dots full-strength green */
.pl-wizard-steps__item.is-past .pl-wizard-steps__name {
  opacity: 0.75;
}
.pl-wizard-steps__item.is-current {
  opacity: 1;
}
.pl-wizard-steps__link {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-1);
  min-width: 0;
  width: 100%;
  text-align: center;
  text-decoration: none;
  color: inherit;
  border-radius: var(--r);
}
.pl-wizard-steps__link:hover {
  text-decoration: none;
}
.pl-wizard-steps__link:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}
.pl-wizard-steps__stub {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-1);
  min-width: 0;
  width: 100%;
  text-align: center;
}
.pl-wizard-steps__item--locked {
  cursor: not-allowed;
}
.pl-wizard-steps__dot {
  display: flex;
  align-items: center;
  justify-content: center;
  width: clamp(1.75rem, 5vw, 2rem);
  height: clamp(1.75rem, 5vw, 2rem);
  border-radius: 50%;
  font-size: clamp(0.6rem, 2.8vw, var(--text-xs));
  font-weight: 800;
  background: var(--n-200);
  color: var(--n-600);
  border: 2px solid var(--n-200);
  flex-shrink: 0;
}
.pl-wizard-steps__item.is-current .pl-wizard-steps__dot {
  background: var(--brand);
  border-color: var(--brand);
  color: #fff;
  box-shadow: 0 0 0 3px var(--brand-light);
}
.pl-wizard-steps__item.is-past .pl-wizard-steps__dot {
  background: var(--green);
  border-color: var(--green);
  color: #fff;
  box-shadow: 0 0 0 3px var(--green-bg);
  /* Heavier ✓: larger than step numbers, max weight, tight line box */
  font-size: clamp(0.78rem, 3vw, 0.9rem);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -0.04em;
}
.pl-wizard-steps__name {
  font-size: clamp(0.5rem, 2.6vw, 0.65rem);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--n-600);
  line-height: 1.2;
  max-width: 100%;
  padding-inline: 1px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
  word-break: break-word;
  hyphens: auto;
}
.pl-wizard-steps__item.is-current .pl-wizard-steps__name {
  color: var(--primary);
}
@media (min-width: 480px) {
  .pl-wizard-steps__name {
    letter-spacing: 0.04em;
  }
}
@media (min-width: 768px) {
  .pl-wizard-progress__track {
    margin-bottom: var(--sp-5);
  }
  .pl-wizard-steps__name {
    font-size: 0.65rem;
    -webkit-line-clamp: 3;
    line-clamp: 3;
  }
}

.pl-wizard__table-wrap {
  overflow-x: auto;
  margin: 0 calc(-1 * var(--sp-2));
  padding: 0 var(--sp-2) var(--sp-4) var(--sp-2);
}
.pl-wizard-table {
  font-size: var(--text-sm);
}
.pl-wizard-table__remove-head {
  width: 2.75rem;
}
.pl-wizard-table .form-control {
  min-width: 7rem;
}
.pl-wizard-table__date-field {
  position: relative;
  min-height: 2.5rem;
}
.pl-wizard-table__date-field .js-schedule-date-display {
  position: relative;
  z-index: 0;
  padding-right: 2.5rem;
  pointer-events: none;
}
.pl-wizard-table__date-field .js-schedule-date-picker {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  min-height: 2.5rem;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: inherit;
  /* Not fully transparent: some engines skip hit-testing / picker for opacity:0 */
  opacity: 0.02;
  cursor: pointer;
}
.pl-wizard-table__remove-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  min-width: 2rem;
  padding: 0;
  color: #dc2626;
  border: 1px solid #fecaca;
  background: #fff;
  border-radius: 9999px;
  line-height: 1;
}
.pl-wizard-table__remove-btn:hover {
  color: #b91c1c;
  border-color: #fca5a5;
  background: #fff5f5;
}
.pl-wizard-table__remove-btn:focus-visible {
  outline: 2px solid #ef4444;
  outline-offset: 2px;
}
.pl-wizard-table__remove-btn[disabled] {
  color: #cbd5e1;
  border-color: #e2e8f0;
  background: #f8fafc;
  cursor: not-allowed;
}

/* Schedule step: “Show end time” — native checkbox + CSS pill (on/off) */
.pl-wizard-table__show-end {
  text-align: center;
  vertical-align: middle;
  white-space: nowrap;
}
.pl-schedule-pill-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}
.pl-schedule-pill-toggle__track {
  position: relative;
  display: inline-block;
  width: 2.75rem;
  height: 1.5rem;
  flex: 0 0 auto;
  background: #cbd5e1;
  border-radius: 9999px;
  transition: background 0.2s ease;
  box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.12);
}
.pl-schedule-pill-toggle__thumb {
  position: absolute;
  top: 0.125rem;
  left: 0.125rem;
  width: 1.25rem;
  height: 1.25rem;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.25);
  transition: transform 0.2s ease;
  pointer-events: none;
}
.pl-schedule-pill-toggle__input:checked + .pl-schedule-pill-toggle__track {
  background: #22c55e;
}
.pl-schedule-pill-toggle__input:checked + .pl-schedule-pill-toggle__track .pl-schedule-pill-toggle__thumb {
  transform: translateX(1.25rem);
}
.pl-schedule-pill-toggle__input:focus-visible + .pl-schedule-pill-toggle__track {
  box-shadow: 0 0 0 2px #fff, 0 0 0 4px var(--brand, #2563eb);
}
@media (prefers-reduced-motion: reduce) {
  .pl-schedule-pill-toggle__track,
  .pl-schedule-pill-toggle__thumb {
    transition: none;
  }
}

.pl-wizard__fee-list {
  margin: 0;
  padding-left: 1.25rem;
  color: var(--text);
  line-height: 1.65;
}
.pl-wizard__fee-list li {
  margin-bottom: var(--sp-2);
}
.pl-wizard__fee-list li:last-child {
  margin-bottom: 0;
}
.pl-wizard__inline-form {
  display: inline;
  margin: 0;
}

.pl-photo-grid {
  display: grid;
  gap: var(--sp-5);
  margin-top: var(--sp-5);
}
.pl-photo-grid--gallery {
  grid-template-columns: 1fr;
  max-width: 100%;
}
/* Wizard Pictures step: three tiles per row, overlay rotate/delete on thumbnails */
.pl-wizard--gallery-wide .pl-photo-grid--gallery {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--sp-5);
}
@media (max-width: 980px) {
  .pl-wizard--gallery-wide .pl-photo-grid--gallery {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 520px) {
  .pl-wizard--gallery-wide .pl-photo-grid--gallery {
    grid-template-columns: 1fr;
  }
}
.pl-wizard--gallery-wide .pl-photo-card--wizard-upload {
  position: relative;
  padding: 0;
  overflow: hidden;
}
.pl-wizard--gallery-wide .pl-photo-card--wizard-upload .pl-photo-card__row {
  flex-direction: column;
  align-items: stretch;
  gap: 0;
}
.pl-wizard--gallery-wide .pl-photo-card--wizard-upload .pl-photo-card__select {
  position: absolute;
  top: var(--sp-2);
  left: var(--sp-2);
  z-index: 3;
  padding-top: 0;
  filter: drop-shadow(0 1px 2px rgba(15, 23, 42, 0.4));
}
.pl-wizard--gallery-wide .pl-photo-card--wizard-upload .pl-photo-card__thumb {
  flex: none;
  width: 100%;
  max-width: none;
  position: relative;
  aspect-ratio: 1;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  overflow: hidden;
  border-radius: var(--r-md);
  background: var(--n-100);
  min-height: 0;
}
.pl-wizard--gallery-wide .pl-photo-card--wizard-upload .pl-photo-card__thumb img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  margin: 0;
  object-fit: cover;
  object-position: center;
  display: block;
  border: none !important;
  border-radius: 0;
}
.pl-wizard--gallery-wide .pl-photo-card--wizard-upload {
  cursor: grab;
}
.pl-wizard--gallery-wide .pl-photo-card--wizard-upload.is-dragging {
  opacity: 0.78;
  cursor: grabbing;
}
.pl-wizard--gallery-wide .pl-photo-card__thumb-glyph {
  position: absolute;
  top: var(--sp-2);
  right: var(--sp-2);
  z-index: 4;
  background: rgba(255, 255, 255, 0.98);
  border-color: var(--n-200);
  box-shadow: var(--shadow-xs);
}
.pl-wizard--gallery-wide .pl-photo-card__thumb-glyph.is-active,
.pl-wizard--gallery-wide .pl-photo-card--default-thumb .pl-photo-card__thumb-glyph {
  background: #fff7cc;
  border-color: #e8b400;
  color: #9a6700;
}
.pl-wizard--gallery-wide .pl-photo-card__overlay-actions {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-3);
  background: linear-gradient(to top, rgba(15, 23, 42, 0.88), transparent);
  border-radius: 0 0 var(--r-md) var(--r-md);
  z-index: 2;
}
.pl-wizard--gallery-wide .pl-photo-card__overlay-btn {
  flex: 0 0 auto;
  background: rgba(255, 255, 255, 0.96);
  border-color: var(--n-200);
  box-shadow: var(--shadow-xs);
}
.pl-wizard--gallery-wide .pl-photo-card__overlay-btn:hover {
  background: #fff;
}
.pl-wizard--gallery-wide .pl-photo-card__overlay-btn.pl-photo-btn--danger {
  background: rgba(254, 242, 242, 0.98);
  border-color: rgba(185, 28, 28, 0.35);
  color: var(--red, #b91c1c);
}
.pl-photo-gallery__intro {
  margin-bottom: var(--sp-4);
  max-width: 48rem;
}

/* “Your photos” heading: programmatic focus for screen readers / scroll; no visible ring */
h2.pl-wizard__section-title[data-pl-gallery-heading]:focus,
h2.pl-wizard__section-title[data-pl-gallery-heading]:focus-visible {
  outline: none;
  box-shadow: none;
}

/* Pictures step: hide device camera on typical desktop (mouse + hover). Touch-first viewports keep camera. */
@media (pointer: fine) and (hover: hover) {
  .pl-wizard--gallery-wide .pl-photo-gallery__camera-wrap {
    display: none !important;
  }
  .pl-wizard--gallery-wide .pl-wizard__upload-files-label {
    display: none !important;
  }
}
@media (pointer: coarse), (hover: none) {
  .pl-wizard--gallery-wide .pl-photo-gallery__camera-wrap ~ .pl-wizard__upload-files-label {
    margin-top: var(--sp-5);
  }
}

/* Camera capture: opacity-0 input over label; centered; white on solid blue */
.pl-photo-gallery__camera-block {
  display: flex;
  justify-content: center;
  margin-bottom: var(--sp-5);
}
.pl-photo-gallery__upload-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: var(--sp-4);
}

.pl-photo-gallery__bg-ai-banner {
  margin-bottom: var(--sp-5);
  padding: var(--sp-4) var(--sp-5);
  border-radius: var(--r-lg);
  border: 1px solid rgba(21, 93, 252, 0.22);
  background: linear-gradient(135deg, rgba(21, 93, 252, 0.07), rgba(21, 93, 252, 0.02));
  box-shadow: var(--shadow-xs);
}
.pl-photo-gallery__bg-ai-banner--above-gallery {
  width: 100%;
  margin-top: 0;
  margin-bottom: var(--sp-4);
  box-sizing: border-box;
  padding: var(--sp-3) var(--sp-4);
}
.pl-photo-gallery__bg-ai-banner--above-gallery .pl-photo-gallery__bg-ai-inner {
  flex-direction: column;
  align-items: stretch;
  gap: var(--sp-3);
}
/* Column layout: avoid flex-grow on children or the banner stretches to fill extra height */
.pl-photo-gallery__bg-ai-banner--above-gallery .pl-photo-gallery__bg-ai-text {
  flex: 0 0 auto;
  width: 100%;
}
.pl-photo-gallery__bg-ai-banner--above-gallery .pl-photo-gallery__bg-ai-progress {
  flex: 0 0 auto;
  max-width: none;
  width: 100%;
}
.pl-photo-gallery__bg-ai-inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-5);
  justify-content: space-between;
}
.pl-photo-gallery__bg-ai-text {
  flex: 1 1 14rem;
  min-width: 0;
}
.pl-photo-gallery__bg-ai-title {
  margin: 0 0 var(--sp-1);
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--n-800);
}
.pl-photo-gallery__bg-ai-progress {
  flex: 1 1 12rem;
  max-width: 22rem;
  margin-top: 0;
}
.pl-photo-gallery__bg-ai-banner[hidden] {
  display: none !important;
}
/* Match .pl-wizard__section-title (var(--brand) #155DFC) and .btn-primary — not --primary (text token). */
.pl-photo-gallery__camera-label.btn-primary {
  color: #fff;
  background: var(--brand);
  border-color: var(--brand);
  box-shadow: none;
}
.pl-photo-gallery__camera-label.btn-primary:hover {
  color: #fff;
  background: var(--brand-hover);
  border-color: var(--brand-hover);
  box-shadow: none;
}
.pl-photo-gallery__camera-label {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: var(--sp-2);
  margin: 0;
  padding-inline: var(--sp-5);
  min-height: 2.75rem;
  cursor: pointer;
  overflow: hidden;
  vertical-align: middle;
}
.pl-photo-gallery__camera-icon {
  flex-shrink: 0;
  display: block;
  color: #fff;
  stroke: #fff;
}
.pl-photo-gallery__camera-label-text {
  position: relative;
  font-weight: 600;
  color: #fff;
}
.pl-photo-gallery__camera-file-input {
  position: absolute;
  inset: 0;
  width: 100%;
  min-height: 100%;
  opacity: 0;
  cursor: pointer;
  z-index: 2;
}
.pl-photo-gallery__ai-note {
  margin-top: calc(-1 * var(--sp-2));
  margin-bottom: var(--sp-4);
  max-width: 48rem;
}
.pl-photo-gallery__toolbar {
  margin-bottom: var(--sp-5);
  padding: 0;
  background: transparent;
  border: none;
}
.pl-photo-gallery__toolbar-unified {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: var(--sp-2);
  width: 100%;
}
.pl-photo-gallery__cap-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: 2.5rem;
  padding: 0.45rem 0.9rem;
  font-weight: 600;
  border: 0;
  border-radius: var(--r-md, 8px);
  box-shadow: var(--shadow-xs);
}
.pl-photo-gallery__cap-btn-ico {
  display: inline-flex;
  flex-shrink: 0;
  line-height: 0;
}
.pl-photo-gallery__cap-btn-ico .pl-photo-btn__ico {
  display: block;
  width: 1.125rem;
  height: 1.125rem;
}
.pl-photo-gallery__cap-btn-label {
  line-height: 1.2;
  white-space: nowrap;
}
.pl-wizard--gallery-wide:not(.pl-wizard--pro-photo-step) .pl-photo-gallery__cap-btn--select-all {
  background: #e2e8f0;
  color: #0f172a;
}
.pl-wizard--gallery-wide:not(.pl-wizard--pro-photo-step) .pl-photo-gallery__cap-btn--select-none {
  background: #f1f5f9;
  color: #334155;
  border: 1px solid #cbd5e1;
  box-shadow: none;
}
.pl-wizard--gallery-wide:not(.pl-wizard--pro-photo-step) .pl-photo-gallery__cap-btn--rotate-ccw,
.pl-wizard--gallery-wide:not(.pl-wizard--pro-photo-step) .pl-photo-gallery__cap-btn--rotate-cw {
  background: #ffedd5;
  color: #9a3412;
  border: 1px solid #fdba74;
  box-shadow: none;
}
.pl-wizard--gallery-wide:not(.pl-wizard--pro-photo-step) .pl-photo-gallery__cap-btn--delete {
  background: #fee2e2;
  color: #991b1b;
  border: 1px solid #fecaca;
  box-shadow: none;
}
.pl-wizard--gallery-wide:not(.pl-wizard--pro-photo-step) .pl-photo-gallery__cap-btn:hover {
  filter: brightness(0.97);
}
/* Pro post-sale step 2 — one row of solid action buttons above the grid */
.pl-wizard.pl-wizard--pro-photo-step .pl-photo-gallery__cap-btn--select-all {
  background: #2563eb;
  color: #fff;
}
.pl-wizard.pl-wizard--pro-photo-step .pl-photo-gallery__cap-btn--select-none {
  background: #64748b;
  color: #fff;
}
.pl-wizard.pl-wizard--pro-photo-step .pl-photo-gallery__cap-btn--rotate-ccw,
.pl-wizard.pl-wizard--pro-photo-step .pl-photo-gallery__cap-btn--rotate-cw {
  background: #ea580c;
  color: #fff;
}
.pl-wizard.pl-wizard--pro-photo-step .pl-photo-gallery__cap-btn--delete {
  background: #b91c1c;
  color: #fff;
}
.pl-wizard.pl-wizard--pro-photo-step .pl-photo-gallery__cap-btn:hover {
  filter: brightness(1.07);
}
.pl-photo-gallery__cap-btn:focus-visible {
  outline: 2px solid var(--primary, #2563eb);
  outline-offset: 2px;
}
.pl-wizard.pl-wizard--pro-photo-step .pl-photo-gallery__cap-btn:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 2px;
  box-shadow: 0 0 0 3px rgba(15, 23, 42, 0.45);
}
.pl-photo-card {
  border: 1px solid var(--border);
  padding: var(--sp-5);
  border-radius: var(--r-lg);
  background: var(--white);
  box-shadow: var(--shadow-xs);
}
.pl-photo-card__row {
  display: flex;
  gap: var(--sp-4);
  flex-wrap: nowrap;
  align-items: flex-start;
}
.pl-photo-card__select {
  flex: 0 0 auto;
  padding-top: var(--sp-2);
}
.pl-photo-card__checkbox {
  width: 1.15rem;
  height: 1.15rem;
  cursor: pointer;
}
.pl-photo-card--selected {
  outline: 2px solid var(--primary, #2563eb);
  outline-offset: 2px;
}
.pl-photo-card--sold {
  opacity: 0.92;
}
.pl-photo-card__sold-badge {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--white);
  background: var(--n-700);
  padding: 2px 8px;
  border-radius: var(--r-sm);
  margin-bottom: var(--sp-2);
}
.pl-photo-card__thumb {
  flex: 0 0 160px;
  position: relative;
}
.pl-photo-card__thumb img {
  display: block;
  max-width: 160px;
  width: 100%;
  height: auto;
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
}
.pl-photo-card__body {
  flex: 1;
  min-width: 0;
}
.pl-photo-card__caption {
  resize: vertical;
  min-height: 4.5rem;
}
.pl-wizard .pl-photo-card__body > label.meta {
  display: block;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--n-700);
  text-transform: none;
  letter-spacing: normal;
  margin-bottom: var(--sp-2);
}
.pl-photo-card__actions {
  margin-top: var(--sp-3);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-1);
}
.pl-photo-btn.pl-photo-btn--icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.5rem;
  min-height: 2.5rem;
  padding: var(--sp-2);
}
.pl-photo-btn__ico {
  display: block;
  width: 1.25rem;
  height: 1.25rem;
  flex-shrink: 0;
}
.pl-photo-btn--ai {
  color: var(--primary, #2563eb);
}
.pl-photo-btn--danger:hover {
  color: #b91c1c;
  border-color: #fecaca;
  background: #fef2f2;
}

/* AI Describe: full-screen busy state (must sit above dashboard chrome; often moved to body via JS) */
.pl-photo-gallery__ai-busy {
  position: fixed;
  inset: 0;
  z-index: 500000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-6);
  background: rgba(15, 23, 42, 0.52);
  backdrop-filter: blur(5px);
}
.pl-photo-gallery__ai-busy[hidden] {
  display: none !important;
}
.pl-photo-gallery__ai-busy-card {
  width: min(26rem, 100%);
  padding: var(--sp-8);
  border-radius: var(--r-lg);
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-lg);
  text-align: center;
}
.pl-photo-gallery__ai-busy-title {
  margin: 0 0 var(--sp-5);
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--primary);
}
.pl-photo-gallery__ai-busy-status {
  margin: var(--sp-4) 0 0;
  min-height: 2.5em;
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--primary);
  line-height: 1.35;
  letter-spacing: -0.02em;
}
.pl-photo-gallery__ai-busy-hint {
  margin: var(--sp-3) 0 0;
  line-height: 1.45;
}
.pl-photo-gallery__upload-ai-choice {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  justify-content: center;
  margin-top: var(--sp-6);
}
.pl-photo-gallery__progress {
  height: 0.625rem;
  border-radius: var(--r-full);
  background: var(--n-200);
  overflow: hidden;
}
.pl-photo-gallery__progress-strip {
  height: 100%;
  width: 42%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--brand-teal), var(--brand));
  animation: pl-photo-gallery-progress-indeterminate 1.15s ease-in-out infinite;
}
.pl-photo-gallery__progress--determinate .pl-photo-gallery__progress-strip--determinate {
  width: 0%;
  min-width: 0;
  max-width: 100%;
  animation: none;
  transition: width 0.15s ease-out;
}
@keyframes pl-photo-gallery-progress-indeterminate {
  0% {
    transform: translateX(-120%);
  }
  100% {
    transform: translateX(320%);
  }
}
@media (prefers-reduced-motion: reduce) {
  .pl-photo-gallery__progress-strip {
    animation: none;
    width: 100%;
    opacity: 0.85;
  }
  .pl-photo-gallery__progress--determinate .pl-photo-gallery__progress-strip--determinate {
    transition: none;
  }
}

/* Photo AI: marketplace items modal (match native <dialog> centering like .staff-access-dialog) */
/* Pro wizard: create estate from Marketing & estate step (no nested form in main wizard) */
.pro-estate-create-open-btn {
  display: inline;
  margin: 0;
  padding: 0;
  border: none;
  background: none;
  color: var(--primary);
  text-decoration: underline;
  cursor: pointer;
  font: inherit;
  font-weight: 600;
}
.pro-estate-create-open-btn:hover {
  color: var(--primary-dark, var(--brand));
}
/* Full-screen dimmer; dialog uses dialog.show() (not showModal) so .pac-container stays on body and positions correctly */
.pro-estate-create-dialog__backdrop {
  position: fixed;
  inset: 0;
  z-index: 9998;
  background: rgba(15, 23, 42, 0.45);
}
.pro-estate-create-dialog {
  position: fixed;
  inset: 0;
  z-index: 9999;
  width: min(36rem, calc(100vw - 2rem));
  max-width: min(36rem, calc(100vw - 2rem));
  max-height: min(90vh, 44rem);
  height: fit-content;
  margin: auto;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg);
  background: var(--surface);
  overflow: hidden;
  box-sizing: border-box;
}
.pro-estate-create-dialog__form {
  padding: var(--sp-6);
  max-height: min(90vh, 44rem);
  overflow-x: hidden;
  overflow-y: auto;
  box-sizing: border-box;
}
.pro-estate-create-dialog__title {
  margin: 0 0 var(--sp-3);
  font-size: var(--text-xl);
  color: var(--primary);
}
.pro-estate-create-dialog__lede {
  margin: 0 0 var(--sp-5);
  line-height: 1.45;
}
/* Explicit label ↔ control spacing (dialog form is not .pl-wizard__form) */
.pro-estate-create-dialog__form .estate-form--compact > .form-group {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin-bottom: var(--sp-5);
}
.pro-estate-create-dialog__form .estate-form--compact > .form-group:last-child {
  margin-bottom: 0;
}
.pro-estate-create-dialog__form .estate-form--compact > .es-address-fields {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
  margin-bottom: var(--sp-5);
}
.pro-estate-create-dialog__form .es-address-fields__locality .form-group {
  gap: var(--sp-2);
}
.pro-estate-create-dialog__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  justify-content: flex-end;
  margin-top: var(--sp-6);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border);
}

/* Pro listing wizard: post-publish celebration + next steps */
.listing-posted-success {
  max-width: 56rem;
  margin-inline: auto;
}
.listing-posted-success__hero {
  text-align: center;
  padding: var(--sp-8) var(--sp-5) var(--sp-7);
  margin-bottom: var(--sp-8);
  border-radius: var(--r-xl);
  border: 1px solid color-mix(in srgb, var(--brand, #155dfc) 22%, var(--border));
  background: linear-gradient(
    145deg,
    color-mix(in srgb, var(--brand, #155dfc) 14%, transparent) 0%,
    var(--white) 42%,
    color-mix(in srgb, var(--n-200) 50%, var(--white)) 100%
  );
  box-shadow: var(--shadow-sm);
}
.listing-posted-success__eyebrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  margin: 0 0 var(--sp-3);
  font-size: var(--text-sm);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--brand, #155dfc);
}
.listing-posted-success__h1 {
  margin: 0 0 var(--sp-3);
  font-size: clamp(1.75rem, 4.5vw, 2.35rem);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -0.03em;
  color: var(--text, #0f172a);
}
.listing-posted-success__lede {
  max-width: 40rem;
  margin: 0 auto var(--sp-5);
  font-size: var(--text-base);
  line-height: 1.55;
  color: var(--text-muted);
}
.listing-posted-success__sale-pill {
  display: inline-block;
  max-width: 100%;
  margin: 0;
  padding: var(--sp-2) var(--sp-4);
  font-size: var(--text-sm);
  font-weight: 600;
  line-height: 1.3;
  color: var(--text);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: 0 1px 0 color-mix(in srgb, var(--n-900) 4%, transparent);
  word-break: break-word;
}
.listing-posted-success__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
  margin-bottom: var(--sp-8);
}
@media (min-width: 48rem) {
  .listing-posted-success__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .listing-posted-success__card--wide {
    grid-column: 1 / -1;
  }
}
.listing-posted-success__card {
  position: relative;
  padding: var(--sp-6);
  border-radius: var(--r-lg);
  border: 1px solid var(--border);
  background: var(--white);
  box-shadow: var(--shadow-xs);
  transition: border-color 0.15s var(--ease, ease), box-shadow 0.15s var(--ease, ease);
}
.listing-posted-success__card:hover {
  border-color: color-mix(in srgb, var(--brand, #155dfc) 20%, var(--border));
  box-shadow: var(--shadow-sm);
}
.listing-posted-success__card--accent {
  border-color: color-mix(in srgb, var(--brand, #155dfc) 32%, var(--border));
  background: linear-gradient(
    180deg,
    var(--white) 0%,
    color-mix(in srgb, var(--brand, #155dfc) 7%, var(--white)) 100%
  );
}
.listing-posted-success__card-head {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-3);
}
.listing-posted-success__card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  margin-bottom: 0;
  border-radius: var(--r-md);
  color: var(--brand, #155dfc);
  background: color-mix(in srgb, var(--brand, #155dfc) 12%, transparent);
  flex-shrink: 0;
}
.listing-posted-success__card-title {
  margin: 0;
  font-size: var(--text-lg);
  font-weight: 700;
  line-height: 1.25;
  color: var(--text);
  flex: 1 1 auto;
  min-width: 0;
}
.listing-posted-success__card-body {
  margin: 0 0 var(--sp-3);
  font-size: var(--text-sm);
  line-height: 1.55;
  color: var(--text-muted);
}
.listing-posted-success__card-body strong {
  color: var(--text);
  font-weight: 600;
}
.listing-posted-success__link-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}
.listing-posted-success__link-list--inline {
  flex-direction: row;
  flex-wrap: wrap;
  gap: var(--sp-3) var(--sp-5);
}
.listing-posted-success__link {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--text-sm);
  font-weight: 600;
  text-decoration: none;
  color: var(--primary, #155dfcff);
  border-bottom: 0;
  box-shadow: none;
  transition: color 0.12s ease, opacity 0.12s ease;
}
.listing-posted-success__link:hover,
.listing-posted-success__link:focus-visible {
  text-decoration: none;
  color: var(--primary-dark, color-mix(in srgb, var(--primary, #155dfcff) 85%, #000 15%));
  border-bottom: 0;
  box-shadow: none;
}
.listing-posted-success__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  padding-top: var(--sp-2);
}

.pl-mp-dialog {
  position: fixed;
  inset: 0;
  width: min(42rem, calc(100vw - 2rem));
  max-width: min(42rem, calc(100vw - 2rem));
  max-height: min(90vh, 44rem);
  height: fit-content;
  margin: auto;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-lg);
  background: var(--surface);
  overflow-x: hidden;
  overflow-y: auto;
  box-sizing: border-box;
}
@media (min-width: 768px) {
  .pl-mp-dialog {
    max-height: min(99vh, 48.4rem);
  }
}
.pl-mp-dialog::backdrop {
  background: rgba(15, 23, 42, 0.45);
}
.pl-mp-dialog__form {
  padding: var(--sp-8);
}
.pl-mp-dialog__title {
  margin: 0 0 var(--sp-3);
  font-size: var(--text-xl);
  color: var(--primary);
}
.pl-mp-dialog__lede {
  margin: 0 0 var(--sp-4);
  max-width: none;
}
.pl-mp-dialog__bulk-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
}
.pl-mp-dialog__rows {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
  max-height: min(60vh, 28rem);
  overflow-y: auto;
  margin-bottom: var(--sp-5);
  padding-right: var(--sp-2);
}
@media (min-width: 768px) {
  .pl-mp-dialog__rows {
    max-height: min(66vh, 30.8rem);
  }
}
.pl-mp-dialog__empty {
  margin: 0 0 var(--sp-5);
}
.pl-mp-dialog__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  justify-content: flex-end;
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border);
}
.pl-mp-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--sp-4);
  align-items: start;
  padding: var(--sp-4);
  border: 1px solid var(--n-200);
  border-radius: var(--r);
  background: var(--n-50);
  cursor: pointer;
}
.pl-mp-item .pl-mp-item__editor input,
.pl-mp-item .pl-mp-item__editor textarea,
.pl-mp-item .pl-mp-item__editor select {
  cursor: auto;
}
.pl-mp-item__check {
  padding-top: var(--sp-1);
}
.pl-mp-item__check input[type='checkbox'] {
  width: 1.15rem;
  height: 1.15rem;
  cursor: pointer;
}
.pl-mp-item__main {
  position: relative;
  min-width: 0;
  padding-right: 2.75rem;
  display: grid;
  grid-template-columns: minmax(120px, 220px) minmax(0, 1fr);
  gap: var(--sp-4);
  align-items: start;
}
.pl-mp-item__media {
  margin: 0;
}
.pl-mp-item__content {
  min-width: 0;
}
.pl-mp-item__crop-frame {
  position: relative;
  overflow: hidden;
  width: min(100%, 220px);
  aspect-ratio: 4 / 3;
  border-radius: var(--r-md);
  border: 1px solid var(--n-200);
  background: var(--n-100);
}
.pl-mp-item__img {
  position: absolute;
  inset: 0 auto auto 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  max-width: none;
}
.pl-mp-item__crop-frame > .pl-mp-item__img {
  position: absolute;
  max-width: none;
  width: auto;
  height: auto;
  display: block;
  object-fit: unset;
  margin: 0;
}
.pl-mp-item__placeholder {
  width: min(100%, 220px);
  aspect-ratio: 4 / 3;
  border: 1px dashed var(--n-300);
  border-radius: var(--r-md);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--n-100);
  color: var(--n-600);
  font-size: var(--text-sm);
}
.pl-mp-item__edit-btn {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1;
}
.pl-mp-item__edit-btn.pl-photo-btn--icon {
  min-width: 2.25rem;
  min-height: 2.25rem;
}
.pl-mp-item__name {
  display: block;
  margin: 0 0 var(--sp-2);
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--primary);
  line-height: 1.35;
  padding-right: var(--sp-1);
}
.pl-mp-item__desc {
  margin: 0 0 var(--sp-3);
  line-height: 1.45;
  max-width: none;
}
.pl-mp-item__meta {
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.45;
}
.pl-mp-item__meta strong {
  color: var(--primary);
  font-weight: 700;
}
.pl-mp-item__editor {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.pl-mp-item__view[hidden],
.pl-mp-item__editor[hidden] {
  display: none !important;
}
.pl-mp-item__editor .pl-mp-item__input-name {
  font-weight: 600;
}
.pl-mp-item.is-editing .pl-mp-item__main {
  padding-right: 2.75rem;
}
.pl-mp-item__field-row {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}
.pl-mp-item__field-label {
  font-weight: 600;
  color: var(--n-600);
}
.pl-mp-item__crop-frame {
  touch-action: none;
  cursor: grab;
}
.pl-mp-item__crop-frame:active {
  cursor: grabbing;
}
.pl-mp-item__editor input[type='range'].pl-mp-item__input {
  padding: 0;
}
@media (max-width: 640px) {
  .pl-mp-item__main {
    grid-template-columns: 1fr;
  }
  .pl-mp-item__media,
  .pl-mp-item__crop-frame,
  .pl-mp-item__placeholder {
    width: 100%;
  }
}

@media (max-width: 520px) {
  .pl-photo-card:not(.pl-photo-card--wizard-upload) .pl-photo-card__row {
    flex-wrap: wrap;
  }
  .pl-photo-card:not(.pl-photo-card--wizard-upload) .pl-photo-card__thumb {
    flex: 0 0 100%;
    max-width: 220px;
  }
}

/* Pro “List a sale” step 3 — gallery tuned for phone/tablet (hero thumb, overlay select, scrollable bulk tools) */
@media (max-width: 768px) {
  .pl-wizard.pl-wizard--pro-photo-step .pl-wizard__section:has([data-pl-gallery-grid]) {
    padding: var(--sp-3);
    background: linear-gradient(180deg, var(--n-50) 0%, var(--white) 38%);
    border-radius: var(--r-xl);
  }
  .pl-wizard.pl-wizard--pro-photo-step .pl-photo-gallery__intro {
    margin-bottom: var(--sp-3);
    font-size: var(--text-sm);
    line-height: 1.5;
  }
  .pl-wizard.pl-wizard--pro-photo-step .pl-photo-gallery__toolbar-unified {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    gap: var(--sp-2);
    padding-bottom: var(--sp-2);
    margin-inline: calc(-1 * var(--sp-1));
    padding-inline: var(--sp-1);
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    mask-image: linear-gradient(
      to right,
      transparent,
      #000 10px,
      #000 calc(100% - 10px),
      transparent
    );
  }
  .pl-wizard.pl-wizard--pro-photo-step .pl-photo-gallery__cap-btn {
    flex-shrink: 0;
    scroll-snap-align: start;
  }
}

@media (max-width: 640px) {
  .pl-wizard {
    padding: var(--sp-4) var(--sp-3);
    border-radius: var(--r-lg);
    max-width: 100%;
    margin-inline: 0;
  }
  .pl-wizard__header {
    margin-bottom: var(--sp-6);
    padding-bottom: var(--sp-4);
  }
  .pl-wizard-nav {
    margin-bottom: var(--sp-6);
  }
  .pl-wizard-nav__top {
    gap: var(--sp-2);
  }
  .pl-wizard__actions--three {
    flex-direction: column;
    align-items: stretch;
  }
  .pl-wizard__actions--three > .btn,
  .pl-wizard__actions--three > form.pl-wizard__inline-form {
    flex: 1 1 auto;
    width: 100%;
    min-height: 2.75rem;
  }
}
@media (min-width: 641px) and (max-width: 900px) {
  .pl-wizard {
    padding: var(--sp-6);
  }
}

/* ---- Tables --------------------------------------------------------------- */
/* overflow: visible — overflow:hidden clipped action buttons in narrow / fixed-layout table cells (see .admin-table-scroll for horizontal pan) */
.admin-table { width: 100%; border-collapse: collapse; background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: visible; box-shadow: var(--shadow-sm); font-size: var(--text-sm); }
.admin-table th { background: var(--n-50); text-align: left; padding: var(--sp-3) var(--sp-4); font-size: var(--text-xs); font-weight: 700; color: var(--n-500); text-transform: uppercase; letter-spacing: 0.07em; border-bottom: 1px solid var(--border); }
.admin-table td { padding: var(--sp-4); border-bottom: 1px solid var(--border); vertical-align: middle; color: var(--text); }
.admin-table tbody tr:last-child td { border-bottom: none; }
.admin-table tbody tr:hover td { background: var(--n-50); }
/* Use around <table class="admin-table"> when the grid would exceed the viewport (contracts, keys, webhooks) */
.admin-table-scroll {
  display: block;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
}
.admin-table-scroll .admin-table {
  /* Wider than viewport when columns need it; parent scrolls horizontally */
  width: max-content;
  min-width: 100%;
  max-width: none;
  box-sizing: border-box;
}

/* ---- Admin panel ---------------------------------------------------------- */
.admin-panel { max-width: 72rem; }
/* Admin global subnav (under site header) */
.admin-subnav {
  position: sticky;
  top: 3.75rem;
  z-index: 90;
  background: rgba(255, 255, 255, 0.97);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow-xs);
}
.admin-subnav__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-1);
  padding-block: var(--sp-2);
  min-height: 3rem;
}
.admin-subnav__link {
  display: inline-flex;
  align-items: center;
  height: 2.25rem;
  padding-inline: var(--sp-3);
  border-radius: var(--r-xs);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--n-600);
  text-decoration: none;
  transition: background var(--dur-sm) var(--ease), color var(--dur-sm) var(--ease);
}
.admin-subnav__link:hover {
  background: var(--n-100);
  color: var(--primary);
}
.admin-subnav__link.is-active {
  background: var(--brand-light);
  color: var(--brand);
}
.admin-leads-export {
  margin: 0 0 var(--sp-4);
}

.admin-toolbar { display: flex; flex-wrap: wrap; align-items: center; gap: var(--sp-1); padding: var(--sp-2) var(--sp-3); background: var(--white); border: 1px solid var(--border); border-radius: var(--r); margin-bottom: var(--sp-6); }
.admin-toolbar a { display: inline-flex; align-items: center; height: 2rem; padding-inline: var(--sp-3); border-radius: var(--r-xs); color: var(--n-600); text-decoration: none; font-size: var(--text-sm); font-weight: 500; transition: background var(--dur-sm) var(--ease); }
.admin-toolbar a:hover { background: var(--n-100); color: var(--primary); }
.admin-toolbar .inline { display: inline-flex; align-items: center; }
.stat-strip { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 10rem), 1fr)); gap: var(--sp-4); margin-bottom: var(--sp-8); }
.stat-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--r); padding: var(--sp-5); }
.stat-value { font-size: var(--text-3xl); font-weight: 800; color: var(--primary); line-height: 1; }
.stat-label { font-size: var(--text-xs); font-weight: 600; color: var(--text-muted); margin-top: var(--sp-1); text-transform: uppercase; letter-spacing: 0.06em; }
.stat-card--link { text-decoration: none; color: inherit; display: block; transition: border-color var(--dur-sm) var(--ease), box-shadow var(--dur-sm) var(--ease); }
.stat-card--link:hover { border-color: var(--brand); box-shadow: var(--shadow-sm); }
.stat-sub { margin-top: var(--sp-2); font-size: var(--text-xs); color: var(--n-500); text-transform: none; letter-spacing: 0; font-weight: 500; }
.admin-toolbar a.is-active { background: var(--brand-light); color: var(--brand); }

/* ---- Admin SaaS CRM ------------------------------------------------------- */
.admin-crm-pipeline { display: flex; flex-wrap: wrap; gap: var(--sp-2); margin-bottom: var(--sp-6); align-items: center; }
.admin-crm-pill {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-4); border-radius: var(--r-full);
  background: var(--white); border: 1px solid var(--border);
  text-decoration: none; color: var(--text); font-size: var(--text-sm); font-weight: 600;
  transition: background var(--dur-sm) var(--ease), border-color var(--dur-sm) var(--ease);
}
.admin-crm-pill:hover { border-color: var(--n-300); background: var(--n-50); }
.admin-crm-pill.is-active { border-color: var(--brand); background: var(--brand-light); color: var(--brand); }
.admin-crm-pill--due.is-active { border-color: #F59E0B; background: #FFFBEB; color: #B45309; }
.admin-crm-pill--muted { font-weight: 500; color: var(--n-500); }
.admin-crm-pill-count { font-variant-numeric: tabular-nums; opacity: 0.85; }
.admin-crm-search { display: flex; flex-wrap: wrap; gap: var(--sp-3); align-items: center; margin-bottom: var(--sp-4); }
.admin-crm-empty { padding: var(--sp-10); text-align: center; background: var(--white); border: 1px dashed var(--border); border-radius: var(--r-lg); color: var(--n-500); }
.admin-crm-row--due td:first-child { box-shadow: inset 3px 0 0 #F59E0B; }
.admin-crm-status { display: inline-flex; padding: 2px 10px; border-radius: var(--r-full); font-size: var(--text-xs); font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; }
.admin-crm-status--dead { background: var(--n-200); color: var(--n-600); }
.admin-crm-status--cold { background: #E0F2FE; color: #0369A1; }
.admin-crm-status--warm { background: #FEF3C7; color: #B45309; }
.admin-crm-status--hot { background: #FEE2E2; color: #B91C1C; }
.admin-crm-status--sold { background: #D1FAE5; color: #047857; }
.admin-crm-form-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--sp-6); margin-top: var(--sp-4); }
.admin-crm-card { background: var(--white); border: 1px solid var(--border); border-radius: var(--r-lg); padding: var(--sp-6); box-shadow: var(--shadow-xs); }
.admin-crm-card-title { font-size: var(--text-sm); font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--n-500); margin: 0 0 var(--sp-4); }
.admin-crm-inline-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--sp-3); }
@media (max-width: 640px) { .admin-crm-inline-3 { grid-template-columns: 1fr; } }
.admin-crm-actions { display: flex; flex-wrap: wrap; gap: var(--sp-3); margin-top: var(--sp-6); }
.admin-crm-delete-form { margin-top: var(--sp-3); }
.admin-crm-provision { border-color: var(--brand); background: linear-gradient(180deg, var(--brand-light) 0%, var(--white) 48%); }
.admin-crm-provision-btns { display: flex; flex-wrap: wrap; gap: var(--sp-3); margin-top: var(--sp-4); }
.admin-crm-provision--hero {
  margin-top: 0;
  margin-bottom: var(--sp-8);
  border-width: 1.5px;
  border-color: rgba(21, 93, 252, 0.35);
  background: linear-gradient(145deg, var(--brand-light) 0%, var(--white) 42%, var(--n-50) 100%);
  box-shadow: var(--shadow-sm), 0 0 0 1px rgba(255, 255, 255, 0.6) inset;
}
.admin-crm-provision__head { max-width: 48rem; }
.admin-crm-provision__kicker {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brand);
  margin-bottom: var(--sp-2);
}
.admin-crm-provision__title { margin-bottom: var(--sp-3); color: var(--primary); }
.admin-crm-provision__lede { margin: 0 0 var(--sp-2); line-height: 1.55; }
.admin-crm-provision__actions { margin-top: var(--sp-5); }
.admin-crm-provision__hint { margin: var(--sp-3) 0 0; color: var(--n-600); }
.admin-crm-provision-form.inline { display: inline-flex; margin: 0; align-items: center; }
.admin-crm-provision__footer { margin-top: var(--sp-5); margin-bottom: 0; }

.admin-sdr-panel { margin-bottom: var(--sp-6); }
.admin-sdr-panel__actions { margin-bottom: var(--sp-4); }
.admin-sdr-generate__row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: var(--sp-3);
}
.admin-sdr-generate__more {
  position: relative;
}
.admin-sdr-generate__more > summary {
  list-style: none;
  cursor: pointer;
}
.admin-sdr-generate__more > summary::-webkit-details-marker { display: none; }
.admin-sdr-generate__menu {
  position: absolute;
  z-index: 20;
  left: 0;
  top: calc(100% + var(--sp-2));
  min-width: min(22rem, 92vw);
  padding: var(--sp-2);
  border: 1px solid var(--n-200);
  border-radius: var(--r);
  background: var(--surface);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}
.admin-sdr-generate__menu-item {
  display: block;
  width: 100%;
  text-align: left;
  padding: var(--sp-2) var(--sp-3);
  border: none;
  border-radius: var(--r);
  background: transparent;
  font: inherit;
  cursor: pointer;
  color: var(--primary);
}
.admin-sdr-generate__menu-item:hover:not(:disabled) {
  background: var(--n-50);
}
.admin-sdr-generate__menu-item:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.admin-sdr-send-form .admin-crm-field { margin-bottom: var(--sp-3); }
.admin-sdr-test-form { display: flex; flex-wrap: wrap; gap: var(--sp-3); align-items: flex-end; }
.admin-sdr-oauth-uri {
  margin-bottom: var(--sp-3);
  padding: var(--sp-3);
  background: var(--n-50);
  border-radius: var(--r);
  border: 1px solid var(--n-200);
}
.admin-sdr-oauth-uri__code {
  display: inline-block;
  max-width: 100%;
  word-break: break-all;
  font-size: var(--text-sm);
}
.admin-sdr-workspace-capabilities {
  margin: var(--sp-3) 0;
  padding-left: 1.25rem;
  line-height: 1.6;
}
.admin-sdr-workspace-upgrade { max-width: 40rem; }
.admin-sdr-calendar-test {
  flex-direction: column;
  align-items: flex-start;
}
.admin-sdr-sync-replies {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  align-items: center;
}
.admin-sdr-hub .admin-sdr-test-form label { display: block; font-size: var(--text-sm); margin-bottom: var(--sp-1); }

.admin-sdr-replies__warn { max-width: 42rem; }
.admin-sdr-replies__empty { padding: var(--sp-2) 0; max-width: 44rem; }
.admin-sdr-replies__empty-list { margin: var(--sp-2) 0 0; padding-left: 1.25rem; }
.admin-sdr-replies__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-6);
}
@media (max-width: 960px) {
  .admin-sdr-replies__grid { grid-template-columns: 1fr; }
}
.admin-sdr-replies__inbound {
  white-space: pre-wrap;
  word-break: break-word;
  margin: var(--sp-3) 0 0;
  padding: var(--sp-3);
  background: var(--n-50);
  border-radius: var(--r);
  font-size: var(--text-sm);
  max-height: 22rem;
  overflow: auto;
}
.admin-sdr-replies__dismiss { padding-top: var(--sp-4); border-top: 1px solid var(--n-200); }

.admin-crm-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
}
.admin-crm-search-live {
  position: relative;
  flex: 1 1 16rem;
  max-width: 32rem;
}
.admin-crm-search-live__icon {
  position: absolute;
  left: var(--sp-3);
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  color: var(--n-400);
  pointer-events: none;
}
.admin-crm-search-live__icon svg { display: block; }
.admin-crm-search-live__input {
  padding-left: 2.75rem;
  height: 2.875rem;
  border-radius: var(--r-lg);
  border-color: var(--n-200);
  box-shadow: none;
}
.admin-crm-search-live__input:focus {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px var(--brand-light);
}
.admin-crm-list-meta { flex: 0 0 auto; font-variant-numeric: tabular-nums; }
.admin-crm-truncate-banner {
  padding: var(--sp-4) var(--sp-5);
  margin-bottom: var(--sp-5);
  background: #FFFBEB;
  border: 1px solid #FCD34D;
  border-radius: var(--r-lg);
  color: #78350F;
  font-size: var(--text-sm);
  line-height: 1.5;
}
.admin-crm-prospects-head { margin-top: 0; }
.admin-crm-table-sub {
  max-width: 14rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.admin-crm-table-empty { padding: var(--sp-8) var(--sp-4); text-align: center; color: var(--n-500); }
.admin-crm-pager {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--sp-4);
  margin-top: var(--sp-6);
  padding: var(--sp-4);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
}
.admin-crm-pager__status { min-width: 12rem; text-align: center; }

.admin-crm-view__title { letter-spacing: -0.02em; }
.admin-crm-view__meta { display: flex; flex-wrap: wrap; align-items: center; gap: var(--sp-2); margin-top: var(--sp-2); }
.admin-crm-view__meta-sep { color: var(--n-300); user-select: none; }
.admin-crm-view__actions { flex-wrap: wrap; }
.admin-crm-view-grid { margin-top: var(--sp-6); }
.admin-crm-view-stack { display: flex; flex-direction: column; gap: var(--sp-4); }
.admin-crm-view-field { display: flex; flex-direction: column; gap: var(--sp-1); }
.admin-crm-view-field__label {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--n-500);
}
.admin-crm-view-field__value { font-size: var(--text-sm); color: var(--text); line-height: 1.5; word-break: break-word; }
.admin-crm-view-links { margin-top: var(--sp-6); }
.admin-crm-view-json {
  margin: 0;
  padding: var(--sp-4);
  font-size: var(--text-xs);
  line-height: 1.45;
  background: var(--n-50);
  border: 1px solid var(--border);
  border-radius: var(--r);
  overflow-x: auto;
  max-height: 24rem;
}
.admin-crm-view-edit-hint { margin-top: var(--sp-8); }

.admin-crm-view-layout {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
  margin-top: var(--sp-6);
}
.admin-crm-view-top2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--sp-6);
  align-items: start;
}
@media (max-width: 900px) {
  .admin-crm-view-top2 { grid-template-columns: 1fr; }
}
.admin-crm-card--span-full { width: 100%; }
.admin-crm-view-empty { color: var(--n-400); }
.admin-crm-view-empty-msg { margin: 0 0 var(--sp-2); }
.admin-crm-view-textblock--overview {
  font-size: var(--text-sm);
  line-height: 1.65;
  color: var(--text);
}
.admin-crm-view-follow3 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--sp-4);
}
@media (max-width: 720px) {
  .admin-crm-view-follow3 { grid-template-columns: 1fr; }
}
.admin-crm-notes-lede { margin: 0 0 var(--sp-4); }
.admin-crm-notes-log { margin-bottom: var(--sp-5); }
.admin-crm-notes-pre {
  margin: 0;
  padding: var(--sp-4);
  font-size: var(--text-sm);
  line-height: 1.55;
  white-space: pre-wrap;
  word-break: break-word;
  background: var(--n-50);
  border: 1px solid var(--border);
  border-radius: var(--r);
  max-height: 28rem;
  overflow: auto;
}
.admin-crm-notes-form .admin-crm-field { margin-bottom: var(--sp-3); }
.admin-crm-input-block {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}
.admin-crm-textarea-tall { min-height: 12rem; font-family: inherit; }
.admin-crm-textarea-notes { min-height: 7rem; font-family: inherit; }
.admin-crm-modal {
  padding: 0;
  border: none;
  border-radius: var(--r-lg);
  max-width: min(52rem, calc(100vw - 2rem));
  width: calc(100vw - 2rem);
  max-height: min(92vh, 48rem);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  margin: 0;
  z-index: 10050;
  background: var(--white);
}
.admin-crm-modal::backdrop {
  background: rgba(15, 23, 42, 0.45);
}
.admin-crm-modal__panel {
  display: flex;
  flex-direction: column;
  max-height: min(92vh, 48rem);
}
.admin-crm-modal__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  padding: var(--sp-4) var(--sp-5);
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.admin-crm-modal__title {
  margin: 0;
  font-size: var(--text-lg);
  font-weight: 700;
}
.admin-crm-modal__body {
  padding: var(--sp-5);
  overflow-y: auto;
  flex: 1;
  min-height: 0;
}
/* CRM prospect: AI Populate in-flight (narrow progress dialog) */
.admin-crm-ai-populate-modal.admin-crm-modal {
  max-width: min(26rem, calc(100vw - 2rem));
  width: calc(100vw - 2rem);
  max-height: none;
}
.admin-crm-ai-populate-modal .admin-crm-modal__panel {
  max-height: none;
}
.admin-crm-ai-populate-modal__body {
  padding-top: var(--sp-3);
}
.admin-crm-ai-populate-modal__hint {
  margin: 0 0 var(--sp-4);
}
.admin-crm-ai-populate-modal__progress {
  margin: 0;
}
.admin-crm-ai-populate-modal__progress .sale-form__ai-progress-track {
  max-width: 100%;
}
.admin-sdr-panel__hint { margin: 0 0 var(--sp-3); }
.admin-sdr-panel__actions { margin-bottom: var(--sp-4); }

.admin-crm-company-info-wrap { margin-top: var(--sp-6); margin-bottom: var(--sp-2); }
.admin-crm-company-info-lede { margin: var(--sp-2) 0 var(--sp-4); }
.admin-crm-company-info-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--sp-4);
}
@media (max-width: 768px) {
  .admin-crm-company-info-grid { grid-template-columns: 1fr; }
}
.admin-crm-card-title--sub {
  font-size: var(--text-xs);
  margin-bottom: var(--sp-3);
}
.admin-crm-view-textblock {
  font-size: var(--text-sm);
  line-height: 1.55;
  color: var(--text);
  word-break: break-word;
}
.admin-crm-form-grid .admin-crm-card--span-2 { grid-column: 1 / -1; }

.admin-sdr-discover-dialog {
  padding: 0;
  border: none;
  border-radius: var(--r-lg);
  max-width: min(40rem, calc(100vw - 2rem));
  width: calc(100vw - 2rem);
  max-height: min(90vh, 36rem);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  /* Native <dialog> can sit at the top of the viewport; pin to viewport center. */
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  margin: 0;
  z-index: 10050;
}
.admin-sdr-discover-dialog::backdrop {
  background: rgba(15, 23, 42, 0.45);
}
.admin-sdr-discover-dialog__inner {
  padding: var(--sp-6);
  max-height: min(90vh, 36rem);
  overflow: auto;
  display: flex;
  flex-direction: column;
}
.admin-sdr-discover-dialog__inner > h2 {
  margin: 0 0 var(--sp-4);
  font-size: var(--text-lg);
}
.admin-sdr-progress {
  height: 10px;
  background: var(--n-100);
  border-radius: var(--r-full);
  overflow: hidden;
  border: 1px solid var(--border);
}
.admin-sdr-progress__fill {
  height: 100%;
  background: linear-gradient(90deg, var(--brand) 0%, #2563eb 100%);
  width: 0%;
  transition: width 0.25s ease;
}
.admin-sdr-discover-log {
  margin-top: var(--sp-4);
  max-height: 18rem;
  overflow: auto;
  font-size: var(--text-xs);
  line-height: 1.45;
  padding: var(--sp-3);
  background: var(--n-50);
  border: 1px solid var(--border);
  border-radius: var(--r);
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  white-space: pre-wrap;
  word-break: break-word;
}
.admin-sdr-discover-log__line { display: block; margin-bottom: var(--sp-1); }
.admin-sdr-discover-log__line:last-child { margin-bottom: 0; }
.admin-sdr-discover-dialog__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: var(--sp-3);
  margin-top: var(--sp-5);
}
.admin-sdr-bg-notice {
  margin-top: var(--sp-4);
  padding: var(--sp-3) var(--sp-4);
  background: var(--n-50);
  border: 1px solid var(--border);
  border-radius: var(--r);
  color: var(--n-600);
}

/* Styled file drop: label + visually-hidden input; zone is click/drop target inside label */
.es-file-drop {
  position: relative;
  display: block;
  margin-top: var(--sp-1);
}
.es-file-drop--compact .es-file-drop__zone {
  min-height: 6.5rem;
  padding: var(--sp-5) var(--sp-4);
  gap: var(--sp-3);
}
.es-file-drop--compact .es-file-drop__icon {
  width: 2.75rem;
  height: 2.75rem;
}
.es-file-drop--compact .es-file-drop__icon svg {
  width: 1.5rem;
  height: 1.5rem;
}
.es-file-drop__control {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin: 0;
  padding: 0;
  cursor: pointer;
  font-size: inherit;
  font-weight: inherit;
  text-transform: none;
  letter-spacing: normal;
  color: inherit;
}
.es-file-drop__legend {
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--n-600);
  text-transform: uppercase;
  letter-spacing: 0.07em;
}
.es-file-drop__hint {
  display: block;
  margin: 0 0 var(--sp-3);
}
.es-file-drop__zone {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--sp-4);
  min-height: 11rem;
  padding: var(--sp-8) var(--sp-6);
  text-align: center;
  border: 2px dashed var(--n-300);
  border-radius: var(--r-lg);
  background: linear-gradient(180deg, var(--n-50) 0%, var(--white) 55%);
  box-shadow: none;
  transition:
    border-color var(--dur-sm) var(--ease),
    background var(--dur-sm) var(--ease),
    box-shadow var(--dur-sm) var(--ease);
}
.es-file-drop:hover .es-file-drop__zone,
.es-file-drop:focus-within .es-file-drop__zone {
  border-color: var(--brand);
  background: linear-gradient(180deg, var(--brand-light) 0%, var(--white) 50%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.95), 0 0 0 1px rgba(21, 93, 252, 0.08);
}
.es-file-drop:focus-within .es-file-drop__zone {
  outline: none;
  box-shadow: 0 0 0 3px var(--brand-light), inset 0 1px 0 rgba(255, 255, 255, 0.95);
}
.es-file-drop--drag .es-file-drop__zone {
  border-color: var(--brand);
  border-style: solid;
  background: var(--brand-light);
  box-shadow: var(--shadow-md);
}
.es-file-drop--has-file .es-file-drop__zone {
  border-style: solid;
  border-color: var(--green-border);
  background: linear-gradient(180deg, var(--green-bg) 0%, var(--white) 45%);
}
.es-file-drop__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3.25rem;
  height: 3.25rem;
  border-radius: var(--r-lg);
  background: var(--white);
  border: 1px solid var(--border);
  color: var(--brand);
  box-shadow: var(--shadow-xs);
}
.es-file-drop__icon svg {
  width: 1.75rem;
  height: 1.75rem;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.es-file-drop__text {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  max-width: 22rem;
}
.es-file-drop__cta {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--primary);
  letter-spacing: -0.01em;
}
.es-file-drop__sub {
  font-size: var(--text-sm);
  color: var(--n-500);
  line-height: 1.5;
}
.es-file-drop__filename {
  display: block;
  margin-top: var(--sp-2);
  padding: var(--sp-2) var(--sp-4);
  max-width: 100%;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--green);
  word-break: break-all;
  min-height: 1.5rem;
}
.es-file-drop__filename:empty {
  display: none;
}
.es-file-drop--has-file .es-file-drop__filename:not(:empty) {
  display: block;
}
.admin-crm-form-group--spaced {
  margin-top: var(--sp-6);
}

.dash-saas-banner {
  margin-bottom: var(--sp-5); padding: var(--sp-4) var(--sp-5);
  background: linear-gradient(90deg, #FEF3C7 0%, #FFFBEB 100%);
  border: 1px solid #FCD34D; border-radius: var(--r-lg);
  color: #78350F; font-size: var(--text-sm); line-height: 1.5;
}

.dash-listing-incomplete-banner {
  margin-bottom: var(--sp-5);
  padding: var(--sp-4) var(--sp-5);
  background: linear-gradient(90deg, #eff6ff 0%, #f8fafc 100%);
  border: 1px solid #bfdbfe;
  border-radius: var(--r-lg);
  color: #1e3a5f;
  font-size: var(--text-sm);
  line-height: 1.5;
}
.dash-listing-incomplete-banner__layout {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
}
.dash-listing-incomplete-banner__icon {
  flex: 0 0 auto;
  color: #2563eb;
  line-height: 0;
  margin-top: 0.12rem;
}
.dash-listing-incomplete-banner__icon svg {
  display: block;
}
.dash-listing-incomplete-banner__body {
  flex: 1;
  min-width: 0;
}
.dash-listing-incomplete-banner__lead {
  font-weight: 400;
}
.dash-listing-incomplete-banner__list {
  margin: 0.5rem 0 0;
  padding-left: 1.25rem;
}
.dash-listing-incomplete-banner__list li {
  margin: 0.2rem 0;
}
.dash-listing-incomplete-banner__list a {
  font-weight: 600;
  color: var(--primary);
}
.dash-listing-incomplete-banner__meta {
  color: var(--text-muted);
  font-size: 0.92em;
}

/* ---- Dashboard layout ----------------------------------------------------- */
.dashboard-header { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--sp-4); padding-bottom: var(--sp-6); border-bottom: 1px solid var(--border); margin-bottom: var(--sp-8); flex-wrap: wrap; }
.dashboard-header__greeting {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--primary);
}
.dashboard-actions { display: flex; gap: var(--sp-3); flex-wrap: wrap; }

/* Professional dashboard sub-navigation */
.pro-dash-subnav {
  margin-bottom: var(--sp-6);
  padding: var(--sp-2) 0;
  border-bottom: 1px solid var(--border);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-1);
}
.pro-dash-subnav__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-1);
}
.pro-dash-subnav__link {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  height: 2.25rem;
  padding-inline: var(--sp-3);
  border-radius: var(--r-xs);
  color: var(--n-600);
  text-decoration: none;
  font-size: var(--text-sm);
  font-weight: 600;
  transition: background var(--dur-sm) var(--ease), color var(--dur-sm) var(--ease);
}
.pro-dash-subnav__link:hover {
  background: var(--n-100);
  color: var(--primary);
}
.pro-dash-subnav__link.is-active {
  background: var(--brand-light);
  color: var(--primary);
}
.pro-dash-subnav__link svg {
  flex-shrink: 0;
}
.pro-dash-subnav__dropdown {
  position: relative;
}
.pro-dash-subnav__summary {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  height: 2.25rem;
  padding-inline: var(--sp-3);
  padding-right: 1.65rem;
  border: none;
  margin: 0;
  border-radius: var(--r-xs);
  cursor: pointer;
  font: inherit;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--n-600);
  background: transparent;
  list-style: none;
  transition: background var(--dur-sm) var(--ease), color var(--dur-sm) var(--ease);
}
.pro-dash-subnav__summary::-webkit-details-marker {
  display: none;
}
.pro-dash-subnav__summary::after {
  content: '';
  position: absolute;
  right: 0.5rem;
  top: 50%;
  margin-top: -2px;
  border: 4px solid transparent;
  border-top-color: currentColor;
  opacity: 0.65;
}
.pro-dash-subnav__dropdown:hover .pro-dash-subnav__summary,
.pro-dash-subnav__dropdown:focus-within .pro-dash-subnav__summary,
.pro-dash-subnav__dropdown[open] > .pro-dash-subnav__summary {
  background: var(--n-100);
  color: var(--primary);
}
.pro-dash-subnav__summary.is-active {
  background: var(--brand-light);
  color: var(--primary);
}
.pro-dash-subnav__summary svg {
  flex-shrink: 0;
}
.pro-dash-subnav__dropdown > .pro-dash-subnav__panel {
  position: absolute;
  z-index: 30;
  top: 100%;
  left: 0;
  min-width: 12rem;
  margin-top: var(--sp-1);
  padding: var(--sp-2);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}
.pro-dash-subnav__panel a {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-xs);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--n-600);
  text-decoration: none;
  transition: background var(--dur-sm) var(--ease), color var(--dur-sm) var(--ease);
}
.pro-dash-subnav__panel a svg {
  flex-shrink: 0;
}
.pro-dash-subnav__panel a:hover {
  background: var(--n-100);
  color: var(--primary);
}
.pro-dash-subnav__panel a.is-active {
  background: var(--brand-light);
  color: var(--primary);
}
.pro-dash-subnav__panel a.pro-dash-subnav__panel-cta {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: var(--sp-2);
  width: 100%;
  box-sizing: border-box;
  font-weight: 600;
  color: #fff;
  background: var(--brand);
}
.pro-dash-subnav__panel a.pro-dash-subnav__panel-cta svg {
  flex-shrink: 0;
}
.pro-dash-subnav__panel a.pro-dash-subnav__panel-cta:hover {
  background: var(--brand-hover);
  color: #fff;
}
.pro-dash-subnav__panel a.pro-dash-subnav__panel-cta.is-active {
  background: var(--brand-hover);
  color: #fff;
}
.pro-dash-subnav__panel-divider {
  border: 0;
  border-top: 1px solid var(--border);
  margin: var(--sp-1) 0;
  align-self: stretch;
}
.pro-dash-placeholder .pro-dash-subnav {
  margin-top: calc(-1 * var(--sp-2));
}

/* Professional dashboard: Help & Guides documentation */
.pro-help-guides .pro-dash-subnav {
  margin-top: calc(-1 * var(--sp-2));
}
.pro-help-guides__hero {
  margin-bottom: var(--sp-6);
  max-width: 48rem;
}
.pro-help-guides .dh-page-header {
  margin-bottom: var(--sp-6);
  max-width: 48rem;
}
.pro-help-guides .dh-page-header .dh-breadcrumb {
  margin-bottom: var(--sp-2);
}
.pro-help-guides__hero--doc {
  padding-bottom: var(--sp-5);
  margin-bottom: var(--sp-5);
  border-bottom: 1px solid var(--border);
  background: linear-gradient(135deg, var(--n-50, #f8fafc) 0%, transparent 55%);
  border-radius: var(--r-lg);
  padding: var(--sp-5) var(--sp-6);
  margin-left: calc(-1 * var(--sp-2));
  margin-right: calc(-1 * var(--sp-2));
}
.pro-help-guides__toc-search {
  margin: 0 0 var(--sp-4);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--border);
}
.pro-help-guides__toc-search-field {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-1) 0;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  transition: box-shadow 0.15s ease;
}
.pro-help-guides__toc-search-field:focus-within {
  box-shadow: none;
}
.pro-help-guides__toc-search-icon {
  flex-shrink: 0;
  display: flex;
  color: var(--n-500);
  opacity: 0.85;
}
.pro-help-guides__toc-search-icon svg {
  display: block;
}
.pro-help-guides__toc-search-input {
  flex: 1;
  min-width: 0;
  border: 0;
  padding: var(--sp-2) 0;
  margin: 0;
  font: inherit;
  font-size: var(--text-sm);
  background: transparent;
  color: var(--n-800);
}
.pro-help-guides__toc-search-input::placeholder {
  color: var(--n-500);
}
.pro-help-guides__toc-search-input:focus {
  outline: none;
}
.pro-help-guides__toc-search-input:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
  border-radius: var(--r-sm);
}
.pro-help-guides__toc-search-status {
  margin: var(--sp-2) 0 0;
  font-size: var(--text-xs);
  line-height: 1.4;
  color: var(--n-600);
}
.pro-help-guides__layout {
  display: grid;
  grid-template-columns: min(16.5rem, 36%) 1fr;
  gap: var(--sp-8);
  align-items: start;
}
.pro-help-guides__toc {
  position: sticky;
  top: calc(3.75rem + var(--sp-4));
  max-height: calc(100vh - 5rem);
  overflow: auto;
  padding: var(--sp-5);
  background: linear-gradient(160deg, var(--n-50, #f8fafc) 0%, var(--white) 100%);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  font-size: var(--text-sm);
  box-shadow: none;
}
.pro-help-guides__toc-title {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--n-500);
}
.pro-help-guides__toc-list {
  margin: 0;
  padding-left: 1.1rem;
  line-height: 1.55;
}
.pro-help-guides__toc-list > li {
  margin-bottom: var(--sp-2);
}
.pro-help-guides__toc-list > li:last-child {
  margin-bottom: 0;
}
.pro-help-guides__toc-list--nested > li {
  margin-bottom: var(--sp-1);
}
.pro-help-guides__toc-branch-label {
  display: block;
  font-weight: 600;
  color: var(--n-700);
  margin-bottom: var(--sp-1);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.pro-help-guides__toc-list ul {
  margin: var(--sp-2) 0 var(--sp-3);
  padding-left: 1rem;
  list-style: disc;
}
.pro-help-guides__toc li.is-help-hidden,
.pro-help-guides__section.is-help-hidden {
  display: none !important;
}
.pro-help-guides__toc-list a {
  color: var(--primary);
  text-decoration: none;
  font-weight: 500;
}
.pro-help-guides__toc-list a:hover {
  text-decoration: underline;
}
.pro-help-guides__body {
  min-width: 0;
  max-width: min(52rem, 100%);
}
.pro-help-guides__body--cms {
  max-width: min(52rem, 100%);
  padding: var(--sp-6) var(--sp-7);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: none;
}
.pro-help-guides__section-title-fallback {
  color: var(--primary);
}
.pro-help-guides__cms-html {
  font-size: var(--text-base);
}
.pro-help-guides__cms-html > :first-child {
  margin-top: 0;
}
.pro-help-guides__section h4 {
  margin-top: var(--sp-4);
  margin-bottom: var(--sp-2);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--n-800);
  scroll-margin-top: calc(3.75rem + var(--sp-3));
}
.pro-help-guides__dl {
  margin: var(--sp-3) 0;
}
.pro-help-guides__dl dt {
  margin-top: var(--sp-3);
  font-weight: 600;
  color: var(--n-800);
}
.pro-help-guides__dl dt:first-child {
  margin-top: 0;
}
.pro-help-guides__dl dd {
  margin: var(--sp-1) 0 0 0;
  padding-left: 0;
  line-height: 1.55;
  color: var(--n-700);
}
.pro-help-guides__note {
  margin-top: var(--sp-5);
  padding: var(--sp-4);
  background: var(--brand-light);
  border-left: 4px solid var(--brand);
  border-radius: 0 var(--r) var(--r) 0;
  font-size: var(--text-sm);
  line-height: 1.55;
  color: var(--n-700);
}
.pro-help-guides__note strong {
  color: var(--primary);
}
.pro-help-guides__numbered {
  margin: var(--sp-3) 0 var(--sp-4);
  padding-left: 1.35rem;
  line-height: 1.65;
  color: var(--n-700);
}
.pro-help-guides__numbered > li {
  margin-bottom: var(--sp-2);
}
.pro-help-guides__numbered ul {
  margin: var(--sp-2) 0 0;
  padding-left: 1.25rem;
  list-style: disc;
}
.pro-help-guides__section {
  padding-bottom: var(--sp-10);
  margin-bottom: var(--sp-8);
  border-bottom: 1px solid var(--border);
}
.pro-help-guides__section:last-of-type {
  border-bottom: none;
  margin-bottom: 0;
}
.pro-help-guides__section h2 {
  margin-top: 0;
  margin-bottom: var(--sp-4);
  font-size: 1.35rem;
  scroll-margin-top: calc(3.75rem + var(--sp-3));
}
.pro-help-guides__section h3 {
  margin-top: var(--sp-6);
  margin-bottom: var(--sp-2);
  font-size: 1.05rem;
  scroll-margin-top: calc(3.75rem + var(--sp-3));
}
.pro-help-guides__section p,
.pro-help-guides__section li {
  color: var(--n-700);
  line-height: 1.6;
}
.pro-help-guides__section ul,
.pro-help-guides__section ol {
  margin: var(--sp-3) 0;
  padding-left: 1.35rem;
}
.pro-help-guides__steps {
  counter-reset: hgstep;
  list-style: none;
  padding-left: 0;
}
.pro-help-guides__steps li {
  position: relative;
  padding-left: 2.25rem;
  margin-bottom: var(--sp-4);
}
.pro-help-guides__steps li::before {
  counter-increment: hgstep;
  content: counter(hgstep);
  position: absolute;
  left: 0;
  top: 0.1rem;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  background: var(--brand-light);
  color: var(--primary);
  font-size: var(--text-xs);
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pro-help-guides__footer-actions {
  margin-top: var(--sp-8);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border);
}
@media (max-width: 900px) {
  .pro-help-guides__layout {
    grid-template-columns: 1fr;
  }
  .pro-help-guides__toc {
    position: static;
  }
}

/* Pro dashboard: site header — mobile “Site menu” dropdown */
.site-dash-mainnav-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  gap: var(--sp-2);
  min-height: 2.5rem;
  padding: 0 var(--sp-3);
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
  background: var(--white);
  font: inherit;
  color: var(--n-600);
  cursor: pointer;
  flex-shrink: 0;
  line-height: 0;
  transition: background var(--dur-sm) var(--ease), border-color var(--dur-sm) var(--ease);
}
.site-dash-mainnav-toggle__label {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--n-700);
  line-height: 1.2;
}
.site-dash-mainnav-toggle__glyph {
  display: block;
  flex-shrink: 0;
}
.site-dash-mainnav-toggle:hover {
  background: var(--n-100);
  border-color: var(--n-300);
}

/* Pro dashboard: workspace — mobile mega-dropdown toggle */
.pro-dash-subnav__mega-toggle {
  display: none;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  box-sizing: border-box;
  min-height: 2.75rem;
  padding: var(--sp-3) var(--sp-4);
  margin: 0;
  border: 1px solid var(--border);
  border-radius: var(--r);
  background: var(--white);
  font: inherit;
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--primary);
  cursor: pointer;
  text-align: left;
  transition: background var(--dur-sm) var(--ease), border-color var(--dur-sm) var(--ease);
}
.pro-dash-subnav__mega-toggle::after {
  content: '';
  flex-shrink: 0;
  margin-left: var(--sp-2);
  border: 5px solid transparent;
  border-top-color: var(--n-500);
  margin-top: 0.2rem;
}
.pro-dash-subnav.is-mega-open .pro-dash-subnav__mega-toggle::after {
  margin-top: 0.35rem;
  border-top-color: transparent;
  border-bottom-color: var(--n-500);
  margin-bottom: 0.15rem;
}
.pro-dash-subnav__mega-toggle:hover {
  background: var(--n-50);
}

.pro-platform-inactive-banner {
  margin-bottom: var(--sp-6);
  padding: var(--sp-4) var(--sp-5);
  background: linear-gradient(135deg, #fff7ed 0%, #ffedd5 100%);
  border: 1px solid #fdba74;
  border-radius: var(--r-lg);
  color: var(--n-800);
}
.pro-platform-inactive-banner__title {
  display: block;
  margin-bottom: var(--sp-2);
  font-size: var(--text-sm);
}
.pro-platform-inactive-banner__body {
  margin: 0 0 var(--sp-3);
  font-size: var(--text-sm);
  line-height: 1.55;
  color: var(--n-700);
}
.pro-platform-inactive-banner__actions {
  margin: 0;
}

@media (min-width: 769px) {
  body.is-dashboard-shell .site-dash-mainnav-dropdown,
  body.is-public-site-shell .site-dash-mainnav-dropdown,
  body.is-shopper-dashboard .site-dash-mainnav-dropdown {
    display: contents;
  }
  body.is-dashboard-shell .site-dash-mainnav-toggle,
  body.is-public-site-shell .site-dash-mainnav-toggle,
  body.is-shopper-dashboard .site-dash-mainnav-toggle {
    display: none !important;
  }
  body.is-dashboard-shell .pro-dash-subnav__mega-panel {
    display: contents;
  }
  body.is-dashboard-shell .pro-dash-subnav__mega-panel .pro-dash-subnav__inner {
    display: contents;
  }
  body.is-dashboard-shell .pro-dash-subnav__mega-toggle {
    display: none !important;
  }
  body.is-dashboard-shell .header-inner {
    height: auto;
    min-height: 3.75rem;
    padding-block: var(--sp-2);
  }
  body.is-dashboard-shell .nav.nav--pro-workspace {
    flex-wrap: wrap;
    justify-content: flex-end;
    row-gap: var(--sp-1);
    column-gap: var(--sp-1);
  }

  /* Public marketing header: logo column | nav (Explore + Search … Hire + auth + List) */
  body.is-public-site-shell .header-inner {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    column-gap: clamp(var(--sp-4), 3vw, var(--sp-10));
  }
  body.is-public-site-shell .header-brand-row {
    flex: 0 1 auto;
    min-width: 0;
    width: auto;
  }
  body.is-public-site-shell .nav.nav--public-site {
    margin-left: 0;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-start;
    min-width: 0;
    width: 100%;
    gap: clamp(var(--sp-6), 6vw, var(--sp-12));
  }
  body.is-public-site-shell .nav-public__lead {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    gap: var(--sp-1);
  }
  body.is-public-site-shell .nav-public__tail {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: var(--sp-1);
    margin-left: auto;
    min-width: 0;
  }

  /*
   * Homepage (sticky + public): Explore / Search Inventory live in .header-public-search-cluster next to
   * the search field so they move with the same flex animation as the bar (no separate nav sibling jump).
   * Hire / auth / List stay in .nav.nav--public-site at the trailing edge (margin-left: auto on nav).
   */
  body.has-sticky-hero-search.is-public-site-shell .header-inner {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    gap: clamp(var(--sp-3), 2vw, var(--sp-6));
    min-width: 0;
  }
  body.has-sticky-hero-search.is-public-site-shell .header-brand-row {
    display: contents;
  }
  body.has-sticky-hero-search.is-public-site-shell .header-public-search-cluster {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    flex: 1 1 0%;
    min-width: 0;
    gap: clamp(var(--sp-3), 2vw, var(--sp-6));
    justify-content: flex-start;
  }
  body.has-sticky-hero-search.is-public-site-shell .header-public-search-cluster .header-hero-search {
    flex: 1 1 0%;
    min-width: 0;
  }
  body.has-sticky-hero-search.is-public-site-shell .header-public-search-cluster .header-hero-search.is-pinned {
    max-width: min(100%, 100rem);
  }
  body.has-sticky-hero-search.is-public-site-shell .nav-public__lead--cluster {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    gap: var(--sp-1);
    white-space: nowrap;
  }
  /* Same treatment as .nav a (cluster sits outside <nav>, so it does not inherit nav link styles) */
  body.has-sticky-hero-search.is-public-site-shell .header-public-search-cluster .nav-public__lead--cluster a {
    display: inline-flex;
    align-items: center;
    height: 2.25rem;
    padding-inline: var(--sp-3);
    border-radius: var(--r-sm);
    color: #314158;
    font-size: var(--text-sm);
    font-weight: 500;
    text-decoration: none;
    white-space: nowrap;
    letter-spacing: -0.01em;
    transition: background var(--dur-sm) var(--ease), color var(--dur-sm) var(--ease);
  }
  body.has-sticky-hero-search.is-public-site-shell .header-public-search-cluster .nav-public__lead--cluster a:hover {
    background: var(--n-100);
    color: var(--primary);
  }
  body.has-sticky-hero-search.is-public-site-shell .header-public-search-cluster .nav-public__lead--cluster a::after {
    display: none;
  }
  body.has-sticky-hero-search.is-public-site-shell .nav-public__lead--drawer {
    display: none !important;
  }
  body.has-sticky-hero-search.is-public-site-shell .nav.nav--public-site {
    flex: 0 0 auto;
    width: auto;
    min-width: 0;
    margin-left: auto;
    gap: var(--sp-1);
    justify-content: flex-end;
  }
  body.has-sticky-hero-search.is-public-site-shell .nav-public__tail {
    margin-left: 0;
  }
}

/* Pro company /dashboard*, public site, shopper: mobile — left slide drawer + backdrop */
.site-nav-drawer-backdrop {
  display: none;
}

html.is-site-nav-open,
body.is-site-nav-open {
  overflow: hidden;
  overscroll-behavior: none;
}
@media (max-width: 768px) {
  body.is-dashboard-shell .site-header,
  body.is-public-site-shell .site-header,
  body.is-shopper-dashboard .site-header {
    z-index: 5020;
  }
  .site-nav-drawer-backdrop {
    display: block;
    position: fixed;
    inset: 0;
    z-index: 5000;
    background: rgba(15, 23, 42, 0.44);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.22s ease, visibility 0.22s;
  }
  body.is-site-nav-open .site-nav-drawer-backdrop {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }

  body.is-dashboard-shell .header-brand-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-3);
    width: 100%;
  }
  body.is-dashboard-shell .site-dash-mainnav-toggle {
    display: inline-flex;
  }
  body.is-dashboard-shell .site-dash-mainnav-dropdown,
  body.is-public-site-shell .site-dash-mainnav-dropdown,
  body.is-shopper-dashboard .site-dash-mainnav-dropdown {
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: min(20rem, 88vw);
    max-width: 100%;
    margin: 0;
    padding: var(--sp-4);
    padding-top: max(var(--sp-4), env(safe-area-inset-top));
    padding-bottom: max(var(--sp-6), env(safe-area-inset-bottom));
    background: var(--white);
    border: none;
    border-right: 1px solid var(--border);
    border-radius: 0;
    box-shadow: var(--shadow-lg);
    z-index: 5010;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    transform: translate3d(-105%, 0, 0);
    transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
    pointer-events: none;
  }
  body.is-dashboard-shell .site-header.is-site-nav-open .site-dash-mainnav-dropdown,
  body.is-public-site-shell .site-header.is-site-nav-open .site-dash-mainnav-dropdown,
  body.is-shopper-dashboard .site-header.is-site-nav-open .site-dash-mainnav-dropdown {
    transform: translate3d(0, 0, 0);
    pointer-events: auto;
  }

  body.is-public-site-shell .header-brand-row,
  body.is-shopper-dashboard .header-brand-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-3);
    width: 100%;
  }
  body.is-public-site-shell .site-dash-mainnav-toggle,
  body.is-shopper-dashboard .site-dash-mainnav-toggle {
    display: inline-flex;
  }
  body.is-public-site-shell .nav.nav--dash-dropdown,
  body.is-shopper-dashboard .nav.nav--dash-dropdown {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    gap: var(--sp-1);
    overflow: visible;
    flex-wrap: nowrap;
  }
  body.is-public-site-shell .nav.nav--public-site {
    margin-left: 0;
  }
  body.is-public-site-shell .nav.nav--dash-dropdown .nav-public__lead,
  body.is-public-site-shell .nav.nav--dash-dropdown .nav-public__tail {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    gap: var(--sp-1);
  }
  body.is-public-site-shell .nav.nav--dash-dropdown .nav-public__tail {
    padding-top: var(--sp-2);
    margin-top: var(--sp-1);
  }
  body.is-public-site-shell .nav.nav--dash-dropdown .nav-public__lead a,
  body.is-public-site-shell .nav.nav--dash-dropdown .nav-public__tail > a,
  body.is-public-site-shell .nav.nav--dash-dropdown .nav-public__tail > .nav-cta {
    width: 100%;
    box-sizing: border-box;
    justify-content: flex-start;
  }
  body.is-public-site-shell .nav.nav--dash-dropdown > a,
  body.is-public-site-shell .nav.nav--dash-dropdown > .nav-cta,
  body.is-shopper-dashboard .nav.nav--dash-dropdown > a,
  body.is-shopper-dashboard .nav.nav--dash-dropdown > .nav-cta {
    width: 100%;
    box-sizing: border-box;
    justify-content: flex-start;
  }
  body.is-public-site-shell .nav.nav--dash-dropdown form.inline,
  body.is-shopper-dashboard .nav.nav--dash-dropdown form.inline {
    display: block;
    width: 100%;
  }
  body.is-public-site-shell .nav.nav--dash-dropdown .link-btn,
  body.is-shopper-dashboard .nav.nav--dash-dropdown .link-btn {
    width: 100%;
    justify-content: flex-start;
    box-sizing: border-box;
  }
  body.is-public-site-shell .nav.nav--dash-dropdown > details.site-header-account-menu,
  body.is-public-site-shell .nav.nav--dash-dropdown .nav-public__tail > details.site-header-account-menu,
  body.is-shopper-dashboard .nav.nav--dash-dropdown > details.site-header-account-menu {
    width: 100%;
  }
  body.is-public-site-shell .nav.nav--dash-dropdown .site-header-account-menu__trigger,
  body.is-shopper-dashboard .nav.nav--dash-dropdown .site-header-account-menu__trigger {
    width: 100%;
    justify-content: flex-start;
    padding-inline: var(--sp-3);
    border-radius: var(--r-sm);
    gap: var(--sp-2);
  }
  body.is-public-site-shell .nav.nav--dash-dropdown .site-header-account-menu__panel,
  body.is-shopper-dashboard .nav.nav--dash-dropdown .site-header-account-menu__panel {
    position: static;
    width: 100%;
    margin-top: var(--sp-1);
    box-shadow: var(--shadow-sm);
  }
  body.is-public-site-shell .header-inner,
  body.is-shopper-dashboard .header-inner {
    align-items: flex-start;
    row-gap: var(--sp-2);
  }
  body.is-dashboard-shell .nav--dash-dropdown {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    gap: var(--sp-1);
    overflow: visible;
    flex-wrap: nowrap;
  }
  body.is-dashboard-shell .nav--dash-dropdown > a,
  body.is-dashboard-shell .nav--dash-dropdown > .nav-cta {
    width: 100%;
    box-sizing: border-box;
    justify-content: flex-start;
  }
  body.is-dashboard-shell .nav--dash-dropdown > details.pro-dash-subnav__dropdown {
    width: 100%;
  }
  body.is-dashboard-shell .nav--dash-dropdown .pro-dash-subnav__link,
  body.is-dashboard-shell .nav--dash-dropdown .pro-dash-subnav__summary {
    width: 100%;
    box-sizing: border-box;
    justify-content: flex-start;
  }
  body.is-dashboard-shell .nav--dash-dropdown form.inline {
    display: block;
    width: 100%;
  }
  body.is-dashboard-shell .nav--dash-dropdown .link-btn {
    width: 100%;
    justify-content: flex-start;
    box-sizing: border-box;
  }
  body.is-dashboard-shell .nav--dash-dropdown > details.site-header-account-menu {
    width: 100%;
  }
  body.is-dashboard-shell .nav--dash-dropdown .site-header-account-menu__trigger {
    width: 100%;
    justify-content: flex-start;
    padding-inline: var(--sp-3);
    border-radius: var(--r-sm);
    gap: var(--sp-2);
  }
  body.is-dashboard-shell .nav--dash-dropdown .site-header-account-menu__panel {
    position: static;
    width: 100%;
    margin-top: var(--sp-1);
    box-shadow: var(--shadow-sm);
  }

  body.is-dashboard-shell .header-inner {
    align-items: flex-start;
    row-gap: var(--sp-2);
  }
  body.is-dashboard-shell .pro-dash-subnav {
    flex-direction: column;
    align-items: stretch;
    margin-bottom: var(--sp-4);
    padding-block: 0;
    border-bottom: 0;
    overflow: visible;
  }
  body.is-dashboard-shell .pro-dash-placeholder .pro-dash-subnav {
    margin-top: 0;
  }
  body.is-dashboard-shell .pro-dash-subnav__mega-toggle {
    display: flex;
  }
  body.is-dashboard-shell .pro-dash-subnav__mega-panel {
    display: none;
    margin-top: var(--sp-2);
    padding: var(--sp-3);
    background: var(--n-50);
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
  }
  body.is-dashboard-shell .pro-dash-subnav.is-mega-open .pro-dash-subnav__mega-panel {
    display: block;
  }
  body.is-dashboard-shell .pro-dash-subnav__inner {
    flex-direction: column;
    align-items: stretch;
    flex-wrap: nowrap;
    gap: var(--sp-2);
    width: 100%;
  }
  body.is-dashboard-shell .pro-dash-subnav__link,
  body.is-dashboard-shell .pro-dash-subnav__summary {
    width: 100%;
    box-sizing: border-box;
    justify-content: flex-start;
  }
  body.is-dashboard-shell .pro-dash-subnav__dropdown {
    width: 100%;
  }
  body.is-dashboard-shell .pro-dash-subnav__dropdown > .pro-dash-subnav__panel {
    position: static;
    min-width: 0;
    margin-top: var(--sp-1);
    margin-left: var(--sp-2);
    box-shadow: none;
    border: 1px solid var(--n-200);
    border-radius: var(--r-sm);
  }
}

/* Lead generation – contact list signup (dashboard) */
.contact-list-lead .cl-lead-subscribers-top-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-3);
  margin: 0 0 var(--sp-4);
  width: 100%;
  box-sizing: border-box;
}
@media (min-width: 520px) {
  .contact-list-lead .cl-lead-subscribers-top-actions {
    gap: var(--sp-4);
  }
}
.contact-list-lead .cl-lead-export-dropdown {
  position: relative;
  display: inline-block;
  align-self: flex-start;
  flex-shrink: 0;
  max-width: 100%;
}
.contact-list-lead .cl-lead-export-dropdown__summary {
  list-style: none;
  list-style-type: none;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}
.contact-list-lead .cl-lead-export-dropdown__summary::-webkit-details-marker {
  display: none;
}
.contact-list-lead .cl-lead-export-dropdown__summary::marker {
  content: none;
  display: none;
}
.contact-list-lead .cl-lead-export-dropdown__summary-label {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  white-space: nowrap;
}
.contact-list-lead .cl-lead-export-dropdown[open] .cl-lead-export-dropdown__summary {
  z-index: 1;
  position: relative;
}
.contact-list-lead .cl-lead-export-dropdown[open] .cl-lead-export-dropdown__summary > svg:last-child {
  transform: rotate(180deg);
}
.contact-list-lead .cl-lead-export-dropdown__summary > svg:last-child {
  transition: transform 0.15s ease;
  flex-shrink: 0;
  opacity: 0.9;
}
.contact-list-lead .cl-lead-export-dropdown__panel {
  position: absolute;
  z-index: 20;
  right: 0;
  top: calc(100% + 4px);
  min-width: 10.5rem;
  padding: 0.25rem 0;
  margin: 0;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r, 6px);
  box-shadow: var(--shadow-md);
  display: flex;
  flex-direction: column;
  gap: 0;
  box-sizing: border-box;
}
.contact-list-lead .cl-lead-export-dropdown__item {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin: 0;
  padding: 0.6rem 0.85rem;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text, #0f172a);
  text-decoration: none;
  line-height: 1.25;
  border: none;
  background: transparent;
  width: 100%;
  text-align: left;
  font-family: inherit;
  box-sizing: border-box;
  cursor: pointer;
}
.contact-list-lead .cl-lead-export-dropdown__item:hover {
  background: var(--n-50, #f8fafc);
  text-decoration: none;
  color: var(--primary);
}
.contact-list-lead .cl-lead-export-dropdown__item--excel {
  color: #fff;
  background: var(--green, #10b981);
  border-top: 1px solid rgba(0, 0, 0, 0.06);
}
.contact-list-lead .cl-lead-export-dropdown__item--excel:hover {
  background: #047857;
  color: #fff;
}
.contact-list-lead .cl-lead-export-dropdown__item--excel svg {
  color: inherit;
}
.contact-list-lead .cl-lead-export-dropdown__item svg {
  flex-shrink: 0;
}
.contact-list-lead .dh-page-header {
  margin-bottom: var(--sp-8);
  padding-bottom: var(--sp-6);
  border-bottom: 1px solid var(--border);
}
.contact-list-lead .dh-page-header .dh-breadcrumb {
  margin-bottom: var(--sp-3);
}
.contact-list-lead .dh-page-subtitle {
  max-width: calc(40rem * 1.2);
}
.contact-list-lead .cl-lead-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--sp-6) var(--sp-7);
  margin-bottom: var(--sp-6);
}
@media (min-width: 640px) {
  .contact-list-lead .cl-lead-card {
    padding: var(--sp-8) var(--sp-10);
  }
}
.contact-list-lead .cl-lead-card__section {
  margin: 0;
  padding: 0;
  border: none;
}
.contact-list-lead .cl-lead-card__heading {
  font-size: var(--text-lg);
  font-weight: 700;
  margin: 0 0 var(--sp-2);
  color: var(--primary);
  letter-spacing: -0.02em;
}
.contact-list-lead .cl-lead-card__heading--flush {
  font-size: var(--text-xl);
  margin-bottom: var(--sp-4);
}
.contact-list-lead .cl-lead-card__intro {
  max-width: calc(38rem * 1.2);
  margin: 0 0 var(--sp-8);
  line-height: 1.6;
  color: var(--text);
  font-size: var(--text-sm);
}
.contact-list-lead .cl-lead-action-btn {
  min-height: 2.75rem;
  padding-inline: var(--sp-6);
  justify-content: center;
  font-weight: 600;
}
.contact-list-lead .cl-lead-action-btn--print {
  box-shadow: none;
}
.contact-list-lead .cl-lead-action-btn--print:hover {
  box-shadow: none;
}
.contact-list-lead .cl-lead-action-btn--excel {
  background: var(--green);
  border-color: var(--green);
  color: #fff;
}
.contact-list-lead .cl-lead-action-btn--excel:hover {
  background: #047857;
  border-color: #047857;
  color: #fff;
  box-shadow: none;
}
.contact-list-lead .cl-lead-action-btn--save {
  margin-top: var(--sp-2);
}
.contact-list-lead .cl-lead-action-btn--ghost {
  background: transparent;
  border-color: var(--n-300);
  color: var(--n-700);
}
.contact-list-lead .cl-lead-action-btn--ghost:hover {
  background: var(--n-50);
  border-color: var(--n-400);
  color: var(--primary);
}
.contact-list-lead .cl-lead-url-block {
  margin: 0 0 var(--sp-8);
  padding: var(--sp-4) var(--sp-5);
  background: var(--n-50);
  border: 1px solid var(--border);
  border-radius: var(--r);
}
.contact-list-lead .cl-lead-url-block__label {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--n-600);
  margin: 0 0 var(--sp-2);
}
.contact-list-lead .cl-lead-url-block__value {
  margin: 0;
  font-size: var(--text-sm);
  line-height: 1.5;
  word-break: break-all;
}
.contact-list-lead .cl-lead-url-block__value a {
  color: var(--brand);
  font-weight: 600;
  text-decoration: none;
}
.contact-list-lead .cl-lead-url-block__value a:hover {
  text-decoration: underline;
}
.contact-list-lead .cl-lead-url-block__hint {
  margin: var(--sp-3) 0 0;
  font-size: var(--text-xs);
}
.contact-list-lead .cl-lead-headline-block {
  margin: 0;
  padding-top: var(--sp-8);
  border-top: 1px solid var(--n-100);
}
.contact-list-lead .cl-lead-headline-block__title {
  font-size: var(--text-base);
  font-weight: 700;
  margin: 0 0 var(--sp-2);
  color: var(--primary);
}
.contact-list-lead .cl-lead-headline-block__help {
  margin: 0 0 var(--sp-5);
  max-width: 38rem;
  line-height: 1.5;
}
.contact-list-lead .cl-signup-headline-form {
  max-width: 100%;
  margin: 0;
}
.contact-list-lead .cl-signup-table-section {
  margin: 0;
  padding: 0;
  border: none;
}
.contact-list-lead .cl-lead-empty {
  margin: 0;
  padding: var(--sp-8) var(--sp-4);
  text-align: center;
  background: var(--n-50);
  border: 1px dashed var(--border);
  border-radius: var(--r);
}
.contact-list-lead .cl-lead-table-note {
  margin: 0 0 var(--sp-4);
  max-width: 40rem;
}
.contact-list-lead .cl-lead-footer {
  margin-top: var(--sp-10);
  padding-top: var(--sp-6);
  border-top: 1px solid var(--border);
}
.contact-list-lead .cl-subscribers-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--sp-3) var(--sp-4);
  margin-bottom: var(--sp-5);
}
.contact-list-lead .cl-subscribers-search-field {
  flex: 0 1 auto;
  min-width: min(100%, 12rem);
  max-width: 20rem;
}
.contact-list-lead .cl-subscribers-search {
  width: 100%;
  margin: 0;
}
.contact-list-lead .cl-subscribers-filter-empty {
  margin: 0 0 var(--sp-3);
}
.contact-list-lead .cl-subscribers-pager {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3) var(--sp-4);
  margin: 0 0 var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border: 1px solid var(--border);
  border-radius: var(--r);
  background: var(--n-50);
}
.contact-list-lead .cl-subscribers-pager__range {
  margin: 0;
  flex: 1 1 12rem;
}
.contact-list-lead .cl-subscribers-pager__controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2) var(--sp-3);
}
.contact-list-lead .cl-subscribers-pager__btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.contact-list-lead .cl-subscribers-pager__status {
  margin: 0;
  min-width: 6rem;
  text-align: center;
  font-variant-numeric: tabular-nums;
}
.contact-list-lead .cl-subscribers-heading__title {
  font-size: var(--text-xl);
  font-weight: 700;
  margin: 0;
  flex: 1 1 12rem;
  line-height: 1.3;
  color: var(--primary);
  letter-spacing: -0.02em;
}
.contact-list-lead .cl-subscribers-heading__number {
  display: inline-block;
  margin-right: 0.35em;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: var(--brand);
}
.contact-list-lead .cl-subscribers-table-wrap {
  overflow-x: auto;
  margin-top: var(--sp-2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  background: var(--white);
  box-shadow: none;
}
.contact-list-lead .cl-subscribers-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
  line-height: 1.45;
}
.contact-list-lead .cl-subscribers-table thead th {
  text-align: left;
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--n-600);
  background: linear-gradient(180deg, var(--n-50) 0%, var(--n-100) 100%);
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
}
.contact-list-lead .cl-subscribers-table tbody td {
  padding: var(--sp-3) var(--sp-4);
  vertical-align: top;
  border-bottom: 1px solid var(--n-100);
  color: var(--text);
}
.contact-list-lead .cl-subscribers-table tbody tr:last-child td {
  border-bottom: none;
}
.contact-list-lead .cl-subscribers-table tbody tr.cl-subscribers-row--stripe-a {
  background: var(--white);
}
.contact-list-lead .cl-subscribers-table tbody tr.cl-subscribers-row--stripe-b {
  background: rgba(248, 250, 252, 0.85);
}
.contact-list-lead .cl-subscribers-table tbody tr:hover {
  background: var(--brand-light);
}
.contact-list-lead .cl-subscribers-table__email {
  min-width: 11rem;
  max-width: 22rem;
  word-break: break-word;
}
.contact-list-lead .cl-subscribers-table__phone {
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.contact-list-lead .cl-subscribers-table__date {
  white-space: nowrap;
  font-size: var(--text-xs);
  color: var(--n-700);
}
.contact-list-lead .cl-subscribers-table__date time {
  font-variant-numeric: tabular-nums;
}

/* Lead generation — narrow viewports: dense “micro” scale */
@media (max-width: 767px) {
  body.is-dashboard-shell .main.shell > .form-panel.contact-list-lead {
    padding: 0.5rem 0.5rem;
  }
  body.is-dashboard-shell .contact-list-lead .dh-breadcrumb {
    font-size: 0.625rem;
    line-height: 1.2;
    margin-bottom: 0.25rem;
  }
  body.is-dashboard-shell .contact-list-lead .dh-breadcrumb a,
  body.is-dashboard-shell .contact-list-lead .dh-breadcrumb__current {
    font-size: inherit;
  }
  body.is-dashboard-shell .contact-list-lead .dh-page-title {
    font-size: 1.0625rem;
    line-height: 1.25;
    letter-spacing: -0.03em;
  }
  body.is-dashboard-shell.is-pro-dashboard .contact-list-lead .dh-page-title {
    font-size: 1.0625rem;
    line-height: 1.25;
  }
  body.is-dashboard-shell .contact-list-lead .dh-page-subtitle {
    font-size: 0.6875rem;
    line-height: 1.35;
    max-width: none;
  }
  body.is-dashboard-shell.is-pro-dashboard .contact-list-lead .dh-page-subtitle {
    font-size: 0.6875rem;
    line-height: 1.35;
  }
  .contact-list-lead .dh-page-header {
    margin-bottom: 0.5rem;
    padding-bottom: 0.5rem;
  }
  .contact-list-lead .cl-lead-subscribers-top-actions {
    gap: 0.25rem;
    margin: 0 0 0.375rem;
  }
  .contact-list-lead .cl-lead-card {
    padding: 0.5rem 0.5rem;
    margin-bottom: 0.5rem;
    border-radius: 6px;
  }
  .contact-list-lead .cl-lead-card__heading {
    font-size: 0.75rem;
    margin: 0 0 0.25rem;
    line-height: 1.25;
  }
  .contact-list-lead .cl-lead-card__heading--flush {
    font-size: 0.8125rem;
    line-height: 1.25;
    margin-bottom: 0.375rem;
  }
  .contact-list-lead .cl-subscribers-heading__title {
    font-size: 0.8125rem;
    line-height: 1.25;
  }
  .contact-list-lead .cl-subscribers-heading__number {
    margin-right: 0.25em;
  }
  .contact-list-lead .cl-lead-card__intro {
    font-size: 0.6875rem;
    line-height: 1.4;
    margin: 0 0 0.5rem;
  }
  .contact-list-lead .cl-lead-url-block {
    margin: 0 0 0.5rem;
    padding: 0.375rem 0.5rem;
  }
  .contact-list-lead .cl-lead-url-block__label {
    font-size: 0.5625rem;
    margin: 0 0 0.125rem;
    letter-spacing: 0.04em;
  }
  .contact-list-lead .cl-lead-url-block__value {
    font-size: 0.6875rem;
    line-height: 1.35;
  }
  .contact-list-lead .cl-lead-url-block__hint {
    font-size: 0.5625rem;
    margin-top: 0.25rem;
    line-height: 1.35;
  }
  .contact-list-lead .cl-lead-headline-block {
    padding-top: 0.5rem;
  }
  .contact-list-lead .cl-lead-headline-block__title {
    font-size: 0.75rem;
    margin: 0 0 0.125rem;
  }
  .contact-list-lead .cl-lead-headline-block__help,
  .contact-list-lead .cl-lead-table-note,
  .contact-list-lead .cl-subscribers-pager__range,
  .contact-list-lead .cl-subscribers-pager__status,
  .contact-list-lead .cl-subscribers-filter-empty,
  .contact-list-lead .cl-lead-empty {
    font-size: 0.625rem;
    line-height: 1.35;
  }
  .contact-list-lead .cl-lead-headline-block__help {
    margin: 0 0 0.375rem;
  }
  .contact-list-lead .cl-lead-empty {
    padding: 0.5rem 0.375rem;
  }
  .main.shell > .form-panel.contact-list-lead .form-group,
  .contact-list-lead .cl-signup-headline-form .form-group {
    margin-bottom: 0.375rem;
  }
  .main.shell > .form-panel.contact-list-lead .form-group label,
  .contact-list-lead .cl-signup-headline-form .form-group label {
    font-size: 0.625rem;
    margin-bottom: 0.125rem;
  }
  .contact-list-lead .cl-signup-headline-form .form-control {
    font-size: 0.75rem;
    padding: 0.25rem 0.4rem;
    min-height: 1.75rem;
    line-height: 1.3;
  }
  .contact-list-lead .cl-lead-action-btn {
    min-height: 1.75rem;
    padding: 0.2rem 0.5rem;
    font-size: 0.6875rem;
    line-height: 1.2;
  }
  .contact-list-lead .cl-lead-action-btn svg {
    width: 12px;
    height: 12px;
  }
  .contact-list-lead .cl-lead-export-dropdown__panel {
    min-width: 8.5rem;
  }
  .contact-list-lead .cl-lead-export-dropdown__item {
    font-size: 0.625rem;
    padding: 0.3rem 0.45rem;
  }
  .contact-list-lead .cl-lead-export-dropdown__item svg {
    width: 11px;
    height: 11px;
  }
  .contact-list-lead .cl-subscribers-search {
    font-size: 0.6875rem;
    padding: 0.25rem 0.375rem;
    min-height: 1.75rem;
  }
  .contact-list-lead .cl-subscribers-toolbar {
    margin-bottom: 0.375rem;
    gap: 0.25rem;
  }
  .contact-list-lead .cl-subscribers-search-field {
    min-width: 0;
    max-width: 100%;
    width: 100%;
  }
  .contact-list-lead .cl-subscribers-pager {
    padding: 0.25rem 0.375rem;
    gap: 0.25rem;
    margin: 0 0 0.25rem;
  }
  .contact-list-lead .cl-subscribers-pager__controls {
    gap: 0.25rem;
  }
  .contact-list-lead .cl-subscribers-pager__btn {
    font-size: 0.625rem;
    min-height: 1.5rem;
    padding: 0.1rem 0.35rem;
  }
  .contact-list-lead .cl-subscribers-pager__status {
    min-width: 0;
  }
  .contact-list-lead .cl-subscribers-table {
    font-size: 0.625rem;
    line-height: 1.3;
  }
  .contact-list-lead .cl-subscribers-table thead th {
    padding: 0.2rem 0.3rem;
    font-size: 0.5rem;
    letter-spacing: 0.04em;
  }
  .contact-list-lead .cl-subscribers-table tbody td {
    padding: 0.2rem 0.3rem;
  }
  .contact-list-lead .cl-subscribers-table__date {
    font-size: 0.5625rem;
  }
  .contact-list-lead .cl-subscribers-table-wrap {
    margin-top: 0.125rem;
  }
  .contact-list-lead .cl-lead-footer {
    margin-top: 0.5rem;
    padding-top: 0.5rem;
  }
  .contact-list-lead .cl-lead-footer .cl-lead-action-btn {
    font-size: 0.6875rem;
  }
}

.contact-list-public__panel {
  max-width: 26rem;
  margin: var(--sp-10) auto;
}
.contact-list-public__company {
  font-size: var(--text-2xl);
  margin: 0 0 var(--sp-4);
  line-height: 1.2;
}
.contact-list-public__headline {
  font-size: var(--text-lg);
  font-weight: 600;
  margin: 0 0 var(--sp-6);
  line-height: 1.35;
  color: var(--text);
}
.contact-list-public__form .form-group {
  margin-bottom: var(--sp-5);
}
.contact-list-public__form .form-group:last-of-type {
  margin-bottom: var(--sp-6);
}
/* Same two-column field layout as company microsite subscribe (shared partial) */
.contact-list-public__panel .company-microsite__subscribe-inner {
  width: 100%;
  max-width: 100%;
}
.contact-list-public__panel .company-microsite__subscribe-form .company-microsite__subscribe-row {
  margin-bottom: var(--sp-3);
}
.contact-list-public__panel .company-microsite__subscribe-form .company-microsite__subscribe-row:last-of-type {
  margin-bottom: var(--sp-4);
}
.contact-list-public__panel .company-microsite__subscribe-form .form-group {
  margin-bottom: var(--sp-3);
}
.contact-list-public__panel .company-microsite__subscribe-form .company-microsite__subscribe-row .form-group {
  margin-bottom: 0;
}

/* Marketing hub (/dashboard/marketing) */
.marketing-hub-page__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(17rem, 1fr));
  gap: var(--sp-4);
  margin-top: var(--sp-5);
  max-width: 48rem;
}
.marketing-hub-page__card {
  display: block;
  padding: var(--sp-5);
  text-decoration: none;
  color: inherit;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--white);
  transition: border-color var(--dur-sm) var(--ease), box-shadow var(--dur-sm) var(--ease);
}
.marketing-hub-page__card:hover {
  border-color: var(--brand);
  box-shadow: none;
}
.marketing-hub-page__card-title {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-md);
  font-weight: 700;
  color: var(--primary);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.marketing-hub-page__card-lede {
  margin: 0;
  line-height: 1.45;
}

/* Professional dashboard: listing settings (company defaults for new listings) */
.listing-settings-page__h1 {
  font-size: 1.5rem;
  font-weight: 700;
  margin: 0 0 var(--sp-3);
  line-height: 1.3;
}
.listing-settings-page__sections {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
  max-width: 48rem;
}
.listing-settings-page__section {
  padding: var(--sp-5);
}
.listing-settings-page__h2 {
  font-size: 1.125rem;
  font-weight: 700;
  margin: 0 0 var(--sp-3);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  line-height: 1.35;
}
.listing-settings-page__p {
  margin: 0;
  line-height: 1.55;
}
.listing-settings-page__foot {
  margin-top: var(--sp-6);
}
.listing-settings-page__p--tight {
  margin-bottom: var(--sp-3);
}
.listing-settings-page__form {
  margin-top: var(--sp-4);
}
.listing-settings-page__actions {
  margin-top: var(--sp-4);
}
.listing-settings-page__addr-toggle-row {
  max-width: 100%;
}
.listing-settings-page__addr-toggle.pl-schedule-pill-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: var(--sp-3);
  max-width: 100%;
  cursor: pointer;
}
.listing-settings-page__addr-toggle-label {
  font-weight: 600;
  font-size: 0.95rem;
  flex: 0 1 auto;
}
.listing-settings-page__addr-options[hidden],
.listing-settings-page__vl-options[hidden],
.listing-settings-page__terms-options[hidden] {
  display: none !important;
}
.listing-settings-page__terms-textarea {
  width: 100%;
  max-width: 48rem;
  min-height: 7rem;
  margin-top: var(--sp-2);
}
.listing-settings-page__mp-toggles {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.listing-settings-page__actions--page {
  margin-top: var(--sp-2);
  padding-top: 0;
}
.listing-settings-page__rule-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.listing-settings-page__rule-item {
  margin: 0;
}
.listing-settings-page__radio-line {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2);
  cursor: pointer;
  font-size: 0.9375rem;
  line-height: 1.45;
}
.listing-settings-page__radio-line--with-hours {
  flex-wrap: nowrap;
  align-items: center;
  gap: var(--sp-2);
}
.listing-settings-page__radio-line--with-hours > input[type="radio"] {
  flex: 0 0 auto;
  margin-top: 0.1rem;
}
.listing-settings-page__hide-until-line {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: var(--sp-2);
  min-width: 0;
  flex: 0 1 auto;
}
.listing-settings-page__hide-until-prompt {
  font-weight: inherit;
  font-size: inherit;
  line-height: inherit;
  margin: 0;
  padding: 0;
  flex: 0 0 auto;
  white-space: nowrap;
  cursor: pointer;
  color: inherit;
}
.listing-settings-page__hide-until-suffix {
  white-space: nowrap;
  flex: 0 0 auto;
  font-size: inherit;
  line-height: inherit;
}
.listing-settings-page__radio-line--with-hours
  .listing-settings-page__hours-input.form-control {
  display: inline-block;
  width: auto;
  min-width: 0;
  max-width: 4.25rem;
  height: 2.25rem;
  box-sizing: border-box;
  padding: 0.2rem 0.35rem;
  text-align: center;
  flex: 0 0 auto;
}

/* Professional dashboard: email marketing */
.pro-email-mkt {
  max-width: 72rem;
}
.pro-email-mkt .dh-page-header {
  margin-bottom: var(--sp-6);
}
.pro-email-mkt__stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(11rem, 1fr));
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
}
.pro-email-mkt__stat {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--sp-1);
  padding: var(--sp-5) var(--sp-5);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
  border-top: 3px solid var(--n-200);
  text-decoration: none;
  color: inherit;
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.pro-email-mkt__stat--link:hover {
  border-top-color: var(--brand);
  box-shadow: var(--shadow-md);
}
.pro-email-mkt__stat-value {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: var(--primary);
  line-height: 1.1;
}
.pro-email-mkt__stat-label {
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--n-800);
}
.pro-email-mkt__stat-hint {
  margin: 0;
  font-size: var(--text-xs);
  line-height: 1.4;
}
.pro-email-mkt__notice {
  margin: 0 0 var(--sp-8);
  padding: var(--sp-4) var(--sp-5);
  background: linear-gradient(90deg, rgba(21, 93, 252, 0.06) 0%, var(--n-50) 100%);
  border: 1px solid var(--border);
  border-radius: var(--r);
  border-left: 4px solid var(--brand);
  line-height: 1.55;
}
.pro-email-mkt__grid {
  display: grid;
  gap: var(--sp-6);
  align-items: start;
}
@media (min-width: 960px) {
  .pro-email-mkt__grid {
    grid-template-columns: minmax(0, 1fr) minmax(17rem, 22rem);
  }
}
.pro-email-mkt__card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
  padding: var(--sp-6) var(--sp-6);
  margin-bottom: var(--sp-6);
}
@media (min-width: 640px) {
  .pro-email-mkt__card {
    padding: var(--sp-7) var(--sp-8);
  }
}
.pro-email-mkt__card--editor {
  scroll-margin-top: var(--sp-4);
}
.pro-email-mkt__card-title {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--primary);
  letter-spacing: -0.02em;
}
.pro-email-mkt__card-intro {
  margin: 0 0 var(--sp-6);
  line-height: 1.55;
  max-width: 42rem;
}
.pro-email-mkt__card-intro code {
  font-size: 0.9em;
  padding: 0.1em 0.35em;
  background: var(--n-100);
  border-radius: var(--r-xs);
}
.pro-email-mkt__empty {
  margin: 0;
  padding: var(--sp-6);
  text-align: center;
  background: var(--n-50);
  border-radius: var(--r);
}
.pro-email-mkt__table-wrap {
  overflow-x: auto;
  margin: 0 calc(-1 * var(--sp-2));
  padding: 0 var(--sp-2);
}
.pro-email-mkt__table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}
.pro-email-mkt__table th {
  text-align: left;
  padding: var(--sp-3) var(--sp-3);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--n-600);
  border-bottom: 1px solid var(--border);
  background: var(--n-50);
}
.pro-email-mkt__table td {
  padding: var(--sp-3);
  vertical-align: middle;
  border-bottom: 1px solid var(--n-100);
}
.pro-email-mkt__table tbody tr:hover {
  background: rgba(248, 250, 252, 0.9);
}
.pro-email-mkt__cell-subject {
  max-width: 14rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pro-email-mkt__cell-date {
  white-space: nowrap;
  font-size: var(--text-xs);
  color: var(--n-700);
}
.pro-email-mkt__cell-actions {
  white-space: nowrap;
  text-align: right;
}
.pro-email-mkt__cell-actions .btn {
  margin-left: var(--sp-2);
}
.pro-email-mkt__badge {
  display: inline-block;
  padding: 0.2rem 0.5rem;
  font-size: var(--text-xs);
  font-weight: 700;
  border-radius: var(--r-xs);
  text-transform: capitalize;
}
.pro-email-mkt__badge--draft {
  background: var(--n-100);
  color: var(--n-800);
}
.pro-email-mkt__badge--scheduled {
  background: rgba(21, 93, 252, 0.12);
  color: var(--brand);
}
.pro-email-mkt__badge--sent {
  background: rgba(5, 150, 105, 0.14);
  color: #047857;
}
.pro-email-mkt__badge--archived {
  background: var(--n-200);
  color: var(--n-800);
}
.pro-email-mkt__form {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
}
.main.shell > .form-panel.pro-dash-placeholder .pro-email-mkt__form .form-group {
  margin: 0;
  gap: 0;
}
.main.shell > .form-panel.pro-dash-placeholder .pro-email-mkt__form .form-group > label.keep-field-label {
  margin-top: 0;
  margin-bottom: 0;
}
.main.shell > .form-panel.pro-dash-placeholder .pro-email-mkt__form input.form-control,
.main.shell > .form-panel.pro-dash-placeholder .pro-email-mkt__form select.form-control,
.main.shell > .form-panel.pro-dash-placeholder .pro-email-mkt__form textarea.form-control {
  margin-top: 0;
  margin-bottom: var(--sp-2);
}
.pro-email-mkt__body-label-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-bottom: 0;
}
.pro-email-mkt__body-label-row label {
  margin-bottom: 0;
}
.pro-email-mkt__body-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2);
}
.pro-email-mkt__ai-off-hint {
  max-width: 14rem;
  line-height: 1.4;
  text-align: right;
}
.pro-email-mkt__ai-off-hint code {
  font-size: 0.85em;
}
.pro-email-mkt__ai-progress-wrap {
  margin: var(--sp-3) 0 0;
}
.pro-email-mkt__ai-progress-wrap.is-busy .pro-email-mkt__ai-progress {
  box-shadow: 0 0 0 1px rgba(21, 93, 252, 0.12);
}
.pro-email-mkt__ai-progress-label {
  margin: 0 0 var(--sp-2);
}
.pro-email-mkt__ai-progress {
  height: 8px;
  border-radius: var(--r);
  background: var(--n-200, #e2e8f0);
  overflow: hidden;
}
.pro-email-mkt__ai-progress-bar {
  height: 100%;
  width: 0;
  border-radius: var(--r);
  background: linear-gradient(90deg, #155dfc, #0092b8);
  transition: width 0.25s ease;
}
.pro-email-mkt__ai-status {
  margin: var(--sp-2) 0 0;
  color: var(--green, #047857);
}
.pro-email-mkt__ai-error {
  margin: var(--sp-2) 0 0;
  padding: var(--sp-2) var(--sp-3);
  font-size: var(--text-sm);
  color: var(--red, #b91c1c);
  background: var(--red-bg, #fef2f2);
  border: 1px solid var(--red-border, #fecaca);
  border-radius: var(--r-sm);
}
.pro-email-mkt__form-group--body .pro-email-mkt__textarea {
  margin-top: var(--sp-3);
}
.pro-email-mkt__import-form {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
  margin-bottom: 0;
}
.pro-email-mkt__import-form .form-group {
  margin: 0;
}
.pro-email-mkt__import-form input[type='file'].form-control {
  margin-top: var(--sp-3);
  margin-bottom: var(--sp-2);
  padding-block: var(--sp-2);
}
.pro-email-mkt__dialog {
  max-width: min(36rem, calc(100vw - 2rem));
  width: 100%;
  margin: auto;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
  box-shadow: var(--shadow-lg);
}
.pro-email-mkt__dialog::backdrop {
  background: rgba(15, 23, 42, 0.5);
  backdrop-filter: blur(2px);
}
.pro-email-mkt__dialog--preview {
  max-width: min(52rem, calc(100vw - 1.25rem));
}
.pro-email-mkt__dialog-panel {
  padding: var(--sp-6);
  max-height: min(75vh, 36rem);
  display: flex;
  flex-direction: column;
  min-height: 0;
  box-sizing: border-box;
}
.pro-email-mkt__dialog-panel.pro-email-mkt__dialog-panel--preview {
  max-height: min(92vh, 56rem);
  padding: var(--sp-5) var(--sp-6) var(--sp-6);
}
.pro-email-mkt__preview-note {
  margin: 0 0 var(--sp-4);
  flex-shrink: 0;
}
.pro-email-mkt__preview-frame-wrap {
  flex: 1 1 auto;
  min-height: min(68vh, 640px);
  border: 1px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
  background: var(--n-100);
}
.pro-email-mkt__preview-frame {
  display: block;
  width: 100%;
  height: min(68vh, 640px);
  min-height: 320px;
  border: 0;
  background: #fff;
}
.pro-email-mkt__dialog-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-bottom: var(--sp-2);
  flex-shrink: 0;
}
.pro-email-mkt__dialog-title {
  margin: 0;
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--primary);
  letter-spacing: -0.02em;
  line-height: 1.3;
}
.pro-email-mkt__dialog-close {
  flex-shrink: 0;
}
.pro-email-mkt__dialog-lede {
  margin: 0 0 var(--sp-4);
  line-height: 1.5;
  flex-shrink: 0;
}
.pro-email-mkt__dialog-hint {
  margin: 0 0 var(--sp-3);
  line-height: 1.45;
  flex-shrink: 0;
}
.pro-email-mkt__dialog-hint code {
  font-size: 0.8125rem;
  word-break: break-all;
}
.pro-email-mkt__dialog-search-wrap {
  margin-bottom: var(--sp-4);
  flex-shrink: 0;
}
.pro-email-mkt__dialog-list-wrap {
  flex: 1 1 auto;
  min-height: 0;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.pro-email-mkt__dialog-list {
  list-style: none;
  margin: 0;
  padding: 0;
  overflow-y: auto;
  flex: 1 1 auto;
  border: 1px solid var(--border);
  border-radius: var(--r);
  background: var(--n-50);
}
.pro-email-mkt__dialog-item {
  margin: 0;
  border-bottom: 1px solid var(--n-200);
}
.pro-email-mkt__dialog-item:last-child {
  border-bottom: none;
}
.pro-email-mkt__dialog-item-btn {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--sp-1);
  width: 100%;
  margin: 0;
  padding: var(--sp-4) var(--sp-4);
  text-align: left;
  border: none;
  background: transparent;
  cursor: pointer;
  font: inherit;
  color: var(--text);
  transition: background var(--dur-sm) var(--ease);
}
.pro-email-mkt__dialog-item-btn:hover {
  background: var(--brand-light);
}
.pro-email-mkt__dialog-item-title {
  font-weight: 700;
  color: var(--primary);
  font-size: var(--text-sm);
}
.pro-email-mkt__dialog-item-meta {
  font-size: var(--text-xs);
  line-height: 1.4;
  display: block;
}
.pro-email-mkt__dialog-empty {
  margin: var(--sp-4) 0 0;
  padding: var(--sp-4);
  text-align: center;
  background: var(--n-50);
  border-radius: var(--r);
  border: 1px dashed var(--border);
}
.pro-email-mkt__req {
  color: var(--danger, #b91c1c);
  font-weight: 700;
}
.pro-email-mkt__textarea {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: var(--text-sm);
  line-height: 1.45;
}
.pro-email-mkt__form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  align-items: center;
}
.pro-email-mkt__delete-form {
  margin-top: var(--sp-6);
  padding-top: var(--sp-6);
  border-top: 1px dashed var(--border);
}
.pro-email-mkt__delete-btn {
  color: var(--n-700);
}
.pro-email-mkt__aside-actions {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.pro-email-mkt__aside-btn {
  justify-content: center;
  text-align: center;
}
.pro-email-mkt__subhead {
  margin: var(--sp-6) 0 var(--sp-3);
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--primary);
}
.pro-email-mkt__mini-list {
  margin: 0;
  padding-left: 1.1rem;
  font-size: var(--text-xs);
  color: var(--n-700);
  line-height: 1.5;
}
.pro-email-mkt__mini-email {
  word-break: break-all;
}
.pro-email-mkt__card--templates .pro-email-mkt__templates {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
}
.pro-email-mkt__tpl-btn {
  flex: 1 1 auto;
  min-width: 8rem;
  justify-content: center;
}

/* SMS marketing — same layout as email; emerald accent and compliance emphasis */
.pro-sms-mkt.pro-email-mkt .config-settings-page__breadcrumb-current {
  color: #047857;
}
.pro-sms-mkt.pro-email-mkt .pro-email-mkt__notice {
  border-left-color: #10b981;
  background: linear-gradient(90deg, rgba(16, 185, 129, 0.08), transparent);
}
.pro-sms-mkt.pro-email-mkt .pro-email-mkt__stat:first-of-type .pro-email-mkt__stat-value {
  background: linear-gradient(120deg, #059669, #0d9488);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.pro-sms-mkt .pro-sms-mkt__segment-hint {
  margin: 0 0 var(--sp-2);
  font-size: 0.8125rem;
  color: var(--color-text-muted, #64748b);
}
.pro-sms-mkt .pro-sms-mkt__segment-hint--warn {
  color: #b45309;
  font-weight: 600;
}

/* Company / settings pages (profile, website, estates, API keys, POS settings) */
.config-settings-page__title-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-bottom: var(--sp-2);
}
.config-settings-page__title-row h1 {
  margin: 0;
}
.config-settings-page__title-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  align-items: center;
}
.config-settings-page__table-wrap {
  overflow-x: auto;
  margin-bottom: var(--sp-6);
  max-width: var(--dashboard-settings-form-max);
}
.config-settings-page__table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}
.config-settings-page__table th,
.config-settings-page__table td {
  padding: var(--sp-3) var(--sp-2);
  text-align: left;
  border-bottom: 1px solid var(--border);
  vertical-align: top;
}
.config-settings-page__table th {
  font-weight: 700;
  color: var(--primary);
}
.config-settings-page__table-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  align-items: center;
}
.config-settings-page__inline-form {
  display: inline;
  margin: 0;
}
.config-settings-page__lede {
  max-width: var(--dashboard-settings-lede-max);
  line-height: 1.5;
  margin-bottom: var(--sp-5);
}
.config-settings-page__breadcrumbs {
  margin: 0 0 var(--sp-4);
}

/* Company profile: breadcrumbs + Preview on one row */
.config-settings-page__breadcrumb-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3) var(--sp-4);
  margin-bottom: var(--sp-4);
}
.config-settings-page__breadcrumb-toolbar .config-settings-page__breadcrumbs {
  margin-bottom: 0;
}

.config-settings-page__breadcrumb-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0 var(--sp-2);
  font-size: var(--text-sm);
  line-height: 1.4;
}
.config-settings-page__breadcrumb-item a {
  color: var(--primary);
  font-weight: 600;
  text-decoration: none;
}
.config-settings-page__breadcrumb-item a:hover {
  text-decoration: underline;
}
.config-settings-page__breadcrumb-current {
  color: var(--primary);
  font-weight: 600;
}
.pro-dash-placeholder .config-settings-page__breadcrumbs {
  margin-bottom: var(--sp-4);
}
.pro-dash-placeholder .config-settings-page__breadcrumb-toolbar .config-settings-page__breadcrumbs {
  margin-bottom: 0;
}
.config-settings-page__title-row--actions-end {
  justify-content: flex-end;
  margin-top: var(--sp-1);
}
.config-settings-page__title-row--actions-end:only-child {
  margin-top: 0;
}
.pro-dash-pagehead {
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-5);
  border-bottom: 1px solid var(--border);
}
.pro-dash-pagehead .dh-breadcrumb {
  margin-bottom: var(--sp-3);
}
.pro-dash-pagehead__lede {
  margin: 0;
  max-width: 40rem;
  line-height: 1.55;
}
.config-settings-page__breadcrumb-nolink {
  color: var(--n-600, #475569);
}
.config-settings-page__breadcrumb-sep {
  color: var(--n-400, #94a3b8);
  user-select: none;
  font-weight: 500;
}
.config-settings-page__form {
  max-width: var(--dashboard-settings-form-max);
}
.config-settings-page__tabs {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: var(--sp-2);
  margin-bottom: var(--sp-6);
  border-bottom: 1px solid var(--border);
}
.config-settings-page__tab {
  appearance: none;
  font: inherit;
  font-weight: 600;
  font-size: var(--text-sm);
  padding: var(--sp-2) var(--sp-4);
  border: 1px solid transparent;
  border-radius: var(--r-xs) var(--r-xs) 0 0;
  background: transparent;
  color: var(--color-text-muted, #64748b);
  cursor: pointer;
  margin-bottom: -1px;
}
.config-settings-page__tab:hover {
  color: var(--primary);
  background: var(--n-50);
}
.config-settings-page__tab[aria-selected="true"] {
  color: var(--primary);
  background: var(--surface, #fff);
  border-color: var(--border);
  border-bottom-color: var(--surface, #fff);
}
.config-settings-page__tab-panel[hidden] {
  display: none !important;
}
.config-settings-page__form > .form-group,
.config-settings-page__form > .form-row {
  margin-bottom: var(--sp-6);
}
.config-settings-page__form > .form-row .form-group {
  margin-bottom: 0;
}
.config-settings-page__form > h2.config-settings-page__h2 {
  margin-top: 0;
  margin-bottom: var(--sp-5);
}
.config-settings-page__form > h2.config-settings-page__h2 ~ h2.config-settings-page__h2 {
  margin-top: var(--sp-8);
}
.config-settings-page__secret-box {
  margin: var(--sp-3) 0;
  padding: var(--sp-3);
  background: var(--n-50);
  border: 1px solid var(--border);
  border-radius: var(--r-xs);
  word-break: break-all;
  font-size: var(--text-sm);
}
.config-settings-page__pre {
  margin: 0 0 var(--sp-4);
  padding: var(--sp-4);
  background: var(--n-50);
  border: 1px solid var(--border);
  border-radius: var(--r-xs);
  overflow-x: auto;
  font-size: var(--text-sm);
}
.config-settings-page__pre--after-lead {
  margin-top: var(--sp-3);
}
.config-settings-page__pre--flush {
  margin-top: 0;
  margin-bottom: 0;
}
.config-settings-page__flash-lead {
  margin: 0 0 var(--sp-3);
  max-width: 40rem;
}
.config-settings-page__flash-only {
  margin: 0;
  max-width: 40rem;
}
.config-settings-page--pos .pos-settings-intro {
  max-width: 40rem;
  line-height: 1.55;
  margin: 0 0 var(--sp-5);
}
.config-settings-page__mono-block .config-settings-page__mono-line {
  display: block;
  font-family: inherit;
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--n-800, #1e293b);
}
.config-settings-page__new-token {
  margin-bottom: var(--sp-6);
}
/* config-settings: show real <label for> (see global .form-group > label sr-only without .keep-field-label) */
.config-settings-page__form .form-group:not(.config-settings-page__checkbox-row) > label.keep-field-label {
  display: block;
  margin: 0 0 var(--sp-2) 0;
  font-weight: 600;
  color: var(--n-700, #334155);
}
/* Explicit checkbox + label (for= / id); .keep-field-label avoids global sr-only on .form-group > label */
.config-settings-page__form .config-settings-page__checkbox-row {
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: var(--sp-2);
}
.config-settings-page__form .config-settings-page__checkbox-input {
  width: auto;
  height: auto;
  min-height: 0;
  margin-top: 0.2em;
  flex-shrink: 0;
}
.config-settings-page__form .config-settings-page__checkbox-row .keep-field-label {
  flex: 1 1 0;
  min-width: 0;
  margin: 0;
  font-weight: 500;
  cursor: pointer;
}

/* Config settings: nested / tabbed section headings (not only direct form children) */
.config-settings-page__form .config-settings-page__h2 {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--n-900, #0f172a);
  margin: 0 0 var(--sp-5);
  padding-bottom: var(--sp-2);
  border-bottom: 1px solid var(--border);
  letter-spacing: -0.02em;
  line-height: 1.3;
}
.config-settings-page__form .config-settings-page__section + .config-settings-page__section .config-settings-page__h2 {
  margin-top: var(--sp-2);
  padding-top: var(--sp-6);
  border-top: 1px solid var(--border);
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: var(--sp-4);
}
.config-settings-page__form .config-settings-page__section + .config-settings-page__section {
  margin-top: var(--sp-2);
}
.config-settings-page__lede {
  max-width: 40rem;
  line-height: 1.55;
  margin: 0 0 var(--sp-5);
}
.config-settings-page__lede + .flash,
.config-settings-page--pos h2 + p.meta + .flash {
  margin-top: var(--sp-2);
}
.config-settings-page__tab-surface {
  background: var(--n-25, #fcfcfd);
  border: 1px solid var(--border);
  border-radius: 0 0 var(--r-lg) var(--r-lg);
  padding: var(--sp-6) var(--sp-6) var(--sp-7);
  box-sizing: border-box;
  margin-top: 0;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.config-settings-page__tabs {
  position: relative;
  z-index: 1;
}
.config-settings-page--pos .config-settings-page__tab[aria-selected="true"] {
  background: var(--n-25, #fcfcfd);
  border-bottom-color: var(--n-25, #fcfcfd);
}
.config-settings-page__form .config-settings-page__tab:focus-visible {
  outline: 2px solid var(--brand, #155dfc);
  outline-offset: 2px;
}
.config-settings-page__form .config-settings-page__form-actions {
  margin-top: var(--sp-8);
  padding-top: var(--sp-6);
  border-top: 1px solid var(--border);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-3);
}
.config-settings-page__form .config-settings-page__form-actions:empty {
  display: none;
}
.config-settings-page__save-btn {
  min-height: 2.75rem;
  font-weight: 600;
  padding-inline: var(--sp-6);
  border-radius: var(--r, 0.5rem);
}
.config-settings-page__mono-block {
  margin: var(--sp-2) 0 0;
  padding: var(--sp-3) var(--sp-4);
  background: var(--n-50, #f8fafc);
  border: 1px solid var(--border);
  border-radius: var(--r-sm, 0.375rem);
  overflow-x: auto;
}
.config-settings-page__form .form-group:has(.config-settings-page__mono-block) .meta {
  display: block;
  margin-bottom: 0.25rem;
}
@media (max-width: 639px) {
  .config-settings-page__tab-surface {
    padding: var(--sp-4) var(--sp-4) var(--sp-5);
    border-radius: 0 0 var(--r) var(--r);
  }
  .config-settings-page__lede {
    max-width: none;
  }
}

/* ---- POS settings (/dashboard/settings/pos) — nested fields, tab shell, production polish ---- */
.pos-settings .config-settings-page__form {
  max-width: min(44rem, 100%);
}
.pos-settings .config-settings-page__tabs {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: var(--sp-2);
  margin-bottom: 0;
  padding: var(--sp-1);
  background: linear-gradient(180deg, var(--n-50, #f8fafc) 0%, var(--n-100, #f1f5f9) 100%);
  border: 1px solid var(--border);
  border-bottom: 0;
  border-radius: var(--r-lg) var(--r-lg) 0 0;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}
.pos-settings .config-settings-page__tab {
  flex: 1 1 8rem;
  min-height: 2.75rem;
  margin-bottom: 0;
  border-radius: var(--r-sm, 0.375rem);
  border: 1px solid transparent;
  background: transparent;
  color: var(--n-600, #475569);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.01em;
  transition: color var(--dur-sm) var(--ease), background var(--dur-sm) var(--ease), box-shadow var(--dur-sm) var(--ease), border-color var(--dur-sm) var(--ease);
}
.pos-settings .config-settings-page__tab:hover {
  color: var(--n-800, #1e293b);
  background: rgba(255, 255, 255, 0.55);
}
.pos-settings .config-settings-page__tab[aria-selected='true'] {
  color: var(--primary, #155dfc);
  background: var(--white, #fff);
  border-color: var(--border);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.08);
}
.pos-settings .config-settings-page__tab[aria-selected='false'] {
  color: var(--n-500, #64748b);
}
.pos-settings .config-settings-page__tab-surface {
  position: relative;
  margin-top: 0;
  border-radius: 0 0 var(--r-lg) var(--r-lg);
  border: 1px solid var(--border);
  background: var(--white, #fff);
  background-image: linear-gradient(180deg, rgba(252, 252, 253, 0.95) 0%, var(--white) 12rem);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04), 0 12px 32px -8px rgba(15, 23, 42, 0.08);
  padding: var(--sp-7) var(--sp-7) var(--sp-8);
}
/* Nested .form-group was not matched by .config-settings-page__form > .form-group — restore vertical rhythm */
.pos-settings .config-settings-page__tab-surface .config-settings-page__section {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
}
.pos-settings .config-settings-page__tab-surface .config-settings-page__section--tight {
  gap: var(--sp-5);
}
.pos-settings .config-settings-page__form .config-settings-page__h2 {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin: 0 0 0 0;
  padding: 0 0 var(--sp-2) 0;
  font-size: clamp(1.05rem, 0.2vw + 1rem, 1.15rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--n-900, #0f172a);
  line-height: 1.3;
  border: 0;
  border-bottom: 1px solid var(--border);
}
.pos-settings .config-settings-page__h2::before {
  content: '';
  display: block;
  width: 0.2rem;
  min-height: 1.1em;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--brand, #155dfc) 0%, #3b82f6 100%);
  flex-shrink: 0;
  box-shadow: 0 0 0 1px rgba(21, 93, 252, 0.12);
}
.pos-settings .config-settings-page__form .config-settings-page__section + .config-settings-page__section .config-settings-page__h2 {
  margin-top: var(--sp-3);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  border-left: 0;
  border-right: 0;
}
.pos-settings .pos-settings-intro {
  margin: 0;
  line-height: 1.6;
  color: var(--n-600, #475569);
  max-width: 40rem;
}
/* Labels: space between label and input; section gap handles space above the first line of each field group */
.pos-settings .config-settings-page__form .form-group:not(.config-settings-page__checkbox-row) > label.keep-field-label {
  margin: 0 0 var(--sp-3) 0;
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.01em;
  text-transform: none;
  color: var(--n-700, #334155);
}
.pos-settings .config-settings-page__form .form-group.config-settings-page__checkbox-row {
  margin-top: 0;
  margin-bottom: 0;
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--r, 0.5rem);
  background: var(--n-25, #fcfcfd);
  border: 1px solid var(--n-100, #f1f5f9);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8) inset;
  gap: var(--sp-3);
  align-items: center;
  transition: border-color var(--dur-sm) var(--ease);
}
.pos-settings .config-settings-page__form .form-group.config-settings-page__checkbox-row:hover,
.pos-settings .config-settings-page__form .form-group.config-settings-page__checkbox-row:focus-within {
  border-color: var(--n-200, #e2e8f0);
}
.pos-settings .config-settings-page__form .form-group.config-settings-page__checkbox-row .config-settings-page__checkbox-input {
  width: 1.125rem;
  height: 1.125rem;
  min-height: 0;
  margin: 0;
  accent-color: var(--brand, #155dfc);
  cursor: pointer;
}
.pos-settings .config-settings-page__form .form-group.config-settings-page__checkbox-row .keep-field-label {
  font-size: var(--text-sm);
  text-transform: none;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.4;
  color: var(--n-800, #1e293b);
}
.pos-settings .form-group :is(input.form-control, select.form-control, textarea.form-control) {
  border-radius: var(--r, 0.5rem);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  transition: border-color var(--dur-sm) var(--ease), box-shadow var(--dur-sm) var(--ease);
}
.pos-settings .form-group .meta {
  margin-top: var(--sp-2);
  line-height: 1.5;
  font-size: var(--text-xs, 0.75rem);
  color: var(--n-500, #64748b);
}
.pos-settings .form-group .meta a {
  color: var(--primary, #155dfc);
  text-decoration: underline;
  text-underline-offset: 0.12em;
}
.pos-settings .form-group .meta a:hover {
  color: var(--n-800, #1e293b);
}
.pos-settings .config-settings-page__mono-block {
  margin-top: var(--sp-2);
  border-radius: var(--r, 0.5rem);
  background: var(--n-25, #fcfcfd);
  font-family: ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
  font-size: var(--text-xs, 0.75rem);
  line-height: 1.5;
  border: 1px solid var(--n-200, #e2e8f0);
  color: var(--n-800, #1e293b);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.6) inset;
  word-break: break-all;
}
.pos-settings .config-settings-page__mono-block .config-settings-page__mono-line {
  color: var(--n-800, #1e293b);
  font-weight: 500;
  font-size: 0.8125rem;
}
.pos-settings .config-settings-page__form .config-settings-page__form-actions {
  margin-top: var(--sp-6);
  padding: var(--sp-6) var(--sp-4) 0;
  background: linear-gradient(180deg, rgba(250, 250, 252, 0) 0%, var(--n-25, #fcfcfd) 20%);
  border-top: 1px solid var(--n-200, #e2e8f0);
  border-radius: 0 0 var(--r-lg) var(--r-lg);
  display: flex;
  justify-content: flex-end;
}
.pos-settings .config-settings-page__save-btn {
  min-width: 12rem;
  border-radius: var(--r, 0.5rem);
  font-weight: 600;
  letter-spacing: 0.02em;
  box-shadow: 0 1px 2px rgba(21, 93, 252, 0.2);
  transition: transform 0.15s var(--ease), box-shadow 0.15s var(--ease);
}
.pos-settings .config-settings-page__save-btn:hover {
  box-shadow: 0 4px 14px rgba(21, 93, 252, 0.28);
}
.pos-settings .config-settings-page__save-btn:active {
  transform: translateY(1px);
}
@media (max-width: 639px) {
  .pos-settings .config-settings-page__tab-surface {
    padding: var(--sp-5) var(--sp-4) var(--sp-6);
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  }
  .pos-settings .config-settings-page__tabs {
    border-radius: var(--r) var(--r) 0 0;
  }
  .pos-settings .config-settings-page__form .config-settings-page__form-actions {
    padding-left: 0;
    padding-right: 0;
  }
  .pos-settings .config-settings-page__save-btn {
    width: 100%;
    min-width: 0;
  }
}
@media (prefers-reduced-motion: reduce) {
  .pos-settings .config-settings-page__save-btn,
  .pos-settings .config-settings-page__save-btn:hover,
  .pos-settings .config-settings-page__save-btn:active {
    transform: none;
    transition: none;
  }
}

/* Company profile (/dashboard/company): slightly tighter corner radius (root border off via .pro-dash-placeholder) */
.main.shell > .form-panel.company-profile-page {
  border-radius: var(--r);
}
.company-profile-page .config-settings-page__logo-card {
  border-radius: var(--r);
}
.company-profile-page .cp-field__help--sm {
  font-size: 0.7em;
  line-height: 1.35;
  margin-top: 0.35rem;
  margin-bottom: 0;
  color: var(--text-muted);
}
.company-profile-page__save-wrap {
  margin-top: var(--sp-6);
}
.company-profile-page__address-display {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: var(--sp-3) var(--sp-4);
  margin-top: var(--sp-5);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border);
}
.company-profile-page__address-display-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--text);
  text-align: start;
  white-space: normal;
}
.company-profile-page__address-display-toggle.pl-schedule-pill-toggle {
  flex: 0 0 auto;
  gap: var(--sp-3);
  max-width: 100%;
}

/* Company profile: main form + compact logo aside */
.config-settings-page__details-logo-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(11.5rem, 15rem);
  gap: var(--sp-6) var(--sp-8);
  align-items: start;
  margin-bottom: var(--sp-2);
}
.config-settings-page__details-main {
  min-width: 0;
}
.config-settings-page__form--with-logo-aside {
  max-width: none;
  width: 100%;
}
.config-settings-page__logo-aside {
  min-width: 0;
}
@media (min-width: 769px) {
  .config-settings-page__logo-aside {
    position: sticky;
    top: var(--sp-4);
  }
}
@media (max-width: 768px) {
  .config-settings-page__details-logo-grid {
    grid-template-columns: 1fr;
  }
  .config-settings-page__logo-aside {
    position: static;
  }
}
.config-settings-page__logo-card {
  max-width: var(--dashboard-settings-form-max);
  margin-bottom: var(--sp-8);
}
.config-settings-page__details-logo-grid .config-settings-page__logo-card {
  max-width: none;
  margin-bottom: 0;
}
.config-settings-page__logo-card--aside {
  padding: var(--sp-4) var(--sp-5);
  margin-bottom: 0;
}
.config-settings-page__logo-card--aside .pro-email-mkt__card-title {
  font-size: var(--text-base);
  margin-bottom: var(--sp-1);
}
.config-settings-page__logo-aside-intro {
  margin: 0 0 var(--sp-3);
  font-size: var(--text-sm);
  line-height: 1.45;
  max-width: none;
}
.config-settings-page__logo-card--aside .config-settings-page__logo-preview-wrap {
  position: relative;
  display: block;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto var(--sp-3);
}
.config-settings-page__logo-card--aside .config-settings-page__logo-preview {
  max-width: 5.5rem;
  margin-inline: auto;
}
.config-settings-page__logo-card--aside .config-settings-page__logo-upload-form {
  margin-bottom: var(--sp-3);
}
.config-settings-page__logo-card--aside .form-group {
  margin-bottom: var(--sp-3);
}
.config-settings-page__logo-preview-wrap {
  position: relative;
  display: block;
  width: fit-content;
  max-width: 100%;
  margin: 0 0 var(--sp-5);
}
.config-settings-page__logo-preview {
  display: block;
  max-width: 10rem;
  width: 100%;
  height: auto;
  aspect-ratio: 1;
  object-fit: contain;
  border-radius: var(--r);
  border: 1px solid var(--border);
  background: var(--white);
  box-shadow: var(--shadow-sm);
}
.config-settings-page__logo-remove-overlay-form {
  position: absolute;
  top: -0.35rem;
  right: -0.35rem;
  margin: 0;
  line-height: 0;
}
.config-settings-page__logo-remove-overlay-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: 50%;
  background: var(--n-800);
  color: #fff;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition: background var(--dur-sm) var(--ease), border-color var(--dur-sm) var(--ease), transform var(--dur-sm) var(--ease);
}
.config-settings-page__logo-remove-overlay-btn:hover {
  background: var(--danger, #b42318);
  border-color: transparent;
}
.config-settings-page__logo-remove-overlay-btn:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}
.config-settings-page__logo-remove-overlay-btn svg {
  flex-shrink: 0;
}
.config-settings-page__logo-upload-form {
  margin-bottom: var(--sp-4);
}

/* Microsite page editor (dashboard): shortcode toolbar */
.microsite-dash-editor__shortcodes {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-bottom: var(--sp-3);
  max-width: 48rem;
}
.microsite-dash-editor__shortcode-btn {
  white-space: nowrap;
}

/* Microsite public: shortcode-expanded blocks */
.microsite-shortcode-block {
  margin: var(--sp-8) 0;
}
.microsite-shortcode-block:first-child {
  margin-top: 0;
}
.microsite-shortcode-block--listings .company-microsite__h2 {
  margin-top: 0;
}
.microsite-shortcode-note {
  margin: var(--sp-2) 0;
}

/* Public company profile (/company/{slug}) — logo, vCard, and action buttons. */
.company-show__hero {
  margin-bottom: var(--sp-6);
}
.company-show__hero-grid {
  display: grid;
  gap: var(--sp-6) var(--sp-8);
  grid-template-columns: 1fr;
  align-items: start;
}
.company-show__hero-logo-col {
  justify-self: start;
}
.company-show__hero-logo-col .company-show__logo {
  display: block;
  width: 100%;
  max-width: 7.5rem;
  height: auto;
  aspect-ratio: 1;
  object-fit: contain;
  border-radius: var(--r-lg);
  border: 1px solid var(--border);
  background: var(--white);
  box-shadow: var(--shadow-sm);
}
.company-show__hero-info {
  align-self: start;
  min-width: 0;
  text-align: left;
}
.company-show__title {
  margin: 0 0 var(--sp-3);
  font-size: clamp(1.35rem, 2.5vw, 1.75rem);
  font-weight: 800;
  color: var(--primary);
  letter-spacing: -0.02em;
  line-height: 1.2;
}
.company-show__vcard {
  margin: 0;
  line-height: 1.5;
}
.company-show__vcard-line {
  margin: 0 0 var(--sp-1);
}
.company-show__vcard-line:last-child {
  margin-bottom: 0;
}
.company-show__vcard-line a {
  color: var(--brand);
  font-weight: 600;
  text-decoration: none;
}
.company-show__vcard-line a:hover {
  text-decoration: underline;
}
.company-show__vcard-line--empty {
  color: var(--text-muted, #64748b);
  font-style: italic;
}
.company-show__actions {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2) var(--sp-3);
  margin: 0;
  padding: 0;
  border: 0;
}
.company-show__hero-grid--no-logo > .company-show__actions {
  margin-bottom: var(--sp-2);
}
.company-show__action-btn {
  margin: 0;
}
.company-show__action-form {
  margin: 0;
  display: inline;
}
.company-show__hero-grid--no-logo .company-show__hero-info {
  order: -1;
}
.company-show__follow-hint {
  margin: var(--sp-4) 0 0;
  max-width: 40rem;
}
.company-show__description {
  margin: 0 0 var(--sp-8);
  line-height: 1.55;
  max-width: 52rem;
}
.company-show__sales-heading {
  margin: 0 0 var(--sp-5);
  font-size: var(--text-lg);
  font-weight: 800;
  color: var(--primary);
}

/* Professional demo public profile: actions share top line with company name (see company/show.php). */
.company-show__hero--pro-demo .company-show__hero-heading-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-3) var(--sp-4);
  margin-bottom: var(--sp-3);
}
.company-show__hero--pro-demo .company-show__hero-heading-row .company-show__title {
  margin-bottom: 0;
  flex: 1 1 auto;
  min-width: 0;
}
.company-show__hero--pro-demo .company-show__hero-heading-row .company-show__actions {
  flex: 0 1 auto;
  margin-left: auto;
  justify-content: flex-end;
}
@media (max-width: 639px) {
  .company-show__hero--pro-demo .company-show__hero-heading-row .company-show__actions {
    width: 100%;
    margin-left: 0;
  }
}

@media (min-width: 900px) {
  /* Top row: logo (fixed width) + company name & contact; second row: actions full width, left-aligned with grid. */
  .company-show__hero-grid:not(.company-show__hero-grid--no-logo) {
    grid-template-columns: 7.5rem minmax(0, 1fr);
    grid-template-rows: auto auto;
    row-gap: var(--sp-5);
  }
  .company-show__hero-grid:not(.company-show__hero-grid--no-logo) .company-show__hero-logo-col {
    grid-column: 1;
    grid-row: 1;
  }
  .company-show__hero-grid:not(.company-show__hero-grid--no-logo) .company-show__hero-info {
    grid-column: 2;
    grid-row: 1;
  }
  .company-show__hero-grid:not(.company-show__hero-grid--no-logo) > .company-show__actions {
    grid-column: 1 / -1;
    grid-row: 2;
  }
  .company-show__hero-grid--no-logo {
    grid-template-columns: minmax(0, 1fr);
  }
}

/* ---- Team / staff page ---------------------------------------------------- */
.staff-page {
  padding-bottom: var(--sp-12);
}
.staff-page__hero {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-8);
  margin-bottom: var(--sp-10);
  padding: var(--sp-8) var(--sp-8);
  background: linear-gradient(135deg, var(--white) 0%, var(--n-50) 100%);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
}
.staff-page__hero::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: min(42%, 280px);
  height: 100%;
  background: radial-gradient(ellipse at 100% 0%, var(--brand-light) 0%, transparent 70%);
  opacity: 0.85;
  pointer-events: none;
}
.staff-page__hero-main {
  position: relative;
  z-index: 1;
  max-width: 36rem;
  flex: 1 1 280px;
}
.staff-page__eyebrow {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--brand);
}
.staff-page .dh-page-header .dh-breadcrumb {
  margin-bottom: 0;
}
.staff-page__lede {
  margin: 0;
  font-size: var(--text-base);
  line-height: 1.55;
  color: var(--text-muted);
}
.staff-page__stats {
  position: relative;
  z-index: 1;
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  align-content: flex-start;
  align-self: flex-start;
}
.staff-page__stat {
  min-width: 7.5rem;
  padding: var(--sp-4) var(--sp-5);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r);
  box-shadow: var(--shadow-xs);
}
.staff-page__stat-value {
  display: block;
  font-size: var(--text-3xl);
  font-weight: 800;
  color: var(--primary);
  line-height: 1.1;
  letter-spacing: -0.03em;
}
.staff-page__stat-label {
  display: block;
  margin-top: var(--sp-1);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.staff-page__section {
  margin-bottom: var(--sp-10);
}
.staff-page__section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-4);
  margin-bottom: var(--sp-4);
  flex-wrap: wrap;
}
.staff-page__section-head h2 {
  margin: 0;
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--primary);
}
.staff-page__section-meta {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text-muted);
}
.staff-member-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.staff-member-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-4) var(--sp-5);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-xs);
  transition: border-color var(--dur-sm) var(--ease), box-shadow var(--dur-sm) var(--ease);
}
.staff-member-row:hover {
  border-color: var(--n-200);
  box-shadow: var(--shadow-sm);
}
.staff-avatar {
  flex-shrink: 0;
  width: 3rem;
  height: 3rem;
  border-radius: var(--r-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-sm);
  font-weight: 800;
  color: var(--brand);
  background: linear-gradient(145deg, var(--brand-light) 0%, var(--white) 100%);
  border: 1px solid rgba(21, 93, 252, 0.12);
}
.staff-avatar--owner {
  color: var(--n-700);
  background: linear-gradient(145deg, var(--n-100) 0%, var(--white) 100%);
  border-color: var(--n-200);
}
.staff-member-row__body {
  flex: 1 1 200px;
  min-width: 0;
}
.staff-member-row__top {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2);
}
.staff-member-row__name {
  font-weight: 700;
  font-size: var(--text-base);
  color: var(--primary);
}
.staff-member-row__email {
  margin: var(--sp-1) 0 0;
  font-size: var(--text-sm);
  color: var(--text-muted);
}
.staff-member-row__role-desc {
  margin: var(--sp-2) 0 0;
  font-size: var(--text-xs);
  line-height: 1.4;
}
.staff-role-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.55rem;
  border-radius: var(--r-full);
  font-size: 0.65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.07em;
}
.staff-role-pill--owner {
  background: var(--n-100);
  color: var(--n-600);
}
.staff-role-pill--staff {
  background: var(--green-bg);
  color: var(--green);
}
.staff-role-pill--administrator {
  background: var(--brand-light);
  color: var(--brand);
}
.staff-role-pill--accounting {
  background: #e0f7fa;
  color: var(--brand-teal);
}
.staff-member-row__actions {
  flex-shrink: 0;
}
.staff-member-row__remove-form {
  margin: 0;
}
.staff-page .btn-outline-danger {
  border-color: rgba(185, 28, 28, 0.35);
  color: #b91c1c;
  background: var(--white);
}
.staff-page .btn-outline-danger:hover {
  background: #fef2f2;
  border-color: #b91c1c;
  color: #991b1b;
}
.staff-member-row__hint {
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--text-muted);
  font-style: italic;
}
.staff-page__split {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
  gap: var(--sp-6);
  align-items: stretch;
}
.staff-page__panel {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-8);
  box-shadow: var(--shadow-md);
  position: relative;
}
.staff-add-panel,
.staff-invites-panel {
  display: flex;
  flex-direction: column;
  min-height: 100%;
}
.staff-page__panel-title-row {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-2);
}
.staff-page__panel-title-row .staff-page__panel-icon {
  margin-bottom: 0;
}
.staff-page__panel-icon {
  width: 2.75rem;
  height: 2.75rem;
  border-radius: var(--r);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-bottom: var(--sp-4);
  color: var(--brand);
  background: var(--brand-light);
}
.staff-page__panel-icon--amber {
  color: var(--amber);
  background: var(--amber-bg);
}
.staff-page__panel-title-row h2 {
  margin: 0;
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--primary);
}
.staff-page__panel-lede {
  margin: 0 0 var(--sp-5);
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--text-muted);
}
.staff-access-dialog-open {
  display: inline;
  height: auto;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  background: none;
  color: var(--brand);
  font: inherit;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 0.12em;
  cursor: pointer;
  vertical-align: baseline;
  white-space: normal;
}
.staff-access-dialog-open:hover {
  background: none;
  color: var(--brand-hover);
}

/* Log out confirmation (layout.php + logout-confirm.js) */
.es-logout-dialog {
  margin: auto;
  max-width: min(22rem, calc(100vw - 2rem));
  width: 100%;
  padding: 0;
  border: none;
  border-radius: var(--r-lg);
  background: var(--white);
  box-shadow: var(--shadow-md);
}
.es-logout-dialog::backdrop {
  background: rgba(15, 23, 43, 0.45);
}
.es-logout-dialog__inner {
  display: flex;
  flex-direction: column;
}
.es-logout-dialog__header {
  padding: var(--sp-5) var(--sp-5) var(--sp-3);
  border-bottom: 1px solid var(--border);
}
.es-logout-dialog__header h2 {
  margin: 0;
  font-size: var(--text-xl);
  font-weight: 800;
  color: var(--primary);
  letter-spacing: -0.02em;
}
.es-logout-dialog__body {
  padding: var(--sp-5);
}
.es-logout-dialog__lede {
  margin: 0;
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--text-muted);
}
.es-logout-dialog__footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5) var(--sp-5);
  border-top: 1px solid var(--border);
}

.staff-access-dialog {
  margin: auto;
  max-width: min(36rem, calc(100vw - 2rem));
  width: 100%;
  padding: 0;
  border: none;
  border-radius: var(--r-lg);
  background: var(--white);
  box-shadow: var(--shadow-md);
}
.staff-access-dialog::backdrop {
  background: rgba(15, 23, 43, 0.45);
}
.staff-access-dialog__inner {
  display: flex;
  flex-direction: column;
  max-height: min(85vh, 640px);
}
.staff-access-dialog__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-4);
  padding: var(--sp-5) var(--sp-5) var(--sp-3);
  border-bottom: 1px solid var(--border);
}
.staff-access-dialog__header h2 {
  margin: 0;
  font-size: var(--text-xl);
  font-weight: 800;
  color: var(--primary);
  letter-spacing: -0.02em;
}
.staff-access-dialog__close {
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  margin: calc(-1 * var(--sp-1)) calc(-1 * var(--sp-1)) 0 0;
  padding: 0;
  border: none;
  border-radius: var(--r-sm);
  background: transparent;
  color: var(--n-500);
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  transition: background var(--dur-sm) var(--ease), color var(--dur-sm) var(--ease);
}
.staff-access-dialog__close:hover {
  background: var(--n-100);
  color: var(--primary);
}
.staff-access-dialog__body {
  padding: var(--sp-5);
  overflow-y: auto;
}

/* Shopper account: edit profile (header modal) */
.shopper-profile-dialog {
  max-width: min(32rem, calc(100vw - 1.5rem));
  width: 100%;
  border: 1px solid var(--border);
}
.shopper-profile-dialog .staff-access-dialog__inner {
  min-height: 0;
  max-height: min(88vh, 36rem);
}
.shopper-profile-dialog__form {
  display: flex;
  flex-direction: column;
  min-height: 0;
  flex: 1;
}
.shopper-profile-dialog__body {
  flex: 1;
  min-height: 0;
}
.shopper-profile-dialog__intro {
  margin-bottom: var(--sp-5);
}
.shopper-profile-dialog__grid {
  display: grid;
  gap: 0 var(--sp-4);
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 520px) {
  .shopper-profile-dialog__grid {
    grid-template-columns: 1fr;
  }
}
.shopper-profile-dialog__field--wide {
  grid-column: 1 / -1;
}
.shopper-profile-dialog__hint {
  margin: var(--sp-2) 0 0;
}
.shopper-profile-dialog__flash {
  margin: 0 0 var(--sp-4);
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--text-sm);
  line-height: 1.45;
  color: var(--n-800);
  background: var(--n-100);
  border-radius: var(--r);
  border: 1px solid var(--border);
}
.shopper-profile-dialog__flash--error {
  color: #991b1b;
  background: #fef2f2;
  border-color: #fecaca;
}
.shopper-profile-dialog__password-card {
  margin-top: var(--sp-6);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--border);
}
.shopper-profile-dialog__password-title {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--primary);
  letter-spacing: -0.01em;
}
.shopper-profile-dialog__password-lede {
  margin: 0 0 var(--sp-4);
}
.shopper-profile-dialog__row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 var(--sp-4);
}
@media (max-width: 520px) {
  .shopper-profile-dialog__row-2 {
    grid-template-columns: 1fr;
  }
}
.shopper-profile-dialog__footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5) var(--sp-5);
  border-top: 1px solid var(--border);
  flex-shrink: 0;
  background: var(--surface, var(--n-50));
}

.staff-access-dialog__intro {
  margin: 0 0 var(--sp-4);
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--text-muted);
}
.staff-access-levels__note {
  margin: 0 0 var(--sp-4);
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--text-xs);
  line-height: 1.45;
  color: var(--text-muted);
  background: var(--n-50);
  border-radius: var(--r);
  border: 1px solid var(--border);
}
.staff-access-levels__list {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.staff-access-levels__item {
  margin: 0;
}
.staff-access-levels__item dt {
  margin: 0 0 var(--sp-1);
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--primary);
}
.staff-access-levels__item dd {
  margin: 0;
  font-size: var(--text-xs);
  line-height: 1.45;
  color: var(--text-muted);
}
.staff-add-form__row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: var(--sp-4) var(--sp-5);
  margin-bottom: var(--sp-5);
}
.staff-add-form__email-wrap {
  flex: 0 1 auto;
  margin-bottom: 0;
  min-width: min(100%, 12rem);
}
.staff-add-form__email-input {
  max-width: 20rem;
  width: 100%;
}
.staff-add-form__role-wrap {
  flex: 1 1 100%;
  margin-bottom: 0;
  min-width: 0;
  max-width: 100%;
}
.staff-access-dialog__footer {
  padding: var(--sp-4) var(--sp-5) var(--sp-5);
  border-top: 1px solid var(--border);
}
.register-email-taken-dialog__footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sp-3);
}
.pl-wizard-cancel-dialog__footer {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: var(--sp-3);
  width: 100%;
  box-sizing: border-box;
}
/* Confirm stays on the right (even when buttons wrap to two lines) */
/* Listing wizard: delete photo(s) confirmation (native <dialog>) */
/* Global themed confirm/alert (see public/js/es-dialog.js) */
.es-app-dialog__footer {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  width: 100%;
  box-sizing: border-box;
}
/* Author `display:flex` wins over the `hidden` attribute’s default; without this, confirm+alert footers both show. */
.es-app-dialog__footer[hidden] {
  display: none !important;
}

.pl-wizard-cancel-dialog__footer .btn-pl-wizard-danger {
  margin-left: auto;
}
/* Red destructive actions (wizard cancel trigger, cancel modal confirm, dashboard delete) */
.btn.btn-pl-wizard-danger {
  background: var(--red);
  color: #fff;
  border-color: var(--red);
}
.btn.btn-pl-wizard-danger:hover {
  background: var(--red);
  border-color: var(--red);
  color: #fff;
  filter: brightness(0.92);
  box-shadow: none;
}
.dash-delete-dialog__footer {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-3);
  width: 100%;
  box-sizing: border-box;
}
.dash-delete-dialog__footer #dash-delete-form {
  display: flex;
  margin-left: auto;
}
.staff-add-form__submit {
  width: 100%;
  max-width: 20rem;
  justify-content: center;
}
.staff-invites-panel__head {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin: 0 0 var(--sp-4);
}
.staff-invites-panel__head .staff-page__panel-icon {
  margin-bottom: 0;
}
.staff-invites-panel__head h2 {
  margin: 0;
  flex: 1;
  min-width: 0;
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--primary);
}
.staff-invites-panel__head .staff-invites-panel__count {
  margin-left: auto;
  flex-shrink: 0;
}
.staff-invites-panel__count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.75rem;
  height: 1.75rem;
  padding: 0 var(--sp-2);
  border-radius: var(--r-full);
  font-size: var(--text-xs);
  font-weight: 800;
  background: var(--amber-bg);
  color: var(--amber);
}
.staff-empty-state {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 8rem;
  margin: 0;
  padding: var(--sp-6) var(--sp-5);
  text-align: center;
  border: 1px dashed var(--border);
  border-radius: var(--r);
  background: var(--n-50);
}
.staff-empty-state__title {
  margin: 0 0 var(--sp-2);
  font-weight: 700;
  font-size: var(--text-base);
  color: var(--primary);
}
.staff-empty-state__text {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--text-muted);
  line-height: 1.5;
  max-width: 22rem;
  margin-inline: auto;
}
.staff-invite-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.staff-invite-card {
  padding: var(--sp-4) var(--sp-5);
  border: 1px solid var(--border);
  border-radius: var(--r);
  background: var(--n-50);
}
.staff-invite-card__email {
  display: block;
  font-weight: 700;
  font-size: var(--text-sm);
  color: var(--primary);
  margin-bottom: var(--sp-2);
  word-break: break-all;
}
.staff-invite-card__role {
  display: block;
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--brand);
  margin-bottom: var(--sp-2);
}
.staff-invite-card__meta {
  display: block;
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-top: var(--sp-1);
}
@media (max-width: 640px) {
  .staff-page__hero {
    padding: var(--sp-6) var(--sp-5);
  }
  .staff-member-row {
    align-items: flex-start;
  }
  .staff-member-row__actions {
    width: 100%;
  }
  .staff-page .btn-outline-danger {
    width: 100%;
  }
  .staff-add-form__submit {
    max-width: none;
  }
}

/* ====================================================================
   Landing Page Sections (lp-* prefix)
   ==================================================================== */

/* Hero — full-bleed, dark bg with photo */
.lp-hero {
  position: relative;
  /* Shorter fold + flex-start avoids a tall band of dead space between headline and search */
  min-height: clamp(520px, 76vh, 680px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  text-align: center;
  padding: clamp(72px, 12vh, 100px) var(--sp-8) 48px;
  background-color: #0B1829;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  margin-top: calc(-1 * var(--sp-8)); /* cancel main padding-top */
  /* Accent line uses negative horizontal margin; clip so it cannot widen the page on phones */
  overflow-x: clip;
}
@supports not (overflow: clip) {
  .lp-hero {
    overflow-x: hidden;
  }
}
.lp-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(8, 15, 35, 0.78);
  z-index: 0;
}
.lp-hero > * { position: relative; z-index: 1; }

/* Hero badge pill */
.lp-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 18px;
  border-radius: var(--r-full);
  border: 1px solid rgba(255,255,255,0.20);
  background: rgba(255,255,255,0.10);
  font-size: var(--text-sm);
  font-weight: 400;
  color: #fff;
  margin-bottom: 24px;
  letter-spacing: -0.15px;
}
.lp-badge-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #05DF72;
  flex-shrink: 0;
}

/* Hero headline */
.lp-hero-h1 {
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  font-weight: 500;
  letter-spacing: -0.023em;
  line-height: 1.15;
  color: #fff;
  margin: 0 0 0;
  /* Full row width so rotating line + blur aren’t clipped by a shrink-wrapped flex item */
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}
.lp-hero-h1-accent-wrap {
  display: block;
}
.lp-hero-h1-accent-viewport {
  display: block;
  overflow: hidden;
  /* Room for descenders (g, y) inside overflow:hidden; blur still needs vertical bleed */
  min-height: 2.55em;
  /*
   * Horizontal bleed: widen the clip box past the headline text so translate + filter:blur()
   * aren’t cut off at the sides. Negative margin pulls into hero side padding; padding restores alignment.
   */
  margin-inline: clamp(-3rem, -14vw, -1.25rem);
  padding-inline: clamp(3rem, 14vw, 10rem);
  /* Extra bottom (and top) padding so gradient text isn’t clipped; margin offsets layout shift */
  padding-block: 0.18em 0.34em;
  margin-block: -0.18em -0.34em;
}
.lp-hero-h1-accent {
  display: block;
  line-height: 1.22;
  background: linear-gradient(90deg, #51A2FF, #00D3F3);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.lp-hero-h1-accent-animate {
  transform-origin: 50% 50%;
}

@keyframes lpHeroAccentOut {
  0% {
    transform: translate3d(0, 0, 0);
    filter: blur(0);
    opacity: 1;
  }
  100% {
    transform: translate3d(-42%, 0, 0);
    filter: blur(12px);
    opacity: 0;
  }
}

@keyframes lpHeroAccentIn {
  0% {
    transform: translate3d(38%, 0, 0);
    filter: blur(11px);
    opacity: 0;
  }
  100% {
    transform: translate3d(0, 0, 0);
    filter: blur(0);
    opacity: 1;
  }
}

.lp-hero-h1-accent-animate--out {
  animation: lpHeroAccentOut 0.4s cubic-bezier(0.4, 0, 1, 1) forwards;
}

.lp-hero-h1-accent-animate--in {
  animation: lpHeroAccentIn 0.45s cubic-bezier(0, 0, 0.2, 1) forwards;
}

@media (prefers-reduced-motion: reduce) {
  .lp-hero-h1-accent-animate--out,
  .lp-hero-h1-accent-animate--in {
    animation: none !important;
  }
}
.lp-hero-sub {
  font-size: 1.25rem;
  font-weight: 400;
  color: #CAD5E2;
  max-width: 47.5rem;
  margin: 8px auto 18px;
  line-height: 1.65;
  letter-spacing: -0.028px;
}

/* Hero search box */
.lp-search-form { width: 100%; max-width: 42rem; margin-inline: auto; margin-bottom: 14px; }
.lp-search-box  { display: flex; align-items: center; background: #fff; border-radius: var(--r-sm); overflow: hidden; box-shadow: none; }
.lp-search-icon { display: flex; align-items: center; padding-left: 16px; color: #90A1B9; flex-shrink: 0; }
.lp-search-input { flex: 1; min-width: 0; height: 3.5rem; padding: 0 16px; border: none; outline: none; font-size: var(--text-base); color: #314158; background: transparent; }
.lp-search-input::placeholder { color: #90A1B9; }
.lp-search-btn  { display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2); height: 3.5rem; padding: 0 24px; background: var(--brand); color: #fff; border: none; font-size: var(--text-sm); font-weight: 500; cursor: pointer; flex-shrink: 0; transition: background var(--dur-sm) var(--ease); letter-spacing: -0.15px; }
.lp-search-btn:hover { background: var(--brand-hover); }
.lp-search-btn svg { display: inline-block; flex-shrink: 0; vertical-align: middle; }

/* Hero CTA buttons */
.lp-hero-ctas { display: flex; gap: 16px; justify-content: center; flex-wrap: nowrap; margin-bottom: 36px; }
.lp-btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 2.5rem;
  padding-inline: var(--sp-5);
  border: 1px solid rgba(255,255,255,0.50);
  border-radius: var(--r-sm);
  color: #fff;
  font-size: var(--text-sm);
  font-weight: 500;
  text-decoration: none;
  background: transparent;
  transition: background var(--dur-sm) var(--ease);
  cursor: pointer;
}
.lp-btn-ghost:hover { background: rgba(255,255,255,0.15); }
.lp-btn-ghost svg { display: inline-block; flex-shrink: 0; vertical-align: middle; }

/* Common LP section heading */
.lp-section-head { text-align: center; margin-bottom: 64px; }
.lp-section-head h2 { font-size: clamp(1.75rem, 4vw, 3rem); font-weight: 500; letter-spacing: 0.35px; line-height: 1.1; color: var(--n-900); margin-bottom: 16px; }
.lp-section-sub  { font-size: 1.25rem; color: var(--n-600); max-width: 47rem; margin-inline: auto; line-height: 1.6; letter-spacing: -0.028px; }
.lp-section-head-white h2 { color: #fff; }
.lp-section-head-white .lp-section-sub { color: #CAD5E2; }

/* Value Proposition section */
.lp-value { padding: 96px 0; background: var(--white); }
.lp-val-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }

.lp-val-card {
  border-radius: var(--r);
  padding: 40px 32px;
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 16px;
  row-gap: 12px;
}
.lp-val-card-1 { background: linear-gradient(135deg, #EFF6FF, #ECFEFF); }
.lp-val-card-2 { background: linear-gradient(135deg, #FAF5FF, #FDF2F8); }
.lp-val-card-3 { background: linear-gradient(135deg, #FFFBEB, #FFF7ED); }

.lp-val-icon {
  width: 48px; height: 48px; border-radius: var(--r);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 0;
  flex-shrink: 0;
  grid-column: 1;
  grid-row: 1;
  align-self: center;
}
.lp-val-icon-1 { background: #155DFC; }
.lp-val-icon-2 { background: #9810FA; }
.lp-val-icon-3 { background: #E17100; }

.lp-val-card h3 {
  font-size: 1.5rem;
  font-weight: 500;
  color: var(--n-900);
  margin: 0;
  letter-spacing: 0.07px;
  line-height: 1.25;
  grid-column: 2;
  grid-row: 1;
  align-self: center;
}
.lp-val-sub {
  font-size: 1rem;
  color: #314158;
  margin: 0 0 20px;
  line-height: 1.5;
  letter-spacing: -0.019px;
  grid-column: 1 / -1;
  grid-row: 2;
}

.lp-val-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  grid-column: 1 / -1;
  grid-row: 3;
}
.lp-val-item { display: flex; align-items: flex-start; gap: 10px; font-size: 1rem; color: #314158; line-height: 1.5; letter-spacing: -0.019px; }
.lp-val-dot  { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; margin-top: 7px; }
.lp-val-dot-1 { background: #155DFC; }
.lp-val-dot-2 { background: #9810FA; }
.lp-val-dot-3 { background: #E17100; }

/* Shopper Features */
.lp-features { padding: 96px 0; background: linear-gradient(135deg, var(--n-50), var(--brand-light)); }
.lp-feat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }

.lp-feat-card {
  background: linear-gradient(135deg, #F8FAFC, #EFF6FF);
  border-radius: var(--r);
  padding: 32px;
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 16px;
  row-gap: 12px;
}
.lp-feat-icon {
  width: 48px;
  height: 48px;
  border-radius: var(--r);
  background: var(--brand);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0;
  flex-shrink: 0;
  grid-column: 1;
  grid-row: 1;
  align-self: center;
}
.lp-feat-card h3 {
  font-size: 1.25rem;
  font-weight: 500;
  color: var(--n-900);
  letter-spacing: -0.028px;
  margin: 0;
  line-height: 1.35;
  grid-column: 2;
  grid-row: 1;
  align-self: center;
}
.lp-feat-card p {
  font-size: 1rem;
  color: #314158;
  line-height: 1.625;
  letter-spacing: -0.019px;
  margin: 0;
  grid-column: 1 / -1;
  grid-row: 2;
}

/* How It Works — dark bg */
.lp-how { padding: 96px 0; background: #0B1829; }
.lp-how-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; position: relative; }
.lp-step-card {
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.20);
  border-radius: var(--r);
  padding: 28px 24px;
  position: relative;
  transition: background var(--dur) var(--ease);
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 16px;
  row-gap: 12px;
  align-items: start;
}
.lp-step-card:hover { background: rgba(255,255,255,0.14); }
.lp-step-num {
  width: 2.75rem;
  height: 2.75rem;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 0.8125rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.02em;
  line-height: 1;
  grid-column: 1;
  grid-row: 1;
  align-self: start;
  margin-top: 0.125rem;
}
.lp-step-num--1 { background: var(--brand); }
.lp-step-num--2 { background: #9810fa; }
.lp-step-num--3 { background: var(--brand-teal); }
.lp-step-num--4 { background: #e17100; }
.lp-step-card h3 {
  font-size: 1.25rem;
  font-weight: 500;
  color: #fff;
  letter-spacing: -0.028px;
  line-height: 1.35;
  margin: 0 0 12px;
  padding: 0;
  grid-column: 2;
  grid-row: 1;
}
.lp-step-card p {
  font-size: 1rem;
  color: #cad5e2;
  line-height: 1.625;
  letter-spacing: -0.019px;
  margin: 0;
  grid-column: 1 / -1;
  grid-row: 2;
}

/* Testimonials */
.lp-testimonials { padding: 96px 0; background: var(--white); }
.lp-test-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.lp-test-card { border-radius: var(--r); border: 1px solid var(--border); padding: 28px; box-shadow: var(--shadow-sm); display: flex; flex-direction: column; }
.lp-test-stars { color: #F59E0B; font-size: 1rem; letter-spacing: 2px; margin-bottom: 16px; }
.lp-test-quote { font-size: 1rem; color: #314158; line-height: 1.625; flex: 1; margin-bottom: 20px; letter-spacing: -0.019px; }
.lp-test-footer { display: flex; align-items: center; gap: 12px; padding-top: 16px; border-top: 1px solid #F1F5F9; }
.lp-test-avatar { width: 40px; height: 40px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: var(--text-sm); font-weight: 600; color: #fff; flex-shrink: 0; }
.lp-test-name   { font-size: 1rem; font-weight: 500; color: var(--n-900); letter-spacing: -0.019px; }
.lp-test-role   { font-size: var(--text-sm); color: #62748E; letter-spacing: -0.015px; }

/* Stats */
.lp-stats { padding: 96px 0; background: var(--white); }
.lp-stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; }
.lp-stat-box { border-radius: var(--r); border: 1px solid var(--border); padding: 40px 24px; text-align: center; box-shadow: var(--shadow-sm); }
.lp-stat-box-num {
  display: block;
  font-size: 3rem; font-weight: 400; line-height: 1; letter-spacing: 0.35px;
  background: var(--brand-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 12px;
}
.lp-stat-box-lbl { font-size: 1rem; color: var(--n-600); line-height: 1.5; }

/* B2B lander: core positioning (no marketplace callouts) */
.lp-b2b-core {
  padding: var(--sp-10) var(--sp-6);
  background: linear-gradient(180deg, var(--n-100) 0%, var(--white) 100%);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.lp-b2b-core__inner {
  max-width: 46rem;
  margin: 0 auto;
  text-align: center;
  font-size: var(--text-lg);
  line-height: 1.7;
  color: var(--n-700);
}
.lp-b2b-feat-list {
  margin: var(--sp-3) 0 0;
  padding: 0;
  list-style: none;
  text-align: left;
}
.lp-b2b-feat-list li {
  position: relative;
  padding-left: 1.15rem;
  margin-bottom: var(--sp-2);
  font-size: var(--text-sm);
  line-height: 1.55;
  color: var(--n-600);
}
.lp-b2b-feat-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 5px;
  height: 5px;
  border-radius: 99px;
  background: var(--brand);
  opacity: 0.7;
}
.lp-feat-card--b2b h3 { margin-bottom: var(--sp-1); }

/* Browse by state (functional section within LP) */
.lp-browse { padding: 80px 0; background: var(--n-50); }
.lp-browse h2 { font-size: 2rem; font-weight: 500; color: var(--n-900); margin-bottom: 8px; }

/* Featured sales (functional section within LP) */
.lp-featured { padding: 80px 0; background: var(--white); }
.lp-featured .lp-featured-view-all {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--brand);
  letter-spacing: -0.02em;
  text-decoration: none;
}
.lp-featured .lp-featured-view-all:hover {
  color: var(--brand-hover);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.lp-featured .lp-featured-view-all svg {
  display: inline-block;
  flex-shrink: 0;
  vertical-align: middle;
}

/* CTA section — gradient full-bleed */
.lp-cta {
  padding: 96px var(--sp-8);
  text-align: center;
  background: linear-gradient(135deg, #155DFC 0%, #9810FA 50%, #E60076 100%);
  margin-bottom: calc(-1 * var(--sp-20)); /* cancel main padding-bottom */
}
.lp-cta-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 20px;
  border-radius: var(--r-full);
  border: 1px solid rgba(255,255,255,0.30);
  background: rgba(255,255,255,0.20);
  font-size: var(--text-sm);
  color: #fff;
  margin-bottom: 24px;
  letter-spacing: -0.15px;
}
.lp-cta h2 { font-size: clamp(1.75rem, 4vw, 3rem); font-weight: 500; color: #fff; letter-spacing: 0.35px; line-height: 1.1; margin-bottom: 24px; }
.lp-cta-sub { font-size: 1.25rem; color: rgba(255,255,255,0.90); max-width: 41rem; margin-inline: auto; line-height: 1.65; margin-bottom: 48px; letter-spacing: -0.028px; }
.lp-cta-btns { display: flex; gap: 16px; justify-content: center; flex-wrap: nowrap; margin-bottom: 32px; }
.lp-cta-btn-primary {
  display: inline-flex; align-items: center; gap: 8px; height: 2.5rem;
  padding-inline: var(--sp-5); border-radius: var(--r-sm);
  background: #fff; color: #155DFC; border: none;
  font-size: var(--text-sm); font-weight: 500; text-decoration: none; cursor: pointer;
  transition: opacity var(--dur-sm) var(--ease);
}
.lp-cta-btn-primary:hover { opacity: 0.9; }
.lp-cta-btn-primary svg { display: inline-block; flex-shrink: 0; vertical-align: middle; }
.lp-cta-btn-ghost { display: inline-flex; align-items: center; gap: 8px; height: 2.5rem; padding-inline: var(--sp-5); border-radius: var(--r-sm); background: transparent; color: #fff; border: 1px solid rgba(255,255,255,0.50); font-size: var(--text-sm); font-weight: 500; text-decoration: none; cursor: pointer; transition: background var(--dur-sm) var(--ease); }
.lp-cta-btn-ghost:hover { background: rgba(255,255,255,0.15); }
.lp-cta-btn-ghost svg { display: inline-block; flex-shrink: 0; vertical-align: middle; }
.lp-cta-bullets { display: flex; gap: 24px; justify-content: center; flex-wrap: wrap; }
.lp-cta-bullet { display: flex; align-items: center; gap: 8px; font-size: var(--text-sm); color: rgba(255,255,255,0.80); }
.lp-cta-bullet-dot { width: 8px; height: 8px; border-radius: 50%; background: #05DF72; flex-shrink: 0; }

/* ---- Footer --------------------------------------------------------------- */
.site-footer { background: #f8fafc; padding-block: var(--sp-12) var(--sp-6); color: #717182; border-top: 1px solid rgba(0,0,0,0.08); }
/* /dashboard/*: marketing grid omitted in layout; one-line legal bar only */
.site-footer.site-footer--pro-app {
  padding-block: var(--sp-4) var(--sp-5);
}
.site-footer.site-footer--pro-app .footer-bottom {
  display: flex;
  justify-content: center;
  text-align: center;
}
.site-footer.site-footer--pro-app .footer-bottom__one-line {
  min-width: 0;
  max-width: 100%;
}
/* Fluid columns: stack on very narrow viewports, no breakpoint cascade needed */
.site-footer .footer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 17.5rem), 1fr));
  gap: clamp(1.25rem, 3.5vw, 2.5rem);
  margin-bottom: var(--sp-12);
}
/* /admin: use fuller footer width so marketing columns stay on one row */
body.is-admin-shell .site-footer > .shell {
  max-width: min(100vw - 2rem, 96rem);
}
body.is-admin-shell .site-footer .footer-grid {
  grid-template-columns: minmax(18rem, 1.6fr) repeat(4, minmax(10rem, 1fr));
}
/* Public marketing + sale listing: keep all footer columns on one row (scroll shell on narrow viewports). */
body.is-public-site-shell .site-footer > .shell {
  max-width: min(100vw - 2rem, 96rem);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}
body.is-public-site-shell .site-footer .footer-grid {
  grid-template-columns: minmax(18rem, 1.6fr) repeat(4, minmax(10rem, 1fr));
}

.footer-logo {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1.25rem;
  font-weight: 700;
  text-decoration: none;
  letter-spacing: -0.01em;
  margin-bottom: var(--sp-4);
  background: linear-gradient(90deg, #155DFC, #9810FA);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
/* Footer: same brand mark as header, slightly smaller for the column */
.footer-logo .logo-es-mark {
  display: block;
  width: 28px;
  height: 28px;
  object-fit: contain;
  flex-shrink: 0;
  -webkit-text-fill-color: initial;
  background: none;
  -webkit-background-clip: initial;
  background-clip: border-box;
}
.footer-desc { font-size: var(--text-sm); line-height: 1.625; color: #717182; max-width: 18rem; margin-bottom: var(--sp-6); letter-spacing: -0.015px; }

/* Social icons */
.footer-social { display: flex; gap: 12px; }
.footer-social-link {
  width: 36px; height: 36px; border-radius: 50%;
  border: 1.5px solid rgba(0,0,0,0.20);
  display: flex; align-items: center; justify-content: center;
  color: rgba(10,10,10,0.55);
  text-decoration: none;
  transition: border-color var(--dur-sm) var(--ease), color var(--dur-sm) var(--ease);
}
.footer-social-link:hover { border-color: #155DFC; color: #155DFC; }

/* Figma n_e45f3, n_03d41, n_74b75, n_b4e7b: footer column headings are 16px/600 */
.footer-heading { display: block; font-size: 1rem; font-weight: 600; color: #0a0a0a; letter-spacing: -0.015px; margin-bottom: var(--sp-4); }
.footer-links { list-style: none; display: flex; flex-direction: column; gap: var(--sp-3); }
.footer-links a { font-size: var(--text-sm); color: #717182; text-decoration: none; letter-spacing: -0.015px; transition: color var(--dur-sm) var(--ease); }
.footer-links a:hover { color: #155DFC; }

.footer-divider { border: none; border-top: 1px solid rgba(0,0,0,0.10); margin-bottom: var(--sp-6); }
.footer-bottom {
  color: #717182;
  font-size: 12pt;
  letter-spacing: 0.01em;
  line-height: 1.4;
}
/* Single row: one size, one color, nowrap with horizontal scroll on narrow viewports */
.footer-bottom__one-line {
  margin: 0;
  max-width: 100%;
  white-space: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  font: inherit;
  color: inherit;
  scrollbar-width: thin;
}
.footer-bottom__one-line a.footer-bottom__link {
  color: inherit;
  text-decoration: none;
  font: inherit;
  transition: color var(--dur-sm) var(--ease);
}
.footer-bottom__one-line a:hover {
  color: #155DFC;
}
.footer-bottom__text,
.footer-bottom__sep { color: inherit; font: inherit; }
.footer-bottom__sep { user-select: none; }

/* ====================================================================
   Public sale listing (SEO detail) — IA inspired by directory norms; EstateSail theme
   ==================================================================== */
.sale-listing {
  max-width: var(--container);
  margin-inline: auto;
  /* When hero is stuck: distance from viewport top — overridden by sale-listing-hero-sticky-offset.js from #site-header height */
  --sale-listing-sticky-top: calc(3.75rem + 1px);
}
@media (max-width: 768px) {
  .sale-listing {
    /* No-JS fallback before layout script measures real header (often one row + menu; avoid oversized gap) */
    --sale-listing-sticky-top: calc(4.25rem + 1px);
  }
  /* Flush listing hero band under the sticky site header (`.main` default padding-top would gap). */
  .main.shell:has(.sale-listing) {
    padding-top: 0;
  }
  .main.shell:has(.sale-listing) > .flash:first-child {
    margin-top: var(--sp-3);
  }
  .sale-listing__hero {
    padding-top: var(--sp-4);
  }
}
.sale-listing__hero {
  position: sticky;
  top: var(--sale-listing-sticky-top);
  z-index: 40;
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-5);
  border-bottom: 1px solid var(--border);
  background: var(--bg);
}
@media print {
  .sale-listing__hero {
    position: static;
    top: auto;
    z-index: auto;
    box-shadow: none;
  }
}
.sale-listing__title {
  font-size: clamp(var(--text-2xl), 4vw, var(--text-4xl));
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.15;
  margin-bottom: var(--sp-4);
  color: var(--primary);
  border: 0;
  box-shadow: none;
  text-shadow: none;
  background: transparent;
}
.sale-listing__hero-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-3);
  row-gap: var(--sp-3);
}
.sale-listing__hero-meta .sale-listing__pills {
  flex: 1 1 auto;
  min-width: 0;
}
/* Desktop / tablet: wrapper is transparent so the toolbar flexes with the hero row */
.sale-listing__toolbar-scroll {
  display: contents;
}
.sale-listing__hero-meta .sale-listing__toolbar {
  flex: 0 1 auto;
  margin-left: auto;
  margin-bottom: 0;
  padding: 0;
  justify-content: flex-end;
}
/* Narrow viewports: one full-width row under pills; horizontal scroll keeps buttons tidy */
@media (max-width: 720px) {
  .sale-listing__toolbar-scroll {
    display: block;
    flex: 1 1 100%;
    width: 100%;
    min-width: 0;
    margin-left: 0;
    margin-top: var(--sp-2);
  }
  .sale-listing__hero-meta .sale-listing__toolbar-scroll .sale-listing__toolbar {
    margin-left: 0;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-items: stretch;
    overflow-x: auto;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    /* Equal spacing between every button */
    gap: var(--sp-2);
    padding: var(--sp-1) 0 0;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    touch-action: manipulation;
  }
  .sale-listing__hero-meta .sale-listing__toolbar-scroll .sale-listing__tool-btn.btn.btn-sm {
    /* .btn-sm sets a short height; use auto + min so icon+label row is not clipped */
    height: auto;
    min-height: 2.75rem;
    white-space: nowrap;
  }
  .sale-listing__hero-meta .sale-listing__toolbar-scroll .sale-listing__tool-btn {
    /* Equal-width columns; glyph left, label right (match DOM order) */
    flex: 1 1 0;
    min-width: 0;
    max-width: none;
    padding: var(--sp-1) var(--sp-2);
    justify-content: center;
    align-items: center;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 0.25rem;
  }
  .sale-listing__hero-meta .sale-listing__toolbar-scroll .sale-listing__tool-btn svg {
    flex-shrink: 0;
    width: 0.875rem;
    height: 0.875rem;
  }
  .sale-listing__hero-meta .sale-listing__toolbar-scroll .sale-listing__tool-btn .sale-listing__tool-btn-text {
    position: static;
    width: auto;
    max-width: 100%;
    min-width: 0;
    height: auto;
    padding: 0;
    margin: 0;
    overflow: hidden;
    clip: auto;
    white-space: nowrap;
    border: 0;
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.02em;
    /* Primary toolbar: labels sit on brand fill */
    color: rgba(255, 255, 255, 0.95);
    line-height: 1.15;
    text-align: start;
    text-overflow: ellipsis;
  }
}
.sale-listing__pills {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2);
}
.sale-listing__pill {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.65rem;
  border-radius: var(--r-full);
  font-size: var(--text-xs);
  font-weight: 600;
  background: var(--surface);
  border: 1px solid var(--border);
  color: var(--text);
}
.sale-listing__pill--muted {
  color: var(--text-muted);
  background: var(--n-50);
}
.sale-listing__facts {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
}
@media (min-width: 720px) {
  .sale-listing__facts {
    grid-template-columns: 1fr 1fr;
  }
}
.sale-listing__fact {
  display: flex;
  gap: var(--sp-4);
  padding: var(--sp-5);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-xs);
}
.sale-listing__fact-icon {
  flex-shrink: 0;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: var(--r);
  background: var(--brand-light);
  color: var(--brand);
  display: flex;
  align-items: center;
  justify-content: center;
}
.sale-listing__fact-label {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  margin: 0 0 var(--sp-2);
}
.sale-listing__fact-value {
  margin: 0;
  font-size: var(--text-base);
  font-weight: 400;
  color: var(--primary);
  line-height: 1.45;
}
/* Listing hero facts: address + dates summary slightly smaller body text */
.sale-listing__facts .sale-listing__fact-value {
  font-size: calc(var(--text-base) - 2px);
}
.sale-listing__fact-sub {
  margin: var(--sp-2) 0 0;
}
.sale-listing__fact-inner {
  flex: 1;
  min-width: 0;
}
/* Countdown anchored to card padding so “Address will be revealed…” sits top-right of the card */
.sale-listing__fact--address-has-countdown {
  position: relative;
}
.sale-listing__fact-inner--address-masked {
  position: static;
}
.sale-listing__fact--address-has-countdown .sale-listing__address-countdown--pinned {
  position: absolute;
  top: var(--sp-5);
  right: var(--sp-5);
  z-index: 1;
  margin: 0;
  max-width: min(100%, 19rem);
  text-align: right;
  line-height: 1.25;
  color: var(--brand);
  font-weight: 600;
}
.sale-listing__fact-inner--address-masked .sale-listing__fact-label--address-row {
  margin: 0 0 var(--sp-2);
  padding-right: min(15rem, 62vw);
}
.sale-listing__fact-value--address-line {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sale-listing__fact-head--split {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-2) var(--sp-4);
}
.sale-listing__fact-head--split .sale-listing__fact-label {
  margin: 0 0 var(--sp-2);
  flex: 1 1 auto;
  min-width: 0;
}
.sale-listing__fact-head--split .sale-listing__address-countdown {
  margin: 0 0 var(--sp-2);
  flex: 0 1 auto;
  margin-left: auto;
  max-width: min(100%, 18rem);
  text-align: right;
  line-height: 1.35;
}
.sale-listing__fact--address-has-countdown .sale-listing__fact-inner > .sale-listing__fact-value {
  margin-top: 0;
}
.sale-listing__address-countdown {
  margin: var(--sp-2) 0 0;
}
.sale-listing__facts .sale-listing__address-countdown,
.sale-listing__facts .sale-listing__address-pending {
  font-size: calc(var(--text-sm) - 2px);
}
.sale-listing__fact-value--schedule-range {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: var(--sp-1) var(--sp-3);
}
.sale-listing__fact-value--schedule-range .sale-listing__schedule-range-sep {
  text-transform: lowercase;
}
/* Hours vary by day: stack under date range on narrow viewports (listing facts card) */
.sale-listing__fact-value--hours-vary {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  column-gap: 0.35em;
}
@media (max-width: 719px) {
  .sale-listing__fact-value--hours-vary {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--sp-1);
    column-gap: unset;
  }
}
@media (min-width: 720px) {
  .sale-listing__fact-value--hours-vary .sale-listing__schedule-hours-vary-note::before {
    content: ' ';
  }
}
@media (max-width: 479px) {
  .sale-listing__fact-value--schedule-range {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--sp-2);
  }
  .sale-listing__fact-value--schedule-range .sale-listing__schedule-range-sep {
    font-size: var(--text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
  }
}
/* Schedule fact: pin “Show Full Schedule” to top-right of the card content column */
.sale-listing__fact-inner--schedule-modal {
  position: relative;
}
.sale-listing__fact-inner--schedule-modal .sale-listing__fact-label--schedule-row {
  margin: 0 0 var(--sp-2);
  padding-right: min(11.75rem, 54vw);
}
.sale-listing__schedule-full-open--pinned {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1;
}
.sale-listing__schedule-full-open {
  margin: 0;
  padding: 0;
  border: 0;
  background: none;
  font: inherit;
  font-size: calc(var(--text-sm) - 2px);
  font-weight: 600;
  color: var(--brand);
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
  text-align: right;
}
.sale-listing__schedule-full-open:hover {
  color: var(--brand-hover);
  text-decoration: none;
}
.sale-listing__schedule-full-open:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
  border-radius: var(--r-sm);
}
.sale-schedule-full-dialog .sale-listing__schedule {
  max-height: min(60vh, 28rem);
  overflow-y: auto;
  padding-right: var(--sp-1);
}
.sale-listing__schedule {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.sale-listing__schedule-row {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: var(--sp-2);
  padding: var(--sp-4) 0;
  border-bottom: 1px solid var(--n-100);
  font-size: calc(var(--text-sm) - 2px);
}
.sale-listing__schedule-row:first-child {
  padding-top: 0;
}
.sale-listing__schedule-row:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}
.sale-listing__schedule-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: var(--sp-2) var(--sp-5);
}
.sale-listing__schedule-day {
  font-weight: 800;
  font-size: calc(var(--text-xs) - 2px);
  text-transform: uppercase;
  color: var(--brand);
  letter-spacing: 0.04em;
}
.sale-listing__schedule-date {
  font-weight: 700;
  font-size: calc(var(--text-base) - 2px);
  color: var(--primary);
}
.sale-listing__schedule-time {
  font-size: calc(var(--text-sm) - 2px);
  color: var(--text);
  line-height: 1.5;
  margin: 0;
  padding: 0;
}
/* Full schedule modal (listing): keep weekday + date + times on one row on narrow phones */
@media (max-width: 479px) {
  .sale-schedule-full-dialog .sale-listing__schedule {
    gap: var(--sp-3);
  }
  .sale-schedule-full-dialog .sale-listing__schedule-row {
    display: grid;
    grid-template-columns: 2.75rem 7.5rem minmax(0, 1fr);
    gap: var(--sp-2) var(--sp-4);
    align-items: baseline;
    padding: 0;
    border-bottom: 0;
  }
  .sale-schedule-full-dialog .sale-listing__schedule-meta {
    display: contents;
  }
  .sale-schedule-full-dialog .sale-listing__schedule-date {
    font-size: var(--text-sm);
    min-width: 0;
  }
}
@media (min-width: 480px) {
  .sale-listing__schedule {
    gap: var(--sp-3);
  }
  .sale-listing__schedule-row {
    display: grid;
    grid-template-columns: 2.75rem 7.5rem minmax(0, 1fr);
    gap: var(--sp-2) var(--sp-4);
    align-items: baseline;
    padding: 0;
    border-bottom: 0;
  }
  .sale-listing__schedule-meta {
    display: contents;
  }
  .sale-listing__schedule-date {
    font-size: var(--text-sm);
  }
}
.sale-listing__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2);
}
.sale-listing__tool-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  text-decoration: none;
}
.shopper-signup-dialog {
  max-width: min(32rem, calc(100vw - 2rem));
  border: 1px solid var(--border);
  box-shadow: var(--shadow-md), 0 0 0 1px rgba(255, 255, 255, 0.06) inset;
}
.shopper-signup-dialog__inner {
  border-radius: var(--r-lg);
  overflow: hidden;
  background: linear-gradient(180deg, var(--n-50) 0%, var(--white) 3.5rem);
}
.shopper-signup-dialog__header {
  padding-top: var(--sp-6);
  background: linear-gradient(135deg, var(--brand-light) 0%, var(--white) 48%);
  border-bottom-color: var(--border);
}
#shopper-signup-progress-fill:focus {
  outline: none;
}
.shopper-signup-dialog__body {
  padding: var(--sp-5) var(--sp-6) var(--sp-6);
}
.shopper-signup-dialog__lede {
  color: var(--text);
  font-weight: 500;
}
.shopper-signup-dialog__progress {
  margin: 0 0 var(--sp-5);
}
.shopper-signup-dialog__progress-track {
  position: relative;
  height: 0.5rem;
  border-radius: var(--r-full);
  background: var(--n-200);
  overflow: hidden;
  box-shadow: none;
}
.shopper-signup-dialog__progress-fill {
  position: relative;
  height: 100%;
  width: 50%;
  border-radius: inherit;
  background: var(--brand-gradient);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.2) inset;
  transition: width 0.42s cubic-bezier(0.33, 1, 0.68, 1);
}
.shopper-signup-dialog__progress-fill::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.45) 0%, transparent 45%, rgba(0, 0, 0, 0.07) 100%);
  pointer-events: none;
}
.shopper-signup-dialog__progress-steps {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: var(--sp-3);
  padding: 0 var(--sp-1);
  gap: var(--sp-4);
}
.shopper-signup-dialog__progress-step {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--n-500);
  transition: color 0.25s var(--ease);
}
.shopper-signup-dialog__progress-step.is-active {
  color: var(--brand);
}
.shopper-signup-dialog__progress-dot {
  flex-shrink: 0;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background: var(--n-300);
  box-shadow: 0 0 0 2px var(--white), 0 0 0 3px var(--n-200);
  transition: background 0.25s var(--ease), box-shadow 0.25s var(--ease);
}
.shopper-signup-dialog__progress-step.is-active .shopper-signup-dialog__progress-dot {
  background: var(--brand);
  box-shadow: 0 0 0 2px var(--white), 0 0 0 3px var(--brand-light);
}
.shopper-signup-dialog__progress-text {
  white-space: nowrap;
}
/* .flash uses display:flex and overrides [hidden]; only add .flash when JS shows a message */
.shopper-signup-dialog .shopper-signup-dialog__flash.flash {
  margin-bottom: var(--sp-3);
}
.shopper-signup-dialog__flash[hidden] {
  display: none !important;
}
.shopper-signup-dialog__row {
  display: grid;
  gap: var(--sp-3) var(--sp-4);
}
.shopper-signup-dialog__row--2 {
  grid-template-columns: 1fr 1fr;
}
/* State column must fit js-es-custom-select trigger + caret (~5.5rem+); narrow cols clip .es-custom-select__value */
.shopper-signup-dialog__row--3 {
  grid-template-columns: minmax(0, 1fr) minmax(5.75rem, 8rem) minmax(5.75rem, 9rem);
  align-items: end;
}
.shopper-signup-dialog__row--contact {
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr);
}
@media (max-width: 520px) {
  .shopper-signup-dialog__row--2:not(.shopper-signup-dialog__row--contact) {
    grid-template-columns: 1fr;
  }
  /* City + state one row; ZIP full width beneath (phone signup modal) */
  .shopper-signup-dialog__row--3 {
    grid-template-columns: minmax(0, 1fr) minmax(5.5rem, 8rem);
    align-items: end;
  }
  .shopper-signup-dialog__row--3 > .sale-route-dialog__field:nth-child(3) {
    grid-column: 1 / -1;
  }
  .shopper-signup-dialog__row--contact {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: var(--sp-3) var(--sp-3);
  }
}
@media (max-width: 400px) {
  .shopper-signup-dialog__row--contact {
    grid-template-columns: 1fr;
  }
}
.shopper-signup-dialog__pass-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.shopper-signup-dialog__pass-input {
  padding-right: 2.75rem;
  width: 100%;
}
.shopper-signup-dialog__pass-toggle {
  position: absolute;
  right: var(--sp-2);
  top: 50%;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  padding: 0;
  border: none;
  border-radius: var(--r-sm);
  background: transparent;
  color: var(--n-500);
  cursor: pointer;
  transition: background var(--dur-sm) var(--ease), color var(--dur-sm) var(--ease);
}
.shopper-signup-dialog__pass-toggle:hover {
  background: var(--n-100);
  color: var(--brand);
}
.shopper-signup-dialog__phone,
.shopper-signup-dialog__state {
  font-variant-numeric: tabular-nums;
}
.shopper-signup-dialog__step2-intro {
  margin: 0 0 var(--sp-3);
}
.shopper-signup-dialog__step2-title {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--primary);
  letter-spacing: -0.01em;
  line-height: 1.35;
}
.shopper-signup-dialog__step2-lede {
  margin: 0;
  font-size: var(--text-xs);
  line-height: 1.5;
  color: var(--text-muted);
}
.shopper-signup-dialog__field-label {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text);
}
.shopper-signup-dialog__range-inline {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-xs);
}
.shopper-signup-dialog #shopper-signup-step1 .sale-route-dialog__field,
.shopper-signup-dialog #shopper-signup-step1 > .shopper-signup-dialog__row {
  margin-bottom: var(--sp-3);
}
.shopper-signup-dialog #shopper-signup-step1 .es-address-fields {
  gap: var(--sp-3);
}
.shopper-signup-dialog__hint {
  margin: var(--sp-2) 0 0;
  font-size: var(--text-xs);
  line-height: 1.45;
  color: var(--text-muted);
}
.shopper-signup-dialog__address-validation-error {
  margin: var(--sp-2) 0 0;
  font-size: var(--text-xs);
  line-height: 1.45;
  color: var(--red);
}
.shopper-signup-dialog__alerts-panel {
  margin: 0 0 var(--sp-4);
  padding: var(--sp-4);
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: var(--white);
  box-shadow: none;
  transition: opacity var(--dur-sm) var(--ease), filter var(--dur-sm) var(--ease);
}
.shopper-signup-dialog__alerts-panel.is-muted {
  opacity: 0.55;
  filter: grayscale(0.06);
  pointer-events: none;
}
.shopper-signup-dialog__decline-option {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  margin: 0 0 var(--sp-5);
  padding: var(--sp-4);
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: linear-gradient(165deg, var(--white) 0%, var(--n-50) 100%);
  cursor: pointer;
  transition: border-color var(--dur-sm) var(--ease), box-shadow var(--dur-sm) var(--ease), background var(--dur-sm) var(--ease);
}
.shopper-signup-dialog__decline-option:hover {
  border-color: #9bb8f6;
  box-shadow: none;
}
.shopper-signup-dialog__decline-option:focus-within {
  box-shadow: 0 0 0 2px var(--brand-light);
}
.shopper-signup-dialog__decline-option input {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  margin: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
}
.shopper-signup-dialog__decline-box {
  flex-shrink: 0;
  width: 1.375rem;
  height: 1.375rem;
  margin-top: 0.1rem;
  border-radius: var(--r);
  border: 2px solid var(--n-400);
  background: var(--white);
  display: grid;
  place-items: center;
  transition: border-color var(--dur-sm) var(--ease), background var(--dur-sm) var(--ease), box-shadow var(--dur-sm) var(--ease);
}
.shopper-signup-dialog__decline-check {
  stroke: var(--white);
  opacity: 0;
  transform: scale(0.85);
  transition: opacity var(--dur-sm) var(--ease), transform var(--dur-sm) var(--ease);
}
.shopper-signup-dialog__decline-option input:checked + .shopper-signup-dialog__decline-box {
  background: var(--brand);
  border-color: var(--brand);
  box-shadow: none;
}
.shopper-signup-dialog__decline-option input:checked + .shopper-signup-dialog__decline-box .shopper-signup-dialog__decline-check {
  opacity: 1;
  transform: scale(1);
}
.shopper-signup-dialog__decline-copy {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  min-width: 0;
}
.shopper-signup-dialog__decline-title {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--primary);
  line-height: 1.35;
}
.shopper-signup-dialog__decline-sub {
  font-size: var(--text-xs);
  color: var(--text-muted);
  line-height: 1.4;
}
.shopper-signup-dialog__rule {
  display: block;
  width: 100%;
  height: 0;
  margin: var(--sp-5) 0 var(--sp-3);
  padding: 0;
  border: none;
  border-top: 1px solid var(--border);
}
.shopper-signup-dialog__terms-row {
  margin: 0 0 var(--sp-3);
}
.shopper-signup-dialog__terms-block {
  margin: 0;
}
@keyframes shopper-signup-field-flash {
  0%,
  100% {
    box-shadow: 0 0 0 0 transparent;
  }
  25%,
  75% {
    box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.35);
  }
}
.shopper-signup-dialog__field-flash {
  animation: shopper-signup-field-flash 0.85s ease-in-out 2;
  border-radius: var(--r-md);
}
.shopper-signup-dialog__footer {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  flex-wrap: wrap;
  width: 100%;
  margin-top: var(--sp-2);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border);
  box-sizing: border-box;
  justify-content: space-between;
}
.shopper-signup-dialog__footer--step1,
.shopper-signup-dialog__footer--step2 {
  justify-content: space-between;
}
.shopper-signup-dialog__nav-back {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  padding: 0.5rem 0.85rem;
  font-weight: 600;
  color: var(--text);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  transition: background var(--dur-sm) var(--ease), border-color var(--dur-sm) var(--ease), color var(--dur-sm) var(--ease);
}
.shopper-signup-dialog__nav-back:hover {
  background: var(--n-50);
  border-color: var(--n-300);
  color: var(--primary);
}
.shopper-signup-dialog__nav-back svg {
  flex-shrink: 0;
  margin-left: -0.1rem;
}
.shopper-signup-dialog__primary-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  min-height: 2.65rem;
  padding-left: var(--sp-5);
  padding-right: var(--sp-5);
  font-weight: 700;
  letter-spacing: 0.02em;
}
.shopper-signup-dialog__primary-glyph {
  flex-shrink: 0;
}
.shopper-signup-dialog__footer--step1 .shopper-signup-dialog__primary-glyph--check {
  display: none !important;
}
.shopper-signup-dialog__primary-glyph--check {
  stroke: currentColor;
}
.shopper-signup-dialog__primary-glyph--forward {
  stroke: currentColor;
  margin-right: -0.15rem;
}
.shopper-signup-dialog__primary-action:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}
@media (max-width: 420px) {
  .shopper-signup-dialog__footer--step1,
  .shopper-signup-dialog__footer--step2 {
    flex-direction: column-reverse;
    align-items: stretch;
  }
  .shopper-signup-dialog__footer--step1 .shopper-signup-dialog__nav-back,
  .shopper-signup-dialog__footer--step2 .shopper-signup-dialog__nav-back {
    width: 100%;
  }
  .shopper-signup-dialog__footer--step1 .shopper-signup-dialog__primary-action,
  .shopper-signup-dialog__footer--step2 .shopper-signup-dialog__primary-action {
    width: 100%;
  }
}
.shopper-signup-dialog__check {
  font-size: var(--text-sm);
  display: flex;
  align-items: flex-start;
  gap: var(--sp-2);
  cursor: pointer;
}
.shopper-signup-dialog__check input {
  margin-top: 0.2rem;
}
.shopper-signup-dialog__range-wrap {
  margin: var(--sp-2) 0 0;
  padding: 0.35rem 0;
}
.shopper-signup-dialog__range {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 1.5rem;
  margin: 0;
  background: transparent;
  cursor: pointer;
  accent-color: var(--brand);
}
.shopper-signup-dialog__range:focus {
  outline: none;
}
.shopper-signup-dialog__range:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 4px;
  border-radius: var(--r-sm);
}
.shopper-signup-dialog__range::-webkit-slider-runnable-track {
  height: 0.4rem;
  border-radius: var(--r-full);
  background: var(--n-200);
  box-shadow: none;
}
.shopper-signup-dialog__range::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 1.2rem;
  height: 1.2rem;
  margin-top: calc((0.4rem - 1.2rem) / 2);
  border-radius: 50%;
  background: linear-gradient(180deg, #3d7bfd 0%, var(--brand) 50%, var(--brand-hover) 100%);
  border: 2px solid var(--white);
  box-shadow: 0 0 0 1px rgba(21, 93, 252, 0.25);
}
.shopper-signup-dialog__range:active::-webkit-slider-thumb {
  box-shadow: none;
}
.shopper-signup-dialog__range::-moz-range-track {
  height: 0.4rem;
  border-radius: var(--r-full);
  background: var(--n-200);
  box-shadow: none;
}
.shopper-signup-dialog__range::-moz-range-thumb {
  width: 1.2rem;
  height: 1.2rem;
  border-radius: 50%;
  background: linear-gradient(180deg, #3d7bfd 0%, var(--brand) 50%, var(--brand-hover) 100%);
  border: 2px solid var(--white);
  box-shadow: none;
}
.shopper-signup-dialog__range::-moz-range-progress {
  height: 0.4rem;
  border-radius: var(--r-full);
  background: var(--brand);
}
.shopper-signup-dialog__range-hint {
  margin: var(--sp-1) 0 0;
}
.shopper-signup-dialog__radius-map-wrap {
  margin-top: var(--sp-4);
}
.shopper-signup-dialog__map-status {
  margin: 0 0 var(--sp-2);
  color: var(--text-muted);
}
.shopper-signup-dialog__map-status:not([hidden]) {
  display: block;
}
.shopper-signup-dialog__radius-map {
  width: 100%;
  height: 14rem;
  min-height: 12rem;
  border-radius: var(--r-md);
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--n-100);
}
.shopper-inv-radius-map-section {
  margin-top: var(--sp-4);
}
.shopper-inv-radius-map-section--lead {
  margin-top: 0;
}
.shopper-inv-radius-map__fallback {
  margin-top: var(--sp-2);
  margin-bottom: 0;
}
.shopper-keyword-tags__limit-msg {
  margin-top: var(--sp-2);
  margin-bottom: 0;
  color: var(--danger, #b91c1c);
}
.shopper-keyword-tags__limit-msg:not([hidden]) {
  display: block;
}
.shopper-signup-dialog__login-hint {
  margin: var(--sp-5) 0 0;
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border);
  text-align: center;
}
.shopper-signup-dialog__login-link {
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: var(--brand);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
  cursor: pointer;
}
.shopper-signup-dialog__login-link:hover {
  color: var(--primary);
}
.shopper-listing-login-dialog {
  max-width: min(26rem, calc(100vw - 2rem));
  border: 1px solid var(--border);
  box-shadow: var(--shadow-md), 0 0 0 1px rgba(255, 255, 255, 0.06) inset;
}
.shopper-listing-login-dialog__inner {
  border-radius: var(--r-lg);
  overflow: hidden;
  background: linear-gradient(180deg, var(--n-50) 0%, var(--white) 3.5rem);
}
.shopper-listing-login-dialog__header {
  padding-top: var(--sp-6);
  background: linear-gradient(135deg, var(--brand-light) 0%, var(--white) 48%);
  border-bottom: 1px solid var(--border);
}
.shopper-listing-login-dialog__body {
  padding: var(--sp-5) var(--sp-6) var(--sp-6);
}
.shopper-listing-login-dialog__lede {
  margin: 0 0 var(--sp-4);
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--text-muted);
}
.shopper-listing-login-dialog__flash {
  margin: 0 0 var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--text-sm);
  line-height: 1.45;
  border-radius: var(--r);
  border: 1px solid transparent;
}
.shopper-listing-login-dialog__flash--error {
  color: var(--red);
  background: var(--red-bg);
  border-color: var(--red-border);
}
.shopper-listing-login-dialog__pass-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.shopper-listing-login-dialog__pass-input {
  padding-right: 2.75rem;
  width: 100%;
}
.shopper-listing-login-dialog__pass-toggle {
  position: absolute;
  right: var(--sp-2);
  top: 50%;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.25rem;
  height: 2.25rem;
  padding: 0;
  border: none;
  border-radius: var(--r-sm);
  background: transparent;
  color: var(--n-500);
  cursor: pointer;
  transition: background var(--dur-sm) var(--ease), color var(--dur-sm) var(--ease);
}
.shopper-listing-login-dialog__pass-toggle:hover {
  background: var(--n-100);
  color: var(--brand);
}
.shopper-listing-login-dialog__footer {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-top: var(--sp-5);
  align-items: center;
  justify-content: space-between;
}
.shopper-listing-login-dialog__btn-primary,
.shopper-listing-login-dialog__btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  min-height: 2.65rem;
  padding-left: var(--sp-5);
  padding-right: var(--sp-5);
  font-weight: 700;
  letter-spacing: 0.02em;
}
.shopper-listing-login-dialog__btn-secondary {
  border: 1px solid var(--n-300);
  background: var(--white);
  color: var(--primary);
}
.shopper-listing-login-dialog__btn-secondary:hover {
  background: var(--n-50);
  border-color: var(--n-400);
}
.shopper-listing-login-dialog__btn-glyph {
  flex-shrink: 0;
  stroke: currentColor;
}
.shopper-listing-login-dialog__btn-primary .shopper-listing-login-dialog__btn-glyph {
  margin-right: -0.1rem;
}
.shopper-listing-login-dialog__subnav {
  margin: var(--sp-5) 0 0;
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border);
  text-align: center;
}
.shopper-listing-login-dialog__subnav a {
  color: var(--brand);
  font-weight: 600;
  text-decoration: none;
}
.shopper-listing-login-dialog__subnav a:hover {
  text-decoration: underline;
}
.shopper-listing-login-dialog__subnav-sep {
  margin: 0 var(--sp-2);
  color: var(--n-400);
}
.shopper-listing-login-dialog__open-from-account {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
}
@media (max-width: 420px) {
  .shopper-listing-login-dialog__footer {
    flex-direction: column-reverse;
    align-items: stretch;
  }
  .shopper-listing-login-dialog__btn-primary,
  .shopper-listing-login-dialog__btn-secondary {
    width: 100%;
  }
}
.sale-listing-account-dialog__actions {
  flex-direction: column;
  align-items: stretch;
}
.sale-listing .btn-link-style {
  background: none;
  border: 0;
  padding: 0;
  font: inherit;
  color: var(--brand);
  text-decoration: underline;
  text-align: center;
  cursor: pointer;
}
.sale-listing .btn-link-style:hover {
  color: var(--brand-hover);
}
.sale-share-dialog__network-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--sp-3);
}
.sale-share-dialog__network {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: var(--sp-2);
  min-width: 0;
  padding: var(--sp-3) var(--sp-2);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--surface);
  color: var(--primary);
  font-size: var(--text-xs);
  font-weight: 600;
  text-align: center;
  text-decoration: none;
  transition: background var(--dur-sm) var(--ease), border-color var(--dur-sm) var(--ease);
  box-sizing: border-box;
}
.sale-share-dialog__network:hover {
  background: var(--n-50);
  border-color: var(--n-300);
}
.sale-share-dialog__network-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  flex-shrink: 0;
}
.sale-share-dialog__network-icon svg {
  display: block;
  max-width: 100%;
  height: auto;
}
.sale-share-dialog__network-label {
  line-height: 1.2;
}
.sale-share-dialog__copy-wrap {
  margin-top: var(--sp-4);
}
.sale-share-dialog__copy-wrap .sale-share-dialog__action {
  width: 100%;
  justify-content: center;
  text-align: center;
  box-sizing: border-box;
}
.sale-share-dialog__action {
  justify-content: center;
  text-align: center;
  text-decoration: none;
  box-sizing: border-box;
}
.sale-listing__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-8);
  align-items: start;
}
@media (min-width: 960px) {
  .sale-listing__grid {
    grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
    gap: var(--sp-10);
  }
}
.sale-listing__grid > .sale-listing__main,
.sale-listing__grid > .sale-listing__aside {
  min-width: 0;
}
.sale-listing__section {
  margin-bottom: var(--sp-10);
}
.sale-listing__section-title {
  font-size: var(--text-lg);
  font-weight: 800;
  color: var(--primary);
  margin: 0 0 var(--sp-4);
  padding-bottom: var(--sp-2);
  border-bottom: 2px solid var(--brand);
  display: inline-block;
  min-width: 8rem;
}
.sale-listing__items-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--sp-4);
  margin-bottom: var(--sp-4);
  width: 100%;
}
.sale-listing__items-toolbar .sale-listing__section-title--items {
  margin-bottom: 0;
  flex: 0 1 auto;
  max-width: calc(100% - 22rem);
}
.sale-listing__items-search {
  flex: 0 0 auto;
  width: 21rem;
  max-width: 100%;
  min-width: 0;
  margin-left: auto;
}
@media (max-width: 480px) {
  .sale-listing__items-toolbar .sale-listing__section-title--items {
    max-width: 100%;
  }
  .sale-listing__items-search {
    width: 100%;
    max-width: 100%;
    margin-left: 0;
  }
}
.sale-listing__items-search-input {
  width: 100%;
  margin: 0;
}
.sale-listing__items-empty {
  margin: 0 0 var(--sp-4);
}
.sale-listing__items-pager {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-3);
  margin-top: var(--sp-4);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border);
}
.sale-listing__items-page-status {
  font-size: var(--text-sm);
  color: var(--text-muted);
  min-height: 1.25rem;
}

/* ---- Sale listing: Marketplace Items (photo cards, search, pagination) ------------------ */
.sale-listing__section--marketplace-items {
  margin-top: var(--sp-8);
  padding-top: var(--sp-6);
  border-top: 1px solid var(--border);
}
.sale-mp-gallery__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--sp-4);
  margin-bottom: var(--sp-5);
  width: 100%;
}
.sale-mp-gallery__title {
  margin-bottom: 0;
  flex: 0 1 auto;
  max-width: calc(100% - 22rem);
}
.sale-mp-gallery__search-wrap {
  flex: 0 0 auto;
  width: 21rem;
  max-width: 100%;
  min-width: 0;
  margin-left: auto;
}
.sale-mp-gallery__search {
  width: 100%;
  margin: 0;
  border-radius: var(--r-lg, 0.65rem);
  border: 1px solid color-mix(in srgb, var(--border) 85%, var(--brand) 15%);
  background: var(--white);
  box-shadow: none;
  padding: 0.55rem 0.85rem 0.55rem 2.35rem;
  font-size: var(--text-sm);
  transition: border-color var(--dur-sm, 0.15s) ease, box-shadow var(--dur-sm, 0.15s) ease;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='8' cy='8' r='6'/%3E%3Cpath d='m13 13 4 4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: 0.65rem 50%;
  background-size: 1.1rem 1.1rem;
}
.sale-mp-gallery__search:hover {
  border-color: color-mix(in srgb, var(--border) 70%, var(--brand) 30%);
}
.sale-mp-gallery__search:focus {
  outline: none;
  border-color: var(--brand);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--brand) 22%, transparent);
}
.sale-mp-gallery__empty {
  margin: 0 0 var(--sp-4);
}
.sale-mp-gallery__grid {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
}
@media (min-width: 560px) {
  .sale-mp-gallery__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 900px) {
  .sale-mp-gallery__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
/* Pagination uses [hidden]; .sale-mp-card { display:flex } would otherwise win and show all rows. */
.sale-mp-gallery__grid > li.sale-mp-card[hidden] {
  display: none !important;
}
.sale-mp-card {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--white);
  overflow: hidden;
  box-shadow: none;
  transition: border-color var(--dur-sm) ease, box-shadow var(--dur-sm) ease;
  min-width: 0;
}
.sale-mp-card:hover {
  border-color: color-mix(in srgb, var(--brand) 25%, var(--border));
  box-shadow: none;
}
.sale-mp-card__media--isolated {
  --sale-mp-crop-inset: 0;
  aspect-ratio: 4 / 3;
  position: relative;
  width: 100%;
  overflow: hidden;
  box-sizing: border-box;
  background: linear-gradient(165deg, var(--n-50, #f8fafc) 0%, var(--n-100, #f1f5f9) 55%, var(--n-150, #e8edf3) 100%);
}
.sale-mp-card__crop-frame {
  position: absolute;
  left: var(--sale-mp-crop-inset);
  top: var(--sale-mp-crop-inset);
  right: var(--sale-mp-crop-inset);
  bottom: var(--sale-mp-crop-inset);
  width: auto;
  height: auto;
  overflow: hidden;
  background: transparent;
  box-sizing: border-box;
}
.sale-mp-card__crop-frame > .sale-mp-card__img--isolated {
  position: absolute;
  max-width: none;
  width: auto;
  height: auto;
  display: block;
  object-fit: unset;
  margin: 0;
}
.sale-mp-card__placeholder {
  width: 100%;
  height: 100%;
  min-height: 8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--n-400, #94a3b8);
  background: linear-gradient(145deg, var(--n-100), var(--n-50, #f8fafc));
}
.sale-mp-card__body {
  padding: var(--sp-4);
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  flex: 1;
  min-height: 0;
}
.sale-mp-card__title {
  margin: 0;
  font-size: var(--text-base);
  font-weight: 700;
  line-height: 1.35;
  color: var(--primary);
}
.sale-mp-card__meta {
  margin: 0;
  font-size: var(--text-xs);
}
.sale-mp-card__desc {
  margin: 0;
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--text);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.sale-mp-card__desc--muted {
  color: var(--text-muted);
  font-style: italic;
}
.sale-mp-card__price {
  margin: 0;
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--primary);
}
.sale-mp-gallery__pager {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  gap: var(--sp-2) var(--sp-3);
  margin-top: var(--sp-6);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--border);
}
.sale-mp-gallery__pager-btn {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
}
.sale-mp-gallery__pager-btn:first-of-type {
  justify-self: start;
}
.sale-mp-gallery__pager-btn:last-of-type {
  justify-self: end;
}
.sale-mp-gallery__pager-btn svg {
  flex-shrink: 0;
}
.sale-mp-gallery__pager-btn-text {
  font-weight: 600;
}
.sale-mp-gallery__page-status {
  grid-column: 2;
  grid-row: 1;
  font-size: var(--text-sm);
  color: var(--text-muted);
  min-height: 1.35rem;
  text-align: center;
  max-width: min(100%, 14rem);
  justify-self: center;
  padding-inline: var(--sp-1);
}
@media (max-width: 520px) {
  .sale-mp-gallery__pager {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
    justify-items: stretch;
  }
  .sale-mp-gallery__page-status {
    grid-column: 1 / -1;
    grid-row: 1;
    max-width: none;
    padding-bottom: var(--sp-2);
  }
  .sale-mp-gallery__pager-btn:first-of-type {
    grid-column: 1;
    grid-row: 2;
    justify-self: stretch;
    width: 100%;
  }
  .sale-mp-gallery__pager-btn:last-of-type {
    grid-column: 2;
    grid-row: 2;
    justify-self: stretch;
    width: 100%;
  }
}
@media (max-width: 560px) {
  .sale-mp-gallery__toolbar {
    flex-direction: column;
    align-items: stretch;
    gap: var(--sp-3);
  }
  .sale-mp-gallery__title {
    max-width: 100%;
  }
  .sale-mp-gallery__search-wrap {
    width: 100%;
    margin-left: 0;
  }
  .sale-mp-gallery__grid {
    gap: var(--sp-4);
  }
  /* Shorter media band than 4:3 full width so phone rows are not overwhelmingly tall */
  .sale-mp-card__media--isolated {
    aspect-ratio: auto;
    height: clamp(8.75rem, 46vw, 11.25rem);
    min-height: 8.25rem;
    max-height: 11.5rem;
  }
}
.sale-listing__body {
  font-size: var(--text-base);
  line-height: 1.65;
  color: var(--text);
}
.sale-listing__body p { margin: 0 0 var(--sp-4); }
.sale-listing__body p:last-child { margin-bottom: 0; }
.sale-listing__body ul, .sale-listing__body ol { margin: 0 0 var(--sp-4); padding-left: 1.25rem; }
.sale-listing__terms {
  line-height: 1.6;
  padding: var(--sp-4);
  background: var(--n-50);
  border-radius: var(--r);
  border: 1px solid var(--border);
}
.sale-listing__items.item-preview-list li {
  padding: var(--sp-4) 0;
  border-bottom: 1px solid var(--border);
}
.sale-listing__items.item-preview-list li:last-child { border-bottom: 0; }
.sale-listing__lead-hint { margin-bottom: var(--sp-3); }
.sale-listing__lead-form {
  margin: 0;
  max-width: 100%;
}
.sale-listing__lead-row {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: var(--sp-3);
}
/* Get updates: same shell + control classes as homepage hero search (see .lp-search-box / .lp-search-input / .lp-search-btn) */
.sale-listing__lead-row .sale-listing__lead-combo.lp-search-box {
  position: relative;
  flex: 1 1 100%;
  width: 100%;
  max-width: 42rem;
  min-width: 0;
  align-items: stretch;
}
/* Listing Get updates: bordered field like form controls; no right border (flush with Notify me) */
.sale-listing__lead-combo.lp-search-box #sale-lead-email.lp-search-input {
  border: 1.5px solid var(--border);
  border-right: none;
  border-radius: 0;
  border-top-left-radius: var(--r-sm);
  border-bottom-left-radius: var(--r-sm);
  background: var(--white);
}
.sale-listing__lead-combo.lp-search-box .lp-search-input:focus-visible {
  outline: none;
  box-shadow: inset 0 0 0 2px var(--brand-light);
}
.sale-listing__lead-email-wrap {
  flex: 1 1 12rem;
  min-width: 0;
}
.sale-lead-shopper-upsell-dialog__lede {
  margin-bottom: 0;
}
.sale-lead-shopper-upsell-dialog__footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5) var(--sp-5);
  border-top: 1px solid var(--border);
}
.sale-listing__related {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.sale-listing__related a {
  font-weight: 600;
  color: var(--brand);
  text-decoration: none;
}
.sale-listing__related a:hover { text-decoration: underline; }
.sale-listing__aside {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}
.sale-listing__aside-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  box-shadow: var(--shadow-sm);
}
.sale-listing__aside-title {
  font-size: var(--text-sm);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 var(--sp-4);
  color: var(--primary);
}
.sale-listing__aside-card .map-embed {
  width: 100%;
  height: 220px;
  border: 0;
  border-radius: var(--r);
}
.sale-listing__aside-card .map-embed--static {
  display: block;
  object-fit: cover;
}
.sale-listing__map-fallback {
  margin: 0;
  padding: var(--sp-6);
  text-align: center;
  background: var(--n-50);
  border-radius: var(--r);
}
.sale-listing__map-approx-disclaimer {
  margin: 0 0 var(--sp-3);
  color: var(--n-600);
}
.sale-listing__photo-carousel {
  --sale-photo-count: 1;
  outline: none;
}
.sale-listing__photo-carousel:focus-visible {
  box-shadow: 0 0 0 2px var(--surface), 0 0 0 4px var(--brand);
  border-radius: var(--r);
}
.sale-listing__photo-carousel-viewport {
  position: relative;
  overflow: hidden;
  width: 100%;
  border-radius: var(--r);
  background: var(--n-50);
}
.sale-listing__photo-carousel-track {
  display: flex;
  width: calc(var(--sale-photo-count) * 100%);
  transition: transform 0.38s cubic-bezier(0.33, 1, 0.68, 1);
  will-change: transform;
}
.sale-listing__photo-carousel-slide {
  flex: 0 0 calc(100% / var(--sale-photo-count));
  box-sizing: border-box;
  margin: 0;
  padding: 0 var(--sp-2);
  min-width: 0;
}
.sale-listing__photo-carousel-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 10;
  min-height: 0;
  border-radius: var(--r-sm);
  overflow: hidden;
  background: var(--n-100);
}
.sale-listing__photo-carousel-frame img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
  border-radius: var(--r-sm);
}
.sale-listing__photo-carousel-caption {
  margin: var(--sp-1) 0 0;
  padding: 0;
  font-size: var(--text-xs);
  text-align: center;
  line-height: 1.35;
}
/* Match slide horizontal inset + frame aspect-ratio so controls center on the image, not the caption below. */
.sale-listing__photo-carousel-overlay {
  position: absolute;
  left: var(--sp-2);
  right: var(--sp-2);
  top: 0;
  aspect-ratio: 16 / 10;
  z-index: 2;
  pointer-events: none;
}
.sale-listing__photo-carousel-overlay .sale-listing__photo-carousel-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: auto;
}
.sale-listing__photo-carousel-overlay .js-sale-photo-prev {
  left: var(--sp-2);
}
.sale-listing__photo-carousel-overlay .js-sale-photo-next {
  right: var(--sp-2);
}
.sale-listing__photo-carousel-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.40625rem;
  height: 1.40625rem;
  padding: 0;
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  color: var(--primary);
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease, opacity 0.15s ease;
}
.sale-listing__photo-carousel-arrow:hover:not(:disabled) {
  background: var(--white);
  border-color: var(--n-300);
  color: var(--brand);
}
.sale-listing__photo-carousel-arrow:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}
.sale-listing__photo-modal {
  width: min(96vw, 1200px);
  max-width: 1200px;
  border: none;
  border-radius: var(--r-lg);
  padding: 0;
  background: transparent;
  color: #fff;
  margin: auto;
  inset: 0;
}
.sale-listing__photo-modal::backdrop {
  background: rgba(2, 6, 23, 0.86);
}
.sale-listing__photo-modal-inner {
  position: relative;
  background: #020617;
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.sale-listing__photo-modal-close {
  position: absolute;
  top: var(--sp-3);
  right: var(--sp-3);
  z-index: 8;
  width: 2.5rem;
  height: 2.5rem;
  border: 1px solid rgba(255, 255, 255, 0.45);
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(15, 23, 42, 0.55);
  color: #fff;
  cursor: pointer;
}
.sale-listing__photo-modal-stage {
  flex: 1 1 auto;
  min-height: min(80vh, 760px);
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr);
  align-items: stretch;
  min-width: 0;
}
.sale-listing__photo-modal-figure {
  margin: 0;
  position: relative;
  z-index: 0;
  min-height: 0;
  min-width: 0;
  height: 100%;
  align-self: stretch;
  background: #020617;
  overflow: hidden;
}
.sale-listing__photo-modal-img {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.sale-listing__photo-modal-caption {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 2;
  margin: 0;
  padding: var(--sp-3) var(--sp-4);
  background: rgba(0, 0, 0, 0.4);
  color: #fff;
  font-size: var(--text-sm);
  line-height: 1.45;
}
.sale-listing__photo-modal-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 6;
  box-sizing: border-box;
  width: clamp(2.5rem, 3.6vw, 3.2rem);
  height: clamp(2.5rem, 3.6vw, 3.2rem);
  border: 0;
  margin: 0;
  padding: 0;
  line-height: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.55);
  color: #fff;
  cursor: pointer;
}
.sale-listing__photo-modal-arrow svg {
  flex-shrink: 0;
  display: block;
  overflow: visible;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.65));
}
.sale-listing__photo-modal-prev {
  left: var(--sp-2);
}
.sale-listing__photo-modal-next {
  right: var(--sp-2);
}
.sale-listing__photo-modal-arrow:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}
@media (max-width: 700px) {
  /* Full-viewport lightbox only when open — never set display on .sale-listing__photo-modal alone (breaks UA dialog { display:none } when closed). */
  .sale-listing__photo-modal:modal {
    box-sizing: border-box;
    position: fixed;
    inset: 0;
    width: 100%;
    max-width: none;
    height: 100%;
    min-height: 100vh;
    min-height: 100dvh;
    max-height: none;
    margin: 0;
    border-radius: 0;
    display: flex;
    flex-direction: column;
    padding: env(safe-area-inset-top, 0px) env(safe-area-inset-right, 0px) env(safe-area-inset-bottom, 0px)
      env(safe-area-inset-left, 0px);
  }
  .sale-listing__photo-modal:modal .sale-listing__photo-modal-inner {
    border-radius: 0;
    flex: 1 1 auto;
    min-height: 0;
    width: 100%;
    align-self: stretch;
    display: flex;
    flex-direction: column;
  }
  .sale-listing__photo-modal:modal .sale-listing__photo-modal-stage {
    flex: 1 1 auto;
    min-height: 0;
  }
  .sale-listing__photo-modal:modal .sale-listing__photo-modal-arrow {
    height: 3rem;
    width: 3rem;
  }
  .sale-listing__photo-modal:modal .sale-listing__photo-modal-prev {
    left: var(--sp-2);
  }
  .sale-listing__photo-modal:modal .sale-listing__photo-modal-next {
    right: var(--sp-2);
  }
}
/* Company card: logo spans full width of the card (bleed past content padding to align with card edges). */
.sale-listing__aside-card--company {
  overflow-x: hidden;
}
.sale-listing__aside-card--company > .sale-listing__company-logo-wrap {
  margin: calc(-1 * var(--sp-5)) calc(-1 * var(--sp-5)) var(--sp-4);
  width: calc(100% + 2 * var(--sp-5));
  max-width: none;
  display: block;
  line-height: 0;
  background: var(--n-50);
  border-bottom: 1px solid var(--border);
  border-radius: var(--r-lg) var(--r-lg) 0 0;
  overflow: hidden;
}
.sale-listing__aside-card--company .sale-listing__aside-title {
  overflow-wrap: anywhere;
}
.sale-listing__company-logo {
  display: block;
  width: 100%;
  height: auto;
  max-height: 12rem;
  object-fit: contain;
  object-position: center;
  border: 0;
  border-radius: 0;
  background: transparent;
}
@media (max-width: 560px) {
  .sale-listing__aside-card--company > .sale-listing__company-logo-wrap {
    margin-bottom: var(--sp-3);
  }
  .sale-listing__company-logo {
    max-height: min(9.5rem, 40vw);
  }
}
.sale-listing__company-actions { margin-bottom: var(--sp-3); }
.sale-listing__company-line {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-sm);
  overflow-wrap: anywhere;
}
.sale-listing__company-line a {
  color: var(--brand);
  font-weight: 600;
  text-decoration: none;
}
.sale-listing__company-line a:hover { text-decoration: underline; }
.sale-listing__company-btns {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: stretch;
  gap: var(--sp-3);
  margin-top: var(--sp-4);
}
.sale-listing__company-btns .sale-listing__message-btn,
.sale-listing__company-btns .sale-listing__view-listings-btn {
  flex: 1 1 50%;
  min-width: 0;
  margin-top: 0;
  width: auto;
  justify-content: center;
  text-align: center;
}
.sale-listing__company-btns > :only-child {
  flex: 1 1 100%;
}
.sale-listing__message-btn {
  width: 100%;
  justify-content: center;
  margin-top: var(--sp-4);
  text-align: center;
}
.sale-listing__aside-card--company .sale-listing__company-btns .sale-listing__message-btn {
  width: auto;
  margin-top: 0;
}

.sale-listing-inquiry-dialog .staff-access-dialog__inner {
  max-height: min(90vh, 720px);
}
.sale-listing-inquiry-dialog__intro strong {
  color: var(--primary);
  font-weight: 700;
}
.sale-listing-inquiry-dialog__form .form-group {
  margin-bottom: var(--sp-6);
}
.sale-listing-inquiry-dialog__form .form-group .form-control {
  margin-bottom: var(--sp-2);
}
.sale-listing-inquiry-dialog__form .form-group:last-of-type {
  margin-bottom: var(--sp-6);
}
.sale-listing-inquiry-dialog__textarea {
  min-height: 8rem;
  resize: vertical;
  line-height: 1.5;
}
.sale-listing-inquiry-dialog__footer {
  margin-top: var(--sp-6);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--border);
}
.sale-listing-inquiry-dialog__error {
  margin-bottom: var(--sp-4);
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--text-sm);
  line-height: 1.45;
  color: #991b1b;
  background: var(--red-bg, #fef2f2);
  border: 1px solid var(--red-border, #fecaca);
  border-radius: var(--r);
}
.sale-listing-inquiry-dialog__success {
  text-align: center;
  padding: var(--sp-6) var(--sp-2);
}
.sale-listing-inquiry-dialog__success-text {
  margin: 0 0 var(--sp-6);
  font-size: var(--text-base);
  line-height: 1.55;
  color: var(--primary);
}

/* Professional dashboard: customer messages (/dashboard/messages) */
.dash-messages-page .dh-page-header {
  margin-bottom: var(--sp-6);
}
.dash-messages-page__lede {
  max-width: 40rem;
  margin: 0;
}
.dash-messages-page__filters {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-bottom: var(--sp-8);
}
.dash-messages-page__filter {
  display: inline-flex;
  align-items: center;
  padding: var(--sp-2) var(--sp-4);
  font-size: var(--text-sm);
  font-weight: 600;
  text-decoration: none;
  color: var(--primary);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r);
  transition: background var(--dur-sm) var(--ease), border-color var(--dur-sm) var(--ease), color var(--dur-sm) var(--ease);
}
.dash-messages-page__filter:hover {
  background: var(--n-50);
  border-color: var(--n-300);
  color: var(--brand);
}
.dash-messages-page__filter.is-active {
  background: var(--primary);
  border-color: var(--primary);
  color: var(--white);
}
.dash-messages-page__filter.is-active:hover {
  color: var(--white);
  border-color: var(--primary);
  background: var(--primary);
  opacity: 0.92;
}
.dash-messages-page__head-actions {
  flex-shrink: 0;
}
.dash-messages-page__banner {
  padding: var(--sp-3) var(--sp-4);
  margin-bottom: var(--sp-6);
  background: var(--amber-bg);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
}
.dash-messages-card__thread {
  margin-top: var(--sp-4);
  padding: var(--sp-4);
  background: var(--n-50);
  border-radius: var(--r-md);
  border: 1px solid var(--border);
}
.dash-messages-card__thread-title {
  margin: 0 0 var(--sp-2);
  font-weight: 700;
}
.dash-messages-card__thread-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.dash-messages-card__thread-item {
  margin: 0;
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--border);
}
.dash-messages-card__thread-item:last-child {
  padding-bottom: 0;
  border-bottom: none;
}
.dash-messages-card__thread-body {
  margin-top: var(--sp-2);
  font-size: var(--text-sm);
  line-height: 1.5;
  white-space: pre-wrap;
}
.dash-messages-card__reply {
  margin-top: var(--sp-5);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--border);
}
.dash-messages-card__reply-label {
  display: block;
  font-weight: 600;
  margin-bottom: var(--sp-2);
  font-size: var(--text-sm);
}
.dash-messages-card__reply-textarea {
  width: 100%;
  min-height: 7rem;
  margin-bottom: var(--sp-3);
}
.dash-messages-card__reply-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-3);
  justify-content: space-between;
}
.dash-messages-card__reply-send-form {
  margin: 0;
  margin-left: auto;
}
.dash-messages-card__reply-err {
  color: var(--danger, #b91c1c);
  margin-top: var(--sp-2);
}
.dash-messages-page__empty {
  padding: var(--sp-10) var(--sp-6);
  text-align: center;
  background: var(--n-50);
  border: 1px dashed var(--border);
  border-radius: var(--r-lg);
}
.dash-messages-page__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
}
.dash-messages-card {
  margin: 0;
  padding: var(--sp-6) var(--sp-6);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
}
.dash-messages-card__top {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-bottom: var(--sp-3);
}
.dash-messages-card__time {
  font-variant-numeric: tabular-nums;
}
.dash-messages-card__badge {
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--r-xs);
  background: var(--n-100);
  color: var(--n-600);
}
.dash-messages-card__badge--new {
  background: #e0f2fe;
  color: #0369a1;
}
.dash-messages-card__badge--contacted {
  background: #ecfccb;
  color: #3f6212;
}
.dash-messages-card__badge--qualified {
  background: #ede9fe;
  color: #5b21b6;
}
.dash-messages-card__badge--closed {
  background: var(--n-200);
  color: var(--n-700);
}
.dash-messages-card__from {
  margin: 0 0 var(--sp-3);
  font-size: var(--text-base);
}
.dash-messages-card__message {
  margin: 0 0 var(--sp-4);
  padding: var(--sp-4);
  font-size: var(--text-sm);
  line-height: 1.55;
  color: var(--primary);
  background: var(--n-50);
  border-radius: var(--r);
  border: 1px solid var(--border);
  white-space: pre-wrap;
  word-break: break-word;
}
.dash-messages-card__meta {
  margin: 0 0 var(--sp-5);
}
.dash-messages-card__meta a {
  color: var(--brand);
  font-weight: 600;
  text-decoration: none;
}
.dash-messages-card__meta a:hover {
  text-decoration: underline;
}
.dash-messages-card__status-form {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-3);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border);
}
.dash-messages-card__select {
  max-width: 12rem;
  margin: 0;
}

@media print {
  .no-print { display: none !important; }
  .site-header,
  .site-footer { display: none !important; }
  .main.shell { padding-top: 0; max-width: 100%; }
  .sale-listing__aside { break-inside: avoid; }
  .sale-listing__photo-carousel-viewport {
    overflow: visible;
  }
  .sale-listing__photo-carousel-track {
    transform: none !important;
    display: block;
    width: 100% !important;
  }
  .sale-listing__photo-carousel-slide {
    flex: none !important;
    width: 100% !important;
    padding: 0 0 var(--sp-4);
    page-break-inside: avoid;
  }
  .sale-listing__photo-carousel-overlay {
    display: none !important;
  }
}

/* ====================================================================
   Responsive
   ==================================================================== */
@media (max-width: 1200px) {
  .lp-stats-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 1024px) {
  .lp-val-grid  { grid-template-columns: repeat(2, 1fr); }
  .lp-feat-grid { grid-template-columns: repeat(2, 1fr); }
  .lp-how-grid  { grid-template-columns: repeat(2, 1fr); }
  .lp-test-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .header-inner { height: auto; padding-block: var(--sp-3); flex-wrap: wrap; align-items: center; }
  .header-brand-row {
    flex: 1 1 100%;
    justify-content: space-between;
  }
  /* Mobile: keep hamburger to the LEFT of the logo */
  .header-brand-row .site-dash-mainnav-toggle {
    order: 1;
    margin-left: 0;
    margin-right: var(--sp-2);
    min-width: 2.5rem;
    padding-inline: var(--sp-2);
  }
  .header-brand-row .logo {
    order: 2;
  }
  /* Homepage (sticky hero search): match hero horizontal inset and full-width pinned bar */
  body.has-sticky-hero-search .site-header .shell {
    padding-inline: var(--sp-4);
  }
  body.has-sticky-hero-search .header-brand-row {
    flex-wrap: wrap;
    align-items: center;
    row-gap: var(--sp-2);
    column-gap: var(--sp-3);
  }
  /* Collapsed header search must not consume flex space or push the logo (mobile) */
  body.has-sticky-hero-search .header-hero-search:not(.is-pinned) {
    flex: 0 0 0;
    width: 0;
    min-width: 0;
    max-width: 0;
    margin: 0;
    padding: 0;
    border: 0;
    gap: 0;
    transform: none;
  }
  body.has-sticky-hero-search .header-brand-row:not(:has(.header-hero-search.is-pinned)) {
    justify-content: flex-start;
  }
  body.has-sticky-hero-search .header-brand-row:has(.header-hero-search.is-pinned) {
    justify-content: flex-start;
  }
  body.has-sticky-hero-search .header-brand-row:has(.header-hero-search.is-pinned) .logo {
    flex: 0 0 auto;
    order: 1;
  }
  body.has-sticky-hero-search .header-brand-row:has(.header-hero-search.is-pinned) .site-dash-mainnav-toggle {
    order: 2;
    align-self: center;
    margin-left: auto;
  }
  body.has-sticky-hero-search .header-brand-row:has(.header-hero-search.is-pinned) .header-hero-search.is-pinned {
    flex: 1 1 100%;
    min-width: 0;
    max-width: none;
    width: 100%;
    order: 3;
  }
  /* Public homepage: search + cluster wrapper share the full-width row (form is inside cluster) */
  body.has-sticky-hero-search.is-public-site-shell .header-brand-row:has(.header-hero-search.is-pinned) .header-public-search-cluster {
    flex: 1 1 100%;
    min-width: 0;
    width: 100%;
    max-width: 100%;
    order: 3;
  }
  body.has-sticky-hero-search.is-public-site-shell .header-brand-row:has(.header-hero-search.is-pinned) .header-public-search-cluster .header-hero-search.is-pinned {
    order: 0;
  }
  /* Drawer shows Explore / Search Inventory; hide duplicate strip in the header cluster */
  body.has-sticky-hero-search.is-public-site-shell .nav-public__lead--cluster {
    display: none !important;
  }
  .header-hero-search.is-pinned {
    max-width: 100%;
  }
  .nav { overflow-x: auto; flex-wrap: nowrap; width: 100%; gap: 0; scrollbar-width: none; }
  .nav.nav--public-site {
    overflow: visible;
  }
  /* Shopper workspace: .nav overflow clips the account <details> dropdown (overflow-y becomes non-visible). */
  body.is-shopper-dashboard .site-header .nav {
    overflow: visible;
  }
  /* Shopper workspace (mobile): profile row uses person glyph instead of avatar */
  body.is-shopper-dashboard .site-header-account-menu--shopper .site-header-account-menu__profile-person-glyph {
    display: inline-flex;
  }
  body.is-shopper-dashboard .site-header-account-menu--shopper .site-header-account-menu__avatar--shopper-desktop {
    display: none !important;
  }
  /* Shopper workspace (mobile): profile row — use only .nav gap (sp-1) like other items, no extra margin */
  body.is-shopper-dashboard .nav > .site-header-account-menu--shopper {
    position: static;
    margin: 0;
    width: 100%;
    flex: 0 0 auto;
    z-index: auto;
  }
  /* Match .nav a + .pro-dash-subnav__link row styling in the mobile Menu panel */
  body.is-shopper-dashboard .nav.nav--dash-dropdown .site-header-account-menu--shopper .site-header-account-menu__trigger {
    width: 100%;
    justify-content: flex-start;
    align-items: center;
    box-sizing: border-box;
    height: 2rem;
    min-height: 0;
    padding-block: 0;
    padding-inline: var(--sp-2);
    gap: var(--sp-2);
    border: none;
    border-radius: var(--r-xs);
    background: transparent;
    font-size: var(--text-xs);
    font-weight: 600;
    font-family: inherit;
    line-height: 1.25;
    color: var(--n-600);
  }
  body.is-shopper-dashboard .nav.nav--dash-dropdown .site-header-account-menu--shopper .site-header-account-menu__trigger:hover {
    background: var(--n-100);
    color: var(--primary);
  }
  body.is-shopper-dashboard .site-header-account-menu--shopper .site-header-account-menu__profile-label {
    display: inline;
  }
  .nav::-webkit-scrollbar { display: none; }
  .nav a, .link-btn { height: 2rem; padding-inline: var(--sp-2); font-size: var(--text-xs); }
  .nav-cta { padding-inline: var(--sp-3) !important; height: 2rem !important; }
  .site-header-account-menu__avatar-img,
  .site-header-account-menu__avatar-fallback {
    width: 2rem;
    height: 2rem;
  }
  .site-header-account-menu__panel {
    max-width: min(18rem, calc(100vw - 2rem));
  }

  /* margin-top matches .main padding-top below (sp-6) so hero + header align with page grid */
  .lp-hero { margin-top: calc(-1 * var(--sp-6)); padding: 56px var(--sp-4) 40px; min-height: clamp(480px, 78vh, 580px); }
  .lp-hero-h1 { font-size: 2.5rem; }
  .lp-hero-h1-accent-viewport {
    margin-inline: clamp(-2rem, -10vw, -0.75rem);
    padding-inline: clamp(2rem, 10vw, 6rem);
  }
  .lp-hero-sub { font-size: 1rem; margin-block: 6px 14px; }
  .lp-hero-ctas { gap: 12px; margin-bottom: 28px; }

  .lp-val-grid  { grid-template-columns: 1fr; }
  .lp-feat-grid { grid-template-columns: 1fr; }
  .lp-how-grid  { grid-template-columns: 1fr 1fr; }
  .lp-test-grid { grid-template-columns: 1fr; }
  .lp-stats-grid{ grid-template-columns: 1fr 1fr; }

  .lp-section-head { margin-bottom: 40px; }
  .lp-section-head h2 { font-size: 1.75rem; }
  .lp-section-sub { font-size: 1rem; }

  .section { padding-block: var(--sp-10); }
  .section-head { flex-direction: column; align-items: flex-start; gap: var(--sp-2); }
  .sales-page__listing-head .sales-page__listing-actions {
    width: 100%;
    display: flex;
    justify-content: flex-end;
  }
  .card-grid { grid-template-columns: 1fr 1fr; gap: var(--sp-4); }
  .card-body { padding: var(--sp-4); }

  .search-filters { padding: var(--sp-4); }
  .form-panel     { padding: var(--sp-5); }
  .form-panel--auth { padding: var(--sp-5); }
  .form-panel--register { padding: var(--sp-5); }
  .form-row       { grid-template-columns: 1fr 1fr; }
  .form-actions   { flex-direction: column; }

  /* Brand row full width; link columns follow fluid auto-fit below */
  .site-footer .footer-grid > :first-child {
    grid-column: 1 / -1;
  }
  /* Public shell: single-row marketing footer (same columns as desktop; shell scrolls horizontally if needed). */
  body.is-public-site-shell .site-footer .footer-grid > :first-child {
    grid-column: auto;
  }
  .footer-bottom { flex-direction: column; text-align: center; }

  .main { padding-block: var(--sp-6) var(--sp-12); }

  body.is-dashboard-shell .nav {
    overflow-x: visible;
    flex-wrap: wrap;
    row-gap: var(--sp-1);
    justify-content: flex-start;
  }
}

@media (max-width: 1200px) {
  /* Tablet + phone: hamburger icon only (no "Menu" text) */
  .site-dash-mainnav-toggle__label {
    display: none;
  }
  .site-dash-mainnav-toggle {
    gap: 0;
    min-width: 2.5rem;
    padding-inline: var(--sp-2);
  }
}
@media (max-width: 560px) {
  /* Hero search: one row — icon, input, compact Search button */
  .lp-search-box {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    width: 100%;
    max-width: 100%;
  }
  .lp-search-icon {
    flex-shrink: 0;
    align-self: center;
    padding-left: var(--sp-3);
  }
  .lp-search-input {
    flex: 1 1 auto;
    min-width: 0;
    height: 3rem;
    padding-inline: var(--sp-3);
  }
  .lp-search-btn {
    flex: 0 0 auto;
    align-self: stretch;
    width: auto;
    min-width: 0;
    height: 3rem;
    padding: 0 14px;
    font-size: 0.8125rem;
    border-radius: 0;
  }
  /* Public sale listing: lead email uses a more specific selector, so it stayed 3.5rem while
     .lp-search-btn above is 3rem; match input + button heights on narrow viewports. */
  .sale-listing__section--lead .sale-listing__lead-combo.lp-search-box .lp-search-input,
  .sale-listing__section--lead .sale-listing__lead-combo.lp-search-box .lp-search-btn {
    height: 3rem;
    min-height: 3rem;
  }
  .lp-hero-ctas {
    gap: 10px;
    padding-inline: 0;
  }
  .lp-hero-ctas .lp-btn-ghost {
    flex: 1 1 0;
    min-width: 0;
    justify-content: center;
    padding-inline: 10px;
    font-size: 0.8125rem;
    white-space: nowrap;
  }
  .lp-cta-btns {
    gap: 10px;
    flex-wrap: nowrap;
  }
  .lp-cta-btns .lp-cta-btn-primary,
  .lp-cta-btns .lp-cta-btn-ghost {
    flex: 1 1 0;
    min-width: 0;
    justify-content: center;
    padding-inline: 10px;
    font-size: 0.8125rem;
    white-space: nowrap;
  }
  body.has-sticky-hero-search .header-hero-search.is-pinned {
    flex-wrap: nowrap;
    row-gap: 0;
    column-gap: 0;
  }
  /* Header bar stays compact; overrides hero mobile .lp-search-input / .lp-search-btn heights above */
  body.has-sticky-hero-search .header-hero-search .lp-search-box .lp-search-input {
    flex: 1 1 auto;
    min-width: 0;
    height: 2.25rem;
    min-height: 2.25rem;
  }
  body.has-sticky-hero-search .header-hero-search .lp-search-box .lp-search-btn {
    flex: 0 0 auto;
    align-self: stretch;
    width: auto;
    min-width: 0;
    height: 2.25rem;
    min-height: 2.25rem;
    padding: 0 10px;
    font-size: 0.8125rem;
  }
}
@media (max-width: 480px) {
  .shell { padding-inline: var(--sp-4); }
  .lp-wrap { padding-inline: var(--sp-4); }
  .card-grid  { grid-template-columns: 1fr; }
  .form-row   { grid-template-columns: 1fr; }
  /* Company profile (/dashboard/company): keep City + State on one row on narrow phones */
  .config-settings-page__form > .form-row.config-settings-page__row--city-state {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: var(--sp-3);
    align-items: start;
  }
  .lp-how-grid{ grid-template-columns: 1fr; }
  .lp-stats-grid { grid-template-columns: 1fr 1fr; }
}

/* Shopper saved listings + Virtual Line — match browse/home listing grid (up to 3 columns) */
.shopper-saved-page__grid.card-grid--listings,
.shopper-entry-passes-page__grid.card-grid--listings,
.shopper-virtual-line-page__grid.card-grid--listings {
  gap: var(--sp-6);
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (max-width: 72rem) {
  .shopper-saved-page__grid.card-grid--listings,
  .shopper-entry-passes-page__grid.card-grid--listings,
  .shopper-virtual-line-page__grid.card-grid--listings {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 40rem) {
  .shopper-saved-page__grid.card-grid--listings,
  .shopper-entry-passes-page__grid.card-grid--listings,
  .shopper-virtual-line-page__grid.card-grid--listings {
    grid-template-columns: minmax(0, 1fr);
  }
}
.shopper-saved-page__listing-head .shopper-saved-page__search {
  flex-shrink: 0;
  width: min(22rem, 100%);
}
.shopper-saved-page__search-field {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 0 var(--sp-3);
  border: none;
  border-radius: var(--r-sm);
  background: transparent;
  box-sizing: border-box;
}
.shopper-saved-page__search-icon {
  flex-shrink: 0;
  display: flex;
  color: var(--n-500);
}
.shopper-saved-page__search-input {
  flex: 1;
  min-width: 0;
  height: 2.625rem;
  padding: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  font-size: var(--text-sm);
  box-shadow: none;
}
.shopper-saved-page__search-input:focus {
  outline: none;
  box-shadow: none;
}
@media (max-width: 640px) {
  .shopper-saved-page__listing-head .shopper-saved-page__search {
    width: 100%;
    max-width: none;
  }
}
.shopper-saved-page__listing-head {
  align-items: center;
}
.shopper-saved-page__filter-empty {
  margin: calc(-1 * var(--sp-2)) 0 var(--sp-4);
}
.shopper-saved-listing__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2);
  margin-top: var(--sp-4);
}
.shopper-saved-listing__line-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.65rem;
  border-radius: var(--r-sm);
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--primary);
  background: var(--n-100);
  border: 1px solid var(--border);
}
.shopper-saved-checkin-dialog__status:not([hidden]) {
  color: var(--danger, #b91c1c);
  font-weight: 600;
  margin-bottom: var(--sp-3);
}
.shopper-saved-checkin-dialog__status.entry-pass-notice--used:not([hidden]),
.sale-route-dialog__hint.entry-pass-notice--used:not([hidden]) {
  color: #111;
  font-weight: 400;
}
.shopper-saved-checkin-dialog__status.entry-pass-notice--used a,
.sale-route-dialog__hint.entry-pass-notice--used a {
  color: #111;
  font-weight: 400;
  text-decoration: underline;
}
.shopper-saved-checkin-dialog__footer {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  align-items: center;
  margin-top: var(--sp-5);
}
.shopper-alert-manage-page__stack {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
  margin-top: var(--sp-6);
}
.shopper-item-search-saved-details {
  width: 100%;
}
.shopper-item-search-saved-summary {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  margin: calc(var(--sp-2) * -1) calc(var(--sp-3) * -1);
  border-radius: var(--r-md);
  list-style: none;
  cursor: pointer;
  color: inherit;
  user-select: none;
}
.shopper-item-search-saved-summary::-webkit-details-marker,
.shopper-item-search-saved-summary::marker {
  display: none;
}
.shopper-item-search-saved-summary:focus {
  outline: none;
}
.shopper-item-search-saved-summary:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}
.shopper-item-search-saved-summary__chev {
  flex-shrink: 0;
  width: 1.35rem;
  height: 1.35rem;
  margin-top: 0.12rem;
  border-radius: var(--r-sm);
  background: var(--n-100);
  position: relative;
}
.shopper-item-search-saved-summary__chev::after {
  content: '';
  position: absolute;
  inset: 0;
  margin: auto;
  width: 0.38rem;
  height: 0.38rem;
  border-right: 2px solid var(--text-muted);
  border-bottom: 2px solid var(--text-muted);
  transform: rotate(-45deg);
}
.shopper-item-search-saved-details[open] .shopper-item-search-saved-summary__chev::after {
  transform: rotate(45deg);
}
.shopper-item-search-saved-summary__text {
  min-width: 0;
}
.shopper-item-search-saved-summary__keywords {
  font-size: var(--text-sm);
  font-weight: 600;
  line-height: 1.35;
  word-break: break-word;
}
.shopper-item-search-saved-summary__meta {
  margin-top: var(--sp-1);
  line-height: 1.45;
}
.shopper-item-search-saved-details__inner {
  padding-top: var(--sp-4);
  margin-top: var(--sp-3);
  border-top: 1px solid var(--border);
}
.shopper-item-search-saved-form__footer {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: var(--sp-3);
  margin-top: var(--sp-4);
}
.shopper-item-search-saved-remove-form.shopper-alert-manage-delete {
  margin-top: 0;
  padding-top: 0;
  border-top: none;
}
.shopper-alert-manage-form__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: var(--sp-4);
  align-items: end;
}
.shopper-alert-manage-form__grid--area {
  grid-template-columns: minmax(0, 1fr) auto;
}
@media (max-width: 52rem) {
  .shopper-alert-manage-form__grid,
  .shopper-alert-manage-form__grid--area {
    grid-template-columns: 1fr;
  }
}
.shopper-alert-manage-form__checks {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-4);
  margin-top: var(--sp-4);
}
.shopper-item-search-notification-prefs__heading {
  flex: 1 0 100%;
  margin: 0 0 var(--sp-2);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text);
}
.shopper-item-search-notification-prefs__sms-setup {
  flex: 1 0 100%;
  margin: 0 0 var(--sp-3);
  max-width: 46rem;
  line-height: 1.45;
}
.shopper-alert-manage-form__actions {
  margin-top: var(--sp-4);
}
.shopper-alert-manage-delete {
  margin-top: var(--sp-4);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border);
}
.shopper-item-search-page__lede {
  max-width: 46rem;
  line-height: 1.55;
}
.shopper-item-search-add-intro {
  margin: 0 0 var(--sp-5);
  font-size: var(--text-base);
  line-height: 1.55;
  color: var(--text);
  max-width: 52rem;
}
.shopper-item-search-page__add {
  padding-bottom: var(--sp-8);
  margin-bottom: var(--sp-4);
  border-bottom: 1px solid var(--border);
}
.shopper-item-search-field-hint {
  margin: 0 0 var(--sp-2);
}
/* Two columns: address hint + field | distance hint + slider (stacks to one column on narrow screens). */
.shopper-item-search-address-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(12rem, 22rem);
  gap: var(--sp-4) var(--sp-5);
  align-items: start;
}
.shopper-item-search-address-row__address-col,
.shopper-item-search-address-row__radius-col {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  min-width: 0;
}
.shopper-item-search-address-row__radius-col .shopper-inv-radius {
  margin-top: 0;
}
@media (max-width: 30rem) {
  .shopper-item-search-address-row {
    grid-template-columns: 1fr;
  }
}
.shopper-item-search-address-row__address {
  min-width: 0;
}
.shopper-item-search-page .shopper-item-search-address-row__radius-col .shopper-signup-dialog__range-wrap {
  min-width: 0;
}
/*
 * Saved search distance slider: volume-style bar — fill grows with index (same discrete steps as before).
 * --inv-radius-fill-pct is set by shopper-item-search-alerts.js for WebKit/Blink (filled portion uses --brand, same as .isa-save-btn).
 */
.shopper-inv-radius[data-shopper-inv-radius] {
  --inv-radius-fill-pct: 0%;
}
.shopper-inv-radius-range-wrap {
  --inv-radius-bar-h: 0.65rem;
  --inv-radius-thumb: 1.125rem;
}
.shopper-inv-radius-range-wrap .shopper-inv-radius-range-input.shopper-signup-dialog__range {
  height: 2rem;
}
.shopper-inv-radius-range-wrap .shopper-inv-radius-range-input.shopper-signup-dialog__range::-webkit-slider-runnable-track {
  height: var(--inv-radius-bar-h);
  border-radius: var(--r-full);
  background: linear-gradient(
    to right,
    var(--brand) 0%,
    var(--brand) var(--inv-radius-fill-pct),
    var(--n-200) var(--inv-radius-fill-pct),
    var(--n-200) 100%
  );
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.07);
}
.shopper-inv-radius-range-wrap .shopper-inv-radius-range-input.shopper-signup-dialog__range::-webkit-slider-thumb {
  width: var(--inv-radius-thumb);
  height: var(--inv-radius-thumb);
  margin-top: calc((var(--inv-radius-bar-h) - var(--inv-radius-thumb)) / 2);
  border-radius: 50%;
  background: var(--white);
  border: 2px solid var(--brand);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 2px 6px rgba(21, 93, 252, 0.15);
}
.shopper-inv-radius-range-wrap .shopper-inv-radius-range-input.shopper-signup-dialog__range:active::-webkit-slider-thumb {
  box-shadow: 0 0 0 2px rgba(21, 93, 252, 0.2);
}
.shopper-inv-radius-range-wrap .shopper-inv-radius-range-input.shopper-signup-dialog__range::-moz-range-track {
  height: var(--inv-radius-bar-h);
  border-radius: var(--r-full);
  background: var(--n-200);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.07);
}
.shopper-inv-radius-range-wrap .shopper-inv-radius-range-input.shopper-signup-dialog__range::-moz-range-progress {
  height: var(--inv-radius-bar-h);
  border-radius: var(--r-full) 0 0 var(--r-full);
  background: var(--brand);
}
.shopper-inv-radius-range-wrap .shopper-inv-radius-range-input.shopper-signup-dialog__range::-moz-range-thumb {
  width: var(--inv-radius-thumb);
  height: var(--inv-radius-thumb);
  border-radius: 50%;
  background: var(--white);
  border: 2px solid var(--brand);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12);
}
.shopper-item-search-page .shopper-inv-radius-block > .shopper-inv-radius-map-section {
  margin-top: 0;
  margin-bottom: var(--sp-8);
}
.shopper-item-search-page .shopper-inv-radius-block > .shopper-inv-radius-map__fallback {
  margin-top: 0;
  margin-bottom: var(--sp-8);
}
.shopper-item-search-page .pac-container {
  z-index: 6500;
}
.shopper-item-search-form-stack {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}
.shopper-item-search-location .shopper-inv-radius-map__fallback + .shopper-inv-radius {
  margin-top: var(--sp-3);
}
.shopper-item-search-location > .shopper-inv-radius:first-child {
  margin-top: 0;
}
.shopper-item-search-location .shopper-inv-radius-block .shopper-inv-radius {
  margin-top: var(--sp-4);
}
.shopper-keyword-tags {
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--white);
  transition: border-color var(--dur-sm) var(--ease), box-shadow var(--dur-sm) var(--ease);
}
.shopper-keyword-tags:focus-within {
  border-color: var(--brand);
  box-shadow: 0 0 0 2px var(--brand-light);
}
.shopper-keyword-tags--invalid {
  border-color: var(--red);
  box-shadow: 0 0 0 2px rgba(220, 38, 38, 0.2);
}
.shopper-keyword-tags__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2);
  min-height: 2.65rem;
  padding: 0.35rem var(--sp-3);
}
.shopper-keyword-tags__tag {
  display: inline-flex;
  align-items: center;
  gap: 0.15rem;
  max-width: 100%;
  padding: 0.28rem 0.35rem 0.28rem 0.65rem;
  border-radius: var(--r-sm);
  font-size: var(--text-xs);
  font-weight: 600;
  line-height: 1.2;
  color: var(--brand);
  background: linear-gradient(165deg, #eef4ff 0%, #e4ecff 100%);
  border: 1px solid rgba(21, 93, 252, 0.28);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.65) inset;
}
.shopper-keyword-tags__text {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 15rem;
}
.shopper-keyword-tags__remove {
  flex-shrink: 0;
  display: grid;
  place-items: center;
  width: 1.35rem;
  height: 1.35rem;
  margin: 0;
  padding: 0;
  border: none;
  border-radius: var(--r-sm);
  background: transparent;
  color: var(--brand);
  font-size: 1.1rem;
  line-height: 1;
  cursor: pointer;
  opacity: 0.75;
  transition: opacity var(--dur-sm) var(--ease), background var(--dur-sm) var(--ease);
}
.shopper-keyword-tags__remove:hover {
  opacity: 1;
  background: rgba(21, 93, 252, 0.12);
}
.shopper-keyword-tags__remove:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 1px;
}
.shopper-keyword-tags__input {
  flex: 1;
  min-width: 9rem;
  border: none;
  outline: none;
  background: transparent;
  font-size: var(--text-sm);
  padding: 0.25rem 0;
  color: var(--text);
}
.shopper-keyword-tags__input::placeholder {
  color: var(--text-muted);
}
/* Saved item search radius: uses .shopper-signup-dialog__range* (same track/thumb as signup distance slider) */
.shopper-saved-listing__footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-top: var(--sp-4);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border);
  font-size: var(--text-sm);
  color: var(--text-muted);
}
.shopper-saved-listing__footer-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-1);
  min-width: 0;
}
.shopper-saved-listing__footer-meta a {
  color: var(--primary);
  font-weight: 600;
}
.shopper-saved-listing__unsave {
  margin: 0;
  flex-shrink: 0;
}
.shopper-saved-empty {
  padding: var(--sp-12) var(--sp-6);
  text-align: center;
  background: var(--n-50);
  border: 1px dashed var(--border);
  border-radius: var(--r-lg);
}

/* Shopper routes + listing save/add-to-route */
.sale-route-dialog__field {
  margin-bottom: var(--sp-4);
}
.sale-route-dialog__field label {
  display: block;
  font-size: var(--text-sm);
  font-weight: 600;
  margin-bottom: var(--sp-1);
}
.sale-route-dialog__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  justify-content: flex-end;
  margin-top: var(--sp-5);
}
.sale-route-dialog__fieldset {
  border: none;
  margin: 0;
  padding: 0;
  min-width: 0;
}
.sale-route-dialog__date-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  margin: var(--sp-4) 0 0;
}
.sale-route-dialog__date-option {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  border: 1px solid var(--border);
  border-radius: var(--r);
  background: var(--white);
  cursor: pointer;
}
.sale-route-dialog__date-option:has(input:checked) {
  border-color: var(--brand);
  box-shadow: 0 0 0 1px var(--brand);
}
.sale-route-dialog__date-option input {
  margin-top: 0.2rem;
  flex-shrink: 0;
}
.sale-route-dialog__selected-day {
  margin: var(--sp-2) 0 0;
}
.sale-entry-pass-dialog__qr-lede {
  margin-bottom: var(--sp-3);
}
.sale-entry-pass-dialog__summary {
  margin: 0 0 var(--sp-4);
  font-weight: 600;
  color: var(--primary);
}
.sale-entry-pass-dialog__qr {
  display: flex;
  justify-content: center;
  margin: var(--sp-4) 0;
  min-height: 12rem;
}
.sale-entry-pass-dialog__qr img,
.sale-entry-pass-dialog__qr canvas {
  display: block;
  max-width: 100%;
}
.sale-entry-pass-dialog__link-wrap {
  margin: 0 0 var(--sp-4);
  word-break: break-all;
}
.entry-pass-verify-body {
  margin: 0;
  min-height: 100vh;
  background: var(--n-50, #f8fafc);
}
.entry-pass-verify {
  box-sizing: border-box;
  max-width: 28rem;
  margin: 0 auto;
  padding: var(--sp-8) var(--sp-4);
}
.entry-pass-verify__title {
  margin: 0 0 var(--sp-4);
  font-size: var(--text-xl);
  color: var(--primary);
}
.entry-pass-verify__lede {
  margin: 0;
  line-height: 1.5;
}
.entry-pass-verify__ok {
  display: inline-block;
  margin: 0 0 var(--sp-4);
  padding: var(--sp-2) var(--sp-4);
  background: #ecfdf5;
  color: #047857;
  border-radius: var(--r);
  font-weight: 700;
}
.entry-pass-verify__dl {
  margin: 0;
}
.entry-pass-verify__dl dt {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text-muted, #64748b);
  margin-top: var(--sp-3);
}
.entry-pass-verify__dl dd {
  margin: var(--sp-1) 0 0;
}
.entry-pass-verify__warn {
  margin: var(--sp-4) 0 0;
  padding: var(--sp-3);
  background: #fffbeb;
  border: 1px solid #fbbf24;
  border-radius: var(--r);
  line-height: 1.45;
}
.entry-pass-verify__meta {
  margin: var(--sp-4) 0 0;
}
.entry-pass-verify__flash {
  margin: 0 0 var(--sp-4);
  padding: var(--sp-3);
  border-radius: var(--r);
  line-height: 1.45;
}
.entry-pass-verify__flash--success {
  background: #ecfdf5;
  color: #047857;
}
.entry-pass-verify__flash--error {
  background: #fef2f2;
  color: #991b1b;
}
.entry-pass-verify__admit {
  margin: var(--sp-6) 0 0;
}
.entry-pass-verify__admit-btn {
  width: 100%;
  justify-content: center;
}
.entry-pass-verify__admit-hint {
  margin: var(--sp-2) 0 0;
}
.shopper-entry-pass-page {
  margin: 0;
  position: relative;
  overflow-x: clip;
  min-height: 100dvh;
  min-height: 100vh;
  background:
    radial-gradient(120% 80% at 50% -20%, rgba(37, 99, 235, 0.12), transparent 55%),
    linear-gradient(165deg, var(--n-100, #f1f5f9) 0%, var(--n-50, #f8fafc) 45%, var(--white, #fff) 100%);
  color: var(--text);
}
.shopper-entry-pass-mosaic {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.shopper-entry-pass-mosaic__shape {
  position: absolute;
  box-sizing: border-box;
  opacity: 0.1;
  transform-origin: center center;
  will-change: transform;
}
.shopper-entry-pass-mosaic__shape--circles {
  border-radius: 50%;
}
.shopper-entry-pass-mosaic__shape--squares {
  border-radius: min(18%, 0.45rem);
}
.shopper-entry-pass-mosaic__shape--triangles {
  clip-path: polygon(50% 0%, 0% 100%, 100% 100%);
}
.shopper-entry-pass-mosaic__shape--hexagons {
  clip-path: polygon(25% 0%, 75% 0%, 100% 50%, 75% 100%, 25% 100%, 0% 50%);
}
.shopper-entry-pass-mosaic__shape--stars {
  clip-path: polygon(
    50% 0%,
    61% 35%,
    98% 35%,
    68% 57%,
    79% 91%,
    50% 70%,
    21% 91%,
    32% 57%,
    2% 35%,
    39% 35%
  );
}
.shopper-entry-pass {
  box-sizing: border-box;
  position: relative;
  z-index: 1;
  max-width: 24rem;
  margin: 0 auto;
  padding: max(var(--sp-5), env(safe-area-inset-top)) var(--sp-4) max(var(--sp-10), env(safe-area-inset-bottom));
  text-align: center;
}
.shopper-entry-pass__card {
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: var(--r-lg, 1rem);
  box-shadow:
    0 1px 2px rgba(15, 23, 42, 0.04),
    0 12px 40px -12px rgba(15, 23, 42, 0.18);
  padding: var(--sp-6) var(--sp-5) var(--sp-7);
}
.shopper-entry-pass__eyebrow {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-xs, 0.75rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--n-500, #64748b);
}
.shopper-entry-pass__company {
  margin: 0 0 var(--sp-5);
  font-size: clamp(1.2rem, 4.2vw, 1.45rem);
  font-weight: 800;
  color: var(--primary);
  line-height: 1.2;
}
.shopper-entry-pass__qr {
  display: flex;
  justify-content: center;
  margin: 0 auto var(--sp-4);
  min-height: 14rem;
  align-items: center;
  padding: var(--sp-3);
  background: var(--white, #fff);
  border-radius: var(--r, 0.5rem);
  border: 1px solid var(--n-100, #f1f5f9);
}
.shopper-entry-pass__qr img,
.shopper-entry-pass__qr canvas {
  display: block;
  max-width: 100%;
  border-radius: calc(var(--r) * 0.75);
  box-shadow: none;
}
.shopper-entry-pass__line {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--text);
}
.shopper-entry-pass__line--lede {
  font-size: var(--text-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--n-600, #475569);
  margin-bottom: var(--sp-1);
}
.shopper-entry-pass__party {
  list-style: none;
  margin: 0 0 var(--sp-3);
  padding: 0;
  text-align: left;
  max-width: 20rem;
  margin-left: auto;
  margin-right: auto;
}
.shopper-entry-pass__party-line {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-base);
  line-height: 1.4;
  color: var(--text);
}
.shopper-entry-pass__party-num {
  font-weight: 700;
  color: var(--n-800, #1e293b);
  margin-right: 0.25rem;
}
.shopper-entry-pass__visit {
  margin: 0 0 var(--sp-3);
}
.shopper-entry-pass__hint {
  margin: 0 0 var(--sp-2);
  line-height: 1.55;
  max-width: 19rem;
  margin-left: auto;
  margin-right: auto;
}
.shopper-entry-pass__pattern {
  margin: var(--sp-5) 0 0;
  padding-top: var(--sp-4);
  border-top: 1px solid var(--n-100, #f1f5f9);
  font-size: var(--text-sm);
  color: var(--n-600, #475569);
}
.shopper-entry-pass__done {
  margin: var(--sp-4) 0;
  font-size: var(--text-lg);
  font-weight: 700;
  color: #047857;
}
.entry-pass-verify__mosaic-note {
  display: block;
  margin-top: var(--sp-1);
  font-size: var(--text-sm);
  font-weight: 400;
  color: var(--n-500, #64748b);
}
.shopper-routes-create__stack {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  align-items: stretch;
  max-width: 40rem;
}
.shopper-routes-create__stack .form-group {
  margin: 0;
}
.shopper-routes-index__create-hint {
  margin: 0 0 var(--sp-4);
  max-width: 42rem;
}
.shopper-route-sheet__one-stop-hint {
  margin: 0 0 var(--sp-4);
  max-width: 42rem;
}
.shopper-routes-create__form {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  align-items: center;
}
.shopper-routes-create__form .form-control {
  flex: 1 1 16rem;
  max-width: 28rem;
}
.shopper-routes-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.shopper-routes-list__item {
  margin: 0;
}
.shopper-routes-list__link {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-4);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r);
  text-decoration: none;
  color: inherit;
  transition: border-color var(--dur-sm) var(--ease), box-shadow var(--dur-sm) var(--ease);
}
.shopper-routes-list__link:hover {
  border-color: var(--brand);
  box-shadow: var(--shadow-sm);
}
.shopper-routes-list__name {
  font-weight: 700;
  color: var(--primary);
}
.shopper-route-shell {
  max-width: 52rem;
  margin-inline: auto;
}
.shopper-route-sheet {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-6) var(--sp-8);
  margin-bottom: var(--sp-8);
}
.shopper-route-sheet__header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-4);
  border-bottom: 2px solid var(--brand);
}
.shopper-route-sheet__title {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-2xl);
  font-weight: 800;
  color: var(--primary);
}
.shopper-route-sheet__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
}
.shopper-route-sheet__edit-btn {
  background: var(--n-100, #f1f5f9);
  border-color: var(--n-200, #e2e8f0);
  color: var(--n-700, #334155);
}
.shopper-route-sheet__edit-btn:hover {
  background: var(--n-200, #e2e8f0);
  border-color: var(--n-300, #cbd5e1);
  color: var(--primary);
}
.shopper-route-sheet__optimize-form {
  display: inline-flex;
  margin: 0;
  align-items: center;
}
.shopper-route-sheet__history-banner {
  margin: 0 0 var(--sp-6);
  padding: var(--sp-4) var(--sp-5);
  background: var(--amber-bg, #fffbeb);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  max-width: 48rem;
}
.shopper-route-sheet__history-banner a {
  font-weight: 600;
}
.shopper-route-sheet__stops-heading,
.shopper-route-sheet__notes-heading {
  font-size: var(--text-lg);
  font-weight: 800;
  color: var(--primary);
  margin: 0 0 var(--sp-3);
}
.shopper-route-sheet__stops-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
}
.shopper-route-sheet__stops-head .shopper-route-sheet__stops-heading {
  margin: 0;
}
.shopper-route-sheet__stops-head--history {
  justify-content: flex-start;
}
.shopper-route-sheet__start {
  margin: 0 0 var(--sp-2);
  max-width: 48rem;
}
.shopper-route-sheet__start-line {
  font-weight: 500;
}
.shopper-route-sheet__start-edit-hint {
  margin-left: var(--sp-1);
}
.shopper-route-sheet__start-open-edit {
  display: inline;
  margin: 0;
  padding: 0;
  border: none;
  background: none;
  font: inherit;
  font-weight: 600;
  color: var(--brand);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.shopper-route-sheet__start-open-edit:hover {
  color: var(--primary);
}
.shopper-route-stop-list {
  margin: 0;
  padding-left: 1.25rem;
}
.shopper-route-stop-list__item {
  margin-bottom: var(--sp-5);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--border);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-3);
}
.shopper-route-stop-list__content {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: var(--sp-3);
  min-width: 0;
}
.shopper-route-stop-list__thumb-link {
  flex: 0 0 auto;
  width: min(7.75rem, 34vw);
  max-width: 9.5rem;
  border-radius: var(--r-sm);
  overflow: hidden;
  background: var(--surface-muted, #f3f4f6);
  line-height: 0;
  align-self: flex-start;
  min-height: 2.75rem;
  text-decoration: none;
  color: inherit;
}
/* Square map tile: aspect-ratio + child img { height:100% } collapses to 0; use absolute fill when showing an image. */
.shopper-route-stop-list__thumb-link--map {
  position: relative;
  flex: 0 0 auto;
  width: min(7.75rem, 34vw);
  max-width: 9.5rem;
  aspect-ratio: 1 / 1;
  min-height: 0;
  overflow: hidden;
}
.shopper-route-stop-list__thumb-link--map:not(.shopper-route-stop-list__thumb-link--placeholder) {
  display: block;
  line-height: 0;
}
.shopper-route-stop-list__thumb-link--map:not(.shopper-route-stop-list__thumb-link--placeholder) > .shopper-route-stop-list__thumb-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* With --placeholder, keep in-flow flex centering (do not absolutely position the pin or the box height can collapse). */
.shopper-route-stop-list__thumb-link--map.shopper-route-stop-list__thumb-link--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  line-height: 1;
  box-sizing: border-box;
}
.shopper-route-stop-list__thumb-link--map.shopper-route-stop-list__thumb-link--placeholder > .shopper-route-stop-list__map-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--muted, #64748b);
  opacity: 0.9;
}
.shopper-route-stop-list__thumb-link--map.shopper-route-stop-list__thumb-link--placeholder > .shopper-route-stop-list__map-placeholder svg {
  display: block;
}
.shopper-route-stop-list__osm-attribution {
  margin-top: var(--sp-2, 0.5rem);
  font-size: var(--text-xs, 0.75rem);
  color: var(--muted, #64748b);
}
.shopper-route-stop-list__thumb-link--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-2);
  line-height: 1.35;
  text-align: center;
  box-sizing: border-box;
  border: 1px dashed var(--border);
}
.shopper-route-stop-list__thumb-placeholder-text {
  font-size: var(--text-xs, 0.75rem);
  font-weight: 600;
  color: var(--muted, #64748b);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.shopper-route-stop-list__thumb-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.shopper-route-stop-list__body {
  flex: 1 1 auto;
  min-width: 0;
}
@media (min-width: 640px) {
  .shopper-route-stop-list__item {
    grid-template-columns: 1fr auto;
    align-items: start;
  }
}
.shopper-route-stop-list__title {
  margin: 0 0 var(--sp-1);
  font-size: var(--text-base);
}
.shopper-route-stop-list__title a {
  color: var(--primary);
  text-decoration: none;
  font-weight: 700;
}
.shopper-route-stop-list__title a:hover {
  color: var(--brand-hover);
  text-decoration: underline;
}
.shopper-route-stop-list__addr {
  margin: 0;
  font-weight: 500;
}
.shopper-route-stop-list__schedule {
  margin: var(--sp-2) 0 0;
  padding-left: 0;
  list-style: none;
}
.shopper-route-stop-list__schedule > li {
  margin: 0;
  padding: 0;
}
.shopper-route-stop-list__schedule > li + li {
  margin-top: var(--sp-1);
}
.shopper-route-stop-list__schedule-canceled {
  margin: var(--sp-2) 0 0;
  color: #991b1b;
}
.shopper-route-stop-list__manage {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-1);
}
.shopper-route-stop-list__manage .inline {
  display: inline;
}
.shopper-route-notes-print {
  min-height: 4rem;
  padding: var(--sp-3);
  background: var(--n-50);
  border-radius: var(--r);
  border: 1px dashed var(--border);
  font-size: var(--text-sm);
  line-height: 1.5;
  white-space: pre-wrap;
}
.shopper-route-edit-dialog {
  max-width: min(32rem, calc(100vw - 2rem));
}
.shopper-route-edit-dialog .staff-access-dialog__inner {
  max-height: min(90vh, 44rem);
}
.shopper-route-edit-modal__card {
  margin: 0 0 var(--sp-5);
  padding: var(--sp-4) var(--sp-5);
  background: linear-gradient(145deg, var(--n-50, #f8fafc) 0%, var(--white) 100%);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  box-shadow: none;
}
.shopper-route-edit-modal__card-title {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-xs, 0.75rem);
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted, #64748b);
}
.shopper-route-edit-modal__card-lede {
  margin: 0 0 var(--sp-3);
  max-width: 36rem;
}
.shopper-route-edit-modal__start-form {
  margin: 0;
}
.shopper-route-edit-modal__start-actions {
  margin-top: var(--sp-3);
  justify-content: flex-start;
}
.shopper-route-edit-modal__notice {
  margin: 0 0 var(--sp-5);
  padding: var(--sp-3) var(--sp-4);
  background: var(--n-50, #f8fafc);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  max-width: 36rem;
}
.shopper-route-edit-modal__section {
  margin: 0 0 var(--sp-5);
}
.shopper-route-edit-modal__section-title {
  margin: 0 0 var(--sp-3);
  font-size: var(--text-lg);
  font-weight: 800;
  color: var(--primary);
  letter-spacing: -0.02em;
}
.shopper-route-edit-modal__footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2);
  justify-content: flex-end;
  margin-top: var(--sp-4);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border);
}
.shopper-route-edit-modal__footer .shopper-route-delete {
  display: inline-flex;
  flex-shrink: 0;
  margin-right: auto;
}
.shopper-route-foot {
  margin-top: var(--sp-6);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2);
}
.shopper-route-foot a {
  font-weight: 600;
  color: var(--brand);
  text-decoration: none;
}
.shopper-route-foot a:hover {
  text-decoration: underline;
}
.shopper-route-foot__sep {
  user-select: none;
  color: var(--muted);
}
.shopper-route-edit__fields {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}
.shopper-route-edit__group--full {
  width: 100%;
}
.shopper-route-edit__address-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
}
@media (min-width: 640px) {
  .shopper-route-edit__address-row {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-5);
    align-items: start;
  }
}
.shopper-route-edit__hint {
  margin: var(--sp-1) 0 0;
}
.shopper-route-delete__btn {
  border-color: #b91c1c;
  color: #b91c1c;
  background: transparent;
}
.shopper-route-delete__btn:hover {
  background: rgba(185, 28, 28, 0.08);
  border-color: #991b1b;
  color: #991b1b;
}
.shopper-routes-index__title {
  color: var(--primary);
}
.shopper-routes-index__lede {
  margin: var(--sp-2) 0 0;
  max-width: 40rem;
}
.shopper-routes-index__create {
  margin-bottom: var(--sp-8);
  padding: var(--sp-5) var(--sp-6);
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
}
.shopper-routes-index__h2 {
  margin: 0 0 var(--sp-4);
}
.shopper-routes-index__empty {
  margin: 0 0 var(--sp-8);
}
.shopper-routes-index__list-head {
  margin-bottom: var(--sp-4);
}
.shopper-routes-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin: var(--sp-8) 0 var(--sp-4);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--border);
}
.shopper-routes-tabs__link {
  display: inline-flex;
  align-items: center;
  padding: var(--sp-2) var(--sp-4);
  border-radius: var(--r-md);
  font-weight: 600;
  color: var(--text);
  text-decoration: none;
  border: 1px solid transparent;
}
.shopper-routes-tabs__link:hover {
  background: var(--n-50, #f8fafc);
  border-color: var(--border);
}
.shopper-routes-tabs__link.is-active {
  background: var(--white);
  border-color: var(--border);
  box-shadow: none;
  color: var(--primary);
}
.shopper-route-pick-append {
  margin-top: var(--sp-4);
  padding-top: var(--sp-3);
  border-top: 1px solid var(--border);
}
.shopper-route-pick-append__form {
  margin: 0;
}
.search-filters__route-day-note {
  margin: 0 0 var(--sp-4);
  max-width: 48rem;
}
.shopper-routes-create-page__form {
  max-width: 28rem;
}
.shopper-routes-create-page__actions {
  margin-top: var(--sp-2);
}
.entry-pass-scanner-wrap .entry-pass-scanner__lede {
  max-width: 42rem;
  margin-bottom: var(--sp-6);
}
.entry-pass-scanner {
  margin-bottom: var(--sp-6);
}
.entry-pass-scanner__reader {
  width: 100%;
  max-width: 22rem;
  margin: 0 auto var(--sp-4);
  min-height: 16rem;
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--n-50, #f8fafc);
}
.entry-pass-scanner__reader video,
.entry-pass-scanner__reader canvas {
  display: block;
  width: 100% !important;
  height: auto !important;
}
.entry-pass-scanner__party {
  max-width: 28rem;
  margin: 0 auto var(--sp-4);
  padding: var(--sp-4);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface, var(--n-0, #fff));
}
.entry-pass-scanner__party[hidden] {
  display: none;
}
.entry-pass-scanner__party-kicker {
  margin: 0 0 var(--sp-2);
  font-size: 0.875rem;
  color: var(--n-600, #64748b);
  text-align: center;
}
.entry-pass-scanner__party-list {
  list-style: none;
  margin: 0 0 var(--sp-3);
  padding: 0;
}
.entry-pass-scanner__party-line {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2) var(--sp-3);
  margin-bottom: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r-md);
  background: var(--n-50, #f1f5f9);
  border: 1px solid transparent;
}
.entry-pass-scanner__party-line:last-child {
  margin-bottom: 0;
}
.entry-pass-scanner__party-line.is-skipped {
  opacity: 0.65;
  background: var(--n-100, #e2e8f0);
  border-color: var(--n-200, #cbd5e1);
  text-decoration: line-through;
}
.entry-pass-scanner__party-line.is-skipped .entry-pass-scanner__skip {
  text-decoration: none;
}
.entry-pass-scanner__party-num {
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: var(--primary, #0f766e);
}
.entry-pass-scanner__party-name {
  flex: 1 1 8rem;
  min-width: 0;
  word-break: break-word;
}
.entry-pass-scanner__skip {
  margin-left: auto;
  flex-shrink: 0;
}
.entry-pass-scanner__party-actions {
  display: flex;
  justify-content: center;
}
.entry-pass-scanner__party-actions .entry-pass-scanner__record {
  min-width: 12rem;
}
.entry-pass-scanner__toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  justify-content: center;
  margin-bottom: var(--sp-4);
}
.entry-pass-scanner__status {
  margin: 0 0 var(--sp-2);
  min-height: 1.5rem;
  font-weight: 700;
  text-align: center;
  color: var(--text);
}
.entry-pass-scanner__status--scan {
  color: var(--primary);
}
.entry-pass-scanner__status--ok {
  color: #047857;
}
.entry-pass-scanner__status--err {
  color: #b91c1c;
}
.entry-pass-scanner__status--pending {
  color: var(--n-600, #475569);
}
.entry-pass-scanner__detail {
  text-align: center;
  margin: 0 0 var(--sp-4);
  min-height: 1.25rem;
}

.line-manager__welcome-title {
  font-size: clamp(1.35rem, 2.2vw, 1.75rem);
  margin: 0 0 var(--sp-3);
  line-height: 1.2;
}
.line-manager__welcome-lede {
  max-width: 44rem;
}
.line-manager__sale-title {
  font-size: var(--text-xl);
  margin: var(--sp-2) 0 0;
}
.line-manager__tabs {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin: 0 0 var(--sp-4);
  border-bottom: 1px solid var(--border);
  padding-bottom: var(--sp-2);
}
.line-manager__tab {
  border: 1px solid var(--border);
  background: var(--n-50, #f8fafc);
  color: var(--text);
  border-radius: var(--radius, 0.375rem) var(--radius, 0.375rem) 0 0;
  padding: var(--sp-2) var(--sp-4);
  font: inherit;
  cursor: pointer;
  margin-bottom: -1px;
}
.line-manager__tab.is-active {
  background: var(--card, #fff);
  border-bottom-color: transparent;
  font-weight: 600;
}
.line-manager__panel {
  padding-top: var(--sp-2);
}

/* Join Line poster: sheet = query container for cqi (100cqi = this sheet’s width).
   Type: --ljp-n-* × --ljp-poster-type-scale × (100cqi / 8.5in). Preview is a smaller 8.5×11
   model; at print 100% @ page width, 100cqi matches the full letter width. */
.ljp-poster-sheet {
  container-type: inline-size;
  container-name: ljp;
}
/* Join Line tab: US Letter 8.5×11 sheet preview + toolbar (print actions live outside the “paper”) */
.line-manager-poster-layout {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-4);
  margin: 0 0 var(--sp-2);
  max-width: 100%;
}
.line-manager-poster {
  --lm-poster-teal: #0f766e;
  position: relative;
  overflow: hidden;
}
/* Printable area: same aspect ratio as @page letter portrait in line_join_poster_print.php */
.line-manager-poster.line-manager-poster--letter {
  width: min(100%, 24rem, calc(86vh * 8.5 / 11));
  max-width: 100%;
  margin: 0 auto;
  padding: clamp(0.4rem, 1.2vw, 0.5rem) clamp(0.5rem, 1.5vw, 0.55rem);
  border-radius: 0.12rem;
  background: linear-gradient(145deg, #0f766e 0%, #115e59 42%, #134e4a 100%);
  box-sizing: border-box;
  aspect-ratio: 8.5 / 11;
  height: auto;
  max-height: min(86vh, 44rem);
  display: flex;
  flex-direction: column;
  box-shadow:
    0 0 0 1px rgba(0, 0, 0, 0.06),
    0 1px 2px rgba(0, 0, 0, 0.04),
    0 8px 28px rgba(15, 23, 42, 0.12),
    0 20px 50px rgba(15, 23, 42, 0.1);
}
.line-manager-poster::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 90% 55% at 50% -15%, rgba(255, 255, 255, 0.16), transparent 55%),
    radial-gradient(ellipse 50% 45% at 100% 100%, rgba(16, 185, 129, 0.2), transparent 50%);
  pointer-events: none;
}
.line-manager-poster--letter .line-manager-poster__card {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: clamp(0.5rem, 1.5vw, 0.75rem) clamp(0.5rem, 1.4vw, 0.9rem) clamp(0.45rem, 1.2vw, 0.65rem);
  border-radius: 0.4rem;
  text-align: center;
  justify-content: space-between;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}
.line-manager-poster__card {
  position: relative;
  z-index: 1;
  max-width: 28rem;
  margin: 0 auto;
  padding: clamp(1.5rem, 3vw, 2.25rem) clamp(1.25rem, 3vw, 1.75rem);
  border-radius: 0.625rem;
  background: linear-gradient(180deg, #fffefb 0%, #f0fdf4 50%, #ecfdf5 100%);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.6) inset,
    0 20px 48px rgba(6, 78, 59, 0.3),
    0 4px 16px rgba(0, 0, 0, 0.1);
  border: 1px solid rgba(16, 185, 129, 0.3);
  text-align: center;
}
.line-manager-poster--letter .line-manager-poster__sub {
  margin-bottom: var(--sp-3);
}
.line-manager-poster--letter .line-manager-poster__brand,
.line-manager-poster--letter .line-manager-poster__kicker,
.line-manager-poster--letter .line-manager-poster__headline,
.line-manager-poster--letter .line-manager-poster__sub,
.line-manager-poster--letter .line-manager-poster__hint {
  flex-shrink: 0;
}
.line-manager-poster--letter .line-manager-poster__qr-wrap {
  margin-bottom: 0;
  flex: 1 1 auto;
  min-height: 0;
  width: 100%;
  box-sizing: border-box;
  align-items: center;
  padding: var(--sp-2);
}
.line-manager-poster--letter .line-manager-poster__qr {
  min-height: 0;
  min-width: 0;
  width: 100%;
  height: 100%;
  max-height: 100%;
  padding: 0;
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
.line-manager-poster--letter .line-manager-poster__qr img,
.line-manager-poster--letter .line-manager-poster__qr canvas {
  max-width: 100% !important;
  max-height: 100% !important;
  width: auto !important;
  height: auto !important;
  margin: 0 auto;
  object-fit: contain;
}
.line-manager-poster--letter .line-manager-poster__hint {
  margin-top: var(--sp-2);
  margin-bottom: 0;
  line-height: 1.35;
  font-size: 0.8rem;
}
.line-manager-poster__size-hint {
  width: 100%;
  text-align: center;
  margin: 0;
}
/* Default (non–theme-editor) type: scaled to fit the mini letter sheet */
.line-manager-poster--letter .line-manager-poster__brand {
  font-size: clamp(0.7rem, 1.7vw, 0.9rem);
}
.line-manager-poster--letter .line-manager-poster__kicker {
  font-size: 0.65rem;
  margin: 0 0 var(--sp-1);
}
.line-manager-poster--letter .line-manager-poster__headline {
  font-size: clamp(0.85rem, 2.2vw, 1.15rem);
  margin: 0 0 var(--sp-1);
}
.line-manager-poster--letter .line-manager-poster__sub {
  font-size: clamp(0.65rem, 1.6vw, 0.82rem);
  margin: 0 0 var(--sp-2);
}
.line-manager-poster--letter.ljp-tuned .line-manager-poster__sub {
  margin: 0 0 var(--sp-3);
}
.line-manager-poster--letter.ljp-tuned .line-manager-poster__hint {
  margin-top: var(--sp-2);
}
.line-manager-poster__toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  justify-content: center;
  align-items: center;
  max-width: 40rem;
}
.line-manager-poster__brand {
  font-size: clamp(1.1rem, 2.2vw, 1.4rem);
  font-weight: 800;
  color: var(--lm-poster-teal);
  margin: 0 0 var(--sp-1);
  line-height: 1.2;
  font-family: Georgia, "Times New Roman", ui-serif, serif;
  letter-spacing: -0.02em;
}
.line-manager-poster__kicker {
  font-size: var(--text-sm, 0.875rem);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #0d4d3f;
  margin: 0 0 var(--sp-2);
}
.line-manager-poster__headline {
  font-size: clamp(1.65rem, 4.2vw, 2.35rem);
  font-weight: 800;
  line-height: 1.1;
  color: var(--lm-poster-teal);
  margin: 0 0 var(--sp-2);
  letter-spacing: -0.02em;
  text-wrap: balance;
  font-family: Georgia, "Times New Roman", ui-serif, serif;
}
.line-manager-poster__sub {
  font-size: clamp(0.95rem, 2.2vw, 1.15rem);
  font-weight: 600;
  color: #134e4a;
  margin: 0 0 var(--sp-5);
  line-height: 1.35;
  text-wrap: balance;
}
.line-manager-poster__qr-wrap {
  display: flex;
  justify-content: center;
  padding: var(--sp-4);
  background: #fff;
  border-radius: 0.5rem;
  box-shadow: 0 1px 0 rgba(15, 118, 110, 0.08), 0 6px 22px rgba(15, 118, 110, 0.1);
  border: 1px solid rgba(15, 118, 110, 0.1);
  margin: 0 auto;
}
.line-manager-poster__qr {
  min-height: 12.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.line-manager-poster__qr img,
.line-manager-poster__qr canvas {
  display: block;
  max-width: 100% !important;
  height: auto !important;
}
.line-manager-poster__hint {
  margin: var(--sp-5) 0 0;
  font-size: var(--text-sm, 0.875rem);
  font-weight: 600;
  color: #0d9488;
  line-height: 1.45;
  max-width: 24rem;
  margin-left: auto;
  margin-right: auto;
}
/* Themed state (see public/js/line-join-poster-theme.js) — match printable poster */
.line-manager-poster.ljp-tuned {
  background: var(--ljp-page-bg) !important;
}
.line-manager-poster.ljp-tuned[data-ljp-no-pattern="1"]::before {
  display: none;
}
.line-manager-poster.ljp-tuned .line-manager-poster__card {
  background: var(--ljp-card-bg) !important;
  color: var(--ljp-text);
  border: 1px solid color-mix(in srgb, var(--ljp-text) 14%, white) !important;
  box-shadow:
    0 0 0 1px color-mix(in srgb, white 65%, transparent) inset,
    0 20px 48px color-mix(in srgb, var(--ljp-text) 20%, rgba(0, 0, 0, 0.15));
}
.line-manager-poster.ljp-tuned .line-manager-poster__brand,
.line-manager-poster.ljp-tuned .line-manager-poster__kicker,
.line-manager-poster.ljp-tuned .line-manager-poster__headline,
.line-manager-poster.ljp-tuned .line-manager-poster__sub,
.line-manager-poster.ljp-tuned .line-manager-poster__hint,
.ljp-poster-print-body .ljp-poster-sheet .line-join-poster-print__brand,
.ljp-poster-print-body .ljp-poster-sheet .line-join-poster-print__kicker,
.ljp-poster-print-body .ljp-poster-sheet .line-join-poster-print__headline,
.ljp-poster-print-body .ljp-poster-sheet .line-join-poster-print__sub,
.ljp-poster-print-body .ljp-poster-sheet .line-join-poster-print__hint {
  color: var(--ljp-text);
  font-family: var(--ljp-font), var(--font-sans, system-ui, sans-serif);
  opacity: 1;
  text-align: center;
}
.line-manager-poster.ljp-tuned .line-manager-poster__kicker,
.ljp-poster-print-body .ljp-poster-sheet .line-join-poster-print__kicker {
  text-transform: none;
  letter-spacing: 0.02em;
  font-size: calc(var(--ljp-n-kicker, 1.2rem) * var(--ljp-poster-type-scale, 1.4) * (100cqi / var(--ljp-paper-ref, 8.5in)));
  font-weight: 600;
}
.line-manager-poster.ljp-tuned .line-manager-poster__brand,
.ljp-poster-print-body .ljp-poster-sheet .line-join-poster-print__brand {
  font-size: calc(var(--ljp-n-brand, 1.4rem) * var(--ljp-poster-type-scale, 1.4) * (100cqi / var(--ljp-paper-ref, 8.5in)));
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
  margin: 0 0 var(--sp-2);
}
.line-manager-poster.ljp-tuned .line-manager-poster__headline,
.ljp-poster-print-body .ljp-poster-sheet .line-join-poster-print__headline {
  font-size: calc(var(--ljp-n-head, 2.3rem) * var(--ljp-poster-type-scale, 1.4) * (100cqi / var(--ljp-paper-ref, 8.5in)));
  line-height: 1.1;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin: 0 0 var(--sp-2);
  text-wrap: balance;
}
.ljp-poster-print-body .ljp-poster-sheet h1.line-join-poster-print__headline {
  margin: 0 0 var(--sp-2);
}
.line-manager-poster.ljp-tuned .line-manager-poster__sub,
.ljp-poster-print-body .ljp-poster-sheet .line-join-poster-print__sub {
  font-size: calc(var(--ljp-n-sub, 1.05rem) * var(--ljp-poster-type-scale, 1.4) * (100cqi / var(--ljp-paper-ref, 8.5in)));
  line-height: 1.35;
  font-weight: 600;
  margin: 0 0 var(--sp-5);
  opacity: 0.95;
  text-wrap: balance;
}
.line-manager-poster.ljp-tuned .line-manager-poster__hint,
.ljp-poster-print-body .ljp-poster-sheet .line-join-poster-print__hint {
  font-size: calc(var(--ljp-n-hint, 0.9rem) * var(--ljp-poster-type-scale, 1.4) * (100cqi / var(--ljp-paper-ref, 8.5in)));
  line-height: 1.45;
  font-weight: 600;
  max-width: 24rem;
  margin: var(--sp-5) auto 0;
  opacity: 0.92;
}
.line-manager-poster.ljp-tuned .line-manager-poster__qr-wrap {
  background: #fff;
  box-shadow: 0 1px 0 color-mix(in srgb, var(--ljp-text) 6%, white), 0 6px 22px color-mix(in srgb, var(--ljp-text) 8%, white);
  border: 1px solid color-mix(in srgb, var(--ljp-text) 10%, white);
}
/* Standalone poster print (Join Line + lead gen): always white page; text/QR use --ljp-text etc. */
.ljp-poster-print-body {
  background: #fff !important;
  --ljp-page-bg: #fff;
}
/* Print poster: same 8.5×11" model as Line Manager; on screen, sheet is up to one letter page. */
.ljp-poster-print-body .ljp-poster-sheet.line-join-poster-print {
  flex: 1 1 auto;
  width: min(100%, 8.5in);
  max-width: 8.5in;
  min-height: min(11in, 100dvh);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  margin: 0 auto;
  box-sizing: border-box;
  padding: clamp(0.85rem, 1.15cqi, 1.1rem) clamp(0.95rem, 1.05cqi, 1rem);
}
.ljp-poster-print-body .ljp-poster-sheet .line-join-poster-print__qr {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1 1 auto;
  min-height: min(6rem, 20cqi);
  width: 100%;
  min-width: 0;
}
.ljp-poster-print-body .ljp-poster-sheet .line-join-poster-print__qr img,
.ljp-poster-print-body .ljp-poster-sheet .line-join-poster-print__qr canvas {
  display: block;
  max-width: 100% !important;
  max-height: 100% !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain;
}
@media print {
  html:has(.ljp-poster-print-body) {
    background: #fff !important;
  }
  .ljp-poster-print-body {
    background: #fff !important;
  }
  .ljp-poster-print-body .ljp-poster-sheet.line-join-poster-print {
    padding: 0.2in 0.25in;
    min-height: 10.2in; /* @page 11in − 0.4in top/bottom */
    max-height: 10.2in;
    height: auto;
    width: 100% !important;
    max-width: 100% !important;
    justify-content: space-between;
    page-break-inside: avoid;
    break-inside: avoid;
  }
  .ljp-poster-print-body .ljp-poster-sheet .line-join-poster-print__qr {
    flex: 1 1 auto;
    min-height: 0;
    max-height: none;
  }
  .ljp-poster-print-body .ljp-poster-sheet.line-join-poster-print > p,
  .ljp-poster-print-body .ljp-poster-sheet.line-join-poster-print > h1 {
    flex-shrink: 0;
  }
}
.line-join__form .form-group {
  margin-bottom: var(--sp-4);
}
.line-join__form .form-group > .keep-field-label {
  display: block;
  margin: 0 0 var(--sp-2) 0;
  font-weight: 600;
}
/* Poster QR /line-join/: form fields left-aligned inside card; title stays centered (shopper shell) */
.line-join--signin .line-join__card {
  text-align: left;
}
.line-join--signin .line-join__card--narrow {
  max-width: 22rem;
  margin-left: auto;
  margin-right: auto;
}
.line-join--signin .line-join__card .line-join__welcome {
  margin: 0 0 var(--sp-5);
  font-size: var(--text-base);
  line-height: 1.55;
  color: var(--text);
  font-weight: 600;
}
.line-join--signin .line-join__flash {
  max-width: 24rem;
  margin-left: auto;
  margin-right: auto;
}
.line-join__checkbox-row {
  margin-bottom: var(--sp-4);
}
.line-join__checkbox-label {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  font-weight: 500;
  font-size: var(--text-sm);
  line-height: 1.45;
  cursor: pointer;
  margin: 0;
  color: var(--n-700, #334155);
}
.line-join__checkbox-label input {
  width: 1.15rem;
  height: 1.15rem;
  margin: 0.1rem 0 0;
  flex-shrink: 0;
  accent-color: var(--primary);
}
.line-join__actions {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-top: var(--sp-2);
  align-items: stretch;
}
.line-join__actions .line-join__submit,
.line-join__actions .line-join__add-guest {
  flex: 1 1 9rem;
  min-width: 0;
  justify-content: center;
  margin-top: 0;
  padding: var(--sp-3) var(--sp-4);
  font-size: var(--text-base);
  min-height: 2.75rem;
}
.line-join__add-guest {
  background: var(--white, #fff);
  color: var(--n-800, #1e293b);
  border: 1px solid var(--n-200, #e2e8f0);
}
.line-join__add-guest:hover:not(:disabled) {
  background: var(--n-50, #f8fafc);
  border-color: var(--n-300, #cbd5e1);
}
.line-join__add-guest:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.line-join__guest-block {
  margin: var(--sp-3) 0 var(--sp-1);
}
.line-join__guest-label {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--n-600, #475569);
}
.line-join__guest-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.line-join__guest-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  margin-bottom: var(--sp-2);
  background: var(--n-50, #f8fafc);
  border-radius: var(--r, 0.5rem);
  border: 1px solid var(--n-100, #f1f5f9);
  font-size: var(--text-sm);
}
.line-join__guest-name {
  flex: 1;
  min-width: 0;
  text-align: left;
  color: var(--text);
}
.line-join__guest-remove {
  flex-shrink: 0;
  border: none;
  background: transparent;
  color: var(--n-500, #64748b);
  font-size: 1.25rem;
  line-height: 1;
  padding: 0.15rem 0.35rem;
  cursor: pointer;
  border-radius: 0.25rem;
}
.line-join__guest-remove:hover {
  color: var(--n-800, #1e293b);
  background: var(--n-100, #f1f5f9);
}
.line-join__guest-fields {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}
.line-join-modal[hidden] {
  display: none;
}
.line-join-modal {
  position: fixed;
  inset: 0;
  z-index: 4000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-4);
  box-sizing: border-box;
}
.line-join-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
  cursor: pointer;
}
.line-join-modal__panel {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 22rem;
  background: var(--white, #fff);
  border-radius: var(--r, 0.5rem);
  padding: var(--sp-5);
  box-shadow: 0 20px 40px rgba(15, 23, 42, 0.2);
  border: 1px solid var(--n-100, #f1f5f9);
}
.line-join-modal__title {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-lg);
  color: var(--text);
}
.line-join-modal__hint {
  margin: 0 0 var(--sp-4);
  font-size: var(--text-sm);
  color: var(--n-600, #475569);
  line-height: 1.5;
}
.line-join-modal__label {
  display: block;
  font-size: var(--text-sm);
  font-weight: 600;
  margin-bottom: var(--sp-2);
  color: var(--n-800, #1e293b);
}
.line-join-modal__actions {
  display: flex;
  gap: var(--sp-3);
  margin-top: var(--sp-5);
  justify-content: flex-end;
  flex-wrap: wrap;
}
.line-join--success .line-join__place {
  margin: var(--sp-4) 0;
  text-align: center;
}
.line-join--success .line-join__place-num {
  font-size: clamp(2rem, 5vw, 2.75rem);
  font-variant-numeric: tabular-nums;
}
.line-join--success .line-join__success-party {
  list-style: none;
  margin: var(--sp-3) auto var(--sp-4);
  padding: 0;
  max-width: 20rem;
  text-align: left;
}
.line-join--success .line-join__success-party-line {
  display: flex;
  align-items: baseline;
  gap: var(--sp-2);
  margin-bottom: var(--sp-2);
  font-size: var(--text-base);
  color: var(--text);
}
.line-join--success .line-join__success-party-num {
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--n-800, #1e293b);
}
.line-join--success .line-join__place--heading {
  margin-bottom: var(--sp-2);
}

/* Line Manager: Join Line Poster theme editor (print page only) */
.ljp-theme-dialog {
  max-width: min(28rem, calc(100% - 2rem));
  width: 100%;
  border: 1px solid var(--border);
  border-radius: var(--r-lg, 0.75rem);
  box-shadow: 0 20px 50px rgba(15, 23, 42, 0.2);
  padding: 0;
  background: var(--white, #fff);
  color: var(--text);
}
.ljp-theme-dialog::backdrop {
  background: rgba(15, 23, 42, 0.45);
}
.ljp-theme-form {
  padding: var(--sp-5) var(--sp-5) var(--sp-4);
  box-sizing: border-box;
}
.ljp-theme-dialog__title {
  margin: 0 0 var(--sp-1);
  font-size: var(--text-lg);
  line-height: 1.3;
  color: var(--primary, #0f172a);
}
.ljp-theme-color-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--sp-3);
}
@media (max-width: 520px) {
  .ljp-theme-color-row {
    grid-template-columns: 1fr;
  }
}
.ljp-theme-color .ljp-swatch {
  display: block;
  width: 100%;
  height: 2.75rem;
  padding: var(--sp-1);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  cursor: pointer;
  background: var(--n-50);
}
.ljp-theme-form input[type="range"] {
  height: auto;
  min-height: 0;
  padding: var(--sp-1) 0;
}
.ljp-labeled-range {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-2);
  width: 100%;
  margin: 0 0 var(--sp-1) 0;
  font-weight: 600;
  color: var(--text, #0f172a);
}
.ljp-range-out {
  float: none;
  font-size: var(--text-xs);
  font-weight: 500;
  color: var(--text-muted);
  font-style: normal;
  margin: 0;
  flex: 0 0 auto;
}
.ljp-theme-form__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-top: var(--sp-5);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border, #e2e8f0);
  justify-content: flex-end;
  align-items: center;
}
.ljp-theme-browse-hint a {
  color: var(--primary);
}

/* ---- Hosted company microsite (/site/{sub} or *.host) -------------------------------- */
.company-microsite {
  --ms-radius-xl: 0.625rem;
  --ms-radius-lg: 0.625rem;
  --ms-shadow-sm: none;
  --ms-shadow-md: none;
  --ms-shadow-lg: none;
  margin: 0;
  min-height: 100vh;
  background: var(--n-50, #f8fafc);
  color: var(--text);
  font-family: "DM Sans", system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
}
.company-microsite-gate {
  margin: 0;
  min-height: 100vh;
  background: linear-gradient(165deg, #f8fafc 0%, #eef2ff 50%, #f8fafc 100%);
  color: var(--text);
  font-family: "DM Sans", system-ui, sans-serif;
}
.company-microsite-gate__main {
  max-width: 32rem;
  margin: 0 auto;
  padding: var(--sp-10) var(--sp-4);
}
.company-microsite-gate__title {
  margin: 0 0 var(--sp-4);
  font-size: 1.625rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--primary);
}
.company-microsite-gate__message {
  margin: 0 0 var(--sp-4);
  line-height: 1.6;
  font-size: var(--text-base);
}
.company-microsite__preview-banner {
  padding: var(--sp-3) var(--sp-4);
  background: linear-gradient(90deg, #fef3c7 0%, #fde68a 100%);
  color: #78350f;
  border-bottom: 1px solid #fbbf24;
  font-size: var(--text-sm);
  font-weight: 500;
  text-align: center;
}
.company-microsite--slate .company-microsite__preview-banner {
  background: linear-gradient(90deg, #422006 0%, #1c1917 100%);
  color: #fde68a;
  border-bottom-color: #92400e;
}
.company-microsite__wrap {
  max-width: 58rem;
  margin: 0 auto;
  padding: var(--sp-6) var(--sp-4) var(--sp-10);
  position: relative;
  z-index: 1;
}
.company-microsite__masthead {
  margin-bottom: var(--sp-3);
  padding-bottom: var(--sp-4);
}
.company-microsite__masthead-brand {
  display: inline-block;
  font-size: clamp(1.125rem, 2.5vw, 1.35rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--primary);
  text-decoration: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.company-microsite__masthead-brand:hover {
  opacity: 0.88;
}
.company-microsite__nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-1) var(--sp-2);
  margin-bottom: var(--sp-7);
  padding: var(--sp-2) 0;
}
.company-microsite__nav-link {
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0.01em;
  color: var(--brand);
  text-decoration: none;
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--r);
  border: 1px solid transparent;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}
.company-microsite__nav-link:hover {
  background: rgba(21, 93, 252, 0.08);
  text-decoration: none;
}
.company-microsite__nav-link:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}
.company-microsite__nav-link.is-active {
  background: rgba(21, 93, 252, 0.12);
  color: var(--brand-dark, #0f52e0);
  border-color: rgba(21, 93, 252, 0.25);
}
.company-microsite__main {
  min-height: 12rem;
}
.company-microsite__page-header {
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-4);
}
.company-microsite__page-title {
  margin: 0 0 var(--sp-2);
  font-size: clamp(1.5rem, 3.5vw, 2rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.2;
  color: var(--primary);
}
.company-microsite__article {
  margin-bottom: var(--sp-8);
}
.company-microsite__page-body {
  line-height: 1.7;
  font-size: 1.0625rem;
}
.company-microsite__page-body p {
  margin: 0 0 var(--sp-4);
}
.company-microsite__hero {
  border-radius: var(--ms-radius-xl);
  padding: clamp(var(--sp-5), 4vw, var(--sp-8));
  margin-bottom: var(--sp-5);
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: var(--ms-shadow-sm);
}
.company-microsite__hero-inner {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-5);
  align-items: center;
}
.company-microsite__logo {
  border-radius: var(--ms-radius-lg);
  object-fit: contain;
  box-shadow: var(--ms-shadow-md);
  border: 3px solid rgba(255, 255, 255, 0.85);
}
.company-microsite__title {
  margin: 0 0 var(--sp-3);
  font-size: clamp(1.75rem, 5vw, 2.35rem);
  font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 1.15;
  color: var(--primary);
}
.company-microsite__lede {
  margin: 0;
  line-height: 1.65;
  max-width: 42rem;
  font-size: 1.0625rem;
}
.company-microsite__intro {
  margin-top: var(--sp-3);
  line-height: 1.7;
  font-size: 1.0625rem;
}
.company-microsite__cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-3);
  margin-bottom: var(--sp-7);
}
.company-microsite__cta-row .btn {
  border-radius: var(--r);
  padding-inline: var(--sp-5);
  font-weight: 600;
  box-shadow: var(--ms-shadow-sm);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.company-microsite__cta-row .btn:hover {
  transform: translateY(-1px);
  box-shadow: var(--ms-shadow-md);
}
.company-microsite__panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--ms-radius-xl);
  padding: clamp(var(--sp-5), 3vw, var(--sp-6));
  margin-bottom: var(--sp-5);
  box-shadow: var(--ms-shadow-sm);
  transition: box-shadow 0.25s ease, border-color 0.25s ease;
}
.company-microsite__panel:hover {
  box-shadow: var(--ms-shadow-md);
}
.company-microsite__h2 {
  margin: 0 0 var(--sp-5);
  font-size: var(--text-xl);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--primary);
  padding-bottom: var(--sp-3);
  border-bottom: 2px solid var(--border);
}
.company-microsite__grid {
  margin-top: var(--sp-3);
}
.company-microsite .card-grid.card-grid--listings .sale-listing-card {
  border-radius: var(--ms-radius-lg);
  overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.company-microsite .card-grid.card-grid--listings .sale-listing-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--ms-shadow-lg);
}
.company-microsite__empty {
  margin: 0;
  padding: var(--sp-4);
  text-align: center;
  border-radius: var(--r-md);
  background: var(--n-50, #f8fafc);
}
.company-microsite__vcard div {
  margin-bottom: var(--sp-2);
}
.company-microsite__contact-more {
  margin: var(--sp-4) 0 0;
}
.company-microsite__profile-lead {
  margin-top: var(--sp-2);
}
.company-microsite__profile-lead-intro {
  margin: 0 0 var(--sp-5);
  line-height: 1.6;
  max-width: 40rem;
}
.company-microsite__profile-lead-form .form-group {
  margin-bottom: var(--sp-4);
}
.company-microsite__profile-lead-form textarea.form-control {
  min-height: 8rem;
  resize: vertical;
}
.company-microsite__profile-lead-actions {
  margin-top: var(--sp-2);
}
.company-microsite__profile-lead-error {
  margin-bottom: var(--sp-4);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--r-md);
  background: #fef2f2;
  color: #991b1b;
  border: 1px solid #fecaca;
  font-size: var(--text-sm);
}
.company-microsite__profile-lead-success {
  padding: var(--sp-4);
  border-radius: var(--r-md);
  background: #ecfdf5;
  border: 1px solid #a7f3d0;
  color: #065f46;
}
.company-microsite__profile-lead-success-text {
  margin: 0;
  line-height: 1.55;
}
.company-microsite__footer {
  text-align: center;
  padding-top: var(--sp-8);
  margin-top: var(--sp-4);
  border-top: 1px solid var(--border);
  font-size: var(--text-sm);
}
.company-microsite__footer a {
  color: var(--brand);
  font-weight: 600;
  text-decoration: none;
}
.company-microsite__footer a:hover {
  text-decoration: underline;
}

.company-microsite__panel--subscribe .form-group {
  margin-bottom: var(--sp-3);
}
.company-microsite__subscribe-row {
  display: grid;
  gap: var(--sp-4);
}
@media (min-width: 640px) {
  .company-microsite__subscribe-row {
    grid-template-columns: 1fr 1fr;
  }
}
.company-microsite__subscribe-form .btn {
  margin-top: var(--sp-2);
}
.company-microsite__subscribe-inner--compact .company-microsite__subscribe-form .btn {
  width: 100%;
}
@media (min-width: 480px) {
  .company-microsite__subscribe-inner--compact .company-microsite__subscribe-form .btn {
    width: auto;
  }
}
.company-microsite__subscribe-lede {
  margin-top: var(--sp-4);
}
.company-microsite__sale-canonical {
  margin: var(--sp-3) 0 0;
  max-width: 40rem;
  line-height: 1.5;
}
.company-microsite__sale .sale-listing__grid {
  margin-top: var(--sp-6);
}

/* —— Aurora: immersive gradient, glass nav, luminous hero —— */
.company-microsite--aurora {
  background: #0c1222;
  background-image:
    radial-gradient(ellipse 120% 80% at 20% -20%, rgba(21, 93, 252, 0.45) 0%, transparent 55%),
    radial-gradient(ellipse 100% 60% at 100% 30%, rgba(0, 146, 184, 0.35) 0%, transparent 50%),
    radial-gradient(ellipse 80% 50% at 50% 100%, rgba(99, 102, 241, 0.2) 0%, transparent 45%),
    linear-gradient(180deg, #0f172a 0%, #0c1222 40%, #0f172a 100%);
  color: #e2e8f0;
}
.company-microsite--aurora .company-microsite__masthead {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: var(--sp-2);
}
.company-microsite--aurora .company-microsite__masthead-brand {
  color: #fff;
  text-shadow: 0 2px 24px rgba(21, 93, 252, 0.4);
}
.company-microsite--aurora .company-microsite__nav {
  margin-bottom: var(--sp-7);
  padding: var(--sp-2);
  gap: var(--sp-2);
  background: rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: var(--ms-radius-lg);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: none;
}
.company-microsite--aurora .company-microsite__nav-link {
  color: rgba(255, 255, 255, 0.88);
}
.company-microsite--aurora .company-microsite__nav-link:hover {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
}
.company-microsite--aurora .company-microsite__nav-link.is-active {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.35);
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08) inset;
}
.company-microsite--aurora .company-microsite__nav-link:focus-visible {
  outline-color: #93c5fd;
}
.company-microsite--aurora .company-microsite__page-title {
  color: #fff;
  text-shadow: 0 2px 20px rgba(0, 0, 0, 0.25);
}
.company-microsite--aurora .company-microsite__hero {
  border: 1px solid rgba(255, 255, 255, 0.15);
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.12) 0%, transparent 50%),
    linear-gradient(135deg, #1d4ed8 0%, #155dfc 38%, #0d9488 72%, #0891b2 100%);
  box-shadow:
    var(--ms-shadow-lg),
    0 0 0 1px rgba(255, 255, 255, 0.08) inset,
    0 0 80px rgba(21, 93, 252, 0.25);
  color: #fff;
}
.company-microsite--aurora .company-microsite__title,
.company-microsite--aurora .company-microsite__lede,
.company-microsite--aurora .company-microsite__intro {
  color: #fff;
}
.company-microsite--aurora .company-microsite__intro a {
  color: #e0f2fe;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.company-microsite--aurora .company-microsite__logo {
  border-color: rgba(255, 255, 255, 0.5);
  background: rgba(255, 255, 255, 0.12);
  box-shadow:
    0 12px 40px rgba(0, 0, 0, 0.25),
    0 0 0 1px rgba(255, 255, 255, 0.2) inset;
}
.company-microsite--aurora .company-microsite__panel {
  background: rgba(15, 23, 42, 0.65);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-color: rgba(255, 255, 255, 0.1);
  color: #e2e8f0;
  box-shadow: none;
}
.company-microsite--aurora .company-microsite__panel:hover {
  border-color: rgba(255, 255, 255, 0.16);
}
.company-microsite--aurora .company-microsite__h2 {
  color: #fff;
  border-bottom-color: rgba(255, 255, 255, 0.15);
}
.company-microsite--aurora .company-microsite__empty {
  background: rgba(255, 255, 255, 0.06);
  color: #cbd5e1;
}
.company-microsite--aurora .meta,
.company-microsite--aurora .company-microsite__vcard {
  color: #cbd5e1;
}
.company-microsite--aurora .company-microsite__footer {
  border-top-color: rgba(255, 255, 255, 0.1);
}
.company-microsite--aurora .company-microsite__footer a {
  color: #93c5fd;
}
.company-microsite--aurora .company-microsite__cta-row .btn-primary {
  background: #fff;
  color: #155dfc;
  border: none;
  box-shadow: none;
}
.company-microsite--aurora .company-microsite__cta-row .btn-primary:hover {
  background: #f8fafc;
  color: #0f52e0;
}
.company-microsite--aurora .company-microsite__cta-row .btn-secondary {
  background: rgba(255, 255, 255, 0.12);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.35);
}
.company-microsite--aurora .company-microsite__cta-row .btn-secondary:hover {
  background: rgba(255, 255, 255, 0.2);
}
.company-microsite--aurora .company-microsite__page-body {
  color: #e2e8f0;
}
.company-microsite--aurora .company-microsite__page-body h1,
.company-microsite--aurora .company-microsite__page-body h2,
.company-microsite--aurora .company-microsite__page-body h3 {
  color: #fff;
}
.company-microsite--aurora .company-microsite__page-body a {
  color: #93c5fd;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.company-microsite--aurora .company-microsite__page-body a:hover {
  color: #e0f2fe;
}
.company-microsite--aurora .sale-listing-card--media-overlays .sale-listing-card__excerpt {
  color: #e2e8f0;
}

/* —— Classic: warm paper, editorial serif headings, bronze accent —— */
.company-microsite--classic {
  background: linear-gradient(180deg, #faf9f7 0%, #f4f1eb 35%, #faf9f7 100%);
  color: #334155;
}
.company-microsite--classic .company-microsite__masthead-brand {
  font-family: "Libre Baskerville", "Georgia", serif;
  font-weight: 700;
  font-size: clamp(1.25rem, 2.8vw, 1.5rem);
  color: #1e293b;
  letter-spacing: -0.02em;
}
.company-microsite--classic .company-microsite__nav-link {
  color: #475569;
  border-radius: var(--r-xs);
}
.company-microsite--classic .company-microsite__nav-link:hover {
  background: rgba(30, 41, 59, 0.06);
  color: #1e293b;
}
.company-microsite--classic .company-microsite__nav-link.is-active {
  background: #fff;
  color: #0f172a;
  border-color: rgba(180, 83, 9, 0.35);
  box-shadow: none;
}
.company-microsite--classic .company-microsite__hero {
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow:
    0 4px 6px -1px rgba(15, 23, 42, 0.06),
    0 20px 40px -12px rgba(15, 23, 42, 0.1);
}
.company-microsite--classic .company-microsite__title {
  font-family: "Libre Baskerville", "Georgia", serif;
  font-weight: 700;
  color: #0f172a;
}
.company-microsite--classic .company-microsite__lede,
.company-microsite--classic .company-microsite__intro {
  color: #475569;
  font-size: 1.0625rem;
}
.company-microsite--classic .company-microsite__intro a {
  color: #a3410f;
  font-weight: 600;
}
.company-microsite--classic .company-microsite__intro a:hover {
  color: #7c2d12;
}
.company-microsite--classic .company-microsite__logo {
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: none;
  background: #fff;
}
.company-microsite--classic .company-microsite__panel {
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: none;
}
.company-microsite--classic .company-microsite__panel:hover {
  box-shadow: none;
}
.company-microsite--classic .company-microsite__h2 {
  font-family: "Libre Baskerville", "Georgia", serif;
  font-weight: 700;
  color: #0f172a;
  border-bottom: 2px solid rgba(180, 83, 9, 0.45);
  padding-bottom: var(--sp-3);
}
.company-microsite--classic .company-microsite__page-title {
  font-family: "Libre Baskerville", "Georgia", serif;
  font-weight: 700;
  color: #0f172a;
}
.company-microsite--classic .company-microsite__page-body {
  color: #475569;
}
.company-microsite--classic .company-microsite__page-body h1,
.company-microsite--classic .company-microsite__page-body h2,
.company-microsite--classic .company-microsite__page-body h3 {
  color: #0f172a;
  font-family: "Libre Baskerville", "Georgia", serif;
  font-weight: 700;
}
.company-microsite--classic .company-microsite__page-body a {
  color: #9a3412;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.company-microsite--classic .company-microsite__page-body a:hover {
  color: #7c2d12;
}
.company-microsite--classic .company-microsite__footer {
  border-top-color: rgba(15, 23, 42, 0.1);
  color: #64748b;
}
.company-microsite--classic .company-microsite__footer a {
  color: #9a3412;
  font-weight: 600;
}
.company-microsite--classic .company-microsite__footer a:hover {
  color: #0f172a;
}
.company-microsite--classic .company-microsite__empty {
  background: rgba(255, 255, 255, 0.8);
  border: 1px dashed rgba(15, 23, 42, 0.12);
  color: #64748b;
}
.company-microsite--classic .company-microsite__cta-row .btn-primary {
  background: #9a3412;
  border: none;
  color: #fff;
}
.company-microsite--classic .company-microsite__cta-row .btn-primary:hover {
  background: #7c2d12;
  color: #fff;
}
.company-microsite--classic .company-microsite__cta-row .btn-secondary {
  background: #fff;
  color: #0f172a;
  border: 1.5px solid rgba(15, 23, 42, 0.15);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}
.company-microsite--classic .company-microsite__cta-row .btn-secondary:hover {
  background: #faf8f5;
  border-color: rgba(15, 23, 42, 0.22);
}
.company-microsite--classic .card-grid.card-grid--listings .card {
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: var(--ms-radius-lg, 0.625rem);
  overflow: hidden;
}
.company-microsite--classic .card-grid.card-grid--listings .card-body {
  color: #334155;
  background: #fff;
}
.company-microsite--classic .card-grid.card-grid--listings .card:hover {
  border-color: rgba(180, 83, 9, 0.35);
  box-shadow: 0 4px 24px rgba(15, 23, 42, 0.1);
}
.company-microsite--classic .card-grid.card-grid--listings .card h3 a {
  color: #0f172a;
}
.company-microsite--classic .card-grid.card-grid--listings .card h3 a:hover {
  color: #9a3412;
}
.company-microsite--classic .card-grid.card-grid--listings .card-footer-row {
  border-top-color: rgba(15, 23, 42, 0.1);
}
.company-microsite--classic .card-grid.card-grid--listings .card-meta,
.company-microsite--classic .card-grid.card-grid--listings .meta-item {
  color: #64748b;
}
.company-microsite--classic .sale-listing-card--media-overlays .sale-listing-card__excerpt {
  color: #e2e8f0;
}

/* —— Slate: midnight, emerald accent, elevated cards —— */
.company-microsite--slate {
  background: #030712;
  background-image:
    radial-gradient(ellipse 100% 80% at 50% -30%, rgba(16, 185, 129, 0.12) 0%, transparent 55%),
    radial-gradient(ellipse 60% 40% at 100% 80%, rgba(59, 130, 246, 0.08) 0%, transparent 50%),
    linear-gradient(180deg, #030712 0%, #0f172a 50%, #020617 100%);
  color: #cbd5e1;
}
.company-microsite--slate .company-microsite__masthead-brand {
  color: #f8fafc;
  text-shadow: 0 0 40px rgba(16, 185, 129, 0.15);
}
.company-microsite--slate .company-microsite__nav {
  padding: var(--sp-2);
  background: rgba(15, 23, 42, 0.6);
  border-radius: var(--ms-radius-lg);
  border: 1px solid rgba(148, 163, 184, 0.12);
  box-shadow: none;
}
.company-microsite--slate .company-microsite__nav-link {
  color: #94a3b8;
}
.company-microsite--slate .company-microsite__nav-link:hover {
  background: rgba(16, 185, 129, 0.1);
  color: #ecfdf5;
}
.company-microsite--slate .company-microsite__nav-link.is-active {
  background: rgba(16, 185, 129, 0.18);
  color: #6ee7b7;
  border-color: rgba(16, 185, 129, 0.35);
}
.company-microsite--slate .company-microsite__nav-link:focus-visible {
  outline-color: #34d399;
}
.company-microsite--slate .company-microsite__hero {
  background: linear-gradient(165deg, #1e293b 0%, #0f172a 100%);
  border: 1px solid rgba(148, 163, 184, 0.15);
  box-shadow:
    var(--ms-shadow-lg),
    0 0 0 1px rgba(16, 185, 129, 0.08) inset,
    0 0 60px rgba(16, 185, 129, 0.06);
}
.company-microsite--slate .company-microsite__title {
  color: #f8fafc;
}
.company-microsite--slate .company-microsite__lede,
.company-microsite--slate .company-microsite__intro,
.company-microsite--slate .meta {
  color: #94a3b8;
}
.company-microsite--slate .company-microsite__logo {
  border-color: rgba(148, 163, 184, 0.25);
  background: rgba(15, 23, 42, 0.5);
  box-shadow: none;
}
.company-microsite--slate .company-microsite__panel {
  background: rgba(30, 41, 59, 0.85);
  border: 1px solid rgba(148, 163, 184, 0.12);
  box-shadow: none;
}
.company-microsite--slate .company-microsite__panel:hover {
  border-color: rgba(16, 185, 129, 0.2);
}
.company-microsite--slate .company-microsite__h2 {
  color: #f1f5f9;
  border-bottom-color: rgba(16, 185, 129, 0.35);
}
.company-microsite--slate .company-microsite__page-title {
  color: #f8fafc;
}
.company-microsite--slate .company-microsite__page-body {
  color: #cbd5e1;
}
.company-microsite--slate a {
  color: #5eead4;
}
.company-microsite--slate .company-microsite__footer {
  border-top-color: rgba(148, 163, 184, 0.12);
}
.company-microsite--slate .company-microsite__footer a {
  color: #5eead4;
}
.company-microsite--slate .company-microsite__empty {
  background: rgba(15, 23, 42, 0.6);
  border: 1px dashed rgba(148, 163, 184, 0.2);
  color: #94a3b8;
}
.company-microsite--slate .company-microsite__cta-row .btn-primary {
  background: linear-gradient(135deg, #059669 0%, #0d9488 100%);
  border: none;
  color: #fff;
}
.company-microsite--slate .company-microsite__cta-row .btn-primary:hover {
  filter: brightness(1.08);
}
.company-microsite--slate .company-microsite__cta-row .btn-secondary {
  background: rgba(148, 163, 184, 0.12);
  color: #e2e8f0;
  border: 1px solid rgba(148, 163, 184, 0.25);
}
.company-microsite--slate .sale-listing-card .sale-listing-card-title {
  color: #f1f5f9;
}
.company-microsite--slate .card-grid.card-grid--listings .card-meta {
  color: #94a3b8;
}
.company-microsite--slate .sale-listing-card--media-overlays .sale-listing-card__excerpt {
  color: #e2e8f0;
}
.company-microsite--aurora .sale-listing-card .sale-listing-card-title {
  color: #f8fafc;
}
.company-microsite--aurora .card-grid.card-grid--listings .card-meta {
  color: #cbd5e1;
}
.company-microsite--classic .sale-listing-card .sale-listing-card-title {
  color: #0f172a;
}

/* —— Ember: warm parchment, editorial serif & rich terracotta —— */
/*
   Identity : artisan warmth — craft spirits, luxury hospitality, editorial food
   System   : warm sand page (#f0e4d0) → white raised surfaces → terracotta accent
   Structure: Libre Baskerville for headings; left-bar accent motif on hero/panels/h2
   Contrast : primary #1a0e06 on #f0e4d0 → 14:1 ✓  secondary #4a2415 → 9:1 ✓
*/
.company-microsite--ember {
  background: #f0e4d0;
  background-image: linear-gradient(180deg, #f5ece0 0%, #ede0ca 50%, #f5ece0 100%);
  color: #1a0e06;
}
/* Ember masthead: serif brand + terracotta rule */
.company-microsite--ember .company-microsite__masthead {
  padding-bottom: var(--sp-5);
  margin-bottom: var(--sp-3);
  border-bottom: 1px solid rgba(184, 53, 32, 0.2);
}
.company-microsite--ember .company-microsite__masthead-brand {
  font-family: "Libre Baskerville", "Georgia", serif;
  font-weight: 700;
  color: #b83520;
  font-size: clamp(1.2rem, 2.6vw, 1.45rem);
  letter-spacing: -0.01em;
}
.company-microsite--ember .company-microsite__nav {
  padding: var(--sp-2);
  background: rgba(255, 255, 255, 0.55);
  border-radius: var(--ms-radius-lg);
  border: 1px solid rgba(184, 53, 32, 0.12);
  box-shadow: 0 1px 2px rgba(26, 14, 6, 0.04);
}
.company-microsite--ember .company-microsite__nav-link {
  color: #4a2415;
  border-radius: var(--r-xs);
  font-weight: 500;
}
.company-microsite--ember .company-microsite__nav-link:hover {
  background: rgba(184, 53, 32, 0.08);
  color: #b83520;
}
.company-microsite--ember .company-microsite__nav-link.is-active {
  background: rgba(184, 53, 32, 0.12);
  color: #b83520;
  border-color: rgba(184, 53, 32, 0.28);
  box-shadow: none;
}
.company-microsite--ember .company-microsite__nav-link:focus-visible {
  outline-color: #b83520;
}
.company-microsite--ember .company-microsite__page-title {
  font-family: "Libre Baskerville", "Georgia", serif;
  color: #1a0e06;
  font-weight: 700;
}
/* Ember hero: white lifts from warm sand — left-bar anchors the brand */
.company-microsite--ember .company-microsite__hero {
  background: #ffffff;
  border: 1px solid rgba(184, 53, 32, 0.1);
  border-left: 4px solid #b83520;
  box-shadow:
    0 1px 3px rgba(26, 14, 6, 0.06),
    0 12px 40px -8px rgba(26, 14, 6, 0.14);
}
.company-microsite--ember .company-microsite__title {
  font-family: "Libre Baskerville", "Georgia", serif;
  font-weight: 700;
  color: #1a0e06;
}
.company-microsite--ember .company-microsite__lede,
.company-microsite--ember .company-microsite__intro {
  color: #4a2415;
}
.company-microsite--ember .company-microsite__intro a {
  color: #b83520;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.company-microsite--ember .company-microsite__logo {
  border: 1px solid rgba(26, 14, 6, 0.1);
  background: #fff;
  box-shadow: 0 2px 12px rgba(26, 14, 6, 0.1);
}
/* Ember panels: white surfaces on warm sand + left accent bar */
.company-microsite--ember .company-microsite__panel {
  background: #ffffff;
  border: 1px solid rgba(26, 14, 6, 0.08);
  border-left: 3px solid rgba(184, 53, 32, 0.35);
  box-shadow: 0 1px 4px rgba(26, 14, 6, 0.05), 0 4px 16px rgba(26, 14, 6, 0.06);
}
.company-microsite--ember .company-microsite__panel:hover {
  border-left-color: #b83520;
  box-shadow: 0 4px 24px rgba(26, 14, 6, 0.1);
}
/* Ember h2: serif + terracotta left-bar — editorial motif */
.company-microsite--ember .company-microsite__h2 {
  font-family: "Libre Baskerville", "Georgia", serif;
  font-weight: 700;
  color: #1a0e06;
  border-bottom: none;
  padding-bottom: 0;
  padding-left: var(--sp-3);
  border-left: 4px solid #b83520;
  margin-bottom: var(--sp-5);
}
.company-microsite--ember .company-microsite__page-body {
  color: #2e1508;
}
.company-microsite--ember .company-microsite__page-body h1,
.company-microsite--ember .company-microsite__page-body h2,
.company-microsite--ember .company-microsite__page-body h3 {
  color: #1a0e06;
  font-family: "Libre Baskerville", "Georgia", serif;
  font-weight: 700;
}
.company-microsite--ember .company-microsite__page-body a {
  color: #b83520;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.company-microsite--ember .company-microsite__page-body a:hover {
  color: #982c18;
}
.company-microsite--ember .sale-listing-card--media-overlays .sale-listing-card__excerpt {
  color: #fdf4f0;
}
.company-microsite--ember .company-microsite__footer {
  border-top-color: rgba(184, 53, 32, 0.15);
  color: #7a4a30;
}
.company-microsite--ember .company-microsite__footer a {
  color: #b83520;
}
.company-microsite--ember .company-microsite__empty {
  background: rgba(255, 255, 255, 0.75);
  border: 1px dashed rgba(184, 53, 32, 0.22);
  color: #7a4a30;
}
.company-microsite--ember .meta,
.company-microsite--ember .company-microsite__vcard {
  color: #7a4a30;
}
.company-microsite--ember .company-microsite__cta-row .btn-primary {
  background: linear-gradient(135deg, #c03a22 0%, #982c18 100%);
  border: none;
  color: #fff;
}
.company-microsite--ember .company-microsite__cta-row .btn-primary:hover {
  background: linear-gradient(135deg, #d04228 0%, #b03320 100%);
}
.company-microsite--ember .company-microsite__cta-row .btn-secondary {
  background: transparent;
  color: #b83520;
  border: 1.5px solid rgba(184, 53, 32, 0.42);
}
.company-microsite--ember .company-microsite__cta-row .btn-secondary:hover {
  background: rgba(184, 53, 32, 0.07);
}
/* Ember cards: white surfaces on warm sand, terracotta-tinted borders */
.company-microsite--ember .card-grid.card-grid--listings .card {
  background: #ffffff;
  border-color: rgba(26, 14, 6, 0.1);
}
.company-microsite--ember .card-grid.card-grid--listings .card-body {
  background: #ffffff;
  color: #1a0e06;
}
.company-microsite--ember .card-grid.card-grid--listings .card:hover {
  border-color: rgba(184, 53, 32, 0.22);
  box-shadow: 0 4px 20px rgba(26, 14, 6, 0.08);
}
.company-microsite--ember .card-grid.card-grid--listings .card h3 {
  color: #1a0e06;
}
.company-microsite--ember .card-grid.card-grid--listings .card h3 a {
  color: #1a0e06;
}
.company-microsite--ember .card-grid.card-grid--listings .card h3 a:hover {
  color: #b83520;
}
.company-microsite--ember .card-grid.card-grid--listings .card-footer-row {
  border-top-color: rgba(26, 14, 6, 0.08);
}
.company-microsite--ember .sale-listing-card .sale-listing-card-title {
  color: #1a0e06;
}
.company-microsite--ember .card-grid.card-grid--listings .card-meta {
  color: #7a4a30;
}
.company-microsite--ember .card-grid.card-grid--listings .meta-item {
  color: #7a4a30;
}

/* —— Coast: open water, ocean-gradient hero & crisp-white surfaces —— */
/*
   Identity : luxury coastal — premium real estate, resort, maritime
   System   : pale sky page → immersive ocean-blue hero → crisp white panels
   Structure: glass nav + filled active pill + ocean gradient hero (max contrast)
   Contrast : hero text #fff on #0558a4 → 10:1 ✓  page text #071828 → 18:1 ✓
*/
.company-microsite--coast {
  background: #f5faff;
  background-image: linear-gradient(180deg, #f8fbff 0%, #eaf3ff 50%, #f8fbff 100%);
  color: #071828;
}
.company-microsite--coast .company-microsite__masthead {
  padding-bottom: var(--sp-4);
  margin-bottom: var(--sp-2);
  border-bottom: 1px solid rgba(5, 88, 164, 0.18);
}
.company-microsite--coast .company-microsite__masthead-brand {
  color: #0558a4;
  letter-spacing: -0.025em;
  font-weight: 800;
}
/* Coast: day-glass nav — light backdrop-filter, solid filled active */
.company-microsite--coast .company-microsite__nav {
  padding: var(--sp-2);
  gap: var(--sp-1);
  background: rgba(255, 255, 255, 0.78);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: var(--ms-radius-lg);
  border: 1px solid rgba(5, 88, 164, 0.15);
  box-shadow: 0 1px 3px rgba(5, 88, 164, 0.07), 0 0 0 1px rgba(255, 255, 255, 0.5) inset;
}
.company-microsite--coast .company-microsite__nav-link {
  color: #1e4f7a;
  border-radius: var(--r-xs);
  font-weight: 500;
}
.company-microsite--coast .company-microsite__nav-link:hover {
  background: rgba(5, 88, 164, 0.1);
  color: #0558a4;
}
.company-microsite--coast .company-microsite__nav-link.is-active {
  background: #0558a4;
  color: #ffffff;
  border-color: transparent;
  box-shadow: 0 2px 8px rgba(5, 88, 164, 0.35);
}
.company-microsite--coast .company-microsite__nav-link:focus-visible {
  outline-color: #0558a4;
}
.company-microsite--coast .company-microsite__page-title {
  color: #071828;
  font-weight: 800;
}
/* Coast hero: deep ocean gradient — dramatic shift from the pale sky page */
.company-microsite--coast .company-microsite__hero {
  background: linear-gradient(145deg, #0558a4 0%, #0284c7 55%, #0369a1 100%);
  border: none;
  box-shadow:
    0 4px 6px -1px rgba(5, 88, 164, 0.25),
    0 24px 60px -12px rgba(5, 88, 164, 0.4);
  color: #fff;
}
.company-microsite--coast .company-microsite__title {
  color: #ffffff;
  font-weight: 800;
}
.company-microsite--coast .company-microsite__lede,
.company-microsite--coast .company-microsite__intro {
  color: rgba(255, 255, 255, 0.9);
}
.company-microsite--coast .company-microsite__intro a {
  color: #bae6fd;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.company-microsite--coast .company-microsite__logo {
  border-color: rgba(255, 255, 255, 0.45);
  background: rgba(255, 255, 255, 0.15);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2), 0 0 0 1px rgba(255, 255, 255, 0.25) inset;
}
/* Coast panels: crisp white — maximum contrast on the pale blue page */
.company-microsite--coast .company-microsite__panel {
  background: #ffffff;
  border: 1px solid rgba(5, 88, 164, 0.1);
  box-shadow: 0 1px 4px rgba(5, 88, 164, 0.07), 0 8px 32px rgba(5, 88, 164, 0.06);
}
.company-microsite--coast .company-microsite__panel:hover {
  border-color: rgba(5, 88, 164, 0.2);
  box-shadow: 0 4px 24px rgba(5, 88, 164, 0.1);
}
.company-microsite--coast .company-microsite__h2 {
  color: #071828;
  border-bottom: 2px solid rgba(5, 88, 164, 0.2);
  padding-bottom: var(--sp-3);
  font-weight: 800;
}
.company-microsite--coast .company-microsite__page-body {
  color: #0d2d4a;
}
.company-microsite--coast .company-microsite__page-body h1,
.company-microsite--coast .company-microsite__page-body h2,
.company-microsite--coast .company-microsite__page-body h3 {
  color: #071828;
  font-weight: 800;
}
.company-microsite--coast .company-microsite__page-body a {
  color: #0558a4;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.company-microsite--coast .company-microsite__page-body a:hover {
  color: #0c4a6e;
}
.company-microsite--coast .sale-listing-card--media-overlays .sale-listing-card__excerpt {
  color: rgba(255, 255, 255, 0.95);
}
.company-microsite--coast .company-microsite__footer {
  border-top-color: rgba(5, 88, 164, 0.15);
  color: #3d6080;
}
.company-microsite--coast .company-microsite__footer a {
  color: #0558a4;
}
.company-microsite--coast .company-microsite__empty {
  background: rgba(255, 255, 255, 0.9);
  border: 1px dashed rgba(5, 88, 164, 0.2);
  color: #3d6080;
}
.company-microsite--coast .meta,
.company-microsite--coast .company-microsite__vcard {
  color: #3d6080;
}
/* Coast CTAs: ocean blue gradient on the pale page */
.company-microsite--coast .company-microsite__cta-row .btn-primary {
  background: linear-gradient(135deg, #0284c7 0%, #0558a4 100%);
  border: none;
  color: #fff;
}
.company-microsite--coast .company-microsite__cta-row .btn-primary:hover {
  filter: brightness(1.08);
}
.company-microsite--coast .company-microsite__cta-row .btn-secondary {
  background: transparent;
  color: #0558a4;
  border: 1.5px solid rgba(5, 88, 164, 0.4);
}
.company-microsite--coast .company-microsite__cta-row .btn-secondary:hover {
  background: rgba(5, 88, 164, 0.07);
}
/* Coast cards: crisp white surfaces, ocean-tinted borders */
.company-microsite--coast .card-grid.card-grid--listings .card {
  background: #ffffff;
  border-color: rgba(5, 88, 164, 0.12);
}
.company-microsite--coast .card-grid.card-grid--listings .card-body {
  background: #ffffff;
  color: #071828;
}
.company-microsite--coast .card-grid.card-grid--listings .card:hover {
  border-color: rgba(5, 88, 164, 0.25);
  box-shadow: 0 4px 20px rgba(5, 88, 164, 0.1);
}
.company-microsite--coast .card-grid.card-grid--listings .card h3 {
  color: #071828;
}
.company-microsite--coast .card-grid.card-grid--listings .card h3 a {
  color: #071828;
}
.company-microsite--coast .card-grid.card-grid--listings .card h3 a:hover {
  color: #0558a4;
}
.company-microsite--coast .card-grid.card-grid--listings .card-footer-row {
  border-top-color: rgba(5, 88, 164, 0.1);
}
.company-microsite--coast .sale-listing-card .sale-listing-card-title {
  color: #071828;
}
.company-microsite--coast .card-grid.card-grid--listings .card-meta {
  color: #3d6080;
}
.company-microsite--coast .card-grid.card-grid--listings .meta-item {
  color: #3d6080;
}

/* —— Grove: deep forest, luminous emerald & organic dark luxury —— */
/*
   Identity : premium eco brand, forest retreat, high-end outdoor/wellness
   System   : #030906 page → #0c1c10 panels → #162b1c cards (3 distinct levels)
   Contrast : h3 #e8f5ec on #162b1c → 12:1 ✓  meta #7abf90 → 4.6:1 ✓
              excerpt fix: was #000 (invisible) → now #b0ccb8 ✓
*/
.company-microsite--grove {
  background: #030906;
  background-image:
    radial-gradient(ellipse 100% 60% at 25% -15%, rgba(22, 101, 52, 0.5) 0%, transparent 55%),
    radial-gradient(ellipse 70% 45% at 85% 70%, rgba(5, 150, 105, 0.22) 0%, transparent 50%),
    linear-gradient(180deg, #030906 0%, #071210 50%, #030906 100%);
  color: #c4dfc8;
}
.company-microsite--grove .company-microsite__preview-banner {
  background: linear-gradient(90deg, #042812 0%, #0f4020 100%);
  color: #a7f3d0;
  border-bottom-color: #145c28;
}
.company-microsite--grove .company-microsite__masthead-brand {
  color: #4ade80;
  font-weight: 800;
  text-shadow: 0 0 30px rgba(74, 222, 128, 0.3);
}
/* Grove: forest glass nav — deep green tint with blur */
.company-microsite--grove .company-microsite__nav {
  padding: var(--sp-2);
  gap: var(--sp-1);
  background: rgba(7, 18, 10, 0.7);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-radius: var(--ms-radius-lg);
  border: 1px solid rgba(74, 222, 128, 0.14);
  box-shadow: 0 0 0 1px rgba(74, 222, 128, 0.04) inset;
}
.company-microsite--grove .company-microsite__nav-link {
  color: #86d9a0;
  font-weight: 500;
}
.company-microsite--grove .company-microsite__nav-link:hover {
  background: rgba(22, 101, 52, 0.25);
  color: #d1fae5;
}
.company-microsite--grove .company-microsite__nav-link.is-active {
  background: rgba(74, 222, 128, 0.16);
  color: #4ade80;
  border-color: rgba(74, 222, 128, 0.32);
}
.company-microsite--grove .company-microsite__nav-link:focus-visible {
  outline-color: #4ade80;
}
.company-microsite--grove .company-microsite__page-title {
  color: #e8f5ec;
  font-weight: 800;
}
/* Grove hero: deep canopy with emerald ambient glow */
.company-microsite--grove .company-microsite__hero {
  background: linear-gradient(160deg, #0d2414 0%, #061208 100%);
  border: 1px solid rgba(74, 222, 128, 0.16);
  box-shadow:
    0 0 0 1px rgba(74, 222, 128, 0.06) inset,
    0 0 100px rgba(22, 101, 52, 0.22),
    0 32px 64px rgba(0, 0, 0, 0.5);
}
.company-microsite--grove .company-microsite__title {
  color: #e8f5ec;
  font-weight: 800;
}
.company-microsite--grove .company-microsite__lede,
.company-microsite--grove .company-microsite__intro {
  color: #a0d4b0;
}
.company-microsite--grove .company-microsite__intro a {
  color: #4ade80;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.company-microsite--grove .company-microsite__logo {
  border-color: rgba(74, 222, 128, 0.28);
  background: rgba(7, 18, 10, 0.6);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4), 0 0 0 1px rgba(74, 222, 128, 0.08) inset;
}
/* Grove panels: clear 3-level depth — panels float above the page */
.company-microsite--grove .company-microsite__panel {
  background: #0c1c10;
  border: 1px solid rgba(74, 222, 128, 0.12);
  box-shadow: 0 8px 40px rgba(0, 0, 0, 0.4), 0 2px 8px rgba(0, 0, 0, 0.3);
}
.company-microsite--grove .company-microsite__panel:hover {
  border-color: rgba(74, 222, 128, 0.24);
  box-shadow:
    0 12px 48px rgba(0, 0, 0, 0.45),
    0 0 0 1px rgba(74, 222, 128, 0.08) inset;
}
/* Grove h2: emerald left-bar — organic vs geometric */
.company-microsite--grove .company-microsite__h2 {
  color: #c8ecd0;
  border-bottom: none;
  padding-bottom: 0;
  padding-left: var(--sp-3);
  border-left: 3px solid rgba(74, 222, 128, 0.6);
  margin-bottom: var(--sp-5);
  font-weight: 800;
}
.company-microsite--grove .company-microsite__empty {
  background: rgba(12, 28, 16, 0.8);
  border: 1px dashed rgba(74, 222, 128, 0.2);
  color: #86d9a0;
}
.company-microsite--grove .meta,
.company-microsite--grove .company-microsite__vcard {
  color: #86d9a0;
}
.company-microsite--grove .company-microsite__footer {
  border-top-color: rgba(74, 222, 128, 0.14);
  color: #86d9a0;
}
.company-microsite--grove .company-microsite__footer a {
  color: #4ade80;
}
.company-microsite--grove .company-microsite__cta-row .btn-primary {
  background: linear-gradient(135deg, #16a34a 0%, #0f6b31 100%);
  border: none;
  color: #fff;
  font-weight: 700;
}
.company-microsite--grove .company-microsite__cta-row .btn-primary:hover {
  filter: brightness(1.08);
}
.company-microsite--grove .company-microsite__cta-row .btn-secondary {
  background: rgba(74, 222, 128, 0.1);
  color: #4ade80;
  border: 1.5px solid rgba(74, 222, 128, 0.28);
}
.company-microsite--grove .company-microsite__cta-row .btn-secondary:hover {
  background: rgba(74, 222, 128, 0.18);
}
.company-microsite--grove .company-microsite__page-body {
  color: #b8d4bc;
}
.company-microsite--grove .company-microsite__page-body h1,
.company-microsite--grove .company-microsite__page-body h2,
.company-microsite--grove .company-microsite__page-body h3 {
  color: #e8f5ec;
}
.company-microsite--grove .company-microsite__page-body a {
  color: #4ade80;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.company-microsite--grove .company-microsite__page-body a:hover {
  color: #86efac;
}
/*
   Grove cards: dark forest bodies — verified contrast ratios:
   #e8f5ec (h3) on #162b1c → 12:1  #86efac (meta) on #162b1c — improved from #7abf90
   #b0ccb8 (excerpt) on #162b1c → 6.1:1  (was #000 → 0.2:1 FAIL)
*/
.company-microsite--grove .card-grid.card-grid--listings .card {
  background: #162b1c;
  border-color: rgba(74, 222, 128, 0.12);
}
.company-microsite--grove .card-grid.card-grid--listings .card-body {
  background: #162b1c;
  color: #c8ecd0;
}
.company-microsite--grove .card-grid.card-grid--listings .card:hover {
  border-color: rgba(74, 222, 128, 0.28);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5), 0 0 0 1px rgba(74, 222, 128, 0.1) inset;
}
.company-microsite--grove .sale-card-slideshow {
  background: #0d2015;
  border-bottom-color: rgba(74, 222, 128, 0.1);
}
.company-microsite--grove .card-grid.card-grid--listings .card h3 {
  color: #e8f5ec;
}
.company-microsite--grove .card-grid.card-grid--listings .card h3 a {
  color: #e8f5ec;
}
.company-microsite--grove .card-grid.card-grid--listings .card h3 a:hover {
  color: #4ade80;
}
.company-microsite--grove .card-grid.card-grid--listings .card-footer-row {
  border-top-color: rgba(74, 222, 128, 0.14);
}
.company-microsite--grove .sale-listing-card .sale-listing-card-title {
  color: #e8f5ec;
}
.company-microsite--grove .card-grid.card-grid--listings .card-meta {
  color: #86efac;
}
.company-microsite--grove .card-grid.card-grid--listings .meta-item {
  color: #86efac;
}
.company-microsite--grove .sale-listing-card--media-overlays .sale-listing-card__excerpt {
  color: #b0ccb8;
}

/* —— Deco: art deco noir, champagne gold & lacquered dark luxury —— */
/*
   Identity : luxury fashion, high-end hotel, art gallery, financial prestige
   System   : #06060e page → #0d0d1c panels → #141428 cards (3 distinct levels)
   Structure: gold top-stripe on body, uppercase typography, geometric precision
   Contrast : h3 #f0e8cc on #141428 → 13:1 ✓  meta #c4a86e → 7:1 ✓
              excerpt fix: was #000 (invisible) → now #d0c4a0 ✓
*/
.company-microsite--deco {
  background: #06060e;
  background-image:
    radial-gradient(ellipse 80% 45% at 50% -15%, rgba(201, 168, 76, 0.1) 0%, transparent 55%),
    radial-gradient(ellipse 55% 35% at 95% 85%, rgba(201, 168, 76, 0.05) 0%, transparent 50%),
    linear-gradient(180deg, #06060e 0%, #0c0c1a 50%, #06060e 100%);
  color: #e8d9b4;
  border-top: 3px solid #c9a84c;
}
.company-microsite--deco .company-microsite__preview-banner {
  background: linear-gradient(90deg, #141000 0%, #0c0c1a 100%);
  color: #e2b96f;
  border-bottom-color: #6b4a0a;
}
/* Deco masthead: gold hairline + generous spacing = geometric grandeur */
.company-microsite--deco .company-microsite__masthead {
  padding-bottom: var(--sp-6);
  margin-bottom: var(--sp-4);
  border-bottom: 1px solid rgba(201, 168, 76, 0.28);
}
.company-microsite--deco .company-microsite__masthead-brand {
  color: #c9a84c;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-size: clamp(0.85rem, 2vw, 1.05rem);
  font-weight: 700;
}
/* Deco nav: geometric gold-bordered container, uppercase links */
.company-microsite--deco .company-microsite__nav {
  padding: var(--sp-2);
  background: rgba(12, 12, 26, 0.8);
  border-radius: var(--ms-radius-lg);
  border: 1px solid rgba(201, 168, 76, 0.22);
  box-shadow: none;
}
.company-microsite--deco .company-microsite__nav-link {
  color: #c4ad7e;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  font-size: 0.78rem;
  font-weight: 600;
}
.company-microsite--deco .company-microsite__nav-link:hover {
  background: rgba(201, 168, 76, 0.1);
  color: #e2c97a;
}
.company-microsite--deco .company-microsite__nav-link.is-active {
  background: rgba(201, 168, 76, 0.16);
  color: #c9a84c;
  border-color: rgba(201, 168, 76, 0.38);
}
.company-microsite--deco .company-microsite__nav-link:focus-visible {
  outline-color: #c9a84c;
}
.company-microsite--deco .company-microsite__page-title {
  color: #f0e8cc;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}
/* Deco hero: lacquered dark, gold top accent + ambient glow */
.company-microsite--deco .company-microsite__hero {
  background: linear-gradient(160deg, #131226 0%, #06060e 100%);
  border: 1px solid rgba(201, 168, 76, 0.2);
  border-top: 3px solid rgba(201, 168, 76, 0.6);
  box-shadow:
    0 0 0 1px rgba(201, 168, 76, 0.05) inset,
    0 0 100px rgba(201, 168, 76, 0.07),
    0 32px 64px rgba(0, 0, 0, 0.6);
}
.company-microsite--deco .company-microsite__title {
  color: #f0e8cc;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  font-weight: 800;
}
.company-microsite--deco .company-microsite__lede,
.company-microsite--deco .company-microsite__intro {
  color: #c4ad7e;
}
.company-microsite--deco .company-microsite__intro a {
  color: #c9a84c;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.company-microsite--deco .company-microsite__logo {
  border-color: rgba(201, 168, 76, 0.32);
  background: rgba(12, 12, 26, 0.7);
  box-shadow: 0 0 0 1px rgba(201, 168, 76, 0.1) inset, 0 8px 32px rgba(0, 0, 0, 0.4);
}
/* Deco panels: lacquered dark with gold crown */
.company-microsite--deco .company-microsite__panel {
  background: #0d0d1c;
  border: 1px solid rgba(201, 168, 76, 0.16);
  border-top: 2px solid rgba(201, 168, 76, 0.45);
  box-shadow: 0 8px 40px rgba(0, 0, 0, 0.45);
}
.company-microsite--deco .company-microsite__panel:hover {
  border-top-color: rgba(201, 168, 76, 0.7);
  box-shadow:
    0 12px 48px rgba(0, 0, 0, 0.55),
    0 0 24px rgba(201, 168, 76, 0.06);
}
/* Deco h2: gold all-caps section marker — signature geometric rule */
.company-microsite--deco .company-microsite__h2 {
  color: #c9a84c;
  border-bottom: 1px solid rgba(201, 168, 76, 0.25);
  padding-bottom: var(--sp-3);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 0.88rem;
  font-weight: 700;
}
.company-microsite--deco .company-microsite__empty {
  background: rgba(13, 13, 28, 0.8);
  border: 1px dashed rgba(201, 168, 76, 0.2);
  color: #c4ad7e;
}
.company-microsite--deco .meta,
.company-microsite--deco .company-microsite__vcard {
  color: #c4ad7e;
}
.company-microsite--deco .company-microsite__footer {
  border-top-color: rgba(201, 168, 76, 0.18);
  color: #c4ad7e;
}
.company-microsite--deco .company-microsite__footer a {
  color: #c9a84c;
}
/* Deco CTAs: gold fill, uppercase — precise and authoritative */
.company-microsite--deco .company-microsite__cta-row .btn-primary {
  background: linear-gradient(135deg, #d4a843 0%, #b88c22 100%);
  border: none;
  color: #06060e;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.company-microsite--deco .company-microsite__cta-row .btn-primary:hover {
  filter: brightness(1.08);
}
.company-microsite--deco .company-microsite__cta-row .btn-secondary {
  background: transparent;
  color: #c9a84c;
  border: 1.5px solid rgba(201, 168, 76, 0.4);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.company-microsite--deco .company-microsite__cta-row .btn-secondary:hover {
  background: rgba(201, 168, 76, 0.1);
}
.company-microsite--deco .company-microsite__page-body {
  color: #d8cbaa;
}
.company-microsite--deco .company-microsite__page-body h1,
.company-microsite--deco .company-microsite__page-body h2,
.company-microsite--deco .company-microsite__page-body h3 {
  color: #f0e8cc;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.company-microsite--deco .company-microsite__page-body a {
  color: #d4b87a;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.company-microsite--deco .company-microsite__page-body a:hover {
  color: #e2c97a;
}
/*
   Deco cards: verified contrast ratios:
   #f0e8cc (h3) on #141428 → 13:1  #c4a86e (meta) on #141428 → 7:1
   #d0c4a0 (excerpt) on #141428 → 9:1  (was #000 → 0.04:1 FAIL)
*/
.company-microsite--deco .card-grid.card-grid--listings .card {
  background: #141428;
  border-color: rgba(201, 168, 76, 0.14);
  border-top: 2px solid rgba(201, 168, 76, 0.4);
}
.company-microsite--deco .card-grid.card-grid--listings .card-body {
  background: #141428;
  color: #e8d9b4;
}
.company-microsite--deco .card-grid.card-grid--listings .card:hover {
  border-top-color: rgba(201, 168, 76, 0.65);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.6), 0 0 24px rgba(201, 168, 76, 0.06);
}
.company-microsite--deco .sale-card-slideshow {
  background: #0c0c20;
  border-bottom-color: rgba(201, 168, 76, 0.12);
}
.company-microsite--deco .card-grid.card-grid--listings .card h3 {
  color: #f0e8cc;
}
.company-microsite--deco .card-grid.card-grid--listings .card h3 a {
  color: #f0e8cc;
}
.company-microsite--deco .card-grid.card-grid--listings .card h3 a:hover {
  color: #c9a84c;
}
.company-microsite--deco .card-grid.card-grid--listings .card-footer-row {
  border-top-color: rgba(201, 168, 76, 0.14);
}
.company-microsite--deco .sale-listing-card .sale-listing-card-title {
  color: #f0e8cc;
}
.company-microsite--deco .card-grid.card-grid--listings .card-meta {
  color: #c4a86e;
}
.company-microsite--deco .card-grid.card-grid--listings .meta-item {
  color: #c4a86e;
}
.company-microsite--deco .sale-listing-card--media-overlays .sale-listing-card__excerpt {
  color: #d0c4a0;
}

/* —— Bloom: blush parchment, deep bordeaux rose & editorial elegance —— */
/*
   Identity : luxury floral, editorial fashion, bridal, high-end beauty brand
   System   : warm blush page → white raised surfaces → deep rose accent
   Structure: centered nav, white hero card, borderless h2, pure typography
   Contrast : primary #1e0910 on #fdf5f8 → 18:1 ✓  secondary #5c1e32 → 13:1 ✓
*/
.company-microsite--bloom {
  background: #fdf0f4;
  background-image: linear-gradient(180deg, #fdf5f8 0%, #f8e0ea 50%, #fdf5f8 100%);
  color: #1e0910;
}
.company-microsite--bloom .company-microsite__preview-banner {
  background: linear-gradient(90deg, #fff5f7 0%, #fce7f0 100%);
  color: #6b1e3a;
  border-bottom: 1px solid rgba(149, 34, 69, 0.2);
}
.company-microsite--bloom .company-microsite__masthead-brand {
  color: #952245;
  letter-spacing: -0.02em;
  font-weight: 800;
}
/* Bloom: centered nav — editorial, lookbook aesthetic */
.company-microsite--bloom .company-microsite__nav {
  justify-content: center;
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid rgba(149, 34, 69, 0.14);
}
.company-microsite--bloom .company-microsite__nav-link {
  color: #5c1e32;
  border-radius: var(--r-xs);
  font-weight: 500;
}
.company-microsite--bloom .company-microsite__nav-link:hover {
  background: rgba(149, 34, 69, 0.08);
  color: #952245;
}
.company-microsite--bloom .company-microsite__nav-link.is-active {
  background: rgba(149, 34, 69, 0.12);
  color: #952245;
  border-color: rgba(149, 34, 69, 0.28);
  box-shadow: none;
}
.company-microsite--bloom .company-microsite__nav-link:focus-visible {
  outline-color: #952245;
}
.company-microsite--bloom .company-microsite__page-title {
  color: #1e0910;
  font-weight: 800;
}
/* Bloom hero: pure white — editorial clarity against the blush page */
.company-microsite--bloom .company-microsite__hero {
  background: #ffffff;
  border: 1px solid rgba(149, 34, 69, 0.1);
  box-shadow:
    0 1px 3px rgba(30, 9, 16, 0.06),
    0 12px 40px -8px rgba(149, 34, 69, 0.12);
}
.company-microsite--bloom .company-microsite__title {
  color: #1e0910;
  font-weight: 800;
}
.company-microsite--bloom .company-microsite__lede,
.company-microsite--bloom .company-microsite__intro {
  color: #5c1e32;
}
.company-microsite--bloom .company-microsite__intro a {
  color: #952245;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.company-microsite--bloom .company-microsite__logo {
  border: 1px solid rgba(30, 9, 16, 0.1);
  background: #fff;
  box-shadow: 0 2px 12px rgba(149, 34, 69, 0.1);
}
/* Bloom panels: pure white — strong contrast on warm blush page */
.company-microsite--bloom .company-microsite__panel {
  background: #ffffff;
  border: 1px solid rgba(30, 9, 16, 0.08);
  box-shadow: 0 1px 4px rgba(149, 34, 69, 0.05), 0 4px 20px rgba(149, 34, 69, 0.06);
}
.company-microsite--bloom .company-microsite__panel:hover {
  border-color: rgba(149, 34, 69, 0.18);
  box-shadow: 0 4px 24px rgba(149, 34, 69, 0.1);
}
/* Bloom h2: pure typographic hierarchy — weight and color, no rule */
.company-microsite--bloom .company-microsite__h2 {
  color: #1e0910;
  border-bottom: none;
  padding-bottom: 0;
  font-weight: 800;
  letter-spacing: -0.015em;
  margin-bottom: var(--sp-6);
}
.company-microsite--bloom .company-microsite__page-body {
  color: #2e1020;
}
.company-microsite--bloom .company-microsite__page-body h1,
.company-microsite--bloom .company-microsite__page-body h2,
.company-microsite--bloom .company-microsite__page-body h3 {
  color: #1e0910;
  font-weight: 800;
  letter-spacing: -0.02em;
}
.company-microsite--bloom .company-microsite__page-body a {
  color: #952245;
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.company-microsite--bloom .company-microsite__page-body a:hover {
  color: #7a1c38;
}
.company-microsite--bloom .company-microsite__footer {
  border-top-color: rgba(149, 34, 69, 0.12);
  color: #7a3050;
}
.company-microsite--bloom .company-microsite__footer a {
  color: #952245;
}
.company-microsite--bloom .company-microsite__empty {
  background: rgba(255, 255, 255, 0.9);
  border: 1px dashed rgba(149, 34, 69, 0.18);
  color: #7a3050;
}
.company-microsite--bloom .meta,
.company-microsite--bloom .company-microsite__vcard {
  color: #7a3050;
}
.company-microsite--bloom .company-microsite__cta-row .btn-primary {
  background: linear-gradient(135deg, #b22a52 0%, #952245 100%);
  border: none;
  color: #fff;
}
.company-microsite--bloom .company-microsite__cta-row .btn-primary:hover {
  background: linear-gradient(135deg, #c0305a 0%, #a52850 100%);
}
.company-microsite--bloom .company-microsite__cta-row .btn-secondary {
  background: transparent;
  color: #952245;
  border: 1.5px solid rgba(149, 34, 69, 0.38);
}
.company-microsite--bloom .company-microsite__cta-row .btn-secondary:hover {
  background: rgba(149, 34, 69, 0.07);
}
/* Bloom cards: white surfaces, subtle rose borders */
.company-microsite--bloom .card-grid.card-grid--listings .card {
  background: #ffffff;
  border-color: rgba(30, 9, 16, 0.09);
}
.company-microsite--bloom .card-grid.card-grid--listings .card-body {
  background: #ffffff;
  color: #1e0910;
}
.company-microsite--bloom .card-grid.card-grid--listings .card:hover {
  border-color: rgba(149, 34, 69, 0.22);
  box-shadow: 0 4px 20px rgba(149, 34, 69, 0.08);
}
.company-microsite--bloom .card-grid.card-grid--listings .card h3 {
  color: #1e0910;
}
.company-microsite--bloom .card-grid.card-grid--listings .card h3 a {
  color: #1e0910;
}
.company-microsite--bloom .card-grid.card-grid--listings .card h3 a:hover {
  color: #952245;
}
.company-microsite--bloom .card-grid.card-grid--listings .card-footer-row {
  border-top-color: rgba(30, 9, 16, 0.08);
}
.company-microsite--bloom .sale-listing-card .sale-listing-card-title {
  color: #1e0910;
}
.company-microsite--bloom .card-grid.card-grid--listings .card-meta {
  color: #7a3050;
}
.company-microsite--bloom .card-grid.card-grid--listings .meta-item {
  color: #7a3050;
}
.company-microsite--bloom .sale-listing-card--media-overlays .sale-listing-card__excerpt {
  color: #fff5f7;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.45);
}

/* =============================================================================
   Theme: Classic Heritage
   Palette  — page #f9fafb · panel/card #ffffff · ink #0a0a0a
              slate #364153 · muted #4a5565 · accent #155dfc
              border #e5e7eb · active-nav #0f172a
   Font     — Inter 400/500 (loaded above)
   Identity — Clean editorial; centered masthead; dark-pill active nav;
              crisp white cards on light-gray ground; vivid-blue links.
   ============================================================================= */
.company-microsite--heritage {
  background: #f9fafb;
  color: #0a0a0a;
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
}

/* ---- Masthead ------------------------------------------------------------ */
.company-microsite--heritage .company-microsite__masthead {
  background: #ffffff;
  border-bottom: 1px solid #e5e7eb;
  text-align: center;
}
.company-microsite--heritage .company-microsite__masthead-brand {
  color: #0a0a0a;
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  font-size: 1.5rem;
  letter-spacing: 0.003em;
}
.company-microsite--heritage .company-microsite__masthead-brand:hover {
  color: #155dfc;
}

/* ---- Navigation ---------------------------------------------------------- */
/* Centred pill-nav — matches Figma's horizontal centred tab bar */
.company-microsite--heritage .company-microsite__nav {
  justify-content: center;
  background: #ffffff;
  border-bottom: 1px solid #e5e7eb;
  padding-bottom: var(--sp-3);
  gap: var(--sp-1);
}
.company-microsite--heritage .company-microsite__nav-link {
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 400;
  font-size: 1rem;
  color: #364153;
  border-radius: 6px;
  padding: 0.35rem 0.85rem;
  transition: color 150ms, background 150ms;
}
.company-microsite--heritage .company-microsite__nav-link:hover {
  color: #0a0a0a;
  background: #f1f3f5;
}
.company-microsite--heritage .company-microsite__nav-link.is-active {
  background: #0f172a;
  color: #ffffff;
  border-color: transparent;
  box-shadow: none;
  font-weight: 500;
}
.company-microsite--heritage .company-microsite__nav-link:focus-visible {
  outline: 2px solid #155dfc;
  outline-offset: 2px;
}

/* ---- Page title (inner-page h1) ------------------------------------------ */
.company-microsite--heritage .company-microsite__page-title {
  color: #0a0a0a;
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  letter-spacing: -0.02em;
}

/* ---- Hero ---------------------------------------------------------------- */
/* Pure-white lifted card — echoes the Figma profile panel */
.company-microsite--heritage .company-microsite__hero {
  background: #ffffff;
  border: 1px solid #e5e7eb;
  box-shadow:
    0 1px 2px rgba(0, 0, 0, 0.06),
    0 4px 16px rgba(0, 0, 0, 0.06);
  text-align: center;
}
.company-microsite--heritage .company-microsite__title {
  color: #0a0a0a;
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  letter-spacing: -0.02em;
}
.company-microsite--heritage .company-microsite__lede,
.company-microsite--heritage .company-microsite__intro {
  color: #364153;
  font-family: 'Inter', system-ui, sans-serif;
  line-height: 1.7;
}
.company-microsite--heritage .company-microsite__intro a {
  color: #155dfc;
  text-decoration: underline;
  text-underline-offset: 3px;
  font-weight: 500;
}
.company-microsite--heritage .company-microsite__intro a:hover {
  color: #1246c9;
}

/* ---- Company logo/avatar ------------------------------------------------- */
.company-microsite--heritage .company-microsite__logo {
  border: 2px solid #e5e7eb;
  background: #ffffff;
  box-shadow: 0 1px 6px rgba(0, 0, 0, 0.08);
}

/* ---- Content panels ------------------------------------------------------ */
/* Level-2 surfaces: white, 1 px border, restrained shadow */
.company-microsite--heritage .company-microsite__panel {
  background: #ffffff;
  border: 1px solid #e5e7eb;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06), 0 2px 8px rgba(0, 0, 0, 0.04);
}
.company-microsite--heritage .company-microsite__panel:hover {
  border-color: #c9cdd4;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
}

/* ---- Section headings ---------------------------------------------------- */
/* Understated rule — ink weight, no decorative bar */
.company-microsite--heritage .company-microsite__h2 {
  color: #0a0a0a;
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  letter-spacing: -0.02em;
  border-bottom: 1px solid #e5e7eb;
  padding-bottom: var(--sp-3);
  margin-bottom: var(--sp-6);
}

/* ---- Page body (rich text pages) ---------------------------------------- */
.company-microsite--heritage .company-microsite__page-body {
  color: #364153;
}
.company-microsite--heritage .company-microsite__page-body h1,
.company-microsite--heritage .company-microsite__page-body h2,
.company-microsite--heritage .company-microsite__page-body h3 {
  color: #0a0a0a;
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  letter-spacing: -0.02em;
}
.company-microsite--heritage .company-microsite__page-body a {
  color: #155dfc;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.company-microsite--heritage .company-microsite__page-body a:hover {
  color: #1246c9;
}

/* ---- Muted content (vcard, meta) ----------------------------------------- */
.company-microsite--heritage .meta,
.company-microsite--heritage .company-microsite__vcard {
  color: #4a5565;
}

/* ---- Empty state --------------------------------------------------------- */
.company-microsite--heritage .company-microsite__empty {
  background: rgba(255, 255, 255, 0.9);
  border: 1px dashed #c9cdd4;
  color: #4a5565;
}

/* ---- Footer -------------------------------------------------------------- */
/* Faint gray-tinted base matching Figma's contact section */
.company-microsite--heritage .company-microsite__footer {
  background: #f3f4f6;
  border-top: 1px solid #e5e7eb;
  color: #4a5565;
}
.company-microsite--heritage .company-microsite__footer a {
  color: #155dfc;
}
.company-microsite--heritage .company-microsite__footer a:hover {
  color: #1246c9;
  text-decoration: underline;
}

/* ---- CTAs ---------------------------------------------------------------- */
/* Primary: near-black fill (Figma "Full profile & contact" button) */
.company-microsite--heritage .company-microsite__cta-row .btn-primary {
  background: #0f172a;
  border-color: #0f172a;
  color: #ffffff;
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
  letter-spacing: -0.01em;
}
.company-microsite--heritage .company-microsite__cta-row .btn-primary:hover {
  background: #1e293b;
  border-color: #1e293b;
}
/* Secondary: outlined (Figma "Mailing list" button) */
.company-microsite--heritage .company-microsite__cta-row .btn-secondary {
  background: transparent;
  color: #0f172a;
  border: 1.5px solid #cbd5e1;
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 400;
}
.company-microsite--heritage .company-microsite__cta-row .btn-secondary:hover {
  background: #f1f5f9;
  border-color: #94a3b8;
}

/* ---- Listing cards ------------------------------------------------------- */
/* Crisp white cards on the light-gray ground — 3-level surface hierarchy */
.company-microsite--heritage .card-grid.card-grid--listings .card {
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06), 0 1px 3px rgba(0, 0, 0, 0.06);
}
.company-microsite--heritage .card-grid.card-grid--listings .card-body {
  background: #ffffff;
  color: #0a0a0a;
}
.company-microsite--heritage .card-grid.card-grid--listings .card:hover {
  border-color: #c9cdd4;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.09);
}
.company-microsite--heritage .card-grid.card-grid--listings .card h3 {
  color: #0a0a0a;
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 500;
}
.company-microsite--heritage .card-grid.card-grid--listings .card h3 a {
  color: #0a0a0a;
}
.company-microsite--heritage .card-grid.card-grid--listings .card h3 a:hover {
  color: #155dfc;
}
.company-microsite--heritage .card-grid.card-grid--listings .card-footer-row {
  border-top-color: #e5e7eb;
}
.company-microsite--heritage .sale-listing-card .sale-listing-card-title {
  color: #0a0a0a;
}
.company-microsite--heritage .card-grid.card-grid--listings .card-meta {
  color: #4a5565;
}
.company-microsite--heritage .card-grid.card-grid--listings .meta-item {
  color: #4a5565;
}
/* Overlay excerpt text on card image tiles must remain legible */
.company-microsite--heritage .sale-listing-card--media-overlays .sale-listing-card__excerpt {
  color: #ffffff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.55);
}

@media print {
  .no-print,
  .site-header,
  .site-footer {
    display: none !important;
  }
  body {
    background: #fff;
  }
  .main {
    padding: 0;
    max-width: none;
  }
  .shopper-route-shell {
    max-width: none;
  }
  .shopper-route-sheet {
    border: none;
    box-shadow: none;
    padding: 0;
  }
  .shopper-route-stop-list__manage {
    display: none !important;
  }
}

/* Estate Manager — create / edit estate (modern sections, Places autocomplete) */
.estate-page--form.config-settings-page {
  max-width: 52rem;
}
.estate-page__migrate {
  margin-bottom: var(--sp-4);
}
.estate-page__migrate code {
  font-size: 0.9em;
}
.estate-page__back {
  margin: 0 0 var(--sp-4);
}
.estate-page__back-link {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--primary);
  text-decoration: none;
}
.estate-page__back-link:hover {
  text-decoration: underline;
}
.estate-page__actions {
  margin-top: var(--sp-6);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--border);
}
.estate-form--full {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
}
.estate-form__panel {
  margin: 0;
  padding: var(--sp-6);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
  box-shadow: none;
}
.estate-form__panel--rep {
  border-color: color-mix(in srgb, var(--primary) 18%, var(--border));
}
.estate-form__panel-title {
  margin: 0 0 var(--sp-1);
  font-size: var(--text-lg);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text);
}
.estate-form__panel-lede {
  margin: 0 0 var(--sp-5);
  font-size: var(--text-sm);
  line-height: 1.55;
  color: var(--n-600);
}

/* US address blocks: street + responsive city / state / ZIP row */
.es-address-fields {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  width: 100%;
}
.es-address-fields__street .form-group {
  margin-bottom: 0;
}
.es-address-fields__locality {
  display: grid;
  gap: var(--sp-2) var(--sp-3);
  /* City, state, ZIP on one row at all breakpoints (incl. narrow mobile) */
  grid-template-columns: minmax(0, 1fr) minmax(5rem, 6.5rem) minmax(5.25rem, 7rem);
  width: 100%;
}
.es-address-fields__locality .form-group {
  margin-bottom: 0;
}
@media (min-width: 36rem) {
  .es-address-fields__locality {
    gap: var(--sp-4);
    grid-template-columns: minmax(0, 2fr) minmax(6.25rem, 7.5rem) minmax(7rem, 9rem);
  }
}

.estate-form__grid {
  display: grid;
  gap: var(--sp-4);
  grid-template-columns: 1fr;
}
@media (min-width: 36rem) {
  .estate-form__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .estate-form__field--span-all {
    grid-column: 1 / -1;
  }
}
.estate-form__grid--rep-contact {
  grid-template-columns: 1fr;
}
@media (min-width: 36rem) {
  .estate-form__grid--rep-contact {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
.estate-form__hint {
  display: block;
  margin-top: var(--sp-1);
  font-size: var(--text-xs);
  line-height: 1.4;
  color: var(--n-600);
}
.estate-form__subheading {
  margin: var(--sp-5) 0 var(--sp-2);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--text);
}
.estate-form__sub-lede {
  margin: 0 0 var(--sp-4);
}
.estate-form__input:focus,
.estate-form__textarea:focus {
  outline: 2px solid color-mix(in srgb, var(--primary) 35%, transparent);
  outline-offset: 1px;
}
.estate-form__textarea {
  min-height: 7rem;
  resize: vertical;
}
.estate-form--compact .form-row {
  display: grid;
  gap: var(--sp-4);
  grid-template-columns: 1fr;
}
@media (min-width: 36rem) {
  .estate-form--compact .form-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* Contract configuration (company defaults) */
.estate-contract-configuration-page__head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
}
.estate-contract-configuration-page__head-title {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-xl);
  font-weight: 700;
}
.estate-contract-configuration-page__head-actions {
  flex-shrink: 0;
}
.estate-contract-configuration-page__lede {
  max-width: 44rem;
}
.estate-contract-configuration-page__flash {
  margin-bottom: var(--sp-4);
}
.estate-contract-configuration-page__error-list {
  margin: var(--sp-2) 0 0;
  padding-left: 1.25rem;
}
.estate-contract-configuration-page__tabs {
  flex-wrap: wrap;
  width: 100%;
  box-sizing: border-box;
}
/* Use full width of the dashboard form-panel (tabs + panels); default .config-settings-page__form is ~48rem */
.estate-contract-configuration-page__form.config-settings-page__form {
  max-width: none;
  width: 100%;
}
.estate-contract-configuration-page__tpl-table-wrap {
  overflow-x: auto;
  margin-top: var(--sp-3);
}
.estate-contract-configuration-page__tpl-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}
.estate-contract-configuration-page__tpl-table th,
.estate-contract-configuration-page__tpl-table td {
  padding: var(--sp-2) var(--sp-3);
  border-bottom: 1px solid var(--border);
  text-align: left;
  vertical-align: middle;
}
.estate-contract-configuration-page__tpl-table th {
  font-weight: 600;
  color: var(--n-600);
}
.estate-contract-configuration-page__tpl-actions {
  white-space: nowrap;
  text-align: right;
}
.estate-contract-configuration-page__tpl-delete-form {
  display: inline-block;
  margin-left: var(--sp-2);
  vertical-align: middle;
}
.estate-contract-configuration-page__tpl-add {
  margin-top: var(--sp-4);
}
.estate-contract-configuration-page__tpl-editor-form .estate-contract-template-wysiwyg {
  margin-top: var(--sp-5);
}
.estate-contract-configuration-page__card {
  margin-bottom: var(--sp-6);
}
/* Nested field groups are not direct children of .config-settings-page__form, so they do not get
   the form-level .form-group margin; restore vertical rhythm between controls. */
.estate-contract-configuration-page__card .form-group + .form-group {
  margin-top: var(--sp-5);
}
.estate-contract-configuration-page__card .form-check .form-check-label {
  line-height: 1.5;
}
.estate-contract-configuration-page__h3 {
  margin: var(--sp-6) 0 var(--sp-2);
  font-size: var(--text-base);
  font-weight: 700;
}
.estate-contract-configuration-page__meter {
  height: 8px;
  border-radius: var(--r);
  background: var(--n-200);
  overflow: hidden;
  max-width: 28rem;
  margin-bottom: var(--sp-2);
}
.estate-contract-configuration-page__meter-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--primary), var(--brand));
  border-radius: var(--r);
  transition: width var(--dur-md) var(--ease);
}
.estate-contract-configuration-page__missing-list {
  margin: var(--sp-2) 0 0;
  padding-left: 1.25rem;
}
.estate-contract-configuration-page__missing-list .estate-contract-configuration-page__missing-link {
  color: var(--primary);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.estate-contract-configuration-page__missing-list .estate-contract-configuration-page__missing-link:hover {
  color: var(--brand);
}
.estate-contract-configuration-page__preview-list {
  margin: 0;
  padding-left: 1.25rem;
  max-width: 44rem;
}
/*
 * Aligned field rows: one grid row for all labels, one for controls (2- or 3-column).
 * Avoids misaligned inputs when labels wrap unevenly (replaces nested .form-group columns).
 */
.estate-contract-configuration-page__field-grid {
  display: grid;
  gap: var(--sp-3) var(--sp-4);
  margin-top: var(--sp-5);
  align-items: start;
  min-width: 0;
}
.estate-contract-configuration-page__field-grid > .form-control {
  margin: 0;
  min-width: 0;
}
.estate-contract-configuration-page__card .pro-email-mkt__card-intro + .estate-contract-configuration-page__field-grid {
  margin-top: 0;
}
.estate-contract-configuration-page__field-grid-label {
  margin: 0;
  align-self: start;
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--n-600);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  line-height: 1.35;
}
.estate-contract-configuration-page__field-grid-hint {
  display: block;
  margin: 0;
}
.estate-contract-configuration-page__field-grid + .form-group {
  margin-top: var(--sp-5);
}
@media (min-width: 640px) {
  .estate-contract-configuration-page__field-grid--2 {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    grid-template-rows: auto auto;
    align-items: start;
  }
  .estate-contract-configuration-page__field-grid--2 > :nth-child(1) {
    grid-column: 1;
    grid-row: 1;
  }
  .estate-contract-configuration-page__field-grid--2 > :nth-child(2) {
    grid-column: 1;
    grid-row: 2;
  }
  .estate-contract-configuration-page__field-grid--2 > :nth-child(3) {
    grid-column: 2;
    grid-row: 1;
  }
  .estate-contract-configuration-page__field-grid--2 > :nth-child(4) {
    grid-column: 2;
    grid-row: 2;
  }
  /* Optional helper under left column only (e.g. commission %) */
  .estate-contract-configuration-page__field-grid--2 > :nth-child(5).estate-contract-configuration-page__field-grid-hint {
    grid-column: 1;
    grid-row: 3;
    align-self: start;
  }
  .estate-contract-configuration-page__field-grid--3 {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr);
    grid-template-rows: auto auto;
    align-items: start;
  }
  .estate-contract-configuration-page__field-grid--3 > :nth-child(1) {
    grid-column: 1;
    grid-row: 1;
  }
  .estate-contract-configuration-page__field-grid--3 > :nth-child(2) {
    grid-column: 1;
    grid-row: 2;
  }
  .estate-contract-configuration-page__field-grid--3 > :nth-child(3) {
    grid-column: 2;
    grid-row: 1;
  }
  .estate-contract-configuration-page__field-grid--3 > :nth-child(4) {
    grid-column: 2;
    grid-row: 2;
  }
  .estate-contract-configuration-page__field-grid--3 > :nth-child(5) {
    grid-column: 3;
    grid-row: 1;
  }
  .estate-contract-configuration-page__field-grid--3 > :nth-child(6) {
    grid-column: 3;
    grid-row: 2;
  }
}
.estate-contract-configuration-page__presets {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}
.estate-contract-configuration-page__preset-row {
  padding: var(--sp-4);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--n-50);
}
.estate-contract-configuration-page__table-wrap {
  overflow-x: auto;
  margin-top: var(--sp-3);
}
.estate-contract-configuration-page__fee-table,
.estate-contract-configuration-page__scope-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}
.estate-contract-configuration-page__fee-table th,
.estate-contract-configuration-page__fee-table td,
.estate-contract-configuration-page__scope-table th,
.estate-contract-configuration-page__scope-table td {
  padding: var(--sp-2) var(--sp-3);
  border-bottom: 1px solid var(--border);
  text-align: left;
  vertical-align: middle;
}
.estate-contract-configuration-page__scope-table th[scope="row"] {
  font-weight: 600;
}
.estate-contract-configuration-page__fieldset {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--sp-4);
  margin-bottom: var(--sp-4);
}
.estate-contract-configuration-page__legend {
  padding: 0 var(--sp-2);
  font-weight: 600;
  font-size: var(--text-sm);
}
.estate-contract-configuration-page__footer-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-4);
  margin-top: var(--sp-8);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border);
}
.estate-contract-configuration-page__updated {
  margin: 0;
}
.estate-contract-configuration-page__logo-thumb {
  vertical-align: middle;
  margin-left: var(--sp-2);
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
}

/* Estate contracts list + generate draft */
.estate-contracts-page__toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
}
.estate-contracts-page__lede {
  flex: 1 1 18rem;
  margin: 0;
  max-width: 44rem;
}
.estate-contracts-page__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  flex-shrink: 0;
}

.estate-contract-generate-page__head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sp-4);
  margin-bottom: var(--sp-6);
}
.estate-contract-generate-page__head-main {
  flex: 1 1 20rem;
  min-width: 0;
}
.estate-contract-generate-page__head-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  flex-shrink: 0;
}
.estate-contract-generate-page__context {
  margin-bottom: 0;
}
.estate-contract-generate-page__controls {
  margin-bottom: var(--sp-6);
  border: 1px solid #dbe3f1;
  border-radius: 16px;
  padding: var(--sp-5);
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  box-shadow: 0 8px 24px rgba(15, 23, 43, 0.06);
}
.estate-contract-generate-page__controls-grid {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
}
.estate-contract-generate-page__hero {
  margin-bottom: var(--sp-4);
  border: 1px solid #dbe3f1;
  border-radius: 16px;
  padding: var(--sp-4) var(--sp-5);
  background: linear-gradient(135deg, #eff6ff 0%, #f8fafc 100%);
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-4);
  align-items: center;
  justify-content: space-between;
}
.estate-contract-generate-page__hero-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
}
.estate-contract-generate-page__hero-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  border: 1px solid #dbe3f1;
  border-radius: 999px;
  background: #fff;
  color: #0f172b;
  font-size: var(--text-xs);
  padding: 0.4rem 0.7rem;
}
.estate-contract-generate-page__hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  justify-content: flex-end;
}
@media (min-width: 52rem) {
  .estate-contract-generate-page__controls-grid {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-start;
  }
  .estate-contract-generate-page__controls-grid > .form-group {
    flex: 1 1 20rem;
    min-width: 0;
  }
}
.estate-contract-generate-page__template-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: var(--sp-3);
}
.estate-contract-generate-page__template-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  align-items: center;
}
.estate-contract-generate-page__esign {
  margin-top: var(--sp-4);
}
.estate-contract-generate-page__esign-list {
  margin: 0;
  padding-left: 1.25rem;
  font-size: var(--text-sm);
  color: var(--text);
  line-height: 1.5;
}
.estate-contract-generate-page__esign-list li {
  margin-bottom: var(--sp-1);
}
.estate-contract-generate-page__preview-layout {
  display: grid;
  gap: var(--sp-6);
  align-items: start;
}
@media (min-width: 60rem) {
  .estate-contract-generate-page__preview-layout {
    grid-template-columns: minmax(0, 1fr) minmax(12.5rem, 17.5rem);
  }
}
.estate-contract-generate-page__vars-rail {
  min-width: 0;
}
.estate-contract-generate-page__vars-rail-inner {
  position: sticky;
  top: var(--sp-4);
  max-height: calc(100vh - 2rem);
  overflow-y: auto;
  padding: var(--sp-4);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
  box-sizing: border-box;
}
.estate-contract-generate-page__preview {
  border: 1px solid #dbe3f1;
  border-radius: 16px;
  padding: var(--sp-5);
  background: #fff;
  box-shadow: 0 8px 24px rgba(15, 23, 43, 0.05);
}
.estate-contract-generate-modal[hidden] {
  display: none;
}
.estate-contract-generate-modal {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-4);
}
.estate-contract-generate-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 43, 0.55);
}
.estate-contract-generate-modal__dialog {
  position: relative;
  width: min(100%, 30rem);
  border-radius: 14px;
  border: 1px solid #dbe3f1;
  background: #fff;
  box-shadow: 0 24px 60px rgba(15, 23, 43, 0.3);
  padding: var(--sp-5);
}
.estate-contract-generate-modal__dialog h2 {
  margin: 0 0 var(--sp-2);
}
.estate-contract-generate-modal__close {
  position: absolute;
  top: var(--sp-3);
  right: var(--sp-3);
  border: 0;
  background: transparent;
  color: #475569;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
}
.estate-contract-generate-modal__form {
  margin-top: var(--sp-4);
}
.estate-contract-generate-modal__actions {
  margin-top: var(--sp-4);
  display: flex;
  gap: var(--sp-2);
  justify-content: flex-end;
}
body.is-modal-open {
  overflow: hidden;
}
.estate-contract-tpl-editor-layout {
  display: grid;
  gap: var(--sp-6);
  align-items: start;
  margin-top: var(--sp-5);
}
.estate-contract-tpl-editor-layout__main {
  min-width: 0;
}
.estate-contract-tpl-editor-layout__body-heading {
  margin: 0 0 var(--sp-3);
  font-size: var(--text-base);
  font-weight: 700;
}
@media (min-width: 56.25rem) {
  .estate-contract-tpl-editor-layout {
    grid-template-columns: minmax(0, 1fr) minmax(12.5rem, 17.5rem);
  }
}
.estate-contract-tpl-vars-rail {
  min-width: 0;
  align-self: stretch;
}
.estate-contract-tpl-vars-rail__inner {
  position: sticky;
  top: var(--sp-4);
  max-height: calc(100vh - 2rem);
  overflow-y: auto;
  padding: var(--sp-4);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
  box-sizing: border-box;
}
.contract-var-rail__title {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-sm);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--n-600);
}
.contract-var-rail__hint {
  margin: 0 0 var(--sp-4);
}
.contract-var-rail__hint code {
  font-size: 0.9em;
}
.contract-var-rail__group {
  margin-bottom: var(--sp-4);
}
.contract-var-rail__group:last-child {
  margin-bottom: 0;
}
.contract-var-rail__group-title {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--n-600);
}
.contract-var-rail__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
}
.contract-var-rail__tag {
  font-size: var(--text-xs) !important;
  white-space: normal;
  text-align: left;
  line-height: 1.3;
  justify-content: flex-start;
}
.estate-contract-generate-page__preview {
  padding: var(--sp-8);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
  max-width: none;
  width: 100%;
  box-sizing: border-box;
}
.estate-contract-generate-page__preview-header {
  margin-bottom: var(--sp-6);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--border);
}
.estate-contract-generate-page__preview-title {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--primary);
}
.estate-contract-generate-page__preview-sub {
  margin: 0;
}
.estate-contract-generate-page__preview-h3 {
  margin: var(--sp-5) 0 var(--sp-2);
  font-size: var(--text-sm);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--n-600);
}
.estate-contract-generate-page__preview-party p {
  margin: 0 0 var(--sp-2);
}
.estate-contract-generate-page__preview-summary .estate-contract-configuration-page__preview-list {
  margin-top: var(--sp-2);
}
.estate-contract-generate-page__preview-foot {
  margin: var(--sp-6) 0 0;
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border);
}
.estate-contract-generate-page__doc-meta {
  margin-bottom: var(--sp-4);
}
.estate-contract-generate-page__document {
  font-size: var(--text-sm);
  line-height: 1.55;
  color: var(--text);
  max-width: none;
}
.estate-contract-template-edit-page__insert-card {
  margin-bottom: var(--sp-4);
}
.estate-contract-template-edit-page__tag-section {
  margin-bottom: var(--sp-5);
}
.estate-contract-template-edit-page__tag-section:last-child {
  margin-bottom: 0;
}
.estate-contract-template-edit-page__tag-group-title {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--n-600);
}
.estate-contract-template-edit-page__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
}
.estate-contract-template-edit-page__tag {
  font-size: var(--text-xs) !important;
  white-space: normal;
  text-align: left;
  line-height: 1.3;
}
.estate-contract-template-edit-page__body {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: var(--text-sm);
  line-height: 1.45;
}
.estate-contract-template-edit-page__actions {
  margin-top: var(--sp-4);
}
.estate-contract-generate-page__document h1 {
  margin: 0 0 var(--sp-4);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--primary);
}
.estate-contract-generate-page__document h2 {
  margin: var(--sp-6) 0 var(--sp-3);
  font-size: var(--text-lg);
  font-weight: 700;
  border-bottom: 1px solid var(--border);
  padding-bottom: var(--sp-2);
}
.estate-contract-generate-page__document h3 {
  margin: var(--sp-5) 0 var(--sp-2);
  font-size: var(--text-base);
  font-weight: 700;
}

/* Markdown ### 4.1 … becomes h3; extra space above #.# subsections. */
.estate-contract-generate-page__document h3.estate-contract-doc-numbered-clause {
  margin-top: max(1.75em, var(--sp-6));
  margin-bottom: var(--sp-2);
}
.estate-contract-generate-page__document > h3.estate-contract-doc-numbered-clause:first-child,
.estate-contract-generate-page__document > div:first-child > h3.estate-contract-doc-numbered-clause:first-child {
  margin-top: 0;
}
.estate-contract-generate-page__document p {
  margin: 0 0 var(--sp-3);
}
.estate-contract-generate-page__document ul {
  margin: 0 0 var(--sp-3);
  padding-left: 1.35rem;
}
.estate-contract-generate-page__document li {
  margin-bottom: var(--sp-1);
}
.estate-contract-generate-page__document hr {
  border: none;
  border-top: 1px solid var(--border);
  margin: var(--sp-6) 0;
}

.estate-contract-generate-page__document p.estate-contract-doc-party-gap {
  margin: 0;
  padding: 0;
  height: 1.1em;
  line-height: 1.1em;
  overflow: hidden;
}

.estate-contract-generate-page__document p.estate-contract-doc-numbered-clause {
  margin-top: 1.25em;
}
.estate-contract-generate-page__document > p.estate-contract-doc-numbered-clause:first-child,
.estate-contract-generate-page__document > div:first-child > p.estate-contract-doc-numbered-clause:first-child {
  margin-top: 0;
}

.estate-contract-generate-page__document h1.estate-contract-doc-numbered-clause,
.estate-contract-generate-page__document h2.estate-contract-doc-numbered-clause {
  margin-top: max(1.5em, var(--sp-5));
}
.estate-contract-generate-page__document > h1.estate-contract-doc-numbered-clause:first-child,
.estate-contract-generate-page__document > div:first-child > h1.estate-contract-doc-numbered-clause:first-child,
.estate-contract-generate-page__document > h2.estate-contract-doc-numbered-clause:first-child,
.estate-contract-generate-page__document > div:first-child > h2.estate-contract-doc-numbered-clause:first-child {
  margin-top: 0;
}

/* ===== Shopper Item Search Alerts – Redesigned UI (isa- prefix) =========== */

/* ---- Page container ---- */
.shopper-item-search-page.form-panel {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

/* ---- Create form (content lives in .form-panel, not a nested card) ---- */
.shopper-item-search-page__create-form {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
  margin: 0;
  padding: 0;
  border: none;
  background: transparent;
}

/* ---- Address field (inside map block) ---- */
.isa-address-section {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.isa-address-label {
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--n-600);
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

/* ---- Search Radius section ---- */
.isa-radius-section {
  background: #eff6ff;
  border: 1px solid #dbeafe;
  border-radius: 10px;
  padding: var(--sp-4) var(--sp-5);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.isa-radius-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.isa-radius-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: #364153;
  letter-spacing: -0.015em;
}

.isa-radius-value {
  font-size: var(--text-sm);
  font-weight: 600;
  color: #030213;
  letter-spacing: -0.015em;
}

.isa-radius-hint {
  font-size: var(--text-xs);
  color: #4a5565;
  margin: 0;
  line-height: 1.4;
}

/* ---- Advanced Filters accordion ---- */
.isa-advanced-filters {
  border-radius: var(--r-sm);
}

.isa-advanced-filters-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  list-style: none;
  padding: var(--sp-2) var(--sp-1);
  font-size: var(--text-base);
  font-weight: 500;
  color: #0a0a0a;
  user-select: none;
  border-radius: var(--r-sm);
  transition: background var(--dur-sm) var(--ease);
}

.isa-advanced-filters-summary::-webkit-details-marker { display: none; }
.isa-advanced-filters-summary::marker { display: none; }

.isa-advanced-filters-summary:hover {
  background: var(--n-50);
}

.isa-af-chevron {
  color: var(--text-muted);
  transition: transform 0.2s var(--ease);
  flex-shrink: 0;
  display: inline-flex;
}

.isa-advanced-filters[open] .isa-af-chevron {
  transform: rotate(180deg);
}

.isa-advanced-filters-content {
  padding-top: var(--sp-4);
}

/* ---- Notification Preferences card ---- */
.isa-notif-card {
  background: linear-gradient(135deg, #eff6ff 0%, #eef2ff 100%);
  border: 1px solid #bedbff;
  border-radius: 14px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.10), 0 4px 6px rgba(0, 0, 0, 0.10);
  padding: var(--sp-5) var(--sp-6);
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}

.isa-notif-title {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  font-size: var(--text-lg);
  font-weight: 500;
  color: #0a0a0a;
  margin: 0;
  letter-spacing: -0.03em;
}

.isa-notif-title-icon {
  color: var(--brand);
  flex-shrink: 0;
}

.isa-notif-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
}

.isa-notif-row-left {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  min-width: 0;
}

.isa-notif-icon {
  color: var(--brand);
  flex-shrink: 0;
}

.isa-notif-label-group {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.isa-notif-label-title {
  font-size: var(--text-base);
  font-weight: 500;
  color: #0a0a0a;
  letter-spacing: -0.02em;
  white-space: nowrap;
}

.isa-notif-label-sub {
  font-size: var(--text-sm);
  font-weight: 400;
  color: #4a5565;
  letter-spacing: -0.01em;
}

/* Toggle switch */
.isa-toggle {
  position: relative;
  display: inline-block;
  width: 44px;
  height: 24px;
  flex-shrink: 0;
}

.isa-toggle input[type="checkbox"] {
  opacity: 0;
  width: 0;
  height: 0;
  position: absolute;
  pointer-events: none;
}

.isa-toggle__slider {
  position: absolute;
  inset: 0;
  border-radius: 9999px;
  background: #d1d5dc;
  cursor: pointer;
  transition: background 0.2s var(--ease);
}

.isa-toggle__slider::before {
  content: '';
  position: absolute;
  height: 18px;
  width: 18px;
  left: 3px;
  bottom: 3px;
  border-radius: 50%;
  background: var(--white);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.10), 0 1px 3px rgba(0, 0, 0, 0.10);
  transition: transform 0.2s var(--ease);
}

.isa-toggle input[type="checkbox"]:checked + .isa-toggle__slider {
  background: #030213;
}

.isa-toggle input[type="checkbox"]:checked + .isa-toggle__slider::before {
  transform: translateX(20px);
}

.isa-toggle input[type="checkbox"]:focus-visible + .isa-toggle__slider {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

.isa-toggle--disabled .isa-toggle__slider {
  opacity: 0.45;
  cursor: not-allowed;
}

/* Notification frequency */
.isa-notif-freq {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.isa-notif-freq-label {
  font-size: var(--text-base);
  font-weight: 500;
  color: #0a0a0a;
  letter-spacing: -0.02em;
}

/* ---- Save button ---- */
.isa-save-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  width: 100%;
  height: 3rem;
  background: var(--brand);
  color: var(--white);
  border: none;
  border-radius: 8px;
  font-size: var(--text-base);
  font-weight: 500;
  cursor: pointer;
  letter-spacing: -0.02em;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.10), 0 10px 15px rgba(0, 0, 0, 0.10);
  transition: background var(--dur-sm) var(--ease), box-shadow var(--dur-sm) var(--ease);
}

.isa-save-btn:hover {
  background: var(--brand-hover);
}

.isa-save-btn svg {
  display: inline-block;
  flex-shrink: 0;
  vertical-align: middle;
}

/* ---- Saved searches section ---- */
.isa-saved-section {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}

.isa-saved-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
}

.isa-saved-heading {
  font-size: var(--text-xl);
  font-weight: 600;
  color: #1e2939;
  letter-spacing: -0.03em;
  margin: 0;
}

.isa-saved-count {
  font-size: var(--text-xs);
  font-weight: 500;
  color: #030213;
  white-space: nowrap;
}

.isa-saved-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  margin: 0;
  padding: 0;
}

@supports (gap: 1lh) {
  .isa-saved-list {
    gap: 1lh;
  }
}

/* ---- Saved search card ---- */
.isa-saved-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05), 0 1px 2px rgba(0, 0, 0, 0.04);
  overflow: hidden;
  transition: box-shadow var(--dur-sm) var(--ease), border-color var(--dur-sm) var(--ease);
}

.isa-saved-card:hover {
  border-color: var(--n-300);
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.07), 0 2px 4px rgba(0, 0, 0, 0.05);
}

.isa-saved-card--paused {
  opacity: 0.92;
}

.isa-saved-card--paused .isa-saved-card-summary__title {
  color: var(--n-600);
}

.isa-saved-card-details {
  margin: 0;
}

.isa-saved-card-summary {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-2);
  padding: var(--sp-5);
  margin: 0;
  cursor: pointer;
  list-style: none;
  user-select: none;
}

.isa-saved-card-summary::-webkit-details-marker,
.isa-saved-card-summary::marker {
  display: none;
}

.isa-saved-card-summary:focus {
  outline: none;
}

.isa-saved-card-summary:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}

.isa-saved-card-summary__chev {
  flex-shrink: 0;
  width: 1.35rem;
  height: 1.35rem;
  margin-top: 0.12rem;
  border-radius: var(--r-sm);
  background: var(--n-100);
  position: relative;
}

.isa-saved-card-summary__chev::after {
  content: '';
  position: absolute;
  inset: 0;
  margin: auto;
  width: 0.38rem;
  height: 0.38rem;
  border-right: 2px solid var(--text-muted);
  border-bottom: 2px solid var(--text-muted);
  transform: rotate(-45deg);
}

.isa-saved-card-details[open] .isa-saved-card-summary__chev::after {
  transform: rotate(45deg);
}

.isa-saved-card-summary__text {
  flex: 1;
  min-width: 0;
}

.isa-saved-card-summary__title {
  font-size: var(--text-sm);
  font-weight: 600;
  line-height: 1.35;
  word-break: break-word;
}

.isa-saved-card-summary__meta {
  margin-top: var(--sp-1);
  line-height: 1.45;
}

.isa-saved-card-actions--summary {
  flex-shrink: 0;
}

.isa-saved-card-details__inner {
  border-top: 1px solid var(--border);
}

.isa-saved-card-view {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: var(--sp-4);
  padding: var(--sp-5);
}

.isa-saved-card-info {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
  min-width: 0;
  flex: 1;
}

.isa-saved-card-address {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-2);
  font-size: var(--text-base);
  font-weight: 500;
  color: #101828;
  letter-spacing: -0.02em;
  line-height: 1.4;
}

.isa-saved-card-address-icon {
  color: var(--brand);
  flex-shrink: 0;
  margin-top: 2px;
}

.isa-saved-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  padding-left: calc(16px + var(--sp-2));
}

.isa-saved-card-tag {
  display: inline-block;
  font-size: var(--text-xs);
  font-weight: 500;
  color: #0a0a0a;
  border: 1px solid var(--border);
  border-radius: var(--r-xs);
  padding: 0.15rem var(--sp-2);
  background: var(--white);
  white-space: nowrap;
}

.isa-saved-card-footer {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  flex-wrap: wrap;
  padding-left: calc(16px + var(--sp-2));
}

.isa-saved-card-last-alert {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--text-xs);
  font-weight: 400;
  color: #4a5565;
  letter-spacing: -0.01em;
}

.isa-saved-card-last-alert-icon {
  color: #717182;
  flex-shrink: 0;
}

.isa-saved-card-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.1rem 0.5rem;
  border-radius: var(--r-full);
  font-size: var(--text-xs);
  font-weight: 500;
  background: var(--green-bg);
  color: #016630;
  border: 1px solid var(--green-border);
}

/* Card action buttons */
.isa-saved-card-actions {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  flex-shrink: 0;
}

.isa-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: var(--r-sm);
  border: none;
  background: transparent;
  color: var(--n-500);
  cursor: pointer;
  padding: 0;
  transition: background var(--dur-sm) var(--ease), color var(--dur-sm) var(--ease);
}

.isa-action-btn svg { display: block; }

.isa-action-btn:hover {
  background: var(--n-100);
  color: var(--primary);
}

.isa-action-btn--danger { color: var(--red); }
.isa-action-btn--danger:hover { background: var(--red-bg); color: var(--red); }

.isa-action-btn--muted {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}

/* Edit form inline */
.isa-saved-card-edit {
  border-top: 1px solid var(--border);
  padding: var(--sp-5);
  background: var(--n-50);
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}

.isa-saved-card-edit-footer {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding-top: var(--sp-4);
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
}

/* ---- Responsive ---- */
@media (max-width: 600px) {
  .shopper-item-search-page__create-form {
    gap: var(--sp-4);
  }
  .isa-notif-card {
    padding: var(--sp-4);
  }
  .isa-saved-card-summary {
    flex-wrap: wrap;
    row-gap: var(--sp-2);
  }
  .isa-saved-card-actions--summary {
    flex: 1 1 100%;
    justify-content: flex-end;
  }
  .isa-saved-card-view {
    flex-direction: column;
    gap: var(--sp-3);
  }
  .isa-saved-card-actions {
    align-self: flex-end;
  }
  .isa-saved-card-tags,
  .isa-saved-card-footer {
    padding-left: 0;
  }
}
@media print {
  .estate-contract-generate-page__no-print {
    display: none !important;
  }
  .estate-contract-generate-page {
    box-shadow: none !important;
    border: none !important;
  }
  .estate-contract-generate-page__preview {
    border: none;
    max-width: none;
    padding: 0;
  }
}

/* Private / pro sale wizard — step 3 analysis */
.pl-wizard-analysis {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}
.pl-wizard-analysis__shuffle {
  transition: opacity 0.45s ease, transform 0.45s ease;
  opacity: 1;
  background: #fff;
  padding: var(--sp-5) var(--sp-4);
  border-radius: var(--r-xl, 12px);
  border: 1px solid var(--border, #e8e8e8);
  overflow: hidden;
}
.pl-wizard-analysis-shuffle--hide {
  opacity: 0;
  transform: scale(0.98);
  pointer-events: none;
  max-height: 0;
  margin: 0;
  padding: 0;
  overflow: hidden;
  transition: opacity 0.5s ease, max-height 0.5s ease, margin 0.5s ease, padding 0.5s ease;
}

/* Step 3 analysis: 3D slideshow (scoped to wizard panel only). */
.pl-wizard-analysis__shuffle #slideshow,
.pl-wizard-analysis__shuffle .js-pl-analysis-slideshow {
  margin: 0 auto;
  padding: var(--sp-4, 1rem) var(--sp-2, 0.5rem);
  width: 100%;
  height: auto;
  min-height: 0;
  background-color: var(--white, #fff);
  box-sizing: border-box;
  overflow: hidden;
}
.pl-wizard-analysis__shuffle .entire-content {
  margin: 0 auto;
  width: 190px;
  perspective: 1000px;
  position: relative;
  padding-top: var(--sp-4, 1rem);
  padding-bottom: var(--sp-3, 0.75rem);
  /* Figures are 120px; ring uses translateZ(300px) — keep enough vertical room without the old 600px box. */
  min-height: 260px;
}
.pl-wizard-analysis__shuffle .entire-content:has(.content-carrousel.is-single) {
  min-height: 0;
  padding-top: var(--sp-2, 0.5rem);
  padding-bottom: var(--sp-2, 0.5rem);
}
.pl-wizard-analysis__shuffle .content-carrousel {
  width: 100%;
  position: absolute;
  float: right;
  animation: rotar 15s infinite linear;
  transform-style: preserve-3d;
}
.pl-wizard-analysis__shuffle .content-carrousel:hover {
  animation-play-state: paused;
  cursor: pointer;
}
.pl-wizard-analysis__shuffle .content-carrousel figure {
  width: 100%;
  height: 120px;
  border: 1px solid #3b444b;
  overflow: hidden;
  position: absolute;
  transform: rotateY(var(--slide-angle, 0deg)) translateZ(300px);
}
.pl-wizard-analysis__shuffle .shadow {
  position: absolute;
  box-shadow: 0 0 20px 0 #000;
  border-radius: 1px;
}
.pl-wizard-analysis__shuffle .content-carrousel img {
  image-rendering: auto;
  transition: all 300ms;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.pl-wizard-analysis__shuffle .content-carrousel img:hover {
  transform: scale(1.2);
  transition: all 300ms;
}
.pl-wizard-analysis__shuffle .content-carrousel.is-paused {
  animation-play-state: paused !important;
}
.pl-wizard-analysis__shuffle .content-carrousel.is-single {
  position: relative;
  float: none;
  animation: none !important;
  min-height: 120px;
}
.pl-wizard-analysis__shuffle .content-carrousel.is-single figure {
  transform: rotateY(0deg) translateZ(0);
  position: relative;
}

@keyframes rotar {
  from {
    transform: rotateY(0deg);
  }
  to {
    transform: rotateY(360deg);
  }
}

@media (prefers-reduced-motion: reduce) {
  .pl-wizard-analysis__shuffle .content-carrousel {
    animation: none !important;
  }
}

.pl-wizard-analysis-shuffle__status {
  text-align: center;
  margin-top: var(--sp-4);
  color: var(--n-600, #555);
  min-height: 1.4em;
}
.pl-wizard-analysis__results {
  transition: opacity 0.4s ease;
}
.pl-wizard-analysis__results[hidden] {
  display: none;
}
.pl-wizard-analysis__results-title {
  font-size: 1.1rem;
  font-weight: 600;
  margin: 0 0 var(--sp-4);
}
.pl-wizard-analysis__deep-research {
  flex: 0 0 auto;
}
.pl-wizard-analysis__deep-research .btn--secondary {
  font-size: 0.9rem;
  white-space: nowrap;
}
.pl-wizard-analysis__results-head {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--sp-3);
  margin: 0 0 var(--sp-4);
}
.pl-wizard-analysis__results-head .pl-wizard-analysis__results-title {
  margin: 0;
}
.pl-wizard-analysis__focus-hint {
  margin: 0 0 var(--sp-3);
  color: var(--text-muted);
}
/* Post-sale / PL wizard: Deep Research confirm — align with pl-mp-dialog + pro-dashboard modals */
.pl-wizard-deep-research-dialog {
  position: fixed;
  inset: 0;
  width: min(28rem, calc(100vw - 1.5rem));
  max-width: min(28rem, calc(100vw - 1.5rem));
  max-height: min(90vh, 36rem);
  height: fit-content;
  margin: auto;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface, var(--white));
  box-shadow: var(--shadow-lg);
  color: var(--n-800);
  overflow: hidden;
  box-sizing: border-box;
}
.pl-wizard-deep-research-dialog::backdrop {
  background: rgba(15, 23, 42, 0.45);
}
.pl-wizard-deep-research-dialog__inner {
  display: flex;
  flex-direction: column;
  min-height: 0;
  max-height: min(90vh, 36rem);
}
.pl-wizard-deep-research-dialog__header {
  flex-shrink: 0;
  padding: var(--sp-5) var(--sp-5) var(--sp-4);
  border-bottom: 1px solid var(--border);
  background: var(--n-50);
}
.pl-wizard-deep-research-dialog__title {
  margin: 0;
  font-size: var(--text-xl);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: var(--primary);
}
.pl-wizard-deep-research-dialog__subtitle {
  margin: var(--sp-2) 0 0;
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--text-muted);
  font-weight: 500;
}
.pl-wizard-deep-research-dialog__body {
  flex: 1;
  min-height: 0;
  padding: var(--sp-5);
  overflow-y: auto;
}
.pl-wizard-deep-research-dialog__callout {
  margin: 0;
  padding: var(--sp-4);
  border-radius: var(--r);
  background: var(--amber-bg, #fffbeb);
  border: 1px solid color-mix(in srgb, var(--amber) 35%, var(--n-200));
  border-left: 0.25rem solid var(--amber, #f59e0b);
  box-shadow: var(--shadow-xs);
}
.pl-wizard-deep-research-dialog__callout-kicker {
  margin: 0 0 var(--sp-2);
  font-size: var(--text-xs);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--n-600);
}
.pl-wizard-deep-research-dialog__callout-text {
  margin: 0;
  font-size: var(--text-sm);
  line-height: 1.55;
  color: var(--n-800, #1f2937);
}
.pl-wizard-deep-research-dialog__footer {
  flex-shrink: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5) var(--sp-5);
  border-top: 1px solid var(--border);
  background: var(--white);
}
.pl-wizard-analysis__leave-hint {
  margin: var(--sp-3) 0 var(--sp-4);
  max-width: 42rem;
  line-height: 1.45;
  color: var(--n-600, #555);
}
.es-photo-ai-complete-dialog {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  margin: 0;
  border: 1px solid var(--border);
  border-radius: var(--radius, 8px);
  padding: 0;
  width: min(28rem, calc(100vw - 2rem));
  max-width: 28rem;
  max-height: 90vh;
  overflow: auto;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12);
}
.es-photo-ai-complete-dialog::backdrop {
  background: rgba(0, 0, 0, 0.45);
}
.es-photo-ai-complete-dialog__inner {
  padding: var(--sp-5) var(--sp-5) var(--sp-4);
}
.es-photo-ai-complete-dialog__title {
  margin: 0 0 var(--sp-3);
  font-size: 1.15rem;
  font-weight: 600;
}
.es-photo-ai-complete-dialog__body {
  margin: 0 0 var(--sp-5);
  line-height: 1.5;
  color: var(--n-700, #333);
}
.es-photo-ai-complete-dialog__footer {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-3);
}
.pl-wizard-analysis__inventory-stack {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--sp-1, 0.25rem);
  min-width: 0;
}
.pl-wizard-analysis__inventory-value {
  margin: 0;
  text-align: right;
  color: #2f8f46;
  font-weight: 600;
  white-space: nowrap;
  /* ~40% smaller than the surrounding step / body scale */
  font-size: 0.6em;
}
.pl-wizard-analysis__inventory-value strong {
  color: #1f7a35;
  font-weight: 700;
}
@media (max-width: 720px) {
  .pl-wizard-analysis__results-head {
    flex-direction: column;
    align-items: flex-start;
  }
  .pl-wizard-analysis__inventory-stack {
    align-items: flex-start;
  }
  .pl-wizard-analysis__inventory-value {
    text-align: left;
    white-space: normal;
  }
}
.pl-wizard-analysis-card {
  /* Visual shell matches .pro-mp-card--ai (marketplace); keep hooks for crop, slider, MP toggle */
  position: relative;
  min-width: 0;
}
.pl-wizard-analysis-card__media {
  flex: 0 0 auto;
  padding: 0;
  position: relative;
}
.pl-wizard-analysis-card__media:not(.pro-mp-card__media--isolated) {
  background: var(--n-50, #fafafa);
}
.pl-wizard-analysis-card__reset {
  position: absolute;
  top: var(--sp-2);
  left: var(--sp-2);
  z-index: 4;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.2rem;
  margin: 0;
  border: 0;
  background: transparent;
  color: #fff;
  cursor: pointer;
  line-height: 0;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.65));
}
.pl-wizard-analysis-card__reset:hover {
  opacity: 0.9;
}
.pl-wizard-analysis-card__reset:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.95);
  outline-offset: 2px;
}
.pl-wizard-analysis-card__reset svg {
  display: block;
}
.pl-wizard-analysis-card__mp-toggle {
  position: absolute;
  top: var(--sp-2);
  right: var(--sp-2);
  z-index: 4;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.75rem;
  height: 1.75rem;
  padding: 0;
  margin: 0;
  border: 0;
  border-radius: 50%;
  cursor: pointer;
  line-height: 0;
  flex-shrink: 0;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
}
.pl-wizard-analysis-card__mp-toggle.is-included {
  background: #16a34a;
}
.pl-wizard-analysis-card__mp-toggle.is-excluded {
  background: #dc2626;
}
.pl-wizard-analysis-card__mp-toggle:hover {
  filter: brightness(1.06);
}
.pl-wizard-analysis-card__mp-toggle:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.95);
  outline-offset: 2px;
}
.pl-wizard-analysis-card__mp-toggle svg {
  display: block;
}
.pl-wizard-analysis-card--mp-excluded::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 2;
  border-radius: inherit;
  background: rgba(120, 120, 120, 0.22);
  pointer-events: none;
}
.pl-wizard-analysis-card--mp-excluded .pl-wizard-analysis-card__title,
.pl-wizard-analysis-card--mp-excluded .pro-mp-card__title,
.pl-wizard-analysis-card--mp-excluded .pl-wizard-analysis-card__desc,
.pl-wizard-analysis-card--mp-excluded .pro-mp-card__desc,
.pl-wizard-analysis-card--mp-excluded .pl-wizard-analysis-card__price {
  color: var(--n-600, #666);
}
.pl-wizard-analysis-card--mp-excluded .pro-mp-ai-icon {
  opacity: 0.5;
}
/* Full-width crop canvas in each grid cell (override marketplace modal’s 220px cap). */
.pl-wizard-analysis-card__crop.pl-mp-item__crop-frame {
  margin: 0;
  width: 100%;
  max-width: none;
  aspect-ratio: 4 / 3;
}
.pl-wizard-analysis-card__media .pl-mp-item__placeholder,
.pl-wizard-analysis-card__media .pro-mp-card__placeholder {
  width: 100%;
  max-width: none;
}
/* Body uses .pro-mp-card__body (marketplace) + wizard hooks */
.pl-wizard-analysis-card__body.pro-mp-card__body {
  padding: var(--sp-4);
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.pl-wizard-analysis-card__title {
  margin: 0;
  font-size: var(--text-base, 1rem);
  font-weight: 700;
  color: var(--primary);
  line-height: 1.35;
}
.pl-wizard-analysis-card__desc {
  margin: 0;
  line-height: 1.45;
  flex: 1 1 auto;
}
.pl-wizard-analysis-card__price {
  margin: 0;
  font-size: var(--text-sm, 0.95rem);
  color: var(--n-700, #444);
}
.pl-wizard-analysis-card__price strong {
  color: var(--primary);
  font-weight: 700;
}
.pl-wizard-analysis-card__pricing-slider {
  margin-top: var(--sp-2);
  padding: var(--sp-3);
  border: none;
  border-radius: 14px;
  background: transparent;
  box-shadow: none;
}
.pl-wizard-analysis-card__price-current {
  margin: 0 0 var(--sp-2);
  font-size: 1.35rem;
  line-height: 1.2;
  font-weight: 800;
  color: #1f7a35;
  text-align: center;
  background: transparent;
  border: none;
  box-shadow: none;
}
/* contenteditable price: same typography as .pl-wizard-analysis-card__price-current */
.pl-wizard-analysis-card__price-current .pl-wizard-analysis-card__price-edit {
  display: inline-block;
  min-width: 0.3em;
  max-width: 100%;
  border: 0;
  outline: 0;
  box-shadow: none;
  -webkit-tap-highlight-color: transparent;
  color: inherit;
  font: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  text-align: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  vertical-align: baseline;
  border-radius: 0;
  caret-color: currentColor;
  -webkit-user-select: text;
  user-select: text;
}
.pl-wizard-analysis-card__price-current .pl-wizard-analysis-card__price-edit:focus,
.pl-wizard-analysis-card__price-current .pl-wizard-analysis-card__price-edit:focus-visible,
.pl-wizard-analysis-card__price-current .pl-wizard-analysis-card__price-edit:focus-within {
  outline: 0;
  box-shadow: none;
  border: 0;
  background: transparent;
}
.pl-wizard-analysis-card__price-range {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 1.5rem;
  max-height: 1.5rem;
  padding: 0;
  background: transparent;
  margin: 0;
  cursor: pointer;
  border: none;
  box-shadow: none;
  outline: none;
  color: inherit;
}
.pl-wizard-analysis-card__price-range::-webkit-slider-runnable-track {
  height: 0.45rem;
  border: none;
  border-radius: 999px;
  background: linear-gradient(90deg, #89b8ff 0%, #6bcf8d 50%, #f7c86b 100%);
}
.pl-wizard-analysis-card__price-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 1rem;
  height: 1rem;
  margin-top: -0.27rem;
  border-radius: 50%;
  border: none;
  background: #126e2f;
  box-shadow: 0 2px 8px rgba(16, 41, 23, 0.25);
}
.pl-wizard-analysis-card__price-range::-moz-range-track {
  height: 0.45rem;
  border: none;
  border-radius: 999px;
  background: linear-gradient(90deg, #89b8ff 0%, #6bcf8d 50%, #f7c86b 100%);
}
.pl-wizard-analysis-card__price-range::-moz-range-thumb {
  width: 1rem;
  height: 1rem;
  border-radius: 50%;
  border: none;
  background: #126e2f;
  box-shadow: 0 2px 8px rgba(16, 41, 23, 0.25);
}
.pl-wizard-analysis-card__price-range:focus,
.pl-wizard-analysis-card__price-range:focus-visible {
  outline: none;
  box-shadow: none;
}
.pl-wizard-analysis-card__price-labels {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--sp-2);
  margin-top: var(--sp-2);
}
.pl-wizard-analysis-card__price-label {
  cursor: pointer;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.15rem;
  font-size: 0.78rem;
  font-weight: 600;
  color: #5a6660;
  text-align: center;
}
.pl-wizard-analysis-card__price-label.is-active {
  color: #113e1f;
}
.pl-wizard-analysis-card__price-label[data-tier="recommended"] .pl-wizard-analysis-card__price-glyph {
  color: #e34b5f;
}
.pl-wizard-analysis-card__price-label[data-tier="quick"] .pl-wizard-analysis-card__price-glyph {
  color: #f7c948;
}
.pl-wizard-analysis-card__price-label[data-tier="premium"] .pl-wizard-analysis-card__price-glyph {
  color: #78bfff;
}
.pl-wizard-analysis-card__price-glyph {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.pl-wizard-analysis-card__price-glyph svg {
  width: 19px;
  height: 19px;
  stroke-width: 2.2;
}
.pl-wizard-analysis-card__tier-price {
  display: block;
  font-size: 0.68rem;
  line-height: 1.2;
  color: var(--n-600, #66736d);
  font-weight: 600;
}
.pl-wizard-analysis-card__media-overlay {
  position: absolute;
  left: var(--sp-3);
  right: var(--sp-3);
  bottom: var(--sp-3);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  pointer-events: auto;
  background: transparent;
  z-index: 3;
}
.pl-wizard-analysis-card__zoom-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  color: #fff;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.65));
  pointer-events: none;
}
.pl-wizard-analysis-card__zoom {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 1.5rem;
  background: transparent;
  background-color: transparent !important;
  border: 0 !important;
  border-radius: 0;
  padding: 0;
  box-shadow: none !important;
  pointer-events: auto;
  cursor: pointer;
  filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.5));
}
.pl-wizard-analysis-card__zoom::-webkit-slider-container {
  background: transparent;
}
.pl-wizard-analysis-card__zoom:focus-visible {
  outline: 2px solid rgba(128, 222, 167, 0.95);
  outline-offset: 3px;
}
.pl-wizard-analysis-card__zoom::-webkit-slider-runnable-track {
  height: 0.45rem;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(174, 220, 196, 0.92) 0%, rgba(104, 201, 145, 0.95) 100%);
  border: 1px solid rgba(255, 255, 255, 0.82);
  box-shadow: 0 2px 8px rgba(15, 26, 21, 0.25);
}
.pl-wizard-analysis-card__zoom::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 1rem;
  height: 1rem;
  margin-top: -0.32rem;
  border-radius: 50%;
  border: 2px solid #fff;
  background: linear-gradient(180deg, #2a8a58 0%, #1a6f42 100%);
  box-shadow: 0 2px 10px rgba(8, 19, 14, 0.42);
}
.pl-wizard-analysis-card__zoom::-moz-range-track {
  height: 0.45rem;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(174, 220, 196, 0.92) 0%, rgba(104, 201, 145, 0.95) 100%);
  border: 1px solid rgba(255, 255, 255, 0.82);
  box-shadow: 0 2px 8px rgba(15, 26, 21, 0.25);
}
.pl-wizard-analysis-card__zoom::-moz-range-thumb {
  width: 1rem;
  height: 1rem;
  border-radius: 50%;
  border: 2px solid #fff;
  background: linear-gradient(180deg, #2a8a58 0%, #1a6f42 100%);
  box-shadow: 0 2px 10px rgba(8, 19, 14, 0.42);
}
.pl-wizard-analysis-card__crop-help {
  margin: 0;
}

/* Footer: global light theme applied directly in .site-footer rules above */




/* Contracts execute page */
.estate-contract-execution-page {
  max-width: 64rem;
  margin: var(--sp-8) auto;
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.08);
}

.estate-contract-execution-page__header {
  margin-bottom: var(--sp-5);
  padding-bottom: var(--sp-4);
  border-bottom: 1px solid var(--border);
}

.estate-contract-execution-page__title {
  margin: 0;
  color: var(--n-900);
  letter-spacing: -0.01em;
}

.estate-contract-execution-page__meta {
  margin: var(--sp-2) 0 0;
  color: var(--n-700);
}

.estate-contract-execution-page__flash {
  display: block;
  margin-bottom: var(--sp-4);
}

.estate-contract-execution-page__document {
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
  background: #fff;
  color: var(--n-900);
  line-height: 1.55;
}

.estate-contract-execution-page__document h1,
.estate-contract-execution-page__document h2,
.estate-contract-execution-page__document h3 {
  color: var(--n-900);
}

/* ### 4.1 … → h3 in contract body; blank line above each #.# subsection heading. */
.estate-contract-execution-page__document h3.estate-contract-doc-numbered-clause {
  margin-top: 1.75em;
  margin-bottom: 0.5em;
  font-size: var(--text-base);
  font-weight: 700;
}
.estate-contract-execution-page__document > h3.estate-contract-doc-numbered-clause:first-child,
.estate-contract-execution-page__document > div:first-child > h3.estate-contract-doc-numbered-clause:first-child {
  margin-top: 0;
}

/* Blank line above and below horizontal rules in contract body (web + countersign). */
.estate-contract-execution-page__document hr {
  margin: 1.25em 0;
  border: 0;
  border-top: 1px solid var(--border, #cbd5e1);
}

.estate-contract-execution-page__document p.estate-contract-doc-party-gap {
  margin: 0;
  padding: 0;
  height: 1.1em;
  line-height: 1.1em;
  overflow: hidden;
}

/* Blank line before subsection-style paragraphs (e.g. 1.1, 2.3.4). */
.estate-contract-execution-page__document p.estate-contract-doc-numbered-clause {
  margin-top: 1.25em;
}
.estate-contract-execution-page__document > p.estate-contract-doc-numbered-clause:first-child,
.estate-contract-execution-page__document > div:first-child > p.estate-contract-doc-numbered-clause:first-child {
  margin-top: 0;
}

.estate-contract-execution-page__document h1.estate-contract-doc-numbered-clause,
.estate-contract-execution-page__document h2.estate-contract-doc-numbered-clause {
  margin-top: 1.5em;
  margin-bottom: 0.5em;
}
.estate-contract-execution-page__document > h1.estate-contract-doc-numbered-clause:first-child,
.estate-contract-execution-page__document > div:first-child > h1.estate-contract-doc-numbered-clause:first-child,
.estate-contract-execution-page__document > h2.estate-contract-doc-numbered-clause:first-child,
.estate-contract-execution-page__document > div:first-child > h2.estate-contract-doc-numbered-clause:first-child {
  margin-top: 0;
}

.estate-contract-execution-page__attest {
  margin-top: var(--sp-6);
  padding: var(--sp-5);
  border: 1px solid color-mix(in srgb, var(--brand) 25%, var(--border));
  border-radius: var(--r-lg);
  background: color-mix(in srgb, #ffffff 90%, var(--brand) 10%);
}

.estate-contract-execution-page__attest-title {
  margin: 0;
  color: var(--n-900);
  font-size: var(--text-lg);
}

.estate-contract-execution-page__attest-copy {
  margin: var(--sp-2) 0 var(--sp-4);
  color: var(--n-700);
}

.estate-contract-execution-page__form label {
  color: var(--n-800);
  font-weight: 600;
}

.estate-contract-execution-page__form .form-group {
  margin-bottom: var(--sp-3);
}

.estate-contract-execution-page__form input.form-control[type="text"],
.estate-contract-execution-page__form input.form-control[type="email"] {
  background: #fff;
  width: min(100%, 28rem);
}

.estate-contract-execution-page__form input.form-control[type="text"]:focus,
.estate-contract-execution-page__form input.form-control[type="email"]:focus,
.estate-contract-execution-page__form input.form-control[type="text"]:active,
.estate-contract-execution-page__form input.form-control[type="email"]:active {
  background: #fff;
}

.estate-contract-execution-page__form input.form-control[type="text"]:-webkit-autofill,
.estate-contract-execution-page__form input.form-control[type="email"]:-webkit-autofill,
.estate-contract-execution-page__form input.form-control[type="text"]:-webkit-autofill:hover,
.estate-contract-execution-page__form input.form-control[type="email"]:-webkit-autofill:hover,
.estate-contract-execution-page__form input.form-control[type="text"]:-webkit-autofill:focus,
.estate-contract-execution-page__form input.form-control[type="email"]:-webkit-autofill:focus {
  -webkit-text-fill-color: var(--text);
  box-shadow: 0 0 0 1000px #fff inset;
}

.estate-contract-execution-page__attest--company .estate-contract-execution-page__form .btn {
  margin-top: var(--sp-1);
}

/* Override global form label clipping so execute form labels always render. */
.estate-contract-execution-page__form .form-group > label,
.estate-contract-execution-page__form .estate-contract-execution-page__pill-check > label {
  position: static !important;
  width: auto !important;
  height: auto !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: visible !important;
  clip: auto !important;
  white-space: normal !important;
  border: 0;
  clip-path: none !important;
}

.estate-contract-execution-page__pill-check {
  margin-bottom: var(--sp-3);
}

.estate-contract-toggle-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  column-gap: 0.75rem;
  row-gap: 0.2rem;
  align-items: center;
  padding: var(--sp-3) var(--sp-4);
  border: 1px solid var(--border);
  border-radius: 14px;
  background: transparent;
  color: var(--n-800);
  cursor: pointer;
  transition: border-color .15s ease, background .15s ease, box-shadow .15s ease;
}

.estate-contract-toggle-row__copy {
  display: grid;
  row-gap: 0.2rem;
}

.estate-contract-toggle-row__copy strong {
  color: var(--n-900);
  font-size: var(--text-sm);
  line-height: 1.2;
}

.estate-contract-toggle-row__copy span {
  color: var(--n-700);
  font-size: var(--text-xs);
}

.estate-contract-toggle-row:has(.pl-schedule-pill-toggle__input:focus-visible) {
  outline: 2px solid color-mix(in srgb, var(--brand) 45%, transparent);
  outline-offset: 2px;
}

.estate-contract-toggle-row:has(.pl-schedule-pill-toggle__input:checked) {
  border-color: var(--brand);
  background: transparent;
  box-shadow: none;
}

@media (max-width: 720px) {
  .estate-contract-execution-page {
    margin: var(--sp-4) auto;
  }

  .estate-contract-execution-page__document,
  .estate-contract-execution-page__attest {
    padding: var(--sp-4);
  }
}
