/* =========================================================
   Freight ERP Density Layer
   Safe final override loaded last.

   Goal:
   - Keep existing CSS files untouched
   - Make 1366x768 at 100% feel closer to zoomed-out 75–85%
   - Reduce oversized app chrome, forms, cards, topnav, and quotation board
   - Avoid CSS zoom because it can break dropdowns, sticky panels, modals
========================================================= */


/* =========================================================
   1. Desktop / Laptop Density Tokens
========================================================= */

@media (min-width: 901px) and (max-width: 1400px) {
  :root {
    --topbar-height: 44px;

    --radius-sm: 6px;
    --radius-md: 9px;
    --radius-lg: 14px;
    --radius-xl: 18px;

    --space-3: 9px;
    --space-4: 12px;
    --space-5: 15px;
    --space-6: 18px;

    --shadow-md: 0 8px 22px rgba(15, 23, 42, 0.06);
    --shadow-lg: 0 14px 34px rgba(15, 23, 42, 0.10);
  }

  html {
    font-size: 14px;
  }

  body {
    line-height: 1.38;
  }
}


/* =========================================================
   2. App Shell / Page Spacing
========================================================= */

@media (min-width: 901px) and (max-width: 1400px) {
  .app-main {
    min-width: 0;
    max-width: 100%;
  }

  .page-content {
    max-width: 94%;
    margin: 0 auto;
    padding: 10px 12px !important;
    margin-top: 30px !important;
  }
  #my-shipments-board-root, #invoices-board-root, .page-header, .dashboard-action-pill, .dashboard-action-pill--info{
    margin-top: 20px !important;
  }
  .page-header {
    margin-bottom: 10px;
    gap: 10px;
  }

  .page-title {
    font-size: 1rem;
  }

  .page-section-title {
    font-size: 1rem;
  }

  .content-grid {
    gap: 12px;
  }

  .stats-grid {
    gap: 10px;
    margin-bottom: 12px;
  }
}


/* =========================================================
   3. Topbar / Top Navigation
========================================================= */

@media (min-width: 901px) and (max-width: 1400px) {
  .topbar {
    min-height: 44px !important;
    height: 44px;
    padding: 4px 23px !important;
    gap: 8px;
  }

  .topbar__left {
    gap: 8px;
  }

  .topbar__actions {
    gap: 7px;
  }

  .topbar__left .page-title {
    font-size: 0.86rem !important;
    font-weight: 800;
  }

  .topbar__left .muted {
    display: none;
  }

  .topnav-bar {
    gap: 1px !important;
    margin-left: 8px !important;
  }

  .tn-link,
  .tn-drop-btn {
    font-size: 0.7rem !important;
    padding: 4px 9px !important;
    min-height: 32px;
  }

  .tn-link--active,
  .tn-drop-btn--active {
    padding-bottom: 10px !important;
    border-bottom-width: 2px !important;
  }

  .tn-drop-menu {
    min-width: 150px !important;
    border-radius: 8px;
  }

  .tn-drop-item {
    padding: 7px 10px !important;
    font-size: 0.74rem !important;
  }

  .search-wrap {
    min-width: 160px;
  }

  .topbar input,
  .topbar select {
    min-height: 31px !important;
    height: 31px;
    padding: 0 9px !important;
    font-size: 0.72rem !important;
    border-radius: 8px !important;
  }

  .topbar .btn,
  .topbar button,
  .notification-bell,
  .profile-btn {
  min-height: 32px !important;
  height: 32px;
  padding: 4px 8px !important;
  font-size: 0.76rem !important;
  border-radius: 8px !important;
  display: grid;
  }

  .notification-badge {
    top: -4px;
    right: -4px;
    min-width: 16px;
    height: 16px;
    font-size: 0.62rem;
    padding: 0 5px;
  }

  .notification-panel,
  .profile-panel {
    top: calc(var(--topbar-height) + 5px);
  }
}


/* =========================================================
   4. Global Form / Button / Badge Density
========================================================= */

@media (min-width: 901px) and (max-width: 1400px) {
  input,
  select,
  textarea {
    padding: 9px 10px;
    min-height: 34px;
    border-radius: 9px;
    font-size: 0.78rem;
  }

  textarea {
    line-height: 1.35;
  }

  label {
    margin-bottom: 4px;
    font-size: 0.72rem;
  }

  .form-group {
    gap: 5px;
  }

  .detail-grid {
    gap: 12px;
  }

  .form-row {
    gap: 8px;
  }

  .btn {
    min-height: 32px;
    padding: 0 11px;
    border-radius: 9px;
    font-size: 0.76rem;
  }

  .btn--sm {
    min-height: 29px;
    padding: 0 9px;
    font-size: 0.7rem;
  }

  .badge,
  .status {
    min-height: 22px;
    padding: 0 7px;
    font-size: 0.66rem;
  }

  .muted {
    font-size: 0.76rem;
  }
}


/* =========================================================
   5. Generic Cards / Panels / Tables
========================================================= */

@media (min-width: 901px) and (max-width: 1400px) {
  .stat-card,
  .panel,
  .detail-card,
  .state-card {
    border-radius: 14px;
  }

  .stat-card {
    padding: 14px;
  }

  .stat-card__label {
    font-size: 0.68rem;
    margin-bottom: 6px;
  }

  .stat-card h3 {
    font-size: 1.35rem;
    margin-bottom: 4px;
  }

  .panel__header {
    padding: 12px 14px;
    gap: 8px;
  }

  .panel__body {
    padding: 12px 14px;
  }

  .detail-card {
    padding: 14px;
  }

  .state-card {
    padding: 20px 14px;
  }

  .data-table thead th {
    padding: 9px 12px;
    font-size: 0.68rem;
  }

  .data-table tbody td {
    padding: 10px 12px;
    font-size: 0.78rem;
  }

  .pagination {
    padding: 9px 12px;
  }

  .pagination__info {
    font-size: 0.76rem;
  }

  .pg-btn {
    min-width: 29px;
    min-height: 29px;
    padding: 0 8px;
    font-size: 0.74rem;
  }

  .pg-per-page {
    min-width: 82px;
    padding: 5px 8px;
    font-size: 0.72rem;
  }
}


/* =========================================================
   6. Quotation / CRM Board Container
========================================================= */

@media (min-width: 901px) and (max-width: 1400px) {
  .quote-board-panel {
    max-width: calc(100vw - 90px);
    margin: 0 auto;
    padding: 9px !important;
    border-radius: 16px !important;
    box-shadow: 0 6px 18px rgba(15, 23, 42, 0.035) !important;
  }

  .quote-board-hero {
    padding: 10px 12px !important;
    border-radius: 14px !important;
    margin-bottom: 9px !important;
    gap: 10px !important;
  }

  .quote-board-hero h2 {
    font-size: 0.96rem !important;
  }

  .quote-board-hero p {
    font-size: 0.72rem !important;
    line-height: 1.28 !important;
    margin-top: 3px !important;
  }

  .quote-board-actions {
    gap: 5px !important;
  }

  .quote-board-actions .btn {
    min-height: 28px;
    padding: 5px 8px;
    font-size: 0.68rem;
  }
}


/* =========================================================
   7. Quotation Stats / Tabs / Toolbar
========================================================= */

