/* Screen-specific styles */

/* Moov home hero & about */
.moov-hero {
  position: relative;
  width: 100%;
  min-height: 320px;
  max-height: 520px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: var(--forest-dark);
  background-image:
    radial-gradient(ellipse 120% 80% at 50% 20%, var(--forest-mid) 0%, transparent 55%),
    radial-gradient(ellipse 80% 60% at 80% 80%, rgba(143,169,152,0.25) 0%, transparent 45%),
    linear-gradient(180deg, var(--forest-dark) 0%, var(--forest) 50%, var(--forest-mid) 100%);
}
.moov-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 120' opacity='0.06'%3E%3Cpath fill='%23fff' d='M60 20c-8 0-14 6-14 14s6 14 14 14 14-6 14-14-6-14-14-14zm0 50c-6 0-11 5-11 11s5 11 11 11 11-5 11-11-5-11-11-11z'/%3E%3Cpath fill='%23fff' d='M30 45c-4 0-7 3-7 7s3 7 7 7 7-3 7-7-3-7-7-7zm60 10c-3 0-6 2.5-6 5.5s3 5.5 6 5.5 6-2.5 6-5.5-3-5.5-6-5.5z'/%3E%3C/svg%3E");
  pointer-events: none;
}
.moov-hero__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.85;
}
.moov-hero__overlay {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 2.5rem 1.5rem;
  color: var(--white);
}
.moov-hero__heading {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  letter-spacing: 0.02em;
  margin: 0 0 0.5rem;
  text-shadow: 0 2px 12px rgba(0,0,0,0.25);
}
.moov-hero__tagline {
  font-family: var(--font-body);
  font-size: 1rem;
  opacity: 0.95;
  margin: 0 0 1.5rem;
}
.moov-hero__cta {
  display: inline-block;
  padding: 0.65rem 1.75rem;
  background: var(--copper);
  color: var(--copper-contrast);
  border: none;
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.9rem;
  text-decoration: none;
  transition: var(--transition);
  box-shadow: var(--shadow-hover);
}
.moov-hero__cta:hover {
  background: var(--copper-hover);
  color: var(--copper-contrast);
  transform: translateY(-1px);
}
.moov-banners {
  padding: 1.25rem var(--gutter);
  background: var(--forest-light);
  border-bottom: 1px solid var(--forest-border);
}
.moov-banners__inner {
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1rem;
}
.moov-banners__item {
  position: relative;
  border-radius: var(--radius-md);
  overflow: hidden;
  aspect-ratio: 2.4/1;
  background: var(--border);
}
.moov-banners__img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;
  background: var(--forest-dark, #1a2e24);
}
.moov-banners--tight {
  padding: 0.5rem var(--gutter);
  background: transparent;
  border-bottom: 0;
}
.moov-banners--tight .moov-banners__inner {
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 0.5rem;
}
.moov-banners__item--tight {
  aspect-ratio: 6/1;
  border-radius: var(--radius-sm, 4px);
}
.moov-about {
  padding: 2.5rem var(--gutter) 3rem;
  background: var(--bg);
}
.moov-about__inner {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}
.moov-about__heading {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.5rem;
  color: var(--charcoal);
  margin: 0 0 1rem;
}
.moov-about__text {
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.6;
  color: var(--text-body);
  margin-bottom: 1.5rem;
}
.moov-about__cta {
  display: inline-block;
  padding: 0.5rem 1.5rem;
  background: var(--forest);
  color: var(--white);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.9rem;
  text-decoration: none;
  transition: var(--transition);
}
.moov-about__cta:hover {
  background: var(--forest-mid);
  color: var(--white);
}

.moov-catalog-brand-strip {
  background: var(--white);
  border-top: 1px solid var(--forest-border);
  border-bottom: 1px solid var(--forest-border);
  padding: 1rem var(--gutter);
}
.moov-catalog-brand-strip__inner {
  max-width: var(--max-width);
  margin: 0 auto;
}
.moov-catalog-brand-strip__heading {
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: 0 0 0.75rem;
  text-align: center;
}
.moov-catalog-brand-strip__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.5rem 1.25rem;
}
.moov-catalog-brand-strip__item {
  margin: 0;
}
.moov-catalog-brand-strip__link {
  font-family: var(--font-body);
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--forest);
  text-decoration: none;
  white-space: nowrap;
  border-bottom: 1px solid transparent;
  transition: var(--transition);
}
.moov-catalog-brand-strip__link:hover {
  color: var(--copper);
  border-bottom-color: var(--copper-border-subtle);
}
.moov-catalog-brand-strip__logo {
  max-height: 36px;
  width: auto;
  object-fit: contain;
  display: block;
  filter: grayscale(0.2);
  transition: filter var(--transition);
}
.moov-catalog-brand-strip__link:hover .moov-catalog-brand-strip__logo {
  filter: grayscale(0);
}

/* Home brands grid (hometwo module) */
.moov-home-brands {
  padding: 2.5rem var(--gutter, 1rem);
  background: var(--surface, #f8f8f6);
  border-top: 1px solid var(--forest-border, #dce3dc);
  border-bottom: 1px solid var(--forest-border, #dce3dc);
}
.moov-home-brands__inner {
  max-width: var(--max-width, 1200px);
  margin: 0 auto;
}
.moov-home-brands__heading {
  font-family: var(--font-display);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: 0 0 1.5rem;
  text-align: center;
}
.moov-home-brands__grid {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 1.25rem 2rem;
}
.moov-home-brands__item {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 100px;
  text-decoration: none;
  transition: opacity var(--transition, 0.15s ease);
}
.moov-home-brands__item:hover {
  opacity: 0.75;
}
.moov-home-brands__logo {
  max-height: 60px;
  max-width: 160px;
  width: auto;
  object-fit: contain;
  filter: grayscale(0.15);
  transition: filter var(--transition, 0.15s ease);
}
.moov-home-brands__item:hover .moov-home-brands__logo {
  filter: grayscale(0);
}
.moov-home-brands__name {
  font-family: var(--font-body);
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--forest);
  white-space: nowrap;
}

/* Auth / login */
.auth-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px 16px;
  background: var(--forest-dark);
  background-image:
    radial-gradient(circle at 20% 50%, rgba(var(--copper-rgb),0.08) 0%, transparent 50%),
    repeating-linear-gradient(0deg, transparent, transparent 39px, rgba(255,255,255,0.025) 39px, rgba(255,255,255,0.025) 40px),
    repeating-linear-gradient(90deg, transparent, transparent 39px, rgba(255,255,255,0.025) 39px, rgba(255,255,255,0.025) 40px);
}

.auth-card {
  width: 100%;
  max-width: 420px;
  background: var(--white);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-modal);
  padding: 24px 24px 20px;
}

.auth-card__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 22px;
  margin-bottom: 4px;
  color: var(--charcoal);
}

.auth-card__subtitle {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--text-muted);
  margin-bottom: 18px;
}

.auth-card__footer {
  margin-top: 16px;
  font-family: var(--font-data);
  font-size: 10px;
  color: var(--text-light);
}

.auth-card__register-text {
  font-size: 12px;
  margin-bottom: 12px;
}

.auth-card__register-btn {
  width: 100%;
  justify-content: center;
}

.auth-card__actions {
  margin-top: 12px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.auth-link {
  font-family: var(--font-body);
  font-size: 11px;
  color: var(--forest);
  text-decoration: underline;
}

/* Auth brand lockup */
.auth-card__brand {
  text-align: center;
  margin-bottom: 20px;
}

.auth-card__brand-logo {
  width: 52px;
  height: 52px;
  border-radius: 12px;
  background: var(--copper);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 12px;
  box-shadow: var(--shadow-hover);
}

.auth-card__brand-logo:has(.auth-card__brand-img) {
  width: auto;
  height: auto;
  background: transparent;
  box-shadow: none;
}

.auth-card__brand-img {
  max-height: 48px;
  width: auto;
  max-width: 160px;
  object-fit: contain;
  display: block;
}

.auth-card__brand-mark {
  color: #fff;
  font-size: 26px;
  font-weight: 900;
  font-family: var(--font-display);
}

/* Guest catalog intro */
.moov-guest-intro {
  margin-top: 1rem;
  padding: 1rem 0;
  border-top: 1px solid var(--border-light, rgba(0,0,0,0.08));
}
.moov-guest-intro__text {
  font-size: 0.9375rem;
  color: var(--text-muted, #666);
  margin: 0 0 0.75rem 0;
}
.moov-guest-intro__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.moov-guest-intro__actions .moov-btn {
  margin: 0;
}

.auth-card__brand-title {
  color: var(--charcoal);
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.5px;
  margin-bottom: 4px;
}

.auth-card__brand-subtitle {
  color: var(--sage);
  font-size: 10px;
  font-family: var(--font-data);
  letter-spacing: 3px;
  text-transform: uppercase;
}

.auth-card__password-row {
  display: flex;
  align-items: center;
  gap: 8px;
}

.auth-card__submit {
  margin-top: 10px;
}

/* Catalog filters */
.filter-section {
  border-bottom: 1px solid var(--border);
  padding: 14px 0;
  margin-bottom: 0;
}

.filter-section__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
}

.filter-section__title {
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--forest);
}

.filter-section__body {
  margin-top: 10px;
  display: grid;
  gap: 8px;
}

.filter-section__hint {
  margin: 0 0 2px;
  font-family: var(--font-body);
  font-size: 11px;
  line-height: 1.35;
  color: var(--text-muted);
}

.filter-section__hint strong {
  color: var(--text-body);
  font-weight: 600;
}

.filter-section__search {
  position: relative;
  margin: 6px 0 8px;
}

.filter-section__brand-search {
  width: 100%;
  padding: 5px 26px 5px 8px;
  border: 1px solid var(--border-light, #ddd);
  border-radius: 6px;
  font-size: 12px;
  font-family: var(--font-body);
  color: var(--text-body);
  background: var(--surface-input, #fff);
  outline: none;
  box-sizing: border-box;
  transition: border-color 0.15s;
}

.filter-section__brand-search:focus {
  border-color: var(--color-primary, #3b82f6);
}

.filter-section__brand-search-clear {
  position: absolute;
  right: 6px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  font-size: 16px;
  line-height: 1;
  color: var(--text-muted);
  padding: 0 2px;
}

.filter-section__brand-search-clear:hover {
  color: var(--text-body);
}

.filter-section__no-results {
  margin: 6px 0 0;
  font-size: 11px;
  color: var(--text-muted);
  font-style: italic;
}

.filter-pill-row--effects .filter-pill {
  position: relative;
}

.filter-pill-row--effects .filter-pill.is-active:not([value=""]) {
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.06);
}

.filter-range-helper {
  display: flex;
  justify-content: space-between;
  margin-top: 4px;
  font-size: 9px;
  color: var(--text-light);
  font-family: var(--font-data);
}

.filter-section--thc .field__input--range {
  width: 100%;
  accent-color: var(--forest);
}

.filter-section--thc .field__input--range-price {
  accent-color: var(--copper);
}

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

.category-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  border: 1px solid transparent;
  border-radius: 6px;
  padding: 7px 10px;
  background: transparent;
  color: var(--text-body);
  cursor: pointer;
  transition: var(--transition);
}

.category-option:hover {
  border-color: var(--border);
  background: var(--sage-bg);
}

.category-option.is-active {
  background: var(--forest-light);
  border-color: var(--forest-border);
  color: var(--forest);
}

.category-option__left {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
}

.category-option__icon {
  font-size: 14px;
  line-height: 1;
}

.category-option__count {
  font-family: var(--font-data);
  font-size: 10px;
  color: var(--text-light);
}

.category-option.is-active .category-option__count {
  color: var(--forest);
}

.strain-option-list {
  display: grid;
  gap: 4px;
}

.strain-option {
  width: 100%;
  text-align: left;
  border: 1px solid transparent;
  border-radius: 6px;
  padding: 7px 10px;
  background: transparent;
  color: var(--text-body);
  font-family: var(--font-body);
  font-size: 12px;
  cursor: pointer;
  transition: var(--transition);
}

.strain-option:hover {
  border-color: var(--border);
  background: var(--sage-bg);
}

.strain-option.is-active {
  background: var(--forest-light);
  border-color: var(--forest-border);
  color: var(--forest);
  font-weight: 700;
}

.catalog-b2b-info {
  margin-top: 16px;
  padding: 12px 14px;
  background: var(--forest-light);
  border: 1px solid var(--forest-border);
  border-radius: var(--radius-md);
}

.catalog-b2b-info__title {
  margin-bottom: 4px;
  font-family: var(--font-data);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.7px;
  text-transform: uppercase;
  color: var(--forest);
}

.catalog-b2b-info__body {
  margin: 0;
  font-family: var(--font-body);
  font-size: 11px;
  color: var(--text-muted);
  line-height: 1.45;
}

.filter-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-pill);
  padding: 4px 10px;
  font-family: var(--font-body);
  font-size: 11px;
  background: var(--sage-bg);
  color: var(--text-body);
  border: 1px solid transparent;
  cursor: pointer;
  transition: var(--transition);
}

.filter-pill.is-active {
  background: var(--forest);
  color: #fff;
  border-color: var(--forest);
}

.catalog-category-pills {
  padding: 12px 0 0;
}

.catalog-category-pills .category-pill-row {
  scrollbar-width: none;
}

.catalog-category-pills .category-pill-row::-webkit-scrollbar {
  display: none;
}

.category-pill-row {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 4px;
}

.category-pill-row::-webkit-scrollbar {
  height: 4px;
}

.category-pill {
  white-space: nowrap;
  padding: 6px 14px;
  border-radius: var(--radius-pill);
  border: 1.5px solid var(--border);
  background: var(--white);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.category-pill__icon {
  font-size: 1em;
  line-height: 1;
}

.category-pill.is-active {
  border-color: var(--copper);
  background: var(--copper-light);
  color: var(--charcoal);
}

.filter-section--effect .filter-pill.is-active {
  border-color: var(--copper);
  background: var(--copper-light);
  color: var(--copper);
}

.catalog-category-pills .category-pill.is-active {
  border-color: var(--forest);
  background: var(--forest);
  color: #fff;
}

.catalog-layout--sidebar-hidden .catalog-category-pills .category-pill-row {
  justify-content: center;
}

.catalog-empty-filters {
  text-align: center;
  padding: 60px 24px;
  color: var(--text-light);
}

.catalog-empty-filters__icon {
  font-size: 32px;
  opacity: 0.4;
  margin-bottom: 12px;
}

.catalog-empty-filters__icon .fa {
  font-size: inherit;
}

.catalog-empty-filters__text {
  font-family: var(--font-body);
  font-size: 14px;
  margin: 0 0 12px;
  color: var(--text-light);
}

.catalog-empty-filters__clear {
  margin-top: 8px;
}

/* Catalog grid vs list modes */
.moov-products-grid.product-grid {
  display: grid;
}

.moov-products-grid.product-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* ── List-view card layout (desktop) ── */
.moov-products-grid.product-list .moov-product-card {
  flex-direction: row;
  align-items: stretch;
  min-height: 0;
  border-radius: var(--radius-lg);
}

.moov-products-grid.product-list .moov-product-card:hover {
  transform: none;
}

/* Image column */
.moov-products-grid.product-list .moov-product-card-image-wrap {
  flex: 0 0 130px;
  width: 130px;
  min-height: 130px;
  border-radius: var(--radius-lg) 0 0 var(--radius-lg);
}

.moov-products-grid.product-list .moov-product-card-image-wrap .moov-card-img {
  width: 100%;
  height: 100%;
  aspect-ratio: auto;
  object-fit: cover;
}

.moov-card-img--no-image,
.product-row__thumb--no-image {
  background-color: #f5f5f5;
  display: block;
}

.moov-products-grid.product-list .moov-card-overlays-top {
  padding: 6px;
}

.moov-products-grid.product-list .moov-card-overlays-top .badge-new {
  font-size: 8px;
  padding: 1px 6px;
}

/* Hide quick view hint in list */
.moov-products-grid.product-list .moov-card-quickview-hint {
  display: none;
}

/* Hide batch overlay in list (too cramped) */
.moov-products-grid.product-list .moov-card-batch-overlay {
  display: none;
}

/* Body column */
.moov-products-grid.product-list .moov-card-body {
  flex: 1 1 0;
  min-width: 0;
  justify-content: center;
  padding: 14px 18px;
}

.moov-products-grid.product-list .moov-card-eyebrow {
  margin-bottom: 2px;
  font-size: 11px;
}

.moov-products-grid.product-list .moov-card-title {
  font-size: 15px;
  margin-bottom: 4px;
  line-height: 1.3;
}

.moov-products-grid.product-list .moov-card-description,
.moov-products-grid.product-list .moov-card-effects,
.moov-products-grid.product-list .potency-row {
  margin-bottom: 4px;
}

.moov-products-grid.product-list .moov-card-effects {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}

.moov-products-grid.product-list .moov-qoh {
  margin: 2px 0 0;
}

/* Price + action column */
.moov-products-grid.product-list .moov-product-quick-order {
  flex: 0 0 auto;
  border-top: none;
  border-left: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 16px 24px;
  min-width: 160px;
  width: auto;
  background: var(--sage-bg);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
}

.moov-products-grid.product-list .moov-product-quick-order .moov-card-price--footer {
  margin: 0;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
}

.moov-products-grid.product-list .moov-product-quick-order .moov-cart-btn {
  flex-shrink: 0;
  width: 100%;
  min-height: 38px;
  font-size: 12px;
  white-space: nowrap;
}

/* ── List-view tablet (768px and below) ── */
@media (max-width: 767px) {
  .moov-products-grid.product-list {
    gap: 8px;
  }

  /* Compact horizontal layout on mobile — image left, content right, action inline */
  .moov-products-grid.product-list .moov-product-card {
    flex-direction: row;
    align-items: stretch;
    min-height: 0;
  }

  .moov-products-grid.product-list .moov-product-card-image-wrap {
    flex: 0 0 90px;
    width: 90px;
    min-height: 90px;
    border-radius: var(--radius-lg) 0 0 var(--radius-lg);
  }

  .moov-products-grid.product-list .moov-card-body {
    flex: 1 1 0;
    min-width: 0;
    padding: 10px 12px;
    justify-content: center;
  }

  .moov-products-grid.product-list .moov-card-title {
    font-size: 13px;
    margin-bottom: 3px;
  }

  .moov-products-grid.product-list .moov-card-description {
    display: none;
  }

  .moov-products-grid.product-list .moov-card-effects {
    display: none;
  }

  .moov-products-grid.product-list .moov-card-rating {
    display: none;
  }

  .moov-products-grid.product-list .potency-row {
    margin-bottom: 2px;
  }

  /* Compact right-side action column on mobile */
  .moov-products-grid.product-list .moov-product-quick-order {
    flex: 0 0 auto;
    border-left: 1px solid var(--border);
    border-top: none;
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 12px;
    min-width: 90px;
    width: auto;
    border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
  }

  .moov-products-grid.product-list .moov-product-quick-order .moov-card-price--footer {
    font-size: 14px;
    font-weight: 700;
    margin: 0;
    text-align: center;
    white-space: nowrap;
  }

  .moov-products-grid.product-list .moov-product-quick-order .moov-cart-btn {
    width: 100%;
    min-height: 32px;
    font-size: 10px;
    padding: 0 8px;
    white-space: nowrap;
  }
}

/* ── List-view very small screens (below 400px) ── */
@media (max-width: 400px) {
  .moov-products-grid.product-list .moov-product-card-image-wrap {
    flex: 0 0 75px;
    width: 75px;
    min-height: 75px;
  }

  .moov-products-grid.product-list .moov-product-quick-order {
    min-width: 80px;
    padding: 8px 10px;
  }

  .moov-products-grid.product-list .moov-product-quick-order .moov-card-price--footer {
    font-size: 13px;
  }

  .moov-products-grid.product-list .moov-product-quick-order .moov-cart-btn {
    font-size: 9px;
    min-height: 28px;
  }
}

/* Product detail drawer */
.drawer-hero {
  position: relative;
  overflow: hidden;
  min-height: 180px;
  background: var(--sage-bg);
}

.drawer-hero__img {
  display: block;
  width: 100%;
  height: 260px;
  object-fit: cover;
  cursor: zoom-in;
  transition: transform 0.4s ease;
}

.drawer-hero__img:hover {
  transform: scale(1.02);
}

.drawer-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.72), rgba(0,0,0,0.1));
  pointer-events: none;
}

.drawer-hero__zoom {
  position: absolute;
  bottom: 12px;
  right: 14px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: none;
  background: rgba(255,255,255,0.92);
  color: var(--charcoal);
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 2;
  box-shadow: 0 2px 8px rgba(0,0,0,0.25);
  transition: background 0.15s ease, transform 0.15s ease;
}

.drawer-hero__zoom:hover {
  background: #fff;
  transform: scale(1.06);
}

.drawer-gallery {
  position: relative;
  width: 100%;
  height: 320px;
  overflow: hidden;
  background: var(--sage-bg);
  touch-action: pan-y;
}

.drawer-gallery__main {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  cursor: zoom-in;
  transition: transform 0.3s ease, opacity 0.25s ease;
  background: linear-gradient(135deg, #f5f7fa 0%, #e8ecf1 100%);
  user-select: none;
  animation: drawer-gallery-fade-in 0.3s ease;
}

@keyframes drawer-gallery-fade-in {
  from {
    opacity: 0;
    transform: scale(0.98);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

.drawer-gallery__main:hover {
  transform: scale(1.02);
}

.drawer-gallery__no-image {
  width: 100%;
  height: 100%;
  background-color: #f5f5f5;
}

@media (max-width: 768px) {
  .drawer-gallery {
    height: 280px;
  }
  
  .drawer-gallery__main:hover {
    transform: none;
  }
}

.drawer-gallery__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: none;
  background: rgba(255,255,255,0.95);
  color: var(--charcoal);
  font-size: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 3;
  box-shadow: 0 2px 12px rgba(0,0,0,0.2);
  transition: all 0.2s ease;
  opacity: 0;
}

.drawer-gallery:hover .drawer-gallery__nav {
  opacity: 1;
}

@media (max-width: 768px) {
  .drawer-gallery__nav {
    opacity: 0.85;
  }
  
  .drawer-gallery__nav:active {
    opacity: 1;
    transform: translateY(-50%) scale(0.95);
  }
}

.drawer-gallery__nav:hover {
  background: #fff;
  transform: translateY(-50%) scale(1.08);
  box-shadow: 0 4px 16px rgba(0,0,0,0.25);
}

.drawer-gallery__nav--prev {
  left: 12px;
}

.drawer-gallery__nav--next {
  right: 12px;
}

.drawer-gallery__indicators {
  position: absolute;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 8px;
  z-index: 3;
  padding: 8px 12px;
  background: rgba(0,0,0,0.35);
  backdrop-filter: blur(8px);
  border-radius: 999px;
}

.drawer-gallery__indicator {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  border: none;
  background: rgba(255,255,255,0.5);
  cursor: pointer;
  transition: all 0.25s ease;
  padding: 0;
}

.drawer-gallery__indicator:hover {
  background: rgba(255,255,255,0.75);
  transform: scale(1.2);
}

.drawer-gallery__indicator.is-active {
  background: #fff;
  width: 24px;
  border-radius: 999px;
}

.drawer-thumbnails {
  padding: 12px 18px;
  background: var(--white);
  border-bottom: 1px solid var(--border);
}

.drawer-thumbnails__scroll {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--border) transparent;
  padding-bottom: 4px;
  scroll-behavior: smooth;
  scroll-snap-type: x proximity;
}

.drawer-thumbnail {
  scroll-snap-align: start;
}

.drawer-thumbnails__scroll::-webkit-scrollbar {
  height: 6px;
}

.drawer-thumbnails__scroll::-webkit-scrollbar-track {
  background: transparent;
}

.drawer-thumbnails__scroll::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 999px;
}

.drawer-thumbnails__scroll::-webkit-scrollbar-thumb:hover {
  background: var(--text-muted);
}

.drawer-thumbnail {
  flex-shrink: 0;
  width: 64px;
  height: 64px;
  border-radius: var(--radius-md);
  border: 2px solid transparent;
  background: var(--sage-bg);
  overflow: hidden;
  cursor: pointer;
  transition: all 0.2s ease;
  padding: 0;
  position: relative;
}

.drawer-thumbnail::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: var(--radius-md);
  background: rgba(58, 111, 89, 0.08);
  opacity: 0;
  transition: opacity 0.2s ease;
  pointer-events: none;
}

.drawer-thumbnail:hover::after {
  opacity: 1;
}

.drawer-thumbnail:hover {
  border-color: var(--forest);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.drawer-thumbnail.is-active {
  border-color: var(--forest);
  box-shadow: 0 0 0 3px rgba(58, 111, 89, 0.15);
}

.drawer-thumbnail.is-active::after {
  opacity: 1;
}

.drawer-thumbnail__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Product image lightbox */
.drawer-image-lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0,0,0,0.88);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  animation: drawer-image-lightbox-fade 0.18s ease forwards;
}

@keyframes drawer-image-lightbox-fade {
  from { opacity: 0; }
  to { opacity: 1; }
}

.drawer-image-lightbox__img {
  max-width: min(1200px, 96vw);
  max-height: 92vh;
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: var(--radius-md);
  box-shadow: 0 20px 60px rgba(0,0,0,0.6);
  cursor: zoom-out;
}

.drawer-image-lightbox__close {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: none;
  background: rgba(255,255,255,0.95);
  color: var(--charcoal);
  font-size: 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 12px rgba(0,0,0,0.35);
  transition: transform 0.15s ease;
}

.drawer-image-lightbox__close:hover {
  transform: scale(1.06);
}

.drawer-hero__meta {
  position: absolute;
  left: 18px;
  bottom: 16px;
  color: #fff;
}

.drawer-hero__title {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 800;
}

.drawer-hero__sku {
  font-family: var(--font-data);
  font-size: 11px;
}

.drawer-section {
  padding: 16px 18px;
  border-bottom: 1px solid var(--border);
}

.drawer-section__title {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 6px;
}

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

.drawer-section__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.drawer-chip {
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--border);
  background: var(--sage-bg);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  color: var(--text-body);
}

/* Product quickview: above sales-portal chrome (nav ~530, shell top ~540); below cart flyout (~99998) */
body.sales-portal .drawer-overlay {
  z-index: 650;
}
body.sales-portal .drawer-panel {
  z-index: 651;
}

/* Mobile: full-width drawer hides backdrop — sticky bar matches catalog filter pattern */
.drawer-mobile-bar {
  display: none;
}

@media (max-width: 768px) {
  .drawer-mobile-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-shrink: 0;
    gap: 12px;
    padding: calc(10px + env(safe-area-inset-top, 0px)) 16px 10px;
    border-bottom: 1px solid var(--border);
    background: var(--white);
    position: sticky;
    top: 0;
    z-index: 6;
  }

  .drawer-mobile-bar__title {
    font-family: var(--font-body);
    font-size: 16px;
    font-weight: 700;
    color: var(--charcoal);
  }

  .drawer-mobile-bar__done {
    padding: 6px 16px;
    border-radius: 999px;
    border: 1.5px solid var(--forest-border);
    background: var(--forest-light);
    color: var(--forest);
    font-family: var(--font-body);
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
  }

  .drawer-mobile-bar__done:hover {
    filter: brightness(0.97);
  }

  .drawer-hero .drawer-close {
    top: calc(14px + env(safe-area-inset-top, 0px));
  }

  .drawer-hero__overlay {
    pointer-events: none;
  }
}

/* Drawer close button */
.drawer-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(255,255,255,0.9);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  font-size: 14px;
  color: var(--charcoal);
}

/* Drawer potency cards */
.drawer-potency-card {
  border-radius: var(--radius-md);
  padding: 10px 14px;
  text-align: center;
}

.drawer-potency-card--thc {
  background: var(--forest-light);
}

.drawer-potency-card--cbd {
  background: #EEF4F7;
}

.drawer-potency-card__label {
  display: block;
  font-family: var(--font-data);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 2px;
}

.drawer-potency-card--thc .drawer-potency-card__label,
.drawer-potency-card--thc .drawer-potency-card__value {
  color: var(--forest);
}

.drawer-potency-card--cbd .drawer-potency-card__label,
.drawer-potency-card--cbd .drawer-potency-card__value {
  color: #2E5D7A;
}

.drawer-potency-card__value {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 800;
}

/* Drawer detail rows */
.drawer-detail-rows {
  background: var(--sage-bg);
  border-radius: var(--radius-md);
  padding: 8px 14px;
}

.drawer-detail-rows--forest {
  background: var(--forest-light);
  border: 1px solid var(--forest-border);
}

.drawer-detail-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 4px 0;
  border-bottom: 1px solid var(--border);
  gap: 12px;
}

.drawer-detail-rows--forest .drawer-detail-row {
  border-bottom-color: rgba(168,201,190,0.27);
}

.drawer-detail-row:last-child {
  border-bottom: none;
}

.drawer-detail-row__label {
  font-family: var(--font-data);
  font-size: 11px;
  color: var(--text-muted);
  flex-shrink: 0;
}

.drawer-detail-row__value {
  font-family: var(--font-data);
  font-size: 11px;
  font-weight: 600;
  color: var(--charcoal);
  text-align: right;
}

.drawer-detail-rows--forest .drawer-detail-row__value {
  color: var(--forest);
  font-weight: 700;
}

/* Drawer add-to-cart row */
.drawer-section--action {
  border-bottom: none;
}

.drawer-add-row {
  display: flex;
  gap: 10px;
  align-items: center;
}

.drawer-qty {
  display: flex;
  align-items: center;
  border: 1.5px solid var(--border);
  border-radius: 6px;
  overflow: hidden;
}

.drawer-qty__btn {
  width: 36px;
  height: 46px;
  border: none;
  background: var(--sage-bg);
  cursor: pointer;
  font-size: 18px;
  color: var(--text-body);
}

.drawer-qty__val {
  width: 44px;
  text-align: center;
  font-family: var(--font-data);
  font-size: 13px;
  font-weight: 700;
  color: var(--charcoal);
}

.moov-card-rating {
  display: flex;
  align-items: center;
  gap: 6px;
  margin: 6px 0 8px;
}

.moov-card-rating__stars {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  color: var(--gold);
  font-size: 10px;
}

.moov-card-rating__meta {
  font-family: var(--font-data);
  font-size: 10px;
  color: var(--text-muted);
}

.moov-product-quick-order {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 14px;
  border-top: 1px solid var(--border);
  margin-top: auto;
  background: var(--sage-bg);
}

.moov-card-price--footer {
  margin: 0;
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 800;
  color: var(--charcoal);
  line-height: 1;
}

.moov-card-price--footer .price-new {
  color: var(--copper);
  margin-right: 6px;
}

.moov-card-price--footer .price-old {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-light);
  text-decoration: line-through;
}

.moov-cart-btn {
  min-height: 36px;
  padding: 0 14px;
  border-radius: var(--radius-md);
  font-size: 11px;
  white-space: nowrap;
}

.moov-cart-btn:disabled {
  font-size: 10px;
}

/* ── Grid-view card: stack price + button on narrow phones so button never clips ── */
@media (max-width: 600px) {
  .moov-products-grid.product-grid .moov-product-quick-order {
    flex-direction: column;
    align-items: stretch;
    gap: 6px;
  }

  .moov-products-grid.product-grid .moov-product-quick-order .moov-card-price--footer {
    text-align: center;
    font-size: 14px;
  }

  .moov-products-grid.product-grid .moov-product-quick-order .moov-cart-btn {
    width: 100%;
    min-height: 32px;
    font-size: 10px;
    padding: 0 6px;
    text-align: center;
    justify-content: center;
  }
}

.moov-results-count {
  font-family: var(--font-data);
  font-size: 11px;
  color: var(--text-muted);
  white-space: normal;
  overflow-wrap: anywhere;
}

/* Custom catalog sort (no native select clipping) */
.catalog-sort {
  position: relative;
  flex: 1 1 auto;
  min-width: 0;
  max-width: 100%;
}

.catalog-sort__trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  width: 100%;
  min-height: 38px;
  padding: 6px 12px;
  margin: 0;
  border: 1.5px solid var(--border);
  border-radius: 7px;
  background: var(--white);
  color: var(--text-body);
  font-family: var(--font-body);
  cursor: pointer;
  text-align: left;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.catalog-sort__trigger:hover {
  border-color: var(--forest-border);
}

.catalog-sort__trigger:focus {
  outline: none;
  border-color: var(--forest);
  box-shadow: 0 0 0 2px var(--forest-light);
}

.catalog-sort__trigger-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1px;
  min-width: 0;
  flex: 1 1 auto;
}

.catalog-sort__label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  line-height: 1.2;
}

.catalog-sort__value {
  font-size: 12px;
  font-weight: 600;
  color: var(--forest);
  line-height: 1.35;
  word-wrap: break-word;
  overflow-wrap: anywhere;
  white-space: normal;
  max-width: 100%;
}

.catalog-sort__chevron {
  flex-shrink: 0;
  font-size: 11px;
  color: var(--text-muted);
  transition: transform 0.2s ease;
}

.catalog-sort__chevron--open {
  transform: rotate(180deg);
}

.catalog-sort__panel {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  left: 0;
  min-width: min(100%, 280px);
  max-width: min(100vw - 32px, 320px);
  margin-left: auto;
  padding: 6px 0;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-hover);
  z-index: 40;
}

.catalog-sort__option {
  display: block;
  width: 100%;
  padding: 10px 14px;
  border: 0;
  background: transparent;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-body);
  text-align: left;
  cursor: pointer;
  line-height: 1.35;
  white-space: normal;
  word-wrap: break-word;
  overflow-wrap: anywhere;
  transition: background 0.12s ease, color 0.12s ease;
}

.catalog-sort__option:hover {
  background: var(--sage-bg);
  color: var(--forest);
}

.catalog-sort__option.is-active {
  background: var(--forest-light);
  color: var(--forest);
  font-weight: 700;
}

@media (min-width: 768px) {
  .catalog-sort__panel {
    left: auto;
    width: max-content;
    max-width: min(90vw, 340px);
  }

  .catalog-sort {
    flex: 0 1 auto;
    min-width: 160px;
    max-width: min(42vw, 320px);
  }
}

/* Guest catalog sort (.moov-sort-dropdown) — km-theme.css is not loaded on storefront; keep panel hidden until open */
.moov-sort-dropdown {
  position: relative;
  display: inline-block;
}

.moov-sort-trigger {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  background: transparent;
  color: var(--text-body);
  border: none;
  padding: 0.35rem 0;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  transition: color 0.2s ease;
}

.moov-sort-trigger:hover {
  color: var(--forest);
}

.moov-sort-trigger:focus {
  outline: none;
  color: var(--forest);
}

.moov-sort-trigger-icon {
  font-size: 10px;
  opacity: 0.8;
  transition: transform 0.2s ease;
}

.moov-sort-dropdown.moov-sort-dropdown-open .moov-sort-trigger-icon {
  transform: rotate(180deg);
}

.moov-sort-dropdown-panel {
  display: none;
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 8px;
  min-width: 240px;
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 0.5rem 0;
  z-index: 100;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-hover);
}

.moov-sort-dropdown.moov-sort-dropdown-open .moov-sort-dropdown-panel {
  display: block;
}

.moov-sort-dropdown-title {
  color: var(--text-muted);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 0 0.75rem 0.35rem;
  border-bottom: 1px solid var(--border);
  margin-bottom: 0.25rem;
}

.moov-sort-options {
  display: flex;
  flex-direction: column;
}

.moov-sort-option {
  display: block;
  padding: 0.5rem 0.85rem;
  color: var(--text-body);
  text-decoration: none;
  font-size: 13px;
}

.moov-sort-option:hover {
  background: var(--sage-bg);
  color: var(--forest);
}

.moov-sort-option--selected {
  background: var(--forest);
  color: #fff;
  font-weight: 600;
}

.moov-sort-option--selected:hover {
  filter: brightness(0.92);
  color: #fff;
}

@media (max-width: 767px) {
  .moov-sort-dropdown {
    min-width: 0;
    max-width: 100%;
  }

  .moov-sort-trigger {
    padding: 8px 12px;
    background: var(--sage-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    font-size: 12px;
    max-width: 100%;
  }

  .moov-sort-trigger-text {
    overflow: visible;
    white-space: normal;
    word-wrap: break-word;
    overflow-wrap: anywhere;
    max-width: none;
    text-align: left;
    line-height: 1.3;
  }

  .moov-sort-dropdown-panel {
    right: 0;
    left: auto;
    min-width: min(100vw - 24px, 260px);
    max-width: min(100vw - 24px, 320px);
  }

  .moov-sort-option {
    white-space: normal;
    word-wrap: break-word;
    overflow-wrap: anywhere;
  }
}

.catalog-view-toggle {
  display: inline-flex;
  border: 1.5px solid var(--border);
  border-radius: 7px;
  overflow: hidden;
  flex-shrink: 0;
}

.catalog-view-toggle__btn {
  width: 36px;
  height: 36px;
  border: 0;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  transition: var(--transition);
}

.catalog-view-toggle__btn.is-active {
  background: var(--forest);
  color: #fff;
}

/* Product detail page */
.product-detail {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1.4fr);
  gap: 32px;
  align-items: flex-start;
}

@media (max-width: 991px) {
  .product-detail {
    grid-template-columns: minmax(0, 1fr);
    gap: 24px;
  }
}

.product-detail__gallery {
  background: var(--white);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-card);
  padding: 16px;
}

.product-detail__info {
  background: var(--white);
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-card);
  padding: 18px 20px 20px;
}

.product-detail__title {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 4px;
}

.product-detail__meta {
  font-family: var(--font-data);
  font-size: 11px;
  color: var(--text-muted);
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  margin-bottom: 10px;
}

.product-detail__section {
  padding-top: 14px;
  border-top: 1px solid var(--border);
  margin-top: 14px;
}

.product-detail__section-title {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 6px;
}

/* Cart / tax preview */
.cart-layout {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  gap: 24px;
  align-items: flex-start;
}

@media (max-width: 991px) {
  .cart-layout {
    grid-template-columns: minmax(0, 1fr);
  }
}

.cart-layout__items {
  min-width: 0;
}

.cart-layout__summary {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.cart-banner-valid {
  background: var(--forest-light);
  border-radius: var(--radius-lg);
  border: 1px solid var(--forest-border);
  padding: 10px 14px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 12px;
}

.cart-banner-valid i {
  color: var(--forest);
}

.cart-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-data);
  font-size: 12px;
}

.cart-table th,
.cart-table td {
  padding: 8px 6px;
  border-bottom: 1px solid var(--border);
}

.cart-table th {
  text-align: left;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-muted);
}

.cart-qty-input {
  width: 72px;
  text-align: center;
}

.summary-card {
  background: #fff;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-card);
  padding: 14px 16px;
}

.summary-card__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-data);
  font-size: 12px;
  margin-bottom: 4px;
}

.summary-card__row--total {
  margin-top: 6px;
  font-size: 14px;
  font-weight: 700;
}

/* Admin dashboard */
.admin-page {
  max-width: 1200px;
  margin: 0 auto;
}

/* Portal pages: the template already has main-content + moov-shell as centering layers.
   Remove admin-page's own width constraint so it fills the parent correctly. */
body.sales-portal .admin-page {
  max-width: 100%;
  margin: 0;
  overflow-wrap: anywhere;
}

.admin-page__header {
  margin-bottom: 22px;
}

.admin-page__title {
  font-family: var(--font-body);
  font-size: 22px;
  font-weight: 800;
  color: var(--forest);
  margin: 0 0 4px;
}

.admin-page__subtitle {
  font-family: var(--font-data);
  font-size: 12px;
  color: var(--text-light);
  margin: 0;
}
.sales-portal-page__actions {
  margin-top: 14px;
}

.admin-quick-actions {
  margin-bottom: 24px;
}

.admin-quick-actions__title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-light);
  font-family: var(--font-body);
  margin: 0 0 12px;
}

.admin-quick-actions__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
}

body.sales-portal .sales-portal-page--dashboard .admin-quick-actions__grid,
body.sales-portal .sales-portal-page--admin-dashboard .admin-quick-actions__grid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 220px), 1fr));
}

.admin-quick-action {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: #fff;
  text-decoration: none;
  color: var(--charcoal);
  transition: border-color 0.15s, box-shadow 0.15s;
  box-shadow: 0 1px 4px rgba(var(--forest-rgb), 0.04);
}

.admin-quick-action:hover {
  border-color: var(--copper);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  text-decoration: none;
  color: var(--charcoal);
}

.admin-quick-action__icon {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-sm);
  background: var(--copper-light);
  color: var(--copper);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  flex-shrink: 0;
}

.admin-quick-action__body { min-width: 0; }

.admin-quick-action__label {
  display: block;
  font-weight: 700;
  font-size: 13px;
  font-family: var(--font-body);
}

.admin-quick-action__hint {
  display: block;
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 2px;
  font-family: var(--font-data);
  overflow-wrap: break-word;
}

.admin-metrc-health {
  margin-top: 16px;
}

.admin-metrc-health__stat {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  font-size: 12px;
}

.admin-metrc-health__stat:last-child { border-bottom: none; }

.admin-metrc-health__label {
  color: var(--text-light);
  font-family: var(--font-data);
}

.admin-metrc-health__value {
  font-weight: 700;
  font-family: var(--font-data);
  text-align: right;
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: break-word;
}

.admin-metrc-health__note {
  font-size: 10px;
  color: var(--text-muted);
  margin-top: 12px;
  line-height: 1.45;
  font-family: var(--font-data);
}

.admin-alert-banner {
  background: var(--red-light);
  border: 1.5px solid var(--red);
  border-radius: 7px;
  padding: 14px 20px;
  margin-bottom: 22px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.admin-alert-banner__icon {
  color: var(--red);
  font-size: 18px;
  flex-shrink: 0;
}

.admin-alert-banner__body {
  flex: 1 1 0;
}

.admin-alert-banner__title {
  font-size: 13px;
  font-weight: 700;
  color: var(--red);
  font-family: var(--font-body);
}

.admin-alert-banner__meta {
  font-size: 11px;
  color: #B71C1C;
  font-family: var(--font-data);
  margin-top: 3px;
  opacity: 0.85;
}

.admin-alert-banner__cta {
  flex-shrink: 0;
}

.admin-kpis {
  margin-bottom: 24px;
}

.kpi-tiles {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.kpi-tile {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 20px;
  box-shadow: 0 2px 8px rgba(var(--forest-rgb), 0.05);
  border-top: 3px solid var(--forest);
}

a.kpi-tile,
.kpi-tile--linked {
  text-decoration: none;
  display: block;
  transition: box-shadow 0.15s, transform 0.12s;
  cursor: pointer;
}

a.kpi-tile:hover,
.kpi-tile--linked:hover {
  box-shadow: 0 4px 16px rgba(var(--forest-rgb), 0.12);
  transform: translateY(-1px);
}

.kpi-tile:nth-child(2) { border-top-color: var(--red); }
.kpi-tile:nth-child(3) { border-top-color: var(--copper); }
.kpi-tile:nth-child(4) { border-top-color: #EF6C00; }

.kpi-tile__label {
  font-size: 9px;
  font-weight: 700;
  color: var(--text-light);
  font-family: var(--font-body);
  letter-spacing: 0.8px;
  text-transform: uppercase;
  margin-bottom: 10px;
}

.kpi-tile__value {
  font-size: 32px;
  font-weight: 800;
  font-family: var(--font-body);
  line-height: 1;
  color: var(--forest);
}

.kpi-tile:nth-child(2) .kpi-tile__value { color: var(--red); }
.kpi-tile:nth-child(3) .kpi-tile__value { color: var(--copper); }
.kpi-tile:nth-child(4) .kpi-tile__value { color: #EF6C00; }

.kpi-tile__sub {
  font-size: 10px;
  color: var(--text-light);
  font-family: var(--font-data);
  margin-top: 8px;
}

.admin-kpis__empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 32px;
  color: var(--text-light);
  font-family: var(--font-data);
  font-size: 12px;
}

.admin-layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 24px;
  align-items: start;
}

.admin-layout__main,
.admin-layout__sidebar {
  min-width: 0;
}

.admin-layout__sidebar {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.admin-card {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(var(--forest-rgb), 0.05);
}

.admin-card--alert {
  border: 2px solid var(--red);
}

.admin-card__header {
  padding: 12px 18px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.admin-card__header--forest {
  background: var(--forest);
}

.admin-card__title {
  font-size: 11px;
  font-weight: 700;
  font-family: var(--font-body);
  color: #fff;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

.admin-card__body {
  padding: 16px;
}

.admin-card__body--flush {
  padding: 0;
}

.admin-card__eyebrow {
  font-size: 9px;
  font-weight: 700;
  color: var(--red);
  font-family: var(--font-data);
  letter-spacing: 1px;
  margin-bottom: 10px;
  text-transform: uppercase;
}

.admin-card__warning {
  font-size: 10px;
  color: var(--red);
  font-family: var(--font-data);
  margin-top: 10px;
  line-height: 1.6;
  display: flex;
  gap: 6px;
  align-items: flex-start;
}

.admin-card__warning i {
  flex-shrink: 0;
  margin-top: 1px;
}

.admin-card__footer {
  padding: 10px 16px;
  border-top: 1px solid var(--border);
}

.admin-card__footer--center {
  text-align: center;
}

.admin-link {
  font-size: 11px;
  color: var(--copper);
  font-family: var(--font-body);
  font-weight: 700;
  text-decoration: none;
}

.admin-link:hover {
  text-decoration: underline;
}

.admin-empty {
  text-align: center;
  padding: 20px;
  color: var(--text-light);
  font-size: 12px;
}

.license-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}

.license-table thead {
  background: var(--sage-bg);
  border-bottom: 1px solid var(--border);
}

.license-table th {
  padding: 9px 16px;
  text-align: left;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  color: var(--text-light);
  letter-spacing: 0.4px;
}

.license-table td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--charcoal);
}

.license-number {
  font-family: var(--font-data) !important;
  color: var(--text-light) !important;
  font-size: 11px;
  font-weight: 400 !important;
}

.license-expiry {
  font-family: var(--font-data) !important;
  font-size: 11px;
}

.license-row--expired {
  background: var(--red-light);
}

.license-row--expired .license-expiry {
  color: var(--red) !important;
  font-weight: 700 !important;
}

.license-row--warning .license-expiry {
  color: #EF6C00 !important;
  font-weight: 700 !important;
}

.compliance-hub {
  display: flex;
  flex-direction: column;
}

.compliance-hub__item {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background 0.15s;
}

.compliance-hub__item:hover {
  background: var(--sage-bg);
}

.compliance-hub__type {
  font-size: 9px;
  font-weight: 700;
  font-family: var(--font-data);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 4px;
}

.compliance-hub__content {
  flex: 1 1 0;
}

.compliance-hub__title {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  color: var(--charcoal);
  overflow-wrap: anywhere;
  word-break: break-word;
}

.compliance-hub__meta {
  font-family: var(--font-data);
  font-size: 10px;
  color: var(--text-light);
  margin-top: 2px;
}

@media (max-width: 900px) {
  .kpi-tiles { grid-template-columns: repeat(2, 1fr); }
  .admin-layout { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .admin-card__header {
    flex-wrap: wrap;
    row-gap: 8px;
  }

  .admin-card__header > form {
    width: 100%;
  }

  .admin-card__header .btn-ghost-moov,
  .admin-card__header .btn-ghost-moov--compact {
    width: 100%;
  }

  .admin-metrc-health__stat {
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
  }

  .admin-metrc-health__label,
  .admin-metrc-health__value {
    flex: none;
    text-align: left;
  }
}

/* ─── Admin Dashboard: KPI semantic color system ──────────────────────────── */
/* Neutralise the global nth-child positional colours on this page so mod
   classes have clean control over every tile's accent strip and value colour. */
.sales-portal-page--admin-dashboard .kpi-tile:nth-child(2),
.sales-portal-page--admin-dashboard .kpi-tile:nth-child(3),
.sales-portal-page--admin-dashboard .kpi-tile:nth-child(4) {
  border-top-color: var(--forest);
}
.sales-portal-page--admin-dashboard .kpi-tile:nth-child(2) .kpi-tile__value,
.sales-portal-page--admin-dashboard .kpi-tile:nth-child(3) .kpi-tile__value,
.sales-portal-page--admin-dashboard .kpi-tile:nth-child(4) .kpi-tile__value {
  color: var(--forest);
}

/* Mod classes — match the payouts page mod pattern */
.admin-dashboard-kpis__tile--license-active  { border-top-color: var(--forest); }
.admin-dashboard-kpis__tile--license-active .kpi-tile__value { color: var(--forest); }

.admin-dashboard-kpis__tile--license-expired { border-top-color: var(--red); }
.admin-dashboard-kpis__tile--license-expired .kpi-tile__value { color: var(--red); }
.admin-dashboard-kpis__tile--license-expired { background: linear-gradient(180deg, var(--red-light) 0%, #fff 60%); }

.admin-dashboard-kpis__tile--orders          { border-top-color: var(--copper); }
.admin-dashboard-kpis__tile--orders .kpi-tile__value { color: var(--copper); }

.admin-dashboard-kpis__tile--open-orders     { border-top-color: #EF6C00; }
.admin-dashboard-kpis__tile--open-orders .kpi-tile__value { color: #EF6C00; }

.admin-dashboard-kpis__tile--metrc           { border-top-color: var(--forest-mid); }
.admin-dashboard-kpis__tile--metrc .kpi-tile__value { color: var(--forest-mid); }

/* Numeric tiles: use tabular figures so counts don't jump width */
.admin-dashboard-kpis__tile--orders .kpi-tile__value,
.admin-dashboard-kpis__tile--open-orders .kpi-tile__value,
.admin-dashboard-kpis__tile--metrc .kpi-tile__value {
  font-variant-numeric: tabular-nums;
  font-family: var(--font-data);
}

/* ─── Compliance hub: class-based accent colours ─────────────────────────── */
/* The base item gets a 3-px left border; mod classes supply the colour,
   replacing the old inline style="border-left: …" approach. */
.compliance-hub__item {
  border-left: 3px solid var(--border);
}
.compliance-hub__item--sync {
  border-left-color: var(--forest);
}
.compliance-hub__item--sync .compliance-hub__type {
  color: var(--forest);
}
.compliance-hub__item--neutral {
  border-left-color: var(--sage);
}
.compliance-hub__item--neutral .compliance-hub__type {
  color: var(--text-muted);
}
.compliance-hub__item--error {
  border-left-color: var(--red);
}
.compliance-hub__item--error .compliance-hub__type {
  color: var(--red);
}

/* ─── Admin Dashboard: 768 px responsive ─────────────────────────────────── */
@media (max-width: 768px) {
  /* KPI grid → 2-col (matches sales_payouts behaviour) */
  body.sales-portal .sales-portal-page--admin-dashboard .kpi-tiles {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
  body.sales-portal .sales-portal-page--admin-dashboard .kpi-tile__value {
    font-size: 24px;
  }
  body.sales-portal .sales-portal-page--admin-dashboard .kpi-tile__sub {
    font-size: 11px;
  }

  /* Alert banner: stack vertically on narrow viewports */
  .sales-portal-page--admin-dashboard .admin-alert-banner {
    flex-wrap: wrap;
    gap: 10px;
  }
  .sales-portal-page--admin-dashboard .admin-alert-banner__cta {
    width: 100%;
    text-align: center;
    justify-content: center;
    box-sizing: border-box;
  }

  /* Admin layout collapses to single column (sidebar below main) */
  body.sales-portal .sales-portal-page--admin-dashboard .admin-layout {
    grid-template-columns: 1fr;
  }
}

/* ─── Admin Dashboard: 480 px — keep KPIs 2-col, not 1-col ──────────────── */
/* The global 480px block forces .admin-kpis .kpi-tiles to 1fr.
   For admin-dashboard the tiles are compact enough to stay 2-up. */
@media (max-width: 480px) {
  body.sales-portal .sales-portal-page--admin-dashboard .kpi-tiles {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
  body.sales-portal .sales-portal-page--admin-dashboard .kpi-tile {
    padding: 14px 12px;
  }
  body.sales-portal .sales-portal-page--admin-dashboard .kpi-tile__value {
    font-size: 20px;
  }
}

/* ─── Manifest (portal) ─── */
.manifest-page {
  max-width: 1200px;
  margin: 0 auto;
}

.manifest-page__header {
  margin-bottom: 22px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.manifest-page__title {
  font-family: var(--font-body);
  font-size: 22px;
  font-weight: 800;
  color: var(--forest);
  margin: 0 0 4px;
}

.manifest-page__subtitle {
  font-family: var(--font-data);
  font-size: 12px;
  color: var(--text-light);
  margin: 0;
}

.manifest-empty {
  display: flex;
  justify-content: center;
  padding: 32px 0 48px;
}

.manifest-empty__card {
  max-width: 480px;
  width: 100%;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 28px 24px;
  text-align: center;
  box-shadow: 0 2px 8px rgba(var(--forest-rgb), 0.05);
}

.manifest-empty__title {
  font-family: var(--font-body);
  font-size: 16px;
  font-weight: 700;
  color: var(--charcoal);
  margin-bottom: 10px;
}

.manifest-empty__body {
  font-family: var(--font-data);
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.55;
}

.manifest-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 12px rgba(var(--forest-rgb), 0.06);
}

.manifest-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 20px;
  border-bottom: 1px solid var(--border);
  background: var(--sage-bg);
}

.manifest-card__header-left { min-width: 0; flex: 1; }

.manifest-card__doc-label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--text-light);
  font-family: var(--font-data);
  margin-bottom: 4px;
}

.manifest-card__doc-number {
  font-family: var(--font-data);
  font-size: 18px;
  font-weight: 700;
  color: var(--forest);
  word-break: break-all;
}

.manifest-card__doc-meta {
  font-size: 11px;
  color: var(--text-muted);
  font-family: var(--font-data);
  margin-top: 6px;
}

.manifest-card__header-right { flex-shrink: 0; }

.manifest-card__body { padding: 0; }

.manifest-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
  border-bottom: 1px solid var(--border);
}

.manifest-info {
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 0;
  min-height: 0;
}

.manifest-info:nth-child(2n) { border-right: none; }

.manifest-info__header {
  padding: 10px 16px;
  background: var(--forest);
}

.manifest-info__title {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: #fff;
  font-family: var(--font-body);
}

.manifest-info__rows { padding: 12px 16px 14px; }

.manifest-info__row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 6px 0;
  border-bottom: 1px solid var(--border);
  font-size: 12px;
}

.manifest-info__row:last-child { border-bottom: none; }

.manifest-info__key {
  color: var(--text-light);
  font-family: var(--font-data);
  flex-shrink: 0;
}

.manifest-info__value {
  text-align: right;
  color: var(--charcoal);
  font-weight: 600;
  word-break: break-word;
}

.manifest-lines {
  padding: 18px 20px 22px;
}

.manifest-lines__header { margin-bottom: 12px; }

.manifest-lines__title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--forest);
  font-family: var(--font-body);
}

.manifest-lines__table-wrap { overflow-x: auto; }

.manifest-lines__table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}

.manifest-lines__table thead {
  background: var(--sage-bg);
  border-bottom: 1px solid var(--border);
}

.manifest-lines__table th {
  padding: 9px 12px;
  text-align: left;
  font-size: 10px;
  font-weight: 700;
  color: var(--text-light);
  letter-spacing: 0.4px;
  font-family: var(--font-body);
}

.manifest-lines__table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}

.manifest-lines__cell-code {
  font-family: var(--font-data);
  font-size: 11px;
  color: var(--text-muted);
}

.manifest-lines__cell-name { font-weight: 600; color: var(--charcoal); }

.manifest-lines__cell-thc { font-family: var(--font-data); }

.manifest-lines__totals td {
  background: var(--sage-bg);
  font-weight: 700;
  border-bottom: none;
}

.manifest-lines__totals-label {
  text-transform: uppercase;
  font-size: 10px;
  letter-spacing: 0.4px;
  color: var(--forest);
}

.manifest-lines__empty {
  text-align: center;
  color: var(--text-muted);
  padding: 24px !important;
}

.manifest-actions {
  padding: 20px;
  border-top: 1px solid var(--border);
  background: #fafbfa;
}

.manifest-actions__form {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-width: 360px;
}

.manifest-actions__primary { width: 100%; }

.manifest-actions__secondary { text-align: center; }

.manifest-actions__row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: stretch;
}

.manifest-actions__download-form,
.manifest-actions__reset-form {
  flex: 1 1 160px;
  min-width: 140px;
}

.manifest-actions__download-form .btn-primary-moov,
.manifest-actions__reset-form .btn-ghost-moov {
  width: 100%;
}

.manifest-status-banner {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 8px;
  background: var(--forest-light);
  border: 1px solid #A8C9BE;
  margin-bottom: 16px;
}

.manifest-status-banner__icon {
  color: var(--forest);
  font-size: 20px;
  flex-shrink: 0;
}

.manifest-status-banner__body { min-width: 0; }

.manifest-status-banner__title {
  font-size: 13px;
  font-weight: 700;
  color: var(--forest);
  font-family: var(--font-body);
}

.manifest-status-banner__meta {
  font-size: 11px;
  color: var(--text-muted);
  font-family: var(--font-data);
  margin-top: 4px;
  line-height: 1.45;
}

@media (max-width: 900px) {
  .manifest-grid { grid-template-columns: 1fr; }
  .manifest-info { border-right: none; }
  .manifest-info:nth-child(2n) { border-right: none; }
}

@media (max-width: 576px) {
  .manifest-card__header { flex-direction: column; }
  .manifest-actions__row { flex-direction: column; }
}

/* ─── Order detail (account order info) ─── */
.order-detail-page { max-width: 1100px; margin: 0 auto; }

.order-detail__back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text-muted);
  text-decoration: none;
  margin-bottom: 14px;
  font-family: var(--font-body);
}

.order-detail__back:hover { color: var(--copper); text-decoration: none; }

.order-detail__title {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 700;
  color: var(--charcoal);
  margin: 0 0 16px;
}

.order-detail__meta-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 12px 20px;
  margin-bottom: 8px;
}

.order-detail__meta-item { min-width: 0; }

.order-detail__meta-label {
  display: block;
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-light);
  font-family: var(--font-data);
  margin-bottom: 4px;
}

.order-detail__meta-value {
  font-size: 13px;
  font-weight: 600;
  color: var(--charcoal);
  font-family: var(--font-body);
  word-break: break-word;
}

.order-detail__addresses {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 16px;
  margin-top: 8px;
}

.order-detail__address-card {
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
}

.order-detail__address-title {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--forest);
  margin: 0 0 10px;
  font-family: var(--font-body);
}

.order-detail__address-body {
  font-size: 12px;
  line-height: 1.55;
  color: var(--charcoal);
}

.order-detail__table-wrap { margin-top: 8px; }

.order-detail__comment {
  margin-top: 16px;
  padding: 14px 16px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--sage-bg);
}

.order-detail__comment-title {
  font-size: 11px;
  font-weight: 700;
  color: var(--forest);
  margin: 0 0 8px;
}

.order-detail__comment-body {
  font-size: 12px;
  color: var(--text-muted);
  margin: 0;
  line-height: 1.5;
}

.order-detail__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid var(--border);
}

.order-detail__metrc {
  margin-top: 16px;
  padding: 14px 16px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: #fff;
}

.order-detail__metrc-title {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: var(--forest);
  margin: 0 0 10px;
  font-family: var(--font-body);
}

.order-detail__metrc-rows { display: grid; gap: 8px; }

.order-detail__metrc-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  font-size: 12px;
}

.order-detail__metrc-key { color: var(--text-light); font-family: var(--font-data); }

.order-detail__metrc-val {
  font-weight: 600;
  text-align: right;
  word-break: break-word;
  font-family: var(--font-data);
}

.order-detail__metrc-error {
  margin-top: 10px;
  font-size: 11px;
  color: var(--red, #c0392b);
  line-height: 1.45;
}

.order-detail__action-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: var(--radius-md);
  border: 1.5px solid var(--border);
  background: #fff;
  color: var(--text-muted);
  text-decoration: none;
  transition: var(--transition);
}

.order-detail__action-icon:hover {
  border-color: var(--forest);
  color: var(--forest);
  background: var(--forest-light);
}

.order-detail__action-icon--danger:hover {
  border-color: var(--red, #c0392b);
  color: var(--red, #c0392b);
}

/* ─── Cart Page ─── */
.cart-page {
  max-width: 1000px;
  margin: 0 auto;
}

.cart-page__header {
  margin-bottom: 24px;
}

.cart-page__title {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 700;
  color: var(--charcoal);
  margin: 0 0 4px;
}

.cart-page__subtitle {
  font-size: 11px;
  color: var(--text-light);
  font-family: var(--font-data);
  margin: 0;
}

.cart-license-banner {
  border-radius: 6px;
  padding: 11px 16px;
  margin-bottom: 22px;
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 11px;
  font-family: var(--font-data);
  font-weight: 600;
}

.cart-license-banner--valid {
  background: var(--forest-light);
  border: 1px solid #A8C9BE;
  color: var(--forest);
}

.cart-license-banner--warning {
  background: rgba(var(--copper-rgb),0.12);
  border: 1px solid var(--copper);
  color: var(--forest);
}
.cart-license-banner__link {
  margin-left: 12px;
  font-weight: 700;
  color: var(--copper);
  text-decoration: underline;
  white-space: nowrap;
}
.cart-license-banner__link:hover {
  color: var(--forest);
}
.cart-license-banner--invalid {
  background: var(--red-light);
  border: 1px solid var(--red);
  color: var(--red);
}

.cart-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 24px;
  align-items: start;
}

.cart-layout__items {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.cart-line-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}

.cart-line-table thead {
  background: var(--sage-bg);
  border-bottom: 1px solid var(--border);
}

.cart-line-table th {
  padding: 9px 16px;
  text-align: left;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  color: var(--text-light);
  letter-spacing: 0.4px;
}

.cart-line-table td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}

.cart-product-cell {
  display: flex;
  gap: 10px;
  align-items: center;
}

.cart-product-cell__img img {
  width: 40px;
  height: 40px;
  object-fit: cover;
  border-radius: 4px;
  border: 1px solid var(--border);
}

.cart-product-cell__name {
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--charcoal);
  text-decoration: none;
  font-size: 12px;
  display: block;
}

.cart-product-cell__name:hover {
  color: var(--forest);
}

.cart-product-cell__sku {
  font-size: 9px;
  color: var(--text-light);
  font-family: var(--font-data);
  margin-top: 2px;
}

.cart-line-table__batch {
  font-family: var(--font-data);
  color: var(--text-light);
  font-size: 11px;
}

.cart-line-table__price {
  font-family: var(--font-data);
  color: var(--charcoal);
}

.cart-line-table__discount {
  font-size: 10px;
  color: var(--text-light);
}

.cart-line-table__linedisc {
  vertical-align: middle;
  white-space: nowrap;
}

.cart-line-discount-pct {
  max-width: 5.25rem;
  min-width: 4rem;
  padding: 4px 6px;
  font-size: 12px;
}

.cart-line-table__thc {
  font-family: var(--font-data);
  font-weight: 700;
  color: var(--copper);
}

.cart-line-table__total {
  font-family: var(--font-data);
  font-weight: 700;
  color: var(--charcoal);
}

.cart-qty-inline {
  display: flex;
  align-items: center;
  gap: 4px;
}

.cart-qty-inline__btn {
  width: 26px;
  height: 26px;
  border: 1.5px solid var(--border);
  border-radius: 4px;
  background: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--charcoal);
  font-size: 10px;
  padding: 0;
}

.cart-qty-inline__btn:hover {
  border-color: var(--forest);
  color: var(--forest);
}

.cart-qty-inline__val {
  width: 44px;
  text-align: center;
  font-family: var(--font-data);
  font-size: 12px;
  font-weight: 700;
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 4px 2px;
  -moz-appearance: textfield;
}

.cart-qty-inline__val::-webkit-outer-spin-button,
.cart-qty-inline__val::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.cart-qty-inline__actions {
  display: flex;
  gap: 4px;
  margin-top: 6px;
}

.cart-qty-inline__update,
.cart-qty-inline__remove {
  width: 24px;
  height: 24px;
  border: none;
  border-radius: 4px;
  background: transparent;
  cursor: pointer;
  font-size: 11px;
  color: var(--text-light);
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cart-qty-inline__update:hover { color: var(--forest); }
.cart-qty-inline__remove:hover { color: var(--red); }

.cart-tax-card {
  background: #F3F4F6;
  border-radius: 8px;
  border-left: 4px solid var(--forest);
  padding: 18px 20px;
  box-shadow: 0 2px 8px rgba(var(--forest-rgb), 0.06);
}

.cart-tax-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}

.cart-tax-card__title {
  font-size: 11px;
  font-weight: 700;
  color: var(--forest);
  font-family: var(--font-body);
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

.cart-tax-card__badge {
  font-size: 9px;
  background: #FFF8E1;
  color: #7A5A00;
  border: 1px solid #FFE082;
  border-radius: 999px;
  padding: 3px 10px;
  font-family: var(--font-data);
  font-weight: 700;
}

.cart-tax-card__rows {
  margin-bottom: 8px;
}

.cart-tax-card__row {
  display: flex;
  justify-content: space-between;
  padding: 5px 0;
  border-bottom: 1px solid var(--border);
  font-size: 11px;
  font-family: var(--font-data);
  color: var(--text-light);
}

.cart-tax-card__row span:last-child {
  color: var(--charcoal);
}

.cart-tax-card__total-row {
  display: flex;
  justify-content: space-between;
  padding-top: 12px;
  margin-top: 2px;
}

.cart-tax-card__total-label {
  font-size: 13px;
  font-weight: 700;
  color: var(--charcoal);
  font-family: var(--font-body);
}

.cart-tax-card__total-value {
  font-size: 18px;
  font-weight: 800;
  color: var(--forest);
  font-family: var(--font-data);
}

.cart-tax-card__disclaimer {
  font-size: 9px;
  color: var(--text-light);
  font-family: var(--font-data);
  margin-top: 8px;
  line-height: 1.6;
}

.cart-summary__row {
  display: flex;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  font-size: 12px;
  font-family: var(--font-data);
}

.cart-summary__row span:first-child {
  color: var(--text-light);
}

.cart-summary__row span:last-child {
  color: var(--charcoal);
}

.cart-summary__total {
  display: flex;
  justify-content: space-between;
  padding: 12px 0 4px;
  border-top: 2px solid var(--charcoal);
  margin-top: 4px;
}

.cart-summary__total span:first-child {
  font-size: 14px;
  font-weight: 700;
  color: var(--charcoal);
  font-family: var(--font-body);
}

.cart-summary__total span:last-child {
  font-size: 18px;
  font-weight: 800;
  color: var(--charcoal);
  font-family: var(--font-data);
}

.cart-summary__payment {
  margin-top: 16px;
}

.cart-summary__payment-label {
  font-size: 10px;
  font-weight: 700;
  color: var(--forest);
  font-family: var(--font-body);
  letter-spacing: 0.6px;
  text-transform: uppercase;
  display: block;
  margin-bottom: 6px;
}

.cart-summary__payment-select {
  width: 100%;
  padding: 10px 12px;
  border: 1.5px solid var(--border);
  border-radius: 5px;
  font-size: 12px;
  font-family: var(--font-data);
  background: var(--bg);
  outline: none;
}

.cart-summary__payment-select:focus {
  border-color: var(--forest);
}

.cart-summary__submit {
  width: 100%;
  justify-content: center;
  margin-top: 16px;
  min-height: 46px;
  display: flex;
  align-items: center;
  gap: 6px;
  text-decoration: none;
}

.cart-summary__meta {
  font-size: 9px;
  color: var(--text-light);
  text-align: center;
  margin-top: 10px;
  font-family: var(--font-data);
  line-height: 1.6;
}

.cart-summary__continue {
  display: block;
  text-align: center;
  margin-top: 12px;
  font-size: 11px;
  color: var(--copper);
  font-family: var(--font-body);
  font-weight: 600;
  text-decoration: none;
}

.cart-summary__continue:hover {
  text-decoration: underline;
}

.cart-empty {
  text-align: center;
  padding: 80px 20px;
}

.cart-empty__title {
  font-family: var(--font-body);
  font-size: 20px;
  font-weight: 700;
  color: var(--text-light);
  margin-bottom: 20px;
}

@media (max-width: 900px) {
  .cart-layout { grid-template-columns: 1fr; }
}

/* Order history page */
.order-page__header {
  margin-bottom: 24px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.order-page__title {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 700;
  color: var(--charcoal);
  margin: 0 0 4px;
}

.order-page__subtitle {
  font-size: 11px;
  color: var(--text-light);
  font-family: var(--font-data);
  margin: 0;
}

.order-tabs {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--border);
  margin-bottom: 20px;
}

.order-tab-btn {
  padding: 10px 18px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  transition: var(--transition);
  white-space: nowrap;
}

.order-tab-btn:hover {
  color: var(--forest);
}

.order-tab-btn.is-active {
  color: var(--forest);
  border-bottom-color: var(--copper);
}

.order-tab-panel {
  display: none;
}

.order-tab-panel.is-active {
  display: block;
}

.order-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}

.order-table thead {
  background: var(--sage-bg);
  border-bottom: 1px solid var(--border);
}

.order-table th {
  padding: 9px 14px;
  text-align: left;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  color: var(--text-light);
  letter-spacing: 0.4px;
  white-space: nowrap;
}

.order-table td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
}

.order-table tbody tr:last-child td {
  border-bottom: none;
}

.order-table tbody tr:hover td {
  background: var(--sage-bg);
}

.order-id {
  font-family: var(--font-data);
  font-weight: 700;
  color: var(--charcoal);
}

.order-status {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  border-radius: var(--radius-pill);
  padding: 3px 10px;
  font-family: var(--font-data);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.4px;
  background: var(--sage-bg);
  color: var(--forest);
  border: 1px solid #A8C9BE;
}

.order-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

.order-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: var(--radius-md);
  border: 1.5px solid var(--border);
  background: var(--bg);
  color: var(--text-muted);
  text-decoration: none;
  transition: var(--transition);
  font-size: 12px;
}

.order-action-btn:hover {
  border-color: var(--forest);
  color: var(--forest);
  background: var(--forest-light);
}

.order-filter-bar {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: flex-end;
  margin-bottom: 16px;
}

.order-filter-group {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.order-filter-group--grow {
  flex: 1 1 180px;
}

.order-filter-label {
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  color: var(--text-light);
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

.order-filter-input {
  padding: 8px 12px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--charcoal);
  background: var(--bg);
  transition: border-color 0.15s;
}

.order-filter-input:focus {
  outline: none;
  border-color: var(--copper);
}

.order-filter-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}

.order-empty {
  text-align: center;
  padding: 48px 20px;
  color: var(--text-light);
}

.order-empty i {
  font-size: 32px;
  margin-bottom: 12px;
  display: block;
  color: var(--border);
}

.order-empty p {
  font-family: var(--font-body);
  font-size: 13px;
}

.order-pagination {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 0 0;
  font-size: 11px;
  color: var(--text-light);
  font-family: var(--font-data);
}

.order-count-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  padding: 0 7px;
  border-radius: 11px;
  background: var(--copper);
  color: var(--copper-contrast);
  font-family: var(--font-data);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.3px;
}

.order-status--pending {
  background: #FFF8EE;
  color: #B06A00;
  border-color: #F5C97A;
}

.table-responsive-stack {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.font-data { font-family: var(--font-data); }
.font-bold { font-weight: 700; }
.text-muted { color: var(--text-muted); }

@media (max-width: 768px) {
  .order-tabs { overflow-x: auto; white-space: nowrap; }

  .order-table--stack thead { display: none; }

  .order-table--stack tbody tr {
    display: block;
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    margin-bottom: 12px;
    padding: 4px 0;
    background: var(--bg);
    box-shadow: 0 1px 4px rgba(0,0,0,0.04);
  }

  .order-table--stack tbody tr:hover td {
    background: transparent;
  }

  .order-table--stack td {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 14px;
    border-bottom: 1px solid var(--border);
    font-size: 12px;
    text-align: right;
  }

  .order-table--stack tbody tr td:last-child {
    border-bottom: none;
  }

  .order-table--stack td::before {
    content: attr(data-label);
    font-family: var(--font-body);
    font-size: 10px;
    font-weight: 700;
    color: var(--text-light);
    letter-spacing: 0.4px;
    text-transform: uppercase;
    text-align: left;
    flex-shrink: 0;
    margin-right: 8px;
  }

  .order-table--stack td[data-label="Actions"] {
    justify-content: flex-end;
    gap: 8px;
  }

  .order-table--stack td[data-label="Actions"]::before {
    display: none;
  }

  .order-pagination {
    flex-direction: column;
    align-items: flex-start;
    gap: 6px;
  }
}

@media (max-width: 480px) {
  .order-filter-bar {
    flex-direction: column;
  }
  .order-filter-group--grow {
    width: 100%;
  }
  .order-filter-actions {
    flex-wrap: wrap;
  }
}

/* Checkout page (onepagecheckout) — Forest & Copper */
.checkout-page__header {
  margin-bottom: 24px;
}

.checkout-page__title {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 700;
  color: var(--charcoal);
  margin: 0 0 4px;
}

.checkout-page__subtitle {
  font-size: 11px;
  color: var(--text-light);
  font-family: var(--font-data);
  margin: 0;
}

.checkout-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.checkout-form .admin-card__body .field + .field {
  margin-top: 16px;
}

.checkout-disclaimer {
  font-size: 10px;
  color: var(--text-muted);
  font-family: var(--font-data);
  margin: 8px 0 0;
  line-height: 1.5;
}

.checkout-divider {
  border: none;
  border-top: 1px solid var(--border);
  margin: 20px 0;
}

.checkout-confirm-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  justify-content: flex-end;
}

.checkout-confirm-row .btn-primary-moov,
.checkout-confirm-row .btn-ghost-moov {
  min-height: 44px;
  font-size: 13px;
}

.checkout-subinfo {
  margin-top: 16px;
}

.checkout-alert {
  border-radius: var(--radius-md);
  font-size: 12px;
}

/* ── Checkout page (checkout/checkout route) ── */

.checkout-page {
  padding-top: 8px;
  padding-bottom: 48px;
}

.checkout-page__alert {
  margin-bottom: 20px;
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: 13px;
}

.checkout-page__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 24px;
  flex-wrap: wrap;
}

.checkout-page__header-content {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.checkout-page__title {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 700;
  color: var(--charcoal);
  margin: 0;
  line-height: 1.2;
}

.checkout-page__subtitle {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-muted);
  margin: 0;
}

.checkout-page__back-link {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 14px;
  background: transparent;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-body);
  text-decoration: none;
  transition: var(--transition);
  white-space: nowrap;
  flex-shrink: 0;
  align-self: center;
}

.checkout-page__back-link:hover {
  border-color: var(--forest-border);
  color: var(--forest);
  background: var(--forest-light);
  text-decoration: none;
}

.checkout-layout {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 1fr);
  gap: 24px;
  align-items: flex-start;
}

.checkout-layout__main {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-width: 0;
}

.checkout-layout__summary {
  min-width: 0;
  position: sticky;
  top: 80px;
}

/* Admin card header hint */
.admin-card__header-hint {
  font-family: var(--font-data);
  font-size: 9px;
  font-weight: 600;
  color: rgba(255,255,255,0.6);
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

/* Payment panel inside checkout */
.checkout-payment-panel {
  padding-top: 12px;
}

/* Override Bootstrap form controls inside checkout admin-cards */
#checkout-checkout .admin-card .form-control {
  font-family: var(--font-body) !important;
  font-size: 13px !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--radius-md) !important;
  background: var(--bg) !important;
  color: var(--charcoal) !important;
  transition: border-color 0.15s !important;
  box-shadow: none !important;
  height: auto !important;
  padding: 10px 13px !important;
}

#checkout-checkout .admin-card .form-control:focus {
  border-color: var(--copper) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(var(--copper-rgb),0.12) !important;
}

#checkout-checkout .admin-card .form-group label,
#checkout-checkout .admin-card .control-label {
  font-family: var(--font-body) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--forest) !important;
  letter-spacing: 0.5px !important;
  text-transform: uppercase !important;
  margin-bottom: 5px !important;
}

#checkout-checkout .admin-card .form-group {
  margin-bottom: 14px;
}

#checkout-checkout .admin-card .radio label,
#checkout-checkout .admin-card .checkbox label {
  font-family: var(--font-body) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  color: var(--text-body) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

/* Order notes textarea */
.checkout-notes-input {
  width: 100%;
  resize: vertical;
  min-height: 80px;
  padding: 11px 14px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--charcoal);
  background: var(--bg);
  transition: border-color 0.15s;
  appearance: none;
  line-height: 1.5;
  box-sizing: border-box;
}

.checkout-notes-input:focus {
  outline: none;
  border-color: var(--copper);
  box-shadow: 0 0 0 3px rgba(var(--copper-rgb),0.12);
}

.checkout-notes-input::placeholder {
  color: var(--text-light);
}

/* Collapsible order items header */
.checkout-items-header {
  cursor: default;
}

.checkout-items-toggle {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 5px 12px;
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.25);
  border-radius: var(--radius-md);
  color: #fff;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.3px;
  cursor: pointer;
  transition: var(--transition);
  line-height: 1;
}

.checkout-items-toggle:hover {
  background: rgba(255,255,255,0.2);
}

.checkout-items-toggle__icon {
  font-size: 10px;
  transition: transform 0.2s ease;
}

/* Line items table */
.checkout-line-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-body);
  font-size: 13px;
}

.checkout-line-table thead tr {
  background: var(--bg);
  border-bottom: 2px solid var(--border);
}

.checkout-line-table th {
  padding: 10px 14px;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--text-muted);
  white-space: nowrap;
}

.checkout-line-table td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
  color: var(--text-body);
}

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

.checkout-line-table tbody tr:hover td {
  background: var(--sage-bg);
}

.checkout-line-table__name {
  font-weight: 600;
  color: var(--charcoal);
  text-decoration: none;
  transition: color 0.15s;
}

.checkout-line-table__name:hover {
  color: var(--copper);
}

.checkout-line-table__option {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 2px;
}

.checkout-line-table__msg {
  font-size: 11px;
  color: var(--red);
  margin-top: 4px;
}

.checkout-line-table tfoot {
  border-top: 2px solid var(--border);
}

.checkout-line-table__foot-row td {
  padding: 8px 14px;
  border-bottom: none;
  font-family: var(--font-body);
  font-size: 13px;
}

.checkout-line-table__total-label {
  font-weight: 600;
  color: var(--text-body);
}

.checkout-line-table__foot-row:last-child .checkout-line-table__total-label,
.checkout-line-table__foot-row:last-child .checkout-line-table__total-val {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 700;
  color: var(--forest);
}

/* Order summary sidebar card */
.checkout-summary-card {
  box-shadow: var(--shadow-hover);
}

.checkout-summary__row {
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between !important;
  align-items: center !important;
  width: 100%;
  box-sizing: border-box;
  gap: 12px;
  padding: 7px 0;
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-body);
  border-bottom: 1px solid var(--border);
}

.checkout-summary__row:last-of-type {
  border-bottom: none;
}

.checkout-summary__row--total {
  display: flex !important;
  flex-direction: row !important;
  justify-content: space-between !important;
  align-items: center !important;
  width: 100%;
  box-sizing: border-box;
  gap: 12px;
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 700;
  color: var(--forest);
  border-top: 2px solid var(--border);
  border-bottom: none;
  margin-top: 4px;
  padding-top: 12px;
}

.checkout-totals-summary {
  padding: 1rem !important;
  overflow: visible !important;
}

.checkout-summary__label {
  color: var(--text-muted);
  font-size: 12px;
  flex: 0 1 auto;
  min-width: 0;
  text-align: left;
}

.checkout-summary__row--total .checkout-summary__label,
.checkout-summary__row--total .checkout-summary__value {
  color: var(--forest);
  font-size: 18px;
  font-weight: 700;
}

.checkout-summary__value {
  font-weight: 600;
  color: var(--charcoal);
  font-family: var(--font-data);
  flex: 0 0 auto;
  margin-left: auto;
  text-align: right;
  white-space: nowrap;
}

.checkout-summary__divider {
  border: none;
  border-top: 1px solid var(--border);
  margin: 16px 0 12px;
}

.checkout-summary__actions {
  margin-bottom: 12px;
}

.checkout-summary__submit {
  width: 100%;
  height: 48px;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.3px;
  border-radius: var(--radius-md);
}

.checkout-summary__meta {
  font-family: var(--font-data);
  font-size: 10px;
  color: var(--text-light);
  text-align: center;
  margin: 8px 0;
  line-height: 1.5;
}

.checkout-summary__meta i {
  color: var(--forest);
  margin-right: 2px;
}

.checkout-summary__back {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-top: 12px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted);
  text-decoration: none;
  transition: color 0.15s;
}

.checkout-summary__back:hover {
  color: var(--forest);
  text-decoration: none;
}

/* Bambora payment block inside checkout admin-card */
#checkout-checkout .checkout-payment-bamb {
  padding: 0;
}

#checkout-checkout .checkout-payment-bamb__legend {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: var(--forest);
  margin-bottom: 12px;
}

#checkout-checkout .checkout-payment-bamb__modes {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

#checkout-checkout .checkout-payment-bamb__mode {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 14px;
  border: 1.5px solid var(--border);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: var(--transition);
  background: var(--bg);
}

#checkout-checkout .checkout-payment-bamb__mode:hover {
  border-color: var(--copper-border);
  background: var(--copper-light);
}

#checkout-checkout .checkout-payment-bamb__mode.is-selected {
  border-color: var(--copper);
  background: var(--copper-light);
}

#checkout-checkout .checkout-payment-bamb__mode input[type="radio"] {
  accent-color: var(--copper);
  width: 15px;
  height: 15px;
  flex-shrink: 0;
}

#checkout-checkout .checkout-payment-bamb__mode-text {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--charcoal);
}

#checkout-checkout .checkout-payment-bamb__panel {
  background: var(--sage-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 16px;
  margin-top: 4px;
}

#checkout-checkout .checkout-payment-bamb__panel-title {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: var(--text-muted);
  margin-bottom: 14px;
}

#checkout-checkout .checkout-payment-bamb__field-label {
  font-family: var(--font-body) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--forest) !important;
  letter-spacing: 0.5px !important;
  text-transform: uppercase !important;
  margin-bottom: 5px !important;
  display: block;
}

#checkout-checkout .checkout-payment-bamb__columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

/* Shipping address inside checkout */
#checkout-checkout .admin-card .shipping-existing-address {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--text-body);
  line-height: 1.6;
}

/* Breadcrumb override for checkout */
#checkout-checkout + .breadcrumb,
.checkout-page ~ .breadcrumb {
  font-size: 12px;
}

/* Responsive */
@media (max-width: 991px) {
  .checkout-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .checkout-layout__summary {
    position: static;
    order: -1;
  }
}

@media (max-width: 640px) {
  .checkout-page__header {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }

  .checkout-page__title {
    font-size: 22px;
  }

  .checkout-page__back-link {
    align-self: flex-start;
  }

  .checkout-line-table th,
  .checkout-line-table td {
    padding: 10px 10px;
    font-size: 12px;
  }

  .checkout-items-toggle {
    font-size: 10px;
    padding: 4px 10px;
  }

  #checkout-checkout .checkout-payment-bamb__columns {
    grid-template-columns: 1fr;
  }
}

/* ── Account hub ── */

.account-hub {
  max-width: 840px;
  margin: 0 auto;
  padding: 32px 20px 48px;
}

.account-overview {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 16px 24px;
  padding: 18px 20px;
  margin-bottom: 24px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: var(--card-bg, #fff);
  box-shadow: 0 1px 6px rgba(var(--forest-rgb), 0.04);
}

.account-overview__main { flex: 1 1 200px; min-width: 0; }

.account-overview__name {
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 4px;
}

.account-overview__meta {
  font-size: 12px;
  color: var(--text-muted);
  font-family: var(--font-data);
}

.account-overview__aside {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
}

@media (max-width: 576px) {
  .account-overview { flex-direction: column; align-items: flex-start; }
  .account-overview__aside { align-items: flex-start; }
}

.account-hub__title {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 28px;
}

.account-hub__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 14px;
  margin-bottom: 36px;
}

.account-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 20px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: var(--card-bg, #fff);
  text-decoration: none;
  color: var(--text);
  transition: border-color .15s, box-shadow .15s;
}

.account-card:hover {
  border-color: var(--copper);
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
  text-decoration: none;
  color: var(--text);
}

.account-card--wide {
  grid-column: 1 / -1;
}

.account-card__icon {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-sm);
  background: var(--copper-light);
  color: var(--copper);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  flex-shrink: 0;
}

.account-card__body {
  flex: 1;
  min-width: 0;
}

.account-card__title {
  font-weight: 600;
  font-size: 14px;
  line-height: 1.3;
}

.account-card__desc {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 2px;
}

.account-card__arrow {
  color: var(--text-muted);
  font-size: 12px;
  flex-shrink: 0;
  transition: transform .15s;
}

.account-card:hover .account-card__arrow {
  transform: translateX(3px);
  color: var(--copper);
}

.account-hub__section {
  margin-top: 12px;
  padding: 24px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  background: var(--card-bg, #fff);
}

.account-hub__section-title {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 6px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.account-hub__section-title .fa {
  color: var(--copper);
}

.account-hub__section-desc {
  font-size: 13px;
  color: var(--text-muted);
  margin: 0 0 20px;
}

.theme-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: 10px;
}

.theme-grid__option {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 14px 8px 12px;
  border-radius: var(--radius-md);
  border: 2px solid var(--border);
  background: transparent;
  cursor: pointer;
  transition: border-color .15s, box-shadow .15s;
  position: relative;
}

.theme-grid__option:hover {
  border-color: var(--copper);
}

.theme-grid__option.is-active {
  border-color: var(--copper);
  box-shadow: 0 0 0 2px var(--copper-light);
}

.theme-grid__swatch {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  flex-shrink: 0;
  border: 2px solid rgba(0,0,0,.08);
}

.theme-grid__label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text);
  text-align: center;
  line-height: 1.2;
}

.theme-grid__check {
  position: absolute;
  top: 6px;
  right: 6px;
  font-size: 10px;
  color: var(--copper);
  opacity: 0;
  transition: opacity .15s;
}

.theme-grid__option.is-active .theme-grid__check {
  opacity: 1;
}

@media (max-width: 576px) {
  .account-hub { padding: 20px 16px 32px; }
  .account-hub__title { font-size: 22px; }
  .account-hub__grid { grid-template-columns: 1fr; }
  .theme-grid { grid-template-columns: repeat(3, 1fr); }
}

/* License card — expired state */
.account-card--license-expired {
  border-color: var(--red);
  background: var(--red-light);
}
.account-card--license-expired:hover {
  border-color: var(--red);
  box-shadow: 0 2px 8px rgba(192, 57, 43, 0.12);
}
.account-card__icon--license {
  background: var(--copper-light);
  color: var(--copper);
}
.account-card__icon--expired {
  background: #FFEBEE;
  color: var(--red);
}
.account-card__badge {
  display: inline-flex;
  align-items: center;
  border-radius: var(--radius-pill);
  padding: 2px 9px;
  font-family: var(--font-data);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.4px;
  white-space: nowrap;
  flex-shrink: 0;
}
.account-card__badge--expired {
  background: #FFEBEE;
  color: var(--red);
  border: 1px solid #EF9A9A;
}

/* Inline update-license CTA inside account overview */
.account-overview__license-cta {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  color: var(--copper);
  text-decoration: none;
  border: 1px solid var(--copper-border);
  border-radius: var(--radius-pill);
  padding: 3px 10px;
  background: var(--copper-light);
  transition: background .15s, border-color .15s;
}
.account-overview__license-cta:hover {
  background: var(--copper-border);
  border-color: var(--copper);
  text-decoration: none;
  color: var(--copper-active);
}
.account-overview__license-cta--urgent {
  background: #FFEBEE;
  border-color: #EF9A9A;
  color: var(--red);
}
.account-overview__license-cta--urgent:hover {
  background: #FFCDD2;
  border-color: var(--red);
  color: var(--red);
}

/* License verify alert banner */
.license-verify__alert {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 18px;
  margin-bottom: 20px;
  border-radius: var(--radius-md);
  background: #FFEBEE;
  border: 1px solid #EF9A9A;
}
.license-verify__alert-icon {
  color: var(--red);
  font-size: 18px;
  flex-shrink: 0;
  margin-top: 1px;
}
.license-verify__alert-title {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 700;
  color: var(--red);
  margin-bottom: 3px;
}
.license-verify__alert-body {
  font-size: 12px;
  color: #7B1C1C;
  line-height: 1.5;
}

/* Account sub-pages (address, password, etc.) */
.account-hub__back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--text-muted);
  text-decoration: none;
  margin-bottom: 12px;
  transition: color .15s;
}
.account-hub__back:hover {
  color: var(--copper);
  text-decoration: none;
}
.account-hub__back .fa { font-size: 10px; }

.account-hub__empty {
  text-align: center;
  padding: 32px 20px;
}
.account-hub__empty-icon {
  font-size: 36px;
  color: var(--text-muted);
  margin-bottom: 12px;
  display: block;
}
.account-hub__empty-text {
  font-size: 14px;
  color: var(--text-muted);
  margin: 0;
}

.account-hub__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid var(--border);
}

.account-address-cards {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.account-address-card {
  border: 1px solid var(--border);
  border-radius: var(--radius-md, 10px);
  background: var(--surface, #fff);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
  overflow: hidden;
}
.account-address-card__body {
  padding: 18px 20px;
  font-size: 14px;
  line-height: 1.55;
  color: var(--text);
  font-family: var(--font-body);
}
.account-address-card__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  padding: 12px 16px;
  border-top: 1px solid var(--border);
  background: var(--surface-alt, #fafafa);
}
.account-address-card__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 40px;
  padding: 0 16px;
  border-radius: var(--radius-md, 8px);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  transition: var(--transition, color 0.15s, background 0.15s, border-color 0.15s);
  border: 2px solid var(--forest);
  color: var(--forest);
  background: #fff;
}
.account-address-card__btn .fa { font-size: 14px; }
.account-address-card__btn:hover {
  background: var(--forest);
  color: #fff;
  text-decoration: none;
}
.account-address-card__btn--remove {
  border-color: rgba(180, 40, 40, 0.45);
  color: #b42828;
}
.account-address-card__btn--remove:hover {
  background: #b42828;
  border-color: #b42828;
  color: #fff;
}
@media (max-width: 576px) {
  .account-address-card__actions {
    flex-direction: column;
    align-items: stretch;
  }
  .account-address-card__btn {
    width: 100%;
  }
}

.address-table-wrap { overflow-x: auto; }
.address-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.address-table__th {
  text-align: left;
  padding: 12px 16px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 10px;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--forest);
  border-bottom: 1px solid var(--border);
}
.address-table__th--actions {
  width: 140px;
  text-align: center;
}
.address-table__cell {
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  vertical-align: middle;
}
.address-table__cell--actions {
  text-align: center;
  white-space: nowrap;
}
.address-table__action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: var(--radius-sm);
  color: var(--text-muted);
  margin: 0 2px;
  transition: color .15s, background .15s;
}
.address-table__action:hover {
  color: var(--copper);
  background: var(--copper-light);
}
.address-table__action--danger:hover { color: var(--red, #c00); }
.address-table__viewonly {
  font-size: 11px;
  color: var(--text-muted);
}
.address-table__viewonly a { color: var(--copper); }

.account-form__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 20px;
}
.account-form .account-hub__section .field { margin-bottom: 16px; }
.account-form__grid .field { margin-bottom: 16px; }
.account-form__radio-group,
.account-form__checkbox-group {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 20px;
  margin-top: 6px;
}
.account-form__radio,
.account-form__checkbox {
  font-size: 13px;
  color: var(--text);
  cursor: pointer;
  font-weight: 400;
}
.account-form__default {
  font-size: 13px;
  color: var(--text);
  cursor: pointer;
  font-weight: 400;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.account-form__input-group {
  display: flex;
  gap: 8px;
  align-items: center;
}
.account-form__input-group .field__input { flex: 1; min-width: 0; }
.field__required { color: var(--red, #c00); }
.field__suffix { display: flex; align-items: center; padding: 0 12px; color: var(--text-muted); font-size: 12px; }

@media (max-width: 576px) {
  .account-form__grid { grid-template-columns: 1fr; }
  .address-table__th--actions { width: 100px; }
}

.wishlist-table__thumb { max-width: 60px; max-height: 60px; object-fit: contain; }
.address-table__th--img { width: 80px; }
.address-table__cell--img { width: 80px; }
.address-table__th--right,
.address-table__cell--right { text-align: right; }
.address-table__cell--muted { color: var(--text-muted); }
.address-table__link { color: var(--text); font-weight: 500; }
.address-table__link:hover { color: var(--copper); }
.wishlist-table__special { color: var(--copper); font-weight: 600; }

/* Sales staff portal */
[x-cloak] {
  display: none !important;
}
.sales-portal-nav {
  background: var(--forest-dark, #1a2e1f);
  color: var(--white, #fff);
  margin-bottom: 0;
  position: relative;
  z-index: 530;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.sales-portal-nav__inner {
  max-width: 1480px;
  margin: 0 auto;
  padding: 0 clamp(16px, 3vw, 28px);
  display: flex;
  align-items: center;
  gap: 0 24px;
  min-height: 48px;
}
.sales-portal-nav__brand {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 140px;
}
.sales-portal-nav__title {
  font-weight: 700;
  font-size: 15px;
}
.sales-portal-nav__user {
  font-size: 12px;
  opacity: 0.85;
}
.sales-portal-nav__links {
  display: flex;
  flex-wrap: nowrap;
  gap: 0;
  list-style: none;
  margin: 0;
  padding: 0;
  min-width: 0;
  align-self: stretch;
  flex-shrink: 0;
}
.sales-portal-nav__item {
  display: flex;
  align-items: stretch;
}
.sales-portal-nav__link {
  display: inline-flex;
  align-items: center;
  color: rgba(255, 255, 255, 0.72);
  text-decoration: none;
  font-size: 13.5px;
  font-weight: 500;
  padding: 0 16px;
  position: relative;
  white-space: nowrap;
  transition: color 0.15s;
  letter-spacing: 0.01em;
}
.sales-portal-nav__link::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 12px;
  right: 12px;
  height: 2px;
  background: var(--copper);
  border-radius: 2px 2px 0 0;
  opacity: 0;
  transform: scaleX(0.6);
  transition: opacity 0.15s, transform 0.15s;
}
.sales-portal-nav__link:hover {
  color: #fff;
  text-decoration: none;
}
.sales-portal-nav__link:hover::after {
  opacity: 0.45;
  transform: scaleX(1);
}
.sales-portal-nav__link.is-active {
  color: #fff;
  font-weight: 600;
}
.sales-portal-nav__link.is-active::after {
  opacity: 1;
  transform: scaleX(1);
}

/* Sales portal — grouped dropdown navigation */
.sales-portal-nav__item--has-dropdown {
  position: relative;
}
.sales-portal-nav__link--trigger {
  background: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
  gap: 4px;
  line-height: 1.2;
  height: 100%;
}
.sales-portal-nav__link--trigger:focus-visible {
  outline: none;
  color: #fff;
}
.sales-portal-nav__link--trigger:focus-visible::after {
  opacity: 0.45;
  transform: scaleX(1);
}
.sales-portal-nav__link-label {
  display: inline-block;
}
.sales-portal-nav__caret {
  font-size: 18px;
  line-height: 1;
  opacity: 0.7;
  transition: transform 0.2s ease;
  flex-shrink: 0;
}
.sales-portal-nav__link--trigger[aria-expanded="true"] .sales-portal-nav__caret {
  transform: rotate(180deg);
  opacity: 1;
}
.sales-portal-nav__link--trigger[aria-expanded="true"] {
  color: #fff;
}
.sales-portal-nav__link--trigger[aria-expanded="true"]::after {
  opacity: 0.45;
  transform: scaleX(1);
}
.sales-portal-nav__dropdown {
  position: absolute;
  top: 100%;
  left: 4px;
  min-width: 240px;
  background: var(--white, #fff);
  border: 1px solid var(--border, rgba(0,0,0,0.08));
  border-radius: var(--radius-md, 8px);
  box-shadow: var(--shadow-modal, 0 12px 32px rgba(0,0,0,0.18));
  padding: 6px 0;
  z-index: 540;
  display: flex;
  flex-direction: column;
}
.sales-portal-nav__dropdown-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 16px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-body, #333);
  font-family: var(--font-body);
  text-decoration: none;
  transition: background 0.12s, color 0.12s;
  white-space: nowrap;
}
.sales-portal-nav__dropdown-item:hover,
.sales-portal-nav__dropdown-item:focus-visible {
  background: var(--forest-light, #f0f4f0);
  color: var(--forest-dark, #1a2e1f);
  text-decoration: none;
  outline: none;
}
.sales-portal-nav__dropdown-item.is-active {
  background: var(--forest-light, #f0f4f0);
  color: var(--forest-dark, #1a2e1f);
  font-weight: 600;
}
.sales-portal-nav__dropdown-item.is-active .sales-portal-nav__dropdown-icon {
  color: var(--copper, #b87333);
}
.sales-portal-nav__dropdown-icon {
  font-size: 18px;
  color: var(--text-muted, #888);
  flex-shrink: 0;
  line-height: 1;
}
.sales-portal-nav__dropdown-item:hover .sales-portal-nav__dropdown-icon,
.sales-portal-nav__dropdown-item:focus-visible .sales-portal-nav__dropdown-icon {
  color: inherit;
}
.sales-portal-nav__dropdown-label {
  flex: 1;
  min-width: 0;
}

.sales-portal-page {
  padding-top: 24px;
}
.sales-portal-login__card {
  max-width: 420px;
  margin: 24px auto 40px;
  padding: 28px;
  background: var(--surface, #fff);
  border-radius: var(--radius-md, 8px);
  box-shadow: 0 4px 24px rgba(0,0,0,0.08);
}
.sales-portal-login__form .field {
  margin-bottom: 16px;
}
.sales-portal-alert {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: var(--radius-md);
  margin-bottom: 18px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  line-height: 1.4;
}
.sales-portal-alert .material-icons {
  font-size: 20px;
  flex-shrink: 0;
}
.sales-portal-alert--error {
  background: var(--red-light);
  color: var(--red);
  border: 1px solid rgba(192, 57, 43, 0.25);
}
.sales-portal-alert--success {
  background: var(--s-avail-bg);
  color: var(--s-avail-text);
  border: 1px solid var(--s-avail-bd);
}
.sales-portal-filters {
  margin-bottom: 20px;
}
.sales-portal-filters__row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 12px;
}
.sales-portal-filters__input {
  flex: 1;
  min-width: 200px;
  max-width: 400px;
}
.sales-portal-filters--inventory.sales-portal-filters--hero {
  width: 100%;
}
.sales-portal-inventory-table-area {
  position: relative;
}
.sales-portal-inventory__loader {
  position: absolute;
  inset: 0;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
  padding: 16px;
  font-size: 14px;
  color: var(--text-muted, #666);
  margin: 0;
  box-sizing: border-box;
  background: rgba(252, 252, 250, 0.82);
  backdrop-filter: blur(2px);
}
.sales-portal-inventory__loader-spinner {
  font-size: 18px;
  color: var(--brand-primary, #2d6a4f);
  line-height: 1;
}
.sales-portal-table--inventory tbody tr.is-clickable {
  cursor: pointer;
  transition: background 0.1s;
}
.sales-portal-table--inventory tbody tr.is-clickable:hover {
  background: var(--surface-hover, rgba(0, 0, 0, 0.04));
}
.sales-portal-table--inventory tbody tr.is-clickable:focus-visible {
  outline: 2px solid var(--brand-primary, #2d6a4f);
  outline-offset: -2px;
}
.sales-portal-table-wrap--inventory {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable;
  border-radius: var(--radius-md, 10px);
  border: 1px solid var(--border, #e8e6e1);
  background: var(--surface, #fff);
  box-shadow:
    0 1px 0 rgba(26, 46, 31, 0.04),
    0 10px 28px rgba(26, 46, 31, 0.07);
}
.sales-portal-table--inventory {
  table-layout: fixed;
  min-width: 720px;
}

.sales-portal-table--inventory > thead > tr > th {
  padding: 13px 14px;
  border-bottom: 1px solid var(--border, #e5e5e5);
  background: linear-gradient(180deg, #fcfcfa 0%, #f2f3ef 100%);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted, #5c6560);
  vertical-align: middle;
  transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

.sales-portal-table--inventory > thead > tr > th.sp-inv-sortable:hover {
  background: linear-gradient(180deg, #faf9f6 0%, #ebece6 100%);
  color: var(--forest-dark, #1a2e1f);
}

.sales-portal-table--inventory > thead > tr > th.sp-inv-sortable:focus-visible {
  outline: 2px solid var(--forest-mid, #52b788);
  outline-offset: -2px;
  z-index: 1;
}

.sales-portal-table--inventory > thead > tr > th.sp-inv-sortable[aria-sort="ascending"],
.sales-portal-table--inventory > thead > tr > th.sp-inv-sortable[aria-sort="descending"] {
  background: linear-gradient(180deg, rgba(82, 183, 136, 0.14) 0%, rgba(82, 183, 136, 0.03) 100%);
  color: var(--forest-dark, #1a2e1f);
  box-shadow: inset 0 -3px 0 var(--forest-mid, #52b788);
}

.sp-inv-th__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  width: 100%;
  min-width: 0;
}

.sp-inv-th__inner--end {
  justify-content: flex-end;
}

.sp-inv-th__label {
  min-width: 0;
  line-height: 1.35;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sp-inv-th__inner--end .sp-inv-th__label {
  flex: 1 1 auto;
  min-width: 0;
  text-align: right;
}

.sp-inv-sort-control {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  color: var(--text-muted, #5c6560);
  transition: background 0.15s ease, transform 0.12s ease;
}

.sp-inv-sortable:hover .sp-inv-sort-control {
  background: rgba(26, 46, 31, 0.06);
}

.sp-inv-sortable[aria-sort="ascending"] .sp-inv-sort-control,
.sp-inv-sortable[aria-sort="descending"] .sp-inv-sort-control {
  background: rgba(82, 183, 136, 0.18);
  color: var(--forest-dark, #1a2e1f);
}

.sp-inv-sortable:active .sp-inv-sort-control {
  transform: scale(0.94);
}

.sp-inv-sort-icon {
  position: relative;
  display: block;
  width: 12px;
  height: 16px;
  flex-shrink: 0;
}

/* Neutral: faint up/down hint */
.sales-portal-table--inventory thead th.sp-inv-sortable[aria-sort="none"] .sp-inv-sort-icon::before,
.sales-portal-table--inventory thead th.sp-inv-sortable[aria-sort="none"] .sp-inv-sort-icon::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  opacity: 0.28;
  transition: opacity 0.15s ease;
}
.sales-portal-table--inventory thead th.sp-inv-sortable[aria-sort="none"] .sp-inv-sort-icon::before {
  top: 1px;
  border-bottom: 5px solid currentColor;
}
.sales-portal-table--inventory thead th.sp-inv-sortable[aria-sort="none"] .sp-inv-sort-icon::after {
  bottom: 1px;
  border-top: 5px solid currentColor;
}
.sales-portal-table--inventory thead th.sp-inv-sortable[aria-sort="none"]:hover .sp-inv-sort-icon::before,
.sales-portal-table--inventory thead th.sp-inv-sortable[aria-sort="none"]:hover .sp-inv-sort-icon::after {
  opacity: 0.55;
}

/* Active sort: single chevron */
.sales-portal-table--inventory thead th.sp-inv-sortable[aria-sort="ascending"] .sp-inv-sort-icon::before,
.sales-portal-table--inventory thead th.sp-inv-sortable[aria-sort="descending"] .sp-inv-sort-icon::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  filter: drop-shadow(0 1px 0 rgba(0, 0, 0, 0.06));
}
.sales-portal-table--inventory thead th.sp-inv-sortable[aria-sort="ascending"] .sp-inv-sort-icon::before {
  transform: translate(-50%, -40%);
  border-bottom: 7px solid var(--forest-mid, #52b788);
}
.sales-portal-table--inventory thead th.sp-inv-sortable[aria-sort="descending"] .sp-inv-sort-icon::before {
  transform: translate(-50%, -60%);
  border-top: 7px solid var(--forest-mid, #52b788);
}
.sales-portal-table--inventory thead th.sp-inv-sortable[aria-sort="ascending"] .sp-inv-sort-icon::after,
.sales-portal-table--inventory thead th.sp-inv-sortable[aria-sort="descending"] .sp-inv-sort-icon::after {
  content: none;
}

.sp-inv-sortable {
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
}

/* Extend sort header styles to customers table */
.sales-portal-table--customers > thead > tr > th {
  padding: 13px 14px;
  border-bottom: 1px solid var(--border, #e5e5e5);
  background: linear-gradient(180deg, #fcfcfa 0%, #f2f3ef 100%);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted, #5c6560);
  vertical-align: middle;
  transition: background 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}
.sales-portal-table--customers > thead > tr > th.sp-inv-sortable:hover {
  background: linear-gradient(180deg, #faf9f6 0%, #ebece6 100%);
  color: var(--forest-dark, #1a2e1f);
}
.sales-portal-table--customers > thead > tr > th.sp-inv-sortable:focus-visible {
  outline: 2px solid var(--forest-mid, #52b788);
  outline-offset: -2px;
  z-index: 1;
}
.sales-portal-table--customers > thead > tr > th.sp-inv-sortable[aria-sort="ascending"],
.sales-portal-table--customers > thead > tr > th.sp-inv-sortable[aria-sort="descending"] {
  background: linear-gradient(180deg, rgba(82, 183, 136, 0.14) 0%, rgba(82, 183, 136, 0.03) 100%);
  color: var(--forest-dark, #1a2e1f);
  box-shadow: inset 0 -3px 0 var(--forest-mid, #52b788);
}
.sales-portal-table--customers thead th.sp-inv-sortable[aria-sort="none"] .sp-inv-sort-icon::before,
.sales-portal-table--customers thead th.sp-inv-sortable[aria-sort="none"] .sp-inv-sort-icon::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  opacity: 0.28;
  transition: opacity 0.15s ease;
}
.sales-portal-table--customers thead th.sp-inv-sortable[aria-sort="none"] .sp-inv-sort-icon::before {
  top: 1px;
  border-bottom: 5px solid currentColor;
}
.sales-portal-table--customers thead th.sp-inv-sortable[aria-sort="none"] .sp-inv-sort-icon::after {
  bottom: 1px;
  border-top: 5px solid currentColor;
}
.sales-portal-table--customers thead th.sp-inv-sortable[aria-sort="none"]:hover .sp-inv-sort-icon::before,
.sales-portal-table--customers thead th.sp-inv-sortable[aria-sort="none"]:hover .sp-inv-sort-icon::after {
  opacity: 0.55;
}
.sales-portal-table--customers thead th.sp-inv-sortable[aria-sort="ascending"] .sp-inv-sort-icon::before,
.sales-portal-table--customers thead th.sp-inv-sortable[aria-sort="descending"] .sp-inv-sort-icon::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  filter: drop-shadow(0 1px 0 rgba(0, 0, 0, 0.06));
}
.sales-portal-table--customers thead th.sp-inv-sortable[aria-sort="ascending"] .sp-inv-sort-icon::before {
  transform: translate(-50%, -40%);
  border-bottom: 7px solid var(--forest-mid, #52b788);
}
.sales-portal-table--customers thead th.sp-inv-sortable[aria-sort="descending"] .sp-inv-sort-icon::before {
  transform: translate(-50%, -60%);
  border-top: 7px solid var(--forest-mid, #52b788);
}
.sales-portal-table--customers thead th.sp-inv-sortable[aria-sort="ascending"] .sp-inv-sort-icon::after,
.sales-portal-table--customers thead th.sp-inv-sortable[aria-sort="descending"] .sp-inv-sort-icon::after {
  content: none;
}

.sales-portal-table--inventory th:nth-child(1),
.sales-portal-table--inventory td:nth-child(1) {
  width: 11%;
  word-break: break-word;
}
.sales-portal-table--inventory th:nth-child(2),
.sales-portal-table--inventory td:nth-child(2) {
  width: 44%;
  word-break: break-word;
}
.sales-portal-table--inventory th:nth-child(3),
.sales-portal-table--inventory td:nth-child(3) {
  width: 9%;
}
.sales-portal-table--inventory th:nth-child(4),
.sales-portal-table--inventory td:nth-child(4),
.sales-portal-table--inventory th:nth-child(5),
.sales-portal-table--inventory td:nth-child(5) {
  width: 12%;
}
@media (max-width: 640px) {
  .sales-portal-table-wrap--inventory {
    overflow-x: visible;
  }
  .sales-portal-table--inventory {
    table-layout: auto;
    min-width: 0;
    width: 100%;
  }
  .sales-portal-table--inventory th:nth-child(n),
  .sales-portal-table--inventory td:nth-child(n) {
    width: auto;
  }
  .sales-portal-table--inventory thead {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
  .sales-portal-table--inventory tbody tr:not(.sales-portal-table__empty-row) {
    display: block;
    padding: 14px 12px;
    margin-bottom: 12px;
    background: var(--surface, #fff);
    border: 1px solid var(--border, #e8e6e1);
    border-left: 3px solid var(--forest-mid, #52b788);
    border-radius: var(--radius-md, 8px);
    box-shadow: 0 2px 10px rgba(26, 46, 31, 0.05);
    cursor: pointer;
    transition: box-shadow 0.15s, transform 0.12s;
  }
  .sales-portal-table--inventory tbody tr:not(.sales-portal-table__empty-row):hover {
    box-shadow: 0 4px 18px rgba(26, 46, 31, 0.12);
    transform: translateY(-1px);
  }
  .sales-portal-table--inventory tbody tr.sales-portal-table__empty-row {
    display: block;
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
    margin: 0;
  }
  .sales-portal-table--inventory tbody tr.sales-portal-table__empty-row td {
    display: block;
    text-align: center;
    padding: 20px 12px;
    border-bottom: none;
    color: var(--text-muted, #666);
    font-size: 14px;
  }
  .sales-portal-table--inventory tbody tr:not(.sales-portal-table__empty-row) td {
    display: grid;
    grid-template-columns: minmax(88px, 34%) minmax(0, 1fr);
    column-gap: 12px;
    row-gap: 4px;
    align-items: start;
    padding: 8px 0;
    border-bottom: 1px solid var(--border, #f0ede8);
    font-size: 14px;
    text-align: left;
    word-break: break-word;
    overflow-wrap: anywhere;
    white-space: normal;
  }
  .sales-portal-table--inventory tbody tr:not(.sales-portal-table__empty-row) td:last-child {
    border-bottom: none;
  }
  .sales-portal-table--inventory tbody tr:not(.sales-portal-table__empty-row) td::before {
    content: attr(data-label);
    grid-column: 1;
    font-weight: 700;
    font-size: 10px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--text-muted, #666);
    line-height: 1.3;
    padding-top: 2px;
  }
  .sales-portal-table--inventory .sales-portal-table__num {
    text-align: left;
    white-space: normal;
  }

  /* ── Admin license table → card layout (matches payouts pattern) ── */
  .sales-portal-table-wrap--admin-license {
    overflow-x: visible;
    margin-left: 0;
    margin-right: 0;
  }
  .sales-portal-table--admin-license {
    table-layout: auto;
    min-width: 0;
    width: 100%;
  }
  .sales-portal-table--admin-license thead {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
  .sales-portal-table--admin-license tbody tr:not(.sales-portal-table__empty-row) {
    display: flex;
    flex-direction: column;
    margin-bottom: 12px;
    background: var(--surface, #fff);
    border: 1px solid var(--border, #e8e6e1);
    border-radius: var(--radius-md, 8px);
    box-shadow: 0 2px 10px rgba(26, 46, 31, 0.06);
    overflow: hidden;
  }
  /* Status-specific left-border accent strips */
  .sales-portal-table--admin-license tbody tr.license-row--expired {
    border-left: 3px solid var(--red, #c0392b);
    background: transparent;
  }
  .sales-portal-table--admin-license tbody tr.license-row--warning {
    border-left: 3px solid #EF6C00;
  }
  /* All cells: flex row, label left / value right */
  .sales-portal-table--admin-license tbody tr:not(.sales-portal-table__empty-row) td {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 7px 14px;
    font-size: 13px;
    border: none;
    border-bottom: 1px solid var(--border, #f0ede8);
    gap: 10px;
    word-break: break-word;
    overflow-wrap: anywhere;
  }
  .sales-portal-table--admin-license tbody tr:not(.sales-portal-table__empty-row) td:last-child {
    border-bottom: none;
  }
  .sales-portal-table--admin-license tbody tr:not(.sales-portal-table__empty-row) td::before {
    content: attr(data-label);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-muted, #6b7b74);
    flex-shrink: 0;
    white-space: nowrap;
  }
  .sales-portal-table--admin-license .sales-portal-table__cell-val {
    text-align: right;
    min-width: 0;
    word-break: break-word;
  }
  /* First cell (Account name): card header — larger text, no label */
  .sales-portal-table--admin-license tbody tr:not(.sales-portal-table__empty-row) td:first-child {
    padding: 12px 14px 10px;
    border-bottom: 1px solid var(--border, #f0ede8);
    font-size: 15px;
    font-weight: 700;
    justify-content: flex-start;
    color: var(--charcoal, #1E2822);
  }
  .sales-portal-table--admin-license tbody tr:not(.sales-portal-table__empty-row) td:first-child::before {
    display: none;
  }
  /* Last cell (Status pill): left-aligned, no label prefix */
  .sales-portal-table--admin-license tbody tr:not(.sales-portal-table__empty-row) td:last-child {
    padding: 8px 14px 10px;
    justify-content: flex-start;
    border-bottom: none;
  }
  .sales-portal-table--admin-license tbody tr:not(.sales-portal-table__empty-row) td:last-child::before {
    display: none;
  }
  /* Empty state row */
  .sales-portal-table--admin-license tbody tr.sales-portal-table__empty-row {
    display: block;
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
    margin: 0;
  }
  .sales-portal-table--admin-license tbody tr.sales-portal-table__empty-row td {
    display: block;
    text-align: center;
    padding: 24px 12px;
    border-bottom: none;
    color: var(--text-muted, #666);
    font-size: 14px;
  }
}
.sales-portal-table__th-num,
.sales-portal-table__num {
  text-align: right;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.sales-portal-filters__hint {
  font-size: 13px;
  color: var(--text-muted);
  margin: 0;
}
.sales-portal-list-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 8px;
}
.sales-portal-list-meta__limit {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--text-muted);
  white-space: nowrap;
}
.sales-portal-list-meta__limit select {
  font-size: 13px;
  padding-top: 3px;
  padding-bottom: 3px;
  min-width: 70px;
}
.sales-portal-filters--customers .sales-portal-filters__row--customer-refine {
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid var(--border, #e8e6e1);
  align-items: flex-end;
  gap: 12px 16px;
}
.sales-portal-filters__mini-label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-muted, #666);
  margin-bottom: 6px;
}
.sales-portal-filters--customers .sales-portal-filters__field {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.sales-portal-filters--customers .sales-portal-filters__field--city {
  flex: 1;
  min-width: min(220px, 100%);
}
.sales-portal-filters--customers .sales-portal-filters__select,
.sales-portal-filters--customers .sales-portal-filters__text {
  min-height: 44px;
  font-size: 14px;
}
.sales-portal-filters__check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  color: var(--forest);
  cursor: pointer;
  padding-bottom: 10px;
  user-select: none;
}
.sales-portal-filters__check input {
  width: 18px;
  height: 18px;
  accent-color: var(--copper);
}
.sales-portal-filters__refine-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 14px;
  margin-left: auto;
}
.sales-portal-filters__apply {
  padding: 10px 18px;
  font-size: 14px;
  border-radius: 10px;
  white-space: nowrap;
}
.sales-portal-filters__clear {
  font-size: 13px;
  color: var(--copper);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.sales-portal-filters__clear:hover {
  color: var(--forest);
}
@media (max-width: 640px) {
  .sales-portal-filters--customers .sales-portal-filters__row--customer-refine {
    flex-direction: column;
    align-items: stretch;
  }
  .sales-portal-filters__refine-actions {
    margin-left: 0;
  }
}

/* Sales portal list pages: catalog-style filter drawer (reuses .catalog-sidebar / .catalog-layout) */
.sales-portal-list-layout__form.catalog-layout {
  align-items: start;
}
.sales-portal-filter-drawer__scroll {
  padding: 12px 20px 28px;
}
.sales-portal-filter-drawer__intro {
  padding-bottom: 18px;
  margin-bottom: 18px;
  border-bottom: 1px solid var(--border, #e8e6e1);
}
.sales-portal-filter-drawer__heading {
  font-family: var(--font-body, "DM Sans", sans-serif);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--forest);
  margin: 0 0 8px;
  letter-spacing: -0.02em;
  text-transform: none;
}
.sales-portal-filter-drawer__lead {
  margin: 0;
  font-size: 13px;
  line-height: 1.55;
  color: var(--text-muted, #5c6560);
}
@media (max-width: 1024px) {
  .catalog-sidebar .sales-portal-filter-drawer__heading {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
}
.sp-filter-card {
  background: var(--surface-alt, #f8f7f4);
  border: 1px solid var(--border, #e8e6e1);
  border-radius: 12px;
  padding: 14px 16px 16px;
  margin-bottom: 12px;
}
.sp-filter-card--compact {
  padding-bottom: 14px;
}
.sp-filter-card__title {
  font-family: var(--font-body, "DM Sans", sans-serif);
  font-size: 13px;
  font-weight: 700;
  color: var(--forest);
  margin: 0 0 12px;
  letter-spacing: 0;
  text-transform: none;
}
.sp-filter-field {
  margin-bottom: 14px;
}
.sp-filter-field--flush {
  margin-bottom: 0;
}
.sp-filter-field--limit {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border, #e8e6e1);
}
.sp-filter-field__label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--charcoal, #2a2a2a);
  margin-bottom: 8px;
}
.sales-portal-filter-drawer .sp-filter-field .field__input,
.sales-portal-filter-drawer .sp-filter-field .sales-portal-filters__select,
.sales-portal-filter-drawer .sp-filter-field .sales-portal-filters__text {
  width: 100%;
  max-width: 100%;
  min-height: 44px;
  border-radius: 10px;
  font-size: 14px;
  box-sizing: border-box;
}
.sp-filter-options {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.sp-filter-option {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 12px 14px;
  background: #fff;
  border: 1px solid var(--border, #e8e6e1);
  border-radius: 10px;
  cursor: pointer;
  margin: 0;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.sp-filter-option:hover {
  border-color: rgba(45, 106, 79, 0.35);
}
.sp-filter-option:focus-within {
  outline: 2px solid var(--copper);
  outline-offset: 2px;
}
.sp-filter-option input {
  margin-top: 3px;
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  accent-color: var(--copper);
}
.sp-filter-option__body {
  flex: 1;
  min-width: 0;
}
.sp-filter-option__label {
  font-weight: 600;
  font-size: 14px;
  color: var(--forest);
  display: block;
  line-height: 1.35;
}
.sp-filter-option__hint {
  display: block;
  font-size: 12px;
  color: var(--text-muted, #5c6560);
  margin-top: 4px;
  line-height: 1.45;
}
.sales-portal-filter-drawer__section {
  margin-bottom: 8px;
}
.sales-portal-filter-drawer__section-title {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted, #666);
  margin: 0 0 14px;
}
.sales-portal-filter-drawer__actions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 10px;
  margin-top: 8px;
  padding-top: 20px;
  border-top: 1px solid var(--border, #e8e6e1);
}
.sales-portal-filter-drawer__actions .sales-portal-filters__apply {
  width: 100%;
  justify-content: center;
  min-height: 44px;
}
.sales-portal-filter-drawer__actions .sales-portal-filters__clear {
  text-align: center;
  text-decoration: none;
  font-weight: 600;
  padding: 8px;
  border-radius: 8px;
}
.sales-portal-filter-drawer__actions .sales-portal-filters__clear:hover {
  background: rgba(0, 0, 0, 0.04);
}
.sales-portal-page--customers-list .catalog-filter-toggle,
.sales-portal-page--inventory-list .catalog-filter-toggle {
  flex-shrink: 0;
  height: auto;
  min-height: 44px;
  padding: 10px 16px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 600;
  color: var(--forest);
  border-color: var(--border, #d9d6d0);
  gap: 8px;
}
.sales-portal-page--customers-list .catalog-filter-toggle.is-active,
.sales-portal-page--inventory-list .catalog-filter-toggle.is-active {
  border-color: var(--forest-border, #c5d4c8);
  color: var(--forest);
}
.sales-portal-customers-live-hint {
  margin: 8px 0 0;
  font-size: 12px;
  color: var(--text-muted, #5c6560);
  line-height: 1.45;
}
.sales-portal-search-live--hero.sales-portal-search-live--inline-search .sales-portal-search-live__input {
  border-radius: 12px;
  border-right: 1px solid var(--border, #d9d6d0);
}
.sales-portal-search-live--hero.sales-portal-search-live--inline-search .sales-portal-search-live__input:focus {
  border-right-color: var(--copper);
}
@media (max-width: 600px) {
  .sales-portal-search-live--hero.sales-portal-search-live--inline-search .sales-portal-search-live__input {
    border-radius: 12px;
  }
}
.sales-portal-filters__check--block {
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  margin-bottom: 4px;
}
.sales-portal-filters__check-main {
  font-weight: 600;
  color: var(--forest);
}
.sales-portal-filters__check-hint {
  font-size: 12px;
  line-height: 1.45;
  color: var(--text-muted, #666);
  margin: 0 0 14px 28px;
  max-width: 280px;
}
.sales-portal-filters__field--limit {
  min-width: 0;
}
.sales-portal-filters__field--limit .sales-portal-filters__select {
  min-width: 88px;
  max-width: 120px;
}
.sales-portal-customers-topbar,
.sales-portal-inventory-topbar {
  flex-wrap: wrap;
  width: 100%;
  top: 0;
}
.sales-portal-customers-topbar__search,
.sales-portal-inventory-topbar__search {
  flex: 1 1 260px;
  min-width: 0;
}
.sales-portal-customers-topbar__search .sales-portal-filters__hero-label,
.sales-portal-inventory-topbar__search .sales-portal-filters__hero-label {
  margin-bottom: 8px;
}
.sales-portal-customers-topbar__search .sales-portal-filters__row,
.sales-portal-inventory-topbar__search .sales-portal-filters__row {
  margin-bottom: 0;
}
.sales-portal-inventory-topbar__search--inline .sales-portal-inventory-search-row__field {
  flex: 1 1 auto;
  width: 100%;
  max-width: none;
}
.sales-portal-inventory-search-row__control {
  width: 100%;
}
.sales-portal-inventory-live-hint {
  margin: 8px 0 0;
  font-size: 12px;
  color: var(--text-muted, #5c6560);
  line-height: 1.45;
}
.sales-portal-inventory-results-hint {
  margin-top: 4px;
}
.sales-portal-table-wrap {
  overflow-x: auto;
  margin-bottom: 32px;
  border-radius: var(--radius-md, 10px);
  border: 1px solid var(--border, #e8e6e1);
  background: var(--surface, #fff);
  box-shadow:
    0 1px 0 rgba(26, 46, 31, 0.04),
    0 10px 28px rgba(26, 46, 31, 0.07);
}
.sales-portal-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}
.sales-portal-table th,
.sales-portal-table td {
  padding: 12px 14px;
  text-align: left;
  border-bottom: 1px solid var(--border, #e8e6e1);
}
.sales-portal-table th {
  padding: 13px 14px;
  background: linear-gradient(180deg, #fcfcfa 0%, #f2f3ef 100%);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text-muted, #5c6560);
  border-bottom: 1px solid var(--border, #e5e5e5);
}
.sales-portal-table tbody tr {
  transition: background 0.12s ease;
}
.sales-portal-table tbody tr:hover {
  background: var(--surface-hover, rgba(0, 0, 0, 0.025));
}
.sales-portal-table tbody tr:last-child td {
  border-bottom: none;
}
.sales-portal-table tbody tr:nth-child(even) {
  background: rgba(0, 0, 0, 0.012);
}
.sales-portal-table tbody tr:nth-child(even):hover {
  background: var(--surface-hover, rgba(0, 0, 0, 0.04));
}
.sales-portal-table a:not(.sales-portal-chip) {
  color: var(--copper);
  font-weight: 500;
}
.sales-portal-back {
  margin-bottom: 12px;
}
.sales-portal-back a {
  color: var(--copper);
  text-decoration: none;
  font-size: 14px;
}
.sales-portal-back a:hover {
  text-decoration: underline;
}
.sales-portal-section {
  margin-bottom: 28px;
}
.sales-portal-section-title {
  font-size: 18px;
  margin: 0 0 12px;
}
.sales-portal-dl {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 6px 16px;
  margin: 0 0 12px;
}
.sales-portal-dl dt {
  font-weight: 600;
  color: var(--text-muted);
}
.sales-portal-dl__empty {
  color: var(--text-muted, #6b6b6b);
  font-weight: 400;
}
.sales-portal-dl--overview dd {
  word-break: break-word;
}
.sales-portal-notice {
  margin: 0 0 14px;
  padding: 10px 14px;
  border-radius: var(--radius-md, 8px);
  font-size: 14px;
  line-height: 1.45;
}
.sales-portal-notice--ok {
  background: rgba(34, 120, 70, 0.12);
  border: 1px solid rgba(34, 120, 70, 0.35);
  color: var(--forest-dark, #1a2e1f);
}
.sales-portal-notice--err {
  background: rgba(180, 50, 40, 0.1);
  border: 1px solid rgba(180, 50, 40, 0.35);
  color: #5c1f1a;
}
.sales-portal-edit-wrap {
  margin-top: 8px;
}
.sales-portal-edit-details {
  border: 1px solid var(--border, #e0ddd6);
  border-radius: var(--radius-md, 8px);
  background: var(--surface-alt, #faf9f7);
  overflow: hidden;
}
.sales-portal-edit-details[open] {
  box-shadow: 0 1px 0 rgba(0, 0, 0, 0.04);
}
.sales-portal-edit-summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 16px;
  cursor: pointer;
  font-weight: 600;
  font-size: 14px;
  color: var(--forest-dark, #1a2e1f);
  user-select: none;
}
.sales-portal-edit-summary::-webkit-details-marker {
  display: none;
}
.sales-portal-edit-summary__icon {
  font-size: 12px;
  opacity: 0.55;
  transition: transform 0.2s ease;
}
.sales-portal-edit-details[open] .sales-portal-edit-summary__icon {
  transform: rotate(180deg);
}
.sales-portal-edit-summary:hover {
  background: rgba(0, 0, 0, 0.03);
}
.sales-portal-edit-card {
  padding: 0 16px 16px;
  border-top: 1px solid var(--border, #e0ddd6);
  background: var(--surface, #fff);
}
.sales-portal-edit-form__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 18px;
  padding-top: 16px;
}
.sales-portal-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}
.sales-portal-field--full {
  grid-column: 1 / -1;
}
.sales-portal-field__label {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--text-muted, #5c5c5c);
}
.sales-portal-field__input {
  width: 100%;
  box-sizing: border-box;
  padding: 10px 12px;
  font-size: 15px;
  line-height: 1.35;
  border: 1px solid var(--border, #d4d0c8);
  border-radius: var(--radius-sm, 6px);
  background: var(--surface, #fff);
  color: var(--text, #1a1a1a);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.sales-portal-field__input:focus {
  outline: none;
  border-color: var(--forest);
  box-shadow: 0 0 0 3px rgba(45, 90, 61, 0.15);
}
.sales-portal-field--full .sales-portal-field__input + .sales-portal-field__input {
  margin-top: 4px;
}
.sales-portal-edit-form__actions {
  margin-top: 18px;
  padding-top: 4px;
}
.sales-portal-edit-form__submit {
  min-width: 160px;
}
@media (max-width: 640px) {
  .sales-portal-edit-form__grid {
    grid-template-columns: 1fr;
  }
}
.sales-portal-team-teaser {
  margin: 20px 0 28px;
  padding: 16px 20px;
  background: var(--surface-alt, #f7f7f5);
  border-radius: var(--radius-md, 8px);
}
.sales-portal-team-teaser p {
  max-width: min(62em, 100%);
  overflow-wrap: anywhere;
  line-height: 1.5;
}
.sales-portal-order-meta p {
  margin: 6px 0;
  font-size: 14px;
}

/*
 * Sticky wrapper around the shell header, customer order bar, and sales nav.
 * Keeps all three visible at the top of the viewport regardless of scroll,
 * so that `openSheet()` / `applyWorkspaceTopOffset()` in sales-portal.js can
 * trust `offsetHeight` to match where those elements actually render.
 *
 * Prior behavior: the three elements were `position: relative` so they
 * scrolled away.  If the Start Order workspace opened while the user was
 * scrolled down, the workspace's computed `top:` offset matched the stack's
 * layout height (not its visual position) and the cart/toolbar controls fell
 * into a dead zone that showed stale main-content underneath.
 */
.sales-portal-shell__stack {
  position: sticky;
  top: 0;
  z-index: 540;
  /* Solid background so scrolling content doesn't leak through transparent
     areas of children (notably between shell__top and the sales nav). */
  background: var(--forest-dark, #1a2e1f);
}

.sales-portal-shell__top {
  background: var(--forest-dark, #1a2e1f);
  color: var(--white, #fff);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  position: relative;
  z-index: 540;
}
.sales-portal-shell__top-inner {
  max-width: 1480px;
  margin: 0 auto;
  padding: 8px clamp(16px, 3vw, 28px);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: 52px;
}
.sales-portal-shell__top-actions {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: flex-end;
  gap: 8px 12px;
  margin-left: auto;
}
.sales-portal-shell__top-actions--public {
  flex-shrink: 0;
}
.sales-portal-shell__public-link {
  display: inline-flex;
  align-items: center;
  color: rgba(255, 255, 255, 0.88);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  padding: 8px 14px;
  border-radius: var(--radius-md, 6px);
  border: 1px solid rgba(255, 255, 255, 0.22);
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
.sales-portal-shell__public-link:hover {
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.38);
  text-decoration: none;
}
.sales-portal-shell__user {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 10px 4px 4px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.12);
}
.sales-portal-shell__user-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--copper);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  flex-shrink: 0;
  line-height: 1;
  letter-spacing: 0;
}
.sales-portal-shell__user-name {
  font-size: 12px;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.9);
  max-width: min(180px, 32vw);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sales-portal-shell__brand-form {
  margin: 0;
}
.sales-portal-shell__brand-select {
  min-width: 120px;
  max-width: min(200px, 38vw);
  padding: 5px 26px 5px 8px;
  border-radius: var(--radius-sm, 4px);
  border: 1px solid rgba(255, 255, 255, 0.25);
  background-color: #243b29;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23ffffff99'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 8px center;
  color: #fff;
  font-size: 12.5px;
  cursor: pointer;
  transition: border-color 0.15s, background-color 0.15s;
  appearance: none;
  -webkit-appearance: none;
}
.sales-portal-shell__brand-select:hover,
.sales-portal-shell__brand-select:focus {
  border-color: rgba(255, 255, 255, 0.45);
  background-color: #2e4e35;
  outline: none;
}
.sales-portal-shell__logout {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: rgba(255, 255, 255, 0.6);
  font-size: 12px;
  font-weight: 500;
  text-decoration: none;
  white-space: nowrap;
  padding: 5px 10px;
  border-radius: var(--radius-sm, 4px);
  border: 1px solid transparent;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.sales-portal-shell__logout:hover {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.07);
  text-decoration: none;
}
.sales-portal-shell__logout-label {
  display: inline;
}
.sales-portal-shell__brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: inherit;
}
.sales-portal-shell__logo {
  max-height: 30px;
  width: auto;
  display: block;
}
.sales-portal-shell__brand-text {
  font-family: var(--font-display, Georgia, serif);
  font-weight: 700;
  font-size: 1rem;
}
.sales-portal-order-bar {
  background: var(--forest-dark, #1a2e1f);
}
.sales-portal-order-bar__inner {
  max-width: 1480px;
  margin: 0 auto;
  padding: 8px clamp(12px, 3vw, 24px);
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 8px 12px;
  font-size: 13px;
  min-height: 48px;
  box-sizing: border-box;
}
.sales-portal-order-bar__label {
  color: rgba(255,255,255,0.5);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 10px;
}
.sales-portal-order-bar__meta {
  color: rgba(255,255,255,0.55);
  font-size: 11px;
}
.sales-portal-order-shell {
  position: relative;
  z-index: 535;
}
.sales-portal-order-bar__identity {
  display: flex;
  flex-direction: column;
  gap: 1px;
  min-width: 0;
  flex: 1 1 0;
}
.sales-portal-order-bar__kicker {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--copper);
}
.sales-portal-order-bar__name {
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sales-portal-order-bar__actions {
  display: flex;
  flex-wrap: nowrap;
  gap: 6px;
  align-items: center;
  flex-shrink: 0;
}
.sales-portal-order-bar__cart-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: var(--radius-md, 6px);
  border: 1px solid rgba(255,255,255,0.2);
  background: transparent;
  color: rgba(255,255,255,0.85);
  font-size: 15px;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  flex-shrink: 0;
}
.sales-portal-order-bar__cart-btn:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.4);
  color: #fff;
}
.sales-portal-order-bar__cart-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  background: var(--copper);
  color: #fff;
  border-radius: 999px;
  min-width: 17px;
  height: 17px;
  font-size: 10px;
  font-family: var(--font-data, monospace);
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 3px;
  line-height: 1;
  box-sizing: border-box;
}
.sales-portal-order-bar__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 7px 14px;
  border-radius: var(--radius-sm, 4px);
  font-size: 12px;
  font-weight: 600;
  font-family: inherit;
  text-decoration: none;
  cursor: pointer;
  border: 1px solid rgba(255,255,255,0.22);
  background: transparent;
  color: rgba(255,255,255,0.85);
  white-space: nowrap;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.sales-portal-order-bar__btn:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.4);
  color: #fff;
}
.sales-portal-order-bar__btn--primary {
  background: var(--copper);
  border-color: var(--copper);
  color: #fff;
}
.sales-portal-order-bar__btn--primary:hover {
  filter: brightness(1.08);
  color: #fff;
}
.sales-portal-order-bar__btn--ghost {
  background: transparent;
  border-color: transparent;
  color: rgba(255,255,255,0.5);
  padding-left: 8px;
  padding-right: 8px;
}
.sales-portal-order-bar__btn--ghost:hover {
  background: rgba(255,255,255,0.07);
  border-color: transparent;
  color: rgba(255,255,255,0.85);
}
.sales-portal-order-bar__checkout-btn {
  display: none;
}
@media (min-width: 601px) {
  .sales-portal-order-bar__checkout-btn {
    display: inline-flex;
  }
}
.embedded-sales-portal .embedded-portal-strip {
  background: var(--forest-dark, #1a2e1f);
  color: rgba(255, 255, 255, 0.92);
  padding: 8px clamp(16px, 3vw, 28px);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.embedded-portal-strip__label {
  display: block;
}
.sales-portal-shell__footer {
  background: var(--forest-dark, #1a2e1f);
  color: rgba(255, 255, 255, 0.75);
  margin-top: auto;
}
.sales-portal-shell__footer-inner {
  max-width: 1480px;
  margin: 0 auto;
  padding: 16px clamp(16px, 3vw, 28px);
  font-size: 12px;
}
.sales-portal-search-hint {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 6px;
}
.sales-portal-search-live {
  position: relative;
}
.sales-portal-search-live__panel {
  position: absolute;
  z-index: 20;
  left: 0;
  right: 0;
  top: 100%;
  margin-top: 4px;
  max-height: 280px;
  overflow-y: auto;
  background: var(--surface, #fff);
  border: 1px solid var(--border, #e5e5e5);
  border-radius: var(--radius-sm, 4px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  list-style: none;
  margin: 0;
  padding: 4px 0;
}
.sales-portal-search-live__item a {
  display: block;
  padding: 8px 12px;
  font-size: 13px;
  color: var(--text, #222);
  text-decoration: none;
}
.sales-portal-search-live__item a:hover {
  background: var(--surface-alt, #f7f7f5);
}
.sp-customer-detail-header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px 20px;
  margin-bottom: 20px;
}
.sp-cd-hero-identity {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  flex: 1 1 200px;
  min-width: 0;
}
.sp-cd-avatar {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--forest-mid);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sp-customer-detail-header .admin-page__header {
  margin-bottom: 0;
  flex: 1 1 0;
  min-width: 0;
}
.sp-customer-detail-header .sales-portal-start-order {
  margin: 0;
  flex-shrink: 0;
}
.sales-portal-start-order {
  margin: 16px 0 24px;
}
.sales-portal-start-order__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 20px;
  border-radius: var(--radius-sm, 4px);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  border: none;
  background: var(--copper);
  color: #fff;
  font-family: inherit;
  white-space: nowrap;
}
.sales-portal-start-order__btn:hover {
  filter: brightness(1.05);
}

/* ── Customer Detail: KPI tiles + info card ──────────────────────────────── */

/* Neutralise global nth-child colour system so mod classes have full control */
.sales-portal-page--customer-detail .kpi-tile:nth-child(2),
.sales-portal-page--customer-detail .kpi-tile:nth-child(3),
.sales-portal-page--customer-detail .kpi-tile:nth-child(4) {
  border-top-color: var(--forest);
}
.sales-portal-page--customer-detail .kpi-tile:nth-child(2) .kpi-tile__value,
.sales-portal-page--customer-detail .kpi-tile:nth-child(3) .kpi-tile__value,
.sales-portal-page--customer-detail .kpi-tile:nth-child(4) .kpi-tile__value {
  color: var(--forest);
}

/* Per-tile accent colours */
.sp-customer-kpi--orders                        { border-top-color: var(--copper); }
.sp-customer-kpi--orders .kpi-tile__value       { color: var(--copper); }
.sp-customer-kpi--transactions                  { border-top-color: var(--forest); }
.sp-customer-kpi--transactions .kpi-tile__value { color: var(--forest); }
.sp-customer-kpi--terms                         { border-top-color: var(--forest-mid, #3a7030); }
.sp-customer-kpi--terms .kpi-tile__value        { color: var(--forest-mid, #3a7030); }
.sp-customer-kpi--currency                      { border-top-color: var(--forest-mid, #3a7030); }
.sp-customer-kpi--currency .kpi-tile__value     { color: var(--forest-mid, #3a7030); }

/* Compact font for text-based KPI values (payment terms, currency codes) */
.sp-customer-kpi__text-val {
  font-size: 20px !important;
  font-family: var(--font-data);
  font-weight: 700;
  letter-spacing: 0.02em;
}

/* Keep 2-column KPI grid on small phones — 4 stacked tiles is too much height */
@media (max-width: 480px) {
  .sales-portal-page--customer-detail .kpi-tiles {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
  .sales-portal-page--customer-detail .kpi-tile {
    padding: 14px 12px;
  }
  .sales-portal-page--customer-detail .kpi-tile__value {
    font-size: 22px;
  }
}

/* Overview info card */
.sp-customer-overview-card {
  border: 1px solid var(--border, #e8e6e1);
  border-radius: var(--radius-lg, 10px);
  padding: 16px 20px;
  background: var(--surface, #fff);
  margin-bottom: 16px;
}

/* Account ID code in subtitle — monospace treatment */
.sp-cd-account-id {
  font-family: var(--font-data);
}

/* Status badge inline in subtitle */
.admin-page__subtitle .sp-status-badge {
  vertical-align: middle;
  margin-left: 8px;
}

body.sales-portal .admin-page.sales-portal-page {
  max-width: 1480px;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
/* em = subtitle’s own font-size; avoids ~52×12px≈628px when html rem is shrunk (e.g. Bootstrap) */
.sales-portal-page__intro {
  max-width: min(62em, 100%);
  line-height: 1.55;
  color: var(--text-muted, #5c6560);
  font-size: 14px;
}
.sales-register-form__section {
  border: 1px solid var(--border, #e8e6e1);
  border-radius: 12px;
  padding: 16px;
  background: var(--surface, #fff);
  margin-bottom: 14px;
}
.sales-register-form__section--compact {
  padding: 12px 16px;
}
.sales-register-form__section-title {
  margin: 0 0 12px;
  font-size: 14px;
  color: var(--forest);
}
.sales-register-form__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px 14px;
}
.sales-register-form__field-full {
  grid-column: 1 / -1;
}
.sales-register-form__readonly {
  border: 1px solid var(--border, #e8e6e1);
  background: var(--surface-alt, #f7f7f5);
  border-radius: var(--radius-md, 8px);
  padding: 11px 12px;
  font-size: 13px;
  font-weight: 600;
  color: var(--forest);
}
.sales-register-form__choice-group {
  display: grid;
  gap: 8px;
}
.sales-register-form__choice-group--inline {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.sales-register-form__choice {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  font-size: 13px;
  color: var(--text, #222);
}
.sales-register-form__helper {
  margin-bottom: 10px;
}
.sales-register-form__checkbox {
  display: inline-flex;
  gap: 8px;
  align-items: center;
  font-size: 13px;
  color: var(--text, #222);
}
.sales-register-form__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
  margin-top: 10px;
}

.sales-portal-nav__quick {
  flex: 1;
  min-width: 180px;
  max-width: min(420px, 100%);
  position: relative;
  z-index: 1;
  margin-left: auto;
  padding: 8px 0;
}
.sales-portal-nav__quick-field {
  position: relative;
  display: flex;
  align-items: center;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 999px;
  padding: 0 6px 0 14px;
  transition: border-color 0.2s, background 0.2s, box-shadow 0.2s;
}
.sales-portal-nav__quick-field:focus-within {
  background: #fff;
  border-color: rgba(255, 255, 255, 0.45);
  box-shadow: 0 0 0 3px rgba(var(--copper-rgb),0.25);
}
.sales-portal-nav__quick-icon {
  color: rgba(255, 255, 255, 0.75);
  font-size: 14px;
  margin-right: 8px;
  flex-shrink: 0;
}
.sales-portal-nav__quick-field:focus-within .sales-portal-nav__quick-icon {
  color: var(--copper);
}
.sales-portal-nav__quick-input {
  flex: 1;
  min-width: 0;
  border: none;
  background: transparent;
  color: #fff;
  font-size: 14px;
  padding: 10px 8px 10px 0;
  outline: none;
  font-family: var(--font-body, "DM Sans", sans-serif);
}
.sales-portal-nav__quick-input::placeholder {
  color: rgba(255, 255, 255, 0.5);
}
.sales-portal-nav__quick-field:focus-within .sales-portal-nav__quick-input {
  color: var(--text, #1a1a1a);
}
.sales-portal-nav__quick-field:focus-within .sales-portal-nav__quick-input::placeholder {
  color: var(--text-muted, #888);
}
.sales-portal-nav__quick-panel {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 8px);
  z-index: 560;
  background: #fff;
  border-radius: 12px;
  border: 1px solid var(--border, #e8e6e1);
  box-shadow: 0 16px 48px rgba(26, 46, 31, 0.14);
  max-height: min(360px, 70vh);
  overflow-y: auto;
  padding: 8px 0;
}
.sales-portal-nav__quick-hint {
  margin: 0;
  padding: 14px 18px;
  font-size: 13px;
  color: var(--text-muted, #666);
}
.sales-portal-nav__quick-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.sales-portal-nav__quick-hit {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border, #f0ede8);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 10px 16px;
}
.sales-portal-nav__quick-hit:last-child {
  border-bottom: none;
}
.sales-portal-nav__quick-hit-main {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.sales-portal-nav__quick-hit-name {
  font-weight: 600;
  font-size: 14px;
  color: var(--forest);
}
.sales-portal-nav__quick-hit-branch {
  font-size: 12px;
  color: var(--text-muted, #666);
}
.sales-portal-nav__quick-hit-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.sales-portal-nav__quick-order-form {
  margin: 0;
  display: inline;
}
.sales-portal-nav__quick-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 7px 14px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  text-decoration: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
  transition: background 0.15s, color 0.15s, box-shadow 0.15s;
}
.sales-portal-nav__quick-btn--ghost {
  background: transparent;
  color: var(--copper);
  border: 1px solid rgba(var(--copper-rgb),0.35);
}
.sales-portal-nav__quick-btn--ghost:hover {
  background: rgba(var(--copper-rgb),0.08);
  text-decoration: none;
  color: var(--copper-hover);
}
.sales-portal-nav__quick-btn--primary {
  background: linear-gradient(135deg, var(--copper), var(--copper-active-gradient));
  color: var(--copper-contrast);
  box-shadow: 0 2px 8px rgba(var(--copper-rgb),0.35);
}
.sales-portal-nav__quick-btn--primary:hover {
  filter: brightness(1.06);
  color: #fff;
}

.sales-portal-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 16px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
  white-space: nowrap;
  transition: background 0.15s, color 0.15s, box-shadow 0.15s;
}
.sales-portal-chip--sm {
  padding: 6px 12px;
  font-size: 12px;
}
.sales-portal-chip--ghost {
  background: #fff;
  color: var(--copper);
  border: 1px solid rgba(var(--copper-rgb),0.4);
}
.sales-portal-chip--ghost:hover {
  background: rgba(var(--copper-rgb),0.06);
  text-decoration: none;
  color: var(--copper-hover);
}
.sales-portal-chip--primary {
  background: linear-gradient(135deg, var(--copper), var(--copper-active-gradient));
  color: var(--copper-contrast);
  box-shadow: 0 2px 8px rgba(var(--copper-rgb),0.28);
}
.sales-portal-chip--primary:hover {
  filter: brightness(1.05);
  color: #fff;
}
.sales-portal-inline-form {
  margin: 0;
  display: inline-flex;
}

.sales-portal-filters--hero .sales-portal-filters__row {
  width: 100%;
  align-items: stretch;
}
.sales-portal-filters--hero {
  margin-bottom: 28px;
  padding: 22px 24px;
  background: linear-gradient(145deg, #faf9f7 0%, #f3f1ec 100%);
  border-radius: 16px;
  border: 1px solid var(--border, #e8e6e1);
  box-shadow: 0 4px 20px rgba(26, 46, 31, 0.06);
}
.sales-portal-filters__hero-label {
  font-family: var(--font-display, "Fraunces", Georgia, serif);
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--forest);
  margin: 0 0 14px;
  letter-spacing: -0.02em;
}
.sales-portal-search-live--hero .sales-portal-search-live__field {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 0;
  flex: 1;
  min-width: 0;
}
.sales-portal-search-live__field {
  position: relative;
}
.sales-portal-search-live--hero .sales-portal-search-live__control {
  position: relative;
  flex: 1;
  min-width: min(200px, 100%);
  display: flex;
  align-items: stretch;
}
.sales-portal-search-live--hero .sales-portal-search-live__control .sales-portal-search-live__input {
  width: 100%;
  min-width: 0;
  flex: 1;
}
.sales-portal-search-live__icon {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted, #888);
  font-size: 16px;
  z-index: 1;
  pointer-events: none;
}
.sales-portal-search-live__input {
  flex: 1;
  min-width: 200px;
  padding: 14px 16px 14px 46px;
  font-size: 15px;
  border: 1px solid var(--border, #d9d6d0);
  border-radius: 12px 0 0 12px;
  border-right: none;
  background: #fff;
  font-family: var(--font-body, "DM Sans", sans-serif);
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.sales-portal-search-live__input:focus {
  border-color: var(--copper);
  box-shadow: inset 0 0 0 1px rgba(var(--copper-rgb),0.2);
}
.sales-portal-search-live__submit {
  border-radius: 0 12px 12px 0;
  padding-left: 22px;
  padding-right: 22px;
  white-space: nowrap;
}
@media (max-width: 600px) {
  .sales-portal-search-live--hero .sales-portal-search-live__control {
    width: 100%;
    min-width: 0;
  }
  .sales-portal-search-live__input {
    border-radius: 12px;
    border-right: 1px solid var(--border, #d9d6d0);
    width: 100%;
  }
  .sales-portal-search-live__submit {
    border-radius: 12px;
    width: 100%;
    margin-top: 10px;
  }
}
.sales-portal-search-live__panel--hero {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 10px);
  z-index: 50;
  max-height: min(400px, 65vh);
  overflow-y: auto;
  background: #fff;
  border-radius: 14px;
  border: 1px solid var(--border, #e8e6e1);
  box-shadow: 0 20px 50px rgba(26, 46, 31, 0.12);
  padding: 6px 0;
}
.sales-portal-search-live__list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.sales-portal-search-live__hit {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px 20px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border, #f0ede8);
}
.sales-portal-search-live__hit:last-child {
  border-bottom: none;
}
.sales-portal-search-live__hit-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.sales-portal-search-live__hit-name {
  font-weight: 600;
  font-size: 15px;
  color: var(--forest);
}
.sales-portal-search-live__hit-branch {
  font-size: 13px;
  color: var(--text-muted, #666);
}
.sales-portal-search-live__hit-sales {
  font-size: 12px;
  color: var(--text-muted, #666);
  margin-top: 2px;
}
.sales-portal-nav__quick-hit-sales {
  font-size: 11px;
  color: var(--text-muted, #666);
  margin-top: 2px;
}
.sales-portal-search-live__hit-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.sales-portal-table--comfortable td,
.sales-portal-table--comfortable th {
  padding: 14px 14px;
  vertical-align: middle;
}
.sales-portal-table__th-actions {
  width: 1%;
  white-space: nowrap;
  text-align: right;
}
.sales-portal-table__actions {
  text-align: right;
  white-space: nowrap;
}
.sales-portal-table__action-row {
  display: inline-flex;
  flex-wrap: nowrap;
  gap: 8px;
  justify-content: flex-end;
  align-items: center;
}
.sales-portal-table__strong {
  font-weight: 600;
  color: var(--forest);
}
.sales-portal-table__muted {
  color: var(--text-muted, #777);
  font-weight: 400;
}

.sales-portal-table-wrap--customers {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable;
  border-radius: var(--radius-md, 10px);
  border: 1px solid var(--border, #e8e6e1);
  background: var(--surface, #fff);
  box-shadow: 0 1px 0 rgba(26, 46, 31, 0.04), 0 10px 28px rgba(26, 46, 31, 0.07);
}

.sales-portal-table--customers {
  min-width: 1100px;
  table-layout: fixed;
}

.sales-portal-table--customers th:nth-child(1),
.sales-portal-table--customers td:nth-child(1) {
  width: 16%;
  min-width: 140px;
}

.sales-portal-table--customers th:nth-child(2),
.sales-portal-table--customers td:nth-child(2) {
  width: 18%;
  min-width: 160px;
}

.sales-portal-table--customers th:nth-child(3),
.sales-portal-table--customers td:nth-child(3) {
  width: 13%;
  min-width: 120px;
}

.sales-portal-table--customers th:nth-child(4),
.sales-portal-table--customers td:nth-child(4) {
  width: 12%;
  min-width: 110px;
}

.sales-portal-table--customers th:nth-child(5),
.sales-portal-table--customers td:nth-child(5) {
  width: 16%;
  min-width: 140px;
}

.sales-portal-table--customers th:nth-child(6),
.sales-portal-table--customers td:nth-child(6) {
  width: 10%;
  min-width: 90px;
  text-align: center;
}

.sales-portal-table--customers th:nth-child(7),
.sales-portal-table--customers td:nth-child(7) {
  width: 15%;
  min-width: 200px;
}

.sales-portal-table--customers td,
.sales-portal-table--customers th {
  padding: 16px 14px;
}

.sales-portal-table--customers .sales-portal-table__cell-val {
  display: block;
  line-height: 1.4;
}

.sales-portal-table--customers td.sales-portal-table__cell-email .sales-portal-table__cell-val {
  word-break: break-word;
  overflow-wrap: break-word;
}

.sales-portal-table--customers td.sales-portal-table__td-customer {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
}

.sales-portal-table--customers .sp-cust-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--forest-mid, #52b788) 0%, var(--forest, #2d6a4f) 100%);
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
  box-shadow: 0 2px 6px rgba(45, 106, 79, 0.2);
}

.sales-portal-table--customers .sp-cust-card-name {
  font-weight: 600;
  color: var(--forest-dark, #1a2e1f);
  font-size: 15px;
}

.sales-portal-table--customers td[data-label*="Payment"] .sales-portal-table__cell-val {
  display: flex;
  justify-content: center;
  align-items: center;
}

.sales-portal-table--customers .cr-badge {
  min-width: 40px;
  padding: 6px 12px;
  border-radius: 6px;
  font-weight: 700;
  font-size: 13px;
  text-align: center;
}

.sales-portal-table--customers .sales-portal-table__action-row {
  gap: 10px;
}

.sales-portal-table--customers .sales-portal-chip {
  padding: 8px 14px;
  font-size: 13px;
  white-space: nowrap;
}

.sales-portal-table--customers .sales-portal-table__muted {
  font-size: 13px;
  margin-left: 4px;
}

.sales-portal-table--customers tbody tr:hover {
  background: var(--surface-hover, rgba(82, 183, 136, 0.04));
}

.sales-portal-table--customers tbody tr:nth-child(even) {
  background: rgba(0, 0, 0, 0.015);
}

.sales-portal-table--customers tbody tr:nth-child(even):hover {
  background: var(--surface-hover, rgba(82, 183, 136, 0.06));
}

.sales-portal-table-wrap--orders,
.sales-portal-table-wrap--order-detail,
.sales-portal-table-wrap--team,
.sales-portal-table-wrap--team-rep-customers,
.sales-portal-table-wrap--team-rep-orders {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable;
}
.sales-portal-table--orders,
.sales-portal-table--team,
.sales-portal-table--team-rep-orders {
  min-width: 960px;
}
/* Prevent header text wrapping */
.sales-portal-table--orders th {
  white-space: nowrap;
}
/* Per-column min-widths — stops the browser collapsing early columns */
.sales-portal-table--orders th:nth-child(1),
.sales-portal-table--orders td:nth-child(1) { min-width: 72px;  }  /* Order # */
.sales-portal-table--orders th:nth-child(2),
.sales-portal-table--orders td:nth-child(2) { min-width: 130px; }  /* Customer */
.sales-portal-table--orders th:nth-child(3),
.sales-portal-table--orders td:nth-child(3) { min-width: 130px; }  /* Branch */
.sales-portal-table--orders th:nth-child(4),
.sales-portal-table--orders td:nth-child(4) { min-width: 88px;  }  /* Date */
.sales-portal-table--orders th:nth-child(5),
.sales-portal-table--orders td:nth-child(5) { min-width: 100px; }  /* Reference */
/* Cap the actions column so it doesn't crowd out the rest */
.sales-portal-table--orders .sales-portal-table__th-actions,
.sales-portal-table--orders .sales-portal-table__actions         { width: 172px; }
.sales-portal-table--order-lines {
  min-width: 520px;
}
.sales-portal-table--team-rep-customers {
  min-width: 640px;
}

/* Manifest order lookup form */
.sp-manifest-lookup__form {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}
.sp-manifest-lookup__input {
  max-width: 180px;
}

.sales-portal-table-wrap--admin-license {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable;
  margin-bottom: 0;
}
.sales-portal-table--admin-license {
  min-width: 640px;
}

.sales-portal-team-totals {
  margin: 0 0 24px;
}
.sales-portal-team-totals__title {
  font-size: 1rem;
  margin: 0 0 12px;
}

.sales-portal-dashboard-kpis {
  margin: 0 0 24px;
}
.sales-portal-dashboard-kpis__title {
  font-size: 1rem;
  margin: 0 0 12px;
}

/* Portal KPIs: wrap by min track width instead of forcing 4 narrow columns or a fixed 2-col split */
body.sales-portal .admin-kpis .kpi-tiles {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 240px), 1fr));
}

.sales-portal-section__hint {
  margin: -4px 0 12px;
  max-width: min(62em, 100%);
}

.sales-portal-nav__quick-hint--error {
  color: #a32020;
  font-weight: 500;
}

/* Sales portal — responsive (nav, order bar, detail pages, workspace) */
@media (max-width: 991px) {
  .sales-portal-nav__inner {
    flex-wrap: wrap;
    gap: 0;
    padding-top: 0;
    padding-bottom: 0;
    min-height: auto;
  }
  .sales-portal-nav__links {
    flex: none;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    width: 100%;
    padding: 0;
    margin: 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  }
  .sales-portal-nav__links::-webkit-scrollbar {
    display: none;
  }
  .sales-portal-nav__item {
    flex-shrink: 0;
  }
  .sales-portal-nav__link {
    padding: 12px 14px;
    font-size: 13px;
  }
  .sales-portal-nav__quick {
    flex: none;
    max-width: none;
    width: 100%;
    padding: 8px 0;
    z-index: 1;
  }
  /* Dropdown panels break out of the horizontally-scrolling link list and
     span full viewport width, anchored just below the sticky nav stack.
     The --sp-nav-dropdown-top custom property is set by a small script in
     sales_nav.twig based on the nav's actual bottom position. */
  .sales-portal-nav__item--has-dropdown {
    position: static;
  }
  .sales-portal-nav__dropdown {
    position: fixed;
    top: var(--sp-nav-dropdown-top, 100px);
    left: 0;
    right: 0;
    width: 100%;
    min-width: 0;
    max-height: calc(100vh - var(--sp-nav-dropdown-top, 100px) - 16px);
    overflow-y: auto;
    border-radius: 0;
    border-left: none;
    border-right: none;
    border-top: 2px solid var(--copper);
    padding: 4px 0;
    z-index: 560;
  }
  .sales-portal-nav__dropdown-item {
    padding: 14px 20px;
    font-size: 14px;
  }
  .sales-portal-nav__dropdown-icon {
    font-size: 20px;
  }
}

@media (max-width: 900px) {
  body.sales-portal .admin-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  body.sales-portal .admin-page__title {
    font-size: clamp(1.05rem, 4.8vw, 1.35rem);
    line-height: 1.28;
    overflow-wrap: anywhere;
    hyphens: auto;
  }
  body.sales-portal .admin-page__subtitle {
    font-size: 11px;
    line-height: 1.4;
    overflow-wrap: anywhere;
  }
  .sales-portal-page {
    padding-top: 14px;
  }
  .sales-portal-order-bar__inner {
    flex-wrap: nowrap;
    padding: 6px 12px;
    min-height: 44px;
  }
  .sales-portal-order-bar__name {
    font-size: 13px;
  }
  .sales-portal-order-bar__actions {
    gap: 4px;
  }
  .sales-portal-order-bar__btn {
    font-size: 12px;
    padding: 6px 10px;
  }
  .sales-portal-start-order__btn {
    width: 100%;
    box-sizing: border-box;
    justify-content: center;
  }
  .sales-portal-dl {
    grid-template-columns: 1fr;
    gap: 2px 0;
  }
  .sales-portal-dl dt {
    margin-top: 12px;
    font-size: 11px;
  }
  .sales-portal-dl dt:first-of-type {
    margin-top: 0;
  }
  .sales-portal-dl dd {
    margin: 0 0 4px;
    overflow-wrap: anywhere;
  }
  .sales-portal-filters--hero {
    padding: 16px 14px;
    border-radius: 12px;
  }
  .sales-portal-search-live--hero .sales-portal-search-live__field {
    flex-direction: column;
    align-items: stretch;
  }
  .sales-portal-search-live--hero .sales-portal-search-live__control {
    width: 100%;
    min-width: 0;
  }
  .sales-portal-table-wrap {
    margin-left: -4px;
    margin-right: -4px;
    padding-left: 4px;
    padding-right: 4px;
    border: none;
    border-radius: 0;
    box-shadow: none;
    background: transparent;
  }

  .sales-portal-page--customers-list .admin-page__header {
    margin-bottom: 10px;
  }
  .sales-portal-page--customers-list .sales-portal-page__intro {
    font-size: 12px;
    line-height: 1.45;
    margin-top: 0;
  }
  .sales-portal-page--customers-list .sales-portal-filters--hero {
    margin-bottom: 18px;
  }
  .sales-portal-page--customers-list .sales-portal-filters__hero-label {
    font-size: 1.05rem;
    margin-bottom: 10px;
  }

  .sales-portal-page--inventory-list .admin-page__header {
    margin-bottom: 10px;
  }
  .sales-portal-page--inventory-list .sales-portal-page__intro {
    font-size: 12px;
    line-height: 1.45;
    margin-top: 0;
  }
  .sales-portal-page--inventory-list .sales-portal-filters--hero {
    margin-bottom: 18px;
  }
  .sales-portal-page--inventory-list .sales-portal-filters__hero-label {
    font-size: 1.05rem;
    margin-bottom: 10px;
  }

  .sales-portal-page--customer-detail .admin-page__header {
    margin-bottom: 0;
  }
  .sales-portal-page--customer-detail .admin-page__title {
    overflow-wrap: anywhere;
    font-size: clamp(1rem, 5vw, 1.35rem);
  }
  .sales-portal-page--customer-detail .admin-page__subtitle {
    font-size: 11px;
  }
  .sales-portal-page--customer-detail .sales-portal-back a {
    display: inline-flex;
    align-items: center;
    min-height: 44px;
    padding: 4px 0;
  }
  .sp-customer-detail-header {
    flex-direction: column;
    justify-content: flex-start;
    gap: 10px;
    margin-bottom: 16px;
  }
  .sp-customer-detail-header .sales-portal-start-order {
    width: 100%;
  }
  .sp-customer-detail-header .sales-portal-start-order__btn {
    width: 100%;
    justify-content: center;
  }
  .sales-portal-page--customer-detail .sales-portal-section-title {
    font-size: 16px;
  }

  .sales-portal-page--orders-list .admin-page__header,
  .sales-portal-page--order-detail .admin-page__header,
  .sales-portal-page--team-list .admin-page__header,
  .sales-portal-page--team-rep .admin-page__header,
  .sales-portal-page--dashboard .admin-page__header,
  .sales-portal-page--admin-dashboard .admin-page__header {
    margin-bottom: 10px;
  }
}

/* ── Sales orders: mobile responsive (card view at 640px, manifest form) ── */
@media (max-width: 640px) {
  /* Manifest lookup: stack form vertically, full-width inputs */
  .sp-manifest-lookup__form {
    flex-direction: column;
    align-items: stretch;
  }
  .sp-manifest-lookup__input {
    max-width: 100%;
    width: 100%;
  }
  .sp-manifest-lookup__form .sales-portal-chip {
    width: 100%;
    justify-content: center;
    box-sizing: border-box;
  }

  /* Orders page: section title sizing */
  .sales-portal-page--orders-list .sales-portal-section-title {
    font-size: 15px;
  }

  /* Orders & order-lines tables: switch to card view (same pattern as inventory) */
  .sales-portal-table-wrap--orders,
  .sales-portal-table-wrap--order-detail {
    overflow-x: visible;
    margin-left: 0;
    margin-right: 0;
    padding-left: 0;
    padding-right: 0;
  }
  .sales-portal-table--orders,
  .sales-portal-table--order-lines {
    min-width: 0;
    width: 100%;
  }
  .sales-portal-table--orders thead,
  .sales-portal-table--order-lines thead {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
  .sales-portal-table--orders tbody tr:not(.sales-portal-table__empty-row),
  .sales-portal-table--order-lines tbody tr:not(.sales-portal-table__empty-row) {
    display: block;
    padding: 14px 12px;
    margin-bottom: 12px;
    background: var(--surface, #fff);
    border: 1px solid var(--border, #e8e6e1);
    border-radius: var(--radius-md, 8px);
    box-shadow: 0 2px 10px rgba(26, 46, 31, 0.05);
  }
  .sales-portal-table--orders tbody tr.sales-portal-table__empty-row,
  .sales-portal-table--order-lines tbody tr.sales-portal-table__empty-row {
    display: block;
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
    margin: 0;
  }
  .sales-portal-table--orders tbody tr.sales-portal-table__empty-row td,
  .sales-portal-table--order-lines tbody tr.sales-portal-table__empty-row td {
    display: block;
    text-align: center;
    padding: 20px 12px;
    border-bottom: none;
    color: var(--text-muted, #666);
    font-size: 14px;
  }
  /* Regular data cells: label | value grid */
  .sales-portal-table--orders tbody tr:not(.sales-portal-table__empty-row) td:not(.sales-portal-table__actions),
  .sales-portal-table--order-lines tbody tr:not(.sales-portal-table__empty-row) td {
    display: grid;
    grid-template-columns: minmax(88px, 34%) minmax(0, 1fr);
    column-gap: 12px;
    row-gap: 4px;
    align-items: start;
    padding: 8px 0;
    border-bottom: 1px solid var(--border, #f0ede8);
    vertical-align: top;
    text-align: left;
    font-size: 14px;
    word-break: break-word;
    overflow-wrap: anywhere;
  }
  .sales-portal-table--orders tbody tr:not(.sales-portal-table__empty-row) td:not(.sales-portal-table__actions)::before,
  .sales-portal-table--order-lines tbody tr:not(.sales-portal-table__empty-row) td::before {
    content: attr(data-label);
    grid-column: 1;
    font-weight: 700;
    font-size: 10px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--text-muted, #666);
    line-height: 1.3;
    padding-top: 2px;
  }
  .sales-portal-table--orders .sales-portal-table__cell-val,
  .sales-portal-table--order-lines .sales-portal-table__cell-val {
    grid-column: 2;
    min-width: 0;
  }
  /* CRM notes cell: display as data cell, not action cell */
  .sales-portal-table--orders tbody tr:not(.sales-portal-table__empty-row) td.sp-col-crm-notes {
    display: grid;
    grid-template-columns: minmax(88px, 34%) minmax(0, 1fr);
    column-gap: 12px;
    align-items: center;
    padding: 8px 0;
    border-top: none;
    margin-top: 0;
    border-bottom: 1px solid var(--border, #f0ede8);
  }
  .sales-portal-table--orders tbody tr:not(.sales-portal-table__empty-row) td.sp-col-crm-notes::before {
    content: attr(data-label);
    grid-column: 1;
    font-weight: 700;
    font-size: 10px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--text-muted, #666);
    line-height: 1.3;
    padding-top: 2px;
    display: block;
    margin-bottom: 0;
  }
  /* Actions cell: block separator at bottom of card */
  .sales-portal-table--orders tbody tr:not(.sales-portal-table__empty-row) td.sales-portal-table__actions:not(.sp-col-crm-notes) {
    display: block;
    padding-top: 12px;
    margin-top: 4px;
    border-top: 1px solid var(--border, #eee);
    border-bottom: none;
  }
  .sales-portal-table--orders tbody tr:not(.sales-portal-table__empty-row) td.sales-portal-table__actions:not(.sp-col-crm-notes)::before {
    display: none;
  }
  /* Action buttons: stretch to fill the row */
  .sales-portal-table--orders .sales-portal-table__action-row {
    justify-content: flex-start;
    width: 100%;
  }
  .sales-portal-table--orders .sales-portal-table__action-row .sales-portal-chip {
    flex: 1;
    justify-content: center;
  }
  /* Left accent stripe + hover lift on order cards */
  .sales-portal-page--orders-list .sales-portal-table--orders tbody tr:not(.sales-portal-table__empty-row) {
    border-left: 3px solid var(--forest-mid, #52b788);
    transition: box-shadow 0.15s, transform 0.12s;
  }
  .sales-portal-page--orders-list .sales-portal-table--orders tbody tr:not(.sales-portal-table__empty-row):hover {
    box-shadow: 0 4px 18px rgba(26, 46, 31, 0.12);
    transform: translateY(-1px);
  }
}

/* ── Customer card: avatar initials (hidden on desktop, shown in mobile cards) ── */
.sp-cust-avatar {
  display: none;
}

/* ── Phone number as tappable link ── */
.sp-cust-tel {
  color: var(--copper);
  text-decoration: none;
}
.sp-cust-tel:hover {
  text-decoration: underline;
  color: var(--copper-hover);
}

/* ── Customer profile flyout (workspace) ── */
.sp-customer-flyout {
  padding: 0 0 2rem;
  animation: sp-result-fade-in 0.3s ease both;
}

.sp-customer-flyout__hero {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 20px 20px 16px;
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}

.sp-customer-flyout__avatar {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--forest-mid);
  color: #fff;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.sp-customer-flyout__hero-info {
  flex: 1 1 0;
  min-width: 0;
}

.sp-customer-flyout__name {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--charcoal);
  margin: 0 0 2px;
  line-height: 1.2;
}

.sp-customer-flyout__sub {
  font-family: var(--font-data);
  font-size: 11px;
  color: var(--text-muted);
  margin: 0;
}

.sp-customer-flyout__order-btn-wrap {
  flex-shrink: 0;
}

.sp-customer-flyout__section {
  padding: 16px 20px 8px;
  border-bottom: 1px solid var(--border);
}

.sp-customer-flyout__section:last-child {
  border-bottom: none;
}

.sp-customer-flyout__section-title {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  margin: 0 0 10px;
}

@media (max-width: 480px) {
  .sp-customer-flyout__hero {
    padding: 14px 14px 12px;
    gap: 10px;
  }
  .sp-customer-flyout__order-btn-wrap {
    width: 100%;
  }
  .sp-customer-flyout__order-btn-wrap .sales-portal-start-order__btn {
    width: 100%;
    justify-content: center;
  }
  .sp-customer-flyout__name {
    font-size: 1rem;
  }
  .sp-customer-flyout__section {
    padding: 12px 14px 6px;
  }
  .sales-portal-page--team-list .sales-portal-page__intro,
  .sales-portal-page--team-rep .sales-portal-page__intro,
  .sales-portal-page--dashboard .sales-portal-page__intro,
  .sales-portal-page--admin-dashboard .sales-portal-page__intro {
    font-size: 12px;
    line-height: 1.45;
    margin-top: 0;
  }
  .sales-portal-page--order-detail .sales-portal-back a,
  .sales-portal-page--team-rep .sales-portal-back a {
    display: inline-flex;
    align-items: center;
    min-height: 44px;
    padding: 4px 0;
  }
  .sales-portal-order-meta--detail {
    padding: 12px 14px;
    margin-bottom: 16px;
    background: var(--surface-alt, #f7f7f5);
    border-radius: var(--radius-md, 8px);
    border: 1px solid var(--border, #e8e6e1);
  }
  .sales-portal-order-meta--detail p {
    font-size: 13px;
    margin: 8px 0;
    overflow-wrap: anywhere;
  }
  .sales-portal-order-meta--detail p:first-child {
    margin-top: 0;
  }
  .sales-portal-order-meta--detail p:last-child {
    margin-bottom: 0;
  }

  .sales-portal-table-wrap--orders,
  .sales-portal-table-wrap--order-detail,
  .sales-portal-table-wrap--team,
  .sales-portal-table-wrap--team-rep-customers,
  .sales-portal-table-wrap--team-rep-orders {
    margin-left: 0;
    margin-right: 0;
    padding-left: 0;
    padding-right: 0;
    overflow-x: visible;
  }
  .sales-portal-table--orders,
  .sales-portal-table--order-lines,
  .sales-portal-table--team,
  .sales-portal-table--team-rep-orders {
    min-width: 0;
    width: 100%;
  }
  .sales-portal-table--orders thead,
  .sales-portal-table--order-lines thead,
  .sales-portal-table--team thead,
  .sales-portal-table--team-rep-orders thead {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
  .sales-portal-table--orders tbody tr:not(.sales-portal-table__empty-row),
  .sales-portal-table--order-lines tbody tr:not(.sales-portal-table__empty-row),
  .sales-portal-table--team tbody tr:not(.sales-portal-table__empty-row),
  .sales-portal-table--team-rep-orders tbody tr:not(.sales-portal-table__empty-row) {
    display: block;
    padding: 14px 12px;
    margin-bottom: 12px;
    background: var(--surface, #fff);
    border: 1px solid var(--border, #e8e6e1);
    border-radius: var(--radius-md, 8px);
    box-shadow: 0 2px 10px rgba(26, 46, 31, 0.05);
  }
  .sales-portal-table--orders tbody tr.sales-portal-table__empty-row,
  .sales-portal-table--order-lines tbody tr.sales-portal-table__empty-row,
  .sales-portal-table--team tbody tr.sales-portal-table__empty-row,
  .sales-portal-table--team-rep-orders tbody tr.sales-portal-table__empty-row {
    display: block;
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
    margin: 0;
  }
  .sales-portal-table--orders tbody tr.sales-portal-table__empty-row td,
  .sales-portal-table--order-lines tbody tr.sales-portal-table__empty-row td,
  .sales-portal-table--team tbody tr.sales-portal-table__empty-row td,
  .sales-portal-table--team-rep-orders tbody tr.sales-portal-table__empty-row td {
    display: block;
    text-align: center;
    padding: 20px 12px;
    border-bottom: none;
    color: var(--text-muted, #666);
    font-size: 14px;
  }
  .sales-portal-table--orders tbody tr:not(.sales-portal-table__empty-row) td:not(.sales-portal-table__actions),
  .sales-portal-table--order-lines tbody tr:not(.sales-portal-table__empty-row) td,
  .sales-portal-table--team tbody tr:not(.sales-portal-table__empty-row) td:not(.sales-portal-table__actions),
  .sales-portal-table--team-rep-orders tbody tr:not(.sales-portal-table__empty-row) td:not(.sales-portal-table__actions) {
    display: grid;
    grid-template-columns: minmax(88px, 34%) minmax(0, 1fr);
    column-gap: 12px;
    row-gap: 4px;
    align-items: start;
    padding: 8px 0;
    border-bottom: 1px solid var(--border, #f0ede8);
    vertical-align: top;
    text-align: left;
    font-size: 14px;
    word-break: break-word;
    overflow-wrap: anywhere;
  }
  .sales-portal-table--orders tbody tr:not(.sales-portal-table__empty-row) td:not(.sales-portal-table__actions)::before,
  .sales-portal-table--order-lines tbody tr:not(.sales-portal-table__empty-row) td::before,
  .sales-portal-table--team tbody tr:not(.sales-portal-table__empty-row) td:not(.sales-portal-table__actions)::before,
  .sales-portal-table--team-rep-orders tbody tr:not(.sales-portal-table__empty-row) td:not(.sales-portal-table__actions)::before {
    content: attr(data-label);
    grid-column: 1;
    font-weight: 700;
    font-size: 10px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--text-muted, #666);
    line-height: 1.3;
    padding-top: 2px;
  }
  .sales-portal-table--orders .sales-portal-table__cell-val,
  .sales-portal-table--order-lines .sales-portal-table__cell-val,
  .sales-portal-table--team .sales-portal-table__cell-val,
  .sales-portal-table--team-rep-orders .sales-portal-table__cell-val {
    grid-column: 2;
    min-width: 0;
  }
  .sales-portal-table--orders tbody tr:not(.sales-portal-table__empty-row) td.sales-portal-table__actions,
  .sales-portal-table--team tbody tr:not(.sales-portal-table__empty-row) td.sales-portal-table__actions,
  .sales-portal-table--team-rep-orders tbody tr:not(.sales-portal-table__empty-row) td.sales-portal-table__actions {
    display: block;
    padding-top: 12px;
    margin-top: 4px;
    border-top: 1px solid var(--border, #eee);
    border-bottom: none;
  }
  .sales-portal-table--orders tbody tr:not(.sales-portal-table__empty-row) td.sales-portal-table__actions::before,
  .sales-portal-table--team tbody tr:not(.sales-portal-table__empty-row) td.sales-portal-table__actions::before,
  .sales-portal-table--team-rep-orders tbody tr:not(.sales-portal-table__empty-row) td.sales-portal-table__actions::before {
    display: block;
    margin-bottom: 10px;
  }
  .sales-portal-table--orders .sales-portal-table__action-row,
  .sales-portal-table--team .sales-portal-table__action-row,
  .sales-portal-table--team-rep-orders .sales-portal-table__action-row {
    justify-content: flex-start;
    width: 100%;
  }

  .sales-portal-table-wrap--customers,
  .sales-portal-table-wrap--team-rep-customers {
    margin-left: 0;
    margin-right: 0;
    padding-left: 0;
    padding-right: 0;
    overflow-x: visible;
  }
  .sales-portal-table--customers,
  .sales-portal-table--team-rep-customers {
    min-width: 0;
    width: 100%;
    table-layout: auto;
  }
  .sales-portal-table--customers th:nth-child(n),
  .sales-portal-table--customers td:nth-child(n) {
    width: auto;
    min-width: 0;
  }
  .sales-portal-table--customers thead,
  .sales-portal-table--team-rep-customers thead {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
  .sales-portal-table--customers tbody tr:not(.sales-portal-table__empty-row),
  .sales-portal-table--team-rep-customers tbody tr:not(.sales-portal-table__empty-row) {
    display: block;
    padding: 14px 12px;
    margin-bottom: 12px;
    background: var(--surface, #fff);
    border: 1px solid var(--border, #e8e6e1);
    border-radius: var(--radius-md, 8px);
    box-shadow: 0 2px 10px rgba(26, 46, 31, 0.05);
  }
  .sales-portal-table--customers tbody tr.sales-portal-table__empty-row,
  .sales-portal-table--team-rep-customers tbody tr.sales-portal-table__empty-row {
    display: block;
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
    margin: 0;
  }
  .sales-portal-table--customers tbody tr.sales-portal-table__empty-row td,
  .sales-portal-table--team-rep-customers tbody tr.sales-portal-table__empty-row td {
    display: block;
    text-align: center;
    padding: 20px 12px;
    border-bottom: none;
    color: var(--text-muted, #666);
    font-size: 14px;
  }
  .sales-portal-table--customers tbody tr:not(.sales-portal-table__empty-row) td:not(.sales-portal-table__actions),
  .sales-portal-table--team-rep-customers tbody tr:not(.sales-portal-table__empty-row) td:not(.sales-portal-table__actions) {
    display: grid;
    grid-template-columns: minmax(88px, 34%) minmax(0, 1fr);
    column-gap: 12px;
    row-gap: 4px;
    align-items: start;
    padding: 8px 0;
    border-bottom: 1px solid var(--border, #f0ede8);
    vertical-align: top;
    text-align: left;
    font-size: 14px;
    word-break: break-word;
    overflow-wrap: anywhere;
  }
  .sales-portal-table--customers tbody tr:not(.sales-portal-table__empty-row) td:not(.sales-portal-table__actions)::before,
  .sales-portal-table--team-rep-customers tbody tr:not(.sales-portal-table__empty-row) td:not(.sales-portal-table__actions)::before {
    content: attr(data-label);
    grid-column: 1;
    font-weight: 700;
    font-size: 10px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--text-muted, #666);
    line-height: 1.3;
    padding-top: 2px;
  }
  .sales-portal-table--customers .sales-portal-table__cell-val,
  .sales-portal-table--team-rep-customers .sales-portal-table__cell-val {
    grid-column: 2;
    min-width: 0;
  }
  .sales-portal-table--customers tbody tr:not(.sales-portal-table__empty-row) td.sales-portal-table__actions,
  .sales-portal-table--team-rep-customers tbody tr:not(.sales-portal-table__empty-row) td.sales-portal-table__actions {
    display: block;
    padding-top: 12px;
    margin-top: 4px;
    border-top: 1px solid var(--border, #eee);
    border-bottom: none;
  }
  .sales-portal-table--customers tbody tr:not(.sales-portal-table__empty-row) td.sales-portal-table__actions::before,
  .sales-portal-table--team-rep-customers tbody tr:not(.sales-portal-table__empty-row) td.sales-portal-table__actions::before {
    display: block;
    margin-bottom: 10px;
  }
  .sales-portal-table--customers .sales-portal-table__action-row,
  .sales-portal-table--team-rep-customers .sales-portal-table__action-row {
    justify-content: flex-start;
    width: 100%;
  }
  .sales-portal-table--customers tr.sales-portal-table__row--no-email .sales-portal-table__cell-email,
  .sales-portal-table--team-rep-customers tr.sales-portal-table__row--no-email .sales-portal-table__cell-email {
    display: none;
  }

  /* ── Open-orders card: left accent stripe + hover lift ── */

  /* Left accent border + card hover lift */
  .sales-portal-page--orders-list .sales-portal-table--orders tbody tr:not(.sales-portal-table__empty-row),
  .sales-portal-page--customer-detail .sp-cd-orders-table tbody tr:not(.sales-portal-table__empty-row) {
    border-left: 3px solid var(--forest-mid, #52b788);
    transition: box-shadow 0.15s, transform 0.12s;
  }
  .sales-portal-page--orders-list .sales-portal-table--orders tbody tr:not(.sales-portal-table__empty-row):hover,
  .sales-portal-page--customer-detail .sp-cd-orders-table tbody tr:not(.sales-portal-table__empty-row):hover {
    box-shadow: 0 4px 18px rgba(26, 46, 31, 0.12);
    transform: translateY(-1px);
  }

  /* ── Team card: enhanced mobile presentation ── */

  /* Left accent border + card hover lift */
  .sales-portal-table--team tbody tr:not(.sales-portal-table__empty-row) {
    border-left: 3px solid var(--forest-mid, #52b788);
    transition: box-shadow 0.15s, transform 0.12s;
  }
  .sales-portal-table--team tbody tr:not(.sales-portal-table__empty-row):hover {
    box-shadow: 0 4px 18px rgba(26, 46, 31, 0.12);
    transform: translateY(-1px);
  }

  /* ── Customer card: enhanced mobile presentation ── */

  /* Left accent border + card hover lift */
  .sales-portal-table--customers tbody tr:not(.sales-portal-table__empty-row) {
    border-left: 3px solid var(--forest-mid, #52b788);
    transition: box-shadow 0.15s, transform 0.12s;
  }
  .sales-portal-table--customers tbody tr:not(.sales-portal-table__empty-row):hover {
    box-shadow: 0 4px 18px rgba(26, 46, 31, 0.12);
    transform: translateY(-1px);
  }

  /* Customer name cell: flex row with avatar (replaces label/value grid) */
  .sales-portal-table--customers tbody tr:not(.sales-portal-table__empty-row) td.sales-portal-table__td-customer {
    display: flex;
    align-items: center;
    gap: 10px;
    padding-bottom: 10px;
    margin-bottom: 4px;
  }
  .sales-portal-table--customers tbody tr:not(.sales-portal-table__empty-row) td.sales-portal-table__td-customer::before {
    display: none;
  }

  /* Avatar circle (initials) */
  .sales-portal-table--customers .sp-cust-avatar {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: var(--forest-mid, #52b788);
    color: #fff;
    font-size: 15px;
    font-weight: 700;
    line-height: 1;
  }

  /* Customer name text inside card header */
  .sales-portal-table--customers .sp-cust-card-name {
    flex: 1;
    min-width: 0;
    font-size: 15px;
    font-weight: 700;
    color: var(--forest, #2d6a4f);
    line-height: 1.3;
  }

  /* Start Order button: grow to fill available width */
  .sales-portal-table--customers .sales-portal-table__action-row .sales-portal-chip--primary {
    flex: 1;
    justify-content: center;
  }

  .sales-portal-nav__link {
    padding: 10px 12px;
    min-height: 44px;
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
  }
  .sales-portal-nav__quick-hit {
    flex-direction: column;
    align-items: stretch;
  }
  .sales-portal-nav__quick-hit-actions {
    justify-content: flex-start;
  }
  body.sales-portal .admin-kpis .kpi-tiles {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  body.sales-portal .kpi-tile {
    padding: 16px 14px;
  }
  body.sales-portal .kpi-tile__value {
    font-size: 26px;
  }
  body.sales-portal .sales-portal-page--dashboard .admin-quick-actions__grid,
  body.sales-portal .sales-portal-page--admin-dashboard .admin-quick-actions__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 480px) {
  .sales-portal-shell__top-inner {
    flex-wrap: nowrap;
    gap: 6px;
    padding-top: 8px;
    padding-bottom: 8px;
    min-height: 48px;
  }
  .sales-portal-shell__brand {
    flex-shrink: 1;
    min-width: 0;
    overflow: hidden;
  }
  .sales-portal-shell__brand-text {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: min(140px, 30vw);
    display: inline-block;
    vertical-align: middle;
  }
  .sales-portal-shell__logo {
    max-height: 24px;
  }
  .sales-portal-shell__top-actions {
    flex-wrap: nowrap;
    gap: 4px 6px;
    flex-shrink: 0;
    margin-left: auto;
  }
  .sales-portal-shell__brand-form {
    display: none;
  }
  .sales-portal-shell__logout-label {
    display: none;
  }
  .sales-portal-shell__user-name {
    max-width: min(90px, 22vw);
    font-size: 11px;
  }
  .sales-portal-shell__user-avatar {
    width: 22px;
    height: 22px;
    font-size: 10px;
  }
  .sales-portal-shell__logout {
    padding: 4px 6px;
  }
  .sales-portal-nav__inner {
    padding-left: 12px;
    padding-right: 12px;
  }
  .sales-portal-nav__link {
    font-size: 13px;
  }
  .admin-quick-actions__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 380px) {
  .sales-portal-order-bar__inner {
    padding: 6px 10px;
    gap: 4px 8px;
  }
  .sales-portal-order-bar__name {
    font-size: 12px;
  }
  .sales-portal-order-bar__btn {
    font-size: 11px;
    padding: 6px 8px;
  }
  .sales-portal-shell__top-inner {
    min-height: 44px;
  }
}

body.sales-portal-workspace-open {
  overflow: hidden;
}
/* Hide nav entirely when a customer order is active — frees ~90 px for the catalog */
body.sp-order-active .sales-portal-nav {
  display: none;
}
.sales-portal-workspace {
  position: fixed;
  inset: 0;
  z-index: 540;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  pointer-events: none;
}
.sales-portal-workspace:not([hidden]) {
  pointer-events: auto;
}
.sales-portal-workspace__scrim {
  position: absolute;
  inset: 0;
  background: rgba(15, 22, 18, 0.45);
  opacity: 0;
  transition: opacity 0.28s ease;
}
.sales-portal-workspace[data-state="open"] .sales-portal-workspace__scrim {
  opacity: 1;
}
.sales-portal-workspace__sheet {
  position: relative;
  width: 100%;
  max-width: 1680px;
  height: min(92vh, 100%);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: 16px 16px 0 0;
  box-shadow: 0 -12px 48px rgba(0, 0, 0, 0.18);
  transform: translateY(100%);
  transition: transform 0.32s cubic-bezier(0.22, 1, 0.36, 1);
  overflow: hidden;
}
.sales-portal-workspace__sheet.is-visible {
  transform: translateY(0);
}
.sales-portal-workspace__toolbar {
  flex-shrink: 0;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  gap: 8px 12px;
  padding: 10px 16px;
  border-bottom: 1px solid var(--border, #e5e5e5);
  background: var(--forest-dark, #1a2e1f);
  min-height: 52px;
  box-sizing: border-box;
}
.sales-portal-workspace__back-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 12px;
  border-radius: var(--radius-pill, 999px);
  border: 1px solid rgba(255,255,255,0.22);
  background: transparent;
  color: rgba(255,255,255,0.9);
  font-size: 13px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: background 0.15s, border-color 0.15s;
}
.sales-portal-workspace__back-btn:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.45);
  color: #fff;
}
.sales-portal-workspace__back-btn .fa {
  font-size: 11px;
}
.sales-portal-workspace__toolbar-meta {
  flex: 1 1 0;
  min-width: 0;
  font-size: 12px;
  font-weight: 600;
  color: rgba(255,255,255,0.65);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  text-align: center;
}
.sales-portal-workspace__toolbar-end {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
.sales-portal-workspace__cart-trigger {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md, 6px);
  border: 1px solid rgba(255,255,255,0.22);
  background: transparent;
  color: rgba(255,255,255,0.9);
  font-size: 16px;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  flex-shrink: 0;
}
@media (min-width: 769px) {
  .sales-portal-workspace__cart-trigger {
    display: none;
  }
}
.sales-portal-workspace__cart-trigger:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.45);
  color: #fff;
}
.sales-portal-workspace__cart-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  background: var(--copper);
  color: #fff;
  border-radius: var(--radius-pill, 999px);
  min-width: 18px;
  height: 18px;
  font-size: 10px;
  font-family: var(--font-data, monospace);
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 3px;
  line-height: 1;
  box-sizing: border-box;
}
.sales-portal-workspace__exit-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md, 6px);
  border: none;
  background: transparent;
  color: rgba(255,255,255,0.5);
  font-size: 16px;
  cursor: pointer;
  transition: color 0.15s, background 0.15s;
  flex-shrink: 0;
}
.sales-portal-workspace__exit-btn:hover {
  background: rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.9);
}
@media (max-width: 480px) {
  .sales-portal-workspace__toolbar {
    padding: 8px 12px;
    min-height: 48px;
  }
  .sales-portal-workspace__back-btn {
    padding: 6px 10px;
    font-size: 12px;
    gap: 5px;
  }
  .sales-portal-workspace__toolbar-meta {
    font-size: 11px;
  }
  .sales-portal-workspace__sheet {
    border-radius: 12px 12px 0 0;
    height: 100%;
  }
}
@media (max-width: 768px) {
  body.sales-portal-workspace-open .sales-portal-shell__top,
  body.sales-portal-workspace-open .sales-portal-nav,
  body.sales-portal-workspace-open .sales-portal-order-shell {
    visibility: hidden;
  }
  .sales-portal-workspace__sheet {
    border-radius: 0;
    height: 100%;
  }
}
.sales-portal-workspace__loading {
  font-size: 12px;
  font-weight: 600;
  color: rgba(255,255,255,0.6);
}
.sales-portal-workspace__mount {
  flex: 1;
  width: 100%;
  min-height: 0;
  overflow: auto;
  overscroll-behavior: contain;
  background: #fff;
}
.sales-portal-workspace__mount .container-full {
  max-width: 100%;
}
.sales-portal-workspace__mount .catalog-topbar {
  top: 0;
}
.sales-portal-toast-stack {
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%);
  z-index: 12000;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  pointer-events: none;
  width: min(480px, calc(100vw - 32px));
}
.sales-portal-toast {
  width: 100%;
  padding: 12px 16px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 600;
  box-shadow: 0 10px 32px rgba(26, 46, 31, 0.22);
  opacity: 0;
  transform: translateY(10px) scale(0.97);
  transition: opacity 0.22s ease, transform 0.22s ease;
  text-align: center;
}
.sales-portal-toast.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}
.sales-portal-toast--success {
  background: #1a7a3f;
  color: #fff;
  border: 1px solid #1a6a35;
}
.sales-portal-toast--danger {
  background: #fdecec;
  color: #8c2020;
  border: 1px solid #f3c2c2;
}
.sales-portal-toast--info {
  background: #1a2e1f;
  color: #fff;
  border: 1px solid #2d5a3d;
}
@media (max-width: 640px) {
  .sales-portal-toast-stack {
    left: 16px;
    right: 16px;
    bottom: calc(16px + env(safe-area-inset-bottom, 0px));
    transform: none;
    width: auto;
  }
  .sales-portal-toast {
    font-size: 13px;
  }
}
/* ── Portal checkout result screen (success / fail) ── */
.sp-checkout-result {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.25rem;
  min-height: 60vh;
  padding: 3rem 2rem;
  text-align: center;
  animation: sp-result-fade-in 0.4s ease both;
}

@keyframes sp-result-fade-in {
  from { opacity: 0; transform: translateY(18px); }
  to   { opacity: 1; transform: translateY(0); }
}

.sp-checkout-result__icon {
  display: flex;
  align-items: center;
  justify-content: center;
}

.sp-checkout-result__checkmark {
  width: 88px;
  height: 88px;
  display: block;
}

.sp-checkout-result--success .sp-checkout-result__circle {
  stroke: var(--s-avail-dot, #2e7d32);
  stroke-width: 2;
  stroke-dasharray: 166;
  stroke-dashoffset: 166;
  stroke-linecap: round;
  animation: sp-result-circle 0.6s cubic-bezier(0.65, 0, 0.45, 1) forwards;
}

.sp-checkout-result--success .sp-checkout-result__check {
  stroke: var(--s-avail-dot, #2e7d32);
  stroke-width: 3;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 48;
  stroke-dashoffset: 48;
  animation: sp-result-check 0.35s cubic-bezier(0.65, 0, 0.45, 1) 0.55s forwards;
}

@keyframes sp-result-circle {
  to { stroke-dashoffset: 0; }
}
@keyframes sp-result-check {
  to { stroke-dashoffset: 0; }
}

.sp-checkout-result__title {
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 700;
  color: var(--charcoal);
  margin: 0;
  line-height: 1.2;
}

.sp-checkout-result--success .sp-checkout-result__title {
  color: var(--forest, #1a3c34);
}

.sp-checkout-result__body {
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--text-light);
  line-height: 1.6;
  max-width: 360px;
  margin: 0;
}

.sp-checkout-result__close {
  margin-top: 0.5rem;
}

@media (prefers-reduced-motion: reduce) {
  .sp-checkout-result {
    animation: none;
  }
  .sp-checkout-result--success .sp-checkout-result__circle,
  .sp-checkout-result--success .sp-checkout-result__check {
    animation: none;
    stroke-dashoffset: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .sales-portal-workspace__sheet,
  .sales-portal-workspace__scrim,
  .sales-portal-toast {
    transition: none;
  }
}

/* ── Home page layout ── */
#common-home {
  width: 100%;
}

.home-layout {
  display: flex;
  gap: 24px;
  padding: 24px var(--page-px, 24px);
  max-width: var(--max-width);
  margin: 0 auto;
  box-sizing: border-box;
}

.home-layout__main {
  flex: 1 1 0;
  min-width: 0;
  min-height: 10rem;
}

/* Home main column is .home-layout__main (not #content) so legacy #content { min-height: 600px } does not apply. */
#common-home .home-layout__main {
  min-height: 0;
}

/* Sidebar column widths when present */
.home-layout--left > *:first-child,
.home-layout--right > *:last-child {
  flex: 0 0 220px;
  min-width: 0;
}

@media (max-width: 640px) {
  .home-layout {
    flex-direction: column;
    gap: 16px;
    padding: 16px 12px;
  }

  .home-layout--left > *:first-child,
  .home-layout--right > *:last-child {
    flex: none;
    width: 100%;
  }
}

/* ── MOOV Hero (KM / custom banner + video) — full-bleed, no broken partial height ── */
.moov-hero-km {
  position: relative;
  width: 100%;
  overflow: hidden;
  background: var(--forest-dark, #0f2419);
  aspect-ratio: 16 / 9;
  min-height: 220px;
  max-height: min(72vh, 680px);
}
.moov-hero-km .moov-hero__video,
.moov-hero-km .moov-hero__img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.moov-hero-km .moov-hero__overlay {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 2;
  color: #fff;
  text-align: center;
  padding: 1.5rem 2rem;
  max-width: 90%;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.45);
}
.moov-hero__eyebrow {
  font-family: var(--moov-font, sans-serif);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  margin-bottom: .75rem;
}
.moov-hero__heading {
  font-family: var(--moov-font, sans-serif);
  font-weight: 600;
  font-size: 24px;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin: 0;
}
.moov-hero__ctas {
  margin-top: 1.5rem;
  display: inline-flex;
  gap: 0.75rem;
  flex-wrap: wrap;
  justify-content: center;
}
.moov-hero__ctas .btn {
  font-size: 11px;
  padding: .5rem 1.5rem;
}
.moov-hero__cta {
  background-color: #fff !important;
  border-color: #fff !important;
  color: #111 !important;
}
.moov-hero__cta:hover,
.moov-hero__cta:focus {
  background-color: transparent !important;
  border-color: #fff !important;
  color: #fff !important;
}
.moov-hero__cta--secondary {
  color: #fff !important;
  border-color: rgba(255, 255, 255, 0.85) !important;
  background: transparent !important;
}
.moov-hero__cta--secondary:hover,
.moov-hero__cta--secondary:focus {
  background: #fff !important;
  border-color: #fff !important;
  color: #111 !important;
}
@media (max-width: 576px) {
  .moov-hero-km {
    aspect-ratio: 4 / 3;
    min-height: 200px;
    max-height: 55vh;
  }
  .moov-hero__heading {
    font-size: 18px;
  }
  .moov-hero-km .moov-hero__overlay {
    padding: 1.25rem;
  }
}

/* ── MOOV Empty State (replaces moov-empty-state) ── */
.moov-empty-state {
  text-align: center;
  padding: 3rem 1.5rem;
  color: var(--moov-text-muted, #888);
}
.moov-empty-state i.fa {
  display: block;
  font-size: 3rem;
  margin-bottom: 1rem;
  opacity: 0.3;
}
.moov-empty-state p {
  margin: 0.5rem 0;
}
.moov-empty-state .btn-primary-moov {
  margin-top: 1rem;
}

/* ── Checkout Success ───────────────────────────────────────────────────── */
#checkout-success {
  padding: 1.25rem 0 2.5rem;
}

#checkout-success .breadcrumb {
  margin: 0 0 1rem;
}

.checkout-success {
  max-width: 760px;
  margin: 0 auto;
}

.checkout-success__card .admin-card__body {
  padding: clamp(1.5rem, 4vw, 2.25rem);
}

.checkout-success__body {
  display: grid;
  gap: 1rem;
}

.checkout-success__heading {
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 3vw, 1.75rem);
  font-weight: 700;
  color: var(--charcoal);
  margin: 0;
  line-height: 1.2;
}

.checkout-success__icon-wrap {
  display: flex;
  justify-content: center;
  margin-bottom: 0.25rem;
}

.checkout-success__checkmark {
  width: 72px;
  height: 72px;
  display: block;
}

.checkout-success__checkmark-circle {
  stroke: var(--s-avail-dot, #2e7d32);
  stroke-width: 2;
  stroke-dasharray: 166;
  stroke-dashoffset: 166;
  stroke-linecap: round;
  animation: checkout-success-circle 0.6s cubic-bezier(0.65, 0, 0.45, 1) forwards;
}

.checkout-success__checkmark-check {
  stroke: var(--s-avail-dot, #2e7d32);
  stroke-width: 3;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 48;
  stroke-dashoffset: 48;
  animation: checkout-success-check 0.35s cubic-bezier(0.65, 0, 0.45, 1) 0.55s forwards;
}

@keyframes checkout-success-circle {
  to { stroke-dashoffset: 0; }
}

@keyframes checkout-success-check {
  to { stroke-dashoffset: 0; }
}

.checkout-success__order-number {
  display: inline-block;
  align-self: start;
  font-family: var(--font-data, "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--forest, #1a3c34);
  background: var(--surface-raised, #f6f9f7);
  border: 1px solid var(--border, #dde6e2);
  border-radius: 999px;
  padding: 0.3rem 0.75rem;
  white-space: nowrap;
}

.checkout-success__order-number span {
  font-weight: 700;
}

.checkout-success__message {
  color: var(--text-body, #374840);
  line-height: 1.65;
  font-size: 0.95rem;
}

.checkout-success__message p {
  margin: 0 0 0.75rem;
}

.checkout-success__message p:last-child {
  margin-bottom: 0;
}

.checkout-success__message a {
  color: var(--copper, #b87333);
  font-weight: 600;
  text-decoration: none;
  border-bottom: 1px solid color-mix(in srgb, var(--copper, #b87333) 30%, transparent);
}

.checkout-success__message a:hover,
.checkout-success__message a:focus {
  color: var(--copper-dark, #9d5d22);
  border-bottom-color: var(--copper-dark, #9d5d22);
}

.checkout-success__actions {
  margin-top: 0.5rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

.checkout-success__customer {
  padding: 0.65rem 1rem;
  background: var(--surface-alt, #f5f7f5);
  border-radius: 6px;
  text-align: left;
}

.checkout-success__customer-name {
  font-weight: 600;
  color: var(--text-heading, #1a2e22);
}

.checkout-success__customer-email {
  font-size: 0.875rem;
  color: var(--text-muted, #607060);
  margin-top: 0.15rem;
}

.checkout-success__totals {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9375rem;
}

.checkout-success__totals-row th,
.checkout-success__totals-row td {
  padding: 0.4rem 0.5rem;
  border-bottom: 1px solid var(--border-light, #dde5dd);
}

.checkout-success__totals-row:last-child th,
.checkout-success__totals-row:last-child td {
  border-bottom: none;
}

.checkout-success__totals-label {
  text-align: left;
  font-weight: 400;
  color: var(--text-body, #374840);
}

.checkout-success__totals-value {
  text-align: right;
  font-variant-numeric: tabular-nums;
}

.checkout-success__totals-row--total .checkout-success__totals-label,
.checkout-success__totals-row--total .checkout-success__totals-value {
  font-weight: 700;
  font-size: 1rem;
  color: var(--text-heading, #1a2e22);
}

@media (max-width: 640px) {
  #checkout-success {
    padding: 1rem 0 2rem;
  }

  .checkout-success__actions {
    flex-direction: column;
  }

  .checkout-success__actions .btn-primary-moov {
    width: 100%;
    justify-content: center;
  }
}

/* ── Commissions / Payouts page ──────────────────────────────────────────── */

.sales-portal-payouts-kpis__tile--pending {
  border-top-color: var(--copper);
}
.sales-portal-payouts-kpis__tile--pending .kpi-tile__value {
  color: var(--copper);
}
.sales-portal-payouts-kpis__tile--paid {
  border-top-color: var(--forest);
}
.sales-portal-payouts-kpis__tile--paid .kpi-tile__value {
  color: var(--forest);
}
.sales-portal-payouts-kpis__tile--hold {
  border-top-color: #1565c0;
}
.sales-portal-payouts-kpis__tile--hold .kpi-tile__value {
  color: #0d47a1;
}
.sales-portal-payouts-kpis__tile--fees {
  border-top-color: #ef6c00;
}
.sales-portal-payouts-kpis__tile--fees .kpi-tile__value {
  color: #c2410c;
}
.sales-portal-payouts-kpis .kpi-tile__value {
  font-variant-numeric: tabular-nums;
}

.sp-payouts-accounting {
  margin-bottom: 24px;
}
.sp-accounting-panels {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
  gap: 16px;
}
.sp-accounting-dl {
  margin: 0;
  padding: 18px 20px;
  background: var(--surface, #fff);
  border: 1px solid var(--border, #e8e6e1);
  border-top: 3px solid var(--forest);
  border-radius: var(--radius-md, 8px);
  box-shadow: 0 2px 8px rgba(var(--forest-rgb), 0.05);
}
.sp-accounting-dl--balance {
  border-top-color: var(--copper);
}
.sp-accounting-dl dt {
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--text-light, #6b7b74);
}
.sp-accounting-dl dd {
  margin: 2px 0 14px;
  font-size: 22px;
  font-weight: 800;
  font-family: var(--font-data);
  font-variant-numeric: tabular-nums;
  color: var(--forest, #1a2e1f);
}
.sp-accounting-dl dd:last-child {
  margin-bottom: 0;
}
.sp-accounting-dl__emph {
  margin-top: 4px;
  padding-top: 12px;
  border-top: 1px solid var(--border, #f0ede8);
}
.sp-accounting-dl__emph-dd {
  font-size: 28px;
  font-weight: 800;
  color: var(--forest);
}

/* Filter bar */
.sp-commissions-filter-wrap {
  margin-bottom: 24px;
}
.sp-commissions-filter {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 12px 16px;
  background: var(--surface-alt, #f7f7f5);
  border: 1px solid var(--border, #dde6e2);
  border-radius: var(--radius-md, 7px);
  padding: 16px 18px;
}
.sp-commissions-filter__fields {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 16px;
  flex: 1 1 auto;
  min-width: 0;
}
.sp-commissions-filter__group {
  display: flex;
  flex-direction: column;
  gap: 5px;
  min-width: 140px;
}
.sp-commissions-filter__label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted, #6b7b74);
  font-family: var(--font-body);
}
.sp-commissions-filter__select,
.sp-commissions-filter__input {
  height: 38px;
  padding: 0 10px;
  font-size: 14px;
  line-height: 1.35;
  border: 1.5px solid var(--border, #dde6e2);
  border-radius: var(--radius-sm, 4px);
  background: var(--white, #fff);
  color: var(--text-body, #374840);
  font-family: var(--font-body);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
  box-sizing: border-box;
}
.sp-commissions-filter__select:focus,
.sp-commissions-filter__input:focus {
  outline: none;
  border-color: var(--copper);
  box-shadow: 0 0 0 3px rgba(var(--copper-rgb),0.15);
}
.sp-commissions-filter__actions {
  display: flex;
  align-items: flex-end;
  gap: 8px;
  flex-shrink: 0;
}
.sp-commissions-filter__status {
  margin-top: 8px;
  font-size: 13px;
  color: var(--text-muted, #6b7b74);
  font-family: var(--font-data);
  min-height: 1.4em;
}

/* Table section */
.sp-commissions-history {
  margin-bottom: 32px;
}
.sp-commissions-history__title {
  font-size: 1rem;
  margin: 0 0 12px;
}

.sp-payout-tabs {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--border-light, #e5e7eb);
  margin-bottom: 16px;
}

.sp-payout-tab {
  padding: 8px 20px;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  background: none;
  font-size: 13px;
  font-family: var(--font-body);
  font-weight: 500;
  color: var(--text-muted);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
  white-space: nowrap;
}

.sp-payout-tab:hover {
  color: var(--text-body);
}

.sp-payout-tab--active {
  color: var(--color-primary, #3b82f6);
  border-bottom-color: var(--color-primary, #3b82f6);
  font-weight: 600;
}
.sales-portal-table-wrap--payouts {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable;
  position: relative;
}
@media (min-width: 769px) {
  .sales-portal-table--payouts {
    min-width: 960px;
  }
}

/* Prevent header text from wrapping vertically */
.sales-portal-table--payouts thead th {
  white-space: nowrap;
}

/* Column widths */
.sales-portal-table--payouts th:nth-child(1),
.sales-portal-table--payouts td:nth-child(1) { min-width: 90px; }
.sales-portal-table--payouts th:nth-child(2),
.sales-portal-table--payouts td:nth-child(2) { min-width: 100px; }
.sales-portal-table--payouts th:nth-child(9),
.sales-portal-table--payouts td:nth-child(9) { min-width: 90px; }
.sales-portal-table--payouts th:nth-child(10),
.sales-portal-table--payouts td:nth-child(10) { min-width: 90px; }

/* Column alignment */
.sp-col-money {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-family: var(--font-data);
}
.sp-col-money--negative {
  color: #a42222;
  font-weight: 600;
}

/* Payouts: quick status tabs (All / Pending / Released) */
.sp-payout-status-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 16px;
}
.sp-payout-status-tabs__link {
  display: inline-block;
  padding: 8px 14px;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  color: var(--text-muted, #5c6b66);
  border: 1px solid rgba(0, 0, 0, 0.08);
  background: #fff;
}
.sp-payout-status-tabs__link:hover {
  border-color: rgba(var(--forest-rgb), 0.35);
  color: var(--forest, #1f5c3f);
}
.sp-payout-status-tabs__link.is-active {
  background: rgba(var(--forest-rgb), 0.12);
  border-color: rgba(var(--forest-rgb), 0.45);
  color: var(--forest, #1f5c3f);
}

/* B2B order list: outstanding invoice aging drill-down */
.order-invoice-aging {
  margin-bottom: 20px;
}
.order-invoice-aging__grid {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.order-invoice-aging__bucket-title {
  margin: 0 0 8px;
  font-size: 15px;
  font-weight: 700;
}
.order-invoice-aging__bucket-total {
  font-weight: 600;
  color: var(--text-muted, #5c6b66);
}
.order-table--compact th,
.order-table--compact td {
  font-size: 13px;
}
.sp-col-deduct {
  color: var(--text-muted, #6b7b74);
}
.sp-col-net {
  font-weight: 700;
  color: var(--forest);
}
.sp-kpi-sub {
  display: inline-block;
  margin-left: 5px;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted, #6b7b74);
  vertical-align: middle;
  letter-spacing: 0.02em;
}
.sp-payout-net {
  color: var(--forest);
  font-size: 15px;
}

/* Row highlight by status */
.sp-payout-row--pending td {
  background: rgba(var(--copper-rgb),0.03);
}
.sp-payout-row--released td {
  background: rgba(var(--forest-rgb), 0.025);
}

/* Status badges */
.sp-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 10px;
  border-radius: var(--radius-pill, 999px);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-family: var(--font-body);
  white-space: nowrap;
}
.sp-status-badge--pending {
  background: rgba(var(--copper-rgb),0.12);
  color: var(--copper-hover);
  border: 1px solid rgba(var(--copper-rgb),0.3);
}
.sp-status-badge--pending::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--copper);
  flex-shrink: 0;
}
.sp-status-badge--released {
  background: rgba(var(--forest-rgb), 0.1);
  color: var(--forest);
  border: 1px solid rgba(var(--forest-rgb), 0.22);
}
.sp-status-badge--released::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--forest);
  flex-shrink: 0;
}
.sp-status-badge--cod {
  background: rgba(180, 120, 0, 0.1);
  color: #7a5000;
  border: 1px solid rgba(180, 120, 0, 0.28);
  font-size: 10px;
  padding: 2px 7px;
  vertical-align: middle;
}
.sp-status-badge--leaflink {
  background: rgba(32, 201, 151, 0.12);
  color: #0d7a5f;
  border: 1px solid rgba(32, 201, 151, 0.35);
  font-size: 10px;
  padding: 2px 7px;
  vertical-align: middle;
}
.sp-status-badge--distru {
  background: rgba(232, 62, 140, 0.1);
  color: #a01060;
  border: 1px solid rgba(232, 62, 140, 0.28);
  font-size: 10px;
  padding: 2px 7px;
  vertical-align: middle;
}

/* Order links */
.sp-link {
  color: var(--copper);
  font-weight: 600;
  text-decoration: none;
  font-family: var(--font-data);
}
.sp-link:hover {
  text-decoration: underline;
  color: var(--copper-hover);
}

/* Loading overlay */
.sp-commissions-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 32px;
  color: var(--text-muted, #6b7b74);
  font-size: 14px;
  font-family: var(--font-data);
}
.sp-commissions-loading__spinner {
  width: 20px;
  height: 20px;
  border: 2px solid var(--border, #dde6e2);
  border-top-color: var(--copper);
  border-radius: 50%;
  animation: sp-spin 0.7s linear infinite;
  flex-shrink: 0;
}
@keyframes sp-spin {
  to { transform: rotate(360deg); }
}

/* Fade in when table is refreshed */
@keyframes sp-fade-in {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.sp-commissions-tbody--loading {
  opacity: 0.4;
  pointer-events: none;
  transition: opacity 0.15s ease;
}
.sp-commissions-tbody--loaded {
  animation: sp-fade-in 0.2s ease forwards;
}

@media (max-width: 768px) {
  /* ── Filter bar ── */
  .sp-commissions-filter {
    flex-direction: column;
    align-items: stretch;
    padding: 14px 14px 16px;
  }
  .sp-commissions-filter__fields {
    flex-direction: column;
    gap: 10px;
  }
  .sp-commissions-filter__group {
    min-width: 0;
    width: 100%;
  }
  .sp-commissions-filter__select,
  .sp-commissions-filter__input {
    width: 100%;
    height: 44px;
    font-size: 15px;
  }
  .sp-commissions-filter__actions {
    flex-direction: row;
    gap: 8px;
    margin-top: 4px;
  }
  .sp-commissions-filter__actions .sales-portal-chip {
    flex: 1 1 0;
    text-align: center;
    justify-content: center;
  }

  /* ── Table → card layout ── */
  .sales-portal-table-wrap--payouts {
    overflow-x: visible;
    margin-left: 0;
    margin-right: 0;
    padding-left: 0;
    padding-right: 0;
  }
  .sales-portal-table--payouts {
    min-width: 0;
    width: 100%;
  }
  .sales-portal-table--payouts thead {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }

  /* Each row becomes a card with flex column layout */
  .sales-portal-table--payouts tbody tr:not(.sales-portal-table__empty-row) {
    display: flex;
    flex-direction: column;
    padding: 0;
    margin-bottom: 12px;
    background: var(--surface, #fff);
    border: 1px solid var(--border, #e8e6e1);
    border-radius: var(--radius-md, 8px);
    box-shadow: 0 2px 10px rgba(26, 46, 31, 0.06);
    overflow: hidden;
  }

  /* Status accent strip on left edge */
  .sales-portal-table--payouts tbody tr.sp-payout-row--pending {
    border-left: 3px solid var(--copper, #b87333);
  }
  .sales-portal-table--payouts tbody tr.sp-payout-row--released {
    border-left: 3px solid var(--forest, #1a3c34);
  }

  /* All cells: base style as flex-row label|value */
  .sales-portal-table--payouts tbody tr:not(.sales-portal-table__empty-row) td {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 14px;
    font-size: 14px;
    border: none;
    gap: 10px;
  }
  .sales-portal-table--payouts tbody tr:not(.sales-portal-table__empty-row) td::before {
    content: attr(data-label);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--text-muted, #6b7b74);
    flex-shrink: 0;
    white-space: nowrap;
  }
  .sales-portal-table--payouts .sales-portal-table__cell-val {
    text-align: right;
    min-width: 0;
    word-break: break-word;
  }

  /* ─── Card header: Order # ─── (ORDER 1) */
  .sales-portal-table--payouts td.sp-payouts-order-cell {
    order: 1;
    padding: 12px 14px 10px;
    border-bottom: 1px solid var(--border, #f0ede8);
    justify-content: flex-start;
    gap: 8px;
  }
  .sales-portal-table--payouts td.sp-payouts-order-cell::before {
    display: none;
  }
  .sales-portal-table--payouts .sp-payouts-order-cell__main {
    flex-direction: row;
    align-items: center;
    gap: 8px;
    width: 100%;
    flex-wrap: wrap;
  }
  .sales-portal-table--payouts .sp-link {
    font-size: 15px;
    font-weight: 700;
  }

  /* ─── Status badge ─── (ORDER 2) */
  .sales-portal-table--payouts tbody td:nth-child(9) {
    order: 2;
    justify-content: flex-start;
    padding: 8px 14px 4px;
  }
  .sales-portal-table--payouts tbody td:nth-child(9)::before {
    display: none;
  }

  /* ─── Net Payout hero ─── (ORDER 3) */
  .sales-portal-table--payouts td.sp-col-net {
    order: 3;
    flex-direction: column;
    align-items: flex-start;
    gap: 3px;
    padding: 10px 14px 12px;
    background: rgba(var(--forest-rgb), 0.04);
    border-top: 1px solid var(--border, #f0ede8);
    border-bottom: 1px solid var(--border, #f0ede8);
  }
  .sales-portal-table--payouts td.sp-col-net::before {
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--text-muted, #6b7b74);
  }
  .sales-portal-table--payouts .sp-payout-net {
    font-size: 28px;
    font-weight: 800;
    font-variant-numeric: tabular-nums;
    line-height: 1.1;
    color: var(--forest, #1a3c34);
    font-family: var(--font-data);
  }
  .sales-portal-table--payouts tbody tr.sp-payout-row--pending td.sp-col-net {
    background: rgba(184, 115, 51, 0.05);
  }
  .sales-portal-table--payouts tbody tr.sp-payout-row--pending .sp-payout-net {
    color: var(--copper, #b87333);
  }

  /* ─── Order date ─── (ORDER 4) */
  .sales-portal-table--payouts tbody td:nth-child(2) {
    order: 4;
    font-size: 13px;
    padding: 8px 14px 4px;
    color: var(--text-muted, #6b7b74);
  }
  .sales-portal-table--payouts tbody td:nth-child(2) .sales-portal-table__cell-val {
    font-family: var(--font-body);
    text-align: right;
  }

  /* ─── Paid-on date ─── (ORDER 5) */
  .sales-portal-table--payouts tbody td:nth-child(10) {
    order: 5;
    font-size: 13px;
    padding: 4px 14px 8px;
    color: var(--text-muted, #6b7b74);
  }
  .sales-portal-table--payouts tbody td:nth-child(10) .sales-portal-table__cell-val {
    font-family: var(--font-body);
    text-align: right;
  }

  /* ─── Fee breakdown ─── (ORDERS 6–10) */
  .sales-portal-table--payouts tbody td:nth-child(3) { order: 6; }
  .sales-portal-table--payouts tbody td:nth-child(4) { order: 7; }
  .sales-portal-table--payouts tbody td:nth-child(5) { order: 8; }
  .sales-portal-table--payouts tbody td:nth-child(6) { order: 9; }
  .sales-portal-table--payouts tbody td:nth-child(7) { order: 10; }

  .sales-portal-table--payouts tbody td:nth-child(3) {
    padding-top: 10px;
    margin-top: 2px;
    border-top: 1px solid var(--border, #f0ede8);
    font-size: 13px;
  }
  .sales-portal-table--payouts tbody td:nth-child(4),
  .sales-portal-table--payouts tbody td:nth-child(5),
  .sales-portal-table--payouts tbody td:nth-child(6),
  .sales-portal-table--payouts tbody td:nth-child(7) {
    font-size: 13px;
  }
  .sales-portal-table--payouts tbody td:nth-child(7) {
    padding-bottom: 12px;
  }
  .sales-portal-table--payouts td.sp-col-money .sales-portal-table__cell-val {
    font-variant-numeric: tabular-nums;
    font-family: var(--font-data);
    text-align: right;
    font-size: 13px;
    font-weight: 600;
  }

  /* Empty row */
  .sales-portal-table--payouts tbody tr.sales-portal-table__empty-row {
    display: block;
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
    margin: 0;
  }
  .sales-portal-table--payouts tbody tr.sales-portal-table__empty-row td {
    display: block;
    text-align: center;
    padding: 24px 12px;
    color: var(--text-muted, #666);
    font-size: 14px;
  }

  /* ── KPI tiles: 2-col grid on mobile for payouts page ── */
  body.sales-portal .sales-portal-page--payouts .kpi-tiles {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
  }
  body.sales-portal .sales-portal-page--payouts .kpi-tile__value {
    font-size: 22px;
  }
  body.sales-portal .sales-portal-page--payouts .kpi-tile__sub {
    font-size: 11px;
  }

  /* ── Accounting panels: single column ── */
  .sp-accounting-panels {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .sp-accounting-dl {
    padding: 14px 16px;
  }
  .sp-accounting-dl dd {
    font-size: 18px;
  }
  .sp-accounting-dl__emph-dd {
    font-size: 22px;
  }
}

.sp-payouts-order-cell__main {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.sp-payout-row--disp-paid .sp-payouts-order-cell__main .sp-link {
  font-weight: 700;
}

/* Brand portal (supplier balances / AP visibility) */
.brand-portal-disclaimer {
  margin-bottom: 1rem;
  max-width: 48rem;
}
.brand-portal-shell__single-supplier {
  font-size: 0.875rem;
  color: var(--moov-text-muted, #666);
  padding: 0 0.5rem;
}
.brand-portal-pagination .pagination {
  margin-top: 1rem;
}

/* ── Sales Reports page ─────────────────────────────────────────────────── */
.sp-tab-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  border-bottom: 2px solid var(--border, #e5e5e5);
  margin-bottom: 24px;
}
.sp-tab-nav__tab {
  display: inline-block;
  padding: 8px 18px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-muted, #666);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  border-radius: 4px 4px 0 0;
  transition: color 0.15s, border-color 0.15s;
}
.sp-tab-nav__tab:hover {
  color: var(--forest);
}
.sp-tab-nav__tab--active {
  color: var(--copper);
  border-bottom-color: var(--copper);
}
.sp-filter-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 12px 20px;
  margin-bottom: 20px;
}
.sp-filter-bar--inline {
  align-items: center;
}
.sp-filter-bar__group {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.sp-filter-bar__label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-muted, #666);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.sp-filter-bar__actions {
  display: flex;
  align-items: center;
  gap: 8px;
}
.sp-report-rep-filter {
  margin-bottom: 16px;
  padding: 14px 18px;
  background: var(--surface-alt, #f8f7f4);
  border: 1px solid var(--border, #e5e5e5);
  border-radius: 8px;
}
.sp-report-leaderboard-sort {
  margin-bottom: 14px;
}
.sp-report-intro {
  font-size: 13px;
  color: var(--text-muted, #666);
  margin-bottom: 16px;
}
.sp-report-panel {
  margin-top: 8px;
}
.sp-col-rank {
  width: 40px;
  text-align: center;
  font-variant-numeric: tabular-nums;
}
.sp-col-money {
  text-align: right;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.sp-row--alert {
  background: var(--warn-surface, #fff8ec);
}
.sp-row--muted {
  opacity: 0.7;
}
.sp-badge {
  display: inline-block;
  padding: 1px 7px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  vertical-align: middle;
  margin-left: 6px;
}
.sp-badge--warn {
  background: var(--warn, #f59e0b);
  color: #fff;
}
@media (max-width: 600px) {
  .sp-filter-bar {
    flex-direction: column;
    align-items: stretch;
  }
  .sp-filter-bar__actions {
    align-self: flex-start;
  }
  .sp-tab-nav__tab {
    padding: 8px 12px;
    font-size: 13px;
  }
  .sp-report-rep-filter {
    padding: 10px 12px;
  }
}

/* Reports tables — mobile card layout */
.sales-portal-table-wrap--reports {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable;
}
.sales-portal-table--reports {
  min-width: 560px;
}

@media (max-width: 640px) {
  .sales-portal-table-wrap--reports {
    overflow-x: visible;
    padding-left: 0;
    padding-right: 0;
  }
  .sales-portal-table--reports {
    min-width: 0;
    width: 100%;
  }
  .sales-portal-table--reports thead {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
  .sales-portal-table--reports tbody tr:not(.sales-portal-table__empty-row) {
    display: block;
    padding: 12px 14px;
    margin-bottom: 10px;
    background: var(--surface, #fff);
    border: 1px solid var(--border, #e8e6e1);
    border-radius: var(--radius-md, 8px);
    box-shadow: 0 2px 8px rgba(26, 46, 31, 0.04);
  }
  .sales-portal-table--reports tbody tr.sales-portal-table__empty-row {
    display: block;
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
    margin: 0;
  }
  .sales-portal-table--reports tbody tr.sales-portal-table__empty-row td {
    display: block;
    text-align: center;
    padding: 20px 12px;
    border-bottom: none;
    color: var(--text-muted, #666);
    font-size: 14px;
  }
  .sales-portal-table--reports tbody tr:not(.sales-portal-table__empty-row) td {
    display: grid;
    grid-template-columns: minmax(80px, 38%) minmax(0, 1fr);
    column-gap: 10px;
    row-gap: 2px;
    align-items: start;
    padding: 7px 0;
    border-bottom: 1px solid var(--border, #f0ede8);
    vertical-align: top;
    text-align: left;
    font-size: 13px;
    word-break: break-word;
    overflow-wrap: anywhere;
  }
  .sales-portal-table--reports tbody tr:not(.sales-portal-table__empty-row) td:last-child {
    border-bottom: none;
  }
  .sales-portal-table--reports tbody tr:not(.sales-portal-table__empty-row) td::before {
    content: attr(data-label);
    grid-column: 1;
    font-weight: 700;
    font-size: 10px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--text-muted, #666);
    line-height: 1.3;
    padding-top: 1px;
  }
  .sales-portal-table--reports .sp-col-money,
  .sales-portal-table--reports .sp-col-rank {
    text-align: left;
    white-space: normal;
  }
  .sales-portal-table--reports tr.sp-row--alert {
    background: var(--warn-surface, #fff8ec);
    border-color: var(--warn, #f59e0b);
  }
  .sales-portal-table--reports tr.sp-row--muted {
    opacity: 0.7;
  }
}

/* ── Reports AJAX ──────────────────────────────────────────────────────────── */
.sp-tab-nav__tab {
  background: none;
  border: none;
  cursor: pointer;
  font-family: inherit;
}
.sp-reports-status {
  margin-bottom: 12px;
  padding: 10px 14px;
  border-radius: 6px;
  font-size: 13px;
  background: var(--warn-surface, #fff8ec);
  color: var(--text, #111);
  border: 1px solid var(--warn, #f59e0b);
}
.sp-report-table-wrap {
  position: relative;
  min-height: 120px;
}
.sp-report-table-wrap[aria-busy="true"] .sp-report-skeleton { display: block; }
.sp-report-table-wrap[aria-busy="true"] .sp-report-table    { display: none !important; }
.sp-report-table-wrap[aria-busy="false"] .sp-report-skeleton { display: none; }
.sp-report-table-wrap[aria-busy="false"] .sp-report-table   { display: table; }
.sp-report-skeleton {
  padding: 8px 0;
}
.sp-report-skeleton__row {
  height: 18px;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--surface-alt, #f3f3f0) 25%, var(--border, #e5e5e5) 50%, var(--surface-alt, #f3f3f0) 75%);
  background-size: 200% 100%;
  animation: sp-shimmer 1.4s infinite;
  margin-bottom: 10px;
  width: 100%;
}
.sp-report-skeleton__row--short { width: 60%; }
@keyframes sp-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ── CRM table: notes column ───────────────────────────────────────────────── */
.sp-col-crm-notes {
  width: 80px;
  text-align: center;
  white-space: nowrap;
}
.sp-crm-notes-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  border-radius: 999px;
  border: 1px solid var(--border, #e5e7eb);
  background: var(--surface, #fff);
  color: var(--text-body, #444);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s, color 0.15s, box-shadow 0.15s;
  white-space: nowrap;
}
.sp-crm-notes-btn:hover {
  background: var(--sage-bg, #f2f5f0);
  border-color: var(--forest-mid, #6a8f73);
  color: var(--forest-dark, #1a2e1f);
}
.sp-crm-notes-btn__count {
  display: inline-block;
  min-width: 18px;
  height: 18px;
  line-height: 18px;
  text-align: center;
  border-radius: 9px;
  background: var(--forest-mid, #6a8f73);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 0 5px;
}
.sp-crm-notes-btn--has-notes {
  border-color: var(--forest-mid, #6a8f73);
  background: var(--forest-light, #f0f7f4);
  color: var(--forest-dark, #1a2e1f);
}
.sales-portal-table--crm tbody tr {
  cursor: pointer;
}
.sales-portal-table--crm tbody tr:hover td {
  background: var(--sage-bg, #f4f6f2);
}

/* ── Report panel header (intro + optional inline action) ──────────────────── */
.sp-report-panel__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.sp-report-panel__header-intro {
  flex: 1 1 260px;
  margin-bottom: 0;
}
.sp-report-panel__header-action {
  flex-shrink: 0;
  white-space: nowrap;
}
@media (max-width: 600px) {
  .sp-report-panel__header {
    align-items: stretch;
  }
  .sp-report-panel__header-action {
    width: 100%;
    justify-content: center;
  }
}

/* ── CRM customer search in drawer ─────────────────────────────────────────── */
.sp-crm-customer-search {
  position: relative;
}
.sp-crm-cust-results {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  z-index: 20;
  background: var(--white, #fff);
  border: 1px solid var(--border, #e5e5e5);
  border-radius: 8px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.12);
  max-height: 260px;
  overflow-y: auto;
}
.sp-crm-cust-result {
  display: flex;
  flex-direction: column;
  gap: 2px;
  width: 100%;
  padding: 10px 14px;
  background: none;
  border: none;
  border-bottom: 1px solid var(--border, #f0ede8);
  text-align: left;
  cursor: pointer;
  transition: background 0.1s;
}
.sp-crm-cust-result:last-child {
  border-bottom: none;
}
.sp-crm-cust-result:hover {
  background: var(--sage-bg, #f4f6f2);
}
.sp-crm-cust-result--loading,
.sp-crm-cust-result--empty {
  cursor: default;
  color: var(--text-muted, #888);
  font-size: 13px;
  pointer-events: none;
}
.sp-crm-cust-result--loading:hover,
.sp-crm-cust-result--empty:hover {
  background: none;
}
.sp-crm-cust-result__name {
  font-weight: 600;
  font-size: 13px;
  color: var(--text, #1a1a1a);
}
.sp-crm-cust-result__branch {
  font-size: 12px;
  color: var(--text-muted, #777);
}

/* ── CRM Notes Drawer ──────────────────────────────────────────────────────── */
.sp-crm-drawer-overlay {
  position: fixed;
  inset: 0;
  z-index: 700;
  background: rgba(0, 0, 0, 0.35);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s;
}
.sp-crm-drawer-overlay.is-open {
  opacity: 1;
  pointer-events: auto;
}
.sp-crm-drawer {
  width: 480px;
  max-width: 100vw;
  z-index: 710;
}
.sp-crm-drawer__title-group {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.sp-crm-drawer__subtitle {
  font-size: 13px;
  color: var(--text-muted, #666);
  font-weight: 400;
  overflow-wrap: anywhere;
  word-break: break-word;
}
.sp-crm-drawer__section {
  margin-bottom: 24px;
}
.sp-crm-drawer__section:last-child {
  margin-bottom: 0;
}
.sp-crm-note-form__row--split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 12px;
}
.sp-crm-note-form__row--split > .field {
  min-width: 0;
}
.sp-crm-note-body {
  resize: vertical;
  min-height: 90px;
}
.sp-crm-note-body__counter {
  text-align: right;
  font-size: 11px;
  color: var(--text-muted, #888);
  margin-top: 4px;
}
.sp-crm-notes-loading {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 0;
  font-size: 14px;
  color: var(--text-muted, #666);
}
.sp-crm-notes-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.sp-crm-note-card {
  border: 1px solid var(--border, #e8e6e1);
  border-left: 3px solid var(--forest-mid, #6a8f73);
  border-radius: 8px;
  padding: 14px 16px;
  background: var(--surface, #fff);
  box-shadow: 0 1px 3px rgba(26, 46, 31, 0.04);
  position: relative;
  transition: box-shadow 0.15s, border-color 0.15s;
}
.sp-crm-note-card:hover {
  box-shadow: 0 2px 8px rgba(26, 46, 31, 0.08);
}
.sp-crm-note-card[data-note-type="call"]      { border-left-color: #1a4ea6; }
.sp-crm-note-card[data-note-type="visit"]     { border-left-color: #136a3a; }
.sp-crm-note-card[data-note-type="follow_up"] { border-left-color: #8a5c00; }
.sp-crm-note-card[data-note-type="general"]   { border-left-color: var(--forest-mid, #6a8f73); }
.sp-crm-note-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 8px;
}
.sp-crm-note-card__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}
.sp-crm-note-card__author {
  font-weight: 700;
  font-size: 13px;
  color: var(--text, #1a1a1a);
}
.sp-crm-note-card__date {
  font-size: 12px;
  color: var(--text-muted, #777);
}
.sp-crm-note-card__type {
  display: inline-block;
  padding: 1px 8px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: var(--sage-bg, #edf0ea);
  color: var(--forest-dark, #1a2e1f);
  border: 1px solid var(--forest-border, #d4ddd5);
}
.sp-crm-note-card__type--call     { background: #e6f0ff; color: #1a4ea6; border-color: #b8d0f5; }
.sp-crm-note-card__type--visit    { background: #e6fff0; color: #136a3a; border-color: #9de0bc; }
.sp-crm-note-card__type--follow_up { background: #fff8e6; color: #8a5c00; border-color: #f0d580; }
.sp-crm-note-card__type--general  { background: var(--sage-bg, #edf0ea); color: var(--forest-dark, #1a2e1f); border-color: var(--forest-border, #d4ddd5); }
.sp-crm-note-card__body {
  font-size: 13px;
  line-height: 1.55;
  color: var(--text-body, #333);
  white-space: pre-wrap;
  word-break: break-word;
}
.sp-crm-note-card__delete {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-muted, #aaa);
  padding: 2px 4px;
  border-radius: 4px;
  flex-shrink: 0;
  font-size: 12px;
  transition: color 0.15s, background 0.15s;
  margin-top: 1px;
}
.sp-crm-note-card__delete:hover {
  color: #c0392b;
  background: #fff0ee;
}
.sp-crm-notes-empty {
  padding: 20px 0;
  text-align: center;
  font-size: 14px;
  color: var(--text-muted, #888);
}
@media (max-width: 640px) {
  .sales-portal-table--crm.sales-portal-table--reports tbody tr:not(.sales-portal-table__empty-row) td.sp-col-crm-notes {
    white-space: normal;
    width: auto;
    text-align: left;
  }
  .sales-portal-table--crm.sales-portal-table--reports .sp-crm-notes-btn {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 600px) {
  .sp-crm-drawer {
    width: 100vw;
  }
  .sp-crm-note-form__row--split {
    grid-template-columns: 1fr;
  }
}

/* ── Customer page tabs ────────────────────────────────────────────────────── */
.sp-customers-tabs {
  display: flex;
  gap: 4px;
  border-bottom: 2px solid var(--border, #e5e7eb);
  margin-bottom: 20px;
}

.sp-customers-tab {
  position: relative;
  padding: 10px 18px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 600;
  color: var(--text-body, #555);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
  display: flex;
  align-items: center;
  gap: 8px;
}

.sp-customers-tab:hover {
  color: var(--forest);
}

.sp-customers-tab.is-active {
  color: var(--forest);
  border-bottom-color: var(--forest);
}

.sp-customers-tab__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  background: var(--forest);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
}

/* ── Pending approval panel ────────────────────────────────────────────────── */
.sp-pending-panel {
  padding-top: 8px;
}

.sp-pending-loading {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 24px 0;
  color: var(--text-muted, #888);
  font-size: 14px;
}

.sp-pending-loading__spinner {
  display: inline-block;
  width: 18px;
  height: 18px;
  border: 2px solid var(--border, #e5e7eb);
  border-top-color: var(--forest);
  border-radius: 50%;
  animation: sp-spin 0.7s linear infinite;
  flex-shrink: 0;
}

.sp-pending-empty {
  padding: 32px 0;
  text-align: center;
  color: var(--text-muted, #888);
  font-size: 14px;
}

.sp-pending-date {
  font-size: 12px;
  color: var(--text-muted, #888);
}

/* ── Register slide-over drawer wizard ─────────────────────────────────────── */
.sp-reg-wizard-progress {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 12px 24px 14px;
  border-bottom: 1px solid var(--border, #e5e7eb);
  background: var(--sage-bg, #f4f6f2);
  flex-shrink: 0;
}

.sp-reg-wizard-steps {
  display: flex;
  align-items: center;
  gap: 0;
}

.sp-reg-wizard-step {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  cursor: pointer;
  padding: 4px 0;
  position: relative;
}

.sp-reg-wizard-step:not(:last-child)::after {
  content: '';
  flex: 1;
  height: 2px;
  background: var(--border, #e5e7eb);
  margin: 0 8px;
  border-radius: 1px;
  transition: background 0.25s;
}

.sp-reg-wizard-step.is-completed:not(:last-child)::after {
  background: var(--forest);
}

.sp-reg-wizard-step__num {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 2px solid var(--border, #ccc);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  background: #fff;
  color: var(--text-muted, #888);
  flex-shrink: 0;
  transition: background 0.2s, border-color 0.2s, color 0.2s;
}

.sp-reg-wizard-step.is-active .sp-reg-wizard-step__num {
  background: var(--forest);
  border-color: var(--forest);
  color: #fff;
}

.sp-reg-wizard-step.is-completed .sp-reg-wizard-step__num {
  background: var(--forest);
  border-color: var(--forest);
  color: #fff;
}

.sp-reg-wizard-step__label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-muted, #888);
  white-space: nowrap;
  transition: color 0.2s;
}

.sp-reg-wizard-step.is-active .sp-reg-wizard-step__label {
  color: var(--forest);
}

.sp-reg-wizard-step.is-completed .sp-reg-wizard-step__label {
  color: var(--forest);
}

.sp-reg-wizard-bar {
  height: 3px;
  background: var(--border, #e5e7eb);
  border-radius: 2px;
  overflow: hidden;
}

.sp-reg-wizard-bar__fill {
  height: 100%;
  background: var(--forest);
  border-radius: 2px;
  transition: width 0.3s ease;
}

.sp-reg-wizard-panel {
  display: none;
}

.sp-reg-wizard-panel.is-active {
  display: block;
}

.sp-reg-drawer__nav {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* valid/error states on field inputs inside drawer */
.sp-reg-field-valid .field__input,
.sp-reg-field-valid .field__select {
  border-color: #2d9e5f;
}

.sp-reg-field-error .field__input,
.sp-reg-field-error .field__select {
  border-color: #b00020 !important;
}

/* ── Register slide-over drawer ────────────────────────────────────────────── */
.sp-reg-drawer-overlay {
  position: fixed;
  inset: 0;
  z-index: 700;
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(2px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s;
}

.sp-reg-drawer-overlay.is-open {
  opacity: 1;
  pointer-events: auto;
}

.sp-reg-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: 600px;
  max-width: 100vw;
  background: var(--white, #fff);
  z-index: 701;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: -8px 0 40px rgba(0,0,0,0.18);
}

.sp-reg-drawer.is-open {
  transform: translateX(0);
}

.sp-reg-drawer__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px 16px;
  border-bottom: 1px solid var(--border, #e5e7eb);
  flex-shrink: 0;
  position: sticky;
  top: 0;
  background: var(--white, #fff);
  z-index: 2;
}

.sp-reg-drawer__title {
  font-family: var(--font-heading, var(--font-body));
  font-size: 18px;
  font-weight: 700;
  color: var(--charcoal, #1a1a2e);
  margin: 0;
}

.sp-reg-drawer__close {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1.5px solid var(--border, #e5e7eb);
  background: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-body, #555);
  transition: background 0.15s, color 0.15s;
  flex-shrink: 0;
}

.sp-reg-drawer__close:hover {
  background: var(--sage-bg, #f4f6f2);
  color: var(--charcoal, #1a1a2e);
}

.sp-reg-drawer__body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 20px 24px;
}

.sp-reg-drawer__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 24px;
  border-top: 1px solid var(--border, #e5e7eb);
  flex-shrink: 0;
  background: var(--white, #fff);
}

.sp-reg-drawer__alert {
  border-radius: 6px;
  padding: 12px 16px;
  font-size: 14px;
  margin-bottom: 16px;
}

.sp-reg-drawer__alert--error {
  background: #fff0f0;
  color: #b00020;
  border: 1px solid #f5c2c7;
}

.sp-reg-drawer__alert--success {
  background: #f0fff4;
  color: #1a7a3e;
  border: 1px solid #b6e8c8;
}

.sp-reg-drawer__submit-spinner {
  display: inline-block;
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255,255,255,0.4);
  border-top-color: #fff;
  border-radius: 50%;
  animation: sp-spin 0.7s linear infinite;
  vertical-align: middle;
}

@keyframes sp-spin {
  to { transform: rotate(360deg); }
}

.sales-register-form--drawer .sales-register-form__section {
  margin-bottom: 24px;
}

.sales-register-form--drawer .sales-register-form__section-title {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--forest);
  margin: 0 0 12px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border, #e5e7eb);
}

.sales-register-form--drawer .sales-register-form__section-hint {
  font-size: 13px;
  color: var(--text-muted, #888);
  margin: -6px 0 12px;
}

.field__input--error {
  border-color: #b00020 !important;
}

/* ── File upload widget ─────────────────────────────────────────────────────── */
.sp-file-upload {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

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

.sp-file-upload__label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 16px;
  border-radius: 6px;
  border: 1.5px dashed var(--forest-border, #89b49c);
  background: var(--forest-light, #f0f7f4);
  color: var(--forest);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  width: fit-content;
}

.sp-file-upload__label:hover {
  background: var(--forest-bg, #e4f0ea);
  border-color: var(--forest);
}

.sp-file-upload__name {
  font-size: 12px;
  color: var(--text-muted, #888);
  word-break: break-all;
}

@media (max-width: 640px) {
  .sp-reg-drawer {
    width: 100vw;
  }
  .sp-reg-drawer__footer {
    flex-wrap: wrap;
    gap: 8px;
  }
  .sp-reg-drawer__footer > .btn-ghost-moov {
    order: 3;
    flex: 1 1 100%;
    text-align: center;
    justify-content: center;
  }
  .sp-reg-drawer__nav {
    flex: 1 1 100%;
    justify-content: flex-end;
  }
  .sp-reg-wizard-step__label {
    display: none;
  }
}

/* ── Add-rep drawer: password row ───────────────────────────────────────────── */
.sp-rep-pw-row {
  display: flex;
  gap: 8px;
  align-items: stretch;
}

.sp-rep-pw-row .field__input {
  flex: 1;
}

/* ── Add-rep drawer: field hint ─────────────────────────────────────────────── */
.field__hint {
  font-size: 12px;
  color: var(--text-mute, #666);
  margin-top: 4px;
}

/* ── Add-rep drawer: success view ───────────────────────────────────────────── */
.sp-rep-success-view {
  text-align: center;
  padding: 40px 8px 24px;
}

.sp-rep-success-view__icon {
  color: var(--forest, #2d7a55);
  margin-bottom: 16px;
}

.sp-rep-success-view__icon .material-icons {
  font-size: 64px;
  line-height: 1;
}

.sp-rep-success-view__msg {
  font-size: 16px;
  font-weight: 600;
  color: var(--charcoal, #1a1a2e);
  margin: 0 0 24px;
}

.sp-rep-creds {
  background: var(--sage-bg, #f4f6f2);
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 8px;
  padding: 4px 16px;
  text-align: left;
}

.sp-rep-creds__row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border, #e5e7eb);
}

.sp-rep-creds__row:last-child {
  border-bottom: none;
}

.sp-rep-creds__label {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-mute, #888);
  width: 72px;
  flex-shrink: 0;
}

.sp-rep-creds__val {
  font-family: var(--font-data, monospace);
  font-size: 13px;
  flex: 1;
  color: var(--charcoal, #1a1a2e);
  word-break: break-all;
}

/* ── Rep Profile Page ───────────────────────────────────────────────────────── */

.rep-profile__nav-bar {
  margin-bottom: 20px;
}

.rep-profile__back-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  font-family: var(--font-body);
  color: var(--forest);
  text-decoration: none;
  transition: color 0.15s;
}

.rep-profile__back-link:hover {
  color: var(--copper);
}

.rep-profile__back-link svg {
  flex-shrink: 0;
}

.rep-profile__hero {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 28px;
  padding: 24px 28px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: 0 2px 12px rgba(var(--forest-rgb), 0.06);
}

.rep-profile__hero-avatar {
  flex-shrink: 0;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--forest);
  color: var(--white);
  font-family: var(--font-display);
  font-size: 24px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: 0;
}

.rep-profile__hero-info {
  flex: 1 1 0;
  min-width: 0;
}

.rep-profile__hero-name {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 700;
  color: var(--forest);
  line-height: 1.2;
  margin: 0 0 4px;
}

.rep-profile__hero-sub {
  font-family: var(--font-data);
  font-size: 12px;
  color: var(--text-muted);
  margin: 0;
  letter-spacing: 0.03em;
}

.rep-profile__kpi-section {
  margin-bottom: 28px;
}

.rep-profile__kpi-tiles {
  grid-template-columns: repeat(5, 1fr);
}

.rep-profile__tabs {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--border);
  margin-bottom: 0;
}

.rep-profile__tab {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  background: transparent;
  border: none;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted);
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
  white-space: nowrap;
}

.rep-profile__tab:hover {
  color: var(--forest);
}

.rep-profile__tab.is-active {
  color: var(--forest);
  border-bottom-color: var(--forest);
}

.rep-profile__tab-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 10px;
  background: var(--sage-bg);
  color: var(--text-muted);
  font-family: var(--font-data);
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
}

.rep-profile__tab.is-active .rep-profile__tab-badge {
  background: var(--forest-light);
  color: var(--forest);
}

.rep-profile__tab-badge--alert {
  background: var(--copper-light);
  color: var(--copper);
}

.rep-profile__tab.is-active .rep-profile__tab-badge--alert {
  background: var(--copper-light);
  color: var(--copper);
}

.rep-profile__panel {
  padding-top: 24px;
}

.rep-profile__panel--hidden {
  display: none;
}

.rep-profile__hint {
  font-size: 12px;
  color: var(--text-muted);
  font-family: var(--font-body);
  margin: 0 0 14px;
  padding: 10px 14px;
  background: var(--sage-bg);
  border-radius: 6px;
  border-left: 3px solid var(--forest-border);
}

@media (max-width: 1100px) {
  .rep-profile__kpi-tiles {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 768px) {
  .rep-profile__hero {
    padding: 18px 16px;
    gap: 14px;
  }

  .rep-profile__hero-avatar {
    width: 44px;
    height: 44px;
    font-size: 18px;
  }

  .rep-profile__hero-name {
    font-size: 20px;
  }

  .rep-profile__kpi-tiles {
    grid-template-columns: repeat(2, 1fr);
  }

  .rep-profile__tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .rep-profile__tab {
    padding: 10px 16px;
    font-size: 13px;
  }
}

@media (max-width: 480px) {
  .rep-profile__hero {
    padding: 14px 12px;
  }

  .rep-profile__hero-avatar {
    width: 38px;
    height: 38px;
    font-size: 16px;
  }

  .rep-profile__hero-name {
    font-size: 18px;
  }

  body.sales-portal .admin-kpis .rep-profile__kpi-tiles {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }

  .rep-profile__kpi-tiles .kpi-tile:last-child:nth-child(odd) {
    grid-column: 1 / -1;
  }

  .rep-profile__tab {
    padding: 10px 12px;
    font-size: 12px;
  }
}

/* ══════════════════════════════════════════════════════════════════════════════
   Sales Portal – User Dropdown Menu (header)
══════════════════════════════════════════════════════════════════════════════ */

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

.sp-user-menu__trigger {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 4px 8px 4px 4px;
  border-radius: var(--radius-pill);
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.14);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  color: rgba(255,255,255,0.92);
  font-family: var(--font-body);
}

.sp-user-menu__trigger:hover,
.sp-user-menu__trigger:focus-visible {
  background: rgba(255,255,255,0.14);
  border-color: rgba(255,255,255,0.3);
  outline: none;
}

.sp-user-menu__avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--copper);
  color: var(--copper-contrast, #fff);
  font-size: 11px;
  font-weight: 700;
  flex-shrink: 0;
  line-height: 1;
}

.sp-user-menu__name {
  font-size: 12px;
  font-weight: 500;
  max-width: min(160px, 30vw);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sp-user-menu__caret {
  font-size: 16px;
  opacity: 0.7;
  transition: transform 0.2s;
  flex-shrink: 0;
}

.sp-user-menu__trigger[aria-expanded="true"] .sp-user-menu__caret {
  transform: rotate(180deg);
}

.sp-user-menu__dropdown {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  min-width: 220px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-modal);
  z-index: 500;
  overflow: hidden;
}

/* Alpine transitions */
.sp-menu-enter        { transition: opacity 0.12s ease, transform 0.12s ease; }
.sp-menu-enter-start  { opacity: 0; transform: translateY(-6px) scale(0.97); }
.sp-menu-enter-end    { opacity: 1; transform: translateY(0) scale(1); }
.sp-menu-leave        { transition: opacity 0.1s ease; }
.sp-menu-leave-start  { opacity: 1; }
.sp-menu-leave-end    { opacity: 0; }

.sp-user-menu__header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px 12px;
  background: var(--forest-light);
}

.sp-user-menu__header-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--copper);
  color: var(--copper-contrast, #fff);
  font-size: 14px;
  font-weight: 700;
  flex-shrink: 0;
  line-height: 1;
}

.sp-user-menu__header-info {
  min-width: 0;
  flex: 1;
}

.sp-user-menu__header-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--forest-dark);
  font-family: var(--font-body);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sp-user-menu__header-sub {
  font-size: 11px;
  color: var(--text-muted);
  font-family: var(--font-data);
  margin-top: 1px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sp-user-menu__divider {
  height: 1px;
  background: var(--border);
  margin: 2px 0;
}

.sp-user-menu__item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 16px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-body);
  font-family: var(--font-body);
  text-decoration: none;
  cursor: pointer;
  transition: background 0.12s;
  border: none;
  background: none;
  width: 100%;
}

.sp-user-menu__item:hover {
  background: var(--forest-light);
  text-decoration: none;
  color: var(--forest-dark);
}

.sp-user-menu__item--danger {
  color: var(--red);
}

.sp-user-menu__item--danger:hover {
  background: var(--red-light);
  color: var(--red);
}

.sp-user-menu__item-icon {
  font-size: 18px;
  color: var(--text-muted);
  flex-shrink: 0;
}

.sp-user-menu__item:hover .sp-user-menu__item-icon,
.sp-user-menu__item--danger:hover .sp-user-menu__item-icon {
  color: inherit;
}

@media (max-width: 640px) {
  .sp-user-menu__name {
    display: none;
  }
  .sp-user-menu__caret {
    display: none;
  }
  .sp-user-menu__dropdown {
    right: -8px;
    min-width: 200px;
  }
}

/* ══════════════════════════════════════════════════════════════════════════════
   Sales Portal – Profile / Settings Page
══════════════════════════════════════════════════════════════════════════════ */

/* ── Hero ── */
.sp-profile-hero {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 0 0 28px;
}

.sp-profile-hero__avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--copper);
  color: var(--copper-contrast, #fff);
  font-size: 26px;
  font-weight: 700;
  flex-shrink: 0;
  line-height: 1;
  box-shadow: 0 0 0 4px var(--copper-bg-subtle);
}

.sp-profile-hero__info { flex: 1 1 auto; min-width: 0; }

.sp-profile-hero__name {
  font-family: var(--font-display);
  font-size: 26px;
  font-weight: 700;
  color: var(--forest-dark);
  margin: 0 0 6px;
  line-height: 1.2;
}

.sp-profile-hero__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin: 0;
  font-size: 13px;
  color: var(--text-muted);
  font-family: var(--font-body);
}

.sp-profile-hero__sep { color: var(--border-dark); }

.sp-profile-hero__code,
.sp-profile-hero__uid {
  font-family: var(--font-data);
  font-size: 12px;
}

/* ── Tab bar ── */
.sp-profile-tabs {
  display: flex;
  gap: 2px;
  border-bottom: 2px solid var(--border);
  margin-bottom: 24px;
}

.sp-profile-tab {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 10px 18px;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s;
  white-space: nowrap;
}

.sp-profile-tab:hover {
  color: var(--forest-dark);
}

.sp-profile-tab.is-active {
  color: var(--copper);
  border-bottom-color: var(--copper);
}

.sp-profile-tab__icon {
  font-size: 18px;
  vertical-align: middle;
  line-height: 1;
}

/* ── Panel ── */
.sp-profile-panel { outline: none; }

/* Alpine fade transition */
.sp-panel-enter       { transition: opacity 0.15s ease, transform 0.15s ease; }
.sp-panel-enter-start { opacity: 0; transform: translateY(6px); }
.sp-panel-enter-end   { opacity: 1; transform: translateY(0); }

.sp-profile-panel__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  align-items: start;
}

.sp-profile-panel__grid--single {
  grid-template-columns: minmax(0, 640px);
}

/* ── Card ── */
.sp-profile-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 24px;
  box-shadow: var(--shadow-card);
}

.sp-profile-card__title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-display);
  font-size: 16px;
  font-weight: 700;
  color: var(--forest-dark);
  margin: 0 0 6px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
}

.sp-profile-card__icon {
  font-size: 20px;
  color: var(--copper);
  flex-shrink: 0;
}

.sp-profile-card__desc {
  font-size: 13px;
  color: var(--text-muted);
  font-family: var(--font-body);
  margin: 0 0 20px;
  line-height: 1.5;
}

/* ── Form ── */
.sp-profile-form__fields {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.sp-profile-form__actions {
  margin-top: 22px;
  display: flex;
  justify-content: flex-end;
}

/* Password show/hide toggle */
.sp-profile-pw-field {
  position: relative;
  display: flex;
  align-items: center;
}

.sp-profile-pw-field .field__input {
  padding-right: 44px;
}

.sp-profile-pw-toggle {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  padding: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.15s;
}

.sp-profile-pw-toggle:hover { color: var(--forest-dark); }

/* ── Account meta ── */
.sp-profile-meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px 20px;
  margin: 4px 0 0;
}

.sp-profile-meta__row {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.sp-profile-meta__label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--text-light);
  font-family: var(--font-body);
}

.sp-profile-meta__value {
  font-size: 14px;
  font-weight: 500;
  color: var(--text-body);
  font-family: var(--font-body);
}

.sp-profile-meta__value--mono {
  font-family: var(--font-data);
  font-size: 13px;
}

/* Role badge */
.sp-profile-role-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 10px 3px 6px;
  border-radius: var(--radius-pill);
  font-size: 12px;
  font-weight: 600;
  background: var(--forest-light);
  color: var(--forest-dark);
  border: 1px solid var(--forest-border);
  font-family: var(--font-body);
}

.sp-profile-role-badge--manager {
  background: var(--copper-light);
  color: var(--copper-active);
  border-color: var(--copper-border);
}

/* ── Toast notification ── */
.sp-profile-toast {
  position: fixed;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%) translateY(16px);
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px;
  background: var(--forest-dark);
  color: #fff;
  border-radius: var(--radius-pill);
  box-shadow: var(--shadow-modal);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 500;
  opacity: 0;
  pointer-events: none;
  z-index: 9000;
  white-space: nowrap;
  transition: opacity 0.25s ease, transform 0.25s ease;
}

.sp-profile-toast--visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}

.sp-profile-toast__icon {
  color: #4caf50;
  display: flex;
  align-items: center;
}

/* ── Responsive ── */
@media (max-width: 860px) {
  .sp-profile-panel__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .sp-profile-hero {
    gap: 14px;
    padding-bottom: 20px;
  }
  .sp-profile-hero__avatar {
    width: 50px;
    height: 50px;
    font-size: 20px;
  }
  .sp-profile-hero__name {
    font-size: 20px;
  }
  .sp-profile-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .sp-profile-tab {
    padding: 10px 14px;
    font-size: 12px;
  }
  .sp-profile-card {
    padding: 18px 16px;
  }
  .sp-profile-meta {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 400px) {
  .sp-profile-tab__icon {
    display: none;
  }
}

/* ── Sales Reports — Date Range Picker ────────────────────────────────────── */
.sp-daterange-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 12px 16px;
  margin-bottom: 24px;
  padding: 16px 20px;
  background: var(--surface-alt, #f8f7f4);
  border: 1px solid var(--border, #e5e5e5);
  border-radius: 10px;
}

@media (min-width: 1920px) {
  body.sales-portal .moov-shell.admin-page.sales-portal-page--reports {
    max-width: min(1680px, 92vw);
    margin-left: auto;
    margin-right: auto;
  }
}

.sp-daterange-presets {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  flex: 1 1 auto;
}

.sp-daterange-preset {
  display: inline-flex;
  align-items: center;
  padding: 5px 13px;
  font-size: 12px;
  font-weight: 600;
  line-height: 1;
  border-radius: 20px;
  border: 1.5px solid var(--border, #e0ddd8);
  background: var(--surface, #fff);
  color: var(--text-muted, #666);
  cursor: pointer;
  transition: background 0.14s, color 0.14s, border-color 0.14s, box-shadow 0.14s;
  white-space: nowrap;
  user-select: none;
}
.sp-daterange-preset:hover {
  background: var(--surface, #fff);
  border-color: var(--copper);
  color: var(--copper);
  box-shadow: 0 0 0 2px rgba(176, 106, 46, 0.10);
}
.sp-daterange-preset--active {
  background: var(--copper);
  border-color: var(--copper);
  color: #fff;
  box-shadow: 0 2px 8px rgba(176, 106, 46, 0.22);
}
.sp-daterange-preset--active:hover {
  background: var(--copper-dark, #944f1a);
  border-color: var(--copper-dark, #944f1a);
  color: #fff;
}

.sp-daterange-inputs {
  display: flex;
  align-items: flex-end;
  gap: 8px;
  flex-shrink: 0;
}

.sp-daterange-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.sp-daterange-field label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-muted, #666);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.sp-daterange-field input[type="date"] {
  padding: 7px 10px;
  font-size: 13px;
  font-family: inherit;
  border: 1.5px solid var(--border, #ddd);
  border-radius: 7px;
  background: var(--surface, #fff);
  color: var(--text, #1a2e1f);
  min-width: 130px;
  transition: border-color 0.14s, box-shadow 0.14s;
  cursor: pointer;
}
.sp-daterange-field input[type="date"]:focus {
  outline: none;
  border-color: var(--copper);
  box-shadow: 0 0 0 3px rgba(176, 106, 46, 0.15);
}
.sp-daterange-field input[type="date"]::-webkit-calendar-picker-indicator {
  opacity: 0.5;
  cursor: pointer;
}
.sp-daterange-field input[type="date"]::-webkit-calendar-picker-indicator:hover {
  opacity: 1;
}

.sp-daterange-sep {
  font-size: 13px;
  color: var(--text-muted, #999);
  padding-bottom: 8px;
  flex-shrink: 0;
}

.sp-daterange-actions {
  display: flex;
  align-items: flex-end;
  gap: 8px;
  flex-shrink: 0;
}

.sp-daterange-apply {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 18px;
  font-size: 13px;
  font-weight: 700;
  font-family: inherit;
  border-radius: 7px;
  border: none;
  background: var(--forest);
  color: #fff;
  cursor: pointer;
  transition: background 0.14s, box-shadow 0.14s, transform 0.1s;
  white-space: nowrap;
  letter-spacing: 0.01em;
}
.sp-daterange-apply:hover {
  background: var(--copper);
  box-shadow: 0 3px 10px rgba(176, 106, 46, 0.25);
}
.sp-daterange-apply:active {
  transform: scale(0.98);
}

.sp-daterange-sort {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex-shrink: 0;
}
.sp-daterange-sort label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-muted, #666);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.sp-daterange-sort select {
  padding: 7px 10px;
  font-size: 13px;
  font-family: inherit;
  border: 1.5px solid var(--border, #ddd);
  border-radius: 7px;
  background: var(--surface, #fff);
  color: var(--text, #1a2e1f);
  cursor: pointer;
  transition: border-color 0.14s, box-shadow 0.14s;
}
.sp-daterange-sort select:focus {
  outline: none;
  border-color: var(--copper);
  box-shadow: 0 0 0 3px rgba(176, 106, 46, 0.15);
}

.sp-daterange-divider {
  width: 1px;
  height: 36px;
  background: var(--border, #e0ddd8);
  flex-shrink: 0;
  align-self: flex-end;
  margin-bottom: 2px;
}

/* Dashboard variant — collapsed-by-default chip + AJAX panel */
.sp-dashboard-range {
  position: relative;
  margin: 0 0 24px;
  display: inline-block;
}
button.sp-dashboard-range__chip {
  -webkit-appearance: none;
  appearance: none;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0;
  padding: 9px 14px 9px 12px;
  font: 600 13px/1 inherit;
  letter-spacing: 0.01em;
  color: var(--text, #2c2a26);
  background: linear-gradient(180deg, #ffffff 0%, #faf8f4 100%);
  border: 1px solid #d8d2c8;
  border-radius: 999px;
  cursor: pointer;
  transition: border-color 0.14s, box-shadow 0.14s, transform 0.06s;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05), inset 0 1px 0 rgba(255, 255, 255, 0.7);
  text-decoration: none;
}
.sp-dashboard-range__chip .fa-calendar {
  color: var(--copper, #b06a2e);
  font-size: 14px;
  margin-right: 2px;
}
.sp-dashboard-range__chip-prefix {
  color: var(--text-muted, #8a8478);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.sp-dashboard-range__chip strong {
  color: var(--copper, #b06a2e);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0;
}
.sp-dashboard-range__chip:hover {
  border-color: var(--copper, #b06a2e);
  box-shadow: 0 2px 6px rgba(176, 106, 46, 0.15), inset 0 1px 0 rgba(255, 255, 255, 0.7);
}
.sp-dashboard-range__chip:focus-visible {
  border-color: var(--copper, #b06a2e);
  box-shadow: 0 0 0 3px rgba(176, 106, 46, 0.18);
  outline: none;
}
.sp-dashboard-range__chip:active {
  transform: translateY(1px);
}
.sp-dashboard-range--open .sp-dashboard-range__chip {
  border-color: var(--copper, #b06a2e);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(176, 106, 46, 0.14);
}
.sp-dashboard-range__caret {
  font-size: 10px;
  color: var(--text-muted, #999);
  transition: transform 0.18s ease;
  margin-left: 4px;
}
.sp-dashboard-range--open .sp-dashboard-range__caret {
  transform: rotate(180deg);
}

.sp-dashboard-range__panel {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  z-index: 30;
  min-width: min(720px, calc(100vw - 32px));
  background: var(--surface, #fff);
  border: 1px solid var(--border, #e0ddd8);
  border-radius: 12px;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.10), 0 2px 6px rgba(0, 0, 0, 0.05);
  padding: 14px;
  animation: sp-dashboard-range-pop 0.16s ease-out;
}
@keyframes sp-dashboard-range-pop {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}
.sp-dashboard-range__panel .sp-daterange-bar {
  margin: 0;
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
}

.sp-daterange-bar--dashboard {
  align-items: center;
  gap: 10px 14px;
}

.sp-dashboard-range--loading .sp-dashboard-range__chip {
  opacity: 0.7;
  pointer-events: none;
}
.sp-dashboard-range--loading .sp-dashboard-range__chip strong::after {
  content: '';
  display: inline-block;
  width: 10px;
  height: 10px;
  margin-left: 6px;
  vertical-align: -1px;
  border: 2px solid rgba(176, 106, 46, 0.25);
  border-top-color: var(--copper, #b06a2e);
  border-radius: 50%;
  animation: sp-dashboard-range-spin 0.7s linear infinite;
}
@keyframes sp-dashboard-range-spin {
  to { transform: rotate(360deg); }
}

.kpi-tile--flash {
  animation: sp-kpi-flash 0.6s ease-out;
}
@keyframes sp-kpi-flash {
  0%   { box-shadow: 0 0 0 0 rgba(176, 106, 46, 0.0); }
  30%  { box-shadow: 0 0 0 4px rgba(176, 106, 46, 0.18); }
  100% { box-shadow: 0 0 0 0 rgba(176, 106, 46, 0.0); }
}

@media (max-width: 720px) {
  .sp-dashboard-range__panel {
    left: -8px;
    right: -8px;
    min-width: 0;
  }
}

.sp-daterange-bar--top-sellers .sp-daterange-sort {
  display: flex;
}

@media (max-width: 768px) {
  .sp-daterange-bar {
    padding: 12px 14px;
    gap: 10px 12px;
  }
  .sp-daterange-inputs {
    flex-wrap: wrap;
  }
  .sp-daterange-field input[type="date"] {
    min-width: 110px;
  }
  .sp-daterange-divider {
    display: none;
  }
}

@media (max-width: 480px) {
  .sp-daterange-bar {
    flex-direction: column;
    align-items: stretch;
  }
  .sp-daterange-presets {
    order: 1;
  }
  .sp-daterange-inputs {
    order: 2;
    justify-content: space-between;
  }
  .sp-daterange-field input[type="date"] {
    min-width: 0;
    width: 100%;
  }
  .sp-daterange-actions {
    order: 3;
    justify-content: stretch;
  }
  .sp-daterange-apply {
    flex: 1;
    justify-content: center;
  }
  .sp-daterange-sort {
    order: 0;
  }
}

/* ── Customer detail: simple open-orders / transactions tables ─────────────── */
.sales-portal-table-wrap--detail {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable;
  margin-bottom: 24px;
}

.sales-portal-table--detail {
  min-width: 420px;
}

@media (max-width: 640px) {
  .sales-portal-table-wrap--detail {
    overflow-x: visible;
  }
  .sales-portal-table--detail {
    min-width: 0;
    width: 100%;
  }
  .sales-portal-table--detail thead {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
  .sales-portal-table--detail tbody tr:not(.sales-portal-table__empty-row) {
    display: block;
    padding: 12px 14px;
    margin-bottom: 20px;
    background: var(--surface, #fff);
    border: 1px solid var(--border, #e8e6e1);
    border-left: 3px solid var(--copper, #d4840b);
    border-radius: var(--radius-md, 8px);
    box-shadow: 0 2px 12px rgba(26, 46, 31, 0.09);
  }
  .sales-portal-table--detail tbody tr.sales-portal-table__empty-row {
    display: block;
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
    margin: 0;
  }
  .sales-portal-table--detail tbody tr.sales-portal-table__empty-row td {
    display: block;
    text-align: center;
    padding: 20px 12px;
    border-bottom: none;
    color: var(--text-muted, #666);
    font-size: 14px;
  }
  .sales-portal-table--detail tbody tr:not(.sales-portal-table__empty-row) td {
    display: grid;
    grid-template-columns: minmax(80px, 38%) minmax(0, 1fr);
    column-gap: 10px;
    row-gap: 2px;
    align-items: start;
    padding: 7px 0;
    border-bottom: 1px solid var(--border, #f0ede8);
    font-size: 14px;
    word-break: break-word;
    overflow-wrap: anywhere;
    text-align: left;
  }
  .sales-portal-table--detail tbody tr:not(.sales-portal-table__empty-row) td:last-child {
    border-bottom: none;
  }
  .sales-portal-table--detail tbody tr:not(.sales-portal-table__empty-row) td::before {
    content: attr(data-label);
    grid-column: 1;
    font-weight: 700;
    font-size: 10px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--text-muted, #666);
    line-height: 1.3;
    padding-top: 1px;
  }
}

/* ── Overflow containment for portal content areas ─────────────────────────── */
body.sales-portal .sales-portal-section {
  min-width: 0;
}

/* Prevent long unbreakable customer names from overflowing header */
.sp-customer-detail-header .admin-page__title {
  overflow-wrap: anywhere;
  word-break: break-word;
}

/* ── Register wizard progress bar: don't overflow on narrow phones ──────────── */
@media (max-width: 380px) {
  .sp-reg-wizard-steps {
    flex-wrap: wrap;
    gap: 8px 0;
  }
  .sp-reg-wizard-step {
    flex: 0 0 auto;
  }
  .sp-reg-wizard-step:not(:last-child)::after {
    display: none;
  }
}

/* ── Report table: ensure CRM wrap doesn't break out of its container ───────── */
.sp-report-table-wrap--crm {
  overflow-x: auto;
}

/* ── Tab nav: allow wrapping on very small screens ──────────────────────────── */
@media (max-width: 420px) {
  .sp-tab-nav {
    gap: 0;
  }
  .sp-tab-nav__tab {
    padding: 8px 10px;
    font-size: 12px;
  }
  .sp-customers-tab {
    padding: 8px 12px;
    font-size: 13px;
  }
}

/* ── Search live input: prevent min-width overflow on narrow portal pages ────── */
@media (max-width: 480px) {
  .sales-portal-search-live__input {
    min-width: 0;
  }
}

/* ── Filter drawer scroll area: ensure content doesn't overflow on iOS ──────── */
.sales-portal-filter-drawer__scroll {
  overflow-x: hidden;
}

/* ── Brand transactions: portal-patterned table + filter tab links ───────────── */
.sp-brand-txn-filter-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 20px;
}

.sp-filter-tab-link {
  display: inline-flex;
  align-items: center;
  padding: 7px 16px;
  border-radius: 999px;
  border: 1.5px solid var(--border, #dde6e2);
  background: var(--surface, #fff);
  color: var(--text-muted, #6b7b74);
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.14s, color 0.14s, border-color 0.14s;
  cursor: pointer;
}

.sp-filter-tab-link:hover {
  border-color: var(--forest-border, #a8c9be);
  color: var(--forest);
  text-decoration: none;
}

.sp-filter-tab-link.is-active {
  background: var(--forest);
  color: #fff;
  border-color: var(--forest);
}

.sales-portal-table-wrap--brand-txn {
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-gutter: stable;
}

.sales-portal-table--brand-txn {
  min-width: 560px;
}

@media (max-width: 640px) {
  .sales-portal-table-wrap--brand-txn {
    overflow-x: visible;
  }
  .sales-portal-table--brand-txn {
    min-width: 0;
    width: 100%;
  }
  .sales-portal-table--brand-txn thead {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
  .sales-portal-table--brand-txn tbody tr:not(.sales-portal-table__empty-row) {
    display: block;
    padding: 12px 14px;
    margin-bottom: 10px;
    background: var(--surface, #fff);
    border: 1px solid var(--border, #e8e6e1);
    border-radius: var(--radius-md, 8px);
    box-shadow: 0 2px 8px rgba(26, 46, 31, 0.04);
  }
  .sales-portal-table--brand-txn tbody tr.sales-portal-table__empty-row {
    display: block;
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
    margin: 0;
  }
  .sales-portal-table--brand-txn tbody tr.sales-portal-table__empty-row td {
    display: block;
    text-align: center;
    padding: 20px 12px;
    border-bottom: none;
    color: var(--text-muted, #666);
    font-size: 14px;
  }
  .sales-portal-table--brand-txn tbody tr:not(.sales-portal-table__empty-row) td {
    display: grid;
    grid-template-columns: minmax(80px, 38%) minmax(0, 1fr);
    column-gap: 10px;
    row-gap: 2px;
    align-items: start;
    padding: 7px 0;
    border-bottom: 1px solid var(--border, #f0ede8);
    font-size: 14px;
    word-break: break-word;
    overflow-wrap: anywhere;
    text-align: left;
  }
  .sales-portal-table--brand-txn tbody tr:not(.sales-portal-table__empty-row) td:last-child {
    border-bottom: none;
  }
  .sales-portal-table--brand-txn tbody tr:not(.sales-portal-table__empty-row) td::before {
    content: attr(data-label);
    grid-column: 1;
    font-weight: 700;
    font-size: 10px;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--text-muted, #666);
    line-height: 1.3;
    padding-top: 1px;
  }
  .sales-portal-table--brand-txn .sales-portal-table__cell-val {
    grid-column: 2;
    min-width: 0;
  }
  .sales-portal-table--brand-txn .sp-col-money {
    text-align: left;
    white-space: normal;
  }
}

/* ── Portal sticky topbar: correct offset (portal nav bars are not sticky) ───── */
body.sales-portal .catalog-topbar {
  top: 0;
}

/* ── Portal page shell containment: flex/grid children must not exceed track width */
body.sales-portal .catalog-main,
body.sales-portal .sales-portal-customers-main,
body.sales-portal .sales-portal-inventory-main {
  min-width: 0;
}

/* ── CRM drawer customer search input: full width ───────────────────────────── */
#sp-crm-cust-search.sales-portal-search-live__input {
  border-radius: 12px;
  border-right: 1px solid var(--border, #d9d6d0);
  width: 100%;
  min-width: 0;
}

/* ── Register form grid: use auto-fit so it never overflows on small drawers ─── */
.sp-reg-drawer .sales-register-form__grid {
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 200px), 1fr));
}

/* ── Sales portal page global min-width guard ──────────────────────────────── */
body.sales-portal .sales-portal-page {
  min-width: 0;
  max-width: 100%;
}

/* ═══════════════════════════════════════════════════════════════════════
   CHECKOUT UI — MODERN PAYMENT CARD SELECTOR (2026 refresh)
   ═══════════════════════════════════════════════════════════════════════ */

/* Full-card payment mode: stacked vertically, touch-friendly */
#checkout-checkout .checkout-payment-bamb__modes {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  margin-bottom: 20px !important;
}

#checkout-checkout .checkout-payment-bamb__mode--card,
#checkout-checkout .checkout-payment-bamb__mode--account {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  padding: 14px 16px !important;
  border: 2px solid var(--border, #DDE6E2) !important;
  border-radius: 10px !important;
  cursor: pointer !important;
  background: var(--white, #fff) !important;
  transition: border-color 0.18s, background 0.18s, box-shadow 0.18s !important;
  position: relative !important;
  margin: 0 !important;
  min-height: 64px !important;
}

#checkout-checkout .checkout-payment-bamb__mode--card input[type="radio"],
#checkout-checkout .checkout-payment-bamb__mode--account input[type="radio"] {
  position: absolute !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  pointer-events: none !important;
}

/* Icon circle */
#checkout-checkout .checkout-payment-bamb__mode-icon {
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  background: var(--sage-bg, #EEF4F1) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  transition: background 0.18s !important;
}

#checkout-checkout .checkout-payment-bamb__mode-icon .material-icons {
  font-size: 20px !important;
  color: var(--forest, #1A3C34) !important;
}

/* Text stack */
#checkout-checkout .checkout-payment-bamb__mode-content {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
}

#checkout-checkout .checkout-payment-bamb__mode-text {
  font-family: var(--font-body) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--forest, #1A3C34) !important;
  line-height: 1.2 !important;
}

#checkout-checkout .checkout-payment-bamb__mode-sub {
  font-family: var(--font-body) !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  color: var(--text-muted, #6b7b74) !important;
  line-height: 1.3 !important;
}

/* Check icon — hidden by default, shown when selected */
#checkout-checkout .checkout-payment-bamb__mode-check {
  flex-shrink: 0 !important;
  opacity: 0 !important;
  transition: opacity 0.18s !important;
}

#checkout-checkout .checkout-payment-bamb__mode-check .material-icons {
  font-size: 20px !important;
  color: var(--copper, #B87333) !important;
}

/* Hover state */
#checkout-checkout .checkout-payment-bamb__mode--card:hover,
#checkout-checkout .checkout-payment-bamb__mode--account:hover {
  border-color: var(--forest-border, #A8C9BE) !important;
  background: var(--sage-bg, #EEF4F1) !important;
  box-shadow: 0 2px 8px rgba(26,60,52,0.08) !important;
}

/* Selected state */
#checkout-checkout .checkout-payment-bamb__mode--card.is-selected,
#checkout-checkout .checkout-payment-bamb__mode--account.is-selected {
  border-color: var(--copper, #B87333) !important;
  background: var(--copper-light, #FDF6EE) !important;
  box-shadow: 0 0 0 1px var(--copper, #B87333), 0 2px 8px rgba(184,115,51,0.12) !important;
}

#checkout-checkout .checkout-payment-bamb__mode--card.is-selected .checkout-payment-bamb__mode-check,
#checkout-checkout .checkout-payment-bamb__mode--account.is-selected .checkout-payment-bamb__mode-check {
  opacity: 1 !important;
}

#checkout-checkout .checkout-payment-bamb__mode--card.is-selected .checkout-payment-bamb__mode-icon,
#checkout-checkout .checkout-payment-bamb__mode--account.is-selected .checkout-payment-bamb__mode-icon {
  background: rgba(184,115,51,0.12) !important;
}

#checkout-checkout .checkout-payment-bamb__mode--card.is-selected .checkout-payment-bamb__mode-icon .material-icons,
#checkout-checkout .checkout-payment-bamb__mode--account.is-selected .checkout-payment-bamb__mode-icon .material-icons {
  color: var(--copper, #B87333) !important;
}

/* Account charge card — forest themed */
#checkout-checkout .checkout-payment-bamb__mode--account.is-selected {
  border-color: var(--forest, #1A3C34) !important;
  background: var(--forest-light, #E8F0ED) !important;
  box-shadow: 0 0 0 1px var(--forest, #1A3C34), 0 2px 8px rgba(26,60,52,0.12) !important;
}

#checkout-checkout .checkout-payment-bamb__mode--account.is-selected .checkout-payment-bamb__mode-check {
  opacity: 1 !important;
}

#checkout-checkout .checkout-payment-bamb__mode--account.is-selected .checkout-payment-bamb__mode-check .material-icons {
  color: var(--forest, #1A3C34) !important;
}

#checkout-checkout .checkout-payment-bamb__mode--account.is-selected .checkout-payment-bamb__mode-icon {
  background: rgba(26,60,52,0.12) !important;
}

/* ── Checkout summary submit button — bigger, bolder ── */
.checkout-summary__submit {
  height: 52px !important;
  font-size: 15px !important;
  letter-spacing: 0.5px !important;
  border-radius: 10px !important;
}

/* ── Checkout page header — show back link inline ── */
.checkout-page__header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0.75rem 0 1.25rem !important;
  margin-bottom: 0.5rem !important;
  border-bottom: 1px solid var(--border, #DDE6E2) !important;
}

/* ── Order Items — expanded by default on desktop ── */
@media (min-width: 992px) {
  #order-details {
    display: block !important;
  }
  .checkout-items-toggle {
    display: none !important;
  }
}

/* ── Address cards grid on checkout delivery ── */
.saved-addresses-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
  gap: 12px !important;
  margin-bottom: 16px !important;
}

.address-card-preview {
  border: 2px solid var(--border, #DDE6E2) !important;
  border-radius: 10px !important;
  padding: 14px !important;
  cursor: pointer !important;
  transition: border-color 0.18s, background 0.18s, box-shadow 0.18s !important;
  background: var(--white, #fff) !important;
  position: relative !important;
}

.address-card-preview:hover {
  border-color: var(--forest-border, #A8C9BE) !important;
  background: var(--sage-bg, #EEF4F1) !important;
}

.address-card-preview.selected {
  border-color: var(--forest, #1A3C34) !important;
  background: var(--forest-light, #E8F0ED) !important;
  box-shadow: 0 0 0 1px var(--forest, #1A3C34) !important;
}

.address-selected-pill .material-icons {
  font-size: 18px !important;
  color: var(--forest, #1A3C34) !important;
  vertical-align: middle !important;
}

.address-name__main {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-weight: 700 !important;
  color: var(--charcoal, #2E3A35) !important;
  font-size: 14px !important;
}

.address-line,
.address-city-state {
  font-size: 13px !important;
  color: var(--text-muted, #6b7b74) !important;
  line-height: 1.4 !important;
}

.address-company {
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--text-body, #374840) !important;
}

/* ── Mobile checkout improvements ── */
@media (max-width: 768px) {
  #checkout-checkout .checkout-payment-bamb__mode--card,
  #checkout-checkout .checkout-payment-bamb__mode--account {
    min-height: 56px !important;
  }

  .saved-addresses-grid {
    grid-template-columns: 1fr !important;
  }

  .checkout-page__header {
    flex-wrap: wrap !important;
    gap: 8px !important;
  }
}

/* ── Inventory quickview open body state ──────────────────────────────────── */
@media (max-width: 640px) {
  .sp-brand-txn-filter-tabs {
    gap: 4px;
  }
  .sp-filter-tab-link {
    padding: 6px 12px;
    font-size: 12px;
  }
}

/* ═══════════════════════════════════════════════════════════
   SALES PORTAL DOC DRAWER  (.sp-dd-*)  — legacy iframe drawer styles
   (manifests and full order HTML open in a new tab as of 2026-04.)
   ═══════════════════════════════════════════════════════════ */

.sp-dd-overlay {
  position: fixed;
  inset: 0;
  z-index: 10620;
  display: flex;
  align-items: stretch;
  justify-content: flex-end;
  padding: 0;
  animation: odm-fade-in 0.18s ease;
}
.sp-dd-overlay[hidden] {
  display: none !important;
}
.sp-dd-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(14, 22, 18, 0.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  cursor: pointer;
}
.sp-dd-panel {
  position: relative;
  z-index: 1;
  width: min(960px, 100vw);
  max-width: 100%;
  height: 100%;
  background: #fff;
  box-shadow: -12px 0 48px rgba(0, 0, 0, 0.22);
  display: flex;
  flex-direction: column;
  animation: sp-dd-slide-in 0.22s cubic-bezier(0.22, 1, 0.36, 1);
}
@keyframes sp-dd-slide-in {
  from { transform: translateX(24px); opacity: 0; }
  to   { transform: translateX(0);     opacity: 1; }
}
.sp-dd-header {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 12px 14px 18px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.08);
  background: #faf9f7;
}
.sp-dd-title {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
  color: var(--forest-dark, #1a3c34);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sp-dd-close {
  border: 0;
  background: transparent;
  cursor: pointer;
  padding: 8px;
  line-height: 0;
  border-radius: 8px;
  color: var(--forest-mid, #2d5a4a);
}
.sp-dd-close:hover {
  background: rgba(0, 0, 0, 0.06);
}
.sp-dd-iframe {
  flex: 1 1 auto;
  width: 100%;
  min-height: 0;
  border: 0;
  background: #f4f4f4;
}

@media (max-width: 600px) {
  .sp-dd-panel {
    width: 100%;
  }
}

/* ═══════════════════════════════════════════════════════════
   ORDER DETAIL MODAL  (.odm-*)
   Premium Forest & Copper redesign
   ═══════════════════════════════════════════════════════════ */

.odm-overlay {
  position: fixed;
  inset: 0;
  z-index: 10500;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: odm-fade-in 0.18s ease;
}
.odm-overlay[hidden] { display: none !important; }

@keyframes odm-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* ── Backdrop ── */
.odm-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(14, 22, 18, 0.72);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  cursor: pointer;
}

/* ── Panel ── */
.odm-panel {
  position: relative;
  z-index: 1;
  background: var(--white);
  border-radius: 14px;
  box-shadow:
    0 32px 80px rgba(0,0,0,0.22),
    0 8px 24px rgba(0,0,0,0.12),
    0 0 0 1px rgba(255,255,255,0.06);
  width: 100%;
  max-width: 860px;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  animation: odm-slide-up 0.24s cubic-bezier(0.22, 1, 0.36, 1);
}

@keyframes odm-fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes odm-slide-up {
  from { transform: translateY(24px) scale(0.985); opacity: 0; }
  to   { transform: translateY(0)    scale(1);     opacity: 1; }
}
@keyframes odm-spin { to { transform: rotate(360deg); } }

/* ── Header ── */
.odm-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 20px 24px 18px;
  background: linear-gradient(145deg, var(--forest-dark) 0%, #1e4a3d 55%, var(--forest-mid) 100%);
  box-shadow: inset 0 -3px 0 var(--copper);
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
}

/* Subtle decorative circle behind header */
.odm-header::after {
  content: '';
  position: absolute;
  right: -60px;
  top: -60px;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background: rgba(255,255,255,0.03);
  pointer-events: none;
}

.odm-header__main { min-width: 0; flex: 1; }

.odm-eyebrow {
  font-family: var(--font-data);
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.38);
  margin-bottom: 2px;
}

.odm-title {
  font-family: var(--font-data);
  font-size: 22px;
  font-weight: 800;
  color: #fff;
  margin: 0;
  letter-spacing: 0.5px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.odm-header__sub {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 5px;
}

.odm-header__sub-customer {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: rgba(255,255,255,0.62);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 260px;
}

.odm-header__sub-sep {
  color: rgba(255,255,255,0.2);
  font-size: 11px;
}

.odm-header__summary {
  font-family: var(--font-data);
  font-size: 10px;
  color: rgba(255,255,255,0.38);
  white-space: nowrap;
}

.odm-close {
  flex-shrink: 0;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  color: rgba(255,255,255,0.6);
  cursor: pointer;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.14s, color 0.14s, border-color 0.14s;
  margin-top: 2px;
}
.odm-close:hover {
  background: rgba(255,255,255,0.14);
  border-color: rgba(255,255,255,0.22);
  color: #fff;
}
.odm-close .material-icons { font-size: 17px; }

/* ── Scrollable body ── */
.odm-body {
  flex: 1 1 auto;
  overflow-y: auto;
  overscroll-behavior: contain;
}

/* ── Loading / error states ── */
.odm-loading,
.odm-error {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: 56px 24px;
  color: var(--text-muted);
  font-family: var(--font-body);
  font-size: 13px;
  text-align: center;
}

.odm-loading__spinner {
  width: 32px;
  height: 32px;
  border: 3px solid var(--forest-light);
  border-top-color: var(--forest);
  border-radius: 50%;
  animation: odm-spin 0.72s linear infinite;
  flex-shrink: 0;
}

.odm-error .material-icons {
  font-size: 36px;
  color: var(--red);
  opacity: 0.6;
}

/* ── Meta cards ── */
.odm-meta {
  padding: 0;
  border-bottom: 1px solid var(--border);
}

.odm-meta-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  padding: 0;
}

.odm-meta-card {
  display: flex;
  flex-direction: column;
  padding: 14px 18px 13px;
  border-right: 1px solid var(--border);
  background: var(--white);
  transition: background 0.12s;
  min-width: 0;
}
.odm-meta-card:last-child { border-right: none; }
.odm-meta-card:hover { background: var(--sage-bg); }

.odm-meta-card__icon {
  font-size: 15px;
  color: var(--forest);
  opacity: 0.35;
  margin-bottom: 6px;
  line-height: 1;
}

.odm-meta-card__label {
  font-family: var(--font-data);
  font-size: 8px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.7px;
  color: var(--text-light);
  margin-bottom: 3px;
  display: block;
}

.odm-meta-card__value {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  color: var(--charcoal);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  display: block;
}
.odm-meta-card__value--mono { font-family: var(--font-data); font-size: 11px; }

.odm-delivery-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 18px;
  border-top: 1px dashed var(--border);
  background: var(--bg);
}

.odm-delivery-row__icon {
  font-size: 15px;
  color: var(--forest);
  opacity: 0.4;
  flex-shrink: 0;
  margin-top: 1px;
}

.odm-delivery-addr {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.4;
  display: block;
}

/* ── Section ── */
.odm-section {
  padding: 18px 22px 20px;
  border-bottom: 1px solid var(--border);
}

.odm-section-title {
  font-family: var(--font-body);
  font-size: 9px;
  font-weight: 700;
  color: var(--forest);
  text-transform: uppercase;
  letter-spacing: 0.7px;
  display: flex;
  align-items: center;
  gap: 5px;
  margin: 0 0 14px;
  opacity: 0.7;
}
.odm-section-title .material-icons { font-size: 13px; }

/* ── Line items table ── */
.odm-lines-wrap {
  overflow-x: auto;
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  overflow: hidden;
}

.odm-lines-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
  min-width: 360px;
}

.odm-lines-table thead { background: var(--bg); }

.odm-lines-table th {
  font-family: var(--font-data);
  font-size: 8px;
  font-weight: 700;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--text-light);
  padding: 9px 12px;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
  text-align: left;
}

.odm-lines-table th.odm-col-right { text-align: right; }

.odm-lines-table td {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--charcoal);
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  vertical-align: top;
}

.odm-lines-table tbody tr:last-child td { border-bottom: none; }

.odm-lines-table tbody tr:nth-child(even) td { background: rgba(242,246,244,0.5); }

.odm-lines-table tbody tr:hover td {
  background: var(--forest-light) !important;
  transition: background 0.1s;
}

.odm-lines-table tfoot td {
  padding: 10px 12px;
  border-top: 1px solid var(--border);
  background: var(--bg);
  font-family: var(--font-data);
}

.odm-lines-table tfoot tr.odm-lines-tfoot-total td {
  background: var(--forest);
  border-top: none;
  padding: 13px 12px;
}

.odm-col-right { text-align: right !important; white-space: nowrap; }

.odm-lines-cell { display: flex; flex-direction: column; gap: 2px; }

.odm-lines-item {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 6px 12px;
}

.odm-lines-code {
  display: inline-block;
  font-family: var(--font-data);
  font-size: 9px;
  color: var(--forest);
  font-weight: 700;
  letter-spacing: 0.4px;
  background: var(--forest-light);
  border: 1px solid var(--forest-border);
  border-radius: 4px;
  padding: 1px 6px;
  margin-bottom: 0;
  white-space: nowrap;
  flex-shrink: 0;
}

.odm-lines-item > .odm-lines-code + .odm-lines-desc {
  flex: 1 1 160px;
  min-width: 0;
}

.odm-lines-desc {
  font-size: 12px;
  color: var(--charcoal);
  line-height: 1.35;
}

/* Secondary line (e.g. channel meta) reuses .odm-lines-desc — full width under SKU + title */
.odm-lines-item > .odm-lines-desc ~ .odm-lines-desc {
  flex: 1 1 100%;
}

.odm-lines-disc {
  font-family: var(--font-data);
  font-size: 9px;
  color: var(--copper);
  font-weight: 600;
  margin-left: 4px;
}

.odm-lines-qty-val {
  font-family: var(--font-data);
  font-size: 13px;
  font-weight: 700;
  color: var(--charcoal);
}

.odm-lines-subtotal-label {
  font-family: var(--font-data);
  font-size: 9px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  text-align: right;
}

.odm-lines-subtotal-val,
.odm-lines-freight-val {
  font-family: var(--font-data);
  font-size: 12px;
  font-weight: 700;
  color: var(--charcoal);
}

/* Must beat .odm-lines-table td { color: var(--charcoal) } (same/higher specificity) */
.odm-lines-table tfoot tr.odm-lines-tfoot-total td.odm-lines-total-label {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.3px;
  color: rgba(255, 255, 255, 0.95);
  text-align: right;
}

.odm-lines-table tfoot tr.odm-lines-tfoot-total td.odm-lines-total-val {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.3px;
}

.odm-lines-empty {
  text-align: center;
  color: var(--text-muted);
  font-style: italic;
  padding: 32px !important;
  font-size: 13px;
}

/* ══════════════════════════════════════════════════
   Commission breakdown — premium waterfall design
   ══════════════════════════════════════════════════ */
.odm-commission {
  padding: 20px 24px 0;
  background: var(--bg);
  border-top: 1.5px solid var(--border-dark);
}

.odm-comm-title {
  display: flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-body);
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.7px;
  color: var(--forest);
  opacity: 0.7;
  margin-bottom: 14px;
}
.odm-comm-title .material-icons { font-size: 14px; }

.odm-comm-waterfall {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* ── Sale price row ── */
.odm-comm-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 10px 14px;
}

.odm-comm-row--sale {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  margin-bottom: 10px;
}

.odm-comm-row--basis {
  background: var(--forest-light);
  border: 1.5px solid var(--forest-border);
  border-radius: var(--radius-md) var(--radius-md) 0 0;
  border-bottom: none;
}

.odm-comm-label {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--text-body);
  display: flex;
  align-items: center;
  gap: 0;
  flex: 1;
  min-width: 0;
}

.odm-comm-label-group {
  display: flex;
  flex-direction: column;
  gap: 1px;
  flex: 1;
}

.odm-comm-label-sub {
  font-family: var(--font-data);
  font-size: 9px;
  color: var(--text-light);
  letter-spacing: 0.2px;
}

.odm-comm-val {
  font-family: var(--font-data);
  font-size: 13px;
  font-weight: 700;
  color: var(--charcoal);
  white-space: nowrap;
  flex-shrink: 0;
}

.odm-comm-val--sale {
  color: var(--text-muted);
  font-size: 12px;
}

.odm-comm-val--basis {
  font-size: 15px;
  font-weight: 800;
  color: var(--forest);
}

/* ── Deduction block ── */
.odm-comm-deducts {
  background: var(--white);
  border: 1.5px solid var(--forest-border);
  border-top: none;
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  margin-bottom: 14px;
  overflow: hidden;
  position: relative;
}

.odm-comm-deducts::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: linear-gradient(to bottom, rgba(192,57,43,0.4), rgba(192,57,43,0.1));
}

.odm-comm-row--deduct {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 9px 14px 9px 16px;
  border-bottom: 1px solid rgba(220,220,220,0.6);
}
.odm-comm-row--deduct:last-child { border-bottom: none; }

.odm-comm-minus {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: rgba(192,57,43,0.1);
  color: var(--red);
  font-size: 13px;
  font-weight: 800;
  line-height: 1;
  flex-shrink: 0;
  margin-right: 8px;
  font-family: var(--font-data);
}

.odm-comm-rate {
  font-family: var(--font-data);
  font-size: 10px;
  color: var(--text-light);
  margin-left: 4px;
}

.odm-comm-val--deduct {
  font-family: var(--font-data);
  font-size: 12px;
  font-weight: 700;
  color: var(--red);
  white-space: nowrap;
  flex-shrink: 0;
}

/* ── Net payout hero card ── */
.odm-comm-net-card {
  background: linear-gradient(140deg, var(--forest-dark) 0%, #1e4a3d 55%, var(--forest-mid) 100%);
  border-radius: var(--radius-md);
  padding: 20px 22px 22px;
  margin: 0 -24px;
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(26,60,52,0.25);
}

/* Decorative circles */
.odm-comm-net-card::before {
  content: '';
  position: absolute;
  right: -50px;
  bottom: -50px;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: rgba(255,255,255,0.04);
  pointer-events: none;
}
.odm-comm-net-card::after {
  content: '';
  position: absolute;
  left: 30%;
  top: -30px;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background: rgba(255,255,255,0.025);
  pointer-events: none;
}

/* Copper top accent line */
.odm-comm-net-card__inner {
  position: relative;
  z-index: 1;
  border-top: 2px solid var(--copper);
  padding-top: 16px;
}

.odm-comm-net-card__eyebrow {
  font-family: var(--font-data);
  font-size: 8px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: rgba(255,255,255,0.35);
  margin-bottom: 6px;
}

.odm-comm-net-card__row {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.odm-comm-net-card__lhs { flex: 1; min-width: 0; }

.odm-comm-net-card__label {
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  color: rgba(255,255,255,0.5);
  margin-bottom: 10px;
}

.odm-comm-net-card__amount {
  font-family: var(--font-display);
  font-size: 36px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.8px;
  line-height: 1;
  text-shadow: 0 2px 12px rgba(0,0,0,0.2);
}

.odm-comm-net-card__footer {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
  flex-wrap: wrap;
}

/* Override status badges on dark bg */
.odm-comm-net-card .sp-status-badge {
  font-size: 10px;
  padding: 4px 10px;
}
.odm-comm-net-card .sp-status-badge--pending {
  background: rgba(255, 183, 77, 0.18);
  color: #ffd54f;
  border-color: rgba(255, 183, 77, 0.35);
}
.odm-comm-net-card .sp-status-badge--pending::before {
  background: #ffd54f;
  box-shadow: 0 0 5px rgba(255, 213, 79, 0.5);
}
.odm-comm-net-card .sp-status-badge--released {
  background: rgba(129, 199, 132, 0.18);
  color: #a5d6a7;
  border-color: rgba(129, 199, 132, 0.3);
}
.odm-comm-net-card .sp-status-badge--released::before {
  background: #a5d6a7;
}

.odm-c-paid-on {
  font-family: var(--font-data);
  font-size: 10px;
  color: rgba(255,255,255,0.35);
}

.odm-comm-net-card-spacer {
  height: 24px;
  background: var(--bg);
}

/* ── Dispensary note ── */
.odm-dispensary-note {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 14px;
  background: var(--copper-light);
  border: 1px solid var(--copper-border);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
  font-family: var(--font-body);
  font-size: 11px;
  color: var(--text-body);
  line-height: 1.55;
  margin-top: -4px;
}
.odm-dispensary-note .material-icons {
  font-size: 16px;
  color: var(--copper);
  flex-shrink: 0;
  margin-top: 1px;
}

/* ── Footer ── */
.odm-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 13px 22px;
  border-top: 1px solid var(--border);
  background: var(--bg);
  flex-shrink: 0;
}

.odm-footer__left {
  font-family: var(--font-data);
  font-size: 10px;
  color: var(--text-light);
}

.odm-footer__actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.odm-footer .sales-portal-chip .material-icons {
  font-size: 13px;
  vertical-align: middle;
  margin-right: 3px;
  margin-top: -1px;
}

/* ── Responsive: mobile bottom-sheet ── */
@media (max-width: 600px) {
  .odm-overlay { align-items: flex-end; padding: 0; }
  .odm-panel {
    max-height: 96vh;
    border-radius: 16px 16px 0 0;
    align-self: flex-end;
  }
  .odm-meta-cards { grid-template-columns: repeat(2, 1fr); }
  .odm-meta-card { border-bottom: 1px solid var(--border); }
  .odm-meta-card:nth-child(1),
  .odm-meta-card:nth-child(2) { border-right: 1px solid var(--border); }
  .odm-meta-card:nth-child(3),
  .odm-meta-card:nth-child(4) { border-right: none; border-bottom: none; }
  .odm-title { font-size: 18px; }
  .odm-header { padding: 16px 18px 14px; }
  .odm-section { padding: 14px 16px 16px; }
  .odm-commission { padding: 16px 16px 0; }
  .odm-comm-net-card { margin: 0 -16px; }
  .odm-footer { padding: 11px 16px; }
  .odm-comm-net-card__amount { font-size: 28px; }
}

/* ─────────────────────────────────────────────────────────────────────────────
   Driver route — status badges, truck card, KPI tints, table polish
   All tokens consumed via var(--*) so the theme switcher (data-theme-accent)
   recolours every surface instantly.
───────────────────────────────────────────────────────────────────────────── */

/* Status badges — extends the existing .sp-status-badge--{state} pattern */
.sp-status-badge--loaded {
  background: var(--copper-bg-subtle);
  color: var(--copper-hover);
  border: 1px solid var(--copper-border-subtle);
}
.sp-status-badge--loaded::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--copper);
  flex-shrink: 0;
  box-shadow: 0 0 0 3px var(--copper-bg-subtle);
}
.sp-status-badge--enroute {
  background: rgba(var(--forest-rgb), 0.08);
  color: var(--forest-mid);
  border: 1px solid rgba(var(--forest-rgb), 0.22);
}
.sp-status-badge--enroute::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--forest-mid);
  flex-shrink: 0;
  animation: sp-status-pulse 1.6s ease-in-out infinite;
}
.sp-status-badge--delivered {
  background: var(--forest-light);
  color: var(--forest-dark);
  border: 1px solid var(--forest-border);
}
.sp-status-badge--delivered::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--forest);
  flex-shrink: 0;
}
@keyframes sp-status-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(var(--forest-rgb), 0.5); }
  50%      { box-shadow: 0 0 0 5px rgba(var(--forest-rgb), 0); }
}

/* Truck info card sitting under the page title */
.driver-truck-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  margin: 14px 0 4px;
  background: linear-gradient(135deg, var(--forest-light) 0%, rgba(var(--copper-rgb), 0.06) 100%);
  border: 1px solid var(--forest-border);
  border-left: 4px solid var(--copper);
  border-radius: var(--radius-md);
  box-shadow: 0 2px 8px rgba(var(--forest-rgb), 0.06);
  transition: var(--transition);
}
.driver-truck-card:hover {
  box-shadow: 0 6px 20px rgba(var(--forest-rgb), 0.1);
}
.driver-truck-card__icon {
  flex: 0 0 44px;
  height: 44px;
  border-radius: var(--radius-md);
  background: var(--copper);
  color: var(--copper-contrast);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px var(--copper-shadow);
}
.driver-truck-card__icon i {
  font-size: 24px;
}
.driver-truck-card__body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.driver-truck-card__label {
  font-family: var(--font-body);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  color: var(--text-light);
}
.driver-truck-card__name {
  font-family: var(--font-body);
  font-size: 18px;
  font-weight: 800;
  color: var(--forest);
  line-height: 1.15;
}
.driver-truck-card__meta {
  font-family: var(--font-data);
  font-size: 12px;
  color: var(--text-muted);
}
.driver-truck-card__meta--tel {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 2px;
  color: var(--forest);
  text-decoration: none;
  font-weight: 600;
  transition: var(--transition);
}
.driver-truck-card__meta--tel:hover,
.driver-truck-card__meta--tel:focus {
  color: var(--copper);
}
.driver-truck-card__meta--tel i {
  font-size: 14px;
}
.driver-truck-card--empty {
  border-left-color: var(--red);
  background: var(--red-light);
}
.driver-truck-card--empty .driver-truck-card__icon {
  background: var(--red);
  box-shadow: 0 2px 8px rgba(192, 57, 43, 0.3);
}
.driver-truck-card--empty .driver-truck-card__name {
  color: var(--red);
}

/* KPI tile colour overrides for the 3-tile driver layout
   (default kpi-tile rules colour child 2/3/4; the driver page only renders 3
   tiles and we want forest / copper / deep forest for total / pending / done). */
.sales-portal-page--driver-orders .kpi-tiles {
  grid-template-columns: repeat(3, 1fr);
}
.sales-portal-page--driver-orders .kpi-tile:nth-child(1) { border-top-color: var(--forest); }
.sales-portal-page--driver-orders .kpi-tile:nth-child(1) .kpi-tile__value { color: var(--forest); }
.sales-portal-page--driver-orders .kpi-tile:nth-child(2) { border-top-color: var(--copper); }
.sales-portal-page--driver-orders .kpi-tile:nth-child(2) .kpi-tile__value { color: var(--copper); }
.sales-portal-page--driver-orders .kpi-tile:nth-child(3) { border-top-color: var(--forest-mid); }
.sales-portal-page--driver-orders .kpi-tile:nth-child(3) .kpi-tile__value { color: var(--forest-mid); }

/* Smooth row hover and current-stop highlight on the dispatch table */
.sales-portal-page--driver-orders .sales-portal-table tbody tr {
  transition: background 0.15s ease, box-shadow 0.15s ease;
}
.sales-portal-page--driver-orders .sales-portal-table tbody tr:hover td {
  background: var(--forest-light);
}
.sales-portal-page--driver-orders .sales-portal-table tr.driver-row--enroute td {
  background: rgba(var(--forest-rgb), 0.04);
}
.sales-portal-page--driver-orders .sales-portal-table tr.driver-row--enroute td:first-child {
  box-shadow: inset 3px 0 0 var(--forest-mid);
}
.sales-portal-page--driver-orders .sales-portal-table tr.driver-row--delivered td {
  background: rgba(var(--forest-rgb), 0.025);
  color: var(--text-muted);
}
.sales-portal-page--driver-orders .sales-portal-table tr.driver-row--delivered .sales-portal-table__strong {
  text-decoration: line-through;
  text-decoration-color: var(--forest-border);
}
.sales-portal-page--driver-orders .sales-portal-table__num {
  font-family: var(--font-data);
}

.driver-row__map {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--forest);
  text-decoration: none;
  transition: var(--transition);
}
.driver-row__map:hover,
.driver-row__map:focus {
  color: var(--copper);
  text-decoration: underline;
  text-decoration-color: var(--copper-border);
  text-underline-offset: 3px;
}
.driver-row__map i {
  font-size: 16px;
  color: var(--copper);
  flex-shrink: 0;
}

/* ───── Mobile: drivers are in a truck, on a phone — keep it legible ───── */
@media (max-width: 900px) {
  .sales-portal-page--driver-orders .kpi-tiles {
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
  }
  .sales-portal-page--driver-orders .kpi-tile {
    padding: 14px 12px;
  }
  .sales-portal-page--driver-orders .kpi-tile__value {
    font-size: 26px;
  }
  .sales-portal-page--driver-orders .kpi-tile__label {
    font-size: 8px;
    letter-spacing: 0.6px;
  }
}

@media (max-width: 600px) {
  .driver-truck-card {
    gap: 10px;
    padding: 12px 14px;
    border-left-width: 3px;
  }
  .driver-truck-card__icon {
    flex: 0 0 38px;
    height: 38px;
  }
  .driver-truck-card__icon i {
    font-size: 20px;
  }
  .driver-truck-card__name {
    font-size: 16px;
  }
  .driver-truck-card__meta {
    font-size: 11px;
  }
  .sales-portal-page--driver-orders .kpi-tile__value {
    font-size: 22px;
  }
}

@media (max-width: 480px) {
  /* The --orders modifier already stacks each cell into a label/value grid.
     Add the driver-specific visual polish: a left accent stripe on every
     card, a colour-coded border per stop status, chunky badges, a phone-
     sized tap target for the address, and a reset of the desktop-only
     enroute/delivered per-td tint. */
  .sales-portal-page--driver-orders .sales-portal-table--orders tbody tr.driver-row {
    display: block;
    padding: 12px 14px 14px;
    margin-bottom: 12px;
    background: var(--white, #fff);
    border: 1px solid var(--border);
    border-left: 4px solid var(--forest-border);
    border-radius: var(--radius-md);
    box-shadow: 0 2px 10px rgba(var(--forest-rgb), 0.06);
  }
  .sales-portal-page--driver-orders .sales-portal-table--orders tbody tr.driver-row--pending {
    border-left-color: var(--copper-border);
  }
  .sales-portal-page--driver-orders .sales-portal-table--orders tbody tr.driver-row--loaded {
    border-left-color: var(--copper);
  }
  .sales-portal-page--driver-orders .sales-portal-table--orders tbody tr.driver-row--enroute {
    border-left-color: var(--forest-mid);
    background: rgba(var(--forest-rgb), 0.03);
  }
  .sales-portal-page--driver-orders .sales-portal-table--orders tbody tr.driver-row--delivered {
    border-left-color: var(--forest);
    opacity: 0.78;
  }
  /* desktop-only treatments that conflict with the card layout */
  .sales-portal-page--driver-orders .sales-portal-table tr.driver-row--enroute td,
  .sales-portal-page--driver-orders .sales-portal-table tr.driver-row--delivered td {
    background: transparent;
    color: inherit;
  }
  .sales-portal-page--driver-orders .sales-portal-table tr.driver-row--enroute td:first-child {
    box-shadow: none;
  }

  /* Readable values: bump body cell font size so it's usable one-handed */
  .sales-portal-page--driver-orders .sales-portal-table--orders tbody tr.driver-row td {
    font-size: 15px;
    padding: 6px 0;
  }
  .sales-portal-page--driver-orders .sales-portal-table--orders tbody tr.driver-row td::before {
    font-size: 10px;
  }

  /* Order number deserves to shout */
  .sales-portal-page--driver-orders .sales-portal-table--orders tbody tr.driver-row .sales-portal-table__strong .sales-portal-table__cell-val {
    font-family: var(--font-data);
    font-size: 18px;
    font-weight: 800;
    color: var(--forest);
  }

  /* Chunky, thumb-friendly status badge on each card */
  .sales-portal-page--driver-orders .sales-portal-table--orders tbody tr.driver-row .sp-status-badge {
    font-size: 12px;
    padding: 5px 14px;
  }

  /* Stop-number chip: centre the number visually (first td per row) */
  .sales-portal-page--driver-orders .sales-portal-table--orders tbody tr.driver-row td:first-child .sales-portal-table__cell-val {
    display: inline-block;
    min-width: 28px;
    height: 28px;
    line-height: 28px;
    text-align: center;
    border-radius: 999px;
    background: var(--forest-light);
    color: var(--forest-dark);
    font-weight: 800;
    padding: 0 10px;
  }

  /* Address (4th td: Stop, Order, Customer, Address, Status, Items, Value) */
  .sales-portal-page--driver-orders .sales-portal-table--orders tbody tr.driver-row td:nth-child(4) .sales-portal-table__cell-val {
    display: inline-block;
    line-height: 1.4;
    padding: 6px 0;
  }
}

/* ── Sales Portal Reports: export toolbar ────────────────────────────────── */
.sp-export-toolbar {
  display: inline-flex;
  align-items: flex-end;
  gap: 8px;
  flex-shrink: 0;
}
.sp-export-toolbar__label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding-bottom: 10px;
  align-self: center;
}
.sp-export-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  font-size: 12.5px;
  font-weight: 600;
  font-family: inherit;
  border-radius: var(--radius-md);
  border: 1.5px solid var(--border);
  background: var(--white);
  color: var(--text-body);
  cursor: pointer;
  transition: var(--transition);
  white-space: nowrap;
  line-height: 1;
}
.sp-export-btn i { font-size: 14px; }
.sp-export-btn:hover {
  border-color: var(--forest);
  background: var(--forest-light);
  color: var(--forest);
  transform: translateY(-1px);
  box-shadow: var(--shadow-card);
}
.sp-export-btn:active { transform: translateY(0); }
.sp-export-btn:focus-visible {
  outline: none;
  border-color: var(--copper);
  box-shadow: 0 0 0 3px rgba(184, 115, 51, 0.18);
}
.sp-export-btn--csv i { color: #2d7d46; }
.sp-export-btn--xls i { color: #1d6f42; }
.sp-export-btn--pdf i { color: #b0392b; }
.sp-export-btn:hover i { color: inherit; }

@media (max-width: 768px) {
  .sp-export-toolbar__label { display: none; }
  .sp-export-btn__text { display: none; }
  .sp-export-btn { padding: 8px 10px; }
}

/* ── Sales Portal Reports: panel accent stripes ──────────────────────────── */
.sp-report-panel {
  position: relative;
}
.sp-report-panel--top-sellers,
.sp-report-panel--sales-by-brand,
.sp-report-panel--sales-by-category,
.sp-report-panel--forecast,
.sp-report-panel--ar-aging,
.sp-report-panel--dormant,
.sp-report-panel--crm,
.sp-report-panel--leaderboard {
  border-left: 3px solid transparent;
  padding-left: 2px;
}
.sp-report-panel--top-sellers    { border-left-color: var(--copper); }
.sp-report-panel--sales-by-brand,
.sp-report-panel--sales-by-category { border-left-color: var(--forest); }
.sp-report-panel--forecast       { border-left-color: #f59e0b; }
.sp-report-panel--ar-aging       { border-left-color: var(--red); }
.sp-report-panel--dormant        { border-left-color: var(--text-muted); }
.sp-report-panel--crm            { border-left-color: var(--forest-mid); }
.sp-report-panel--leaderboard    { border-left-color: var(--gold); }

/* ── Sales Portal Reports: A/R totals summary bar ────────────────────────── */
.sp-ar-totals {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 14px;
  margin: 12px 0 14px;
  padding: 12px 16px;
  background: linear-gradient(135deg, var(--forest-light) 0%, rgba(235, 244, 240, 0.4) 100%);
  border: 1px solid var(--forest-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
}
.sp-ar-totals__label {
  font-size: 11px;
  font-weight: 700;
  color: var(--forest);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-right: 4px;
}
.sp-ar-totals__item {
  display: inline-flex;
  flex-direction: column;
  min-width: 88px;
  padding: 4px 12px;
  border-left: 1px solid var(--forest-border);
}
.sp-ar-totals__item:first-of-type { border-left: none; }
.sp-ar-totals__k {
  font-size: 10px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 2px;
}
.sp-ar-totals__v {
  font-family: var(--font-data);
  font-size: 15px;
  font-weight: 700;
  color: var(--charcoal);
  font-variant-numeric: tabular-nums;
}
.sp-ar-totals__item--grand {
  margin-left: auto;
  padding: 6px 14px;
  background: var(--white);
  border: 1px solid var(--forest);
  border-radius: var(--radius-md);
  box-shadow: 0 1px 2px rgba(26, 60, 52, 0.08);
}
.sp-ar-totals__item--grand .sp-ar-totals__k { color: var(--forest); }
.sp-ar-totals__item--grand .sp-ar-totals__v { color: var(--forest); font-size: 16px; }

@media (max-width: 680px) {
  .sp-ar-totals { gap: 6px 10px; padding: 10px 12px; }
  .sp-ar-totals__item { min-width: 72px; padding: 3px 8px; }
  .sp-ar-totals__item--grand { margin-left: 0; flex-basis: 100%; }
  .sp-ar-totals__v { font-size: 13px; }
}

/* ── Sales Portal Reports: share-bar cell for sales-by-brand ─────────────── */
.sp-share-cell {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;
  width: 100%;
}
.sp-share-cell__bar {
  flex: 1;
  height: 6px;
  min-width: 40px;
  max-width: 120px;
  background: var(--forest-light);
  border-radius: var(--radius-pill);
  overflow: hidden;
}
.sp-share-cell__fill {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--forest) 0%, var(--copper) 100%);
  border-radius: var(--radius-pill);
  transition: width 0.3s ease;
}
.sp-share-cell__pct {
  font-family: var(--font-data);
  font-weight: 700;
  font-size: 12px;
  color: var(--charcoal);
  min-width: 44px;
  text-align: right;
  font-variant-numeric: tabular-nums;
}

/* ── Sales Portal Reports: rank medal for leaderboard top 3 ──────────────── */
.sp-rank-medal {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  font-weight: 800;
  font-size: 11px;
  font-family: var(--font-data);
  color: var(--white);
  line-height: 1;
}
.sp-rank-medal--1 { background: linear-gradient(135deg, #f5cf47 0%, #d4a843 100%); color: #5b4400; }
.sp-rank-medal--2 { background: linear-gradient(135deg, #cfd4d9 0%, #a0a6ad 100%); color: #2c333a; }
.sp-rank-medal--3 { background: linear-gradient(135deg, #e0a777 0%, #b87333 100%); color: #fff; }

/* ── Sales Portal Reports: dormant & over-terms subtle row tint ─────────── */
.sales-portal-table--reports tbody tr.sp-row--stale td:first-child {
  border-left: 2px solid var(--text-light);
  padding-left: 10px;
}

/* ── Sales Portal Reports: mobile overrides ──────────────────────────────── */

/* Tab nav: scroll horizontally instead of wrapping on narrow screens */
@media (max-width: 640px) {
  .sp-tab-nav {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: 2px;
    /* Fade right edge to hint that more tabs exist */
    -webkit-mask-image: linear-gradient(to right, black 80%, transparent 100%);
    mask-image: linear-gradient(to right, black 80%, transparent 100%);
  }
  .sp-tab-nav::-webkit-scrollbar {
    display: none;
  }
  .sp-tab-nav__tab {
    flex-shrink: 0;
    white-space: nowrap;
  }
}

/* Date range bar: tighten preset pills on very small phones */
@media (max-width: 380px) {
  .sp-daterange-preset {
    padding: 4px 9px;
    font-size: 11px;
  }
  .sp-daterange-apply {
    font-size: 12px;
    padding: 8px 14px;
  }
}

/* Stale row left-border doesn't translate well to card layout */
@media (max-width: 640px) {
  .sales-portal-table--reports tbody tr.sp-row--stale td:first-child {
    border-left: none;
    padding-left: 0;
  }
  .sales-portal-table--reports tbody tr.sp-row--stale {
    border-color: var(--text-light, #bbb);
  }
}

/* Share-cell bar: allow it to shrink gracefully in card value column */
@media (max-width: 640px) {
  .sp-share-cell {
    white-space: normal;
    flex-wrap: wrap;
    gap: 4px 6px;
  }
  .sp-share-cell__bar {
    min-width: 30px;
  }
}

/* ═══════════════════════════════════════════════════════════════════════
   Manager · Sales Pricing Rules page
   ═══════════════════════════════════════════════════════════════════════ */
.pricing-rules-input {
  max-width: 220px;
}

.pricing-rules-input .staff-ctrl__input {
  height: 44px;
  font-size: 15px;
  font-weight: 700;
}

.pricing-rules-input .staff-ctrl__suffix {
  padding: 0 14px;
  font-size: 14px;
}

.pricing-rules-form .field {
  margin-bottom: 22px;
}

.pricing-rules-status {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  border-radius: var(--radius-md);
  margin: 4px 0 22px;
}

.pricing-rules-status__icon {
  font-size: 22px;
  flex-shrink: 0;
  margin-top: 1px;
}

.pricing-rules-status__body {
  display: flex;
  flex-direction: column;
  gap: 3px;
  font-family: var(--font-body);
  font-size: 13px;
  line-height: 1.45;
}

.pricing-rules-status__title {
  font-weight: 700;
  letter-spacing: 0.3px;
}

.pricing-rules-status__desc strong {
  font-weight: 700;
}

.pricing-rules-status--on {
  background: var(--s-avail-bg);
  border: 1px solid var(--s-avail-bd);
  color: var(--s-avail-text);
}
.pricing-rules-status--on .pricing-rules-status__icon {
  color: var(--s-avail-dot);
}

.pricing-rules-status--off {
  background: var(--sage-bg);
  border: 1px solid var(--border);
  color: var(--text-muted);
}
.pricing-rules-status--off .pricing-rules-status__icon {
  color: var(--text-light);
}

.pricing-rules-form .btn-primary-moov .material-icons {
  font-size: 16px;
}

/* ── Inline CRM Notes (customer detail page) ──────────────────────────────── */
.sp-cd-notes-title {
  display: flex;
  align-items: center;
  gap: 10px;
}
.sp-cd-notes-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  padding: 0 7px;
  border-radius: 999px;
  background: var(--forest-mid, #6a8f73);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  vertical-align: middle;
}
.sp-cd-note-compose {
  background: var(--surface, #fff);
  border: 1px solid var(--border, #e8e6e1);
  border-radius: 12px;
  padding: 18px 20px;
  margin-bottom: 20px;
  box-shadow: 0 1px 4px rgba(26, 46, 31, 0.06);
}
.sp-cd-compose-top {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.sp-cd-type-pills {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  flex: 1 1 auto;
}
.sp-cd-type-pill {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  border-radius: 999px;
  border: 1.5px solid var(--border, #e5e7eb);
  background: var(--surface, #fff);
  color: var(--text-muted, #666);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s;
  white-space: nowrap;
  font-family: var(--font-body, inherit);
}
.sp-cd-type-pill:hover {
  border-color: var(--forest-mid, #6a8f73);
  color: var(--forest-dark, #1a2e1f);
  background: var(--sage-bg, #f2f5f0);
}
.sp-cd-type-pill--general.is-active { background: var(--sage-bg, #edf0ea); color: var(--forest-dark, #1a2e1f); border-color: var(--forest-mid, #6a8f73); }
.sp-cd-type-pill--call.is-active    { background: #e6f0ff; color: #1a4ea6; border-color: #b8d0f5; }
.sp-cd-type-pill--visit.is-active   { background: #e6fff0; color: #136a3a; border-color: #9de0bc; }
.sp-cd-type-pill--follow_up.is-active { background: #fff8e6; color: #8a5c00; border-color: #f0d580; }
.sp-cd-note-date {
  padding: 7px 12px;
  border: 1.5px solid var(--border, #e5e7eb);
  border-radius: 8px;
  font-size: 13px;
  color: var(--text, #1a1a1a);
  background: var(--surface, #fff);
  font-family: var(--font-body, inherit);
  cursor: pointer;
  min-width: 0;
}
.sp-cd-note-date:focus {
  outline: none;
  border-color: var(--forest-mid, #6a8f73);
  box-shadow: 0 0 0 3px rgba(106, 143, 115, 0.12);
}
.sp-cd-note-textarea {
  width: 100%;
  padding: 12px 14px;
  border: 1.5px solid var(--border, #e5e7eb);
  border-radius: 8px;
  font-size: 14px;
  line-height: 1.55;
  color: var(--text, #1a1a1a);
  background: var(--surface, #fff);
  font-family: var(--font-body, inherit);
  resize: vertical;
  min-height: 84px;
  transition: border-color 0.15s, box-shadow 0.15s;
  box-sizing: border-box;
  display: block;
}
.sp-cd-note-textarea:focus {
  outline: none;
  border-color: var(--forest-mid, #6a8f73);
  box-shadow: 0 0 0 3px rgba(106, 143, 115, 0.12);
}
.sp-cd-note-textarea::placeholder {
  color: var(--text-muted, #bbb);
}
.sp-cd-compose-footer {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 10px;
  flex-wrap: wrap;
}
.sp-cd-note-counter {
  font-size: 11px;
  color: var(--text-muted, #aaa);
  margin-right: auto;
}
.sp-cd-note-error {
  font-size: 13px;
  color: #c0392b;
  font-weight: 500;
}
.sp-cd-note-submit {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 110px;
  justify-content: center;
}
.sp-cd-notes-success {
  padding: 10px 16px;
  background: var(--forest-light, #f0f7f4);
  border: 1px solid var(--forest-border, #d4ddd5);
  border-radius: 8px;
  color: var(--forest-dark, #1a2e1f);
  font-size: 13px;
  font-weight: 500;
  margin-bottom: 16px;
}
@media (max-width: 600px) {
  .sp-cd-note-compose {
    padding: 14px 16px;
    border-radius: 10px;
  }
  .sp-cd-compose-top {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .sp-cd-note-date {
    width: 100%;
  }
  .sp-cd-compose-footer {
    flex-direction: column-reverse;
    align-items: stretch;
    gap: 8px;
  }
  .sp-cd-note-submit {
    width: 100%;
    justify-content: center;
    padding: 12px 16px;
    font-size: 15px;
  }
  .sp-cd-note-counter {
    margin-right: 0;
    text-align: right;
  }
  .sp-cd-type-pill {
    padding: 8px 16px;
    font-size: 13px;
  }
}

/* ═══════════════════════════════════════════════════════════════════════════
   Sales Customers — responsive polish to match the open-orders list
   ═══════════════════════════════════════════════════════════════════════════
   Brings the customers page to feature-parity with sales_orders.twig in terms
   of desktop density, tablet spacing, and mobile card collapse.  The underlying
   shell (moov-shell admin-page sales-portal-page) is already shared — these
   rules fix the customers-specific extras: header actions, tabs, topbar stack,
   filter drawer on mobile, and the register drawer's safe-area edges.
   ──────────────────────────────────────────────────────────────────────── */

/* Desktop: give the header actions room to breathe and let the register CTA
   sit to the right of the title block like other portal pages do. */
.sales-portal-page--customers-list .admin-page__header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px 24px;
}
.sales-portal-page--customers-list .admin-page__header > :not(.sales-portal-page__actions) {
  flex: 1 1 320px;
  min-width: 0;
}
.sales-portal-page--customers-list .sales-portal-page__actions {
  flex: 0 0 auto;
  margin: 0;
}

/* Tabs: scrollable on narrow, bigger hit targets, crisper active state. */
.sp-customers-tabs {
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-bottom: 1px;
}
.sp-customers-tabs::-webkit-scrollbar { display: none; }
.sp-customers-tab {
  flex: 0 0 auto;
  min-height: 40px;
  white-space: nowrap;
  border-radius: 8px 8px 0 0;
}
.sp-customers-tab:focus-visible {
  outline: 2px solid var(--copper, #B87333);
  outline-offset: 2px;
  border-radius: 6px;
}

/* Topbar (filter toggle + live search) stacks cleanly and fills width. */
@media (max-width: 768px) {
  .sales-portal-page--customers-list .admin-page__header {
    flex-direction: column;
    align-items: stretch;
  }
  /* Reset flex-basis so title + subtitle shrink to natural height in column layout.
     Without this, flex: 1 1 320px makes each item 320px tall on mobile. */
  .sales-portal-page--customers-list .admin-page__header > :not(.sales-portal-page__actions) {
    flex: none;
  }
  .sales-portal-page--customers-list .sales-portal-page__actions {
    display: flex;
    justify-content: flex-start;
  }
  .sales-portal-page--customers-list .sales-portal-page__actions .btn-primary-moov {
    width: 100%;
    justify-content: center;
  }
  .sales-portal-customers-topbar {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }
  .sales-portal-customers-topbar__search,
  .sales-portal-customers-topbar__search--inline {
    width: 100%;
  }
  .sales-portal-customers-topbar .catalog-filter-toggle {
    width: 100%;
    justify-content: center;
  }
  .sales-portal-list-meta {
    flex-wrap: wrap;
    gap: 8px;
  }
  .sales-portal-list-meta__limit {
    margin-left: auto;
  }
}

/* Mobile card collapse: a little extra polish on the customer rows so the
   avatar + name read as a single unit, and action chips stack comfortably
   on narrow screens — matching the --orders table's aesthetic. */
@media (max-width: 640px) {
  /* Tighten the space between the sticky search topbar and the results list. */
  .sales-portal-customers-main {
    gap: 8px;
  }
  .sales-portal-list-meta {
    margin-top: 0;
  }
  .sales-portal-table--customers tr {
    border-left-color: var(--forest-mid, #3a6b4d);
  }
  .sales-portal-table--customers .sales-portal-table__td-customer {
    display: flex !important;
    align-items: center;
    gap: 10px;
    grid-template-columns: none;
  }
  .sales-portal-table--customers .sales-portal-table__td-customer::before {
    display: none; /* avatar + name speak for themselves */
  }
  .sales-portal-table--customers .sp-cust-avatar {
    flex: 0 0 auto;
    margin: 0;
  }
  .sales-portal-table--customers .sales-portal-table__actions .sales-portal-table__action-row {
    flex-wrap: wrap;
    gap: 8px;
  }
  .sales-portal-table--customers .sales-portal-table__actions .sales-portal-chip {
    flex: 1 1 auto;
    justify-content: center;
    min-height: 36px;
  }
}

/* Hide email on very narrow screens when it's the only thing pushing the
   card taller — keep phone + actions visible. */
@media (max-width: 420px) {
  .sales-portal-table--customers .sales-portal-table__cell-email {
    font-size: 12px;
  }
  .sales-portal-table--customers .sales-portal-table__cell-email .sales-portal-table__cell-val {
    word-break: break-all;
  }
}

/* Register drawer: use dynamic viewport height + safe-area insets so iOS
   Safari doesn't clip the bottom action row behind the home-indicator. */
@media (max-width: 640px) {
  .sp-reg-drawer {
    height: 100vh;
    height: 100dvh;
  }
  .sp-reg-drawer__body {
    padding-bottom: calc(16px + env(safe-area-inset-bottom, 0px));
  }
  .sp-reg-drawer__footer {
    padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px));
  }
  .sp-reg-wizard-progress {
    overflow-x: auto;
    scrollbar-width: none;
  }
  .sp-reg-wizard-progress::-webkit-scrollbar { display: none; }
  .sp-reg-wizard-steps {
    min-width: max-content;
  }
}

/* Pending table: mirror the same row-hover affordance the active table gets.
   Data-labels are injected by JS at render time (see sales_customers.twig
   loadPending()), so the @media card collapse already covers it. */
.sp-pending-panel .sales-portal-table--customers tbody tr {
  transition: background-color 0.12s ease;
}
.sp-pending-panel .sales-portal-table--customers tbody tr:hover {
  background: rgba(26, 46, 31, 0.025);
}

/* ── Credit rating badges ─────────────────────────────────────────────── */
.cr-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.6em;
  padding: 0.15em 0.45em;
  border-radius: 4px;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1.4;
  cursor: default;
}
.cr-badge--lg {
  font-size: 1rem;
  min-width: 2em;
  padding: 0.2em 0.6em;
  border-radius: 6px;
}
.cr-tier--a   { background: #d4edda; color: #155724; }
.cr-tier--b   { background: #fff3cd; color: #856404; }
.cr-tier--c   { background: #ffe5d0; color: #8a3e00; }
.cr-tier--d   { background: #f8d7da; color: #721c24; }
.cr-tier--none { background: #e9ecef; color: #6c757d; }

.cr-badge-label {
  margin-left: 0.4em;
  font-size: 0.85rem;
  color: var(--color-text-muted, #666);
}
.cr-badge-detail {
  display: block;
  font-size: 0.72rem;
  color: var(--color-text-muted, #888);
  margin-top: 0.1em;
}
.sp-customer-kpi--credit-rating .kpi-tile__value {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.1em;
}

/* ── Overdue accounts table row highlights ─────────────────────────────── */
.cod-row--warning td { background: #fffbf0; }
.cod-row--critical td { background: #fff5f5; }
.text-right { text-align: right; }

/* ── Integration settings (inside portal Settings tab) ─────────────────── */
.sp-int-layout {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 20px;
  align-items: start;
}
@media (max-width: 700px) {
  .sp-int-layout { grid-template-columns: 1fr; }
}

/* Left nav list */
.sp-int-nav {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-card);
}
.sp-int-nav__label {
  padding: 10px 14px 8px;
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-light);
  border-bottom: 1px solid var(--border);
}
.sp-int-nav__list {
  list-style: none;
  margin: 0;
  padding: 6px 0;
}
.sp-int-nav__item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 9px 14px;
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-body);
  border-radius: 0;
  transition: background 0.12s, color 0.12s;
  text-align: left;
}
.sp-int-nav__item:hover { background: var(--forest-light); }
.sp-int-nav__item.is-active {
  background: var(--copper-light);
  color: var(--copper-active);
  font-weight: 600;
}
.sp-int-nav__name { flex: 1; }

/* Status badge on list item */
.sp-int-badge--on {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: var(--radius-pill);
  background: var(--forest-light);
  color: var(--forest-dark);
  border: 1px solid var(--forest-border);
}
.sp-int-badge--off {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 2px 7px;
  border-radius: var(--radius-pill);
  background: var(--bg-alt, #f1f3f5);
  color: var(--text-light);
  border: 1px solid var(--border);
}

/* Right settings area */
.sp-int-settings { min-width: 0; }
.sp-int-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 48px 24px;
  color: var(--text-muted);
  font-family: var(--font-body);
  font-size: 13px;
}

/* Settings card extends sp-profile-card */
.sp-int-card { padding: 0; }
.sp-int-card .sp-profile-card__title {
  padding: 16px 20px 14px;
  margin: 0;
  gap: 10px;
}
.sp-int-card__status {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-left: auto;
  font-size: 11px;
  font-weight: 500;
  color: var(--text-muted);
  font-family: var(--font-body);
}
.sp-int-card__tested { color: var(--text-light); }

.sp-int-dot {
  width: 7px; height: 7px;
  border-radius: 50%; flex-shrink: 0;
}
.sp-int-dot--ok   { background: var(--forest, #2e7d32); }
.sp-int-dot--fail { background: var(--red, #c62828); }

/* Test mode warning banner */
.sp-int-test-banner {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--amber-light, #fff8e1);
  border-bottom: 1px solid var(--amber-border, #ffe082);
  padding: 9px 20px;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  color: var(--amber-dark, #e65100);
}

.sp-int-fields {
  padding: 16px 20px;
  display: flex;
  flex-direction: column;
}

/* Rows inside the card */
.sp-int-row--toggles {
  display: flex;
  gap: 28px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}
.sp-int-row--half {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

/* Toggle switch */
.sp-int-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  user-select: none;
}
.sp-int-toggle__track {
  position: relative;
  width: 36px;
  height: 20px;
  background: var(--border);
  border-radius: 10px;
  transition: background 0.18s;
  flex-shrink: 0;
}
.sp-int-toggle__track::after {
  content: '';
  position: absolute;
  top: 3px; left: 3px;
  width: 14px; height: 14px;
  background: var(--white);
  border-radius: 50%;
  box-shadow: 0 1px 2px rgba(0,0,0,.2);
  transition: left 0.18s;
}
.sp-int-toggle__track.is-on { background: var(--forest, #2e7d32); }
.sp-int-toggle__track.is-on::after { left: 19px; }
.sp-int-toggle--warn .sp-int-toggle__track.is-on { background: var(--amber, #f59e0b); }
.sp-int-toggle__label {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-body);
}
.sp-int-toggle__hint {
  font-family: var(--font-body);
  font-size: 11px;
  color: var(--text-light);
}

/* Feedback */
.sp-int-feedback { margin-top: 4px; margin-bottom: 4px; }
.sp-int-feedback--ok,
.sp-int-feedback--err {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  padding: 8px 12px;
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: 12px;
  line-height: 1.5;
}
.sp-int-feedback--ok  { background: var(--forest-light); color: var(--forest-dark); }
.sp-int-feedback--err { background: var(--red-light, #ffebee); color: var(--red, #c62828); }

/* Connected account chip */
.sp-int-account {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 4px;
  padding: 8px 12px;
  background: var(--bg-alt, #f1f3f5);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: 12px;
}
.sp-int-account__label {
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-light);
  font-size: 10px;
}
.sp-int-account__name { font-weight: 600; color: var(--text-body); }

/* Action buttons row in card */
.sp-int-card .sp-profile-form__actions {
  padding: 0 20px 18px;
  gap: 8px;
}

/* field__hint (shared utility) */
.field__hint {
  display: block;
  font-family: var(--font-body);
  font-size: 11px;
  color: var(--text-light);
  margin-top: 3px;
}

/* ── A/R Aging expandable buckets ──────────────────────────────────────── */
.order-invoice-aging {
  margin-bottom: 20px;
}
.order-invoice-aging__intro {
  margin: 0 0 14px;
  font-size: 13px;
  color: var(--text-muted, #5c6b66);
}
.order-invoice-aging__grid {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.order-invoice-aging__bucket {
  border: 1px solid var(--border-light, #dde3de);
  border-radius: 6px;
  overflow: hidden;
}
/* Over-90 buckets get a warning tint on the header */
.order-invoice-aging__bucket[data-aging-bucket="91_plus"] .order-invoice-aging__toggle {
  background: #fff7ed;
  border-left: 3px solid #f59e0b;
}
.order-invoice-aging__bucket[data-aging-bucket="91_plus"].is-open .order-invoice-aging__toggle {
  background: #fef3c7;
}
.order-invoice-aging__toggle {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 16px;
  background: var(--surface-raised, #f9faf9);
  border: none;
  cursor: pointer;
  text-align: left;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-dark, #1a2e22);
  transition: background 0.15s;
}
.order-invoice-aging__toggle:hover {
  background: var(--surface-active, #eef3ee);
}
.order-invoice-aging__bucket.is-open .order-invoice-aging__toggle {
  background: var(--surface-active, #eef3ee);
}
.order-invoice-aging__toggle-label {
  flex: 1;
}
.order-invoice-aging__count {
  font-size: 11px;
  font-weight: 400;
  color: var(--text-muted, #5c6b66);
  margin-left: 4px;
}
.order-invoice-aging__total {
  font-family: var(--font-data, monospace);
  font-size: 14px;
  font-weight: 700;
  color: var(--forest, #1d5c3a);
  margin-right: 6px;
}
.order-invoice-aging__chevron {
  flex-shrink: 0;
  font-size: 11px;
  color: var(--text-muted, #5c6b66);
  transition: transform 0.2s ease;
}
.order-invoice-aging__bucket.is-open .order-invoice-aging__chevron {
  transform: rotate(180deg);
}
.order-invoice-aging__panel {
  border-top: 1px solid var(--border-light, #dde3de);
}
/* compact table inside panel */
.order-invoice-aging__panel .order-table--compact th,
.order-invoice-aging__panel .order-table--compact td {
  font-size: 13px;
  padding: 7px 12px;
}
@media (max-width: 600px) {
  .order-invoice-aging__toggle {
    flex-wrap: wrap;
  }
  .order-invoice-aging__total {
    order: 2;
  }
  .order-invoice-aging__chevron {
    order: 3;
    margin-left: auto;
  }
}
/* ── end A/R Aging ──────────────────────────────────────────────────────── */