@media (min-width: 901px) and (max-width: 1400px) {
  .quote-board-stats {
    gap: 7px !important;
    margin-bottom: 9px !important;
  }

  .quote-stat-card {
    padding: 8px 9px !important;
    gap: 7px !important;
    border-radius: 12px !important;
  }

  .quote-stat-card > span {
    width: 28px !important;
    height: 28px !important;
    border-radius: 9px !important;
    font-size: 0.86rem !important;
  }

  .quote-stat-card strong {
    font-size: 0.9rem !important;
  }

  .quote-stat-card p {
    font-size: 0.64rem !important;
    margin-top: 2px !important;
  }

  .quote-board-tabs {
    gap: 5px !important;
    padding-bottom: 6px !important;
    margin-bottom: 7px !important;
  }

  .quote-board-tab {
    padding: 4px 7px !important;
    font-size: 0.68rem !important;
    gap: 5px !important;
  }

  .quote-board-tab em {
    min-width: 17px !important;
    padding: 2px 5px !important;
    font-size: 0.6rem !important;
  }

  .quote-board-toolbar {
    grid-template-columns: minmax(0, 1fr) 140px !important;
    gap: 7px !important;
    margin-bottom: 9px !important;
  }

  .quote-board-search {
    padding: 0 8px !important;
    border-radius: 10px !important;
  }

  .quote-board-search input {
    padding: 7px 0 !important;
    font-size: 0.72rem !important;
    min-height: 29px !important;
  }

  .quote-board-sort {
    min-height: 30px !important;
    padding: 0 8px !important;
    font-size: 0.72rem !important;
    border-radius: 10px !important;
  }
}


/* =========================================================
   8. Filter Rail
========================================================= */

@media (min-width: 901px) and (max-width: 1400px) {
  .quote-board-decision-layout {
    grid-template-columns: 175px minmax(0, 1fr) !important;
    gap: 9px !important;
  }

  .quote-board-filter-panel {
    padding: 8px !important;
    border-radius: 13px !important;
    margin-bottom: 9px !important;
  }

  .quote-board-filter-panel--rail {
    top: 56px !important;
    padding: 8px !important;
  }

  .quote-board-filter-panel__head {
    gap: 5px !important;
    margin-bottom: 7px !important;
  }

  .quote-board-filter-panel__head strong {
    font-size: 0.74rem !important;
  }

  .quote-board-filter-panel__head p {
    font-size: 0.62rem !important;
    line-height: 1.24 !important;
  }

  .quote-board-filters,
  .quote-board-filters--rail {
    gap: 6px !important;
  }

  .quote-board-filters .form-group label,
  .quote-board-filters--rail .form-group label {
    font-size: 0.6rem !important;
    margin-bottom: 2px !important;
  }

  .quote-board-filters input,
  .quote-board-filters select,
  .quote-board-filters--rail input,
  .quote-board-filters--rail select {
    min-height: 29px !important;
    padding: 6px 8px !important;
    font-size: 0.68rem !important;
    border-radius: 8px !important;
  }

  .quote-board-check-filter {
    min-height: 29px !important;
    font-size: 0.66rem !important;
  }

  .quote-board-advanced-filters {
    padding: 6px !important;
    border-radius: 10px !important;
  }

  .quote-board-advanced-filters summary {
    font-size: 0.64rem !important;
  }
}


/* =========================================================
   9. Quote / CRM Cards
========================================================= */

@media (min-width: 901px) and (max-width: 1400px) {
  .quote-card-grid,
  .crm-card-grid {
        grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)) !important;
        gap: 5px !important;
  }

  .quote-card {
    padding: 8px !important;
    border-radius: 14px !important;
    box-shadow: 0 4px 14px rgba(15, 23, 42, 0.035) !important;
  }

  .quote-card::before {
    height: 3px !important;
    opacity: 0.52 !important;
  }

  .quote-card:hover {
    transform: translateY(-1px);
    box-shadow: 0 8px 20px rgba(15, 23, 42, 0.065) !important;
  }

  .quote-card__top {
    gap: 6px !important;
  }

  .quote-card__id-row {
    gap: 4px !important;
  }

  .quote-card__id {
    font-size: 0.78rem !important;
    line-height: 1.15 !important;
  }

  .quote-card__customer {
    margin-top: 2px !important;
    font-size: 0.66rem !important;
    line-height: 1.2 !important;
  }

  .quote-card__amount {
    min-width: 76px !important;
  }

  .quote-card__amount strong {
    font-size: 0.82rem !important;
  }

  .quote-card__amount span {
    font-size: 0.6rem !important;
  }

  .quote-card__badges {
    gap: 4px !important;
    margin-top: 5px !important;
  }

  .quote-card__mini-badge,
  .quote-card .status,
  .quote-card .badge {
    min-height: 19px !important;
    padding: 0 6px !important;
    font-size: 0.58rem !important;
  }

  .quote-card__badges .status:not(:first-child),
  .quote-card__badges .badge:not(:first-child) {
    opacity: 0.84;
  }
}


/* =========================================================
   10. Card Body / Metadata / Actions
========================================================= */

@media (min-width: 901px) and (max-width: 1400px) {
  .quote-card__route {
    gap: 7px !important;
    padding: 7px !important;
    margin-top: 7px !important;
    min-height: 58px !important;
    max-height: 132px !important;
    border-radius: 11px !important;
  }

  .quote-card__mode {
    width: 25px !important;
    height: 25px !important;
    border-radius: 9px !important;
    font-size: 0.8rem !important;
  }

  .quote-card__route strong {
    font-size: 0.76rem !important;
    line-height: 1.15 !important;
  }

  .quote-card__route p {
    margin-top: 2px !important;
    font-size: 0.64rem !important;
    line-height: 1.2 !important;
  }

  .quote-card__meta {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 5px !important;
    margin-top: 6px !important;
  }

  .quote-card__meta div {
    padding: 5px 6px !important;
    border-radius: 9px !important;
  }

  .quote-card__meta span {
    font-size: 0.52rem !important;
    letter-spacing: 0.025em !important;
  }

  .quote-card__meta strong {
    margin-top: 1px !important;
    font-size: 0.66rem !important;
    line-height: 1.12 !important;
  }

  .quote-card__notice {
    margin-top: 6px !important;
    padding: 6px 7px !important;
    border-radius: 10px !important;
    font-size: 0.64rem !important;
    line-height: 1.24 !important;
  }

  .quote-card__actions {
    gap: 5px !important;
    margin-top: 7px !important;
  }

  .quote-card__actions .btn,
  .quote-card .btn {
    min-height: 26px !important;
    padding: 4px 7px !important;
    font-size: 0.64rem !important;
  }

  .quote-card .btn--primary {
    font-weight: 900;
  }
}


/* =========================================================
   11. CRM Text Clamp
========================================================= */

@media (min-width: 901px) and (max-width: 1400px) {
  .crm-board-layout {
    margin-top: 7px !important;
  }

  .crm-title-text {
    height: 17px !important;
    max-height: 17px !important;
    line-height: 1.15 !important;
  }

  .crm-title-description {
    height: 28px !important;
    max-height: 28px !important;
    line-height: 1.2 !important;
  }
}


/* =========================================================
   12. Footer / Pagination
========================================================= */

@media (min-width: 901px) and (max-width: 1400px) {
  .quote-board-footer {
    margin-top: 7px !important;
    padding-top: 7px !important;
    gap: 7px !important;
    font-size: 0.68rem !important;
  }

  .quote-board-pagination {
    gap: 4px !important;
  }

  .quote-board-pagination .btn,
  .quote-board-footer .btn {
    min-height: 26px !important;
    padding: 4px 7px !important;
    font-size: 0.64rem !important;
  }

  .quote-board-footer select {
    min-height: 28px !important;
    padding: 4px 7px !important;
    font-size: 0.68rem !important;
  }
}


/* =========================================================
   13. Empty States
========================================================= */

@media (min-width: 901px) and (max-width: 1400px) {
  .quote-board-empty {
    padding: 22px 12px !important;
    border-radius: 14px !important;
  }

  .quote-board-empty > div {
    font-size: 1.35rem !important;
  }

  .quote-board-empty h3 {
    font-size: 0.9rem !important;
    margin: 4px 0 2px !important;
  }

  .quote-board-empty p {
    font-size: 0.72rem !important;
  }
}


/* =========================================================
   14. Modal Safety
   Keep modals readable; do not over-shrink them.
========================================================= */

@media (min-width: 901px) and (max-width: 1400px) {
  .modal {
    max-width: 500px;
  }

  .modal__header,
  .modal__body,
  .modal__footer {
    padding: 14px 16px;
  }

  .eta-modal__card {
    padding: 18px;
    border-radius: 16px;
  }

  .toast {
    padding: 10px 12px;
    font-size: 0.78rem;
  }
}


/* =========================================================
   15. Preserve Mobile Behavior
   Below 901px, the existing responsive CSS remains in charge.
========================================================= */

@media (max-width: 900px) {
  html {
    font-size: 16px;
  }
}
/* =========================================================
   CRM Badge Hierarchy
   Fixes color/noise issue from marketplace CRM cards.

   Rule:
   - 1 strong primary badge
   - secondary badges are softer
   - age is plain text
   - unverified is neutral, not warning-orange
   - attention uses orange, not harsh red unless truly failed
========================================================= */

.crm-card-badges {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 7px;
}

.crm-badge {
  min-height: 20px;
  padding: 0 7px;
  border-radius: 999px;
  font-size: 0.62rem;
  line-height: 1;
  font-weight: 800;
  white-space: nowrap;
}

/* Main state badge: visible but not oversized */
.crm-badge--primary {
  box-shadow: 0 3px 8px rgba(15, 23, 42, 0.06);
}

/* Supporting badges should not fight the primary badge */
.crm-badge--soft {
  opacity: 0.72;
  filter: saturate(0.78);
}

/* Attention = action required, not failure */
.crm-badge--attention {
  background: var(--warning-soft) !important;
  color: var(--warning) !important;
  border: 1px solid color-mix(in srgb, var(--warning) 28%, transparent);
  animation: crm-attention-soft-pulse 1.8s ease-in-out infinite;
}

/* Unverified should feel neutral, not alarming */
.crm-badge--neutral {
  background: var(--surface-muted) !important;
  color: var(--text-faint) !important;
  border: 1px solid var(--border);
}

/* Verified remains a trust signal */
.crm-badge--verified {
  background: var(--success-soft) !important;
  color: var(--success) !important;
  border: 1px solid color-mix(in srgb, var(--success) 25%, transparent);
}

/* Age should not be a badge/color competitor */
.crm-card-age {
  color: var(--text-faint);
  font-size: 0.68rem;
  line-height: 1;
  font-weight: 700;
  white-space: nowrap;
}

@keyframes crm-attention-soft-pulse {
  0%,
  100% {
    box-shadow: 0 0 0 0 rgba(180, 83, 9, 0.20);
  }

  50% {
    box-shadow: 0 0 0 4px rgba(180, 83, 9, 0);
  }
}


/* =========================================================
   CRM Card Color Discipline
   Makes cards calmer and more professional.
========================================================= */

/* Avoid heavy red/pink cards unless the card itself is failed/lost */
.crm-card-grid .quote-card--danger,
.crm-card-grid article[style*="var(--danger-soft)"] {
  background:
    radial-gradient(circle at top left, rgba(254, 226, 226, 0.45), transparent 26%),
    var(--surface) !important;
}

/* Warning cards should feel like follow-up, not panic */
.crm-card-grid .quote-card--warning,
.crm-card-grid article[style*="var(--warning-soft)"] {
  background:
    radial-gradient(circle at top left, rgba(254, 243, 199, 0.55), transparent 26%),
    var(--surface) !important;
}

/* Success/converted should remain calm */
.crm-card-grid .quote-card--success,
.crm-card-grid article[style*="var(--success-soft)"] {
  background:
    radial-gradient(circle at top left, rgba(220, 252, 231, 0.52), transparent 26%),
    var(--surface) !important;
}


/* =========================================================
   CRM Role-Specific Psychology
========================================================= */

/* Broker: make opportunity action clearer */
.crm-card-grid a[href*="/quotations/new"].btn--ghost {
  border-color: color-mix(in srgb, var(--primary) 35%, var(--border));
  color: var(--primary);
  background: rgba(219, 234, 254, 0.38);
  font-weight: 900;
}

.crm-card-grid a[href*="/quotations/new"].btn--ghost:hover {
  background: var(--primary);
  color: var(--text-inverse);
}

/* Customer: selected/quote progress actions should feel reassuring */
.crm-card-grid a[href*="/quotations/"].btn--ghost,
.crm-card-grid a[href*="/crm/"].btn--ghost {
  font-weight: 800;
}

/* Admin/Ops: manage action stays secondary */
.crm-card-grid a.btn--ghost[href*="/crm/"] {
  border-color: var(--border);
}


/* =========================================================
   1366x768 CRM Badge Compactness
========================================================= */

@media (min-width: 901px) and (max-width: 1400px) {
  .crm-card-badges {
    gap: 4px;
    margin-bottom: 6px;
  }

  .crm-badge {
    min-height: 18px;
    padding: 0 6px;
    font-size: 0.56rem;
  }

  .crm-card-age {
    font-size: 0.62rem;
  }
}
/* =========================================================
   CRM Clickable Cards
   Whole card opens detail, while inner buttons/links still work.
========================================================= */

.crm-clickable-card {
  cursor: pointer;
  transition:
    transform 0.14s ease,
    box-shadow 0.14s ease,
    border-color 0.14s ease;
}

.crm-clickable-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.075) !important;
  border-color: color-mix(in srgb, var(--primary) 30%, var(--border)) !important;
}

.crm-clickable-card:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 3px;
}

.crm-clickable-card a,
.crm-clickable-card button,
.crm-clickable-card input,
.crm-clickable-card select,
.crm-clickable-card textarea,
.crm-clickable-card summary {
  cursor: pointer;
}

/* =========================================================
   crm-detail-density.css
   CRM Inquiry Detail View — Component & Density Layer

   Load order: after erp-density.css and quotations-board.css
   Scope: detail view components only — broker decision banner,
          collapsible sections, fast facts grid, clarification
          cards, and 1366×768 density overrides.

   Does not modify board cards, topbar, or modal behavior.
========================================================= */


/* =========================================================
   1. Collapsible Section — <details> / <summary>
   Native element; gets zero treatment from existing CSS.
========================================================= */

details.crm-collapsible {
  border: 1px solid var(--border);
  border-radius: var(--radius-md, 12px);
  background: var(--surface);
  overflow: hidden;
  transition: box-shadow 0.14s ease, border-color 0.14s ease;
}

details.crm-collapsible[open] {
  box-shadow: 0 6px 18px rgba(15, 23, 42, 0.05);
}

details.crm-collapsible > summary {
  padding: 13px 16px;
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  user-select: none;
  font-weight: 800;
  font-size: 0.9rem;
  line-height: 1.2;
  color: var(--text);
  transition: background 0.12s ease;
}

/* Remove default WebKit triangle */
details.crm-collapsible > summary::-webkit-details-marker {
  display: none;
}

details.crm-collapsible > summary::marker {
  content: "";
}

details.crm-collapsible > summary:hover {
  background: var(--surface-soft);
}

details.crm-collapsible > summary:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: -2px;
}

/* Toggle chevron — CSS only, no JS */
.crm-collapsible__toggle-icon {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--surface-soft);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.6rem;
  color: var(--text-muted);
  transition: transform 0.18s ease, background 0.12s ease;
}

details.crm-collapsible[open] .crm-collapsible__toggle-icon {
  transform: rotate(180deg);
  background: var(--primary-soft);
  border-color: color-mix(in srgb, var(--primary) 30%, var(--border));
  color: var(--primary);
}

/* Summary left cluster */
.crm-collapsible__summary-left {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.crm-collapsible__summary-left strong {
  font-size: 0.9rem;
  font-weight: 800;
  line-height: 1.2;
}

.crm-collapsible__summary-subtitle {
  font-size: 0.74rem;
  font-weight: 600;
  color: var(--text-muted);
  line-height: 1.2;
}

/* Summary right cluster (badges + toggle) */
.crm-collapsible__summary-right {
  display: flex;
  align-items: center;
  gap: 7px;
  flex-shrink: 0;
}

/* Body */
.crm-collapsible__body {
  padding: 14px 16px;
  border-top: 1px solid var(--border);

  /* Animate open/close without JS */
  animation: crm-collapsible-reveal 0.18s ease forwards;
}

@keyframes crm-collapsible-reveal {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}


/* =========================================================
   2. Broker Decision Banner
   First thing a broker sees. Must be visually dominant
   but not aggressive. Contains the primary CTAs.
========================================================= */

.crm-decision-banner {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  flex-wrap: wrap;
  padding: 15px 18px;
  border-radius: var(--radius-md, 12px);
  border: 1px solid var(--border);
  border-left-width: 4px;
  background: var(--surface-soft);
  margin-bottom: 14px;
  transition: box-shadow 0.14s ease;
}

.crm-decision-banner:hover {
  box-shadow: 0 6px 20px rgba(15, 23, 42, 0.06);
}

/* State variants — set border-left-color via modifier */
.crm-decision-banner--ready {
  border-left-color: var(--success);
  background:
    radial-gradient(circle at left center, color-mix(in srgb, var(--success) 6%, transparent), transparent 60%),
    var(--surface-soft);
}

.crm-decision-banner--usable {
  border-left-color: var(--primary);
  background:
    radial-gradient(circle at left center, var(--primary-soft), transparent 60%),
    var(--surface-soft);
}

.crm-decision-banner--needs-info {
  border-left-color: var(--warning, #f59e0b);
  background:
    radial-gradient(circle at left center, color-mix(in srgb, var(--warning, #f59e0b) 8%, transparent), transparent 60%),
    var(--surface-soft);
}

.crm-decision-banner--attention {
  border-left-color: var(--danger);
  background:
    radial-gradient(circle at left center, var(--danger-soft), transparent 60%),
    var(--surface-soft);
  animation: crm-attention-border-pulse 2.2s ease-in-out infinite;
}

@keyframes crm-attention-border-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(220, 38, 38, 0.08); }
  50%       { box-shadow: 0 0 0 5px rgba(220, 38, 38, 0); }
}

.crm-decision-banner__icon {
  font-size: 1.45rem;
  line-height: 1;
  padding-top: 1px;
  flex-shrink: 0;
}

.crm-decision-banner__body {
  flex: 1;
  min-width: 180px;
}

.crm-decision-banner__headline {
  font-size: 0.98rem;
  font-weight: 900;
  line-height: 1.2;
  color: var(--text);
  margin: 0 0 4px;
}

.crm-decision-banner__subtext {
  font-size: 0.84rem;
  color: var(--text-muted);
  line-height: 1.5;
  margin: 0;
}

/* Missing info tag cluster */
.crm-decision-banner__missing {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  margin-top: 9px;
}

/* CTAs right-aligned */
.crm-decision-banner__actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  flex-shrink: 0;
}


/* =========================================================
   3. Fast Facts Grid
   The 6-cell shipment summary row.
   Prevents awkward wrapping at mid-widths.
========================================================= */

.crm-fast-facts {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
  padding: 14px 20px;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

/* Clamp to 3 cols before it gets too narrow to be readable */
@media (max-width: 1100px) {
  .crm-fast-facts {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 700px) {
  .crm-fast-facts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.crm-fast-fact {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md, 10px);
  background: var(--surface);
  min-width: 0;
  transition: border-color 0.12s ease, background 0.12s ease;
}

.crm-fast-fact:hover {
  border-color: color-mix(in srgb, var(--primary) 25%, var(--border));
  background: var(--surface-soft);
}

.crm-fast-fact__label {
  font-size: 0.66rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-muted);
  line-height: 1;
}

.crm-fast-fact__value {
  font-size: 0.86rem;
  font-weight: 800;
  color: var(--text);
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Dimmed when value is a "needs clarification" placeholder */
.crm-fast-fact__value--missing {
  color: var(--text-muted);
  font-weight: 600;
  font-style: italic;
}


/* =========================================================
   4. Clarification Cards
   Pending state should draw attention without panic.
   Responded state should feel resolved and calm.
========================================================= */

.crm-clarification-card {
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md, 12px);
  background: var(--surface-soft);
  transition: border-color 0.12s ease;
}

.crm-clarification-card--pending {
  background: var(--warning-soft);
  border-color: color-mix(in srgb, var(--warning, #f59e0b) 30%, var(--border));
  border-left: 3px solid var(--warning, #f59e0b);
}

.crm-clarification-card--responded {
  background: var(--surface-soft);
  border-left: 3px solid var(--success);
}

.crm-clarification-card__header {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 8px;
}

.crm-clarification-card__type {
  font-weight: 800;
  font-size: 0.84rem;
  line-height: 1.2;
  text-transform: capitalize;
}

.crm-clarification-card__message {
  font-size: 0.84rem;
  line-height: 1.55;
  color: var(--text);
  margin: 0;
}

/* Customer response inset */
.crm-clarification-card__response {
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  background: var(--surface);
  border: 1px solid var(--border);
}

.crm-clarification-card__response-label {
  font-size: 0.62rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-muted);
  margin-bottom: 4px;
  display: block;
}

.crm-clarification-card__response-text {
  font-size: 0.84rem;
  line-height: 1.5;
  margin: 0;
}

/* Customer response form */
.crm-clarification-response-form {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}


/* =========================================================
   5. Marketplace Progress Section
   Metrics grid inside collapsible or visible panel.
========================================================= */

.crm-progress-metrics {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
  margin-top: 12px;
}

.crm-progress-metric {
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--surface-soft);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.crm-progress-metric__label {
  font-size: 0.64rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-muted);
  line-height: 1;
}

.crm-progress-metric__value {
  font-size: 1.1rem;
  font-weight: 800;
  line-height: 1.15;
  color: var(--text);
}

/* Attention alert inside progress section */
.crm-progress-alert {
  margin-bottom: 12px;
  padding: 11px 13px;
  border: 1px solid var(--danger);
  border-radius: 12px;
  background: var(--danger-soft);
  font-size: 0.86rem;
  line-height: 1.5;
  color: var(--danger);
}

.crm-progress-alert strong {
  display: block;
  margin-bottom: 3px;
}

/* Guidance text below metrics */
.crm-progress-guidance {
  margin-top: 12px;
  font-size: 0.8rem;
  color: var(--text-muted);
  line-height: 1.5;
}


/* =========================================================
   6. Request Quality Bar
   Used in admin view inside the detail grid.
========================================================= */

.crm-quality-bar-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 10px 0;
}

.crm-quality-bar-track {
  flex: 1;
  height: 8px;
  border-radius: 999px;
  background: var(--border);
  overflow: hidden;
}

.crm-quality-bar-fill {
  height: 100%;
  border-radius: 999px;
  background: var(--primary);
  transition: width 0.35s ease;
}

.crm-quality-bar-fill--high {
  background: var(--success);
}

.crm-quality-bar-fill--mid {
  background: var(--primary);
}

.crm-quality-bar-fill--low {
  background: var(--warning, #f59e0b);
}

.crm-quality-missing {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  margin-top: 8px;
}


/* =========================================================
   7. Customer Trust Card
   Verification badge + contact reveal logic.
========================================================= */

.crm-trust-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 8px;
  margin-bottom: 10px;
  font-size: 0.84rem;
}

.crm-trust-grid__cell {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.crm-trust-grid__cell-label {
  font-size: 0.7rem;
  color: var(--text-muted);
  font-weight: 700;
}

.crm-trust-grid__cell-value {
  font-weight: 800;
  font-size: 0.86rem;
  line-height: 1.2;
}

.crm-contact-hidden {
  font-size: 0.8rem;
  color: var(--text-muted);
  font-style: italic;
  margin: 0;
  line-height: 1.45;
}


/* =========================================================
   8. Original Request Description Box
   Readable evidence block for the customer's raw input.
========================================================= */

.crm-inquiry-description {
  margin-top: 8px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius-md, 10px);
  background: var(--surface-soft);
  max-height: 260px;
  overflow: auto;
  white-space: pre-wrap;
  line-height: 1.6;
  font-size: 0.88rem;
  color: var(--text);

  /* Subtle inset feel */
  box-shadow: inset 0 2px 6px rgba(15, 23, 42, 0.04);
}

.crm-inquiry-description::-webkit-scrollbar {
  width: 5px;
}

.crm-inquiry-description::-webkit-scrollbar-track {
  background: transparent;
}

.crm-inquiry-description::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 999px;
}

.crm-inquiry-description--empty {
  color: var(--text-muted);
  font-style: italic;
}

/* Signal badges row above description */
.crm-description-signals {
  display: flex;
  gap: 7px;
  flex-wrap: wrap;
  margin-bottom: 8px;
  align-items: center;
}


/* =========================================================
   9. Hero Block
   Shared across all roles. Handles the gradient panel top.
========================================================= */

.crm-detail-hero {
  padding: 18px 20px;
  border-bottom: 1px solid var(--border);
}

.crm-detail-hero__meta-row {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.crm-detail-hero__title {
  margin: 0;
  font-size: 1.22rem;
  line-height: 1.3;
  letter-spacing: -0.02em;
}

.crm-detail-hero__subtitle {
  margin: 8px 0 0;
  line-height: 1.5;
  max-width: 840px;
  color: var(--text-muted);
  font-size: 0.88rem;
}


/* =========================================================
   10. Section Wrapper Padding Helper
   Consistent inner padding used by all role sections.
========================================================= */

.crm-detail-section {
  padding: 0 20px 16px;
}

.crm-detail-section--first {
  padding-top: 16px;
}

.crm-detail-section--last {
  padding-bottom: 20px;
}


/* =========================================================
   11. 1366×768 Density Overrides
   Mirrors the approach in erp-density.css.
   Scoped to detail view classes only.
========================================================= */

@media (min-width: 901px) and (max-width: 1400px) {

  /* Hero */
  .crm-detail-hero {
    padding: 13px 16px;
  }

  .crm-detail-hero__title {
    font-size: 1.05rem;
  }

  .crm-detail-hero__subtitle {
    font-size: 0.8rem;
    margin-top: 5px;
  }

  .crm-detail-hero__meta-row {
    gap: 6px;
    margin-bottom: 6px;
  }

  /* Decision banner */
  .crm-decision-banner {
    padding: 11px 14px;
    gap: 11px;
    margin-bottom: 11px;
    border-radius: var(--radius-md, 10px);
  }

  .crm-decision-banner__icon {
    font-size: 1.2rem;
  }

  .crm-decision-banner__headline {
    font-size: 0.88rem;
  }

  .crm-decision-banner__subtext {
    font-size: 0.76rem;
  }

  .crm-decision-banner__missing {
    margin-top: 7px;
    gap: 4px;
  }

  .crm-decision-banner__actions {
    gap: 6px;
  }

  /* Fast facts */
  .crm-fast-facts {
    padding: 10px 16px;
    gap: 7px;
    /* Force 3 cols on dense screens — 6 gets too narrow */
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .crm-fast-fact {
    padding: 8px 10px;
    gap: 3px;
    border-radius: 9px;
  }

  .crm-fast-fact__label {
    font-size: 0.58rem;
    letter-spacing: 0.03em;
  }

  .crm-fast-fact__value {
    font-size: 0.78rem;
  }

  /* Collapsible */
  details.crm-collapsible > summary {
    padding: 10px 13px;
    font-size: 0.82rem;
  }

  .crm-collapsible__body {
    padding: 11px 13px;
  }

  .crm-collapsible__summary-left strong {
    font-size: 0.82rem;
  }

  .crm-collapsible__summary-subtitle {
    font-size: 0.68rem;
  }

  .crm-collapsible__toggle-icon {
    width: 16px;
    height: 16px;
    font-size: 0.55rem;
  }

  /* Clarification cards */
  .crm-clarification-card {
    padding: 10px 12px;
    border-radius: 10px;
  }

  .crm-clarification-card__type {
    font-size: 0.76rem;
  }

  .crm-clarification-card__message {
    font-size: 0.76rem;
  }

  .crm-clarification-card__response {
    padding: 8px 10px;
    border-radius: 8px;
    margin-top: 8px;
  }

  .crm-clarification-card__response-text {
    font-size: 0.76rem;
  }

  /* Marketplace metrics */
  .crm-progress-metrics {
    gap: 7px;
    margin-top: 9px;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  }

  .crm-progress-metric {
    padding: 8px 10px;
    border-radius: 8px;
    gap: 3px;
  }

  .crm-progress-metric__label {
    font-size: 0.56rem;
  }

  .crm-progress-metric__value {
    font-size: 0.96rem;
  }

  .crm-progress-alert {
    padding: 9px 11px;
    font-size: 0.78rem;
    border-radius: 10px;
    margin-bottom: 9px;
  }

  .crm-progress-guidance {
    font-size: 0.72rem;
    margin-top: 9px;
  }

  /* Quality bar */
  .crm-quality-bar-track {
    height: 7px;
  }

  .crm-quality-missing {
    gap: 4px;
    margin-top: 6px;
  }

  /* Trust grid */
  .crm-trust-grid {
    gap: 6px;
    font-size: 0.78rem;
  }

  .crm-trust-grid__cell-label {
    font-size: 0.62rem;
  }

  .crm-trust-grid__cell-value {
    font-size: 0.78rem;
  }

  /* Description box */
  .crm-inquiry-description {
    padding: 11px 12px;
    font-size: 0.8rem;
    max-height: 210px;
    border-radius: 9px;
    margin-top: 6px;
  }

  /* Section padding */
  .crm-detail-section {
    padding: 0 16px 12px;
  }

  .crm-detail-section--first {
    padding-top: 12px;
  }

  .crm-detail-section--last {
    padding-bottom: 16px;
  }
}


/* =========================================================
   12. Preserve Mobile Behavior
   Below 901px the existing responsive CSS remains in charge.
   Only restore fast-facts to 2-col; everything else is natural.
========================================================= */

@media (max-width: 900px) {
  .crm-fast-facts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 12px 14px;
  }

  .crm-decision-banner {
    flex-direction: column;
    gap: 10px;
  }

  .crm-decision-banner__actions {
    width: 100%;
    justify-content: flex-start;
  }

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

  .crm-detail-hero {
    padding: 14px 16px;
  }

  .crm-detail-section {
    padding: 0 14px 12px;
  }
}

@media (max-width: 560px) {
  .crm-fast-facts {
    grid-template-columns: 1fr;
  }

  .crm-progress-metrics {
    grid-template-columns: 1fr;
  }

  .crm-trust-grid {
    grid-template-columns: 1fr;
  }
}
/* =========================================================
   Floating scroll CTA
   Used by data-scroll-to="#quote-shipment-details"
========================================================= */

.quote-scroll-fab {
  position: fixed;
  left: 50%;
  bottom: 22px;
  transform: translateX(-50%);
  z-index: 9999;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  min-height: 42px;
  padding: 0 16px;

  border: 1px solid color-mix(in srgb, var(--primary) 42%, var(--border));
  border-radius: 999px;

  background:
    linear-gradient(135deg, var(--primary), color-mix(in srgb, var(--primary) 72%, #111827));
  color: #fff;

  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.01em;

  box-shadow:
    0 12px 30px rgba(15, 23, 42, 0.22),
    0 0 0 4px rgba(37, 99, 235, 0.08);

  cursor: pointer;
  transition:
    transform 0.16s ease,
    box-shadow 0.16s ease,
    opacity 0.16s ease;
}

.quote-scroll-fab:hover {
  transform: translateX(-50%) translateY(-2px);
  box-shadow:
    0 16px 38px rgba(15, 23, 42, 0.28),
    0 0 0 5px rgba(37, 99, 235, 0.12);
}

.quote-scroll-fab:active {
  transform: translateX(-50%) translateY(0);
}

.quote-scroll-fab strong {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;

  background: rgba(255, 255, 255, 0.18);
  color: #fff;

  font-size: 0.88rem;
  line-height: 1;
}

#quote-shipment-details {
  scroll-margin-top: 130px;
}

.scroll-focus-pulse {
  animation: scrollFocusPulse 1.35s ease-out 1;
}

@keyframes scrollFocusPulse {
  0% {
    box-shadow: 0 0 0 0 rgba(37, 99, 235, 0.32);
    border-color: var(--primary);
    transform: translateY(-1px);
  }

  45% {
    box-shadow: 0 0 0 7px rgba(37, 99, 235, 0.12);
    border-color: var(--primary);
  }

  100% {
    box-shadow: var(--shadow-sm);
    transform: translateY(0);
  }
}

@media (max-width: 700px) {
  .quote-scroll-fab {
    bottom: 16px;
    min-height: 40px;
    padding: 0 14px;
    font-size: 0.74rem;
  }
}
.quote-scroll-fab--hidden {
  opacity: 0;
  pointer-events: none;
  transform: translateX(-50%) translateY(12px);
}
html {
  scroll-behavior: smooth;
}
/* =========================================================
   Quote cards: match CRM card alignment
========================================================= */

.quote-card--crm-match {
  display: flex;
  flex-direction: column;
}

/* Same structure as CRM cards: facts are the alignment anchor */
.quote-card--crm-match .quote-fast-facts {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  display: grid;
  gap: 10px;
  padding: 14px 20px;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

/* Money always appears in the first stat column */
.quote-card--crm-match .crm-fast-fact:first-child .crm-fast-fact__value {
  font-weight: 900;
  color: var(--text);
  font-size: 0.76rem;
}

/* Prevent long customer/broker names from breaking alignment */
.quote-card--crm-match .crm-fast-fact__value {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Footer stays at the bottom so cards line up better */
.quote-card--crm-match > div:last-child {
  margin-top: auto;
}

@media (max-width: 700px) {
  .quote-card--crm-match .crm-fast-facts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.quote-compare-check {
  position: relative;
  z-index: 4;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 8px;
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--text-soft);
  cursor: pointer;
}

.quote-compare-check input {
  width: 15px;
  height: 15px;
  accent-color: var(--primary);
}

.quote-compare-tray {
    position: fixed;
    bottom: 14px;
    z-index: 80;
    margin: 12px auto 0;
    max-width: 520px;
    padding: 10px 12px;
    border: 1px solid var(--primary);
    border-radius: 999px;
    background: var(--surface);
    box-shadow: 0 14px 32px rgba(15, 23, 42, 0.18);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    left: 35%;
    width: 75%;
}

.quote-compare-box {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 10000;
  width: min(360px, calc(100vw - 28px));
  border: 1px solid var(--border);
  border-radius: 18px;
  background: var(--surface);
  box-shadow: 0 20px 54px rgba(15, 23, 42, 0.24);
  overflow: hidden;
}

.quote-compare-box__head {
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

#quote-compare-result {
  padding: 14px;
}

.quote-compare-result-card {
  display: grid;
  gap: 6px;
  padding: 12px;
  border: 1px solid var(--success);
  border-radius: 14px;
  background: var(--success-soft);
}

.quote-compare-result-card h3,
.quote-compare-result-card p {
  margin: 0;
}
/* =========================================================
   Quote Compare Assistant
   Customer-side quote decision helper
========================================================= */

.quote-compare-check {
  position: relative;
  z-index: 4;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 8px;
  font-size: 0.72rem;
  font-weight: 800;
  color: var(--text-soft);
  cursor: pointer;
}

.quote-compare-check input {
  width: 15px;
  height: 15px;
  accent-color: var(--primary);
}


.quote-compare-box {
  position: fixed;
  right: 18px;
  bottom: 18px;
  z-index: 10000;
  width: min(430px, calc(100vw - 28px));
  max-height: min(680px, calc(100vh - 36px));
  overflow: auto;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: var(--surface);
  box-shadow: 0 20px 54px rgba(15, 23, 42, 0.24);
}

.quote-compare-box__head {
  position: sticky;
  top: 0;
  z-index: 2;
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.quote-compare-box__head p {
  margin: 2px 0 0;
  font-size: 0.78rem;
}

#quote-compare-result {
  padding: 14px;
  display: grid;
  gap: 12px;
}

.quote-compare-tabs {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}

.quote-compare-tab {
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--surface-soft);
  color: var(--text-soft);
  font-size: 0.68rem;
  font-weight: 900;
  padding: 7px 6px;
  cursor: pointer;
}

.quote-compare-tab--active {
  background: var(--primary);
  border-color: var(--primary);
  color: var(--text-inverse);
}

.quote-compare-rules {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.quote-compare-rules label {
  display: grid;
  gap: 5px;
  font-size: 0.74rem;
  font-weight: 800;
  color: var(--text-soft);
}

.quote-compare-checkline {
  display: flex !important;
  align-items: center;
  gap: 8px !important;
}

.quote-compare-result-card {
  display: grid;
  gap: 7px;
  padding: 12px;
  border: 1px solid var(--success);
  border-radius: 14px;
  background: var(--success-soft);
}

.quote-compare-result-card h3,
.quote-compare-result-card p {
  margin: 0;
}

.quote-compare-result-card p {
  font-size: 0.82rem;
  line-height: 1.45;
}

.quote-compare-table {
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
}

.quote-compare-row {
  display: grid;
  grid-template-columns: 0.8fr 1fr 1fr 0.5fr;
  gap: 8px;
  padding: 8px 10px;
  font-size: 0.74rem;
  border-bottom: 1px solid var(--border);
}

.quote-compare-row:last-child {
  border-bottom: 0;
}

.quote-compare-row--head {
  background: var(--surface-soft);
  color: var(--text-faint);
  font-size: 0.62rem;
  font-weight: 900;
  text-transform: uppercase;
}

.quote-compare-row--best {
  background: var(--success-soft);
  font-weight: 900;
}

.quote-compare-note {
  margin: 0;
  font-size: 0.78rem;
  color: var(--text-soft);
}

@media (max-width: 700px) {
  .quote-compare-tray {
    border-radius: 16px;
    flex-direction: column;
    align-items: stretch;
  }

  .quote-compare-box {
    left: 10px;
    right: 10px;
    width: auto;
  }

  .quote-compare-tabs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
/* =========================================================
   Quote compare preview refinements
========================================================= */

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

.quote-compare-row__quote {
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--primary);
  font: inherit;
  font-weight: 900;
  text-align: left;
  cursor: pointer;
}

.quote-compare-row__quote:hover {
  text-decoration: underline;
}

.quote-compare-back {
  width: fit-content;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--primary);
  font-size: 0.78rem;
  font-weight: 900;
  cursor: pointer;
}

.quote-compare-back:hover {
  text-decoration: underline;
}

.quote-compare-result-card--detail {
  border-color: var(--primary);
  background:
    radial-gradient(circle at top left, var(--primary-soft), transparent 34%),
    var(--surface);
}

.quote-compare-mini-list {
  display: grid;
  gap: 7px;
  margin: 8px 0;
}

.quote-compare-mini-list div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 7px 0;
  border-bottom: 1px solid var(--border);
}

.quote-compare-mini-list div:last-child {
  border-bottom: 0;
}

.quote-compare-mini-list span {
  color: var(--text-faint);
  font-size: 0.72rem;
  font-weight: 800;
}

.quote-compare-mini-list strong {
  font-size: 0.78rem;
  text-align: right;
}
.dashboard-action-pill summary::-webkit-details-marker {
  display: none;
}

.dashboard-action-pill[open] {
  border-color: var(--primary);
}

.dashboard-action-pill--danger {
  border-color: color-mix(in srgb, var(--danger) 45%, var(--border)) !important;
}

.dashboard-action-pill--warning {
  border-color: color-mix(in srgb, var(--warning) 45%, var(--border)) !important;
}

.dashboard-action-pill--success {
  border-color: color-mix(in srgb, var(--success) 45%, var(--border)) !important;
}

@media (max-width: 760px) {
  section[style*="grid-template-columns:minmax(0, 1fr) auto"] {
    grid-template-columns: 1fr !important;
  }
}
/* =========================================================
   Payment Reminder Footer Notice
   Same location as system update notice, payment-focused
========================================================= */

.payment-reminder-footer-notice {
  position: fixed;
  left: 50%;
  bottom: 18px;
  transform: translateX(-50%);
  z-index: 10020;

  width: min(720px, calc(100vw - 28px));
  padding: 12px 14px;

  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;

  border: 1px solid var(--border);
  border-left: 5px solid var(--warning);
  border-radius: 18px;

  background: var(--surface);
  box-shadow: 0 18px 46px rgba(15, 23, 42, 0.2);
}

.payment-reminder-footer-notice__icon {
  width: 38px;
  height: 38px;
  border-radius: 14px;

  display: flex;
  align-items: center;
  justify-content: center;

  background: var(--warning-soft);
  font-size: 1.25rem;
}

.payment-reminder-footer-notice__content {
  min-width: 0;
}

.payment-reminder-footer-notice__content strong {
  display: block;
  font-size: 0.88rem;
  font-weight: 950;
  color: var(--text);
}

.payment-reminder-footer-notice__content span {
  display: block;
  margin-top: 2px;
  font-size: 0.8rem;
  line-height: 1.35;
  color: var(--text-soft);
}

.payment-reminder-footer-notice__actions {
  display: flex;
  gap: 7px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.payment-reminder-footer-notice--danger {
  border-left-color: var(--danger);
}

.payment-reminder-footer-notice--danger .payment-reminder-footer-notice__icon {
  background: var(--danger-soft);
}

.payment-reminder-footer-notice--success {
  border-left-color: var(--success);
}

.payment-reminder-footer-notice--success .payment-reminder-footer-notice__icon {
  background: var(--success-soft);
}

@media (max-width: 720px) {
  .payment-reminder-footer-notice {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .payment-reminder-footer-notice__actions {
    grid-column: 1 / -1;
    justify-content: stretch;
  }

  .payment-reminder-footer-notice__actions .btn {
    flex: 1;
    justify-content: center;
  }
}
.customer-request-v3-modal {
  backdrop-filter: blur(3px);
}

/* =========================================================
   Customer crm request styles
========================================================= */
.customer-request-v3-card {
  width: 800px !important;
  min-width: 1200px;
  /* width: min(840px, 94vw) !important; */
  max-height: 94vh !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 18px !important;
  box-shadow: 0 24px 70px rgba(15, 23, 42, 0.28) !important;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr) auto;
}

.customer-request-v3-header {
  padding: 16px 20px 12px;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
}

.customer-request-v3-header h3 {
  margin: 0 0 4px;
  font-size: 1.05rem;
  font-weight: 850;
  color: var(--text);
}

.customer-request-v3-header p {
  margin: 0;
  font-size: 0.85rem;
}

.customer-request-v3-progress-wrap {
  padding: 11px 20px 13px;
  border-bottom: 1px solid var(--border);
  background: var(--surface-soft);
}

.customer-request-v3-progress-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 7px;
  font-size: 0.78rem;
  font-weight: 800;
  color: var(--text-muted);
}

.customer-request-v3-progress-track {
  height: 8px;
  border-radius: 999px;
  background: rgba(148, 163, 184, 0.28);
  overflow: hidden;
}

.customer-request-v3-progress-bar {
  height: 100%;
  width: 8%;
  border-radius: 999px;
  transition: width 0.28s ease, background 0.28s ease;
}

.customer-request-v3-progress-bar--early {
  background: linear-gradient(90deg, #2563eb, #38bdf8);
}

.customer-request-v3-progress-bar--middle {
  background: linear-gradient(90deg, #7c3aed, #2563eb);
}

.customer-request-v3-progress-bar--late {
  background: linear-gradient(90deg, #f59e0b, #22c55e);
}

.customer-request-v3-progress-bar--done {
  background: linear-gradient(90deg, #16a34a, #22c55e);
}

.customer-request-v3-main {
  overflow: auto;
  padding: 16px 20px;
  background: var(--surface);
}

.customer-request-v3-current-card,
.customer-request-v3-preview-head {
  padding: 15px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background:
    radial-gradient(circle at top left, rgba(37, 99, 235, 0.09), transparent 32%),
    var(--surface-soft);
}

.customer-request-v3-current-kicker {
  display: inline-flex;
  margin-bottom: 8px;
  padding: 4px 8px;
  border-radius: 999px;
  background: var(--primary-soft);
  color: var(--primary);
  font-size: 0.72rem;
  font-weight: 850;
}

.customer-request-v3-current-card h4,
.customer-request-v3-preview-head h4 {
  margin: 0;
  color: var(--text);
  font-size: 1.03rem;
  line-height: 1.32;
  font-weight: 850;
}

.customer-request-v3-current-card p,
.customer-request-v3-preview-head p {
  margin: 7px 0 0;
  color: var(--text-muted);
  font-size: 0.86rem;
  line-height: 1.45;
}

.customer-request-v3-current-footer {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px dashed var(--border);
  color: var(--text-muted);
  font-size: 0.76rem;
  font-weight: 800;
}

.customer-request-v3-required {
  color: #dc2626;
}

.customer-request-v3-optional {
  color: #b45309;
}

.customer-request-v3-answer-wrap {
  margin-top: 12px;
}

.customer-request-v3-field {
  width: 100%;
  min-height: 42px;
  border: 1px solid var(--border);
  border-radius: 13px;
  padding: 10px 12px;
  font-size: 0.9rem;
  background: var(--surface);
  color: var(--text);
  outline: none;
}

.customer-request-v3-field:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}

textarea.customer-request-v3-field {
  resize: vertical;
  min-height: 90px;
}

.customer-request-v3-choice-wrap {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 10px;
}

.customer-request-v3-choice {
  min-height: 44px;
  border: 2px solid var(--border);
  border-radius: 13px;
  background: var(--surface);
  color: var(--text);
  font-weight: 800;
  cursor: pointer;
}

.customer-request-v3-choice:hover,
.customer-request-v3-choice--selected {
  border-color: var(--primary);
  background: var(--primary-soft);
  color: var(--primary);
}

.customer-request-v3-voice-wrap {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px dashed var(--border);
}

.customer-request-v3-voice-status {
  width: 100%;
  font-size: 0.8rem;
}

.customer-request-v3-summary {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
}

.customer-request-v3-summary-item {
  min-height: auto;
  padding: 11px 12px;
  border: 1px solid var(--border);
  border-radius: 13px;
  background: var(--surface-soft);
}

.customer-request-v3-summary-item--wide {
  grid-column: 2 / -1;
}

.customer-request-v3-summary-item span {
  display: block;
  font-size: 0.72rem;
  margin-bottom: 4px;
}

.customer-request-v3-summary-item strong {
  display: block;
  font-size: 0.88rem;
  color: var(--text);
  line-height: 1.35;
  overflow-wrap: anywhere;
  word-break: normal;
}

.customer-request-v3-warning,
.customer-request-v3-note,
.customer-request-v3-meta {
  margin-top: 10px;
  padding: 9px 11px;
  border-radius: 13px;
  font-size: 0.82rem;
  line-height: 1.35;
}

.customer-request-v3-warning {
  border: 1px solid rgba(220, 38, 38, 0.35);
  background: rgba(254, 226, 226, 0.8);
  color: #991b1b;
}

.customer-request-v3-note {
  border: 1px solid rgba(245, 158, 11, 0.35);
  background: rgba(254, 243, 199, 0.75);
  color: #92400e;
}

.customer-request-v3-meta {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
  border: 1px solid var(--border);
  background: var(--surface-soft);
  color: var(--text-muted);
  font-weight: 750;
}

.customer-request-v3-edit-form {
  display: grid;
  gap: 12px;
  margin-top: 12px;
}

.customer-request-v3-footer {
  position: sticky;
  bottom: 0;
  z-index: 2;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 20px;
  border-top: 1px solid var(--border);
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(10px);
}

.customer-request-v3-footer-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.request-v3-missing {
  border: 1px solid #dc2626 !important;
  border-radius: 13px;
  animation: requestV3Pulse 1.2s infinite;
}

.form-group.request-v3-missing {
  padding: 8px;
  background: rgba(254, 226, 226, 0.36);
}

@keyframes requestV3Pulse {
  0% {
    box-shadow: 0 0 0 0 rgba(220, 38, 38, 0.32);
  }

  70% {
    box-shadow: 0 0 0 7px rgba(220, 38, 38, 0);
  }

  100% {
    box-shadow: 0 0 0 0 rgba(220, 38, 38, 0);
  }
}


.action-dashboard-view{
    margin-bottom:16px;
    padding:16px 18px;
    border:1px solid var(--border);
    border-radius:var(--radius-lg);
    background:
      radial-gradient(circle at top left, var(--primary-soft), transparent 34%),
      var(--surface);
    box-shadow:var(--shadow-sm);
    display:grid;
    grid-template-columns:minmax(0, 1fr) auto;
    gap:14px;
    align-items:start;
}
@media (max-width: 760px) {
  .action-dashboard-view{
    margin-top:40px !important;
  }
}

@media (max-width: 560px) {
  .action-dashboard-view{
    margin-top:40px !important;
  }
}

@media (max-width: 760px) {
  .customer-request-v3-card {
    width: 96vw !important;
    min-width: 96vw !important;
    max-height: 92vh !important;
  }

  .customer-request-v3-header,
  .customer-request-v3-progress-wrap,
  .customer-request-v3-main,
  .customer-request-v3-footer {
    padding-left: 14px;
    padding-right: 14px;
  }

  .customer-request-v3-summary {
    grid-template-columns: 1fr;
  }

  .customer-request-v3-choice-wrap {
    grid-template-columns: 1fr;
  }

  .customer-request-v3-footer {
    align-items: stretch;
    flex-direction: column-reverse;
  }

  .customer-request-v3-footer-actions {
    width: 100%;
  }

  .customer-request-v3-footer-actions .btn,
  #crv3-cancel-btn {
    flex: 1;
  }
}

/* =========================================================
   Customer crm request styles
========================================================= */

.crm-ai-followup-card {
  margin-bottom: 14px;
  padding: 14px;
  border: 1px solid rgba(37, 99, 235, 0.24);
  border-radius: 16px;
  background:
    radial-gradient(circle at top left, rgba(37, 99, 235, 0.09), transparent 36%),
    var(--surface);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
}

.crm-ai-followup-card__head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 12px;
}

.crm-ai-followup-card__head strong {
  display: block;
  font-size: 0.98rem;
  color: var(--text);
}

.crm-ai-followup-card__head p {
  margin: 4px 0 0;
  font-size: 0.84rem;
  line-height: 1.45;
}

.crm-ai-followup-form {
  display: grid;
  gap: 10px;
}

.crm-ai-followup-question {
  display: grid;
  gap: 6px;
}

.crm-ai-followup-question span {
  font-weight: 750;
  font-size: 0.84rem;
  color: var(--text);
}

.crm-ai-followup-question input {
  min-height: 40px;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 9px 11px;
  background: var(--surface);
  color: var(--text);
}

.crm-ai-followup-question input:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.12);
}

.crm-ai-followup-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
  padding-top: 4px;
}

@media (max-width: 640px) {
  .crm-ai-followup-card__head {
    flex-direction: column;
  }

  .crm-ai-followup-actions .btn {
    flex: 1;
  }
}
.crm-ai-warning-pulse {
  border-color: rgba(245, 158, 11, 0.42) !important;
  background:
    radial-gradient(circle at top left, rgba(245, 158, 11, 0.12), transparent 34%),
    var(--surface);
  animation: crmAiWarningPulse 1.6s infinite;
}

@keyframes crmAiWarningPulse {
  0% {
    box-shadow: 0 0 0 0 rgba(245, 158, 11, 0.34);
  }

  70% {
    box-shadow: 0 0 0 8px rgba(245, 158, 11, 0);
  }

  100% {
    box-shadow: 0 0 0 0 rgba(245, 158, 11, 0);
  }
}

.crm-ai-rec-list {
  display: grid;
  gap: 9px;
}

.crm-ai-rec-item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 9px;
  align-items: flex-start;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 13px;
  background: var(--surface-soft);
  cursor: pointer;
}

.crm-ai-rec-item:hover {
  border-color: var(--warning);
}

.crm-ai-rec-item input {
  margin-top: 3px;
}

.crm-ai-rec-item strong {
  display: block;
  font-size: 0.86rem;
  color: var(--text);
}

.crm-ai-rec-item small {
  display: block;
  margin-top: 3px;
  font-size: 0.76rem;
}

.crm-ai-rec-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 10px;
}
.crm-gap-clarification-btn {
  border: 0;
  cursor: pointer;
  font: inherit;
}

.crm-gap-clarification-btn:hover {
  filter: brightness(0.96);
  transform: translateY(-1px);
}