/* Groene Vrienden CRM final UI layer.
   Loaded after the Vite bundle so broad legacy CSS cannot break the demo layout. */

@font-face {
    font-family: "Material Symbols Rounded";
    font-style: normal;
    font-weight: 100 700;
    src: url("/assets/fonts/material-symbols-rounded.ttf") format("truetype");
    font-display: block;
}

/* CRM subpage rhythm + Contactpogingen management preview 2026-05-11 */
#view-leads{--lead-top-zone:56px;--lead-action-zone:62px;--lead-intro-zone:138px;display:flex!important;flex-direction:column!important}
#view-leads>.back-bar{order:0!important;min-height:var(--lead-top-zone)!important;margin:0 0 28px!important}
#view-leads>.lead-workspace-tabs{order:1!important;min-height:58px!important;margin:0 0 30px!important}
#view-leads>.leads-actionbar{order:2!important;min-height:var(--lead-action-zone)!important;margin:0 0 28px!important}
#view-leads>.intro{order:3!important;min-height:var(--lead-intro-zone)!important;margin:0!important}
#view-leads>.lead-filter-stack{order:4!important}
#view-leads>.lead-sync-notice{order:5!important}
#view-leads>.lead-report-shell,#view-leads>.lead-contact-lead-list,#view-leads>.lead-table-shell,#view-leads>.lead-list{order:6!important}
#view-leads .lead-contact-command,#view-leads .lead-contact-analysis{overflow:hidden!important}
#view-leads .lead-contact-kpi-grid{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:12px!important;padding:16px 20px 20px!important}
#view-leads .lead-contact-kpi-grid article{min-width:0!important;padding:16px!important;border:1px solid var(--md-outline-variant,#e8eaed)!important;border-radius:12px!important;background:var(--md-surface-variant,#f8f9fa)!important}
#view-leads .lead-contact-kpi-grid span,#view-leads .lead-contact-analysis-main span,#view-leads .lead-contact-analysis-metrics small{display:block!important;color:var(--md-on-surface-variant,#5f6368)!important;font-size:12px!important;font-weight:700!important}
#view-leads .lead-contact-kpi-grid strong{display:block!important;margin:6px 0!important;color:var(--md-on-surface,#202124)!important;font-size:34px!important;font-weight:500!important;line-height:1!important}
#view-leads .lead-contact-kpi-grid small{color:var(--md-on-surface-variant,#5f6368)!important;font-size:12px!important;line-height:1.35!important}
#view-leads .lead-contact-level-toggle{display:inline-flex!important;flex-wrap:wrap!important;gap:6px!important;padding:4px!important;border:1px solid var(--md-outline-variant,#e8eaed)!important;border-radius:999px!important;background:var(--md-surface-variant,#f8f9fa)!important}
#view-leads .lead-contact-level-toggle button{min-height:36px!important;padding:0 14px!important;border:0!important;border-radius:999px!important;background:transparent!important;color:var(--md-on-surface-variant,#5f6368)!important;font-weight:700!important}
#view-leads .lead-contact-level-toggle button.active{background:var(--md-primary-container,#e8f0fe)!important;color:var(--md-primary,#1a73e8)!important}
#view-leads .lead-contact-analysis-list{display:grid!important;gap:12px!important;padding:0 20px 20px!important}
#view-leads .lead-contact-analysis-row{display:grid!important;grid-template-columns:minmax(180px,.9fr) minmax(340px,1.6fr) minmax(260px,1fr)!important;gap:14px!important;align-items:center!important;min-width:0!important;padding:14px!important;border:1px solid var(--md-outline-variant,#e8eaed)!important;border-radius:12px!important;background:var(--md-surface,#fff)!important}
#view-leads .lead-contact-analysis-main,#view-leads .lead-contact-distribution,#view-leads .lead-contact-analysis-metrics{min-width:0!important}
#view-leads .lead-contact-analysis-main strong{display:block!important;margin:4px 0!important;color:var(--md-on-surface,#202124)!important;font-size:17px!important;line-height:1.25!important}
#view-leads .lead-contact-analysis-main small{color:var(--md-on-surface-variant,#5f6368)!important;font-size:12px!important;line-height:1.35!important}
#view-leads .lead-contact-distribution{display:grid!important;gap:6px!important}
#view-leads .lead-contact-distribution button{display:grid!important;grid-template-columns:24px minmax(120px,1fr) minmax(48px,max-content) minmax(48px,max-content)!important;gap:8px!important;align-items:center!important;min-height:26px!important;padding:0!important;border:0!important;border-radius:0!important;background:transparent!important;color:var(--md-on-surface,#202124)!important;text-align:left!important}
#view-leads .lead-contact-distribution button.active{color:var(--md-primary,#1a73e8)!important}
#view-leads .lead-contact-distribution span,#view-leads .lead-contact-distribution em,#view-leads .lead-contact-distribution small{font-size:12px!important;font-style:normal!important;font-weight:700!important;white-space:nowrap!important}
#view-leads .lead-contact-distribution i{display:block!important;height:8px!important;overflow:hidden!important;border-radius:999px!important;background:var(--md-outline-variant,#e8eaed)!important}
#view-leads .lead-contact-distribution b{display:block!important;height:100%!important;border-radius:inherit!important;background:var(--md-primary,#1a73e8)!important}
#view-leads .lead-contact-analysis-metrics{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:8px!important}
#view-leads .lead-contact-analysis-metrics span{min-width:0!important;padding:10px!important;border-radius:10px!important;background:var(--md-surface-variant,#f8f9fa)!important}
#view-leads .lead-contact-analysis-metrics b{display:block!important;color:var(--md-on-surface,#202124)!important;font-size:18px!important;line-height:1!important}
@media (max-width:1180px){#view-leads .lead-contact-kpi-grid,#view-leads .lead-contact-analysis-row,#view-leads .lead-contact-analysis-metrics{grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important}}
@media (max-width:760px){#view-leads{--lead-top-zone:48px;--lead-action-zone:54px;--lead-intro-zone:124px}#view-leads .lead-contact-kpi-grid,#view-leads .lead-contact-analysis-row,#view-leads .lead-contact-analysis-metrics{grid-template-columns:minmax(0,1fr)!important}}

html,
body {
    overflow-x: hidden !important;
}

/* Lead register search polish: keep one clean focus ring on the wrapper. */
html body[data-active-view="view-leads"] #view-leads .lead-search-field .bes-search {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    height: 48px !important;
    min-height: 48px !important;
    max-height: none !important;
    padding: 0 14px !important;
    border: 1px solid var(--color-border-strong, #d8dee9) !important;
    border-radius: 16px !important;
    background: var(--color-surface-base, #fff) !important;
    box-shadow: none !important;
    overflow: hidden !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-search-field .bes-search:focus-within {
    border-color: var(--color-brand-500, #4f6eea) !important;
    box-shadow: 0 0 0 3px rgba(79, 110, 234, .16) !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-search-field .bes-search input,
html body[data-active-view="view-leads"] #view-leads .lead-search-field .bes-search input:focus,
html body[data-active-view="view-leads"] #view-leads .lead-search-field .bes-search input:focus-visible {
    height: 100% !important;
    padding: 0 !important;
    border: 0 !important;
    outline: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

/* Customer dossier polish 2026-05-11 */
#view-bestellingen .bes-active-filters {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 8px !important;
    margin: -4px 0 18px !important;
}

#view-bestellingen .bes-active-filters button {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    min-height: 32px !important;
    padding: 0 10px 0 12px !important;
    border: 1px solid #DADCE0 !important;
    border-radius: 999px !important;
    background: #fff !important;
    color: #3C4043 !important;
    font: inherit !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
}

#view-bestellingen .bes-active-filters button:hover {
    border-color: #A8C7FA !important;
    background: #F8FBFF !important;
}

#view-bestellingen .bes-active-filters button b {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 18px !important;
    height: 18px !important;
    border-radius: 999px !important;
    background: #E8F0FE !important;
    color: #1A73E8 !important;
    font-size: 11px !important;
    line-height: 1 !important;
}

#view-bestellingen .bes-active-filters .bes-active-clear {
    border-color: transparent !important;
    background: transparent !important;
    color: #1A73E8 !important;
}

#view-bestellingen .bes-coverage-strip {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 10px !important;
    margin: -2px 0 16px !important;
    padding: 10px 12px !important;
    border: 1px solid #DADCE0 !important;
    border-left: 4px solid #188038 !important;
    border-radius: 8px !important;
    background: #F8FBFF !important;
}

#view-bestellingen .bes-coverage-strip.is-warning {
    border-left-color: #F29900 !important;
    background: #FFFBF0 !important;
}

#view-bestellingen .bes-coverage-strip span {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
    color: #5F6368 !important;
    font-size: 12px !important;
    font-weight: 700 !important;
}

#view-bestellingen .bes-coverage-strip strong {
    color: #202124 !important;
    font-size: 18px !important;
    line-height: 1.1 !important;
}

@media (max-width: 760px) {
    #view-bestellingen .bes-coverage-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

#view-bestellingen .bes-customer-contact {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 6px 10px !important;
    margin-top: 4px !important;
}

#view-bestellingen .bes-customer-contact a,
#view-bestellingen .bes-customer-contact span {
    color: #1A73E8 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    text-decoration: none !important;
}

#view-bestellingen .bes-customer-contact a + a {
    border-left: 1px solid #DADCE0 !important;
    padding-left: 10px !important;
}

#view-bestellingen .bes-customer-contact a:hover {
    text-decoration: underline !important;
}

#view-bestellingen .bes-address {
    display: block !important;
    margin-top: 4px !important;
}

#view-bestellingen .bes-address.is-incomplete {
    color: #9A3412 !important;
    font-style: normal !important;
    font-weight: 600 !important;
}

#view-bestellingen .bes-product-chip {
    display: inline-flex !important;
    align-items: center !important;
    gap: 7px !important;
    min-height: 26px !important;
    border: 1px solid #DADCE0 !important;
    background: #F8F9FA !important;
    color: #202124 !important;
}

#view-bestellingen .bes-product-chip b {
    color: #5F6368 !important;
    font-size: 10px !important;
    font-weight: 800 !important;
    letter-spacing: .04em !important;
    text-transform: uppercase !important;
}

#view-bestellingen .bes-product-chip span {
    color: #202124 !important;
    font-size: 12px !important;
    font-weight: 700 !important;
}

#view-bestellingen .bes-product-chip.is-more {
    background: #EEF2FF !important;
    color: #3153D8 !important;
    font-weight: 800 !important;
}

#view-bestellingen .bes-customer-meta .bes-advisor-chip {
    border: 1px solid #C7D2FE !important;
    background: #EEF2FF !important;
    color: #3153D8 !important;
    font-weight: 700 !important;
}

#view-bestellingen .bes-customer-meta .bes-advisor-chip.is-empty {
    border-color: #DADCE0 !important;
    border-style: dashed !important;
    background: #F8F9FA !important;
    color: #5F6368 !important;
}

#view-bestellingen .bes-pipeline-pill.is-getekend {
    border-color: #C7D2FE !important;
    background: #EEF2FF !important;
    color: #3730A3 !important;
}

#view-bestellingen .bes-pipeline-pill.is-schouw {
    border-color: #FDE68A !important;
    background: #FFFBEB !important;
    color: #92400E !important;
}

#view-bestellingen .bes-pipeline-pill.is-installatie {
    border-color: #BFDBFE !important;
    background: #EFF6FF !important;
    color: #1D4ED8 !important;
}

#view-bestellingen .bes-pipeline-pill.is-oplevering {
    border-color: #BBF7D0 !important;
    background: #ECFDF5 !important;
    color: #047857 !important;
}

body[data-active-view="view-bestellingen"] #view-bestellingen .bes-customer-list {
    padding-bottom: 120px !important;
}

body[data-active-view="view-bestellingen"] .qt-fab {
    bottom: 108px !important;
    opacity: .86 !important;
}

body[data-active-view="view-bestellingen"] .qt-fab:hover {
    opacity: 1 !important;
}

.sidebar-brand .brand-text strong span + span,
.mobile-brand strong span + span {
    margin-left: 3px !important;
}

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

.skip-link {
    position: fixed !important;
    z-index: 100000 !important;
    top: 12px !important;
    left: 12px !important;
    transform: translateY(-140%) !important;
    border: 2px solid #1A73E8 !important;
    border-radius: 8px !important;
    background: #fff !important;
    color: #174EA6 !important;
    padding: 10px 14px !important;
    font-weight: 800 !important;
    text-decoration: none !important;
    box-shadow: 0 10px 30px rgba(11, 18, 32, .18) !important;
}

.skip-link:focus {
    transform: translateY(0) !important;
}

.portal-footer,
.portal-footer-static {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px 16px !important;
    margin: 24px auto 0 !important;
    padding: 18px 24px 32px !important;
    color: #5F6368 !important;
    font-size: 12px !important;
    font-weight: 700 !important;
}

.portal-footer-static {
    background: var(--md-surface-variant, #f8f9fa) !important;
}

#view-bestellingen .bes-product-chip.is-empty {
    border-style: dashed !important;
    color: #5F6368 !important;
}

#view-bestellingen .bes-customer-meta .bes-customer-timeline {
    display: inline-flex !important;
    border-color: #DADCE0 !important;
    background: #fff !important;
    color: #5F6368 !important;
    font-weight: 700 !important;
}

#view-bestellingen .bes-open-action {
    text-decoration: none !important;
}

@media (min-width: 960px) {
    body[data-active-view="view-bestellingen"] #view-bestellingen .bes-customer-list {
        padding-right: 86px !important;
    }
}

/* Absolute EOF lead scroll/performance guard 2026-05-09 */
html body[data-active-view="view-leads"],
html body[data-active-view="view-leads"] #app,
html body[data-active-view="view-leads"] .crm-app {
    min-height: 100% !important;
    overflow-x: hidden !important;
}

html body[data-active-view="view-leads"] .main-content,
html body[data-active-view="view-leads"] .page {
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
}

html body[data-active-view="view-leads"] #view-leads {
    min-height: auto !important;
    max-height: none !important;
    overflow: visible !important;
    touch-action: pan-y !important;
    overscroll-behavior: contain !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-list,
html body[data-active-view="view-leads"] #view-leads .lead-contact-card-grid,
html body[data-active-view="view-leads"] #view-leads .lead-data-table-wrap,
html body[data-active-view="view-leads"] #view-leads .lead-salesdock-results,
html body[data-active-view="view-leads"] #view-leads .gv-empty {
    max-height: none !important;
    overflow-y: visible !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-data-table-wrap {
    overflow-x: hidden !important;
    touch-action: pan-y !important;
}

/* Lead-register wheel scroll fix 2026-05-10 */
html body[data-active-view="view-leads"] #view-leads,
html body[data-active-view="view-leads"] #view-leads .lead-list,
html body[data-active-view="view-leads"] #view-leads .lead-data-table-wrap,
html body[data-active-view="view-leads"] #view-leads .lead-data-table,
html body[data-active-view="view-leads"] #view-leads .lead-data-table tbody {
    max-height: none !important;
    overflow: visible !important;
    overscroll-behavior-y: auto !important;
    touch-action: pan-y !important;
}

html body[data-active-view="view-leads"] .main-content,
html body[data-active-view="view-leads"] .page {
    overscroll-behavior-y: auto !important;
}

/* Lead-register cross-source search 2026-05-08 */
html body[data-active-view="view-leads"] #view-leads .lead-salesdock-results {
    width: 100% !important;
    border: 1px solid var(--color-border-soft, #e5e7eb) !important;
    border-radius: 18px !important;
    background: var(--color-surface-base, #fff) !important;
    box-shadow: 0 18px 45px rgba(15, 23, 42, .06) !important;
    overflow: hidden !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-salesdock-results-head {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 18px !important;
    padding: 22px 24px !important;
    border-bottom: 1px solid var(--color-border-soft, #e5e7eb) !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-salesdock-results-head h3 {
    margin: 3px 0 6px !important;
    color: var(--color-text-primary, #111827) !important;
    font-size: 22px !important;
    line-height: 1.2 !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-salesdock-results-head p {
    max-width: 720px !important;
    margin: 0 !important;
    color: var(--color-text-secondary, #64748b) !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-salesdock-result-list {
    display: grid !important;
    gap: 0 !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-salesdock-result-card {
    display: grid !important;
    grid-template-columns: minmax(260px, 1.4fr) minmax(220px, .8fr) minmax(150px, auto) !important;
    align-items: center !important;
    gap: 16px !important;
    padding: 18px 24px !important;
    border-bottom: 1px solid var(--color-border-soft, #e5e7eb) !important;
    background: var(--color-surface-base, #fff) !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-salesdock-result-card:last-child {
    border-bottom: 0 !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-salesdock-reference {
    display: block !important;
    margin-bottom: 4px !important;
    color: var(--color-brand-700, #3153d8) !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    letter-spacing: .04em !important;
    text-transform: uppercase !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-salesdock-result-card h4 {
    margin: 0 0 4px !important;
    color: var(--color-text-primary, #111827) !important;
    font-size: 18px !important;
    line-height: 1.25 !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-salesdock-result-card p,
html body[data-active-view="view-leads"] #view-leads .lead-salesdock-result-card small {
    margin: 0 !important;
    color: var(--color-text-secondary, #64748b) !important;
    font-size: 13px !important;
    line-height: 1.45 !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-link-state {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 34px !important;
    padding: 0 12px !important;
    border: 1px solid #fed7aa !important;
    border-radius: 999px !important;
    background: #fff7ed !important;
    color: #9a3412 !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    white-space: nowrap !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-link-state.is-linked {
    border-color: #bbf7d0 !important;
    background: #ecfdf5 !important;
    color: #047857 !important;
}

@media (max-width: 900px) {
    html body[data-active-view="view-leads"] #view-leads .lead-salesdock-results-head,
    html body[data-active-view="view-leads"] #view-leads .lead-salesdock-result-card {
        grid-template-columns: 1fr !important;
        display: grid !important;
    }
}

/* Lead auto-link clarity 2026-05-08 */
#view-leads .lead-match-confidence {
    display: inline-flex !important;
    align-items: center !important;
    width: fit-content !important;
    margin-top: 6px !important;
    padding: 4px 8px !important;
    border-radius: 999px !important;
    background: #eef2ff !important;
    color: #3150a8 !important;
    font: 700 11px/1.2 var(--font-sans, "Google Sans", Arial, sans-serif) !important;
    font-style: normal !important;
}

#view-leads .lead-match-confidence.is-high {
    background: #e6f4ea !important;
    color: #137333 !important;
}

#view-leads .lead-match-confidence.is-low {
    background: #fef7e0 !important;
    color: #a16207 !important;
}

.crm-app,
.crm-app * {
    box-sizing: border-box;
}

.crm-app .main-content {
    width: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    margin-right: 0 !important;
    overflow-x: hidden !important;
}

.crm-app .main-content > .page {
    width: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding-inline: clamp(24px, 2.5vw, 48px) !important;
    overflow-x: hidden !important;
}

.crm-app .view,
.crm-app [id^="view-"] {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
}

.crm-app :is(.dashboard-stats, .quick-actions, .salesdock-summary, .salesdock-flow, .stats-grid, .kpi-grid, .energy-kpi-grid, .finance-kpis, .lead-duplicate-worktable, .lead-cost-editor, .bes-customer-list, .ops-grid, .invoice-table-wrap, .data-table-wrap) {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
}

#view-home .dashboard-stats,
#view-home .quick-actions,
#view-home .salesdock-summary,
#view-home .salesdock-flow {
    display: grid !important;
    width: 100% !important;
    max-width: 100% !important;
    gap: 12px !important;
}

#view-home .dashboard-stats {
    grid-template-columns: repeat(auto-fit, minmax(168px, 1fr)) !important;
}

#view-home .quick-actions {
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)) !important;
}

#view-home .salesdock-summary,
#view-home .salesdock-flow {
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
}

#view-home :is(.dashboard-stat, .quick-action, .salesdock-panel, .dashboard-empty-recent, .dashboard-recent-row, .salesdock-summary > div, .salesdock-flow > div) {
    min-width: 0 !important;
    max-width: 100% !important;
}

#view-home :is(.quick-action-body, .salesdock-summary strong, .salesdock-flow strong, .salesdock-note) {
    min-width: 0 !important;
    overflow-wrap: anywhere !important;
}

#view-lead-duplicates .lead-duplicate-worktable {
    display: grid !important;
    gap: 0 !important;
}

#view-lead-duplicates :is(.lead-duplicate-line, .lead-duplicate-worktable-row, .lead-duplicate-compact-row) {
    max-width: 100% !important;
    min-width: 0 !important;
}

#view-energy-finance .energy-finance-workbench-polished,
#view-energy-klanten .energy-domain-grid,
#view-energy-anomalies .energy-anomaly-workbench {
    grid-template-columns: minmax(0, 1fr) !important;
    max-width: 100% !important;
}

.crm-app :is(input, select, textarea, button) {
    max-width: 100%;
}

.crm-app :is(.crm-table, table) {
    max-width: 100%;
}

@media (max-width: 767px) {
    .crm-app .main-content {
        width: 100% !important;
        margin-left: 0 !important;
    }

    .crm-app .main-content > .page {
        padding-inline: 16px !important;
    }
}

/* Final pass 2026-05-06: dense CRM polish and no sideways drift. */
.crm-app :is(.bes-customer-row, .invoice-row, .comm-row, .product-row, .lead-duplicate-workrow) {
    min-width: 0 !important;
    max-width: 100% !important;
}

#view-bestellingen .bes-customer-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(220px, max-content) !important;
    align-items: start !important;
    gap: 16px !important;
}

#view-bestellingen .bes-customer-row > div,
#view-bestellingen .bes-customer-products,
#view-bestellingen .bes-customer-meta {
    min-width: 0 !important;
    max-width: 100% !important;
}

#view-bestellingen .bes-customer-meta {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: flex-end !important;
    gap: 6px !important;
    max-width: min(520px, 40vw) !important;
}

#view-bestellingen .bes-customer-meta :is(span, small),
#view-bestellingen .bes-customer-products small {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-bestellingen .bes-customer-meta .bes-customer-invoices,
#view-bestellingen .bes-customer-meta .bes-customer-heatpump {
    max-width: 280px !important;
}

#view-bestellingen .bes-customer-row strong,
#view-bestellingen .bes-customer-row em,
#view-bestellingen .bes-customer-row > div:first-child > span {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-facturen .invoice-command-bar,
#view-facturen .invoice-status-tabs,
#view-facturen .invoice-kpi-grid {
    min-width: 0 !important;
    max-width: 100% !important;
}

#view-facturen .invoice-command-bar {
    display: grid !important;
    grid-template-columns: minmax(260px, 1fr) minmax(0, max-content) !important;
    gap: 12px !important;
    align-items: center !important;
}

#view-facturen .invoice-status-tabs {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: flex-end !important;
    gap: 6px !important;
    overflow: hidden !important;
}

#view-facturen .invoice-status-tabs button {
    height: 34px !important;
    max-width: 190px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-facturen .invoice-table-card,
#view-facturen .invoice-table,
#view-facturen .invoice-row {
    overflow-x: hidden !important;
}

#view-facturen .invoice-row {
    grid-template-columns: minmax(210px, 1.35fr) minmax(150px, 0.9fr) minmax(100px, 0.55fr) minmax(130px, 0.7fr) minmax(120px, 0.65fr) !important;
}

#view-facturen .invoice-row > *,
#view-facturen .invoice-row :is(strong, span, small) {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#view-leads .lead-report-shell,
#view-leads .lead-cost-editor,
#view-leads .lead-cost-row,
#view-leads .lead-duplicate-workspace,
#view-leads .lead-duplicate-table-panel,
#view-leads .lead-duplicate-worktable {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
}

#view-leads .lead-cost-row {
    grid-template-columns: minmax(180px, 1.2fr) minmax(150px, 0.9fr) minmax(120px, 0.7fr) minmax(180px, 1fr) !important;
}

#view-leads .lead-cost-row > *,
#view-leads .lead-cost-row :is(strong, span, small) {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

@media (max-width: 1180px) {
    #view-bestellingen .bes-customer-row,
    #view-facturen .invoice-command-bar,
    #view-leads .lead-cost-row {
        grid-template-columns: 1fr !important;
    }

    #view-bestellingen .bes-customer-meta,
    #view-facturen .invoice-status-tabs {
        justify-content: flex-start !important;
        max-width: 100% !important;
    }
}

/* Final pass 2026-05-06: screenshot corrections for clipped right-side controls. */
#view-bestellingen .bes-customer-row {
    grid-template-columns: minmax(0, 1fr) 420px !important;
    overflow: hidden !important;
}

#view-bestellingen .bes-customer-meta {
    width: 420px !important;
    max-width: 420px !important;
    overflow: hidden !important;
}

#view-bestellingen .bes-customer-meta :is(span, small) {
    width: auto !important;
    flex: 0 1 auto !important;
}

#view-bestellingen .bes-customer-meta .bes-customer-invoices,
#view-bestellingen .bes-customer-meta .bes-customer-heatpump {
    width: auto !important;
    max-width: 220px !important;
}

#view-products .product-actionbar,
#view-products .product-filterbar,
#view-products .product-stats-grid {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
}

#view-products .product-actionbar {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 14px !important;
    align-items: center !important;
}

#view-products .product-actionbar-buttons {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: flex-end !important;
    gap: 8px !important;
    max-width: 560px !important;
}

#view-products .product-actionbar-buttons .ev-btn {
    height: 36px !important;
    max-width: 180px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-products .product-filterbar {
    display: grid !important;
    grid-template-columns: minmax(260px, 1fr) minmax(160px, 220px) auto !important;
    gap: 10px !important;
    align-items: center !important;
}

#view-products .product-filterbar > * {
    min-width: 0 !important;
}

#view-facturen .invoice-command-bar {
    grid-template-columns: 1fr !important;
    align-items: stretch !important;
}

#view-facturen .invoice-status-tabs {
    justify-content: flex-start !important;
}

#view-facturen .invoice-search {
    width: min(720px, 100%) !important;
}

@media (max-width: 1280px) {
    #view-bestellingen .bes-customer-row,
    #view-products .product-actionbar,
    #view-products .product-filterbar {
        grid-template-columns: 1fr !important;
    }

    #view-bestellingen .bes-customer-meta {
        width: 100% !important;
        max-width: 100% !important;
        justify-content: flex-start !important;
    }

    #view-products .product-actionbar-buttons {
        justify-content: flex-start !important;
        max-width: 100% !important;
    }
}

/* Final pass 2026-05-06: keep dense pages readable without clipping controls. */
@media (min-width: 1025px) {
    .crm-app .main-content {
        width: calc(100vw - 256px) !important;
        max-width: calc(100vw - 256px) !important;
    }

    .crm-app .sidebar.is-collapsed ~ .main-content {
        width: calc(100vw - 72px) !important;
        max-width: calc(100vw - 72px) !important;
    }

    .crm-app .main-content > .page,
    .crm-app .main-content [id^="view-"] {
        box-sizing: border-box !important;
        max-width: calc(100vw - 320px) !important;
    }

    .crm-app .sidebar.is-collapsed ~ .main-content > .page,
    .crm-app .sidebar.is-collapsed ~ .main-content [id^="view-"] {
        max-width: calc(100vw - 136px) !important;
    }
}

#view-bestellingen .bes-customer-row {
    grid-template-columns: minmax(0, 1fr) !important;
}

#view-bestellingen .bes-customer-meta {
    width: 100% !important;
    max-width: 100% !important;
    justify-content: flex-start !important;
    text-align: left !important;
}

#view-bestellingen .bes-customer-meta small {
    flex-basis: auto !important;
    max-width: 180px !important;
}

#view-products .product-actionbar {
    display: block !important;
    overflow: visible !important;
}

#view-products .product-actionbar-buttons {
    width: 100% !important;
    max-width: 100% !important;
    margin-top: 12px !important;
    justify-content: flex-start !important;
}

#view-products .product-actionbar-buttons .ev-btn {
    flex: 0 1 auto !important;
    max-width: 260px !important;
}

#view-products .product-filterbar {
    display: flex !important;
    flex-wrap: wrap !important;
    overflow: visible !important;
}

#view-products .product-filterbar .product-search {
    flex: 1 0 100% !important;
    min-width: 260px !important;
}

#view-products .product-filterbar select {
    flex: 0 1 240px !important;
    min-width: 220px !important;
}

#view-products .product-filterbar > span {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
}

#view-products .product-stats-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 12px !important;
    overflow: visible !important;
}

#view-products .product-stat-card {
    min-width: 0 !important;
}

@media (max-width: 1400px) {
    #view-products .product-stats-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 767px) {
    #view-products .product-stats-grid {
        grid-template-columns: 1fr !important;
    }
}

/* Lead analytics compact overrides. */
#view-leads .lead-targeting-toolbar {
    align-items: center !important;
    gap: 16px !important;
}

#view-leads .lead-targeting-tabs {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    justify-content: flex-end !important;
}

#view-leads .lead-targeting-tabs button {
    height: 32px !important;
    padding: 0 12px !important;
    border: 1px solid var(--md-outline) !important;
    border-radius: 16px !important;
    background: var(--md-surface) !important;
    color: var(--md-on-surface-variant) !important;
    cursor: pointer !important;
    font-family: var(--font-sans) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
}

#view-leads .lead-targeting-tabs button:hover,
#view-leads .lead-targeting-tabs button.active {
    border-color: var(--md-primary) !important;
    background: var(--md-primary-container) !important;
    color: var(--md-primary) !important;
}

#view-leads .lead-mini-table.lead-sales-product-table .lead-mini-head,
#view-leads .lead-mini-table.lead-sales-product-table .lead-mini-row {
    grid-template-columns: minmax(0, 1.35fr) 82px 52px 66px 96px 96px 82px !important;
}

#view-leads .lead-mini-table.lead-sales-category-table .lead-mini-head,
#view-leads .lead-mini-table.lead-sales-category-table .lead-mini-row {
    grid-template-columns: minmax(0, 1fr) 58px 70px 96px 96px !important;
}

#view-leads .lead-mini-table.lead-targeting-table .lead-mini-head,
#view-leads .lead-mini-table.lead-targeting-table .lead-mini-row {
    grid-template-columns: minmax(0, 1.2fr) 58px 56px 60px 88px 88px 88px 74px minmax(0, 0.9fr) 80px !important;
    gap: 8px !important;
    padding: 9px 12px !important;
}

#view-leads .lead-mini-table.lead-targeting-table .lead-mini-row span,
#view-leads .lead-mini-table.lead-sales-product-table .lead-mini-row span,
#view-leads .lead-mini-table.lead-sales-category-table .lead-mini-row span {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#view-leads .lead-mini-table.lead-targeting-table small {
    display: block !important;
    margin-top: 1px !important;
    color: var(--md-on-surface-variant) !important;
    font-size: 10.5px !important;
    line-height: 14px !important;
}

#view-leads .lead-cost-summary-strip {
    grid-template-columns: repeat(auto-fit, minmax(118px, 1fr)) !important;
}

#view-leads .lead-cost-editor-head,
#view-leads .lead-cost-row {
    grid-template-columns: minmax(132px, 0.9fr) minmax(170px, 1fr) 64px minmax(170px, 0.9fr) minmax(250px, 1fr) !important;
}

@media (max-width: 1320px) {
    #view-leads .lead-mini-table.lead-targeting-table .lead-mini-head,
    #view-leads .lead-mini-table.lead-targeting-table .lead-mini-row {
        grid-template-columns: minmax(0, 1.15fr) 54px 54px 84px 84px 72px minmax(0, 0.85fr) !important;
    }

    #view-leads .lead-mini-table.lead-targeting-table .lead-mini-head span:nth-child(4),
    #view-leads .lead-mini-table.lead-targeting-table .lead-mini-row span:nth-child(4),
    #view-leads .lead-mini-table.lead-targeting-table .lead-mini-head span:nth-child(7),
    #view-leads .lead-mini-table.lead-targeting-table .lead-mini-row span:nth-child(7),
    #view-leads .lead-mini-table.lead-targeting-table .lead-mini-head span:nth-child(10),
    #view-leads .lead-mini-table.lead-targeting-table .lead-mini-row span:nth-child(10) {
        display: none !important;
    }
}

/* Final compact enforcement 2026-05-06: dense Google-style rows, no sideways canvas. */
.crm-app,
.crm-app .main-content,
.crm-app .main-content > .page,
.crm-app .view.active,
.crm-app [id^="view-"],
.crm-app :is(.lead-report-card, .product-table-card, .product-material-card, .invoice-table-card, .crm-table-card, .customer-detail-section, .comm-section, .energy-command-center, .energy-finance-workbench-polished) {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: clip !important;
}

.crm-app {
    touch-action: pan-y !important;
    overscroll-behavior-x: none !important;
}

.crm-app :is(.lead-report-card-head, .crm-section-head, .product-actionbar, .energy-page-head, .dashboard-section-head) {
    min-width: 0 !important;
    gap: 10px !important;
}

.crm-app :is(.lead-report-card-head h2, .lead-report-card-head h3, .crm-section-head h2, .crm-section-head h3, .product-page h1, .dashboard-section-head h2) {
    line-height: 1.2 !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-report-card {
    margin-bottom: 12px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workspace,
#view-leads .lead-duplicate-workspace {
    grid-template-columns: 184px minmax(0, 1fr) !important;
    max-width: 100% !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-supplier-panel,
#view-leads .lead-duplicate-supplier-panel {
    max-height: calc(100vh - 196px) !important;
    padding: 6px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-supplier-list button,
#view-leads .lead-duplicate-supplier-list button {
    min-height: 36px !important;
    padding: 6px 8px !important;
    border-radius: 9px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-table-panel,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-worktable,
#view-leads .lead-duplicate-table-panel,
#view-leads .lead-duplicate-worktable {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: clip !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-worktable,
#view-leads .lead-duplicate-worktable {
    max-height: calc(100vh - 244px) !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workrow,
#view-leads .lead-duplicate-workrow {
    grid-template-columns: minmax(126px, 1.15fr) minmax(106px, .9fr) minmax(124px, .95fr) 92px 70px minmax(118px, 1fr) 68px !important;
    gap: 5px !important;
    min-height: 40px !important;
    padding: 5px 7px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workrow.is-head,
#view-leads .lead-duplicate-workrow.is-head {
    min-height: 28px !important;
    padding: 5px 7px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workcell,
#view-leads .lead-duplicate-workcell {
    font-size: 12px !important;
    line-height: 1.25 !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-editor,
#view-leads .lead-duplicate-line-editor {
    grid-template-columns: minmax(0, .88fr) minmax(0, .9fr) !important;
    gap: 4px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-claim-amount,
#view-leads .lead-claim-amount {
    grid-template-columns: 28px minmax(0, 1fr) !important;
    gap: 4px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workcell :is(input, select),
body[data-active-view="view-lead-duplicates"] #view-leads .lead-claim-amount :is(span, input),
#view-leads .lead-duplicate-workcell :is(input, select),
#view-leads .lead-claim-amount :is(span, input) {
    height: 28px !important;
    min-height: 28px !important;
    border-radius: 8px !important;
    font-size: 12px !important;
    padding-inline: 7px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-actions .leads-small-btn,
#view-leads .lead-duplicate-actions .leads-small-btn {
    height: 26px !important;
    min-height: 26px !important;
    padding-inline: 7px !important;
    font-size: 11.5px !important;
}

#view-leads .lead-cost-editor-head,
#view-leads .lead-cost-row {
    grid-template-columns: minmax(128px, 1.05fr) minmax(138px, 1fr) 62px minmax(150px, 1fr) minmax(132px, .8fr) !important;
    gap: 6px !important;
}

#view-leads .lead-cost-row {
    min-height: 40px !important;
    padding: 6px 8px !important;
}

#view-leads .lead-cost-input-row {
    grid-template-columns: 30px minmax(0, 1fr) 64px !important;
    gap: 4px !important;
}

#view-leads .lead-cost-input-row > span,
#view-leads .lead-cost-input-row input,
#view-leads .lead-cost-input-row .leads-small-btn {
    height: 28px !important;
    min-height: 28px !important;
    font-size: 12px !important;
}

#view-products .product-table-card,
#view-products .product-table-scroll {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: clip !important;
}

#view-products .product-row {
    min-width: 0 !important;
    grid-template-columns: minmax(220px, 1.55fr) minmax(72px, .5fr) minmax(94px, .65fr) minmax(94px, .65fr) minmax(98px, .7fr) minmax(120px, .9fr) 64px 52px !important;
    gap: 8px !important;
    padding: 10px 12px !important;
}

#view-products .product-row :is(strong, small, span),
.customer-product-row :is(strong, span, em, small),
.customer-product-row--detailed :is(strong, span, em, small) {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#view-products .product-row small,
.customer-product-row span,
.customer-product-row--detailed span {
    display: -webkit-box !important;
    -webkit-line-clamp: 1 !important;
    -webkit-box-orient: vertical !important;
    white-space: normal !important;
}

@media (max-width: 1360px) {
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workspace,
    #view-leads .lead-duplicate-workspace {
        grid-template-columns: 1fr !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-supplier-panel,
    #view-leads .lead-duplicate-supplier-panel {
        position: static !important;
        max-height: 132px !important;
        border-right: 0 !important;
        border-bottom: 1px solid var(--md-outline-variant) !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-supplier-list,
    #view-leads .lead-duplicate-supplier-list {
        grid-template-columns: repeat(auto-fit, minmax(148px, 1fr)) !important;
    }

    #view-products .product-row.head {
        display: none !important;
    }

    #view-products .product-row:not(.head) {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        border: 1px solid var(--md-outline-variant) !important;
        border-radius: 12px !important;
        margin-bottom: 8px !important;
    }
}

@media (max-width: 960px) {
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workrow,
    #view-leads .lead-duplicate-workrow,
    #view-leads .lead-cost-row {
        grid-template-columns: 1fr !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workrow.is-head,
    #view-leads .lead-duplicate-workrow.is-head,
    #view-leads .lead-cost-editor-head {
        display: none !important;
    }
}

/* Email automations demo polish 2026-05-06 */
#view-email-automations,
#view-email-automations * {
    box-sizing: border-box !important;
}

#view-email-automations {
    max-width: 100% !important;
    overflow-x: hidden !important;
}

#view-email-automations .ea-hero,
#view-email-automations .ea-selected-card,
#view-email-automations .ea-panel,
#view-email-automations .ea-metric {
    border-color: var(--md-outline-variant) !important;
    box-shadow: none !important;
}

#view-email-automations .ea-layout,
#view-email-automations .ea-data-grid,
#view-email-automations .ea-asset-grid {
    min-width: 0 !important;
}

#view-email-automations .ea-audience-head,
#view-email-automations .ea-audience-row {
    grid-template-columns: minmax(170px, 1.3fr) minmax(130px, 1fr) minmax(120px, 0.9fr) minmax(110px, 0.8fr) 54px !important;
    gap: 10px !important;
}

#view-email-automations .ea-audience-row span,
#view-email-automations .ea-audience-head span {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

@media (max-width: 1180px) {
    #view-email-automations .ea-layout,
    #view-email-automations .ea-data-grid {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 760px) {
    #view-email-automations .ea-audience-head {
        display: none !important;
    }

    #view-email-automations .ea-audience-row {
        grid-template-columns: 1fr !important;
    }
}

/* Background sync cockpit 2026-05-08 */
#view-home .background-sync-section {
    border-color: #d8e2f1 !important;
}

#view-home .background-sync-badge {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 34px !important;
    border-radius: 999px !important;
    padding: 7px 12px !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    white-space: nowrap !important;
    letter-spacing: 0 !important;
}

#view-home .background-sync-badge.ready {
    background: #e6f4ea !important;
    color: #137333 !important;
}

#view-home .background-sync-badge.running,
#view-home .background-sync-badge.queued {
    background: #e8f0fe !important;
    color: #1a73e8 !important;
}

#view-home .background-sync-badge.warning {
    background: #fff7d6 !important;
    color: #8a5b00 !important;
}

#view-home .background-sync-badge.neutral {
    background: var(--md-surface-container, #f1f5f9) !important;
    color: var(--md-on-surface-variant, #64748b) !important;
}

#view-home .background-sync-panel {
    display: grid !important;
    gap: 14px !important;
    border: 1px solid var(--md-outline-variant, #d9e2ef) !important;
    border-radius: 16px !important;
    padding: 16px !important;
    background: linear-gradient(135deg, rgba(232, 240, 254, .72), rgba(255, 255, 255, .96)) !important;
    overflow: hidden !important;
}

#view-home .background-sync-panel[data-state="warning"] {
    background: linear-gradient(135deg, rgba(255, 247, 214, .86), rgba(255, 255, 255, .96)) !important;
}

#view-home .background-sync-main {
    display: grid !important;
    gap: 4px !important;
}

#view-home .background-sync-main strong {
    color: var(--md-on-surface, #202124) !important;
    font-size: 15px !important;
    line-height: 1.35 !important;
}

#view-home .background-sync-main span,
#view-home .background-sync-meta {
    color: var(--md-on-surface-variant, #64748b) !important;
    font-size: 13px !important;
    line-height: 1.45 !important;
}

#view-home .background-sync-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 10px !important;
}

#view-home .background-sync-grid > div {
    min-width: 0 !important;
    border: 1px solid rgba(60, 64, 67, .10) !important;
    border-radius: 12px !important;
    padding: 12px !important;
    background: rgba(255, 255, 255, .82) !important;
}

#view-home .background-sync-grid span {
    display: block !important;
    color: var(--md-on-surface-variant, #64748b) !important;
    font-size: 12px !important;
    line-height: 1.25 !important;
}

#view-home .background-sync-grid strong {
    display: block !important;
    margin-top: 4px !important;
    color: var(--md-on-surface, #202124) !important;
    font-size: 22px !important;
    line-height: 1.1 !important;
    white-space: normal !important;
}

#view-home .background-sync-meta {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
}

#view-home .background-sync-meta span {
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
    min-height: 30px !important;
    border-radius: 999px !important;
    padding: 6px 10px !important;
    background: rgba(255, 255, 255, .78) !important;
    white-space: nowrap !important;
}

#view-home .background-sync-action {
    min-width: 124px !important;
}

@media (max-width: 900px) {
    #view-home .background-sync-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 560px) {
    #view-home .background-sync-grid {
        grid-template-columns: 1fr !important;
    }

    #view-home .background-sync-meta span {
        width: 100% !important;
        white-space: normal !important;
    }
}

/* CRM final density override 2026-05-06 */
.crm-app,
.crm-main,
.main-content,
.main-content > .page,
#view-leads,
#view-email-automations {
    max-width: 100% !important;
    overflow-x: hidden !important;
}

#view-leads .lead-report-shell,
#view-leads .lead-report-card {
    min-width: 0 !important;
    max-width: 100% !important;
}

#view-leads .lead-kpi-grid.is-duplicate-compact {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 10px !important;
    margin-bottom: 12px !important;
}

#view-leads .lead-kpi-grid.is-duplicate-compact .lead-kpi-card {
    min-height: 74px !important;
    padding: 12px 14px !important;
}

#view-leads .lead-duplicate-workspace {
    display: grid !important;
    grid-template-columns: 224px minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: start !important;
    padding: 12px !important;
}

#view-leads .lead-duplicate-supplier-panel {
    position: sticky !important;
    top: 12px !important;
    max-height: calc(100vh - 190px) !important;
    overflow-y: auto !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 12px !important;
    background: var(--md-surface-variant) !important;
    padding: 8px !important;
}

#view-leads .lead-duplicate-supplier-title {
    display: flex !important;
    justify-content: space-between !important;
    gap: 8px !important;
    padding: 4px 6px 8px !important;
    font-size: 12px !important;
}

#view-leads .lead-duplicate-supplier-list {
    display: grid !important;
    gap: 4px !important;
}

#view-leads .lead-duplicate-supplier-list button {
    min-height: 48px !important;
    padding: 8px 10px !important;
    border-radius: 10px !important;
    background: transparent !important;
    border: 1px solid transparent !important;
    text-align: left !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 4px 8px !important;
}

#view-leads .lead-duplicate-supplier-list button.active {
    background: var(--md-primary-container) !important;
    border-color: rgba(26, 115, 232, 0.28) !important;
    color: var(--md-primary) !important;
}

#view-leads .lead-duplicate-supplier-list button span,
#view-leads .lead-duplicate-supplier-list button small {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-leads .lead-duplicate-supplier-list button small {
    grid-column: 1 / -1 !important;
    font-size: 11px !important;
    color: var(--md-on-surface-variant) !important;
}

#view-leads .lead-duplicate-table-panel,
#view-leads .lead-cost-editor {
    min-width: 0 !important;
    overflow-x: hidden !important;
}

#view-leads .lead-duplicate-worktable {
    display: grid !important;
    gap: 0 !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 12px !important;
    overflow: hidden !important;
    background: var(--md-surface) !important;
}

#view-leads .lead-duplicate-workrow {
    display: grid !important;
    grid-template-columns: minmax(145px, 1.35fr) minmax(140px, 1.05fr) minmax(145px, 1fr) minmax(118px, 0.7fr) minmax(104px, 0.65fr) minmax(190px, 1.2fr) minmax(110px, 0.6fr) !important;
    gap: 8px !important;
    align-items: center !important;
    padding: 8px 10px !important;
    border: 0 !important;
    border-bottom: 1px solid var(--md-outline-variant) !important;
    min-width: 0 !important;
}

#view-leads .lead-duplicate-workrow.is-head {
    position: sticky !important;
    top: 0 !important;
    z-index: 1 !important;
    background: var(--md-surface-variant) !important;
    padding-block: 9px !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    color: var(--md-on-surface-variant) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.45px !important;
}

#view-leads .lead-duplicate-workcell,
#view-leads .lead-cost-row > div {
    min-width: 0 !important;
    font-size: 13px !important;
}

#view-leads .lead-duplicate-workcell strong,
#view-leads .lead-cost-main strong,
#view-leads .lead-duplicate-workcell small,
#view-leads .lead-cost-main span,
#view-leads .lead-cost-meta small,
#view-leads .lead-cost-impact span {
    display: block !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#view-leads .lead-duplicate-workcell small,
#view-leads .lead-cost-main span,
#view-leads .lead-cost-meta small,
#view-leads .lead-cost-impact span {
    font-size: 11.5px !important;
    color: var(--md-on-surface-variant) !important;
}

#view-leads .lead-duplicate-line-editor {
    display: grid !important;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr) !important;
    gap: 6px !important;
}

#view-leads .lead-duplicate-line-editor input,
#view-leads .lead-duplicate-workcell select,
#view-leads .lead-claim-target-select,
#view-leads .lead-claim-amount input,
#view-leads .lead-cost-input-row input {
    width: 100% !important;
    height: 34px !important;
    min-height: 34px !important;
    border-radius: 10px !important;
    background: var(--md-surface) !important;
    padding: 0 10px !important;
    font-size: 13px !important;
}

#view-leads .lead-claim-amount {
    display: grid !important;
    grid-template-columns: 42px minmax(0, 1fr) !important;
    gap: 6px !important;
    align-items: center !important;
}

#view-leads .lead-claim-amount span,
#view-leads .lead-cost-input-row span {
    height: 34px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 17px !important;
    background: var(--md-surface-container) !important;
    color: var(--md-on-surface-variant) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
}

#view-leads .lead-duplicate-actions {
    display: flex !important;
    gap: 6px !important;
    justify-content: flex-end !important;
}

#view-leads .leads-small-btn {
    min-height: 32px !important;
    height: 32px !important;
    padding: 0 12px !important;
    border-radius: 16px !important;
    font-size: 12.5px !important;
}

#view-leads .lead-cost-summary-strip {
    display: grid !important;
    grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
    gap: 0 !important;
    border-bottom: 1px solid var(--md-outline-variant) !important;
    background: var(--md-surface-variant) !important;
}

#view-leads .lead-cost-summary-item {
    padding: 10px 12px !important;
    border-right: 1px solid var(--md-outline-variant) !important;
    min-width: 0 !important;
}

#view-leads .lead-cost-summary-item strong {
    display: block !important;
    font-size: 17px !important;
    font-weight: 500 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#view-leads .lead-cost-editor-head,
#view-leads .lead-cost-row {
    display: grid !important;
    grid-template-columns: minmax(160px, 1.1fr) minmax(190px, 1.25fr) minmax(76px, 0.45fr) minmax(180px, 1fr) minmax(250px, 1.35fr) !important;
    gap: 10px !important;
    align-items: center !important;
    min-width: 0 !important;
}

#view-leads .lead-cost-editor-head {
    padding: 9px 12px !important;
    background: var(--md-surface-variant) !important;
    border-bottom: 1px solid var(--md-outline-variant) !important;
    color: var(--md-on-surface-variant) !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.45px !important;
}

#view-leads .lead-cost-row {
    padding: 10px 12px !important;
    border-bottom: 1px solid var(--md-outline-variant) !important;
}

#view-leads .lead-cost-input-row {
    display: grid !important;
    grid-template-columns: 44px minmax(0, 1fr) auto !important;
    gap: 8px !important;
    align-items: center !important;
}

@media (max-width: 1180px) {
    #view-leads .lead-kpi-grid.is-duplicate-compact {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    #view-leads .lead-duplicate-workspace {
        grid-template-columns: 1fr !important;
    }

    #view-leads .lead-duplicate-supplier-panel {
        position: static !important;
        max-height: none !important;
    }

    #view-leads .lead-duplicate-supplier-list {
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
    }

    #view-leads .lead-duplicate-workrow,
    #view-leads .lead-cost-editor-head,
    #view-leads .lead-cost-row {
        grid-template-columns: 1fr !important;
    }

    #view-leads .lead-duplicate-workrow.is-head,
    #view-leads .lead-cost-editor-head {
        display: none !important;
    }

    #view-leads .lead-cost-summary-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

/* Final CRM consistency pass: dense Google-style surfaces without horizontal page drift. */
.crm-app,
.crm-shell,
.crm-main,
.crm-content,
.crm-page,
.view-shell,
[id^="view-"] {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: clip !important;
}

.crm-app * {
    min-width: 0;
    box-sizing: border-box;
}

.crm-app pre,
.crm-app code,
.crm-app textarea,
.crm-app input,
.crm-app select,
.crm-app button,
.crm-app table,
.crm-app th,
.crm-app td {
    max-width: 100%;
}

.crm-modal.show,
.template-modal {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 24px !important;
    overflow: hidden !important;
}

.crm-modal-box,
.template-modal-box {
    width: min(1120px, calc(100vw - 48px)) !important;
    max-height: calc(100vh - 48px) !important;
    border-radius: 24px !important;
    border: 1px solid var(--md-outline-variant) !important;
    background: var(--md-surface) !important;
    box-shadow: 0 8px 24px rgba(60, 64, 67, 0.2) !important;
    overflow: hidden !important;
}

.crm-modal-head,
.template-modal-head {
    min-height: 64px !important;
    padding: 16px 20px !important;
    border-bottom: 1px solid var(--md-outline-variant) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 16px !important;
}

.crm-modal-head h2,
.crm-modal-head h3,
.template-modal-head h2,
.template-modal-head h3 {
    margin: 0 !important;
    color: var(--md-on-surface) !important;
    font-size: 22px !important;
    line-height: 1.25 !important;
    font-weight: 400 !important;
}

.crm-modal-body,
.template-modal-body {
    max-height: calc(100vh - 176px) !important;
    padding: 18px 20px !important;
    overflow-y: auto !important;
    overflow-x: clip !important;
}

.crm-modal-actions,
.template-modal-actions {
    padding: 12px 20px 18px !important;
    border-top: 1px solid var(--md-outline-variant) !important;
    display: flex !important;
    justify-content: flex-end !important;
    gap: 10px !important;
    flex-wrap: wrap !important;
}

.crm-modal-close,
.template-modal .crm-modal-close {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    border: 0 !important;
    border-radius: 50% !important;
    background: transparent !important;
    color: var(--md-on-surface-variant) !important;
    cursor: pointer !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 0 !important;
    line-height: 1 !important;
    transition: background 150ms ease, color 150ms ease !important;
}

.crm-modal-close::before,
.template-modal .crm-modal-close::before {
    content: "close";
    font-family: "Material Symbols Rounded";
    font-size: 22px;
    font-weight: 400;
    line-height: 1;
    font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;
}

.crm-modal-close:hover,
.template-modal .crm-modal-close:hover,
.rp-search-clear:hover {
    background: var(--md-surface-container) !important;
    color: var(--md-on-surface) !important;
}

.rp-search-clear {
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    border: 0 !important;
    border-radius: 50% !important;
    background: transparent !important;
    color: var(--md-on-surface-variant) !important;
    font-size: 0 !important;
}

.rp-search-clear::before {
    content: "close";
    font-family: "Material Symbols Rounded";
    font-size: 18px;
    line-height: 1;
}

.customer-detail-raw,
.customer-detail-technical-data {
    display: none !important;
}

.invoice-table-card,
.form-table-card,
.ops-panel,
.crm-table-card,
.customer-detail-section,
.comm-section,
.template-list-card {
    max-width: 100% !important;
    overflow: hidden !important;
}

.invoice-table,
.form-table,
.crm-data-table,
.ops-table,
.comm-table,
.product-table,
.lead-data-table {
    width: 100% !important;
    max-width: 100% !important;
    table-layout: fixed !important;
    border-collapse: collapse !important;
}

.invoice-table-head,
.form-table-head,
.invoice-row,
.form-table-row,
.ops-grid-row,
.crm-grid-row {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
}

.invoice-table th,
.invoice-table td,
.form-table th,
.form-table td,
.crm-data-table th,
.crm-data-table td,
.ops-table th,
.ops-table td,
.comm-table th,
.comm-table td,
.product-table th,
.product-table td,
.lead-data-table th,
.lead-data-table td {
    padding: 10px 12px !important;
    vertical-align: middle !important;
    overflow-wrap: anywhere !important;
}

.invoice-table th,
.form-table th,
.crm-data-table th,
.ops-table th,
.comm-table th,
.product-table th,
.lead-data-table th {
    background: var(--md-surface-variant) !important;
    color: var(--md-on-surface-variant) !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: 0.45px !important;
    text-transform: uppercase !important;
    border-bottom: 1px solid var(--md-outline-variant) !important;
}

.invoice-table td,
.form-table td,
.crm-data-table td,
.ops-table td,
.comm-table td,
.product-table td,
.lead-data-table td {
    color: var(--md-on-surface) !important;
    font-size: 13px !important;
    border-bottom: 1px solid var(--md-outline-variant) !important;
}

.invoice-table-card input,
.invoice-table-card select,
.invoice-table-card textarea,
.form-table-card input,
.form-table-card select,
.form-table-card textarea,
.template-modal input,
.template-modal select,
.template-modal textarea,
.crm-modal input,
.crm-modal select,
.crm-modal textarea {
    width: 100% !important;
    min-height: 38px !important;
    border: 1px solid var(--md-outline) !important;
    border-radius: 10px !important;
    background: var(--md-surface) !important;
    color: var(--md-on-surface) !important;
    font: 400 13px/1.4 var(--font-sans) !important;
    padding: 0 12px !important;
}

.invoice-table-card textarea,
.form-table-card textarea,
.template-modal textarea,
.crm-modal textarea {
    min-height: 92px !important;
    padding: 10px 12px !important;
    resize: vertical !important;
}

.invoice-table-card input:focus,
.invoice-table-card select:focus,
.invoice-table-card textarea:focus,
.form-table-card input:focus,
.form-table-card select:focus,
.form-table-card textarea:focus,
.template-modal input:focus,
.template-modal select:focus,
.template-modal textarea:focus,
.crm-modal input:focus,
.crm-modal select:focus,
.crm-modal textarea:focus {
    border-color: var(--md-primary) !important;
    box-shadow: 0 0 0 1px var(--md-primary) !important;
    outline: 0 !important;
}

.invoice-action,
.template-modal-actions button,
.crm-modal-actions button,
.form-table-card button,
.invoice-table-card button {
    min-height: 36px !important;
    border-radius: 18px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
}

@media (max-width: 900px) {
    .crm-modal.show,
    .template-modal {
        padding: 10px !important;
    }

    .crm-modal-box,
    .template-modal-box {
        width: calc(100vw - 20px) !important;
        max-height: calc(100vh - 20px) !important;
        border-radius: 18px !important;
    }

    .crm-modal-body,
    .template-modal-body {
        padding: 14px !important;
        max-height: calc(100vh - 144px) !important;
    }

    .invoice-table,
    .form-table,
    .crm-data-table,
    .ops-table,
    .comm-table,
    .product-table,
    .lead-data-table {
        table-layout: auto !important;
    }
}

/* CRM final operational polish 2026-05-06: compact, no horizontal drift. */
.crm-app,
.crm-app body,
.crm-main,
.main-content,
.crm-content,
.crm-page,
.view.active {
    max-width: 100% !important;
    overflow-x: hidden !important;
    overscroll-behavior-x: none !important;
}

.crm-app :is(.dashboard-section, .lead-report-card, .ops-panel, .invoice-table-card, .crm-modal-box, .energy-command-center, .energy-contract-card, .product-page-card) {
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 12px !important;
    box-shadow: none !important;
}

#view-home .dashboard-stats,
#view-home .quick-actions {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(184px, 1fr)) !important;
    gap: 12px !important;
}

#view-home .dashboard-stat,
#view-home .quick-action,
#view-home .dashboard-recent-row {
    min-width: 0 !important;
    border-radius: 12px !important;
}

#view-home .dashboard-section {
    padding: 18px 20px !important;
    margin-bottom: 16px !important;
}

#view-leads .lead-duplicates-manager .lead-report-card-head,
#view-leads .lead-duplicate-status-overview .lead-report-card-head,
#view-leads .lead-cost-card .lead-report-card-head {
    min-height: 0 !important;
    padding: 12px 16px !important;
    gap: 12px !important;
}

#view-leads .lead-duplicate-status-overview,
#view-leads .lead-duplicates-manager,
#view-leads .lead-cost-card {
    overflow: hidden !important;
}

#view-leads .lead-duplicate-commandbar {
    padding: 8px 12px !important;
}

#view-leads .lead-duplicate-workspace {
    display: grid !important;
    grid-template-columns: 208px minmax(0, 1fr) !important;
    gap: 0 !important;
    overflow: hidden !important;
}

#view-leads .lead-duplicate-supplier-panel {
    position: sticky !important;
    top: 8px !important;
    align-self: start !important;
    max-height: calc(100vh - 224px) !important;
    overflow-y: auto !important;
    border-right: 1px solid var(--md-outline-variant) !important;
    padding: 8px !important;
}

#view-leads .lead-duplicate-supplier-title {
    padding: 2px 2px 8px !important;
}

#view-leads .lead-duplicate-supplier-list {
    display: grid !important;
    gap: 6px !important;
}

#view-leads .lead-duplicate-supplier-list button {
    min-height: 42px !important;
    padding: 7px 8px !important;
    border-radius: 10px !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 6px !important;
}

#view-leads .lead-duplicate-supplier-list button span,
#view-leads .lead-duplicate-supplier-list button small {
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-leads .lead-duplicate-supplier-list button small {
    font-size: 10.5px !important;
    line-height: 1.2 !important;
}

#view-leads .lead-duplicate-table-panel,
#view-leads .lead-duplicate-worktable {
    min-width: 0 !important;
    overflow-x: hidden !important;
}

#view-leads .lead-duplicate-worktable {
    max-height: calc(100vh - 278px) !important;
    overflow-y: auto !important;
    border: 0 !important;
}

#view-leads .lead-duplicate-workrow {
    display: grid !important;
    grid-template-columns: minmax(128px, 1.2fr) minmax(122px, 1fr) minmax(154px, 1.1fr) 112px 86px minmax(160px, 1.25fr) 86px !important;
    gap: 6px !important;
    align-items: center !important;
    min-height: 48px !important;
    padding: 6px 8px !important;
    border-bottom: 1px solid var(--md-outline-variant) !important;
}

#view-leads .lead-duplicate-workrow.is-head {
    min-height: 30px !important;
    padding: 6px 8px !important;
    font-size: 10.5px !important;
}

#view-leads .lead-duplicate-workcell {
    gap: 2px !important;
    min-width: 0 !important;
    font-size: 12.5px !important;
}

#view-leads .lead-duplicate-workcell :is(strong, small, span) {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#view-leads .lead-duplicate-workcell small {
    display: -webkit-box !important;
    -webkit-line-clamp: 1 !important;
    -webkit-box-orient: vertical !important;
    white-space: normal !important;
}

#view-leads .lead-duplicate-workcell :is(select, input),
#view-leads .lead-claim-amount :is(span, input) {
    height: 30px !important;
    min-height: 30px !important;
    border-radius: 8px !important;
    font-size: 12px !important;
    padding: 0 8px !important;
}

#view-leads .lead-duplicate-line-editor {
    grid-template-columns: minmax(0, 0.8fr) minmax(0, 1fr) !important;
    gap: 4px !important;
}

#view-leads .lead-claim-amount {
    grid-template-columns: 30px minmax(0, 1fr) !important;
    gap: 4px !important;
}

#view-leads .lead-duplicate-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 4px !important;
}

#view-leads .lead-duplicate-actions .leads-small-btn {
    width: 100% !important;
    min-height: 28px !important;
    height: 28px !important;
    padding: 0 8px !important;
    font-size: 12px !important;
}

#view-leads .lead-cost-card {
    grid-column: 1 / -1 !important;
}

#view-leads .lead-cost-editor {
    max-height: 560px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 12px !important;
}

#view-leads .lead-cost-editor-head,
#view-leads .lead-cost-row {
    display: grid !important;
    grid-template-columns: minmax(142px, 1.05fr) minmax(178px, 1.05fr) 68px minmax(160px, 1fr) minmax(220px, 1.15fr) !important;
    gap: 8px !important;
    align-items: center !important;
    min-width: 0 !important;
}

#view-leads .lead-cost-row {
    min-height: 48px !important;
    padding: 7px 10px !important;
}

#view-leads .lead-cost-row > *,
#view-leads .lead-cost-row :is(strong, span, small) {
    min-width: 0 !important;
}

#view-leads .lead-cost-price label {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    clip: rect(0 0 0 0) !important;
}

#view-leads .lead-cost-input-row {
    display: grid !important;
    grid-template-columns: 36px minmax(74px, 1fr) 76px !important;
    gap: 6px !important;
    align-items: center !important;
}

#view-leads .lead-cost-input-row > span,
#view-leads .lead-cost-input-row input,
#view-leads .lead-cost-input-row .leads-small-btn {
    height: 30px !important;
    min-height: 30px !important;
    font-size: 12px !important;
}

#view-leads .lead-cost-input-row .leads-small-btn {
    padding: 0 8px !important;
    justify-content: center !important;
}

#view-facturen .invoice-table-head,
#view-facturen .invoice-row {
    grid-template-columns: minmax(180px, 1.25fr) minmax(220px, 1.45fr) 116px 142px 132px !important;
    gap: 10px !important;
    padding: 10px 14px !important;
}

#view-facturen .invoice-row :is(strong, span, small) {
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#view-energie .energy-domain-grid,
#view-energy-finance .energy-finance-grid,
#view-energy-finance .energy-finance-workbench-polished,
#view-energie-cijfers .energy-finance-grid,
#view-energie-cijfers .energy-finance-workbench-polished {
    grid-template-columns: minmax(0, 1fr) !important;
    overflow-x: hidden !important;
}

#view-energy-anomalies .energy-anomaly-list,
#view-energy-anomalies .energy-anomaly-row {
    max-width: 100% !important;
    overflow-x: hidden !important;
}

@media (max-width: 1280px) {
    #view-leads .lead-duplicate-workspace {
        grid-template-columns: 1fr !important;
    }

    #view-leads .lead-duplicate-supplier-panel {
        position: static !important;
        max-height: 160px !important;
        border-right: 0 !important;
        border-bottom: 1px solid var(--md-outline-variant) !important;
    }

    #view-leads .lead-duplicate-supplier-list {
        grid-template-columns: repeat(auto-fit, minmax(176px, 1fr)) !important;
    }

    #view-leads .lead-duplicate-workrow,
    #view-leads .lead-cost-editor-head,
    #view-leads .lead-cost-row,
    #view-facturen .invoice-table-head,
    #view-facturen .invoice-row {
        grid-template-columns: 1fr !important;
    }

    #view-leads .lead-duplicate-workrow.is-head,
    #view-leads .lead-cost-editor-head,
    #view-facturen .invoice-table-head {
        display: none !important;
    }
}

/* Producten: compacte Google-stijl met leadkosten/marketingkosten in marge. */
#view-products .product-catalog-legacy,
#view-products .product-legacy-section,
#view-products .product-legacy-table,
#view-products .product-category-block {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
}

#view-products .product-legacy-row {
    min-width: 0 !important;
    gap: 10px !important;
    padding: 9px 14px !important;
}

#view-products .product-legacy-row > span {
    min-width: 0 !important;
}

#view-products .product-legacy-row :is(strong, b, em, small) {
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#view-products .product-legacy-row small {
    display: block !important;
    white-space: nowrap !important;
}

#view-products .product-components-table .product-legacy-row {
    grid-template-columns: minmax(220px, 1.25fr) 128px minmax(170px, .85fr) 42px !important;
    min-width: 0 !important;
}

#view-products .product-margin-table .product-legacy-row {
    grid-template-columns: minmax(220px, 1.35fr) 106px 116px 106px minmax(132px, .75fr) minmax(132px, .8fr) !important;
    min-width: 0 !important;
}

#view-products .product-category-table .product-legacy-row {
    grid-template-columns: minmax(240px, 1.35fr) 110px 110px 110px 110px minmax(145px, .75fr) 72px !important;
    min-width: 0 !important;
}

#view-products .product-margin-table .product-legacy-row > span:nth-child(n+2),
#view-products .product-category-table .product-legacy-row > span:nth-child(n+3):not(:last-child),
#view-products .product-components-table .product-legacy-row > span:nth-child(2) {
    text-align: right !important;
}

#view-products .product-margin-controls {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: flex-end !important;
    gap: 8px !important;
}

#view-products .product-period-select,
#view-products .product-margin-controls .ifee-mon-select {
    height: 36px !important;
    max-width: 220px !important;
    border: 1px solid var(--md-outline) !important;
    border-radius: 18px !important;
    background: var(--md-surface) !important;
    padding: 0 12px !important;
    color: var(--md-on-surface) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
}

#view-products .product-report-refresh[disabled] {
    opacity: .55 !important;
    cursor: progress !important;
}

#view-products .product-margin-kpis {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
}

#view-products .product-margin-kpis > div {
    min-width: 0 !important;
    padding: 12px 14px !important;
}

#view-products .product-margin-kpis strong {
    font-size: 20px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#view-products .product-margin-kpis small,
#view-products .product-lead-cost-note {
    display: block !important;
    margin-top: 2px !important;
    color: var(--md-on-surface-variant) !important;
    font-size: 11px !important;
    font-weight: 400 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#view-products .product-muted-cost {
    color: var(--md-on-surface-variant) !important;
}

#view-products .product-edit-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

@media (max-width: 1180px) {
    #view-products .product-margin-kpis,
    #view-products .product-edit-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    #view-products .product-margin-controls {
        justify-content: flex-start !important;
    }
}

@media (max-width: 900px) {
    #view-products .product-components-table .product-legacy-row,
    #view-products .product-margin-table .product-legacy-row,
    #view-products .product-category-table .product-legacy-row {
        grid-template-columns: 1fr !important;
    }

    #view-products .product-legacy-row-head {
        display: none !important;
    }

    #view-products .product-margin-table .product-legacy-row > span:nth-child(n+2),
    #view-products .product-category-table .product-legacy-row > span:nth-child(n+3):not(:last-child),
    #view-products .product-components-table .product-legacy-row > span:nth-child(2) {
        text-align: left !important;
    }

    #view-products .product-margin-kpis,
    #view-products .product-edit-grid {
        grid-template-columns: 1fr !important;
    }
}

/* Responsive shell hardening 2026-05-07.
   This file is loaded last; keep the shell math here so the sidebar can never
   add its width on top of a 100vw content area. */
html,
body,
#app {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: clip !important;
}

body {
    margin: 0 !important;
}

.sidebar ~ .main-content,
.main-content,
.main-content > .page,
.main-content [id^="view-"] {
    box-sizing: border-box !important;
    min-width: 0 !important;
    overflow-x: clip !important;
}

.sidebar ~ .main-content {
    margin-right: 0 !important;
}

.main-content > .page {
    margin: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
}

@media (min-width: 1025px) {
    .sidebar:not(.is-collapsed) ~ .main-content {
        width: calc(100vw - 256px) !important;
        max-width: calc(100vw - 256px) !important;
        margin-left: 256px !important;
    }

    .sidebar.is-collapsed ~ .main-content {
        width: calc(100vw - 72px) !important;
        max-width: calc(100vw - 72px) !important;
        margin-left: 72px !important;
    }

    .main-content > .page {
        padding-inline: clamp(20px, 2vw, 32px) !important;
    }
}

@media (min-width: 768px) and (max-width: 1024px) {
    .sidebar.is-collapsed {
        width: 72px !important;
    }

    .sidebar:not(.is-collapsed) {
        width: clamp(224px, 30vw, 256px) !important;
    }

    .sidebar.is-collapsed ~ .main-content {
        width: calc(100vw - 72px) !important;
        max-width: calc(100vw - 72px) !important;
        margin-left: 72px !important;
    }

    .sidebar:not(.is-collapsed) ~ .main-content {
        width: calc(100vw - clamp(224px, 30vw, 256px)) !important;
        max-width: calc(100vw - clamp(224px, 30vw, 256px)) !important;
        margin-left: clamp(224px, 30vw, 256px) !important;
    }

    .main-content > .page {
        padding-inline: clamp(16px, 2.2vw, 24px) !important;
    }
}

@media (max-width: 767px) {
    .sidebar {
        left: 0 !important;
        width: min(88vw, 320px) !important;
        max-width: calc(100vw - 16px) !important;
        transform: translateX(-106%) !important;
    }

    .sidebar.open {
        transform: translateX(0) !important;
    }

    .sidebar ~ .main-content,
    .main-content {
        width: 100vw !important;
        max-width: 100vw !important;
        margin-left: 0 !important;
        padding-top: 64px !important;
        padding-bottom: 96px !important;
    }

    .main-content > .page {
        padding-inline: clamp(12px, 4vw, 18px) !important;
    }
}

.sidebar-link,
.sidebar-user,
.md3-bottom-nav__item,
.klanten-hub-tab,
.back-btn,
.ev-btn,
.leads-small-btn,
.bes-view-btn,
.invoice-action,
.form-table-card button,
.invoice-table-card button,
.crm-modal-actions button,
.product-actionbar-buttons button {
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: manual !important;
}

.sidebar-link {
    display: grid !important;
    grid-template-columns: 28px minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 12px !important;
    width: 100% !important;
    max-width: 100% !important;
}

.sidebar-link .material-symbols-rounded {
    grid-column: 1 !important;
    width: 28px !important;
    min-width: 28px !important;
    max-width: 28px !important;
    overflow: hidden !important;
}

.sidebar-link > span:not(.material-symbols-rounded):not(.sidebar-count):not(.sidebar-folder-chevron),
.sidebar-user-body strong,
.sidebar-user-body span,
.sidebar-folder-current {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
}

.sidebar-folder-current {
    justify-self: end !important;
    max-width: 76px !important;
    font-size: 11px !important;
}

.sidebar-folder-chevron {
    justify-self: end !important;
    width: 20px !important;
    min-width: 20px !important;
}

.sidebar-count {
    justify-self: end !important;
    width: auto !important;
    min-width: 22px !important;
    max-width: 44px !important;
    height: 22px !important;
    padding-inline: 6px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.sidebar.is-collapsed .sidebar-link {
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    gap: 0 !important;
}

.sidebar.is-collapsed .sidebar-link .material-symbols-rounded {
    grid-column: 1 !important;
}

.sidebar.is-collapsed .sidebar-link > span:not(.material-symbols-rounded),
.sidebar.is-collapsed .sidebar-count,
.sidebar.is-collapsed .sidebar-folder-current,
.sidebar.is-collapsed .sidebar-folder-chevron,
.sidebar.is-collapsed .sidebar-user-body {
    display: none !important;
}

.klanten-hub-tabs,
.bes-toolbar,
.bes-filters,
.invoice-status-tabs,
.product-actionbar-buttons,
.lead-duplicate-commandbar,
.energy-page-actions,
.back-bar {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: visible !important;
}

.klanten-hub-tab,
.back-btn,
.ev-btn,
.leads-small-btn,
.bes-view-btn,
.invoice-action {
    max-width: 100% !important;
    min-width: 0 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.klanten-hub-tab {
    flex: 1 1 150px !important;
    justify-content: center !important;
}

.bes-toolbar .back-btn,
.product-actionbar-buttons .ev-btn,
.lead-duplicate-commandbar .leads-small-btn {
    flex: 0 1 auto !important;
}

.main-content :is(h1, h2, h3, h4, strong, b, small, span, em, p, label, button, a) {
    word-break: normal !important;
    hyphens: manual !important;
}

.main-content :is(.chip, .pill, [class*="chip"], [class*="pill"], [class*="badge"], [class*="status"], [class*="tab"]) {
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    overflow-wrap: normal !important;
}

@media (max-width: 520px) {
    .klanten-hub-tab,
    .bes-toolbar .back-btn,
    .product-actionbar-buttons .ev-btn,
    .lead-duplicate-commandbar .leads-small-btn {
        flex-basis: 100% !important;
        width: 100% !important;
        justify-content: center !important;
    }

    .bes-view-btn,
    .invoice-status-tabs button {
        flex: 1 1 0 !important;
    }
}

.md3-bottom-nav {
    width: min(calc(100vw - 16px), 520px) !important;
    max-width: calc(100vw - 16px) !important;
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    overflow: hidden !important;
}

.md3-bottom-nav__item {
    min-width: 0 !important;
    max-width: 100% !important;
}

.md3-bottom-nav__item > span:last-child {
    width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-size: clamp(10px, 2.8vw, 12px) !important;
    line-height: 1.1 !important;
}

.sidebar-folder-toggle {
    grid-template-columns: 28px minmax(0, 1fr) minmax(0, 76px) 20px !important;
}

.sidebar.is-collapsed .sidebar-nav {
    padding-inline: 4px !important;
}

.sidebar.is-collapsed .sidebar-customer-group,
.sidebar.is-collapsed .sidebar-nav > div {
    width: 100% !important;
    max-width: 100% !important;
    margin-inline: 0 !important;
}

.notif-panel:not(.show),
#toast:not(.show) {
    visibility: hidden !important;
    pointer-events: none !important;
}

.notif-panel {
    width: min(380px, calc(100vw - 24px)) !important;
    max-width: calc(100vw - 24px) !important;
    right: 12px !important;
}

#toast {
    width: min(360px, calc(100vw - 24px)) !important;
    max-width: calc(100vw - 24px) !important;
    right: 12px !important;
}

@media (max-width: 420px) {
    .mobile-topbar {
        display: grid !important;
        grid-template-columns: 40px minmax(0, 1fr) auto !important;
        gap: 4px !important;
        padding-inline: 8px !important;
    }

    .mobile-brand {
        min-width: 0 !important;
        overflow: hidden !important;
    }

    .mobile-brand strong {
        min-width: 0 !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }

    .mobile-topbar > div:last-child {
        min-width: 0 !important;
        gap: 2px !important;
    }

    .mobile-menu-btn,
    .topbar-btn,
    .user-chip {
        width: 36px !important;
        min-width: 36px !important;
        height: 36px !important;
        padding: 0 !important;
    }

    .user-chip-avatar {
        width: 30px !important;
        height: 30px !important;
    }
}

#view-products .product-title-button,
#view-products .product-title-button strong {
    display: block !important;
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-products .prod-sku-badge,
#view-products .prod-inactive-badge,
#view-products .product-sd-state,
#view-products .product-kind-pill {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

@media (max-width: 520px) {
    #view-products .product-row:not(.head),
    #view-products .product-legacy-row:not(.product-legacy-row-head),
    #view-products .product-category-table .product-legacy-row,
    #view-products .product-components-table .product-legacy-row,
    #view-products .product-margin-table .product-legacy-row {
        grid-template-columns: 1fr !important;
    }

    #view-products .product-legacy-row > span,
    #view-products .product-row > span {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
    }
}

#view-energy-finance .energy-chart-card,
#view-energy-finance .energy-chart-card svg,
#view-energy-finance .energy-bar-chart,
#view-energy-finance .energy-bar-row {
    max-width: 100% !important;
    min-width: 0 !important;
}

#view-energy-finance .energy-chart-card {
    overflow: hidden !important;
}

#view-energy-finance .energy-chart-card svg {
    width: 100% !important;
}

@media (max-width: 760px) {
    #view-energy-finance .energy-bar-row {
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 6px !important;
    }

    #view-energy-finance .energy-bar-row b,
    #view-energy-finance .energy-bar-row span {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }

    #view-energy-finance .ops-table-row.energy-finance-row {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 6px !important;
        width: 100% !important;
        max-width: 100% !important;
        overflow: hidden !important;
    }

    #view-energy-finance .ops-table-row.energy-finance-row.ops-table-head {
        display: none !important;
    }

    #view-energy-finance .ops-table-row.energy-finance-row > span {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    #view-energy-finance .ops-table-row.energy-finance-row :is(strong, small) {
        display: block !important;
        max-width: 100% !important;
        min-width: 0 !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
    }
}

.klanten-hub-tab {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
}

.klanten-hub-tab .material-symbols-rounded {
    position: static !important;
    inset: auto !important;
    width: 18px !important;
    min-width: 18px !important;
    max-width: 18px !important;
    margin: 0 !important;
    transform: none !important;
    flex: 0 0 auto !important;
}

.invoice-status-tabs button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    min-width: 0 !important;
    overflow: hidden !important;
}

.invoice-status-tabs button span {
    position: static !important;
    inset: auto !important;
    transform: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    max-width: 3ch !important;
    min-width: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

@media (max-width: 520px) {
    .invoice-status-tabs {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 8px !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    .invoice-status-tabs button {
        width: 100% !important;
        max-width: 100% !important;
    }
}

#view-products .product-category-row,
#view-products .product-legacy-row,
#view-products .product-row {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
}

#view-products .product-category-row > span,
#view-products .product-legacy-row > span,
#view-products .product-row > span {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
}

#view-products .product-category-row > span:first-child,
#view-products .product-legacy-row > span:first-child,
#view-products .product-row > span:first-child {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 4px !important;
}

#view-products .product-title-button {
    width: 100% !important;
    max-width: 100% !important;
    justify-self: stretch !important;
    text-align: left !important;
}

#view-products .product-title-button strong {
    width: 100% !important;
    max-width: 100% !important;
}

#view-products .product-category-row :is(strong, small, span),
#view-products .product-legacy-row :is(strong, small, span),
#view-products .product-row :is(strong, small, span) {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

@media (max-width: 1280px) {
    .sidebar:not(.is-collapsed) ~ .main-content #view-products .product-category-table .product-legacy-row,
    .sidebar:not(.is-collapsed) ~ .main-content #view-products .product-legacy-row:not(.product-legacy-row-head) {
        grid-template-columns: minmax(0, 1fr) !important;
    }

    .sidebar:not(.is-collapsed) ~ .main-content #view-products .product-category-table .product-legacy-row.product-legacy-row-head,
    .sidebar:not(.is-collapsed) ~ .main-content #view-products .product-legacy-row-head {
        display: none !important;
    }
}

@media (max-width: 1024px) {
    #view-products .product-category-table .product-legacy-row,
    #view-products .product-legacy-row:not(.product-legacy-row-head) {
        grid-template-columns: minmax(0, 1fr) !important;
    }

    #view-products .product-category-table .product-legacy-row.product-legacy-row-head,
    #view-products .product-legacy-row-head {
        display: none !important;
    }
}

#view-energy-finance :is(.energy-kpi-grid, .energy-finance-kpis, .finance-kpis, .energy-command-kpis) {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(min(150px, 100%), 1fr)) !important;
    max-width: 100% !important;
    min-width: 0 !important;
}

#view-energy-finance .energy-kpi-card {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
}

#view-energy-finance .energy-kpi-card :is(strong, small, span) {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-energy-finance .ops-table {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
}

#view-energy-finance .ops-table-row.energy-finance-row {
    grid-template-columns: minmax(90px, .72fr) minmax(0, 1.25fr) minmax(72px, .5fr) minmax(82px, .55fr) minmax(72px, .45fr) !important;
    gap: 8px !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
}

#view-energy-finance .ops-table-row.energy-finance-row > span {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#view-energy-finance .ops-table-row.energy-finance-row :is(strong, small) {
    display: block !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

@media (max-width: 1024px) {
    #view-energy-finance .ops-table-row.energy-finance-row {
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 6px !important;
    }

    #view-energy-finance .ops-table-row.energy-finance-row.ops-table-head {
        display: none !important;
    }
}

@media (max-width: 767px) {
    .sidebar:not(.is-collapsed) ~ .main-content #view-home,
    .sidebar:not(.is-collapsed) ~ .main-content #view-leads,
    .sidebar:not(.is-collapsed) ~ .main-content #view-lead-duplicates,
    .sidebar:not(.is-collapsed) ~ .main-content #view-products,
    .sidebar:not(.is-collapsed) ~ .main-content #view-facturen,
    .sidebar:not(.is-collapsed) ~ .main-content #view-energie-klanten,
    .sidebar:not(.is-collapsed) ~ .main-content #view-energy-finance,
    .sidebar:not(.is-collapsed) ~ .main-content #view-energy-anomalies {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
    }

    .sidebar:not(.is-collapsed) ~ .main-content [id^="view-"],
    .sidebar ~ .main-content [id^="view-"],
    .main-content [id^="view-"],
    .main-content .view.active,
    #view-leads,
    #view-products,
    #view-facturen,
    #view-energy-finance {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        flex-basis: auto !important;
    }

    #view-leads,
    #view-products,
    #view-facturen,
    #view-energy-finance {
        padding-inline: 0 !important;
    }
}

#view-energy-finance .ops-kpis.energy-kpis,
#view-energy-finance .energy-kpis-polished {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(min(150px, 100%), 1fr)) !important;
    gap: 12px !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
}

#view-energy-finance .ops-kpis.energy-kpis .energy-kpi-card,
#view-energy-finance .energy-kpis-polished .energy-kpi-card {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding-inline: clamp(14px, 3vw, 20px) !important;
}

@media (max-width: 420px) {
    #view-energy-finance .ops-kpis.energy-kpis,
    #view-energy-finance .energy-kpis-polished {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 520px) {
    #view-facturen .invoice-status-tabs {
        display: grid !important;
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 8px !important;
        width: 100% !important;
        max-width: 100% !important;
        overflow: visible !important;
    }

    #view-facturen .invoice-status-tabs button {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        padding-inline: 8px !important;
    }

    #view-facturen .invoice-status-tabs button span {
        padding-inline: 4px !important;
        max-width: 2.75ch !important;
        flex: 0 0 auto !important;
    }
}

@media (max-width: 520px) {
    #view-leads .lead-report-card,
    #view-leads .lead-duplicate-status-overview,
    #view-leads .lead-duplicates-manager,
    #view-leads .lead-duplicate-table-panel {
        white-space: normal !important;
    }

    #view-leads .lead-report-card-head {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 10px !important;
        align-items: start !important;
        overflow: visible !important;
        white-space: normal !important;
    }

    #view-leads .lead-report-card-head > div,
    #view-leads .lead-report-card-head :is(h2, h3, p, span) {
        max-width: 100% !important;
        min-width: 0 !important;
        white-space: normal !important;
        overflow: visible !important;
        text-overflow: clip !important;
    }

    #view-leads .lead-report-head-actions {
        display: flex !important;
        flex-wrap: wrap !important;
        justify-content: flex-start !important;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        gap: 8px !important;
        white-space: normal !important;
        overflow: visible !important;
    }

    #view-leads .lead-report-head-actions > span {
        flex: 1 1 100% !important;
        white-space: normal !important;
        line-height: 1.35 !important;
    }

    #view-leads .lead-data-gap {
        display: grid !important;
        grid-template-columns: 32px minmax(0, 1fr) !important;
        align-items: start !important;
        white-space: normal !important;
        overflow: visible !important;
    }

    #view-leads .lead-data-gap p {
        white-space: normal !important;
        overflow: visible !important;
        text-overflow: clip !important;
        line-height: 1.35 !important;
    }
}

@media (max-width: 420px) {
    #view-energy-finance .ops-panel-head {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 10px !important;
        align-items: start !important;
        overflow: visible !important;
    }

    #view-energy-finance .ops-panel-head > div,
    #view-energy-finance .ops-panel-head :is(h2, h3, p, span) {
        max-width: 100% !important;
        min-width: 0 !important;
    }

    #view-energy-finance .ops-panel-head button {
        justify-self: start !important;
        min-width: max-content !important;
        max-width: 100% !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        padding-inline: 14px !important;
    }
}

/* Product marketingkosten en catalogusblokken */
#view-products .product-marketing-settings,
#view-products .product-tech-info,
#view-products .product-marketing-control,
#view-products .product-marketing-control-grid {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
}

#view-products .product-marketing-control-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, .9fr) minmax(0, 1.35fr) !important;
    gap: 14px !important;
}

#view-products .product-marketing-control {
    display: grid !important;
    gap: 8px !important;
}

#view-products .product-segment-list,
#view-products .product-source-list,
#view-products .product-marketing-refresh {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    align-items: center !important;
    min-width: 0 !important;
}

#view-products .product-marketing-refresh {
    justify-content: flex-end !important;
}

#view-products .product-segment,
#view-products .product-source-chip {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 0 !important;
    max-width: 100% !important;
    min-height: 32px !important;
    padding: 0 10px !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 8px !important;
    background: var(--md-surface) !important;
    color: var(--md-on-surface) !important;
    font-size: 12px !important;
    font-weight: 650 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-products .product-segment {
    gap: 6px !important;
    padding-block: 7px !important;
}

#view-products .product-segment.active,
#view-products .product-source-chip.active {
    border-color: var(--md-primary) !important;
    background: color-mix(in srgb, var(--md-primary) 10%, var(--md-surface)) !important;
    color: var(--md-primary) !important;
}

#view-products .product-date-range {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
}

#view-products .product-date-range label {
    display: grid !important;
    gap: 4px !important;
    min-width: 0 !important;
    font-size: 12px !important;
    font-weight: 650 !important;
}

#view-products .product-date-range input {
    width: 100% !important;
    min-width: 0 !important;
    height: 34px !important;
}

#view-products .product-marketing-infobar {
    display: grid !important;
    gap: 3px !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 0 12px !important;
    padding: 12px 14px !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 8px !important;
    background: color-mix(in srgb, var(--md-primary) 6%, var(--md-surface)) !important;
    color: var(--md-on-surface) !important;
    text-align: left !important;
    cursor: pointer !important;
}

#view-products .product-marketing-infobar :is(strong, span),
#view-products .product-marketing-control :is(strong, small),
#view-products .product-marketing-refresh span {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-products .product-margin-table .product-legacy-row {
    grid-template-columns: minmax(190px, 1.22fr) 94px 112px 102px minmax(128px, .8fr) 112px 76px !important;
}

#view-products .product-margin-table .product-legacy-row > span:nth-child(n+2) {
    text-align: right !important;
}

#view-products .product-drawer-summary,
#view-products .product-drawer-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(min(180px, 100%), 1fr)) !important;
    gap: 10px !important;
    max-width: 100% !important;
}

#view-products .product-profit-lines {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(min(150px, 100%), 1fr)) !important;
    gap: 8px !important;
    max-width: 100% !important;
    min-width: 0 !important;
}

#view-products .product-profit-lines > div {
    min-width: 0 !important;
    padding: 10px !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 8px !important;
    background: var(--md-surface) !important;
}

#view-products .product-profit-lines :is(span, strong, small) {
    display: block !important;
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-products .product-drawer-summary > span,
#view-products .product-breakdown-row {
    min-width: 0 !important;
    padding: 10px !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 8px !important;
    background: var(--md-surface) !important;
}

#view-products .product-breakdown-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 10px !important;
    align-items: center !important;
    margin-top: 8px !important;
}

#view-products .product-drawer-summary :is(strong, small),
#view-products .product-breakdown-row :is(strong, small, span) {
    display: block !important;
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-products .product-marketing-drawer-box {
    width: min(880px, calc(100vw - 24px)) !important;
    max-width: calc(100vw - 24px) !important;
}

#view-products :is(.product-marketing-settings, .product-margin-section, .product-catalog-list, .product-tech-info) {
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: none !important;
}

@media (max-width: 1024px) {
    #view-products .product-marketing-control-grid,
    #view-products .product-drawer-grid,
    #view-products .product-margin-table .product-legacy-row {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 620px) {
    #view-products .product-segment-list,
    #view-products .product-source-list,
    #view-products .product-actionbar-buttons,
    #view-products .product-margin-controls {
        display: grid !important;
        grid-template-columns: 1fr !important;
        width: 100% !important;
    }

    #view-products .product-segment,
    #view-products .product-source-chip,
    #view-products .product-actionbar-buttons > *,
    #view-products .product-margin-controls > * {
        width: 100% !important;
        justify-content: center !important;
    }

    #view-products .product-date-range,
    #view-products .product-breakdown-row {
        grid-template-columns: 1fr !important;
    }

    #view-products .product-breakdown-row > span:last-child {
        text-align: left !important;
    }
}

/* CRM hotfixes 07-05: keep overlays, close controls and toasts viewport-safe. */
.crm-modal:not(.show) {
    display: none !important;
}

.crm-modal-close,
.template-modal .crm-modal-close,
.rp-search-clear {
    font-size: 0 !important;
    overflow: hidden !important;
    text-indent: 0 !important;
    white-space: nowrap !important;
}

.crm-modal-close::before,
.template-modal .crm-modal-close::before,
.rp-search-clear::before {
    content: "\00d7" !important;
    font-family: Arial, "Google Sans", sans-serif !important;
    font-size: 24px !important;
    font-weight: 500 !important;
    line-height: 1 !important;
    font-variation-settings: normal !important;
}

.rp-search-clear::before {
    font-size: 18px !important;
}

.toast,
#toast {
    width: min(360px, calc(100vw - 24px)) !important;
    max-width: calc(100vw - 24px) !important;
    right: max(12px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(12px, env(safe-area-inset-bottom, 0px)) !important;
    box-sizing: border-box !important;
    opacity: 0 !important;
    transform: translateY(10px) !important;
    transition: opacity 180ms ease, transform 180ms ease !important;
}

.toast.show,
#toast.show {
    opacity: 1 !important;
    transform: translateY(0) !important;
}

.toast-content,
.toast-content strong,
.toast-content span {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#view-team-agenda .tg-mm-hd {
    min-width: 0 !important;
    white-space: nowrap !important;
}

#view-tickets .ticket-stat-card:not(.ticket-stat-urgent) strong,
#view-tickets .ticket-stat-card:not(.ticket-stat-urgent) span {
    color: inherit !important;
}

/* Customer pipeline and kanban board. */
#view-bestellingen .bes-customer-titleline {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    min-width: 0 !important;
    max-width: 100% !important;
}

#view-bestellingen .bes-customer-titleline strong {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-bestellingen .bes-pipeline-pill {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 auto !important;
    min-height: 24px !important;
    max-width: 148px !important;
    padding: 3px 9px !important;
    border-radius: 999px !important;
    background: var(--md-surface-container) !important;
    color: var(--md-on-surface-variant) !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-bestellingen .bes-pipeline-pill.is-schouw {
    background: #E8F0FE !important;
    color: #185ABC !important;
}

#view-bestellingen .bes-pipeline-pill.is-installatie {
    background: #FEF7E0 !important;
    color: #8A5A00 !important;
}

#view-bestellingen .bes-pipeline-pill.is-oplevering {
    background: #E6F4EA !important;
    color: #137333 !important;
}

#view-bestellingen .bes-kanban-board {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(220px, 1fr)) !important;
    gap: 12px !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: auto !important;
    padding-bottom: 8px !important;
}

#view-bestellingen .bes-kanban-column {
    display: flex !important;
    flex-direction: column !important;
    min-width: 0 !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 8px !important;
    background: var(--md-surface-container-lowest, #fff) !important;
    overflow: hidden !important;
}

#view-bestellingen .bes-kanban-head {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    padding: 12px !important;
    border-bottom: 1px solid var(--md-outline-variant) !important;
    background: var(--md-surface-container) !important;
}

#view-bestellingen .bes-kanban-head div {
    display: grid !important;
    gap: 2px !important;
    min-width: 0 !important;
}

#view-bestellingen .bes-kanban-head :is(strong, span) {
    display: block !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-bestellingen .bes-kanban-head strong {
    font-size: 14px !important;
    font-weight: 500 !important;
    color: var(--md-on-surface) !important;
}

#view-bestellingen .bes-kanban-head span {
    font-size: 11px !important;
    color: var(--md-on-surface-variant) !important;
}

#view-bestellingen .bes-kanban-head b {
    display: grid !important;
    place-items: center !important;
    width: 30px !important;
    height: 30px !important;
    border-radius: 50% !important;
    background: var(--md-surface) !important;
    color: var(--md-on-surface) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
}

#view-bestellingen .bes-kanban-items {
    display: grid !important;
    gap: 10px !important;
    align-content: start !important;
    padding: 10px !important;
    min-height: 160px !important;
}

#view-bestellingen .bes-kanban-items > p {
    margin: 0 !important;
    padding: 12px !important;
    border: 1px dashed var(--md-outline-variant) !important;
    border-radius: 8px !important;
    color: var(--md-on-surface-variant) !important;
    font-size: 12px !important;
}

#view-bestellingen .bes-customer-row.is-kanban {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    padding: 12px !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 8px !important;
    background: var(--md-surface) !important;
    text-align: left !important;
}

#view-bestellingen .bes-customer-row.is-kanban .bes-customer-meta {
    justify-content: flex-start !important;
    text-align: left !important;
}

#view-bestellingen .bes-customer-row.is-kanban .bes-customer-actions {
    width: 100% !important;
    justify-content: flex-start !important;
    margin-top: 8px !important;
}

#view-bestellingen .bes-customer-row.is-kanban .bes-open-action {
    flex: 1 1 auto !important;
    min-width: 118px !important;
}

#view-bestellingen .bes-stat[data-empty="true"] {
    border-color: var(--md-outline-variant, #E8EAED) !important;
    background: var(--md-surface-container-lowest, #FFFFFF) !important;
    color: var(--md-on-surface-variant, #5F6368) !important;
    box-shadow: none !important;
}

#view-bestellingen .bes-stat[data-empty="true"] .bes-stat-value {
    color: #9AA0A6 !important;
    font-weight: 500 !important;
}

#view-bestellingen .bes-stat[data-empty="true"] span {
    color: var(--md-on-surface-variant, #5F6368) !important;
}

#view-bestellingen .bes-stat[data-empty="true"].active {
    border-color: #DADCE0 !important;
    background: #F8F9FA !important;
    color: var(--md-on-surface-variant, #5F6368) !important;
}

#view-financiering .fin-toolbar .back-btn:disabled {
    opacity: .55 !important;
    cursor: not-allowed !important;
    box-shadow: none !important;
}

@media (max-width: 1180px) {
    #view-bestellingen .bes-kanban-board {
        grid-template-columns: repeat(2, minmax(220px, 1fr)) !important;
        overflow-x: hidden !important;
    }
}

@media (max-width: 680px) {
    #view-bestellingen .bes-kanban-board {
        grid-template-columns: 1fr !important;
    }

    #view-bestellingen .bes-customer-titleline {
        align-items: flex-start !important;
        flex-direction: column !important;
    }

    #view-bestellingen .bes-pipeline-pill {
        max-width: 100% !important;
    }
}

#view-leads .lead-advice-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 12px !important;
}

#view-leads .lead-advice-grid article {
    min-width: 0 !important;
    padding: 14px !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 18px !important;
    background: color-mix(in srgb, var(--md-primary-container) 18%, #fff) !important;
}

#view-leads .lead-advice-grid article span {
    display: block !important;
    color: var(--md-on-surface-variant) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: .02em !important;
    text-transform: uppercase !important;
}

#view-leads .lead-advice-grid article strong {
    display: block !important;
    margin-top: 8px !important;
    color: var(--md-on-surface) !important;
    font-size: 18px !important;
    font-weight: 650 !important;
    line-height: 1.25 !important;
}

#view-leads .lead-advice-grid article p {
    margin: 8px 0 0 !important;
    color: var(--md-on-surface-variant) !important;
    font-size: 13px !important;
    line-height: 1.45 !important;
}

#view-leads .lead-mini-table.lead-region-performance-table .lead-mini-head,
#view-leads .lead-mini-table.lead-region-performance-table .lead-mini-row,
#view-leads .lead-mini-table.lead-conversion-table .lead-mini-head,
#view-leads .lead-mini-table.lead-conversion-table .lead-mini-row {
    grid-template-columns: minmax(150px, 1.25fr) minmax(64px, .45fr) minmax(74px, .5fr) minmax(96px, .65fr) minmax(92px, .75fr) !important;
    min-width: 0 !important;
}

#view-leads .lead-mini-table.lead-region-performance-table .lead-mini-row span,
#view-leads .lead-mini-table.lead-conversion-table .lead-mini-row span {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#view-leads .lead-mini-table.lead-region-performance-table small {
    display: block !important;
    margin-top: 2px !important;
    color: var(--md-on-surface-variant) !important;
    font-size: 11px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

@media (max-width: 980px) {
    #view-leads .lead-advice-grid {
        grid-template-columns: 1fr !important;
    }

    #view-leads .lead-mini-table.lead-region-performance-table .lead-mini-head,
    #view-leads .lead-mini-table.lead-region-performance-table .lead-mini-row,
    #view-leads .lead-mini-table.lead-conversion-table .lead-mini-head,
    #view-leads .lead-mini-table.lead-conversion-table .lead-mini-row {
        grid-template-columns: minmax(136px, 1.35fr) minmax(56px, .42fr) minmax(70px, .52fr) minmax(88px, .68fr) !important;
    }

    #view-leads .lead-mini-table.lead-region-performance-table .lead-mini-head span:nth-child(5),
    #view-leads .lead-mini-table.lead-region-performance-table .lead-mini-row span:nth-child(5),
    #view-leads .lead-mini-table.lead-conversion-table .lead-mini-head span:nth-child(5),
    #view-leads .lead-mini-table.lead-conversion-table .lead-mini-row span:nth-child(5) {
        display: none !important;
    }
}

/* CRM hotfix 07-05: keep dialogs beside the desktop sidebar and preserve labels. */
@media (min-width: 1025px) {
    #app > .sidebar:not(.is-collapsed) ~ .main-content .crm-modal.show,
    .crm-app .sidebar:not(.is-collapsed) ~ .main-content .crm-modal.show {
        inset: 0 0 0 256px !important;
        width: auto !important;
        max-width: none !important;
        padding: 24px !important;
    }

    #app > .sidebar.is-collapsed ~ .main-content .crm-modal.show,
    .crm-app .sidebar.is-collapsed ~ .main-content .crm-modal.show {
        inset: 0 0 0 72px !important;
        width: auto !important;
        max-width: none !important;
        padding: 24px !important;
    }
}

@media (min-width: 768px) and (max-width: 1024px) {
    #app > .sidebar:not(.is-collapsed) ~ .main-content .crm-modal.show,
    .crm-app .sidebar:not(.is-collapsed) ~ .main-content .crm-modal.show {
        inset: 0 0 0 clamp(224px, 30vw, 256px) !important;
        width: auto !important;
        max-width: none !important;
        padding: 18px !important;
    }

    #app > .sidebar.is-collapsed ~ .main-content .crm-modal.show,
    .crm-app .sidebar.is-collapsed ~ .main-content .crm-modal.show {
        inset: 0 0 0 72px !important;
        width: auto !important;
        max-width: none !important;
        padding: 18px !important;
    }
}

@media (max-width: 767px) {
    #app > .main-content .crm-modal.show,
    .crm-app .main-content .crm-modal.show {
        inset: 0 !important;
        width: auto !important;
        max-width: none !important;
        padding: 12px !important;
    }
}

#app > .main-content .crm-modal-box,
.crm-app .main-content .crm-modal-box {
    width: min(1120px, 100%) !important;
}

#app > .main-content .crm-modal-body,
.crm-app .main-content .crm-modal-body {
    overflow-x: hidden !important;
}

#app > .sidebar:not(.is-collapsed) .sidebar-folder-current,
.crm-app .sidebar:not(.is-collapsed) .sidebar-folder-current {
    display: none !important;
}

#app > .sidebar:not(.is-collapsed) .sidebar-folder-toggle,
.crm-app .sidebar:not(.is-collapsed) .sidebar-folder-toggle {
    grid-template-columns: 28px minmax(0, 1fr) 20px !important;
}

/* CRM hotfix 07-05 09:00: customer dialogs must never expose Material text or clip titles. */
.crm-app .crm-modal.show,
#app .crm-modal.show {
    position: fixed !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
    background: transparent !important;
}

.crm-app .crm-modal-overlay,
#app .crm-modal-overlay {
    position: absolute !important;
    inset: 0 !important;
    background: rgba(32, 33, 36, 0.56) !important;
    backdrop-filter: blur(2px) !important;
}

.crm-app .crm-modal-box,
#app .crm-modal-box {
    position: relative !important;
    z-index: 2 !important;
    display: flex !important;
    flex-direction: column !important;
    width: min(1080px, 100%) !important;
    max-width: 100% !important;
    max-height: calc(100dvh - 48px) !important;
    overflow: hidden !important;
    margin: 0 auto !important;
    transform: none !important;
}

.crm-app .crm-modal-head,
#app .crm-modal-head {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 44px !important;
    align-items: center !important;
    gap: 16px !important;
    min-height: 68px !important;
    padding: 16px 22px !important;
    overflow: hidden !important;
}

.crm-app .crm-modal-head :is(h2, h3),
#app .crm-modal-head :is(h2, h3) {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
}

.crm-app .crm-modal-close,
#app .crm-modal-close {
    display: grid !important;
    place-items: center !important;
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    min-height: 40px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 50% !important;
    background: transparent !important;
    color: var(--md-on-surface-variant) !important;
    font-size: 0 !important;
    line-height: 0 !important;
    text-indent: 0 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
}

.crm-app .crm-modal-close::before,
#app .crm-modal-close::before {
    content: "\00d7" !important;
    display: block !important;
    font-family: Arial, "Google Sans", sans-serif !important;
    font-size: 30px !important;
    font-weight: 400 !important;
    line-height: 1 !important;
    transform: translateY(-1px) !important;
}

.crm-app .crm-modal-close:hover,
#app .crm-modal-close:hover {
    background: var(--md-surface-container) !important;
    color: var(--md-on-surface) !important;
}

@media (min-width: 1025px) {
    #app > .sidebar:not(.is-collapsed) ~ .main-content .crm-modal.show,
    .crm-app .sidebar:not(.is-collapsed) ~ .main-content .crm-modal.show {
        inset: 0 0 0 256px !important;
        padding: 24px !important;
    }

    #app > .sidebar.is-collapsed ~ .main-content .crm-modal.show,
    .crm-app .sidebar.is-collapsed ~ .main-content .crm-modal.show {
        inset: 0 0 0 72px !important;
        padding: 24px !important;
    }
}

@media (min-width: 768px) and (max-width: 1024px) {
    #app > .sidebar:not(.is-collapsed) ~ .main-content .crm-modal.show,
    .crm-app .sidebar:not(.is-collapsed) ~ .main-content .crm-modal.show {
        inset: 0 0 0 clamp(224px, 30vw, 256px) !important;
        padding: 18px !important;
    }

    #app > .sidebar.is-collapsed ~ .main-content .crm-modal.show,
    .crm-app .sidebar.is-collapsed ~ .main-content .crm-modal.show {
        inset: 0 0 0 72px !important;
        padding: 18px !important;
    }
}

@media (max-width: 767px) {
    #app > .main-content .crm-modal.show,
    .crm-app .main-content .crm-modal.show {
        inset: 0 !important;
        padding: 12px !important;
    }

    .crm-app .crm-modal-box,
    #app .crm-modal-box {
        max-height: calc(100dvh - 24px) !important;
        border-radius: 16px !important;
    }

    .crm-app .crm-modal-head,
    #app .crm-modal-head {
        min-height: 60px !important;
        padding: 12px 14px !important;
    }
}

/* CRM hotfix 07-05 09:30: Material-style IA refresh for the primary menu. */
#app > .sidebar .sidebar-nav,
.crm-app .sidebar .sidebar-nav {
    display: grid !important;
    gap: 6px !important;
    padding: 8px 10px 14px !important;
}

#app > .sidebar .sidebar-nav-group,
.crm-app .sidebar .sidebar-nav-group {
    min-width: 0 !important;
}

#app > .sidebar .sidebar-group-toggle,
.crm-app .sidebar .sidebar-group-toggle {
    appearance: none !important;
    display: grid !important;
    grid-template-columns: 28px minmax(0, 1fr) 22px !important;
    align-items: center !important;
    gap: 10px !important;
    width: 100% !important;
    min-height: 44px !important;
    padding: 0 12px !important;
    border: 0 !important;
    border-radius: 22px !important;
    background: transparent !important;
    color: var(--md-on-surface-variant) !important;
    font: inherit !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    text-align: left !important;
    cursor: pointer !important;
}

#app > .sidebar .sidebar-group-toggle > span:nth-child(2),
.crm-app .sidebar .sidebar-group-toggle > span:nth-child(2) {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#app > .sidebar .sidebar-group-toggle:hover,
.crm-app .sidebar .sidebar-group-toggle:hover,
#app > .sidebar .sidebar-group-toggle.active,
.crm-app .sidebar .sidebar-group-toggle.active {
    background: var(--md-primary-container) !important;
    color: var(--md-primary) !important;
}

#app > .sidebar .sidebar-group-chevron,
.crm-app .sidebar .sidebar-group-chevron {
    justify-self: end !important;
    transition: transform .16s ease !important;
}

#app > .sidebar .sidebar-nav-group.is-open .sidebar-group-chevron,
.crm-app .sidebar .sidebar-nav-group.is-open .sidebar-group-chevron {
    transform: rotate(180deg) !important;
}

#app > .sidebar .sidebar-group-links,
.crm-app .sidebar .sidebar-group-links {
    display: grid !important;
    gap: 2px !important;
    margin: 4px 0 8px 18px !important;
    padding-left: 8px !important;
    border-left: 1px solid var(--md-outline-variant) !important;
}

#app > .sidebar .sidebar-group-links .sidebar-link--material,
.crm-app .sidebar .sidebar-group-links .sidebar-link--material {
    min-height: 38px !important;
    height: auto !important;
    grid-template-columns: 26px minmax(0, 1fr) auto !important;
    gap: 10px !important;
    padding: 0 10px !important;
    border-radius: 19px !important;
    font-size: 13px !important;
}

#app > .sidebar .sidebar-group-links .sidebar-link--material > span:not(.material-symbols-rounded):not(.sidebar-count),
.crm-app .sidebar .sidebar-group-links .sidebar-link--material > span:not(.material-symbols-rounded):not(.sidebar-count) {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#app > .sidebar.is-collapsed .sidebar-nav,
.crm-app .sidebar.is-collapsed .sidebar-nav {
    padding-inline: 8px !important;
}

#app > .sidebar.is-collapsed .sidebar-group-toggle,
.crm-app .sidebar.is-collapsed .sidebar-group-toggle {
    grid-template-columns: 1fr !important;
    justify-items: center !important;
    width: 48px !important;
    min-height: 48px !important;
    padding: 0 !important;
    margin-inline: auto !important;
}

#app > .sidebar.is-collapsed:not(.open) .sidebar-group-toggle > span:not(.material-symbols-rounded:first-child),
.crm-app .sidebar.is-collapsed:not(.open) .sidebar-group-toggle > span:not(.material-symbols-rounded:first-child),
#app > .sidebar.is-collapsed:not(.open) .sidebar-group-links,
.crm-app .sidebar.is-collapsed:not(.open) .sidebar-group-links {
    display: none !important;
}

/* CRM hotfix 07-05 09:30: reduce customer filter density without hiding power filters. */
#view-bestellingen .bes-filters {
    align-items: center !important;
    gap: 8px !important;
}

#view-bestellingen .bes-search {
    flex: 1 1 320px !important;
    min-width: min(320px, 100%) !important;
}

#view-bestellingen .bes-filters .form-select {
    flex: 0 1 190px !important;
    min-width: min(190px, 100%) !important;
}

#view-bestellingen .bes-more-filter-btn {
    appearance: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    min-height: 42px !important;
    max-width: 100% !important;
    padding: 0 14px !important;
    border: 1px solid #DADCE0 !important;
    border-radius: 999px !important;
    background: #fff !important;
    color: var(--md-on-surface) !important;
    font-weight: 800 !important;
    white-space: nowrap !important;
    cursor: pointer !important;
}

#view-bestellingen .bes-more-filter-btn:hover,
#view-bestellingen .bes-more-filter-btn.active {
    background: var(--md-primary-container) !important;
    border-color: var(--md-primary-container) !important;
    color: var(--md-primary) !important;
}

#view-bestellingen .bes-more-filter-btn strong {
    display: grid !important;
    place-items: center !important;
    min-width: 22px !important;
    height: 22px !important;
    padding: 0 6px !important;
    border-radius: 999px !important;
    background: var(--md-primary) !important;
    color: #fff !important;
    font-size: 12px !important;
    line-height: 1 !important;
}

#view-bestellingen .bes-advanced-filters {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
    gap: 10px !important;
    width: 100% !important;
    margin: 10px 0 0 !important;
    padding: 12px !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 16px !important;
    background: var(--md-surface-container-low) !important;
}

#view-bestellingen .bes-advanced-filters .form-select {
    width: 100% !important;
    min-width: 0 !important;
}

@media (max-width: 720px) {
    #view-bestellingen .bes-more-filter-btn,
    #view-bestellingen .bes-filter-reset,
    #view-bestellingen .bes-filter-summary {
        width: 100% !important;
    }

    #view-bestellingen .bes-more-filter-btn,
    #view-bestellingen .bes-filter-reset {
        justify-content: center !important;
    }
}

/* CRM motion 07-05 10:00: Material 3 sidebar submenu animation. */
#app > .sidebar,
.crm-app .sidebar {
    transition: width 250ms cubic-bezier(0.4, 0, 0.2, 1) !important;
    overflow-x: hidden !important;
}

#app > .sidebar[data-labels-hidden="true"],
.crm-app .sidebar[data-labels-hidden="true"] {
    transition-delay: 100ms !important;
}

#app > .sidebar .nav-label,
.crm-app .sidebar .nav-label,
#app > .sidebar .sidebar-user-body,
.crm-app .sidebar .sidebar-user-body,
#app > .sidebar .brand-text,
.crm-app .sidebar .brand-text {
    opacity: 1 !important;
    transition: opacity 100ms ease-out !important;
}

#app > .sidebar[data-labels-hidden="true"] .nav-label,
.crm-app .sidebar[data-labels-hidden="true"] .nav-label,
#app > .sidebar[data-labels-hidden="true"] .sidebar-user-body,
.crm-app .sidebar[data-labels-hidden="true"] .sidebar-user-body,
#app > .sidebar[data-labels-hidden="true"] .brand-text,
.crm-app .sidebar[data-labels-hidden="true"] .brand-text,
#app > .sidebar[data-collapsed="true"] .nav-label,
.crm-app .sidebar[data-collapsed="true"] .nav-label {
    opacity: 0 !important;
}

#app > .sidebar .sidebar-group-toggle,
.crm-app .sidebar .sidebar-group-toggle,
#app > .sidebar .nav-item,
.crm-app .sidebar .nav-item {
    transition: background-color 150ms ease, color 150ms ease !important;
}

#app > .sidebar .expand-chevron,
.crm-app .sidebar .expand-chevron {
    transition: transform 200ms cubic-bezier(0.4, 0, 0.2, 1) !important;
    transform-origin: center !important;
}

#app > .sidebar .sidebar-group-toggle[aria-expanded="true"] .expand-chevron,
.crm-app .sidebar .sidebar-group-toggle[aria-expanded="true"] .expand-chevron {
    transform: rotate(180deg) !important;
}

#app > .sidebar .nav-submenu,
.crm-app .sidebar .nav-submenu {
    display: grid !important;
    grid-template-rows: 0fr !important;
    gap: 0 !important;
    margin: 0 0 0 18px !important;
    padding-left: 8px !important;
    border-left: 1px solid var(--md-outline-variant) !important;
    opacity: 0 !important;
    overflow: hidden !important;
    pointer-events: none !important;
    transition:
        grid-template-rows 240ms cubic-bezier(0.2, 0, 0, 1),
        opacity 160ms ease-out,
        margin-block 240ms cubic-bezier(0.2, 0, 0, 1) !important;
}

#app > .sidebar .nav-submenu[data-open="true"],
#app > .sidebar .sidebar-group-toggle[aria-expanded="true"] + .nav-submenu,
.crm-app .sidebar .nav-submenu[data-open="true"],
.crm-app .sidebar .sidebar-group-toggle[aria-expanded="true"] + .nav-submenu {
    grid-template-rows: 1fr !important;
    margin: 4px 0 8px 18px !important;
    opacity: 1 !important;
    pointer-events: auto !important;
}

#app > .sidebar .nav-submenu > .nav-submenu-inner,
.crm-app .sidebar .nav-submenu > .nav-submenu-inner {
    display: grid !important;
    gap: 2px !important;
    min-height: 0 !important;
    overflow: hidden !important;
}

#app > .sidebar .nav-submenu .nav-item,
.crm-app .sidebar .nav-submenu .nav-item {
    opacity: 0 !important;
    transform: translateY(-4px) !important;
    transition:
        opacity 180ms ease-out,
        transform 180ms ease-out,
        background-color 150ms ease,
        color 150ms ease !important;
}

#app > .sidebar .sidebar-group-toggle[aria-expanded="true"] + .nav-submenu .nav-item,
#app > .sidebar .nav-submenu[data-open="true"] .nav-item,
.crm-app .sidebar .sidebar-group-toggle[aria-expanded="true"] + .nav-submenu .nav-item,
.crm-app .sidebar .nav-submenu[data-open="true"] .nav-item {
    opacity: 1 !important;
    transform: none !important;
    transition-delay: calc(var(--i, 0) * 30ms), calc(var(--i, 0) * 30ms), 0ms, 0ms !important;
}

#app > .sidebar.is-collapsed .nav-submenu,
.crm-app .sidebar.is-collapsed .nav-submenu {
    display: none !important;
}

@media (prefers-reduced-motion: reduce) {
    #app > .sidebar,
    .crm-app .sidebar,
    #app > .sidebar .nav-submenu,
    .crm-app .sidebar .nav-submenu,
    #app > .sidebar .nav-submenu .nav-item,
    .crm-app .sidebar .nav-submenu .nav-item,
    #app > .sidebar .expand-chevron,
    .crm-app .sidebar .expand-chevron,
    #app > .sidebar .nav-label,
    .crm-app .sidebar .nav-label,
    #app > .sidebar .sidebar-user-body,
    .crm-app .sidebar .sidebar-user-body,
    #app > .sidebar .brand-text,
    .crm-app .sidebar .brand-text {
        transition: none !important;
        animation: none !important;
    }
}

.email-hub-actions {
    justify-content: flex-end !important;
    margin: -6px 0 16px !important;
}

.leads-actionbar .leads-primary-btn .material-symbols-rounded {
    font-size: 18px !important;
    line-height: 1 !important;
}

/* CRM hotfix 07-05 11:35: keep the primary sidebar on one screen, no inner scroll. */
#app > .sidebar,
.crm-app .sidebar {
    height: 100dvh !important;
    max-height: 100dvh !important;
    display: grid !important;
    grid-template-rows: 84px 44px minmax(0, 1fr) 76px !important;
    overflow: hidden !important;
}

#app > .sidebar .sidebar-brand,
.crm-app .sidebar .sidebar-brand {
    min-height: 84px !important;
    height: 84px !important;
    padding: 10px 16px !important;
}

#app > .sidebar .sidebar-brand .brand-mark,
.crm-app .sidebar .sidebar-brand .brand-mark {
    width: 48px !important;
    height: 48px !important;
    min-width: 48px !important;
}

#app > .sidebar .md3-sidebar-toggle,
.crm-app .sidebar .md3-sidebar-toggle {
    width: 44px !important;
    height: 44px !important;
    min-height: 44px !important;
    margin: 0 0 0 18px !important;
}

#app > .sidebar .sidebar-nav,
.crm-app .sidebar .sidebar-nav {
    align-content: stretch !important;
    align-self: stretch !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    gap: clamp(5px, 1.2vh, 14px) !important;
    height: 100% !important;
    min-height: 0 !important;
    padding: clamp(8px, 1.4vh, 18px) 10px clamp(10px, 1.8vh, 22px) !important;
    overflow: hidden !important;
    overscroll-behavior: none !important;
}

#app > .sidebar .sidebar-nav-group,
.crm-app .sidebar .sidebar-nav-group {
    flex: 0 1 auto !important;
}

#app > .sidebar .sidebar-nav:has(.sidebar-nav-group.is-open),
.crm-app .sidebar .sidebar-nav:has(.sidebar-nav-group.is-open) {
    justify-content: space-between !important;
}

#app > .sidebar .sidebar-group-toggle,
.crm-app .sidebar .sidebar-group-toggle {
    min-height: clamp(40px, 5vh, 54px) !important;
    height: clamp(40px, 5vh, 54px) !important;
    border-radius: 999px !important;
    padding: 0 12px !important;
    font-size: clamp(13px, 1.9vh, 17px) !important;
}

#app > .sidebar .sidebar-nav:has(.sidebar-nav-group.is-open) .sidebar-group-toggle,
.crm-app .sidebar .sidebar-nav:has(.sidebar-nav-group.is-open) .sidebar-group-toggle {
    min-height: clamp(36px, 4.25vh, 46px) !important;
    height: clamp(36px, 4.25vh, 46px) !important;
}

#app > .sidebar .sidebar-group-toggle .material-symbols-rounded,
.crm-app .sidebar .sidebar-group-toggle .material-symbols-rounded {
    font-size: 23px !important;
}

#app > .sidebar .nav-submenu[data-open="true"],
#app > .sidebar .sidebar-group-toggle[aria-expanded="true"] + .nav-submenu,
.crm-app .sidebar .nav-submenu[data-open="true"],
.crm-app .sidebar .sidebar-group-toggle[aria-expanded="true"] + .nav-submenu {
    margin: 2px 0 4px 18px !important;
}

#app > .sidebar .nav-submenu > .nav-submenu-inner,
.crm-app .sidebar .nav-submenu > .nav-submenu-inner {
    gap: 1px !important;
}

#app > .sidebar .sidebar-group-links .sidebar-link--material,
.crm-app .sidebar .sidebar-group-links .sidebar-link--material {
    min-height: 34px !important;
    height: 34px !important;
    border-radius: 17px !important;
    font-size: 12.5px !important;
    padding: 0 10px !important;
}

#app > .sidebar .sidebar-group-links .sidebar-link--material .material-symbols-rounded,
.crm-app .sidebar .sidebar-group-links .sidebar-link--material .material-symbols-rounded {
    font-size: 21px !important;
}

#app > .sidebar .sidebar-foot,
.crm-app .sidebar .sidebar-foot {
    align-self: end !important;
    height: 76px !important;
    min-height: 76px !important;
    padding: 8px 12px !important;
    overflow: hidden !important;
}

#app > .sidebar .sidebar-foot .sidebar-user,
.crm-app .sidebar .sidebar-foot .sidebar-user {
    min-height: 56px !important;
    height: 56px !important;
}

#app > .sidebar.is-collapsed,
.crm-app .sidebar.is-collapsed {
    grid-template-rows: 72px 52px minmax(0, 1fr) 72px !important;
}

#app > .sidebar.is-collapsed .sidebar-brand,
.crm-app .sidebar.is-collapsed .sidebar-brand {
    height: 72px !important;
    min-height: 72px !important;
    padding: 12px !important;
}

#app > .sidebar.is-collapsed .md3-sidebar-toggle,
.crm-app .sidebar.is-collapsed .md3-sidebar-toggle {
    margin-inline: auto !important;
}

@media (max-height: 760px) {
    #app > .sidebar,
    .crm-app .sidebar {
        grid-template-rows: 70px 38px minmax(0, 1fr) 64px !important;
    }

    #app > .sidebar .sidebar-brand,
    .crm-app .sidebar .sidebar-brand {
        min-height: 70px !important;
        height: 70px !important;
        padding: 8px 14px !important;
    }

    #app > .sidebar .sidebar-brand .brand-mark,
    .crm-app .sidebar .sidebar-brand .brand-mark {
        width: 42px !important;
        height: 42px !important;
        min-width: 42px !important;
    }

    #app > .sidebar .md3-sidebar-toggle,
    .crm-app .sidebar .md3-sidebar-toggle {
        width: 38px !important;
        height: 38px !important;
        min-height: 38px !important;
    }

    #app > .sidebar .sidebar-group-toggle,
    .crm-app .sidebar .sidebar-group-toggle {
        min-height: 34px !important;
        height: 34px !important;
    }

    #app > .sidebar .sidebar-nav,
    .crm-app .sidebar .sidebar-nav {
        gap: 4px !important;
        padding-block: 6px 8px !important;
    }

    #app > .sidebar .sidebar-group-links .sidebar-link--material,
    .crm-app .sidebar .sidebar-group-links .sidebar-link--material {
        min-height: 30px !important;
        height: 30px !important;
    }

    #app > .sidebar .sidebar-foot,
    .crm-app .sidebar .sidebar-foot {
        height: 64px !important;
        min-height: 64px !important;
        padding: 5px 10px !important;
    }

    #app > .sidebar .sidebar-foot .sidebar-user,
    .crm-app .sidebar .sidebar-foot .sidebar-user {
        min-height: 52px !important;
        height: 52px !important;
    }
}

/* Klanten 07-05: compactere controls, snelfilters en lichtere lijst-rendering. */
#view-bestellingen .bes-toolbar {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin-bottom: 8px !important;
}

#view-bestellingen .bes-view-toggle {
    margin-left: auto !important;
}

#view-bestellingen .bes-action-menu {
    position: relative !important;
    flex: 0 0 auto !important;
}

#view-bestellingen .bes-action-menu > summary {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 42px !important;
    min-width: 42px !important;
    padding: 0 !important;
    list-style: none !important;
    cursor: pointer !important;
}

#view-bestellingen .bes-action-menu > summary::-webkit-details-marker {
    display: none !important;
}

#view-bestellingen .bes-action-menu-panel {
    position: absolute !important;
    top: calc(100% + 8px) !important;
    left: auto !important;
    right: 0 !important;
    z-index: 40 !important;
    display: grid !important;
    gap: 4px !important;
    width: 260px !important;
    min-width: 0 !important;
    max-width: calc(100vw - 32px) !important;
    padding: 8px !important;
    border: 1px solid #DADCE0 !important;
    border-radius: 14px !important;
    background: #fff !important;
    box-shadow: 0 12px 30px rgba(60, 64, 67, 0.18) !important;
}

#view-bestellingen .bes-action-menu:not([open]) .bes-action-menu-panel {
    display: none !important;
}

#view-bestellingen .bes-action-menu-panel button {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    width: 100% !important;
    min-height: 40px !important;
    padding: 8px 10px !important;
    border: 0 !important;
    border-radius: 10px !important;
    background: transparent !important;
    color: #202124 !important;
    font: inherit !important;
    font-weight: 700 !important;
    text-align: left !important;
    cursor: pointer !important;
}

#view-bestellingen .bes-action-menu-panel button:hover,
#view-bestellingen .bes-action-menu-panel button:focus-visible {
    background: #F1F3F4 !important;
    outline: none !important;
}

#view-bestellingen .bes-filters {
    position: sticky !important;
    top: 10px !important;
    z-index: 18 !important;
    border: 1px solid rgba(218, 220, 224, 0.82) !important;
    background: rgba(255, 255, 255, 0.94) !important;
    backdrop-filter: blur(14px) !important;
}

#view-bestellingen .bes-filter-summary {
    margin-left: auto !important;
    color: #5F6368 !important;
    font-weight: 800 !important;
    white-space: nowrap !important;
}

#view-bestellingen .bes-stats {
    grid-template-columns: repeat(4, minmax(120px, 1fr)) !important;
}

#view-bestellingen .bes-stat {
    appearance: none !important;
    text-align: left !important;
    cursor: pointer !important;
    transition: border-color 150ms ease, background-color 150ms ease, box-shadow 150ms ease, transform 150ms ease !important;
}

#view-bestellingen .bes-stat:hover,
#view-bestellingen .bes-stat:focus-visible {
    border-color: #1A73E8 !important;
    box-shadow: 0 2px 8px rgba(26, 115, 232, 0.14) !important;
    outline: none !important;
}

#view-bestellingen .bes-stat.active {
    border-color: #1A73E8 !important;
    background: #E8F0FE !important;
}

#view-bestellingen .bes-customer-row {
    cursor: pointer !important;
    text-align: left !important;
    color: inherit !important;
    text-decoration: none !important;
}

#view-bestellingen .bes-customer-row:focus-visible {
    outline: 3px solid rgba(26, 115, 232, 0.34) !important;
    outline-offset: -3px !important;
}

#view-bestellingen .bes-customer-titleline {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 8px !important;
    min-width: 0 !important;
}

#view-bestellingen .bes-customer-titleline strong {
    min-width: 0 !important;
    max-width: 100% !important;
}

#view-bestellingen .bes-customer-products {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    max-width: 100% !important;
    overflow: hidden !important;
}

#view-bestellingen .bes-customer-products small {
    display: inline-flex !important;
    max-width: min(100%, 230px) !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#view-bestellingen .bes-customer-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: flex-end !important;
    gap: 6px !important;
    margin-top: 10px !important;
}

#view-bestellingen .bes-icon-action,
#view-bestellingen .bes-open-action {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 36px !important;
    border: 1px solid #DADCE0 !important;
    border-radius: 999px !important;
    background: #fff !important;
    color: #3C4043 !important;
    text-decoration: none !important;
    transition: background-color 150ms ease, border-color 150ms ease, color 150ms ease !important;
}

#view-bestellingen .bes-icon-action {
    width: 36px !important;
}

#view-bestellingen .bes-icon-action .material-symbols-rounded {
    display: inline-flex !important;
    margin: 0 !important;
    color: inherit !important;
    font-size: 19px !important;
}

#view-bestellingen .bes-open-action {
    padding: 0 14px !important;
    font: inherit !important;
    font-weight: 800 !important;
    cursor: pointer !important;
}

#view-bestellingen .bes-icon-action:hover,
#view-bestellingen .bes-open-action:hover,
#view-bestellingen .bes-icon-action:focus-visible,
#view-bestellingen .bes-open-action:focus-visible {
    border-color: #1A73E8 !important;
    background: #E8F0FE !important;
    color: #174EA6 !important;
    outline: none !important;
}

#view-bestellingen .bes-list-refreshing {
    position: sticky !important;
    top: 72px !important;
    z-index: 12 !important;
    align-self: center !important;
    margin: 0 auto 10px !important;
    width: max-content !important;
    max-width: 100% !important;
    padding: 7px 12px !important;
    border: 1px solid #DADCE0 !important;
    border-radius: 999px !important;
    background: #fff !important;
    color: #5F6368 !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    box-shadow: 0 2px 8px rgba(60, 64, 67, 0.12) !important;
}

#view-bestellingen .bes-skeleton-list {
    gap: 0 !important;
}

#view-bestellingen .bes-customer-skeleton {
    pointer-events: none !important;
}

#view-bestellingen .bes-customer-skeleton span,
#view-bestellingen .bes-customer-skeleton > div:last-child {
    display: block !important;
    height: 12px !important;
    border-radius: 999px !important;
    background: linear-gradient(90deg, #F1F3F4, #E8EAED, #F1F3F4) !important;
    background-size: 200% 100% !important;
    animation: bes-skeleton 1.2s ease-in-out infinite !important;
}

#view-bestellingen .bes-customer-skeleton span:first-child {
    width: min(260px, 64%) !important;
    height: 18px !important;
}

#view-bestellingen .bes-customer-skeleton span:nth-child(2) {
    width: min(420px, 80%) !important;
}

#view-bestellingen .bes-customer-skeleton span:nth-child(3) {
    width: min(360px, 70%) !important;
}

#view-bestellingen .bes-customer-skeleton > div:last-child {
    width: 180px !important;
    height: 38px !important;
}

@keyframes bes-skeleton {
    0% { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

@media (max-width: 860px) {
    #view-bestellingen .bes-toolbar,
    #view-bestellingen .bes-filters {
        align-items: stretch !important;
    }

    #view-bestellingen .bes-view-toggle,
    #view-bestellingen .bes-filter-summary {
        margin-left: 0 !important;
    }

    #view-bestellingen .bes-action-menu {
        align-self: flex-start !important;
    }

    #view-bestellingen .bes-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    #view-bestellingen .bes-customer-actions {
        justify-content: flex-start !important;
    }
}

/* Lead-register redesign 07-05 13:30: sticky filters, readable data tables and no content overlap. */
#view-leads {
    --lead-card-border: rgba(218, 220, 224, 0.92);
    --lead-muted: #5f6368;
    padding-right: max(32px, env(safe-area-inset-right)) !important;
}

#view-leads .lead-filter-stack {
    position: sticky !important;
    top: 10px !important;
    z-index: 22 !important;
    display: grid !important;
    gap: 8px !important;
    margin-bottom: 18px !important;
    padding: 10px !important;
    border: 1px solid rgba(218, 220, 224, 0.82) !important;
    border-radius: 18px !important;
    background: rgba(255, 255, 255, 0.94) !important;
    box-shadow: 0 12px 28px rgba(60, 64, 67, 0.08) !important;
    backdrop-filter: blur(14px) !important;
}

#view-leads .lead-filterbar {
    position: static !important;
    display: grid !important;
    grid-template-columns: minmax(240px, 1.35fr) repeat(3, minmax(160px, 0.85fr)) minmax(250px, 1.1fr) !important;
    gap: 10px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

#view-leads .lead-search-field,
#view-leads .lead-filter-control,
#view-leads .lead-daterange label {
    display: grid !important;
    gap: 5px !important;
    min-width: 0 !important;
    color: var(--lead-muted) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: .01em !important;
}

#view-leads .lead-search-field > span,
#view-leads .lead-filter-control > span {
    padding-left: 2px !important;
}

#view-leads .lead-search-field .bes-search,
#view-leads .lead-filter-control .form-select,
#view-leads .lead-daterange input {
    width: 100% !important;
    min-width: 0 !important;
    height: 42px !important;
    border-radius: 12px !important;
    background: #fff !important;
}

#view-leads .lead-daterange {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
    min-width: 0 !important;
}

#view-leads .lead-active-filters {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    align-items: center !important;
}

#view-leads .lead-active-filters button {
    min-height: 30px !important;
    max-width: 100% !important;
    padding: 0 10px !important;
    border: 1px solid #dfe5f7 !important;
    border-radius: 999px !important;
    background: #f6f8ff !important;
    color: #3359d8 !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    white-space: nowrap !important;
}

#view-leads .lead-active-filters .is-reset {
    border-color: transparent !important;
    background: transparent !important;
    color: #5f6368 !important;
}

#view-leads .lead-kpi-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 12px !important;
}

#view-leads .lead-kpi-card {
    min-width: 0 !important;
    min-height: 104px !important;
    padding: 14px !important;
    border: 1px solid var(--lead-card-border) !important;
    border-radius: 16px !important;
    box-shadow: none !important;
}

#view-leads .lead-kpi-card span {
    color: var(--lead-muted) !important;
    font-size: 12px !important;
    line-height: 1.25 !important;
}

#view-leads .lead-kpi-card strong {
    display: block !important;
    max-width: 100% !important;
    margin-top: 8px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-size: clamp(20px, 1.8vw, 28px) !important;
    letter-spacing: 0 !important;
}

#view-leads .lead-report-grid {
    display: grid !important;
    grid-template-columns: repeat(12, minmax(0, 1fr)) !important;
    gap: 16px !important;
}

#view-leads .lead-report-grid > .lead-report-card {
    grid-column: span 6 !important;
}

#view-leads .lead-report-grid > .lead-cost-card {
    grid-column: 1 / -1 !important;
}

#view-leads .lead-report-card {
    border: 1px solid var(--lead-card-border) !important;
    border-radius: 16px !important;
    box-shadow: none !important;
}

#view-leads .lead-list {
    padding: 0 !important;
    overflow: visible !important;
    border: 1px solid var(--lead-card-border) !important;
    border-radius: 16px !important;
    background: #fff !important;
}

#view-leads .lead-list-summary {
    position: sticky !important;
    top: 94px !important;
    z-index: 12 !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 12px 14px !important;
    border-bottom: 1px solid var(--lead-card-border) !important;
    background: rgba(255, 255, 255, 0.96) !important;
    backdrop-filter: blur(10px) !important;
}

#view-leads .lead-list-summary > div:first-child {
    display: flex !important;
    gap: 6px !important;
    align-items: baseline !important;
    min-width: 0 !important;
}

#view-leads .lead-list-summary strong,
#view-leads .lead-list-summary span {
    white-space: nowrap !important;
}

#view-leads .lead-table-tools {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: flex-end !important;
    align-items: center !important;
    gap: 8px !important;
}

#view-leads .lead-table-tools label {
    display: flex !important;
    gap: 6px !important;
    align-items: center !important;
    color: var(--lead-muted) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
}

#view-leads .lead-table-tools .form-select {
    width: 88px !important;
    min-width: 88px !important;
    height: 34px !important;
}

#view-leads .lead-data-table-wrap {
    width: 100% !important;
    max-width: 100% !important;
    max-height: min(72vh, 760px) !important;
    overflow: auto !important;
    overscroll-behavior: contain !important;
    border-radius: 0 0 16px 16px !important;
}

#view-leads .lead-data-table {
    width: max-content !important;
    min-width: 1280px !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    table-layout: fixed !important;
    background: #fff !important;
}

#view-leads .lead-data-table th,
#view-leads .lead-data-table td {
    max-width: 260px !important;
    padding: 10px 12px !important;
    border-bottom: 1px solid #eef1f5 !important;
    border-right: 1px solid #f2f4f7 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    word-break: normal !important;
    vertical-align: middle !important;
}

#view-leads .lead-data-table th {
    position: sticky !important;
    top: 0 !important;
    z-index: 4 !important;
    background: #f8fafc !important;
    color: #3c4043 !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    letter-spacing: .02em !important;
    text-align: left !important;
    text-transform: none !important;
}

#view-leads .lead-data-table th:first-child,
#view-leads .lead-data-table td:first-child {
    position: sticky !important;
    left: 0 !important;
    z-index: 5 !important;
    background: inherit !important;
    box-shadow: 1px 0 0 #e8eaed !important;
}

#view-leads .lead-data-table th:first-child {
    z-index: 8 !important;
    background: #f8fafc !important;
}

#view-leads .lead-data-table tbody tr {
    background: #fff !important;
}

#view-leads .lead-data-table tbody tr:nth-child(even) {
    background: #fbfcff !important;
}

#view-leads .lead-data-table tbody tr:hover {
    background: #f3f7ff !important;
}

#view-leads .lead-data-table th:nth-child(1),
#view-leads .lead-data-table td:nth-child(1) { width: 172px !important; }
#view-leads .lead-data-table th:nth-child(2),
#view-leads .lead-data-table td:nth-child(2) { width: 160px !important; }
#view-leads .lead-data-table th:nth-child(3),
#view-leads .lead-data-table td:nth-child(3) { width: 160px !important; }
#view-leads .lead-data-table th:nth-child(4),
#view-leads .lead-data-table td:nth-child(4) { width: 150px !important; }
#view-leads .lead-data-table th:nth-child(5),
#view-leads .lead-data-table td:nth-child(5) { width: 120px !important; text-align: right !important; }
#view-leads .lead-data-table th:nth-child(6),
#view-leads .lead-data-table td:nth-child(6) { width: 240px !important; }
#view-leads .lead-data-table th:nth-child(7),
#view-leads .lead-data-table td:nth-child(7) { width: 120px !important; }
#view-leads .lead-data-table th:nth-child(8),
#view-leads .lead-data-table td:nth-child(8) { width: 230px !important; }
#view-leads .lead-data-table th:nth-child(9),
#view-leads .lead-data-table td:nth-child(9) { width: 112px !important; text-align: right !important; }
#view-leads .lead-data-table th:nth-child(10),
#view-leads .lead-data-table td:nth-child(10) { width: 128px !important; }

#view-leads .lead-data-table .is-number {
    text-align: right !important;
    font-variant-numeric: tabular-nums !important;
}

#view-leads .lead-data-table .is-mono,
#view-leads .lead-date-cell small {
    font-family: ui-monospace, SFMono-Regular, Consolas, "Liberation Mono", monospace !important;
    font-size: 12px !important;
}

#view-leads .lead-date-cell {
    display: grid !important;
    gap: 1px !important;
}

#view-leads .lead-date-cell span,
#view-leads .lead-date-cell small,
#view-leads .lead-customer-cell strong,
#view-leads .lead-customer-cell small,
#view-leads .lead-customer-cell a,
#view-leads .lead-product-cell {
    display: block !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-leads .lead-date-cell small,
#view-leads .lead-customer-cell small,
#view-leads .lead-customer-cell a {
    color: var(--lead-muted) !important;
    font-size: 12px !important;
    text-decoration: none !important;
}

#view-leads .lead-source-chip,
#view-leads .lead-status-chip {
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-leads .lead-status-chip {
    display: inline-flex !important;
    align-items: center !important;
    height: 26px !important;
    padding: 0 10px !important;
    border-radius: 999px !important;
    font-size: 12px !important;
    font-weight: 800 !important;
}

#view-leads .lead-status-chip.is-green { background: #e8f5e9 !important; color: #137333 !important; }
#view-leads .lead-status-chip.is-red { background: #fce8e6 !important; color: #b3261e !important; }
#view-leads .lead-status-chip.is-blue { background: #e8f0fe !important; color: #2850c7 !important; }

#view-leads .lead-cost-editor {
    overflow-x: auto !important;
}

#view-leads .lead-cost-editor-head,
#view-leads .lead-cost-row {
    min-width: 1120px !important;
}

#view-leads .lead-cost-editor-head {
    position: sticky !important;
    top: 0 !important;
    z-index: 3 !important;
    background: #f8fafc !important;
    border-bottom: 1px solid var(--lead-card-border) !important;
}

#view-leads .lead-cost-meta span,
#view-leads .lead-cost-main span,
#view-leads .lead-cost-impact span {
    display: block !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-leads .lead-data-gap {
    border: 1px dashed #d7dde8 !important;
    border-radius: 14px !important;
    background: #fbfcff !important;
}

@media (max-width: 1280px) {
    #view-leads .lead-filterbar {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    #view-leads .lead-kpi-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }

    #view-leads .lead-report-grid > .lead-report-card {
        grid-column: 1 / -1 !important;
    }
}

@media (max-width: 760px) {
    #view-leads {
        padding-right: 0 !important;
    }

    #view-leads .lead-filter-stack {
        position: static !important;
        border-radius: 14px !important;
    }

    #view-leads .lead-filterbar,
    #view-leads .lead-daterange,
    #view-leads .lead-kpi-grid {
        grid-template-columns: 1fr !important;
    }

    #view-leads .lead-list-summary {
        position: static !important;
        display: grid !important;
        align-items: stretch !important;
    }

    #view-leads .lead-table-tools {
        justify-content: flex-start !important;
    }

    #view-leads .lead-data-table-wrap {
        max-height: 68vh !important;
    }
}

@media (max-width: 520px) {
    #view-bestellingen .bes-stats {
        grid-template-columns: 1fr !important;
    }

    #view-bestellingen .bes-action-menu {
        flex-basis: 100% !important;
        width: 100% !important;
    }

    #view-bestellingen .bes-action-menu-panel {
        position: static !important;
        left: auto !important;
        right: 0 !important;
        min-width: 0 !important;
        width: 100% !important;
        max-width: 100% !important;
        margin-top: 8px !important;
    }
}

@media (prefers-reduced-motion: reduce) {
    #view-bestellingen .bes-stat,
    #view-bestellingen .bes-icon-action,
    #view-bestellingen .bes-open-action,
    #view-bestellingen .bes-customer-skeleton span,
    #view-bestellingen .bes-customer-skeleton > div:last-child {
        transition: none !important;
        animation: none !important;
    }
}

/* Producten 07-05: datadichte catalogustabellen met vaste headers en duidelijke cellen. */
#view-products .product-legacy-section {
    overflow: visible !important;
}

#view-products .product-legacy-table {
    overflow: visible !important;
    border: 1px solid #DADCE0 !important;
    border-radius: 12px !important;
    background: #fff !important;
}

#view-products .product-legacy-row {
    display: grid !important;
    align-items: center !important;
    gap: 0 !important;
    min-height: 48px !important;
    padding: 0 !important;
    border-bottom: 1px solid #EEF0F2 !important;
}

#view-products .product-legacy-row:last-child {
    border-bottom: 0 !important;
}

#view-products .product-legacy-row > span {
    align-self: stretch !important;
    display: flex !important;
    min-width: 0 !important;
    flex-direction: column !important;
    justify-content: center !important;
    padding: 8px 12px !important;
    border-right: 1px solid #EEF0F2 !important;
}

#view-products .product-legacy-row > span:last-child {
    border-right: 0 !important;
}

#view-products .product-legacy-row-head {
    position: sticky !important;
    top: 8px !important;
    z-index: 16 !important;
    min-height: 40px !important;
    border-bottom: 1px solid #DADCE0 !important;
    background: #F8FAFD !important;
    box-shadow: 0 1px 0 #DADCE0 !important;
}

#view-products .product-legacy-row-head > span {
    color: #5F6368 !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    line-height: 1.2 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
}

#view-products .product-components-table .product-legacy-row {
    grid-template-columns: minmax(220px, 1.2fr) minmax(120px, .55fr) minmax(260px, 1.05fr) 48px !important;
}

#view-products .product-margin-table .product-legacy-row {
    grid-template-columns: minmax(240px, 1.5fr) 104px 124px 112px minmax(128px, .85fr) minmax(130px, .85fr) 88px !important;
}

#view-products .product-category-table .product-legacy-row {
    grid-template-columns: minmax(260px, 1.5fr) 120px 116px 116px 132px minmax(150px, .85fr) 84px !important;
}

#view-products .product-margin-table .product-legacy-row > span:nth-child(n+2),
#view-products .product-category-table .product-legacy-row > span:nth-child(n+3):not(:last-child),
#view-products .product-components-table .product-legacy-row > span:nth-child(2) {
    align-items: flex-end !important;
    text-align: right !important;
}

#view-products .product-category-table .product-legacy-row > span:nth-child(6),
#view-products .product-components-table .product-legacy-row > span:nth-child(3) {
    align-items: flex-start !important;
    text-align: left !important;
}

#view-products .product-legacy-row small {
    margin-top: 2px !important;
    color: #5F6368 !important;
    font-size: 11px !important;
    line-height: 1.25 !important;
}

#view-products .product-legacy-row strong,
#view-products .product-legacy-row b,
#view-products .product-legacy-row em {
    line-height: 1.25 !important;
}

#view-products .product-used-pill {
    width: fit-content !important;
    max-width: 100% !important;
}

#view-products .product-margin-warning {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 8px !important;
    margin: 12px 0 !important;
    padding: 10px 12px !important;
    border: 1px solid #FAD2CF !important;
    border-radius: 12px !important;
    background: #FCE8E6 !important;
    color: #A50E0E !important;
}

#view-products .product-margin-warning .material-symbols-rounded {
    font-size: 20px !important;
    color: inherit !important;
}

#view-products .product-margin-warning strong,
#view-products .product-margin-warning span {
    min-width: 0 !important;
}

#view-products .product-margin-warning > span:last-child {
    color: #5F2120 !important;
    font-size: 13px !important;
}

#view-products .product-stats-grid.product-compact-kpis {
    grid-template-columns: repeat(5, minmax(120px, 1fr)) !important;
    gap: 8px !important;
}

#view-products .product-stat-card {
    min-height: 70px !important;
    padding: 10px 12px !important;
}

#view-products .product-stat-card strong {
    font-size: 22px !important;
}

#view-products .product-filterbar > span {
    color: #5F6368 !important;
    font-weight: 800 !important;
}

#view-products .product-period-select {
    padding-right: 34px !important;
    appearance: auto !important;
}

#view-products .product-catalog-toolbar .product-actionbar-buttons .ev-btn,
#view-products .product-catalog-toolbar .product-period-select {
    min-height: 38px !important;
}

@media (max-width: 1180px) {
    #view-products .product-stats-grid.product-compact-kpis {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 900px) {
    #view-products .product-legacy-table {
        border: 0 !important;
        background: transparent !important;
    }

    #view-products .product-legacy-row-head {
        display: none !important;
    }

    #view-products .product-components-table .product-legacy-row,
    #view-products .product-margin-table .product-legacy-row,
    #view-products .product-category-table .product-legacy-row {
        grid-template-columns: 1fr !important;
        margin-bottom: 8px !important;
        border: 1px solid #DADCE0 !important;
        border-radius: 12px !important;
        background: #fff !important;
    }

    #view-products .product-legacy-row > span {
        align-items: flex-start !important;
        border-right: 0 !important;
        border-bottom: 1px solid #EEF0F2 !important;
        text-align: left !important;
    }

    #view-products .product-legacy-row > span:last-child {
        border-bottom: 0 !important;
    }

    #view-products .product-margin-table .product-legacy-row > span:nth-child(n+2),
    #view-products .product-category-table .product-legacy-row > span:nth-child(n+3):not(:last-child),
    #view-products .product-components-table .product-legacy-row > span:nth-child(2) {
        align-items: flex-start !important;
        text-align: left !important;
    }
}

@media (max-width: 640px) {
    #view-products .product-stats-grid.product-compact-kpis {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

/* Lead-register final mobile polish: no floating overlap and compact secondary actions. */
body[data-active-view="view-leads"] .qt-fab,
body[data-active-view="view-lead-duplicates"] .qt-fab,
body[data-active-view="view-marketing"] .qt-fab {
    display: none !important;
}

#view-leads .leads-actionbar {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 10px !important;
}

#view-leads .leads-secondary {
    margin-left: auto !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    width: auto !important;
    min-height: 0 !important;
    padding: 6px !important;
}

@media (max-width: 760px) {
    #view-leads .leads-actionbar {
        display: grid !important;
        grid-template-columns: 1fr !important;
    }

    #view-leads .leads-secondary {
        margin-left: 0 !important;
        width: 100% !important;
        display: grid !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        padding: 6px !important;
        border-radius: 14px !important;
    }

    #view-leads .leads-secondary .leads-icon-btn {
        width: 100% !important;
        height: 40px !important;
        min-height: 40px !important;
        justify-content: center !important;
    }
}

/* Lead-register data controls 07-05 14:00: sortable tables, product exports and clipped-free grids. */
#view-leads .lead-filterbar {
    grid-template-columns: minmax(240px, 1.4fr) repeat(5, minmax(142px, .82fr)) !important;
}

#view-leads .lead-sort-button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 6px !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    color: inherit !important;
    font: inherit !important;
    font-weight: 800 !important;
    letter-spacing: inherit !important;
    text-align: left !important;
    cursor: pointer !important;
}

#view-leads .lead-sort-button span,
#view-leads .lead-sort-button b {
    flex: 0 0 auto !important;
    color: var(--md-primary) !important;
    font-size: 11px !important;
    line-height: 1 !important;
}

#view-leads .lead-mini-toolbar {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    margin-bottom: 10px !important;
}

#view-leads .lead-mini-toolbar h4 {
    margin: 0 !important;
}

#view-leads .lead-mini-toolbar > div {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: flex-end !important;
    gap: 8px !important;
}

#view-leads .lead-mini-table {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    border: 1px solid var(--lead-card-border, #DADCE0) !important;
    border-radius: 14px !important;
}

#view-leads .lead-mini-head,
#view-leads .lead-mini-row {
    width: 100% !important;
    min-width: 0 !important;
    align-items: center !important;
}

#view-leads .lead-mini-head > span,
#view-leads .lead-mini-row > span {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    word-break: normal !important;
}

#view-leads .lead-mini-row > span :is(em, small) {
    display: block !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-leads .lead-mini-table :is(input[type="checkbox"]) {
    width: 18px !important;
    height: 18px !important;
    margin: 0 !important;
    accent-color: var(--md-primary) !important;
}

#view-leads .lead-sales-product-table .lead-mini-head,
#view-leads .lead-sales-product-table .lead-mini-row {
    display: grid !important;
    grid-template-columns: 34px minmax(240px, 1.5fr) 132px 82px 92px 150px 150px 132px !important;
    min-width: 1030px !important;
    gap: 10px !important;
}

#view-leads .lead-sales-category-table .lead-mini-head,
#view-leads .lead-sales-category-table .lead-mini-row {
    display: grid !important;
    grid-template-columns: minmax(150px, 1.1fr) 82px 92px 148px 148px !important;
    min-width: 620px !important;
    gap: 10px !important;
}

#view-leads .lead-product-conversion-table .lead-mini-head,
#view-leads .lead-product-conversion-table .lead-mini-row,
#view-leads .lead-province-table .lead-mini-head,
#view-leads .lead-province-table .lead-mini-row {
    display: grid !important;
    grid-template-columns: minmax(260px, 1.4fr) 110px 120px 120px !important;
    min-width: 650px !important;
    gap: 10px !important;
}

#view-leads .lead-revenue-gap-table .lead-mini-head,
#view-leads .lead-revenue-gap-table .lead-mini-row {
    display: grid !important;
    grid-template-columns: minmax(220px, 1.2fr) 88px minmax(220px, 1fr) !important;
    min-width: 640px !important;
}

#view-leads .lead-data-table th .lead-sort-button {
    width: 100% !important;
}

#view-leads .lead-data-table th .lead-sort-button span {
    margin-left: auto !important;
}

@media (max-width: 1280px) {
    #view-leads .lead-filterbar {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 760px) {
    #view-leads .lead-filterbar {
        grid-template-columns: 1fr !important;
    }

    #view-leads .lead-mini-toolbar,
    #view-leads .lead-mini-toolbar > div {
        align-items: stretch !important;
        justify-content: flex-start !important;
    }

    #view-leads .lead-mini-toolbar .leads-small-btn {
        flex: 1 1 150px !important;
        justify-content: center !important;
    }
}

/* Lead-register no horizontal swipe 07-05 14:20. */
body[data-active-view="view-leads"],
body[data-active-view="view-lead-duplicates"],
body[data-active-view="view-marketing"] {
    overflow-x: hidden !important;
    overscroll-behavior-x: none !important;
}

body[data-active-view="view-leads"] :is(.crm-app, .app-shell, .crm-main, .crm-content, .page-content),
body[data-active-view="view-lead-duplicates"] :is(.crm-app, .app-shell, .crm-main, .crm-content, .page-content),
body[data-active-view="view-marketing"] :is(.crm-app, .app-shell, .crm-main, .crm-content, .page-content),
#view-leads {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
    overflow-x: clip !important;
    overscroll-behavior-x: none !important;
    touch-action: pan-y !important;
}

#view-leads :is(.lead-report-shell, .lead-report-grid, .lead-report-card, .lead-sales-intel-card, .lead-sales-intel-grid, .lead-sales-panel, .lead-mini-stack, .lead-filter-stack, .lead-list-summary, .lead-cost-editor, .lead-data-table-wrap) {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
    overflow-x: clip !important;
    overscroll-behavior-x: none !important;
    touch-action: pan-y !important;
}

#view-leads .lead-mini-table {
    min-width: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
    overflow-x: clip !important;
    overflow-y: visible !important;
    touch-action: pan-y !important;
}

#view-leads .lead-mini-head,
#view-leads .lead-mini-row {
    min-width: 0 !important;
    max-width: 100% !important;
}

#view-leads .lead-sales-product-table .lead-mini-head,
#view-leads .lead-sales-product-table .lead-mini-row {
    grid-template-columns: 28px minmax(0, 1.45fr) minmax(0, .46fr) minmax(0, .38fr) minmax(0, .45fr) minmax(0, .65fr) minmax(0, .65fr) minmax(0, .55fr) !important;
    min-width: 0 !important;
    gap: 8px !important;
}

#view-leads .lead-sales-category-table .lead-mini-head,
#view-leads .lead-sales-category-table .lead-mini-row {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, .38fr) minmax(0, .42fr) minmax(0, .62fr) minmax(0, .62fr) !important;
    min-width: 0 !important;
    gap: 8px !important;
}

#view-leads .lead-product-conversion-table .lead-mini-head,
#view-leads .lead-product-conversion-table .lead-mini-row,
#view-leads .lead-province-table .lead-mini-head,
#view-leads .lead-province-table .lead-mini-row {
    grid-template-columns: minmax(0, 1.25fr) minmax(0, .38fr) minmax(0, .48fr) minmax(0, .52fr) !important;
    min-width: 0 !important;
    gap: 8px !important;
}

#view-leads .lead-revenue-gap-table .lead-mini-head,
#view-leads .lead-revenue-gap-table .lead-mini-row {
    grid-template-columns: minmax(0, 1.1fr) minmax(52px, .34fr) minmax(0, 1fr) !important;
    min-width: 0 !important;
    gap: 8px !important;
}

#view-leads .lead-targeting-table .lead-mini-head,
#view-leads .lead-targeting-table .lead-mini-row {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, .32fr) minmax(0, .32fr) minmax(0, .34fr) minmax(0, .5fr) minmax(0, .5fr) minmax(0, .5fr) minmax(0, .44fr) minmax(0, .78fr) minmax(0, .44fr) !important;
    min-width: 0 !important;
    gap: 6px !important;
}

#view-leads .lead-conversion-table .lead-mini-head,
#view-leads .lead-conversion-table .lead-mini-row {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, .45fr) minmax(0, .52fr) minmax(0, .44fr) minmax(0, .54fr) !important;
    min-width: 0 !important;
    gap: 8px !important;
}

#view-leads .lead-cost-editor {
    overflow-x: hidden !important;
    overflow-x: clip !important;
}

#view-leads .lead-cost-editor-head,
#view-leads .lead-cost-row {
    width: 100% !important;
    min-width: 0 !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, .34fr) minmax(0, .95fr) minmax(0, .85fr) !important;
}

#view-leads .lead-data-table-wrap {
    overflow-x: hidden !important;
    overflow-y: auto !important;
    touch-action: pan-y !important;
}

#view-leads .lead-data-table {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    table-layout: fixed !important;
}

#view-leads .lead-data-table th,
#view-leads .lead-data-table td {
    max-width: none !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
}

#view-leads .lead-data-table th:first-child,
#view-leads .lead-data-table td:first-child {
    position: static !important;
    left: auto !important;
}

#view-leads .lead-data-table th:nth-child(1),
#view-leads .lead-data-table td:nth-child(1) { width: 11% !important; }
#view-leads .lead-data-table th:nth-child(2),
#view-leads .lead-data-table td:nth-child(2) { width: 9% !important; }
#view-leads .lead-data-table th:nth-child(3),
#view-leads .lead-data-table td:nth-child(3) { width: 9% !important; }
#view-leads .lead-data-table th:nth-child(4),
#view-leads .lead-data-table td:nth-child(4) { width: 10% !important; }
#view-leads .lead-data-table th:nth-child(5),
#view-leads .lead-data-table td:nth-child(5) { width: 8% !important; text-align: right !important; }
#view-leads .lead-data-table th:nth-child(6),
#view-leads .lead-data-table td:nth-child(6) { width: 17% !important; }
#view-leads .lead-data-table th:nth-child(7),
#view-leads .lead-data-table td:nth-child(7) { width: 8% !important; }
#view-leads .lead-data-table th:nth-child(8),
#view-leads .lead-data-table td:nth-child(8) { width: 16% !important; }
#view-leads .lead-data-table th:nth-child(9),
#view-leads .lead-data-table td:nth-child(9) { width: 5% !important; text-align: right !important; }
#view-leads .lead-data-table th:nth-child(10),
#view-leads .lead-data-table td:nth-child(10) { width: 7% !important; }

#view-leads .lead-data-table :is(.lead-customer-cell strong, .lead-customer-cell a, .lead-customer-cell small, .lead-date-cell span, .lead-date-cell small, .lead-product-cell, .lead-source-chip, .lead-status-chip) {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-leads .lead-sort-button {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-leads .lead-sort-button span,
#view-leads .lead-sort-button b {
    margin-left: 4px !important;
}

@media (max-width: 1120px) {
    #view-leads .lead-data-table th:nth-child(2),
    #view-leads .lead-data-table td:nth-child(2),
    #view-leads .lead-data-table th:nth-child(3),
    #view-leads .lead-data-table td:nth-child(3),
    #view-leads .lead-data-table th:nth-child(9),
    #view-leads .lead-data-table td:nth-child(9) {
        display: none !important;
    }

    #view-leads .lead-data-table th:nth-child(1),
    #view-leads .lead-data-table td:nth-child(1) { width: 13% !important; }
    #view-leads .lead-data-table th:nth-child(4),
    #view-leads .lead-data-table td:nth-child(4) { width: 14% !important; }
    #view-leads .lead-data-table th:nth-child(5),
    #view-leads .lead-data-table td:nth-child(5) { width: 10% !important; }
    #view-leads .lead-data-table th:nth-child(6),
    #view-leads .lead-data-table td:nth-child(6) { width: 24% !important; }
    #view-leads .lead-data-table th:nth-child(7),
    #view-leads .lead-data-table td:nth-child(7) { width: 10% !important; }
    #view-leads .lead-data-table th:nth-child(8),
    #view-leads .lead-data-table td:nth-child(8) { width: 20% !important; }
    #view-leads .lead-data-table th:nth-child(10),
    #view-leads .lead-data-table td:nth-child(10) { width: 9% !important; }
}

@media (max-width: 760px) {
    #view-leads .lead-data-table-wrap {
        max-height: 68vh !important;
    }

    #view-leads .lead-data-table th,
    #view-leads .lead-data-table td {
        padding: 8px 8px !important;
        font-size: 12px !important;
    }

    #view-leads .lead-data-table th:nth-child(5),
    #view-leads .lead-data-table td:nth-child(5),
    #view-leads .lead-data-table th:nth-child(7),
    #view-leads .lead-data-table td:nth-child(7) {
        display: none !important;
    }

    #view-leads .lead-data-table th:nth-child(1),
    #view-leads .lead-data-table td:nth-child(1) { width: 19% !important; }
    #view-leads .lead-data-table th:nth-child(4),
    #view-leads .lead-data-table td:nth-child(4) { width: 20% !important; }
    #view-leads .lead-data-table th:nth-child(6),
    #view-leads .lead-data-table td:nth-child(6) { width: 26% !important; }
    #view-leads .lead-data-table th:nth-child(8),
    #view-leads .lead-data-table td:nth-child(8) { width: 24% !important; }
    #view-leads .lead-data-table th:nth-child(10),
    #view-leads .lead-data-table td:nth-child(10) { width: 11% !important; }

    #view-leads .lead-sales-product-table .lead-mini-head,
    #view-leads .lead-sales-product-table .lead-mini-row {
        grid-template-columns: 26px minmax(0, 1.4fr) minmax(0, .36fr) minmax(0, .58fr) !important;
    }

    #view-leads .lead-sales-product-table .lead-mini-head > span:nth-child(3),
    #view-leads .lead-sales-product-table .lead-mini-row > span:nth-child(3),
    #view-leads .lead-sales-product-table .lead-mini-head > span:nth-child(5),
    #view-leads .lead-sales-product-table .lead-mini-row > span:nth-child(5),
    #view-leads .lead-sales-product-table .lead-mini-head > span:nth-child(7),
    #view-leads .lead-sales-product-table .lead-mini-row > span:nth-child(7),
    #view-leads .lead-sales-product-table .lead-mini-head > span:nth-child(8),
    #view-leads .lead-sales-product-table .lead-mini-row > span:nth-child(8) {
        display: none !important;
    }

    #view-leads .lead-sales-category-table .lead-mini-head,
    #view-leads .lead-sales-category-table .lead-mini-row {
        grid-template-columns: minmax(0, 1.1fr) minmax(0, .36fr) minmax(0, .42fr) minmax(0, .58fr) !important;
    }

    #view-leads .lead-sales-category-table .lead-mini-head > span:nth-child(5),
    #view-leads .lead-sales-category-table .lead-mini-row > span:nth-child(5) {
        display: none !important;
    }

    #view-leads .lead-targeting-table .lead-mini-head,
    #view-leads .lead-targeting-table .lead-mini-row {
        grid-template-columns: minmax(0, 1.25fr) minmax(0, .38fr) minmax(0, .38fr) minmax(0, .48fr) minmax(0, .8fr) !important;
    }

    #view-leads .lead-targeting-table .lead-mini-head > span:nth-child(4),
    #view-leads .lead-targeting-table .lead-mini-row > span:nth-child(4),
    #view-leads .lead-targeting-table .lead-mini-head > span:nth-child(6),
    #view-leads .lead-targeting-table .lead-mini-row > span:nth-child(6),
    #view-leads .lead-targeting-table .lead-mini-head > span:nth-child(7),
    #view-leads .lead-targeting-table .lead-mini-row > span:nth-child(7),
    #view-leads .lead-targeting-table .lead-mini-head > span:nth-child(8),
    #view-leads .lead-targeting-table .lead-mini-row > span:nth-child(8),
    #view-leads .lead-targeting-table .lead-mini-head > span:nth-child(10),
    #view-leads .lead-targeting-table .lead-mini-row > span:nth-child(10) {
        display: none !important;
    }

    #view-leads .lead-product-conversion-table .lead-mini-head,
    #view-leads .lead-product-conversion-table .lead-mini-row,
    #view-leads .lead-province-table .lead-mini-head,
    #view-leads .lead-province-table .lead-mini-row {
        grid-template-columns: minmax(0, 1.25fr) minmax(0, .42fr) minmax(0, .52fr) !important;
    }

    #view-leads .lead-product-conversion-table .lead-mini-head > span:nth-child(4),
    #view-leads .lead-product-conversion-table .lead-mini-row > span:nth-child(4),
    #view-leads .lead-province-table .lead-mini-head > span:nth-child(4),
    #view-leads .lead-province-table .lead-mini-row > span:nth-child(4) {
        display: none !important;
    }

    #view-leads .lead-cost-editor-head,
    #view-leads .lead-cost-row {
        grid-template-columns: minmax(0, 1fr) minmax(0, .8fr) minmax(0, .36fr) !important;
    }

    #view-leads .lead-cost-editor-head > *:nth-child(4),
    #view-leads .lead-cost-row > *:nth-child(4),
    #view-leads .lead-cost-editor-head > *:nth-child(5),
    #view-leads .lead-cost-row > *:nth-child(5) {
        display: none !important;
    }
}

/* Higher-specificity no-swipe grid overrides for legacy lead mini-table rules. */
#view-leads .lead-mini-table.lead-sales-product-table .lead-mini-head,
#view-leads .lead-mini-table.lead-sales-product-table .lead-mini-row {
    grid-template-columns: 28px minmax(0, 1.45fr) minmax(0, .46fr) minmax(0, .38fr) minmax(0, .45fr) minmax(0, .65fr) minmax(0, .65fr) minmax(0, .55fr) !important;
    min-width: 0 !important;
}

#view-leads .lead-mini-table.lead-sales-category-table .lead-mini-head,
#view-leads .lead-mini-table.lead-sales-category-table .lead-mini-row {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, .38fr) minmax(0, .42fr) minmax(0, .62fr) minmax(0, .62fr) !important;
    min-width: 0 !important;
}

#view-leads .lead-mini-table.lead-targeting-table .lead-mini-head,
#view-leads .lead-mini-table.lead-targeting-table .lead-mini-row {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, .32fr) minmax(0, .32fr) minmax(0, .34fr) minmax(0, .5fr) minmax(0, .5fr) minmax(0, .5fr) minmax(0, .44fr) minmax(0, .78fr) minmax(0, .44fr) !important;
    min-width: 0 !important;
}

#view-leads .lead-mini-table.lead-product-conversion-table .lead-mini-head,
#view-leads .lead-mini-table.lead-product-conversion-table .lead-mini-row,
#view-leads .lead-mini-table.lead-province-table .lead-mini-head,
#view-leads .lead-mini-table.lead-province-table .lead-mini-row {
    grid-template-columns: minmax(0, 1.25fr) minmax(0, .38fr) minmax(0, .48fr) minmax(0, .52fr) !important;
    min-width: 0 !important;
}

#view-leads .lead-mini-table.lead-revenue-gap-table .lead-mini-head,
#view-leads .lead-mini-table.lead-revenue-gap-table .lead-mini-row {
    grid-template-columns: minmax(0, 1.1fr) minmax(0, .34fr) minmax(0, 1fr) !important;
    min-width: 0 !important;
}

@media (max-width: 760px) {
    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-head,
    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-row {
        grid-template-columns: 26px minmax(0, 1.4fr) minmax(0, .36fr) minmax(0, .58fr) !important;
    }

    #view-leads .lead-mini-table.lead-sales-category-table .lead-mini-head,
    #view-leads .lead-mini-table.lead-sales-category-table .lead-mini-row {
        grid-template-columns: minmax(0, 1.1fr) minmax(0, .36fr) minmax(0, .42fr) minmax(0, .58fr) !important;
    }

    #view-leads .lead-mini-table.lead-targeting-table .lead-mini-head,
    #view-leads .lead-mini-table.lead-targeting-table .lead-mini-row {
        grid-template-columns: minmax(0, 1.25fr) minmax(0, .38fr) minmax(0, .38fr) minmax(0, .48fr) minmax(0, .8fr) !important;
    }

    #view-leads .lead-mini-table.lead-product-conversion-table .lead-mini-head,
    #view-leads .lead-mini-table.lead-product-conversion-table .lead-mini-row,
    #view-leads .lead-mini-table.lead-province-table .lead-mini-head,
    #view-leads .lead-mini-table.lead-province-table .lead-mini-row {
        grid-template-columns: minmax(0, 1.25fr) minmax(0, .42fr) minmax(0, .52fr) !important;
    }
}

/* Lead productmix readability: no swipe, but enough room for the main table. */
#view-leads .lead-sales-intel-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 16px !important;
}

#view-leads .lead-sales-panel.is-wide {
    grid-column: 1 / -1 !important;
    grid-row: auto !important;
}

#view-leads .lead-sales-panel {
    align-self: start !important;
}

#view-leads .lead-mini-table.lead-sales-product-table .lead-mini-head,
#view-leads .lead-mini-table.lead-sales-product-table .lead-mini-row {
    grid-template-columns: 34px minmax(220px, 2fr) minmax(90px, .68fr) minmax(58px, .42fr) minmax(68px, .46fr) minmax(116px, .82fr) minmax(116px, .82fr) minmax(104px, .72fr) !important;
    gap: 10px !important;
}

#view-leads .lead-mini-table.lead-sales-product-table .lead-mini-head > span:nth-child(8),
#view-leads .lead-mini-table.lead-sales-product-table .lead-mini-row > span:nth-child(8) {
    display: block !important;
}

#view-leads .lead-mini-table.lead-sales-product-table .lead-mini-head > span:nth-child(3),
#view-leads .lead-mini-table.lead-sales-product-table .lead-mini-row > span:nth-child(3),
#view-leads .lead-mini-table.lead-sales-product-table .lead-mini-head > span:nth-child(5),
#view-leads .lead-mini-table.lead-sales-product-table .lead-mini-row > span:nth-child(5),
#view-leads .lead-mini-table.lead-sales-product-table .lead-mini-head > span:nth-child(7),
#view-leads .lead-mini-table.lead-sales-product-table .lead-mini-row > span:nth-child(7) {
    display: block !important;
}

#view-leads .lead-mini-table.lead-sales-category-table .lead-mini-head,
#view-leads .lead-mini-table.lead-sales-category-table .lead-mini-row {
    grid-template-columns: minmax(0, 1.25fr) minmax(52px, .35fr) minmax(60px, .42fr) minmax(92px, .72fr) minmax(92px, .72fr) !important;
}

#view-leads .lead-mini-toolbar {
    align-items: center !important;
    gap: 12px !important;
}

#view-leads .lead-mini-toolbar > div {
    gap: 8px !important;
}

@media (max-width: 1320px) {
    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-head,
    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-row {
        grid-template-columns: 30px minmax(0, 1.7fr) minmax(74px, .62fr) minmax(54px, .42fr) minmax(62px, .45fr) minmax(104px, .78fr) minmax(96px, .72fr) !important;
    }

    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-head > span:nth-child(8),
    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-row > span:nth-child(8) {
        display: none !important;
    }
}

@media (max-width: 980px) {
    #view-leads .lead-sales-intel-grid {
        grid-template-columns: 1fr !important;
    }

    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-head,
    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-row {
        grid-template-columns: 28px minmax(0, 1.45fr) minmax(56px, .42fr) minmax(88px, .68fr) minmax(84px, .62fr) !important;
    }

    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-head > span:nth-child(3),
    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-row > span:nth-child(3),
    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-head > span:nth-child(5),
    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-row > span:nth-child(5),
    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-head > span:nth-child(8),
    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-row > span:nth-child(8) {
        display: none !important;
    }
}

@media (max-width: 760px) {
    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-head,
    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-row {
        grid-template-columns: 26px minmax(0, 1.5fr) minmax(48px, .42fr) minmax(76px, .62fr) !important;
    }

    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-head > span:nth-child(7),
    #view-leads .lead-mini-table.lead-sales-product-table .lead-mini-row > span:nth-child(7) {
        display: none !important;
    }

    #view-leads .lead-mini-table.lead-sales-category-table .lead-mini-head,
    #view-leads .lead-mini-table.lead-sales-category-table .lead-mini-row {
        grid-template-columns: minmax(0, 1.1fr) minmax(46px, .34fr) minmax(62px, .46fr) !important;
    }

    #view-leads .lead-mini-table.lead-sales-category-table .lead-mini-head > span:nth-child(3),
    #view-leads .lead-mini-table.lead-sales-category-table .lead-mini-row > span:nth-child(3),
    #view-leads .lead-mini-table.lead-sales-category-table .lead-mini-head > span:nth-child(5),
    #view-leads .lead-mini-table.lead-sales-category-table .lead-mini-row > span:nth-child(5) {
        display: none !important;
    }
}

/* Lead-register hardening 2026-05-07: readable analytics, no collapsed campaign price grid. */
#view-leads .lead-targeting-table,
#view-leads .lead-cost-card,
#view-leads .lead-cost-editor {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
    overflow-x: clip !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
}

#view-leads .lead-mini-table.lead-targeting-table .lead-mini-head,
#view-leads .lead-mini-table.lead-targeting-table .lead-mini-row {
    grid-template-columns:
        minmax(136px, 1.15fr)
        minmax(58px, .38fr)
        minmax(54px, .34fr)
        minmax(60px, .38fr)
        minmax(104px, .7fr)
        minmax(104px, .7fr)
        minmax(108px, .72fr)
        minmax(72px, .5fr)
        minmax(180px, 1.18fr)
        minmax(118px, .78fr) !important;
    gap: 8px !important;
}

#view-leads .lead-targeting-table .lead-mini-head > span,
#view-leads .lead-targeting-table .lead-mini-row > span,
#view-leads .lead-targeting-table .lead-mini-row :is(em, small) {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
}

#view-leads .lead-cost-editor {
    display: block !important;
    grid-template-columns: none !important;
    max-height: 620px !important;
    overflow-y: auto !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 12px !important;
    background: var(--md-surface) !important;
}

#view-leads .lead-cost-summary-strip {
    display: grid !important;
    width: 100% !important;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)) !important;
    border-bottom: 1px solid var(--md-outline-variant) !important;
}

#view-leads .lead-cost-summary-item {
    min-width: 0 !important;
}

#view-leads .lead-cost-summary-item span,
#view-leads .lead-cost-summary-item strong {
    display: block !important;
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
}

#view-leads .lead-cost-editor-head,
#view-leads .lead-cost-row {
    display: grid !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    grid-template-columns:
        minmax(180px, 1.05fr)
        minmax(220px, 1.25fr)
        minmax(72px, .42fr)
        minmax(190px, 1fr)
        minmax(260px, 1.2fr) !important;
    gap: 12px !important;
    align-items: center !important;
    overflow-x: hidden !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
}

#view-leads .lead-cost-editor-head {
    position: sticky !important;
    top: 0 !important;
    z-index: 3 !important;
}

#view-leads .lead-cost-row > *,
#view-leads .lead-cost-row :is(strong, span, small, b),
#view-leads .lead-cost-editor-head > span {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
}

#view-leads .lead-cost-main,
#view-leads .lead-cost-meta,
#view-leads .lead-cost-number,
#view-leads .lead-cost-impact,
#view-leads .lead-cost-price {
    display: grid !important;
    min-width: 0 !important;
    grid-column: auto !important;
    grid-row: auto !important;
}

#view-leads .lead-cost-meta {
    gap: 2px !important;
}

#view-leads .lead-cost-input-row {
    display: grid !important;
    grid-template-columns: 42px minmax(84px, 1fr) 78px !important;
    gap: 6px !important;
    align-items: center !important;
    min-width: 0 !important;
}

#view-leads .lead-cost-input-row :is(span, input, button) {
    min-width: 0 !important;
    white-space: nowrap !important;
}

@media (max-width: 1240px) {
    #view-leads .lead-mini-table.lead-targeting-table .lead-mini-head,
    #view-leads .lead-mini-table.lead-targeting-table .lead-mini-row {
        grid-template-columns:
            minmax(132px, 1.2fr)
            minmax(56px, .42fr)
            minmax(54px, .38fr)
            minmax(102px, .72fr)
            minmax(102px, .72fr)
            minmax(172px, 1.18fr) !important;
    }

    #view-leads .lead-targeting-table .lead-mini-head > span:nth-child(4),
    #view-leads .lead-targeting-table .lead-mini-row > span:nth-child(4),
    #view-leads .lead-targeting-table .lead-mini-head > span:nth-child(7),
    #view-leads .lead-targeting-table .lead-mini-row > span:nth-child(7),
    #view-leads .lead-targeting-table .lead-mini-head > span:nth-child(8),
    #view-leads .lead-targeting-table .lead-mini-row > span:nth-child(8),
    #view-leads .lead-targeting-table .lead-mini-head > span:nth-child(10),
    #view-leads .lead-targeting-table .lead-mini-row > span:nth-child(10) {
        display: none !important;
    }

    #view-leads .lead-cost-editor-head,
    #view-leads .lead-cost-row {
        grid-template-columns: minmax(170px, 1.05fr) minmax(210px, 1.3fr) minmax(180px, 1fr) minmax(236px, 1.15fr) !important;
    }

    #view-leads .lead-cost-editor-head > span:nth-child(3),
    #view-leads .lead-cost-row > .lead-cost-number {
        display: none !important;
    }
}

@media (max-width: 760px) {
    #view-leads .lead-cost-summary-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    #view-leads .lead-cost-editor-head {
        display: none !important;
    }

    #view-leads .lead-cost-row {
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 8px !important;
        padding: 12px !important;
    }

    #view-leads .lead-cost-row > * {
        display: grid !important;
    }

    #view-leads .lead-cost-price {
        gap: 6px !important;
    }
}

/* Final lead workspace consistency pass 2026-05-07. Keep this block last. */
#view-leads,
#view-marketing {
    max-width: 100% !important;
    overflow-x: hidden !important;
}

.lead-workspace-tabs {
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    width: 100% !important;
    margin: 18px 0 14px !important;
    padding: 8px !important;
    border: 1px solid var(--md-outline-variant, #E0E3E7) !important;
    border-radius: 24px !important;
    background: var(--md-surface, #fff) !important;
    box-shadow: 0 1px 2px rgba(60, 64, 67, 0.08) !important;
}

.lead-workspace-tabs button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    min-width: 0 !important;
    min-height: 42px !important;
    padding: 0 16px !important;
    border: 1px solid transparent !important;
    border-radius: 18px !important;
    background: transparent !important;
    color: var(--md-on-surface-variant, #5f6368) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
}

.lead-workspace-tabs button.active,
.lead-workspace-tabs button[aria-current="page"] {
    border-color: rgba(66, 133, 244, 0.28) !important;
    background: var(--md-primary-container, #E8F0FE) !important;
    color: var(--md-primary, #4f73e6) !important;
}

.lead-workspace-tabs .material-symbols-rounded {
    font-size: 20px !important;
    line-height: 1 !important;
}

.lead-workspace-tabs b {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 24px !important;
    height: 24px !important;
    padding: 0 8px !important;
    border-radius: 999px !important;
    background: rgba(66, 133, 244, 0.12) !important;
    color: var(--md-primary, #4f73e6) !important;
    font-size: 12px !important;
    font-weight: 800 !important;
}

#view-leads .lead-sync-notice {
    align-items: center !important;
    flex-wrap: nowrap !important;
    gap: 12px !important;
}

#view-leads .lead-sync-notice > span:not(.material-symbols-rounded) {
    min-width: 0 !important;
    flex: 1 1 auto !important;
    line-height: 1.42 !important;
}

#view-leads .lead-sync-notice button {
    flex: 0 0 auto !important;
    width: auto !important;
    min-width: max-content !important;
    max-width: none !important;
    height: 36px !important;
    padding: 0 16px !important;
    white-space: nowrap !important;
    line-height: 1 !important;
}

#view-leads .lead-duplicate-workspace {
    display: grid !important;
    grid-template-columns: minmax(220px, 270px) minmax(0, 1fr) !important;
    gap: 18px !important;
    align-items: start !important;
    width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
}

#view-leads .lead-duplicate-supplier-panel,
#view-leads .lead-duplicate-table-panel,
#view-leads .lead-duplicate-worktable {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
}

#view-leads .lead-duplicate-supplier-title {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
}

#view-leads .lead-duplicate-supplier-title strong,
#view-leads .lead-duplicate-supplier-title span {
    white-space: nowrap !important;
}

#view-leads .lead-duplicate-supplier-list {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 6px !important;
    overflow-x: hidden !important;
}

#view-leads .lead-duplicate-supplier-list button {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 4px 8px !important;
    min-width: 0 !important;
    width: 100% !important;
}

#view-leads .lead-duplicate-supplier-list button span,
#view-leads .lead-duplicate-supplier-list button small,
#view-leads .lead-duplicate-workrow.is-head span,
#view-leads .lead-duplicate-workcell strong,
#view-leads .lead-duplicate-workcell small {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-leads .lead-duplicate-workrow {
    display: grid !important;
    grid-template-columns:
        minmax(0, 1.2fr)
        minmax(0, 0.95fr)
        minmax(0, 1.45fr)
        minmax(0, 0.78fr)
        minmax(0, 0.62fr)
        minmax(0, 1.08fr)
        minmax(0, 0.62fr) !important;
    gap: 12px !important;
    align-items: center !important;
    min-width: 0 !important;
    width: 100% !important;
    padding: 12px 14px !important;
    min-height: 88px !important;
}

#view-leads .lead-duplicate-workrow.is-head {
    min-height: 42px !important;
    padding: 10px 14px !important;
    background: var(--md-surface-variant, #F8FAFC) !important;
    font-size: 11px !important;
    letter-spacing: 0.04em !important;
    line-height: 1.2 !important;
}

#view-leads .lead-duplicate-workcell,
#view-leads .lead-duplicate-workcell > * {
    min-width: 0 !important;
    max-width: 100% !important;
}

#view-leads .lead-duplicate-workcell {
    display: grid !important;
    gap: 4px !important;
}

#view-leads .lead-claim-target-chip {
    display: inline-flex !important;
    width: fit-content !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-leads .lead-claim-target-select,
#view-leads .lead-duplicate-workcell select,
#view-leads .lead-duplicate-workcell input {
    width: 100% !important;
    min-width: 0 !important;
    height: 36px !important;
    padding: 0 10px !important;
    border-radius: 12px !important;
    font-size: 13px !important;
}

#view-leads .lead-claim-amount {
    display: grid !important;
    grid-template-columns: 42px minmax(0, 1fr) !important;
    gap: 6px !important;
    align-items: center !important;
    min-width: 0 !important;
}

#view-leads .lead-duplicate-line-editor,
#view-leads .lead-duplicate-actions {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 7px !important;
    min-width: 0 !important;
}

#view-leads .lead-duplicate-actions .leads-small-btn {
    width: 100% !important;
    min-width: 0 !important;
    height: 34px !important;
    padding: 0 10px !important;
    border-radius: 999px !important;
    white-space: nowrap !important;
}

#view-marketing .lead-workspace-tabs {
    margin-top: 0 !important;
}

#view-marketing .ops-kpis {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)) !important;
    gap: 14px !important;
    margin: 14px 0 18px !important;
}

#view-marketing .ops-kpis > div,
#view-marketing .ops-panel {
    border: 1px solid var(--md-outline-variant, #E0E3E7) !important;
    border-radius: 22px !important;
    background: var(--md-surface, #fff) !important;
    box-shadow: 0 1px 2px rgba(60, 64, 67, 0.08) !important;
}

#view-marketing .ops-kpis > div {
    display: grid !important;
    gap: 6px !important;
    padding: 18px !important;
}

#view-marketing .ops-kpis strong {
    font-size: clamp(22px, 2vw, 30px) !important;
    line-height: 1.05 !important;
    white-space: nowrap !important;
}

#view-marketing .ops-grid-main {
    display: grid !important;
    grid-template-columns: minmax(0, 1.55fr) minmax(320px, 0.85fr) !important;
    gap: 18px !important;
    align-items: start !important;
}

#view-marketing .ops-panel {
    min-width: 0 !important;
    padding: 18px !important;
}

#view-marketing .ops-table {
    overflow: hidden !important;
    border: 1px solid var(--md-outline-variant, #E0E3E7) !important;
    border-radius: 16px !important;
}

#view-marketing .ops-table-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1.8fr) repeat(4, minmax(0, 0.78fr)) !important;
    gap: 12px !important;
    align-items: center !important;
    width: 100% !important;
    min-width: 0 !important;
    padding: 12px 14px !important;
    border-bottom: 1px solid var(--md-outline-variant, #E0E3E7) !important;
}

#view-marketing .ops-table-head {
    background: var(--md-surface-variant, #F8FAFC) !important;
    color: var(--md-on-surface-variant, #5f6368) !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    letter-spacing: 0.04em !important;
    text-transform: uppercase !important;
}

#view-marketing .ops-table-row span,
#view-marketing .ops-table-row strong,
#view-marketing .ops-table-row small {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-marketing .ev-field input,
#view-marketing .ev-field select {
    width: 100% !important;
    min-width: 0 !important;
    height: 42px !important;
    border-radius: 14px !important;
}

.toast,
#toast {
    width: min(340px, calc(100vw - 32px)) !important;
    max-width: calc(100vw - 32px) !important;
    border-radius: 18px !important;
}

.toast-content span {
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    white-space: normal !important;
}

@media (max-width: 1200px) {
    #view-leads .lead-duplicate-workspace,
    #view-marketing .ops-grid-main {
        grid-template-columns: minmax(0, 1fr) !important;
    }

    #view-leads .lead-duplicate-supplier-list {
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
    }
}

@media (max-width: 820px) {
    .lead-workspace-tabs button {
        flex: 1 1 100% !important;
        justify-content: flex-start !important;
    }

    #view-leads .lead-sync-notice {
        flex-wrap: wrap !important;
    }

    #view-leads .lead-duplicate-workrow,
    #view-leads .lead-duplicate-workrow.is-head,
    #view-marketing .ops-table-row,
    #view-marketing .ops-table-head {
        grid-template-columns: minmax(0, 1fr) !important;
    }

    #view-leads .lead-duplicate-workrow.is-head,
    #view-marketing .ops-table-head {
        display: none !important;
    }
}

/* Duplicate requests workqueue final pass 2026-05-07 16:35. */
body[data-active-view="view-lead-duplicates"] #view-leads {
    gap: 14px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-filter-stack {
    position: static !important;
    top: auto !important;
    z-index: auto !important;
    margin: 0 0 12px !important;
    overflow: visible !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-filterbar {
    align-items: end !important;
    grid-template-columns: minmax(230px, 1.25fr) repeat(5, minmax(132px, 0.72fr)) !important;
    gap: 10px !important;
    overflow: visible !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-daterange {
    grid-column: 1 / -1 !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(170px, 220px)) minmax(0, 1fr) !important;
    gap: 10px !important;
    align-items: end !important;
    overflow: visible !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-daterange label {
    min-width: 0 !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-daterange input {
    height: 42px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-report-shell.is-duplicate-mode {
    gap: 12px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-report-shell.is-duplicate-mode .lead-report-heading {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 14px !important;
    margin: 0 !important;
    padding: 0 !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-report-shell.is-duplicate-mode .lead-report-heading h2 {
    font-size: clamp(26px, 2.4vw, 34px) !important;
    line-height: 1.15 !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-kpi-grid.is-duplicate-compact {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 12px !important;
    margin: 4px 0 10px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-kpi-grid.is-duplicate-compact .lead-kpi-card {
    min-height: 68px !important;
    padding: 12px 16px !important;
    border-radius: 14px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-status-overview {
    margin-bottom: 10px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-status-overview .lead-report-card-head,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicates-manager .lead-report-card-head {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 14px !important;
    align-items: center !important;
    padding: 14px 18px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-report-head-actions {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    min-width: 0 !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-report-head-actions span {
    white-space: nowrap !important;
    color: var(--md-on-surface-variant) !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-commandbar {
    padding: 10px 18px 12px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-filter-group.is-status {
    max-height: none !important;
    overflow: visible !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workspace {
    display: grid !important;
    grid-template-columns: 264px minmax(0, 1fr) !important;
    gap: 14px !important;
    align-items: start !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-supplier-panel {
    position: sticky !important;
    top: 16px !important;
    align-self: start !important;
    max-height: calc(100vh - 180px) !important;
    padding: 12px !important;
    border-right: 1px solid var(--md-outline-variant) !important;
    overflow: hidden !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-supplier-list {
    max-height: calc(100vh - 260px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding-right: 2px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-supplier-list button {
    min-height: 52px !important;
    padding: 9px 10px !important;
    border-radius: 12px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-table-panel {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-worktable {
    width: 100% !important;
    max-height: calc(100vh - 250px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    border-radius: 14px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workrow {
    grid-template-columns: minmax(170px, 1.18fr) minmax(150px, 0.9fr) minmax(230px, 1.26fr) minmax(128px, 0.7fr) minmax(94px, 0.5fr) minmax(280px, 1.48fr) minmax(132px, 0.62fr) !important;
    gap: 10px !important;
    min-height: 74px !important;
    padding: 10px 12px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workrow.is-head {
    min-height: 38px !important;
    padding: 9px 12px !important;
    background: var(--md-surface-variant, #F8FAFC) !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-claim-target-chip {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-editor {
    grid-template-columns: minmax(92px, 0.8fr) minmax(132px, 1.2fr) !important;
    gap: 6px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-claim-amount {
    grid-template-columns: 36px minmax(0, 1fr) !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-actions {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    flex-wrap: nowrap !important;
    gap: 6px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-actions .leads-small-btn {
    width: auto !important;
    min-width: 62px !important;
    height: 32px !important;
    min-height: 32px !important;
    padding: 0 11px !important;
    white-space: nowrap !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-actions .leads-small-btn:not(.is-secondary) {
    min-width: 76px !important;
}

@media (max-width: 1500px) {
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workspace {
        grid-template-columns: 1fr !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-supplier-panel {
        position: static !important;
        max-height: none !important;
        border-right: 0 !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-supplier-list {
        grid-template-columns: repeat(auto-fit, minmax(178px, 1fr)) !important;
        max-height: 150px !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-worktable {
        max-height: none !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workrow {
        grid-template-columns: minmax(170px, 1.15fr) minmax(150px, 0.95fr) minmax(220px, 1.25fr) minmax(122px, 0.75fr) minmax(92px, 0.55fr) !important;
        min-height: 104px !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workrow.is-head {
        display: none !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-proof {
        grid-column: 1 / 4 !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-actions {
        grid-column: 4 / -1 !important;
        justify-content: flex-end !important;
    }
}

@media (max-width: 1180px) {
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-filterbar {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-daterange {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workrow {
        grid-template-columns: 1fr !important;
        gap: 8px !important;
        min-height: 0 !important;
        padding: 12px !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workrow.is-head {
        display: none !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-actions {
        justify-content: flex-start !important;
        flex-wrap: wrap !important;
    }
}

@media (max-width: 760px) {
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-filterbar,
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-daterange,
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-kpi-grid.is-duplicate-compact,
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-status-overview .lead-report-card-head,
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicates-manager .lead-report-card-head {
        grid-template-columns: 1fr !important;
    }
}

/* Duplicate requests group cards final 2026-05-07. Keep after generic lead table rules. */
body[data-active-view="view-lead-duplicates"] #view-leads,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-report-shell,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-report-card,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-table-panel,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-group,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-entry-row {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .leads-secondary {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .leads-icon-btn {
    width: auto !important;
    min-width: 0 !important;
    height: 40px !important;
    padding: 0 14px !important;
    gap: 8px !important;
    border-radius: 999px !important;
}

#view-leads .leads-icon-btn .leads-action-label {
    display: none !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .leads-icon-btn .leads-action-label {
    display: inline !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font: 500 13px/1 var(--font-sans) !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-filterbar.is-duplicate-filterbar {
    grid-template-columns: minmax(260px, 1.4fr) minmax(180px, .8fr) minmax(180px, .8fr) !important;
    align-items: end !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-filterbar.is-duplicate-filterbar .lead-daterange {
    grid-column: 1 / -1 !important;
    grid-template-columns: repeat(2, minmax(160px, 220px)) minmax(0, 1fr) !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-kpi-grid.is-duplicate-compact {
    display: none !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-report-shell.is-duplicate-mode {
    gap: 12px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workspace {
    grid-template-columns: minmax(220px, 260px) minmax(0, 1fr) !important;
    gap: 14px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-supplier-panel {
    position: sticky !important;
    top: 88px !important;
    align-self: start !important;
    max-height: calc(100vh - 130px) !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-supplier-list {
    max-height: min(420px, calc(100vh - 250px)) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-group-list {
    display: grid !important;
    gap: 14px !important;
    min-width: 0 !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-group {
    display: grid !important;
    gap: 14px !important;
    padding: 16px !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 16px !important;
    background: var(--md-surface) !important;
    box-shadow: 0 1px 2px rgba(60, 64, 67, .08) !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-group header,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-head {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 12px !important;
    align-items: start !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-group h4 {
    margin: 0 !important;
    color: var(--md-on-surface) !important;
    font-size: 18px !important;
    font-weight: 500 !important;
    line-height: 24px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-group p,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-main span,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-meta span,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-policy-note,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-original-note {
    color: var(--md-on-surface-variant) !important;
    font-size: 12px !important;
    line-height: 18px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-tags,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-actions,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-group-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    justify-content: flex-end !important;
    min-width: 0 !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-summary-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 10px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-summary-grid > div {
    min-width: 0 !important;
    padding: 10px 12px !important;
    border-radius: 12px !important;
    background: var(--md-surface-variant) !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-summary-grid span,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-summary-grid strong {
    display: block !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-summary-grid span {
    color: var(--md-on-surface-variant) !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: .02em !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-summary-grid strong {
    color: var(--md-on-surface) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-timeline {
    display: grid !important;
    gap: 10px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-entry-row {
    display: grid !important;
    gap: 10px !important;
    padding: 12px !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 14px !important;
    background: var(--md-surface) !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-entry-row.is-visible-match {
    border-color: rgba(26, 115, 232, .28) !important;
    background: #fbfdff !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-entry-row.is-context {
    opacity: .72 !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-main {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    min-width: 0 !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-main > div {
    display: grid !important;
    gap: 2px !important;
    min-width: 0 !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-main strong,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-main span {
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-main strong {
    color: var(--md-on-surface) !important;
    font-size: 14px !important;
    font-weight: 500 !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-claim-chip {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 28px !important;
    max-width: 100% !important;
    padding: 4px 10px !important;
    border-radius: 999px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-size: 12px !important;
    font-weight: 500 !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-meta {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-meta span {
    min-width: 0 !important;
    padding: 8px 10px !important;
    border-radius: 10px !important;
    background: var(--md-surface-variant) !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-meta span strong {
    display: block !important;
    color: var(--md-on-surface) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: .02em !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-policy-note,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-original-note {
    padding: 10px 12px !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 12px !important;
    background: var(--md-surface-variant) !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-policy-note {
    display: grid !important;
    gap: 8px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-policy-note > div,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-policy-note ul {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    min-width: 0 !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-policy-note ul {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-policy-note li {
    max-width: 100% !important;
    padding: 4px 8px !important;
    border-radius: 999px !important;
    background: var(--md-surface-container) !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-form {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(138px, 1fr)) !important;
    gap: 10px !important;
    align-items: end !important;
    min-width: 0 !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-form label {
    display: grid !important;
    gap: 5px !important;
    min-width: 0 !important;
    color: var(--md-on-surface-variant) !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    text-transform: uppercase !important;
    letter-spacing: .02em !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-form select,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-form input,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-form textarea {
    width: 100% !important;
    min-width: 0 !important;
    border: 1px solid var(--md-outline) !important;
    border-radius: 10px !important;
    background: var(--md-surface) !important;
    color: var(--md-on-surface) !important;
    font: 400 13px/1.35 var(--font-sans) !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-form select,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-form input,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-claim-amount span {
    height: 36px !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-form textarea {
    min-height: 36px !important;
    max-height: 92px !important;
    padding: 8px 10px !important;
    resize: vertical !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-form .leads-small-btn {
    height: 36px !important;
    justify-self: start !important;
    white-space: nowrap !important;
}

body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-form .lead-duplicate-note {
    grid-column: span 2 !important;
}

@media (max-width: 1400px) {
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-workspace {
        grid-template-columns: 1fr !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-supplier-panel {
        position: static !important;
        max-height: none !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-supplier-list {
        display: grid !important;
        grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)) !important;
        max-height: 190px !important;
    }
}

@media (max-width: 1180px) {
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-filterbar.is-duplicate-filterbar,
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-group header,
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-head,
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-form {
        grid-template-columns: 1fr !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-tags,
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-actions,
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-group-actions {
        justify-content: flex-start !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-summary-grid,
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-meta {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 680px) {
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-summary-grid,
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-meta,
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-filterbar.is-duplicate-filterbar .lead-daterange,
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-kpi-grid.is-duplicate-compact {
        grid-template-columns: 1fr !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-form .lead-duplicate-note {
        grid-column: auto !important;
    }

    body[data-active-view="view-lead-duplicates"] #view-leads .leads-secondary,
    body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-group-actions,
body[data-active-view="view-lead-duplicates"] #view-leads .lead-duplicate-line-actions {
        width: 100% !important;
    }
}

/* 2026-05-08: product catalog readability guard. */
#view-products,
#view-products * {
    overflow-wrap: normal !important;
    word-break: normal !important;
    hyphens: none !important;
}

#view-products p,
#view-products small,
#view-products span,
#view-products strong,
#view-products b,
#view-products em,
#view-products button,
#view-products input,
#view-products select,
#view-products textarea {
    writing-mode: horizontal-tb !important;
}

#view-products button,
#view-products .ev-btn,
#view-products .product-page-tab,
#view-products .product-sticky-nav button,
#view-products .product-list-toggles button,
#view-products .product-source-chip,
#view-products .product-runtime-nav button,
#view-products .product-runtime-toggles button,
#view-products .product-runtime-periods button,
#view-products .product-runtime-source-tools button {
    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
}

#view-products .product-loss-banner,
#view-products .product-runtime-loss {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
    grid-template-columns: none !important;
    align-items: center !important;
}

#view-products .product-loss-banner > div,
#view-products .product-runtime-loss > strong {
    flex: 1 1 320px !important;
    min-width: 0 !important;
}

#view-products .product-runtime-loss > span {
    flex: 1 1 260px !important;
    min-width: 0 !important;
}

#view-products .product-loss-banner > button,
#view-products .product-runtime-loss > button {
    flex: 0 0 auto !important;
}

#view-products .product-category-toggle {
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    border: 0 !important;
    background: transparent !important;
    color: inherit !important;
    padding: 0 !important;
    font: inherit !important;
    text-align: left !important;
    cursor: pointer !important;
}

#view-products .product-category-toggle .material-symbols-rounded {
    transition: transform .15s ease !important;
}

#view-products .product-category-block:not(.is-collapsed) .product-category-toggle .material-symbols-rounded {
    transform: rotate(180deg) !important;
}

#view-products .product-runtime-component-editor select,
#view-products .product-component-editor-row select {
    min-height: 38px !important;
    min-width: 220px !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 8px !important;
    padding: 8px 10px !important;
    background: var(--md-surface) !important;
}

#view-products button.product-stat-card {
    width: 100% !important;
    border: 1px solid var(--md-outline-variant) !important;
    text-align: left !important;
    cursor: pointer !important;
}

#view-products button.product-stat-card.active {
    border-color: var(--md-primary) !important;
    background: var(--md-primary-container) !important;
}

#view-products .product-stat-card[data-runtime-filter-ready] {
    cursor: pointer !important;
}

#view-products .product-stat-card[data-runtime-filter-ready]:hover,
#view-products .product-stat-card.runtime-active {
    border-color: var(--md-primary) !important;
    background: var(--md-primary-container) !important;
}

#view-products .product-reset-filters {
    justify-self: start !important;
}

@media (max-width: 900px) {
    #view-products .product-loss-banner,
    #view-products .product-runtime-loss {
        flex-direction: column !important;
        align-items: flex-start !important;
    }

    #view-products .product-loss-banner button,
    #view-products .product-runtime-loss button {
        justify-self: start !important;
    }
}

/* 2026-05-08: CRM-wide final UI foundation. Loaded after Vite, so it wins over legacy page CSS. */
:root {
    --crm-font: "Google Sans", "Roboto", "Segoe UI", system-ui, sans-serif;
    --font-sans: var(--crm-font);
    --t-xs: 11px;
    --t-sm: 12px;
    --t-base: 13px;
    --t-md: 14px;
    --t-lg: 16px;
    --t-xl: 20px;
    --t-2xl: 24px;
    --t-3xl: 30px;
    --s-1: 4px;
    --s-2: 8px;
    --s-3: 12px;
    --s-4: 16px;
    --s-5: 20px;
    --s-6: 24px;
    --s-8: 32px;
    --s-10: 40px;
    --s-12: 48px;
    --s-16: 64px;
    --r-sm: 6px;
    --r-md: 10px;
    --r-lg: 14px;
    --r-pill: 999px;
    --crm-primary: #1a73e8;
    --crm-primary-hover: #1557b0;
    --crm-primary-soft: #e8f0fe;
    --crm-success: #1e8e3e;
    --crm-warning: #f9ab00;
    --crm-danger: #d93025;
    --crm-bg: #f8f9fa;
    --crm-surface: #ffffff;
    --crm-surface-2: #f1f3f4;
    --crm-border: #e0e3e7;
    --crm-text: #202124;
    --crm-muted: #5f6368;
    --crm-subtle: #80868b;
    --shadow-1: 0 1px 2px rgba(60, 64, 67, .08);
    --shadow-2: 0 2px 6px rgba(60, 64, 67, .12);
    --shadow-3: 0 8px 24px rgba(60, 64, 67, .18);
    --md-primary: var(--crm-primary);
    --md-primary-container: var(--crm-primary-soft);
    --md-on-primary: #fff;
    --md-surface: var(--crm-surface);
    --md-surface-variant: var(--crm-bg);
    --md-surface-container: var(--crm-surface-2);
    --md-on-surface: var(--crm-text);
    --md-on-surface-variant: var(--crm-muted);
    --md-outline: var(--crm-border);
    --md-outline-variant: #e8eaed;
    --success: var(--crm-success);
    --danger: var(--crm-danger);
}

html,
body,
.crm-app,
.crm-app :is(input, select, textarea, button) {
    font-family: var(--crm-font) !important;
}

.crm-app {
    color: var(--crm-text) !important;
    background: var(--crm-bg) !important;
    font-size: var(--t-base) !important;
    line-height: 1.4 !important;
}

.crm-app .intro {
    display: grid !important;
    gap: var(--s-2) !important;
    margin-bottom: var(--s-6) !important;
}

.crm-app .crm-page-header {
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: end !important;
}

.crm-app .crm-page-header-main {
    display: grid !important;
    gap: var(--s-2) !important;
    min-width: 0 !important;
}

.crm-app .crm-page-header-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: var(--s-2) !important;
    justify-content: flex-end !important;
}

.crm-app .intro .intro-label {
    color: var(--crm-subtle) !important;
    font-size: var(--t-xs) !important;
    font-weight: 600 !important;
    letter-spacing: .08em !important;
    line-height: 1.2 !important;
    text-transform: uppercase !important;
}

.crm-app .intro h1 {
    margin: 0 !important;
    color: var(--crm-text) !important;
    font-size: var(--t-2xl) !important;
    font-weight: 600 !important;
    letter-spacing: 0 !important;
    line-height: 1.2 !important;
}

.crm-app .intro p {
    max-width: 760px !important;
    margin: 0 !important;
    color: var(--crm-muted) !important;
    font-size: var(--t-md) !important;
    line-height: 1.45 !important;
}

.crm-app :is(.ev-btn, .leads-primary, .ops-primary, .gv-empty-cta, .crm-primary-btn, .crm-secondary-btn, .product-reset-filters, .product-page-tab, .product-segment, .lead-workspace-tabs button, .filter-chip, .bes-segment button, .customer-view-toggle button, .invoice-filter-chip, .ticket-filter-chip) {
    min-height: 36px !important;
    border-radius: var(--r-md) !important;
    font-size: var(--t-base) !important;
    font-weight: 500 !important;
    letter-spacing: 0 !important;
    line-height: 1.2 !important;
}

.crm-app :is(.ev-btn-primary, .leads-primary, .ops-primary, .gv-empty-cta:not(.secondary), .crm-primary-btn) {
    border-color: var(--crm-primary) !important;
    background: var(--crm-primary) !important;
    color: #fff !important;
    box-shadow: var(--shadow-1) !important;
}

.crm-app .crm-secondary-btn {
    border: 1px solid var(--crm-border) !important;
    background: var(--crm-surface) !important;
    color: var(--crm-primary) !important;
    box-shadow: none !important;
}

.crm-app :is(.ev-btn-primary, .leads-primary, .ops-primary, .gv-empty-cta:not(.secondary), .crm-primary-btn):hover {
    border-color: var(--crm-primary-hover) !important;
    background: var(--crm-primary-hover) !important;
}

.crm-app :is(.ev-btn-secondary, .leads-secondary, .ops-secondary, .gv-empty-cta.secondary, .product-page-tab, .product-segment, .filter-chip, .lead-workspace-tabs button) {
    border: 1px solid var(--crm-border) !important;
    background: var(--crm-surface) !important;
    color: var(--crm-muted) !important;
    box-shadow: none !important;
}

.crm-app :is(.product-page-tab.active, .product-segment.active, .filter-chip.active, .lead-workspace-tabs button.active, .bes-segment button.active, .customer-view-toggle button.active) {
    border-color: var(--crm-primary) !important;
    background: var(--crm-primary-soft) !important;
    color: var(--crm-primary) !important;
}

.crm-app :is(.dashboard-stat, .kpi-card, .product-stat-card, .finance-kpi, .invoice-kpi, .energy-kpi, .user-stat-card, .ops-panel, .lead-report-card, .mapped-module-shell, .gv-empty) {
    border: 1px solid var(--crm-border) !important;
    border-radius: var(--r-lg) !important;
    background: var(--crm-surface) !important;
    box-shadow: var(--shadow-1) !important;
}

.crm-app :is(.dashboard-stat, .kpi-card, .product-stat-card, .finance-kpi, .invoice-kpi, .energy-kpi, .user-stat-card) {
    min-height: 96px !important;
    padding: var(--s-4) !important;
}

.crm-app :is(.dashboard-stat span, .kpi-card span, .product-stat-card span, .finance-kpi span, .invoice-kpi span, .energy-kpi span, .user-stat-card span) {
    color: var(--crm-muted) !important;
    font-size: var(--t-sm) !important;
    font-weight: 600 !important;
    letter-spacing: .06em !important;
    text-transform: uppercase !important;
}

.crm-app :is(.dashboard-stat strong, .kpi-card strong, .product-stat-card strong, .finance-kpi strong, .invoice-kpi strong, .energy-kpi strong, .user-stat-card strong) {
    color: var(--crm-text) !important;
    font-size: var(--t-2xl) !important;
    font-weight: 600 !important;
    letter-spacing: 0 !important;
    line-height: 1.2 !important;
}

.crm-app :is(.badge, .status-badge, .customer-status, .product-status, .lead-pill, .filter-chip, .invoice-status, .ticket-status) {
    border-radius: var(--r-pill) !important;
    font-size: var(--t-sm) !important;
    font-weight: 500 !important;
    letter-spacing: 0 !important;
}

.crm-app :is(.filterbar, .lead-filterbar, .customer-filterbar, .product-toolbar, .invoice-filters, .ticket-filters, .finance-filters) {
    border: 1px solid var(--crm-border) !important;
    border-radius: var(--r-lg) !important;
    background: var(--crm-surface) !important;
    box-shadow: var(--shadow-1) !important;
}

.crm-app .crm-module-hero {
    border: 1px solid var(--crm-border) !important;
    border-radius: var(--r-lg) !important;
    background: var(--crm-surface) !important;
    box-shadow: var(--shadow-1) !important;
    color: var(--crm-text) !important;
}

.crm-app :is(input, select, textarea) {
    border-color: var(--crm-border) !important;
    border-radius: var(--r-md) !important;
    color: var(--crm-text) !important;
    font-size: var(--t-md) !important;
}

.crm-app :is(input, select, textarea, button, a):focus-visible {
    outline: 2px solid var(--crm-primary) !important;
    outline-offset: 2px !important;
}

.crm-app .sidebar-link {
    text-decoration: none !important;
}

.crm-app .gv-empty {
    padding: var(--s-8) !important;
    text-align: center !important;
}

.crm-app .gv-empty-title {
    color: var(--crm-text) !important;
    font-size: 18px !important;
    font-weight: 600 !important;
}

.crm-app .gv-empty-desc {
    color: var(--crm-muted) !important;
    font-size: var(--t-md) !important;
}

.crm-app .qt-fab {
    right: 28px !important;
    bottom: 28px !important;
    left: auto !important;
    width: 52px !important;
    height: 52px !important;
    border-radius: var(--r-pill) !important;
    background: var(--crm-primary) !important;
    color: #fff !important;
    box-shadow: var(--shadow-3) !important;
}

.qt-fab {
    right: 28px !important;
    bottom: 28px !important;
    left: auto !important;
    width: 52px !important;
    height: 52px !important;
    border-radius: var(--r-pill) !important;
    background: var(--crm-primary) !important;
    color: #fff !important;
    box-shadow: var(--shadow-3) !important;
}

.crm-app .toast {
    border-radius: var(--r-lg) !important;
    box-shadow: var(--shadow-3) !important;
}

.toast {
    border-radius: var(--r-lg) !important;
    box-shadow: var(--shadow-3) !important;
}

@media (max-width: 900px) {
    .crm-app .main-content > .page {
        padding-inline: var(--s-4) !important;
    }

    .crm-app .qt-fab {
        right: 18px !important;
        bottom: 18px !important;
    }

    .qt-fab {
        right: 18px !important;
        bottom: 18px !important;
    }
}

/* Deep audit hotfix 08-05: modal opacity, text wrapping and material-demand density. */
.crm-modal.show,
.template-modal {
    position: fixed !important;
    inset: 0 !important;
    z-index: 9000 !important;
    isolation: isolate !important;
    overflow: hidden !important;
}

.crm-modal.show::before,
.template-modal::before {
    content: "" !important;
    position: fixed !important;
    inset: 0 !important;
    z-index: 0 !important;
    background: rgba(32, 33, 36, 0.68) !important;
    backdrop-filter: blur(3px) !important;
    pointer-events: none !important;
}

.crm-modal-overlay,
.template-modal-backdrop,
.targeting-drill-backdrop {
    position: fixed !important;
    inset: 0 !important;
    z-index: 1 !important;
    background: rgba(32, 33, 36, 0.68) !important;
    opacity: 1 !important;
    backdrop-filter: blur(3px) !important;
}

.crm-modal-box,
.template-modal-box,
.targeting-drill-box {
    position: relative !important;
    z-index: 2 !important;
    background: var(--crm-surface, #fff) !important;
}

.crm-app,
.crm-app :is(p, span, small, strong, b, em, dd, td, th, li) {
    word-break: normal !important;
    overflow-wrap: break-word !important;
}

.crm-app :is(button, .crm-primary-btn, .crm-secondary-btn, .ev-btn, .back-btn, .ops-mini-action, .crm-nowrap-action),
.crm-email-text,
.crm-email-text *,
a[href^="mailto:"] {
    white-space: nowrap !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
}

#view-products .product-material-grid {
    grid-template-columns: repeat(auto-fit, minmax(min(460px, 100%), 1fr)) !important;
}

#view-products .product-material-card,
#view-products .product-material-card * {
    min-width: 0 !important;
}

#view-products .product-material-row {
    grid-template-columns: minmax(240px, 1fr) minmax(280px, 1.25fr) max-content !important;
}

#view-products .product-material-row > *,
#view-products .product-unlinked-list > span,
#view-products .product-unlinked-list > span > * {
    min-width: 0 !important;
    max-width: 100% !important;
}

#view-products .product-material-row small,
#view-products .product-unlinked-list small,
#view-products .product-unlinked-list strong {
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
}

#view-products .product-unlinked-list > span {
    display: block !important;
}

@media (max-width: 1180px) {
    #view-products .product-material-row {
        grid-template-columns: 1fr !important;
        align-items: start !important;
    }

    #view-products .product-material-row .ops-mini-action {
        justify-self: start !important;
    }
}

/* Lead-register Google review pass 08-05: semantic signal colors, conversion definitions and compact score bars. */
#view-leads .lead-metric-definition-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)) !important;
    gap: 8px !important;
}

#view-leads .lead-metric-definition-grid span {
    display: block !important;
    min-width: 0 !important;
    padding: 10px 12px !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-radius: 10px !important;
    background: #fff !important;
    color: var(--md-on-surface-variant) !important;
    font-size: 12px !important;
    line-height: 1.45 !important;
}

#view-leads .lead-metric-definition-grid strong {
    display: block !important;
    margin-bottom: 3px !important;
    color: var(--md-on-surface) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
}

#view-leads .lead-insight-card {
    margin: 16px 0 !important;
}

#view-leads .lead-insight-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 12px !important;
}

#view-leads .lead-insight-grid article {
    display: grid !important;
    gap: 6px !important;
    min-width: 0 !important;
    padding: 14px !important;
    border: 1px solid var(--md-outline-variant) !important;
    border-left: 4px solid var(--md-outline-variant) !important;
    border-radius: 14px !important;
    background: var(--md-surface-container-low, #fff) !important;
}

#view-leads .lead-insight-grid article.is-positive { border-left-color: #137333 !important; background: #f1f8f3 !important; }
#view-leads .lead-insight-grid article.is-info { border-left-color: #2850c7 !important; background: #f5f8ff !important; }
#view-leads .lead-insight-grid article.is-warning { border-left-color: #b06000 !important; background: #fff8e1 !important; }
#view-leads .lead-insight-grid article.is-danger { border-left-color: #b3261e !important; background: #fef3f2 !important; }

#view-leads .lead-insight-grid article span {
    color: var(--md-on-surface-variant) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: .05em !important;
    text-transform: uppercase !important;
}

#view-leads .lead-insight-grid article strong {
    min-width: 0 !important;
    overflow: hidden !important;
    color: var(--md-on-surface) !important;
    font-size: 18px !important;
    font-weight: 650 !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-leads .lead-insight-grid article p {
    margin: 0 !important;
    color: var(--md-on-surface-variant) !important;
    font-size: 12px !important;
    line-height: 1.45 !important;
}

#view-leads .lead-mini-row em:is(.is-positive, .is-info, .is-warning, .is-danger, .is-neutral) {
    display: inline-flex !important;
    max-width: 100% !important;
    align-items: center !important;
    padding: 4px 10px !important;
    border-radius: 999px !important;
    font-style: normal !important;
    font-weight: 700 !important;
}

#view-leads .lead-mini-row em.is-positive,
#view-leads .lead-score-bar.is-positive { background: #e8f5e9 !important; color: #137333 !important; }
#view-leads .lead-mini-row em.is-info,
#view-leads .lead-score-bar.is-info { background: #e8f0fe !important; color: #2850c7 !important; }
#view-leads .lead-mini-row em.is-warning,
#view-leads .lead-score-bar.is-warning { background: #fff4ce !important; color: #8a5a00 !important; }
#view-leads .lead-mini-row em.is-danger,
#view-leads .lead-score-bar.is-danger { background: #fce8e6 !important; color: #b3261e !important; }
#view-leads .lead-mini-row em.is-neutral,
#view-leads .lead-score-bar.is-neutral { background: var(--md-surface-container, #f1f3f4) !important; color: var(--md-on-surface-variant, #5f6368) !important; }

#view-leads .lead-mini-row > span > small {
    margin-top: 4px !important;
}

#view-leads .lead-score-cell {
    display: grid !important;
    gap: 5px !important;
    align-items: center !important;
    min-width: 0 !important;
}

#view-leads .lead-score-cell b {
    display: block !important;
    overflow: hidden !important;
    color: var(--md-on-surface) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    line-height: 1.1 !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-leads .lead-score-cell i {
    display: block !important;
    width: 100% !important;
    height: 6px !important;
    overflow: hidden !important;
    border-radius: 999px !important;
    background: var(--md-surface-container, #eef1f5) !important;
}

#view-leads .lead-score-bar {
    display: block !important;
    height: 100% !important;
    border-radius: inherit !important;
}

@media (max-width: 900px) {
    #view-leads .lead-insight-grid {
        grid-template-columns: 1fr !important;
    }
}

/* Lead-register campaign readability pass 08-05: supplier campaigns and LeadDesk belcampagnes stay separate. */
#view-leads .lead-mini-table.lead-leaddesk-campaign-table .lead-mini-head,
#view-leads .lead-mini-table.lead-leaddesk-campaign-table .lead-mini-row {
    grid-template-columns: minmax(0, 1.65fr) 82px 82px 82px 78px !important;
}

#view-leads .lead-table-tools {
    display: grid !important;
    grid-template-columns: minmax(260px, 1.25fr) repeat(6, minmax(132px, .62fr)) minmax(92px, .38fr) auto auto !important;
    align-items: end !important;
    gap: 10px !important;
    flex: 1 1 980px !important;
    width: 100% !important;
}

#view-leads .lead-table-tools label {
    display: grid !important;
    gap: 4px !important;
    color: var(--md-on-surface-variant) !important;
    font-size: 12px !important;
    font-weight: 500 !important;
}

#view-leads .lead-table-tools .form-select,
#view-leads .lead-list-search input {
    width: 100% !important;
    height: 40px !important;
    padding: 0 12px !important;
    border: 1px solid var(--md-outline) !important;
    border-radius: 12px !important;
    background: var(--md-surface) !important;
    color: var(--md-on-surface) !important;
    font-size: 14px !important;
}

#view-leads .lead-data-table-wrap {
    max-height: none !important;
    overflow-x: auto !important;
    overflow-y: visible !important;
}

#view-leads .lead-data-table {
    min-width: 1620px !important;
    table-layout: fixed !important;
}

#view-leads .lead-data-table th {
    position: sticky !important;
    top: 0 !important;
    z-index: 2 !important;
    white-space: nowrap !important;
    overflow-wrap: normal !important;
}

#view-leads .lead-data-table td {
    word-break: normal !important;
    overflow-wrap: normal !important;
}

#view-leads .lead-data-table td:not(.lead-customer-cell),
#view-leads .lead-data-table th {
    white-space: nowrap !important;
}

#view-leads .lead-product-cell,
#view-leads .lead-customer-cell strong,
#view-leads .lead-customer-cell a,
#view-leads .lead-customer-cell small {
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-leads .lead-source-campaign-cell,
#view-leads .lead-id-cell,
#view-leads .lead-date-cell,
#view-leads .lead-call-cell {
    display: grid !important;
    gap: 3px !important;
    align-content: center !important;
    min-width: 0 !important;
}

#view-leads .lead-source-campaign-cell small,
#view-leads .lead-id-cell small,
#view-leads .lead-date-cell small,
#view-leads .lead-call-cell small {
    color: var(--md-on-surface-variant) !important;
    font-size: 12px !important;
    line-height: 1.25 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-leads .lead-source-campaign-cell small b {
    margin-right: 4px !important;
    color: var(--md-on-surface) !important;
    font-weight: 700 !important;
}

#view-leads .lead-id-cell strong,
#view-leads .lead-call-cell strong,
#view-leads .lead-call-cell small {
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-leads .lead-data-table th:nth-child(1),
#view-leads .lead-data-table td:nth-child(1) { width: 285px !important; }
#view-leads .lead-data-table th:nth-child(2),
#view-leads .lead-data-table td:nth-child(2) { width: 165px !important; }
#view-leads .lead-data-table th:nth-child(3),
#view-leads .lead-data-table td:nth-child(3) { width: 150px !important; }
#view-leads .lead-data-table th:nth-child(4),
#view-leads .lead-data-table td:nth-child(4) { width: 118px !important; }
#view-leads .lead-data-table th:nth-child(5),
#view-leads .lead-data-table td:nth-child(5) { width: 210px !important; }
#view-leads .lead-data-table th:nth-child(6),
#view-leads .lead-data-table td:nth-child(6) { width: 145px !important; }
#view-leads .lead-data-table th:nth-child(7),
#view-leads .lead-data-table td:nth-child(7) { width: 260px !important; }
#view-leads .lead-data-table th:nth-child(8),
#view-leads .lead-data-table td:nth-child(8) { width: 165px !important; }
#view-leads .lead-data-table th:nth-child(9),
#view-leads .lead-data-table td:nth-child(9) { width: 118px !important; }

#view-leads .lead-call-cell strong,
#view-leads .lead-call-cell small {
    max-width: 155px !important;
}

@media (max-width: 900px) {
    #view-leads .lead-table-tools {
        grid-template-columns: 1fr !important;
    }

    #view-leads .lead-mini-table.lead-leaddesk-campaign-table .lead-mini-head {
        display: none !important;
    }

    #view-leads .lead-mini-table.lead-leaddesk-campaign-table .lead-mini-row {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

/* Lead-register redesign foundation 08-05: semantic chips, compact density and first visual analysis layer. */
#view-leads .lead-kpi-grid {
    grid-template-columns: repeat(auto-fit, minmax(168px, 1fr)) !important;
    gap: 10px !important;
}

#view-leads .lead-kpi-card {
    min-height: 96px !important;
    padding: 14px 16px !important;
}

#view-leads .lead-kpi-card span {
    margin-bottom: 5px !important;
    font-size: 12px !important;
    font-weight: 650 !important;
    letter-spacing: .02em !important;
}

#view-leads .lead-kpi-card strong {
    font-size: 25px !important;
    font-weight: 650 !important;
    line-height: 31px !important;
}

#view-leads .lead-kpi-card small {
    display: block !important;
    margin-top: 4px !important;
    overflow: hidden !important;
    color: var(--md-on-surface-variant, #5f6368) !important;
    font-size: 11px !important;
    line-height: 15px !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-leads .lead-kpi-benchmark {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    gap: 7px !important;
    align-items: center !important;
    margin-top: 8px !important;
}

#view-leads .lead-kpi-benchmark i {
    display: block !important;
    height: 5px !important;
    overflow: hidden !important;
    border-radius: 999px !important;
    background: #e2e8f0 !important;
}

#view-leads .lead-kpi-benchmark b {
    display: block !important;
    height: 100% !important;
    border-radius: inherit !important;
    background: #1a73e8 !important;
}

#view-leads .lead-kpi-benchmark em {
    color: #64748b !important;
    font-size: 10px !important;
    font-style: normal !important;
    font-weight: 650 !important;
    white-space: nowrap !important;
}

#view-leads .lead-report-card-head {
    padding: 12px 16px !important;
}

#view-leads .lead-report-card-head h3 {
    font-size: 16px !important;
    font-weight: 650 !important;
    line-height: 22px !important;
}

#view-leads .lead-report-card-head p {
    font-size: 12px !important;
    line-height: 18px !important;
}

#view-leads .lead-mini-head,
#view-leads .lead-mini-row {
    padding: 9px 14px !important;
}

#view-leads .lead-source-chip,
#view-leads .lead-mini-row em:not(.is-positive):not(.is-info):not(.is-warning):not(.is-danger):not(.is-neutral):not(.sentiment-negative):not(.sentiment-lost):not(.sentiment-neutral) {
    gap: 6px !important;
    border: 1px solid #cbd5e1 !important;
    background: #fff !important;
    color: #334155 !important;
    font-weight: 650 !important;
}

#view-leads .lead-source-chip::before,
#view-leads .lead-mini-row em:not(.is-positive):not(.is-info):not(.is-warning):not(.is-danger):not(.is-neutral):not(.sentiment-negative):not(.sentiment-lost):not(.sentiment-neutral)::before {
    width: 6px !important;
    height: 6px !important;
    flex: 0 0 auto !important;
    border-radius: 999px !important;
    background: #4f46e5 !important;
    content: "" !important;
}

#view-leads .lead-status-chip {
    gap: 6px !important;
    border: 1px solid transparent !important;
    font-weight: 750 !important;
}

#view-leads .lead-status-chip::before {
    width: 7px !important;
    height: 7px !important;
    flex: 0 0 auto !important;
    border-radius: 999px !important;
    content: "" !important;
}

#view-leads .lead-status-chip.is-sale,
#view-leads .lead-status-chip.is-green {
    border-color: #bbf7d0 !important;
    background: #ecfdf3 !important;
    color: #047857 !important;
}

#view-leads .lead-status-chip.is-sale::before,
#view-leads .lead-status-chip.is-green::before { background: #059669 !important; }

#view-leads .lead-status-chip.is-offer,
#view-leads .lead-status-chip.is-blue {
    border-color: #bfdbfe !important;
    background: #eff6ff !important;
    color: #1d4ed8 !important;
}

#view-leads .lead-status-chip.is-offer::before,
#view-leads .lead-status-chip.is-blue::before { background: #2563eb !important; }

#view-leads .lead-status-chip.is-contacted {
    border-color: #cbd5e1 !important;
    background: #f1f5f9 !important;
    color: #475569 !important;
}

#view-leads .lead-status-chip.is-contacted::before { background: #64748b !important; }

#view-leads .lead-status-chip.is-no-contact {
    border-color: #fde68a !important;
    background: #fffbeb !important;
    color: #a16207 !important;
}

#view-leads .lead-status-chip.is-no-contact::before { background: #d97706 !important; }

#view-leads .lead-status-chip.is-lost,
#view-leads .lead-status-chip.is-red {
    border-color: #fecdd3 !important;
    background: #fff1f2 !important;
    color: #be123c !important;
}

#view-leads .lead-status-chip.is-lost::before,
#view-leads .lead-status-chip.is-red::before { background: #e11d48 !important; }

#view-leads .lead-status-chip.is-new {
    border-color: #ddd6fe !important;
    background: #f5f3ff !important;
    color: #6d28d9 !important;
}

#view-leads .lead-status-chip.is-new::before { background: #7c3aed !important; }

#view-leads :is(button, [role="button"], a, input, select, textarea):focus-visible {
    outline: 2px solid #334155 !important;
    outline-offset: 2px !important;
}

#view-leads .lead-click-row:hover {
    background: #f8fafc !important;
}

#view-leads .lead-visual-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 14px !important;
}

#view-leads .lead-funnel-visual,
#view-leads .lead-dual-chart,
#view-leads .lead-province-heat {
    display: grid !important;
    gap: 10px !important;
    padding: 14px 16px 16px !important;
}

#view-leads .lead-funnel-step {
    display: grid !important;
    grid-template-columns: minmax(120px, .75fr) minmax(0, 1fr) minmax(128px, .8fr) !important;
    gap: 12px !important;
    align-items: center !important;
}

#view-leads .lead-funnel-step div {
    display: grid !important;
    gap: 2px !important;
}

#view-leads .lead-funnel-step strong {
    color: #202124 !important;
    font-size: 13px !important;
}

#view-leads .lead-funnel-step span,
#view-leads .lead-funnel-step small {
    color: #64748b !important;
    font-size: 12px !important;
}

#view-leads .lead-funnel-step i,
#view-leads .lead-dual-row i {
    position: relative !important;
    display: block !important;
    height: 12px !important;
    border-radius: 999px !important;
    background: #e2e8f0 !important;
}

#view-leads .lead-funnel-step i b,
#view-leads .lead-dual-row i b {
    display: block !important;
    height: 100% !important;
    border-radius: inherit !important;
}

#view-leads .lead-funnel-step.is-positive i b,
#view-leads .lead-dual-row i b.is-positive { background: #059669 !important; }
#view-leads .lead-funnel-step.is-info i b,
#view-leads .lead-dual-row i b.is-info { background: #2563eb !important; }
#view-leads .lead-funnel-step.is-warning i b,
#view-leads .lead-dual-row i b.is-warning { background: #d97706 !important; }
#view-leads .lead-funnel-step.is-danger i b,
#view-leads .lead-dual-row i b.is-danger { background: #e11d48 !important; }
#view-leads .lead-dual-row i b.is-neutral { background: #94a3b8 !important; }

#view-leads .lead-dual-row {
    display: grid !important;
    grid-template-columns: 92px minmax(0, 1fr) 76px 70px !important;
    gap: 10px !important;
    align-items: center !important;
    color: #475569 !important;
    font-size: 12px !important;
}

#view-leads .lead-dual-row em {
    position: absolute !important;
    top: 50% !important;
    width: 10px !important;
    height: 10px !important;
    border: 2px solid #fff !important;
    border-radius: 999px !important;
    background: #111827 !important;
    box-shadow: 0 0 0 1px #94a3b8 !important;
    transform: translate(-50%, -50%) !important;
}

#view-leads .lead-dual-row strong {
    color: #202124 !important;
    text-align: right !important;
}

#view-leads .lead-bubble-chart {
    position: relative !important;
    min-height: 250px !important;
    margin: 14px 16px 18px !important;
    overflow: hidden !important;
    border: 1px solid #e2e8f0 !important;
    border-radius: 14px !important;
    background:
        linear-gradient(#eef2f7 1px, transparent 1px),
        linear-gradient(90deg, #eef2f7 1px, transparent 1px),
        #fff !important;
    background-size: 25% 25% !important;
}

#view-leads .lead-bubble-chart button {
    position: absolute !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 2px solid #fff !important;
    border-radius: 999px !important;
    color: #fff !important;
    cursor: pointer !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    transform: translate(-50%, 50%) !important;
    box-shadow: 0 8px 22px rgba(15, 23, 42, .16) !important;
}

#view-leads .lead-bubble-chart button.is-positive { background: #059669 !important; }
#view-leads .lead-bubble-chart button.is-info { background: #2563eb !important; }
#view-leads .lead-bubble-chart button.is-warning { background: #d97706 !important; }
#view-leads .lead-bubble-chart button.is-danger { background: #e11d48 !important; }
#view-leads .lead-bubble-chart button.is-neutral { background: #64748b !important; }

#view-leads .lead-bubble-axis {
    position: absolute !important;
    color: #64748b !important;
    font-size: 11px !important;
    font-weight: 650 !important;
}

#view-leads .lead-bubble-axis.is-x {
    right: 10px !important;
    bottom: 8px !important;
}

#view-leads .lead-bubble-axis.is-y {
    top: 10px !important;
    left: 10px !important;
}

#view-leads .lead-province-heat {
    grid-template-columns: repeat(auto-fit, minmax(132px, 1fr)) !important;
}

#view-leads .lead-province-heat button {
    display: grid !important;
    gap: 3px !important;
    min-height: 74px !important;
    padding: 10px !important;
    border: 1px solid transparent !important;
    border-radius: 12px !important;
    text-align: left !important;
    cursor: pointer !important;
}

#view-leads .lead-province-heat button.is-positive { background: #ecfdf3 !important; border-color: #bbf7d0 !important; color: #047857 !important; }
#view-leads .lead-province-heat button.is-info { background: #eff6ff !important; border-color: #bfdbfe !important; color: #1d4ed8 !important; }
#view-leads .lead-province-heat button.is-warning { background: #fffbeb !important; border-color: #fde68a !important; color: #a16207 !important; }
#view-leads .lead-province-heat button.is-danger { background: #fff1f2 !important; border-color: #fecdd3 !important; color: #be123c !important; }
#view-leads .lead-province-heat button.is-neutral { background: #f8fafc !important; border-color: #e2e8f0 !important; color: #475569 !important; }

#view-leads .lead-province-heat strong {
    overflow: hidden !important;
    color: inherit !important;
    font-size: 13px !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#view-leads .lead-province-heat span {
    color: inherit !important;
    font-size: 18px !important;
    font-weight: 750 !important;
}

#view-leads .lead-province-heat small {
    color: currentColor !important;
    font-size: 11px !important;
}

@media (max-width: 1100px) {
    #view-leads .lead-visual-grid {
        grid-template-columns: 1fr !important;
    }
}

@media (max-width: 700px) {
    #view-leads .lead-funnel-step,
    #view-leads .lead-dual-row {
        grid-template-columns: 1fr !important;
    }
}

/* Enterprise portal tokens bridge 08-05: mirrored for the legacy runtime stylesheet. */
:root {
    --color-brand-50: #f0fdf4;
    --color-brand-100: #dcfce7;
    --color-brand-500: #22c55e;
    --color-brand-600: #16a34a;
    --color-brand-700: #15803d;
    --color-surface-base: #ffffff;
    --color-surface-raised: #ffffff;
    --color-surface-sunken: #f8fafc;
    --color-surface-overlay: #ffffff;
    --color-text-primary: #0f172a;
    --color-text-secondary: #475569;
    --color-text-tertiary: #94a3b8;
    --color-text-inverse: #ffffff;
    --color-border-default: #e2e8f0;
    --color-border-strong: #cbd5e1;
    --color-border-focus: #0f172a;
    --color-status-success-bg: #d1fae5;
    --color-status-success-fg: #065f46;
    --color-status-warning-bg: #fef3c7;
    --color-status-warning-fg: #92400e;
    --color-status-danger-bg: #fee2e2;
    --color-status-danger-fg: #991b1b;
    --color-status-info-bg: #dbeafe;
    --color-status-info-fg: #1e40af;
    --color-status-neutral-bg: #f1f5f9;
    --color-status-neutral-fg: #334155;
    --color-dimension-supplier: #6366f1;
    --color-dimension-manager: #14b8a6;
    --color-dimension-region: #f59e0b;
    --color-dimension-product: #10b981;
    --color-dimension-campaign: #a855f7;
    --font-sans-enterprise: "Inter", "Google Sans", "Roboto", system-ui, sans-serif;
    --font-mono-enterprise: "JetBrains Mono", "SFMono-Regular", Consolas, monospace;
    --text-tabular: "tnum" 1, "lnum" 1;
    --density-row-height: 48px;
    --density-card-padding: 24px;
    --density-kpi-height: 128px;
}

:root[data-theme="dark"] {
    color-scheme: dark;
    --color-surface-base: #0f172a;
    --color-surface-raised: #1e293b;
    --color-surface-sunken: #020617;
    --color-surface-overlay: #1e293b;
    --color-text-primary: #f1f5f9;
    --color-text-secondary: #cbd5e1;
    --color-text-tertiary: #64748b;
    --color-border-default: #334155;
    --color-border-strong: #475569;
    --color-border-focus: #f1f5f9;
    --color-status-success-bg: rgba(16, 185, 129, 0.15);
    --color-status-success-fg: #6ee7b7;
    --color-status-warning-bg: rgba(245, 158, 11, 0.16);
    --color-status-warning-fg: #fcd34d;
    --color-status-danger-bg: rgba(239, 68, 68, 0.16);
    --color-status-danger-fg: #fca5a5;
    --color-status-info-bg: rgba(59, 130, 246, 0.16);
    --color-status-info-fg: #93c5fd;
    --color-status-neutral-bg: rgba(148, 163, 184, 0.14);
    --color-status-neutral-fg: #cbd5e1;
}

:root[data-density="compact"] {
    --density-row-height: 36px;
    --density-card-padding: 12px;
    --density-kpi-height: 96px;
}

html[data-theme="dark"] body,
html[data-theme="dark"] .crm-app,
html[data-theme="dark"] .main-content {
    background: var(--color-surface-sunken) !important;
    color: var(--color-text-primary) !important;
}

html[data-theme="dark"] :is(.lead-report-card, .lead-kpi-card, .crm-modal-box, .bes-list, .ops-panel, .product-page-card, .invoice-table-card, .dashboard-section, .gv-empty) {
    border-color: var(--color-border-default) !important;
    background: var(--color-surface-raised) !important;
    color: var(--color-text-primary) !important;
}

html[data-theme="dark"] :is(.sidebar, .mobile-topbar, .lead-filter-stack, .lead-data-table th) {
    border-color: var(--color-border-default) !important;
    background: var(--color-surface-base) !important;
    color: var(--color-text-primary) !important;
}

html[data-density="compact"] #view-leads :is(.lead-kpi-card, .lead-report-card-head, .lead-mini-row, .lead-mini-head, .lead-data-table th, .lead-data-table td) {
    padding-block: 8px !important;
}

#view-leads .lead-contact-workbench,
#view-leads .lead-contact-guidance,
#view-leads .lead-contact-lead-list { overflow: hidden; }

#view-leads .lead-contact-bucket-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 12px;
    width: 100%;
}

#view-leads .lead-contact-bucket {
    display: grid;
    gap: 6px;
    min-width: 0;
    min-height: 132px;
    padding: 14px;
    border: 1px solid var(--color-border-default, #e2e8f0);
    border-radius: var(--radius-lg, 12px);
    background: var(--color-surface-base, #fff);
    color: var(--color-text-primary, #0f172a);
    text-align: left;
    cursor: pointer;
    transition: border-color var(--motion-fast, 120ms ease), box-shadow var(--motion-fast, 120ms ease), transform var(--motion-fast, 120ms ease);
}

#view-leads .lead-contact-bucket:hover,
#view-leads .lead-contact-bucket.active {
    border-color: var(--color-brand-600, #16a34a);
    box-shadow: var(--shadow-md, 0 4px 12px rgba(15, 23, 42, .06));
    transform: translateY(-1px);
}

#view-leads .lead-contact-bucket span {
    color: var(--color-text-secondary, #475569);
    font-size: 13px;
    font-weight: 700;
    white-space: normal;
}

#view-leads .lead-contact-bucket strong {
    font-size: clamp(24px, 3vw, 36px);
    line-height: 1;
    font-feature-settings: "tnum" 1, "lnum" 1;
}

#view-leads .lead-contact-bucket small,
#view-leads .lead-contact-bucket em {
    color: var(--color-text-secondary, #475569);
    font-size: 12px;
    font-style: normal;
}

#view-leads .lead-contact-bucket i {
    display: block;
    height: 6px;
    overflow: hidden;
    border-radius: 999px;
    background: var(--color-status-neutral-bg, #f1f5f9);
}

#view-leads .lead-contact-bucket i b {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: var(--color-status-info-fg, #1e40af);
}

#view-leads .lead-contact-bucket.is-positive i b { background: var(--color-status-success-fg, #065f46); }
#view-leads .lead-contact-bucket.is-warning i b { background: var(--color-status-warning-fg, #92400e); }
#view-leads .lead-contact-bucket.is-danger i b { background: var(--color-status-danger-fg, #991b1b); }
#view-leads .lead-contact-bucket.is-neutral i b { background: var(--color-text-tertiary, #94a3b8); }

#view-leads .lead-contact-selection-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-top: 16px;
    padding: 14px 16px;
    border: 1px dashed var(--color-border-strong, #cbd5e1);
    border-radius: var(--radius-lg, 12px);
    background: var(--color-surface-sunken, #f8fafc);
}

#view-leads .lead-contact-selection-summary div { display: grid; gap: 4px; }
#view-leads .lead-contact-selection-summary span { color: var(--color-text-secondary, #475569); }

#view-leads .lead-contact-lead-list {
    margin-top: 24px;
    padding: 20px;
    border: 1px solid var(--color-border-default, #e2e8f0);
    border-radius: 20px;
    background: var(--color-surface-base, #fff);
    box-shadow: var(--shadow-sm, 0 1px 2px rgba(15, 23, 42, .04));
}

#view-leads .lead-contact-list-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 16px;
}

#view-leads .lead-contact-list-head span {
    color: var(--color-text-tertiary, #94a3b8);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}

#view-leads .lead-contact-list-head h3 { margin: 4px 0; font-size: 22px; }
#view-leads .lead-contact-list-head p { margin: 0; color: var(--color-text-secondary, #475569); }

#view-leads .lead-contact-list-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: end;
    justify-content: flex-end;
    gap: 10px;
}

#view-leads .lead-contact-list-actions label {
    display: grid;
    gap: 5px;
    color: var(--color-text-secondary, #475569);
    font-size: 12px;
    font-weight: 700;
}

#view-leads .lead-contact-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 12px;
}

#view-leads .lead-contact-card {
    display: grid;
    gap: 12px;
    min-width: 0;
    padding: 14px;
    border: 1px solid var(--color-border-default, #e2e8f0);
    border-radius: var(--radius-lg, 12px);
    background: var(--color-surface-sunken, #f8fafc);
}

#view-leads .lead-contact-card-main {
    display: grid;
    gap: 5px;
    min-width: 0;
    padding: 0;
    border: 0;
    background: transparent;
    color: inherit;
    text-align: left;
    cursor: pointer;
}

#view-leads .lead-contact-card-main strong,
#view-leads .lead-contact-card-main small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#view-leads .lead-contact-card-main strong { font-size: 16px; }
#view-leads .lead-contact-card-main small { color: var(--color-text-secondary, #475569); }

#view-leads .lead-contact-card-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

#view-leads .lead-contact-card-meta span {
    display: grid;
    gap: 2px;
    min-width: 0;
    color: var(--color-text-primary, #0f172a);
    font-size: 13px;
}

#view-leads .lead-contact-card-meta b {
    color: var(--color-text-tertiary, #94a3b8);
    font-size: 11px;
    text-transform: uppercase;
}

#view-leads .lead-contact-card footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

@media (max-width: 760px) {
    #view-leads .lead-contact-selection-summary,
    #view-leads .lead-contact-list-head { display: grid; }
    #view-leads .lead-contact-list-actions { justify-content: start; }
    #view-leads .lead-contact-card-meta { grid-template-columns: 1fr; }
}

.portal-preference-panel {
    display: grid !important;
    gap: 10px !important;
    margin: 0 0 16px !important;
    padding: 12px !important;
    border: 1px solid var(--color-border-default, #e2e8f0) !important;
    border-radius: 12px !important;
    background: var(--color-surface-sunken, #f8fafc) !important;
}

.portal-preference-panel strong,
.portal-preference-panel span {
    display: block !important;
}

.portal-preference-panel strong {
    color: var(--color-text-primary, #0f172a) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
}

.portal-preference-panel span {
    color: var(--color-text-secondary, #475569) !important;
    font-size: 12px !important;
}

.portal-preference-row {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
}

.portal-preference-row button {
    min-height: 30px !important;
    padding: 4px 10px !important;
    border: 1px solid var(--color-border-strong, #cbd5e1) !important;
    border-radius: 9999px !important;
    background: var(--color-surface-base, #fff) !important;
    color: var(--color-text-secondary, #475569) !important;
    cursor: pointer !important;
    font-size: 12px !important;
    font-weight: 700 !important;
}

.portal-preference-row button.active {
    border-color: var(--color-brand-600, #16a34a) !important;
    background: var(--color-brand-50, #f0fdf4) !important;
    color: var(--color-brand-700, #15803d) !important;
}
/* Leads table hardening 2026-05-08: prevent one-letter column collapse. */
body[data-active-view="view-leads"] #view-leads .lead-data-table-wrap,
#view-leads .lead-data-table-wrap {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto !important;
    overflow-y: visible !important;
    scrollbar-gutter: stable !important;
}

body[data-active-view="view-leads"] #view-leads .lead-data-table,
#view-leads .lead-data-table {
    width: 100% !important;
    min-width: 1480px !important;
    max-width: none !important;
    table-layout: fixed !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
}

body[data-active-view="view-leads"] #view-leads .lead-data-table th,
body[data-active-view="view-leads"] #view-leads .lead-data-table td,
#view-leads .lead-data-table th,
#view-leads .lead-data-table td {
    min-width: 0 !important;
    max-width: none !important;
    white-space: nowrap !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    vertical-align: middle !important;
}

body[data-active-view="view-leads"] #view-leads .lead-data-table th:nth-child(1),
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(1),
#view-leads .lead-data-table th:nth-child(1),
#view-leads .lead-data-table td:nth-child(1) { width: 230px !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table th:nth-child(2),
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(2),
#view-leads .lead-data-table th:nth-child(2),
#view-leads .lead-data-table td:nth-child(2) { width: 150px !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table th:nth-child(3),
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(3),
#view-leads .lead-data-table th:nth-child(3),
#view-leads .lead-data-table td:nth-child(3) { width: 150px !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table th:nth-child(4),
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(4),
#view-leads .lead-data-table th:nth-child(4),
#view-leads .lead-data-table td:nth-child(4) { width: 105px !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table th:nth-child(5),
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(5),
#view-leads .lead-data-table th:nth-child(5),
#view-leads .lead-data-table td:nth-child(5) { width: 180px !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table th:nth-child(6),
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(6),
#view-leads .lead-data-table th:nth-child(6),
#view-leads .lead-data-table td:nth-child(6) { width: 120px !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table th:nth-child(7),
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(7),
#view-leads .lead-data-table th:nth-child(7),
#view-leads .lead-data-table td:nth-child(7) { width: 240px !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table th:nth-child(8),
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(8),
#view-leads .lead-data-table th:nth-child(8),
#view-leads .lead-data-table td:nth-child(8) { width: 165px !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table th:nth-child(9),
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(9),
#view-leads .lead-data-table th:nth-child(9),
#view-leads .lead-data-table td:nth-child(9) { width: 140px !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table :is(strong, small, a, span, b),
#view-leads .lead-data-table :is(strong, small, a, span, b) {
    max-width: 100% !important;
    min-width: 0 !important;
    white-space: nowrap !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

body[data-active-view="view-leads"] #view-leads .lead-source-campaign-cell,
body[data-active-view="view-leads"] #view-leads .lead-id-cell,
body[data-active-view="view-leads"] #view-leads .lead-date-cell,
body[data-active-view="view-leads"] #view-leads .lead-customer-cell,
body[data-active-view="view-leads"] #view-leads .lead-call-cell,
#view-leads .lead-source-campaign-cell,
#view-leads .lead-id-cell,
#view-leads .lead-date-cell,
#view-leads .lead-customer-cell,
#view-leads .lead-call-cell {
    min-width: 0 !important;
}

body[data-active-view="view-leads"] #view-leads .lead-source-campaign-cell small,
body[data-active-view="view-leads"] #view-leads .lead-id-cell strong,
body[data-active-view="view-leads"] #view-leads .lead-id-cell small,
body[data-active-view="view-leads"] #view-leads .lead-date-cell span,
body[data-active-view="view-leads"] #view-leads .lead-date-cell small,
body[data-active-view="view-leads"] #view-leads .lead-customer-cell strong,
body[data-active-view="view-leads"] #view-leads .lead-customer-cell a,
body[data-active-view="view-leads"] #view-leads .lead-customer-cell small,
body[data-active-view="view-leads"] #view-leads .lead-call-cell strong,
body[data-active-view="view-leads"] #view-leads .lead-call-cell small,
#view-leads .lead-source-campaign-cell small,
#view-leads .lead-id-cell strong,
#view-leads .lead-id-cell small,
#view-leads .lead-date-cell span,
#view-leads .lead-date-cell small,
#view-leads .lead-customer-cell strong,
#view-leads .lead-customer-cell a,
#view-leads .lead-customer-cell small,
#view-leads .lead-call-cell strong,
#view-leads .lead-call-cell small {
    display: block !important;
}

body[data-active-view="view-leads"] #view-leads .lead-source-chip,
body[data-active-view="view-leads"] #view-leads .lead-status-chip,
#view-leads .lead-source-chip,
#view-leads .lead-status-chip {
    display: inline-flex !important;
    max-width: 100% !important;
}

/* Leads register card view 2026-05-08: no sideways swipe, readable at a glance. */
body[data-active-view="view-leads"],
body[data-active-view="view-leads"] #app,
body[data-active-view="view-leads"] .crm-app,
body[data-active-view="view-leads"] .main-content,
body[data-active-view="view-leads"] .page,
body[data-active-view="view-leads"] #view-leads {
    max-width: 100vw !important;
    overflow-x: hidden !important;
}

body[data-active-view="view-leads"] #view-leads .lead-data-table-wrap,
#view-leads .lead-data-table-wrap {
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow-x: hidden !important;
    overflow-y: visible !important;
}

body[data-active-view="view-leads"] #view-leads .lead-data-table,
#view-leads .lead-data-table {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    border: 0 !important;
    background: transparent !important;
}

body[data-active-view="view-leads"] #view-leads .lead-data-table thead,
#view-leads .lead-data-table thead {
    display: none !important;
}

body[data-active-view="view-leads"] #view-leads .lead-data-table tbody,
#view-leads .lead-data-table tbody {
    display: grid !important;
    width: 100% !important;
    gap: 12px !important;
}

body[data-active-view="view-leads"] #view-leads .lead-data-table tr.lead-click-row,
#view-leads .lead-data-table tr.lead-click-row {
    display: grid !important;
    grid-template-columns: minmax(220px, 1.35fr) minmax(170px, .9fr) minmax(170px, .9fr) minmax(150px, .8fr) minmax(130px, .7fr) !important;
    grid-template-areas:
        "customer source product calls status"
        "customer ids date cost province" !important;
    gap: 10px 16px !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    padding: 14px 16px !important;
    border: 1px solid var(--color-border-default, #e2e8f0) !important;
    border-radius: 18px !important;
    background: var(--color-surface-base, #fff) !important;
    box-shadow: 0 8px 22px rgba(15, 23, 42, .05) !important;
    align-items: center !important;
}

body[data-active-view="view-leads"] #view-leads .lead-data-table tr.lead-click-row:hover,
#view-leads .lead-data-table tr.lead-click-row:hover {
    border-color: var(--color-brand-300, #86efac) !important;
    box-shadow: 0 12px 28px rgba(15, 23, 42, .08) !important;
}

body[data-active-view="view-leads"] #view-leads .lead-data-table td,
#view-leads .lead-data-table td {
    display: grid !important;
    min-width: 0 !important;
    max-width: 100% !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    color: var(--color-text-primary, #0f172a) !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    text-align: left !important;
    justify-items: start !important;
    align-content: center !important;
}

body[data-active-view="view-leads"] #view-leads .lead-data-table td::before,
#view-leads .lead-data-table td::before {
    display: block !important;
    margin-bottom: 3px !important;
    color: var(--color-text-tertiary, #94a3b8) !important;
    font-size: 10px !important;
    font-weight: 800 !important;
    letter-spacing: .04em !important;
    line-height: 1.2 !important;
    text-transform: uppercase !important;
}

body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(1),
#view-leads .lead-data-table td:nth-child(1) { grid-area: source !important; width: auto !important; }
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(1)::before,
#view-leads .lead-data-table td:nth-child(1)::before { content: "Bron" !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(2),
#view-leads .lead-data-table td:nth-child(2) { grid-area: ids !important; width: auto !important; }
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(2)::before,
#view-leads .lead-data-table td:nth-child(2)::before { content: "Lead ID" !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(3),
#view-leads .lead-data-table td:nth-child(3) { grid-area: date !important; width: auto !important; }
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(3)::before,
#view-leads .lead-data-table td:nth-child(3)::before { content: "Ontvangen" !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(4),
#view-leads .lead-data-table td:nth-child(4) { grid-area: cost !important; width: auto !important; }
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(4)::before,
#view-leads .lead-data-table td:nth-child(4)::before { content: "Kosten" !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(5),
#view-leads .lead-data-table td:nth-child(5) { grid-area: product !important; width: auto !important; }
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(5)::before,
#view-leads .lead-data-table td:nth-child(5)::before { content: "Product" !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(6),
#view-leads .lead-data-table td:nth-child(6) { grid-area: province !important; width: auto !important; }
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(6)::before,
#view-leads .lead-data-table td:nth-child(6)::before { content: "Provincie" !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(7),
#view-leads .lead-data-table td:nth-child(7) {
    grid-area: customer !important;
    width: auto !important;
    align-self: stretch !important;
    align-content: center !important;
    padding-right: 14px !important;
    border-right: 1px solid var(--color-border-default, #e2e8f0) !important;
}
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(7)::before,
#view-leads .lead-data-table td:nth-child(7)::before { content: "Klant" !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(8),
#view-leads .lead-data-table td:nth-child(8) { grid-area: calls !important; width: auto !important; }
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(8)::before,
#view-leads .lead-data-table td:nth-child(8)::before { content: "Belmomenten" !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(9),
#view-leads .lead-data-table td:nth-child(9) {
    grid-area: status !important;
    width: auto !important;
    justify-items: start !important;
}
body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(9)::before,
#view-leads .lead-data-table td:nth-child(9)::before { content: "Status" !important; }

body[data-active-view="view-leads"] #view-leads .lead-data-table :is(strong, small, a, span, b),
#view-leads .lead-data-table :is(strong, small, a, span, b) {
    min-width: 0 !important;
    max-width: 100% !important;
    white-space: nowrap !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

body[data-active-view="view-leads"] #view-leads .lead-customer-cell strong,
#view-leads .lead-customer-cell strong {
    color: var(--color-text-primary, #0f172a) !important;
    font-size: 17px !important;
    font-weight: 800 !important;
}

body[data-active-view="view-leads"] #view-leads .lead-customer-cell a,
body[data-active-view="view-leads"] #view-leads .lead-customer-cell small,
#view-leads .lead-customer-cell a,
#view-leads .lead-customer-cell small {
    color: var(--color-text-secondary, #475569) !important;
    font-size: 13px !important;
}

body[data-active-view="view-leads"] #view-leads .lead-source-chip,
body[data-active-view="view-leads"] #view-leads .lead-status-chip,
#view-leads .lead-source-chip,
#view-leads .lead-status-chip {
    width: fit-content !important;
    max-width: 100% !important;
}

body[data-active-view="view-leads"] #view-leads .lead-call-cell,
#view-leads .lead-call-cell {
    text-align: left !important;
}

@media (max-width: 1180px) {
    body[data-active-view="view-leads"] #view-leads .lead-data-table tr.lead-click-row,
    #view-leads .lead-data-table tr.lead-click-row {
        grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr) minmax(0, .85fr) !important;
        grid-template-areas:
            "customer source status"
            "customer product calls"
            "ids date province"
            "cost cost cost" !important;
    }

    body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(7),
    #view-leads .lead-data-table td:nth-child(7) {
        border-right: 0 !important;
        padding-right: 0 !important;
    }
}

@media (max-width: 760px) {
    body[data-active-view="view-leads"] #view-leads .lead-data-table tr.lead-click-row,
    #view-leads .lead-data-table tr.lead-click-row {
        grid-template-columns: 1fr !important;
        grid-template-areas:
            "customer"
            "status"
            "source"
            "product"
            "calls"
            "ids"
            "date"
            "cost"
            "province" !important;
        padding: 14px !important;
    }
}

/* Pipeline sellable UI pass 2026-05-08. Keep this block last. */
.crm-app :is(#view-leads, #view-lead-sale-matching, #view-bestellingen, #view-offertes, #view-energie-klanten, #view-energy-finance, #view-energy-anomalies),
.crm-app :is(#view-leads, #view-lead-sale-matching, #view-bestellingen, #view-offertes, #view-energie-klanten, #view-energy-finance, #view-energy-anomalies) * {
    box-sizing: border-box !important;
}

.crm-app :is(#view-leads, #view-lead-sale-matching, #view-bestellingen, #view-offertes, #view-energie-klanten, #view-energy-finance, #view-energy-anomalies) {
    max-width: 100% !important;
    overflow-x: hidden !important;
}

#view-leads {
    display: flex !important;
    flex-direction: column !important;
}

#view-leads > :is(.intro, .lead-filter-stack, .lead-sync-notice) {
    order: 10 !important;
}

#view-leads > :is(.lead-list, .gv-empty) {
    order: 20 !important;
}

#view-leads > .lead-report-shell {
    order: 30 !important;
}

.crm-modal.show,
.crm-app .crm-modal.show,
#app .crm-modal.show {
    position: fixed !important;
    inset: 0 !important;
    z-index: 2147483000 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 24px !important;
    overflow: hidden !important;
    background: transparent !important;
    isolation: isolate !important;
}

.crm-modal.show::before,
.crm-app .crm-modal.show::before,
#app .crm-modal.show::before {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    z-index: 0 !important;
    background: rgba(15, 23, 42, .58) !important;
    backdrop-filter: blur(3px) !important;
    pointer-events: none !important;
}

.crm-modal-overlay,
.crm-app .crm-modal-overlay,
#app .crm-modal-overlay {
    position: absolute !important;
    inset: 0 !important;
    z-index: 1 !important;
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    border: 0 !important;
    background: rgba(15, 23, 42, .58) !important;
    opacity: 1 !important;
    backdrop-filter: blur(3px) !important;
}

.crm-modal-box,
.crm-app .crm-modal-box,
#app .crm-modal-box {
    position: relative !important;
    z-index: 2 !important;
    width: min(100%, var(--crm-modal-width, 920px)) !important;
    max-height: min(88vh, 860px) !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    border: 1px solid rgba(148, 163, 184, .35) !important;
    border-radius: 24px !important;
    background: #fff !important;
    color: #0f172a !important;
    opacity: 1 !important;
    box-shadow: 0 28px 80px rgba(15, 23, 42, .30) !important;
}

.crm-modal-head,
.crm-modal-body,
.crm-app .crm-modal-head,
.crm-app .crm-modal-body,
#app .crm-modal-head,
#app .crm-modal-body {
    background: #fff !important;
    color: #0f172a !important;
    opacity: 1 !important;
}

.crm-modal-head {
    flex: 0 0 auto !important;
    border-bottom: 1px solid #e2e8f0 !important;
}

.crm-modal-body {
    flex: 1 1 auto !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
}

.crm-modal :is(.ev-actions, .crm-modal-actions, .lead-import-actions, .lead-webhook-actions, .lead-duplicate-actions, .lead-detail-actions) {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: flex-end !important;
    align-items: center !important;
    gap: 10px !important;
}

.crm-modal :is(.ev-actions .ev-btn, .crm-modal-actions button, .lead-import-actions button, .lead-webhook-actions button, .lead-duplicate-actions button, .lead-salesdock-import button, .leads-small-btn, .leads-primary-btn) {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    min-width: 0 !important;
    min-height: 40px !important;
    padding: 0 16px !important;
    border: 1px solid #d7dce5 !important;
    border-radius: 999px !important;
    background: #fff !important;
    color: #1f2937 !important;
    font: 700 13px/1 var(--font-sans, "Google Sans", Arial, sans-serif) !important;
    text-decoration: none !important;
    white-space: nowrap !important;
    cursor: pointer !important;
    box-shadow: none !important;
}

.crm-modal :is(.ev-actions .ev-btn-primary, .crm-modal-actions button[type="submit"], .lead-import-actions button[type="submit"], .leads-primary-btn) {
    border-color: #1a73e8 !important;
    background: #1a73e8 !important;
    color: #fff !important;
}

.crm-modal :is(.ev-actions .ev-btn:hover, .crm-modal-actions button:hover, .lead-import-actions button:hover, .lead-webhook-actions button:hover, .lead-duplicate-actions button:hover, .lead-salesdock-import button:hover, .leads-small-btn:hover) {
    border-color: #1a73e8 !important;
    color: #174ea6 !important;
    background: #e8f0fe !important;
}

.crm-modal :is(.ev-actions .ev-btn-primary:hover, .crm-modal-actions button[type="submit"]:hover, .lead-import-actions button[type="submit"]:hover, .leads-primary-btn:hover) {
    border-color: #1558c0 !important;
    background: #1558c0 !important;
    color: #fff !important;
}

#view-leads .leads-actions,
#view-leads .leads-secondary {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 8px !important;
    min-width: 0 !important;
}

#view-leads .leads-secondary {
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
}

#view-leads .leads-icon-btn,
body[data-active-view="view-lead-duplicates"] #view-leads .leads-icon-btn {
    width: auto !important;
    min-width: 112px !important;
    max-width: 100% !important;
    height: 40px !important;
    padding: 0 14px !important;
    gap: 8px !important;
    border: 1px solid #d7dce5 !important;
    border-radius: 999px !important;
    background: #fff !important;
    color: #1f2937 !important;
    font-weight: 700 !important;
    box-shadow: 0 1px 2px rgba(15, 23, 42, .04) !important;
}

#view-leads .leads-icon-btn .leads-action-label,
body[data-active-view="view-lead-duplicates"] #view-leads .leads-icon-btn .leads-action-label {
    display: inline !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font: 700 13px/1 var(--font-sans, "Google Sans", Arial, sans-serif) !important;
}

#view-leads .leads-icon-btn:hover {
    border-color: #1a73e8 !important;
    background: #e8f0fe !important;
    color: #174ea6 !important;
}

.crm-app :is(.lead-workspace-tabs, .md3-primary-nav, .customer-view-toggle, .bes-segment, .invoice-filter-group) {
    max-width: 100% !important;
    overflow-x: hidden !important;
}

.crm-app :is(.lead-workspace-tabs button, .md3-primary-nav button, .customer-view-toggle button, .bes-segment button, .filter-chip, .invoice-filter-chip) {
    min-height: 40px !important;
    border-radius: 999px !important;
    white-space: nowrap !important;
}

#view-energy-finance .energy-kpi-card,
#view-energie-klanten .energy-kpi-card {
    min-width: 0 !important;
    min-height: 118px !important;
    overflow: visible !important;
}

#view-energy-finance .energy-kpi-card :is(strong, small),
#view-energie-klanten .energy-kpi-card :is(strong, small),
#view-leads .lead-kpi-card :is(strong, small),
#view-leads .lead-summary-card :is(strong, small) {
    max-width: none !important;
    overflow: visible !important;
    text-overflow: clip !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    line-height: 1.15 !important;
}

#view-energy-finance .energy-kpi-card strong,
#view-energie-klanten .energy-kpi-card strong {
    font-size: clamp(20px, 1.45vw, 26px) !important;
}

.crm-app :is(.sidebar-user-avatar, .user-chip-avatar, .user-pick-av, .ops-user-avatar, .energy-avatar, .ticket-check-avatar, .td-assign-av) {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 auto !important;
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    min-height: 36px !important;
    max-width: 36px !important;
    max-height: 36px !important;
    overflow: hidden !important;
    text-transform: uppercase !important;
    letter-spacing: 0 !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
}

.crm-app :is(.lead-salesdock-quality-runtime [data-salesdock-quality-run], .lead-salesdock-import button, .lead-match-actions button) {
    min-width: 132px !important;
    white-space: nowrap !important;
}

/* Lead-Sale Matching customer dossier UX 2026-05-08. */
#view-lead-sale-matching,
#view-lead-sale-matching * {
    box-sizing: border-box !important;
}

#view-lead-sale-matching {
    max-width: 100% !important;
    overflow-x: hidden !important;
}

#view-lead-sale-matching .lead-sale-layout {
    grid-template-columns: minmax(0, 1.35fr) minmax(360px, .65fr) !important;
}

#view-lead-sale-matching .lead-sale-row {
    grid-template-columns: minmax(210px, 1.1fr) minmax(220px, 1.1fr) minmax(220px, 1fr) minmax(180px, .72fr) !important;
}

#view-lead-sale-matching .lead-sale-row-cluster {
    min-height: 86px !important;
}

#view-lead-sale-matching .lead-sale-row strong,
#view-lead-sale-matching .lead-sale-row small {
    white-space: normal !important;
}

#view-lead-sale-matching .lead-sale-mini-actions {
    flex-wrap: wrap !important;
    justify-content: flex-start !important;
}

#view-lead-sale-matching .lead-sale-mini-actions button:first-child {
    border-color: #1a73e8 !important;
    background: #1a73e8 !important;
    color: #fff !important;
}

#view-lead-sale-matching .lead-sale-related-sales {
    border-color: #bbf7d0 !important;
    background: #f0fdf4 !important;
}

#view-lead-sale-matching .lead-sale-related-sales strong,
#view-lead-sale-matching .lead-sale-related-sales p {
    color: #166534 !important;
}

@media (max-width: 1240px) {
    #view-lead-sale-matching .lead-sale-layout {
        grid-template-columns: 1fr !important;
    }

    #view-lead-sale-matching .lead-sale-detail {
        position: static !important;
    }
}

/* Lead-Sale Matching decision layout polish 2026-05-08. */
#view-lead-sale-matching .lead-sale-layout {
    grid-template-columns: minmax(0, 1fr) minmax(340px, 420px) !important;
    gap: 16px !important;
}

#view-lead-sale-matching .lead-sale-list,
#view-lead-sale-matching .lead-sale-detail,
#view-lead-sale-matching .lead-sale-table {
    max-width: 100% !important;
    overflow-x: hidden !important;
}

#view-lead-sale-matching .lead-sale-row {
    grid-template-columns: minmax(150px, .9fr) minmax(170px, 1fr) minmax(150px, .85fr) 118px !important;
    gap: 10px !important;
    padding: 12px 16px !important;
}

#view-lead-sale-matching .lead-sale-row > span {
    min-width: 0 !important;
    overflow: hidden !important;
}

#view-lead-sale-matching .lead-sale-row-head span:last-child {
    text-align: center !important;
}

#view-lead-sale-matching .lead-sale-mini-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 6px !important;
    width: 100% !important;
    min-width: 0 !important;
}

#view-lead-sale-matching .lead-sale-mini-actions button {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 32px !important;
    border-radius: 18px !important;
    padding: 0 10px !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
}

#view-lead-sale-matching .lead-sale-mini-actions button + button {
    border-color: var(--md-outline, #dadce0) !important;
    background: #fff !important;
    color: var(--md-on-surface-variant, #5f6368) !important;
}

#view-lead-sale-matching .lead-sale-detail {
    position: sticky !important;
    top: 16px !important;
    max-height: calc(100vh - 112px) !important;
    overflow-y: auto !important;
}

#view-lead-sale-matching .lead-sale-detail-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
}

#view-lead-sale-matching .lead-sale-detail-actions button {
    min-width: 0 !important;
}

@media (max-width: 1240px) {
    #view-lead-sale-matching .lead-sale-layout {
        grid-template-columns: 1fr !important;
    }

    #view-lead-sale-matching .lead-sale-detail {
        position: static !important;
        max-height: none !important;
    }
}

@media (max-width: 900px) {
    #view-lead-sale-matching .lead-sale-row,
    #view-lead-sale-matching .lead-sale-row-head {
        grid-template-columns: 1fr !important;
    }

    #view-lead-sale-matching .lead-sale-mini-actions {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 760px) {
    .crm-modal.show,
    .crm-app .crm-modal.show,
    #app .crm-modal.show {
        align-items: flex-end !important;
        padding: 12px !important;
    }

    .crm-modal-box,
    .crm-app .crm-modal-box,
    #app .crm-modal-box {
        width: 100% !important;
        max-height: 92vh !important;
        border-radius: 22px 22px 16px 16px !important;
    }

    #view-leads .leads-icon-btn,
    body[data-active-view="view-lead-duplicates"] #view-leads .leads-icon-btn {
        flex: 1 1 150px !important;
        min-width: 0 !important;
    }
}

/* Leads UX cleanup 2026-05-08: one filter layer, compact cards, no page-wide sideways swipe. */
body[data-active-view="view-leads"] #view-leads.lead-ux-compact,
body[data-active-view="view-leads"] #view-leads {
    --lead-card-gap: 12px;
    max-width: 100% !important;
    overflow-x: hidden !important;
}

body[data-active-view="view-leads"] #view-leads .lead-workspace-tabs {
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    align-items: stretch !important;
    gap: 8px !important;
    max-width: 100% !important;
    overflow: hidden !important;
}

body[data-active-view="view-leads"] #view-leads .lead-workspace-tabs button {
    width: 100% !important;
    min-width: 0 !important;
    justify-content: center !important;
    white-space: nowrap !important;
}

body[data-active-view="view-leads"] #view-leads .lead-filter-stack {
    position: static !important;
    z-index: auto !important;
    margin-top: 10px !important;
}

body[data-active-view="view-leads"] #view-leads .lead-filterbar {
    display: grid !important;
    grid-template-columns: minmax(230px, 1.35fr) repeat(3, minmax(150px, .85fr)) minmax(132px, auto) !important;
    align-items: end !important;
    gap: 10px !important;
    width: 100% !important;
}

body[data-active-view="view-leads"] #view-leads .lead-filter-stack:not(.is-advanced-open) .lead-advanced-filter {
    display: none !important;
}

body[data-active-view="view-leads"] #view-leads .lead-filter-stack.is-advanced-open .lead-filterbar {
    grid-template-columns: repeat(auto-fit, minmax(176px, 1fr)) !important;
}

body[data-active-view="view-leads"] #view-leads .lead-search-field,
body[data-active-view="view-leads"] #view-leads .lead-filter-control,
body[data-active-view="view-leads"] #view-leads .lead-daterange,
body[data-active-view="view-leads"] #view-leads .lead-filterbar :is(input, select, .bes-search) {
    min-width: 0 !important;
    max-width: 100% !important;
}

body[data-active-view="view-leads"] #view-leads .lead-more-filters-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 7px !important;
    min-height: 44px !important;
    padding: 10px 14px !important;
    border: 1px solid var(--color-border-strong, #cbd5e1) !important;
    border-radius: 12px !important;
    background: var(--color-surface-base, #fff) !important;
    color: var(--color-text-secondary, #475569) !important;
    cursor: pointer !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    white-space: nowrap !important;
}

body[data-active-view="view-leads"] #view-leads .lead-more-filters-btn.lead-advanced-filter {
    display: inline-flex !important;
}

body[data-active-view="view-leads"] #view-leads .lead-more-filters-btn:hover {
    border-color: var(--color-brand-300, #86efac) !important;
    background: var(--color-brand-50, #f0fdf4) !important;
    color: var(--color-brand-800, #166534) !important;
}

body[data-active-view="view-leads"] #view-leads .lead-duplicate-filter-hidden,
body[data-active-view="view-leads"] #view-leads .lead-list-summary :is(.lead-list-search, .lead-table-tools > .lead-list-filter:not(.is-page-size)) {
    display: none !important;
}

body[data-active-view="view-leads"] #view-leads .lead-list-summary {
    position: static !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    margin-top: 10px !important;
    padding: 12px 14px !important;
}

body[data-active-view="view-leads"] #view-leads > .lead-report-shell {
    display: none !important;
}

body[data-active-view="view-leads"] #view-leads .lead-table-tools.is-compact,
body[data-active-view="view-leads"] #view-leads .lead-table-tools {
    display: flex !important;
    flex: 0 0 auto !important;
    flex-wrap: wrap !important;
    align-items: end !important;
    justify-content: flex-end !important;
    gap: 8px !important;
    width: auto !important;
}

body[data-active-view="view-leads"] #view-leads .lead-list-filter.is-page-size {
    display: grid !important;
    gap: 4px !important;
    min-width: 104px !important;
}

body[data-active-view="view-leads"] #view-leads .lead-data-table tbody {
    gap: var(--lead-card-gap) !important;
}

body[data-active-view="view-leads"] #view-leads .lead-data-table tr.lead-click-row {
    grid-template-columns: minmax(235px, 1.25fr) minmax(200px, 1fr) minmax(150px, .72fr) minmax(170px, .78fr) !important;
    grid-template-areas:
        "customer source product status"
        "customer ids date calls"
        "customer cost province calls" !important;
    padding: 14px 16px !important;
    border-radius: 16px !important;
}

body[data-active-view="view-leads"] #view-leads .lead-status-cell {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 7px !important;
}

body[data-active-view="view-leads"] #view-leads .lead-row-open {
    display: inline-flex !important;
    align-items: center !important;
    gap: 3px !important;
    max-width: 100% !important;
    color: var(--color-brand-700, #15803d) !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
}

body[data-active-view="view-leads"] #view-leads .lead-row-open .material-symbols-rounded {
    font-size: 17px !important;
    line-height: 1 !important;
}

body[data-active-view="view-leads"] #view-leads .lead-muted-missing {
    color: var(--color-text-tertiary, #94a3b8) !important;
    font-weight: 500 !important;
    opacity: .78 !important;
}

body[data-active-view="view-leads"] #view-leads .lead-search-field .bes-search {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    width: 100% !important;
    height: 48px !important;
    min-width: 0 !important;
    padding: 0 14px !important;
    border: 1px solid var(--color-border-strong, #d8dee9) !important;
    border-radius: 16px !important;
    background: var(--color-surface-base, #fff) !important;
    box-shadow: none !important;
    overflow: hidden !important;
    transition: border-color .16s ease, box-shadow .16s ease, background .16s ease !important;
}

body[data-active-view="view-leads"] #view-leads .lead-search-field .bes-search:focus-within {
    border-color: var(--color-brand-500, #4f6eea) !important;
    box-shadow: 0 0 0 3px rgba(79, 110, 234, .16) !important;
}

body[data-active-view="view-leads"] #view-leads .lead-search-field .bes-search svg {
    flex: 0 0 auto !important;
    width: 18px !important;
    height: 18px !important;
    color: var(--color-text-tertiary, #94a3b8) !important;
}

body[data-active-view="view-leads"] #view-leads .lead-search-field .bes-search input,
body[data-active-view="view-leads"] #view-leads .lead-search-field .bes-search input:focus,
body[data-active-view="view-leads"] #view-leads .lead-search-field .bes-search input:focus-visible {
    flex: 1 1 auto !important;
    width: 100% !important;
    height: 100% !important;
    min-width: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    outline: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    color: var(--color-text-primary, #111827) !important;
    font-size: 15px !important;
    font-weight: 600 !important;
}

body[data-active-view="view-leads"] #view-leads .lead-search-field .bes-search input::placeholder {
    color: var(--color-text-tertiary, #94a3b8) !important;
    font-weight: 500 !important;
}

body[data-active-view="view-leads"] #view-leads .lead-status-chip::before {
    content: "radio_button_unchecked";
    display: inline-block;
    margin-right: 5px;
    font-family: "Material Symbols Rounded";
    font-size: 13px;
    font-weight: 400;
    line-height: 1;
    vertical-align: -2px;
}

body[data-active-view="view-leads"] #view-leads .bes-more-results {
    width: 100% !important;
    margin-top: 12px !important;
    justify-content: center !important;
}

@media (max-width: 1180px) {
    body[data-active-view="view-leads"] #view-leads .lead-workspace-tabs {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }

    body[data-active-view="view-leads"] #view-leads .lead-filterbar,
    body[data-active-view="view-leads"] #view-leads .lead-filter-stack.is-advanced-open .lead-filterbar {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 760px) {
    body[data-active-view="view-leads"] #view-leads .lead-workspace-tabs,
    body[data-active-view="view-leads"] #view-leads .lead-filterbar,
    body[data-active-view="view-leads"] #view-leads .lead-filter-stack.is-advanced-open .lead-filterbar,
    body[data-active-view="view-leads"] #view-leads .lead-list-summary {
        grid-template-columns: 1fr !important;
        display: grid !important;
    }

    body[data-active-view="view-leads"] #view-leads .lead-data-table tr.lead-click-row {
        grid-template-columns: 1fr !important;
        grid-template-areas:
            "customer"
            "source"
            "ids"
            "date"
            "cost"
            "product"
            "province"
            "calls"
            "status" !important;
    }

    body[data-active-view="view-leads"] #view-leads .lead-table-tools {
        width: 100% !important;
        justify-content: stretch !important;
    }
}

/* Absolute EOF lead search polish 2026-05-08 */
html body[data-active-view="view-leads"] #view-leads .lead-search-field .bes-search {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    height: 48px !important;
    padding: 0 14px !important;
    border: 1px solid var(--color-border-strong, #d8dee9) !important;
    border-radius: 16px !important;
    background: var(--color-surface-base, #fff) !important;
    box-shadow: none !important;
    overflow: hidden !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-search-field .bes-search:focus-within {
    border-color: var(--color-brand-500, #4f6eea) !important;
    box-shadow: 0 0 0 3px rgba(79, 110, 234, .16) !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-search-field .bes-search input,
html body[data-active-view="view-leads"] #view-leads .lead-search-field .bes-search input:focus,
html body[data-active-view="view-leads"] #view-leads .lead-search-field .bes-search input:focus-visible {
    height: 100% !important;
    padding: 0 !important;
    border: 0 !important;
    outline: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}
/* Pitch hardening: customer quick-action icons must not depend on Material Symbols ligatures. */
#view-bestellingen .bes-icon-action .material-symbols-rounded {
    width: 18px !important;
    height: 18px !important;
    overflow: hidden !important;
    color: transparent !important;
    font-size: 0 !important;
    line-height: 0 !important;
}

#view-bestellingen .bes-icon-action svg {
    width: 18px !important;
    height: 18px !important;
    flex: 0 0 18px !important;
    color: currentColor !important;
}

#view-bestellingen .bes-icon-action .material-symbols-rounded::before {
    content: "" !important;
    display: block !important;
    width: 18px !important;
    height: 18px !important;
    background-color: #3C4043 !important;
    -webkit-mask-position: center !important;
    -webkit-mask-repeat: no-repeat !important;
    -webkit-mask-size: 18px 18px !important;
    mask-position: center !important;
    mask-repeat: no-repeat !important;
    mask-size: 18px 18px !important;
}

#view-bestellingen .bes-icon-action[href^="tel:"] .material-symbols-rounded::before {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2 19.8 19.8 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6A19.8 19.8 0 0 1 2.12 4.18 2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72c.13.96.35 1.89.66 2.78a2 2 0 0 1-.45 2.11L8.09 9.84a16 16 0 0 0 6.07 6.07l1.23-1.23a2 2 0 0 1 2.11-.45c.89.31 1.82.53 2.78.66A2 2 0 0 1 22 16.92z'/%3E%3C/svg%3E") !important;
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2 19.8 19.8 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6A19.8 19.8 0 0 1 2.12 4.18 2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72c.13.96.35 1.89.66 2.78a2 2 0 0 1-.45 2.11L8.09 9.84a16 16 0 0 0 6.07 6.07l1.23-1.23a2 2 0 0 1 2.11-.45c.89.31 1.82.53 2.78.66A2 2 0 0 1 22 16.92z'/%3E%3C/svg%3E") !important;
}

#view-bestellingen .bes-icon-action[href^="mailto:"] .material-symbols-rounded::before {
    -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='20' height='16' x='2' y='4' rx='2'/%3E%3Cpath d='m22 7-8.97 5.7a2 2 0 0 1-2.06 0L2 7'/%3E%3C/svg%3E") !important;
    mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='20' height='16' x='2' y='4' rx='2'/%3E%3Cpath d='m22 7-8.97 5.7a2 2 0 0 1-2.06 0L2 7'/%3E%3C/svg%3E") !important;
}

#view-bestellingen .bes-icon-action:hover .material-symbols-rounded::before,
#view-bestellingen .bes-icon-action:focus-visible .material-symbols-rounded::before {
    background-color: #174EA6 !important;
}

/* Keep extra customer filters as a light popover so KPI tiles do not jump. */
#view-bestellingen .bes-advanced-filters {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    width: min(440px, 100%) !important;
    margin: 8px 0 -70px auto !important;
    position: relative !important;
    z-index: 24 !important;
    border-radius: 12px !important;
    background: #fff !important;
    box-shadow: 0 12px 30px rgba(60, 64, 67, 0.18) !important;
}

@media (max-width: 720px) {
    #view-bestellingen .bes-advanced-filters {
        grid-template-columns: 1fr !important;
        width: 100% !important;
        margin-bottom: 8px !important;
    }
}

/* App-wide page rhythm 2026-05-11: keep page headers from jumping between sidebar pages. */
.crm-app {
    --crm-page-top-pad: 36px;
    --crm-backbar-zone: 56px;
    --crm-header-gap: 24px;
    --crm-title-zone: 126px;
    --crm-page-title-size: 34px;
    --crm-page-copy-size: 17px;
    --crm-page-label-size: 12px;
    --crm-lead-tabs-zone: 56px;
    --crm-lead-action-zone: 56px;
}

.crm-app .main-content > .page {
    padding-top: var(--crm-page-top-pad) !important;
}

.crm-app :is(
    .view.active:not(#view-home),
    .view.active:not(#view-home) > .crm-page,
    .view.active:not(#view-home) > .view-shell,
    .view.active:not(#view-home) > .ops-page
) > .back-bar {
    display: flex !important;
    align-items: flex-start !important;
    min-height: var(--crm-backbar-zone) !important;
    margin: 0 0 var(--crm-header-gap) !important;
}

.crm-app :is(
    .view.active:not(#view-home),
    .view.active:not(#view-home) > .crm-page,
    .view.active:not(#view-home) > .view-shell,
    .view.active:not(#view-home) > .ops-page
):not(:has(> .back-bar)) > :is(.intro, .crm-page-header, .page-head, .td-header, .rp-header) {
    margin-top: calc(var(--crm-backbar-zone) + var(--crm-header-gap)) !important;
}

.crm-app :is(
    .view.active:not(#view-home),
    .view.active:not(#view-home) > .crm-page,
    .view.active:not(#view-home) > .view-shell,
    .view.active:not(#view-home) > .ops-page
) > :is(.intro, .crm-page-header, .page-head, .td-header, .rp-header) {
    display: grid !important;
    align-content: start !important;
    min-height: var(--crm-title-zone) !important;
    margin-bottom: var(--crm-header-gap) !important;
}

.crm-app :is(.intro, .crm-page-header, .page-head, .td-header, .rp-header) :is(.intro-label, .eyebrow, .page-kicker) {
    display: inline-block !important;
    margin: 0 0 10px !important;
    color: var(--crm-subtle, var(--ink-muted)) !important;
    font-size: var(--crm-page-label-size) !important;
    font-weight: 700 !important;
    letter-spacing: .08em !important;
    line-height: 1.2 !important;
    text-transform: uppercase !important;
}

.crm-app :is(.intro, .crm-page-header, .page-head, .td-header, .rp-header) h1 {
    min-height: 40px !important;
    margin: 0 0 12px !important;
    color: var(--crm-text, var(--ink)) !important;
    font-family: var(--crm-font, Archivo, sans-serif) !important;
    font-size: var(--crm-page-title-size) !important;
    font-weight: 500 !important;
    letter-spacing: 0 !important;
    line-height: 1.12 !important;
}

.crm-app :is(.intro, .crm-page-header, .page-head, .td-header, .rp-header) p {
    max-width: 860px !important;
    margin: 0 !important;
    color: var(--crm-muted, var(--ink-muted)) !important;
    font-size: var(--crm-page-copy-size) !important;
    font-weight: 400 !important;
    letter-spacing: 0 !important;
    line-height: 1.45 !important;
}

.crm-app :is(#view-leads, #view-bestellingen, #view-energie-klanten, #view-energy-finance, #view-energy-anomalies, #view-offertes, #view-lead-sale-matching) > :is(.intro, .crm-page-header, .page-head) :is(.intro-label, .eyebrow, .page-kicker) {
    color: var(--crm-subtle, var(--ink-muted)) !important;
    font-family: var(--crm-font, Archivo, sans-serif) !important;
    font-size: var(--crm-page-label-size) !important;
    font-weight: 700 !important;
    letter-spacing: .08em !important;
    line-height: 1.2 !important;
    text-transform: uppercase !important;
}

.crm-app :is(#view-leads, #view-bestellingen, #view-energie-klanten, #view-energy-finance, #view-energy-anomalies, #view-offertes, #view-lead-sale-matching) > :is(.intro, .crm-page-header, .page-head) h1 {
    color: var(--crm-text, var(--ink)) !important;
    font-family: var(--crm-font, Archivo, sans-serif) !important;
    font-size: var(--crm-page-title-size) !important;
    font-weight: 500 !important;
    letter-spacing: 0 !important;
    line-height: 1.12 !important;
    margin: 0 0 12px !important;
}

.crm-app :is(#view-leads, #view-bestellingen, #view-energie-klanten, #view-energy-finance, #view-energy-anomalies, #view-offertes, #view-lead-sale-matching) > :is(.intro, .crm-page-header, .page-head) p {
    color: var(--crm-muted, var(--ink-muted)) !important;
    font-family: var(--crm-font, Archivo, sans-serif) !important;
    font-size: var(--crm-page-copy-size) !important;
    line-height: 1.45 !important;
    margin: 0 !important;
}

.crm-app #view-lead-sale-matching:not(:has(> .back-bar)) > .page-head {
    margin-top: calc(var(--crm-backbar-zone) + var(--crm-header-gap)) !important;
}

body[data-active-view="view-leads"] #view-leads,
#view-leads {
    --lead-top-zone: var(--crm-backbar-zone);
    --lead-tabs-zone: var(--crm-lead-tabs-zone);
    --lead-action-zone: var(--crm-lead-action-zone);
    --lead-intro-zone: var(--crm-title-zone);
    display: flex !important;
    flex-direction: column !important;
}

body[data-active-view="view-leads"] #view-leads > .back-bar,
#view-leads > .back-bar {
    order: 0 !important;
    min-height: var(--lead-top-zone) !important;
    margin: 0 0 var(--crm-header-gap) !important;
}

body[data-active-view="view-leads"] #view-leads > .lead-workspace-tabs,
#view-leads > .lead-workspace-tabs {
    order: 2 !important;
    min-height: var(--lead-tabs-zone) !important;
    margin: 0 0 var(--crm-header-gap) !important;
}

body[data-active-view="view-leads"] #view-leads > .leads-actionbar,
#view-leads > .leads-actionbar {
    order: 3 !important;
    min-height: var(--lead-action-zone) !important;
    margin: 0 0 var(--crm-header-gap) !important;
}

body[data-active-view="view-leads"] #view-leads > .intro,
#view-leads > .intro {
    order: 1 !important;
    min-height: var(--lead-intro-zone) !important;
    margin: 0 0 var(--crm-header-gap) !important;
}

body[data-active-view="view-leads"] #view-leads > .lead-filter-stack,
#view-leads > .lead-filter-stack {
    order: 4 !important;
    margin-top: 0 !important;
}

body[data-active-view="view-leads"] #view-leads > :is(.lead-sync-notice, .lead-report-shell, .lead-contact-lead-list, .lead-table-shell, .lead-list),
#view-leads > :is(.lead-sync-notice, .lead-report-shell, .lead-contact-lead-list, .lead-table-shell, .lead-list) {
    order: 5 !important;
}

@media (max-width: 760px) {
    .crm-app {
        --crm-page-top-pad: 24px;
        --crm-backbar-zone: 52px;
        --crm-header-gap: 18px;
        --crm-title-zone: 112px;
        --crm-page-title-size: 28px;
        --crm-page-copy-size: 15px;
        --crm-page-label-size: 11px;
        --crm-lead-tabs-zone: 54px;
        --crm-lead-action-zone: 54px;
    }
}

/* Active preview/app DOM variant: same rhythm without requiring a .crm-app wrapper. */
:root {
    --crm-page-top-pad: 36px;
    --crm-backbar-zone: 56px;
    --crm-header-gap: 24px;
    --crm-title-zone: 126px;
    --crm-page-title-size: 34px;
    --crm-page-copy-size: 17px;
    --crm-page-label-size: 12px;
    --crm-lead-tabs-zone: 56px;
    --crm-lead-action-zone: 56px;
}

.main-content > .page {
    padding-top: var(--crm-page-top-pad) !important;
}

.view.active:not(#view-home) > .back-bar {
    display: flex !important;
    align-items: flex-start !important;
    min-height: var(--crm-backbar-zone) !important;
    margin: 0 0 var(--crm-header-gap) !important;
}

.view.active:not(#view-home):not(:has(> .back-bar)) > :is(.intro, .crm-page-header, .page-head, .td-header, .rp-header) {
    margin-top: calc(var(--crm-backbar-zone) + var(--crm-header-gap)) !important;
}

.view.active:not(#view-home) > :is(.intro, .crm-page-header, .page-head, .td-header, .rp-header) {
    display: grid !important;
    align-content: start !important;
    min-height: var(--crm-title-zone) !important;
    margin-bottom: var(--crm-header-gap) !important;
}

.view.active:not(#view-home) > :is(.intro, .crm-page-header, .page-head, .td-header, .rp-header) :is(.intro-label, .eyebrow, .page-kicker),
:is(#view-leads, #view-bestellingen, #view-energie-klanten, #view-energy-finance, #view-energy-anomalies, #view-offertes, #view-lead-sale-matching) > :is(.intro, .crm-page-header, .page-head) :is(.intro-label, .eyebrow, .page-kicker) {
    display: inline-block !important;
    margin: 0 0 10px !important;
    color: var(--crm-subtle, var(--ink-muted)) !important;
    font-family: var(--crm-font, var(--font-sans, Archivo, sans-serif)) !important;
    font-size: var(--crm-page-label-size) !important;
    font-weight: 700 !important;
    letter-spacing: .08em !important;
    line-height: 1.2 !important;
    text-transform: uppercase !important;
}

.view.active:not(#view-home) > :is(.intro, .crm-page-header, .page-head, .td-header, .rp-header) h1,
:is(#view-leads, #view-bestellingen, #view-energie-klanten, #view-energy-finance, #view-energy-anomalies, #view-offertes, #view-lead-sale-matching) > :is(.intro, .crm-page-header, .page-head) h1 {
    min-height: 40px !important;
    margin: 0 0 12px !important;
    color: var(--crm-text, var(--ink, #202124)) !important;
    font-family: var(--crm-font, var(--font-sans, Archivo, sans-serif)) !important;
    font-size: var(--crm-page-title-size) !important;
    font-weight: 500 !important;
    letter-spacing: 0 !important;
    line-height: 1.12 !important;
}

.view.active:not(#view-home) > :is(.intro, .crm-page-header, .page-head, .td-header, .rp-header) p,
:is(#view-leads, #view-bestellingen, #view-energie-klanten, #view-energy-finance, #view-energy-anomalies, #view-offertes, #view-lead-sale-matching) > :is(.intro, .crm-page-header, .page-head) p {
    max-width: 860px !important;
    margin: 0 !important;
    color: var(--crm-muted, var(--ink-muted)) !important;
    font-family: var(--crm-font, var(--font-sans, Archivo, sans-serif)) !important;
    font-size: var(--crm-page-copy-size) !important;
    font-weight: 400 !important;
    letter-spacing: 0 !important;
    line-height: 1.45 !important;
}

#view-leads {
    --lead-top-zone: var(--crm-backbar-zone);
    --lead-tabs-zone: var(--crm-lead-tabs-zone);
    --lead-action-zone: var(--crm-lead-action-zone);
    --lead-intro-zone: var(--crm-title-zone);
    display: flex !important;
    flex-direction: column !important;
}

#view-leads > .back-bar {
    order: 0 !important;
    min-height: var(--lead-top-zone) !important;
    margin: 0 0 var(--crm-header-gap) !important;
}

#view-leads > .intro {
    order: 1 !important;
    min-height: var(--lead-intro-zone) !important;
    margin: 0 0 var(--crm-header-gap) !important;
}

#view-leads > .lead-workspace-tabs {
    order: 2 !important;
    min-height: var(--lead-tabs-zone) !important;
    margin: 0 0 var(--crm-header-gap) !important;
}

#view-leads > .leads-actionbar {
    order: 3 !important;
    min-height: var(--lead-action-zone) !important;
    margin: 0 0 var(--crm-header-gap) !important;
}

#view-leads > .lead-filter-stack {
    order: 4 !important;
    margin-top: 0 !important;
}

#view-leads > :is(.lead-sync-notice, .lead-report-shell, .lead-contact-lead-list, .lead-table-shell, .lead-list) {
    order: 5 !important;
}

#view-lead-sale-matching:not(:has(> .back-bar)) > .page-head {
    margin-top: calc(var(--crm-backbar-zone) + var(--crm-header-gap)) !important;
}

@media (max-width: 760px) {
    :root {
        --crm-page-top-pad: 24px;
        --crm-backbar-zone: 52px;
        --crm-header-gap: 18px;
        --crm-title-zone: 140px;
        --crm-page-title-size: 28px;
        --crm-page-copy-size: 15px;
        --crm-page-label-size: 11px;
        --crm-lead-tabs-zone: 54px;
        --crm-lead-action-zone: 54px;
    }
}

/* Header rhythm verification 2026-05-12: keep duplicate leads and matching aligned with the main CRM pages. */
body[data-active-view="view-lead-duplicates"] #view-leads {
    gap: 0 !important;
}

#view-lead-sale-matching.lead-sale-matching-view {
    gap: 0 !important;
}

#view-lead-sale-matching > .page-head {
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: start !important;
    column-gap: 16px !important;
    row-gap: 0 !important;
}

#view-lead-sale-matching > .page-head > div:first-child {
    display: grid !important;
    align-content: start !important;
}

.view.active:not(#view-home) > .crm-page-header > .crm-page-header-main,
:is(#view-bestellingen, #view-energie-klanten, #view-energy-finance, #view-energy-anomalies, #view-offertes) > .crm-page-header > .crm-page-header-main {
    display: grid !important;
    align-content: start !important;
    gap: 0 !important;
}

#view-lead-sale-matching > .page-head .lead-sale-actions {
    align-self: start !important;
    justify-content: flex-end !important;
}

@media (max-width: 900px) {
    #view-lead-sale-matching > .page-head {
        grid-template-columns: minmax(0, 1fr) !important;
        position: relative !important;
        min-height: var(--crm-title-zone) !important;
        row-gap: 0 !important;
        margin-bottom: calc(var(--crm-header-gap) + 58px) !important;
        overflow: visible !important;
    }

    #view-lead-sale-matching > .page-head .lead-sale-actions {
        position: absolute !important;
        top: calc(var(--crm-title-zone) + 12px) !important;
        right: 0 !important;
        left: 0 !important;
        justify-content: flex-start !important;
    }
}

/* === Integrated legacy schouw styles from styles-schouw.css 2026-05-12 === */
/* === EMBEDDED SCHOUW BUNDLE (v5.4) CSS - auto-scoped to .schouw-app === */
.schouw-app{--g:#389F80;--gd:#256B56;--gl:#E8F5F0;--y:#E8C03A;--z:#1A1A1A;--gr:#6B7280;--bg:#F7FAF9;--r:#D0E8DF;--rs:#A8D4C4;--ob:#E8F7F0;--or2:#7DC4A8;--ot:#1A5C40;--wb:#FDF8E6;--wr:#E8C03A;--wt:#6B4A00;--eb:#FEF2F2;--er:#F5A8A4;--et:#7C1A16;--w:#FFFFFF;}

.schouw-app{background:var(--bg);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,sans-serif;color:var(--z);min-height:100vh}
.schouw-app .tb{background:var(--w);border-bottom:1px solid var(--r);padding:0 20px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 1px 8px rgba(0,0,0,.06)}
.schouw-app .tbtag{font-size:11px;font-weight:700;color:var(--g);letter-spacing:.07em;text-transform:uppercase;background:var(--gl);padding:4px 11px;border-radius:99px}
.schouw-app .tabs{background:var(--w);border-bottom:2px solid var(--r);display:flex;padding:0 20px;gap:4px}
.schouw-app .tbtn{padding:12px 18px;font-size:13px;font-weight:600;color:var(--gr);background:none;border:none;cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .15s;font-family:inherit}
.schouw-app .tbtn.on{color:var(--g);border-bottom-color:var(--g);font-weight:700}
.schouw-app .tpanel{display:none}.schouw-app .tpanel.on{display:block}
.schouw-app .hero{background:linear-gradient(135deg,#1A4A38,#256B56,#389F80);padding:24px 20px 48px}
.schouw-app .hero-in{max-width:660px;margin:0 auto}
.schouw-app .hbadge{display:inline-flex;align-items:center;gap:6px;background:rgba(232,192,58,.2);border:1px solid rgba(232,192,58,.4);color:var(--y);border-radius:99px;padding:4px 12px;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px}
.schouw-app .hero h1{font-size:22px;font-weight:800;color:#fff;margin-bottom:6px;line-height:1.3}
.schouw-app .hero h1 span{color:var(--y)}
.schouw-app .hero p{font-size:13px;color:rgba(255,255,255,.7);line-height:1.6}
.schouw-app .main{max-width:660px;margin:0 auto;padding:0 16px 80px}
.schouw-app .card{background:var(--w);border-radius:16px;box-shadow:0 2px 16px rgba(56,159,128,.10);border:1px solid var(--r);margin-top:-24px;position:relative;z-index:2}
.schouw-app .prog{height:5px;background:var(--r);border-radius:16px 16px 0 0;overflow:hidden}
.schouw-app .progbar{height:5px;background:linear-gradient(90deg,var(--gd),var(--g));transition:width .4s}
.schouw-app .stepbar{display:flex;gap:5px;overflow-x:auto;padding:10px 18px;border-bottom:1px solid var(--r);background:var(--bg);scrollbar-width:none}
.schouw-app .stepbar::-webkit-scrollbar{display:none}
.schouw-app .spill{padding:4px 10px;border-radius:99px;font-size:10px;font-weight:600;white-space:nowrap;border:1.5px solid var(--r);color:var(--gr);background:var(--w);flex-shrink:0;transition:all .2s}
.schouw-app .spill.done{background:var(--gl);border-color:var(--g);color:var(--ot)}
.schouw-app .spill.cur{background:var(--g);border-color:var(--g);color:#fff}
.schouw-app .prodgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}
.schouw-app .prodcard{border:2px solid var(--r);border-radius:12px;padding:16px 10px;cursor:pointer;text-align:center;background:var(--w);transition:all .15s;user-select:none}
.schouw-app .prodcard:hover{border-color:var(--rs);transform:translateY(-1px)}
.schouw-app .prodcard.on{border-color:var(--g);background:var(--gl)}
.schouw-app .prodcard .pico{font-size:26px;margin-bottom:6px}
.schouw-app .prodcard .pnm{font-size:12px;font-weight:700;color:var(--z);margin-bottom:7px}
.schouw-app .prodcard .pchk{width:18px;height:18px;border-radius:4px;border:2px solid #CBD5E0;background:#fff;margin:0 auto;display:flex;align-items:center;justify-content:center;font-size:11px;transition:all .15s}
.schouw-app .prodcard.on .pchk{background:var(--g);border-color:var(--g);color:#fff}
.schouw-app .cin{padding:20px 20px 0}
.schouw-app .slbl{font-size:10px;font-weight:700;color:var(--g);letter-spacing:.1em;text-transform:uppercase;margin-bottom:3px}
.schouw-app .sttl{font-size:17px;font-weight:800;color:var(--z);margin-bottom:18px}
.schouw-app .grp{margin-bottom:14px}
.schouw-app .ql{display:block;font-size:13px;font-weight:700;color:var(--z);margin-bottom:5px}
.schouw-app .hint{font-size:11px;color:var(--gr);margin-bottom:6px;line-height:1.55}
.schouw-app .rg{display:flex;flex-direction:column;gap:5px}
.schouw-app .rb{display:flex;align-items:flex-start;gap:9px;padding:10px 12px;border-radius:10px;cursor:pointer;border:2px solid var(--r);background:var(--w);font-size:13px;color:var(--z);user-select:none;transition:all .1s}
.schouw-app .rb:hover{border-color:var(--rs)}.schouw-app .rb.on{border-color:var(--g);background:var(--gl)}
.schouw-app .dot{width:17px;height:17px;border-radius:50%;flex-shrink:0;border:2px solid #CBD5E0;background:#fff;margin-top:1px;display:flex;align-items:center;justify-content:center;transition:all .1s}
.schouw-app .rb.on .dot{background:var(--g);border-color:var(--g)}.schouw-app .di{width:6px;height:6px;border-radius:50%;background:#fff}
.schouw-app .rsub{font-size:11px;color:var(--gr);margin-top:1px;line-height:1.4}
.schouw-app input[type=text], .schouw-app input[type=tel], .schouw-app input[type=date], .schouw-app input[type=number], .schouw-app input[type=email]{width:100%;padding:10px 13px;border-radius:10px;border:2px solid var(--r);font-size:13px;color:var(--z);outline:none;font-family:inherit;background:#FAFCFB;transition:border .1s}
.schouw-app input:focus{border-color:var(--g);background:#fff}
.schouw-app textarea{width:100%;padding:10px 13px;border-radius:10px;border:2px solid var(--r);font-size:13px;color:var(--z);outline:none;font-family:inherit;resize:vertical;min-height:80px;background:#FAFCFB}
.schouw-app textarea:focus{border-color:var(--g);background:#fff}
.schouw-app select{width:100%;padding:10px 13px;border-radius:10px;border:2px solid var(--r);font-size:13px;color:var(--z);background:#FAFCFB;outline:none;font-family:inherit}
.schouw-app .gebdat-row{display:grid;grid-template-columns:70px 1fr 90px;gap:6px}
.schouw-app .gebdat-sel{padding:10px 8px;border-radius:10px;border:2px solid var(--r);font-size:13px;color:var(--z);background:#FAFCFB;outline:none;font-family:inherit;transition:border .1s}
.schouw-app .gebdat-sel:focus{border-color:var(--g);background:#fff}
.schouw-app .gebdat-day,.schouw-app .gebdat-year{text-align:center}
@media (max-width:480px){.schouw-app .gebdat-row{grid-template-columns:60px 1fr 80px;gap:5px}.schouw-app .gebdat-sel{font-size:16px;padding:10px 6px}}
.schouw-app .g2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.schouw-app .g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.schouw-app .fl{display:flex;align-items:center;gap:9px;padding:10px 13px;border-radius:10px;border:2px dashed var(--rs);cursor:pointer;font-size:12px;color:var(--gr);background:#FAFCFB}
.schouw-app .fl:hover{border-color:var(--g);color:var(--g)}
.schouw-app input[type=file]{display:none}
.schouw-app .fn{font-size:11px;color:var(--g);margin-top:4px;font-weight:600}
.schouw-app .dv{border:none;border-top:1px solid var(--r);margin:14px 0}
.schouw-app .warn{background:var(--eb);border:1.5px solid var(--er);border-radius:10px;padding:10px 13px;font-size:12px;color:var(--et);margin-top:7px;line-height:1.6}
.schouw-app .info{background:var(--wb);border:1.5px solid var(--wr);border-radius:10px;padding:10px 13px;font-size:12px;color:var(--wt);margin-top:7px;line-height:1.6}
.schouw-app .good{background:var(--ob);border:1.5px solid var(--or2);border-radius:10px;padding:10px 13px;font-size:12px;color:var(--ot);margin-top:7px;line-height:1.6}
.schouw-app .blok{background:#FEF2F2;border:2.5px solid #F5A8A4;border-radius:10px;padding:12px 14px;font-size:13px;font-weight:700;color:#7C1A16;margin-top:8px;line-height:1.6}
.schouw-app .er{font-size:11px;color:#DC2626;margin-top:5px}
.schouw-app .nav{display:flex;gap:8px;padding:16px 20px 20px;justify-content:space-between;border-top:1px solid var(--r);margin-top:14px}
.schouw-app .btnp{flex:1;padding:12px 18px;background:var(--g);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;transition:background .15s;font-family:inherit}
.schouw-app .btnp:hover{background:var(--gd)}
.schouw-app .btns{padding:12px 18px;background:var(--bg);color:var(--gr);border:2px solid var(--r);border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit}
.schouw-app .btns:hover{border-color:var(--rs);color:var(--z)}
.schouw-app .kbox{background:#1A3A2E;border-radius:12px;padding:16px;margin-top:12px}
.schouw-app .ktitle{font-size:10px;font-weight:700;color:var(--y);letter-spacing:.1em;text-transform:uppercase;margin-bottom:12px}
.schouw-app .kg{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.schouw-app .kc{background:#256B56;border-radius:9px;padding:12px}.schouw-app .kc.em{border:1.5px solid rgba(232,192,58,.3)}
.schouw-app .kclbl{font-size:9px;font-weight:700;color:rgba(255,255,255,.5);letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}
.schouw-app .kclbl.y{color:var(--y)}.schouw-app .knr{font-size:30px;font-weight:900;color:#fff;line-height:1}.schouw-app .knr.y{color:var(--y)}
.schouw-app .kunit{font-size:11px;color:rgba(255,255,255,.4);margin-bottom:8px}
.schouw-app .krow{display:flex;justify-content:space-between;padding:3px 0;border-bottom:1px solid rgba(255,255,255,.08);font-size:11px}.schouw-app .krow:last-child{border:none}
.schouw-app .klbl{color:rgba(255,255,255,.45)}.schouw-app .kval{font-weight:700;font-family:monospace;color:#fff}.schouw-app .kval.g{color:#6EE7B7}.schouw-app .kval.o{color:var(--y)}.schouw-app .kval.r{color:#FCA5A5}
.schouw-app .rhead{padding:18px 20px;border-radius:16px 16px 0 0}.schouw-app .rbody{padding:20px}
.schouw-app .rsec{margin-bottom:16px}.schouw-app .rsect{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}
.schouw-app .ri{border-radius:9px;padding:10px 13px;margin-bottom:6px;font-size:12px;line-height:1.65}
.schouw-app .ri.rd{background:var(--eb);border:1.5px solid var(--er);color:var(--et)}
.schouw-app .ri.or{background:var(--wb);border:1.5px solid var(--wr);color:var(--wt)}
.schouw-app .ri.ye{background:#FEFCE8;border:1.5px solid #FDE047;color:#78350F}
.schouw-app .okrow{display:flex;gap:7px;padding:5px 0;border-bottom:1px solid var(--r);font-size:12px;color:#374151}.schouw-app .okrow:last-child{border:none}
.schouw-app .okc{color:var(--g);flex-shrink:0;font-weight:700}
.schouw-app .sbox{background:var(--bg);border:1px solid var(--r);border-radius:11px;overflow:hidden;margin-bottom:14px}
.schouw-app .sboxt{font-size:10px;font-weight:700;color:var(--gr);letter-spacing:.08em;text-transform:uppercase;padding:8px 14px;background:var(--r);border-bottom:1px solid var(--rs)}
.schouw-app .srow{display:flex;gap:8px;padding:6px 14px;border-bottom:1px solid var(--r);font-size:12px}.schouw-app .srow:last-child{border:none}
.schouw-app .sl{color:var(--gr);min-width:155px;flex-shrink:0;font-weight:600}
.schouw-app .sv{color:var(--z);font-size:11px;font-family:monospace}
.schouw-app .krgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.schouw-app .krcard{background:#fff;border:2px solid var(--r);border-radius:11px;overflow:hidden}.schouw-app .krcard.hl{border-color:var(--g)}
.schouw-app .krhead{padding:7px 13px;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.schouw-app .krhead.nm{background:var(--bg);color:var(--gr)}.schouw-app .krhead.em{background:#1A3A2E;color:var(--y)}
.schouw-app .krbody{padding:12px}.schouw-app .krnr{font-size:28px;font-weight:800;color:var(--z);line-height:1}.schouw-app .krcard.hl .krnr{color:var(--g)}
.schouw-app .krunit{font-size:11px;color:#94A3B8;margin-bottom:8px}.schouw-app .krrow{display:flex;justify-content:space-between;padding:3px 0;border-bottom:1px solid var(--r);font-size:11px}.schouw-app .krrow:last-child{border:none}
.schouw-app .krlbl{color:#94A3B8}.schouw-app .krval{font-weight:700;font-family:monospace;font-size:10px}
.schouw-app .akk{background:var(--ob);border:2px solid var(--or2);border-radius:11px;padding:15px;margin-bottom:15px}
.schouw-app .chkrow{display:flex;align-items:flex-start;gap:10px;cursor:pointer;margin-top:10px}
.schouw-app .chkbox{width:20px;height:20px;border-radius:5px;border:2px solid #CBD5E0;background:#fff;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:13px;transition:all .1s}
.schouw-app .chkbox.on{background:var(--g);border-color:var(--g);color:#fff}
.schouw-app .btnr{width:100%;padding:11px;background:var(--bg);color:var(--gr);border:2px solid var(--r);border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;margin-top:8px;font-family:inherit}
.schouw-app .btnpdf{width:100%;padding:13px;background:#1A1A1A;color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;margin-top:10px;font-family:inherit}
.schouw-app .btnpdf:hover{background:#333}
.schouw-app .btnsave{width:100%;padding:16px;background:var(--g);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:800;cursor:pointer;font-family:inherit;box-shadow:0 2px 12px rgba(56,159,128,0.25);transition:all .15s}
.schouw-app .btnsave:hover{background:var(--gd);box-shadow:0 4px 16px rgba(56,159,128,0.35);transform:translateY(-1px)}
.schouw-app .btnsave.dis{background:#CBD5E0;color:#718096;cursor:not-allowed;box-shadow:none}
.schouw-app .btnsave.dis:hover{background:#CBD5E0;box-shadow:none;transform:none}
.schouw-app .mppt-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.schouw-app .mppt-card{background:var(--ob);border:2px solid var(--or2);border-radius:11px;padding:13px}
.schouw-app .mppt-label{font-size:10px;font-weight:700;color:var(--ot);letter-spacing:.07em;text-transform:uppercase;margin-bottom:5px}
.schouw-app .mppt-val{font-size:22px;font-weight:800;color:var(--ot);line-height:1}
.schouw-app .mppt-sub{font-size:11px;color:var(--ot);margin-top:3px}
.schouw-app .dvblok{background:var(--bg);border:1.5px solid var(--r);border-radius:11px;padding:14px;margin-bottom:10px}
.schouw-app .dvblok-titel{font-size:11px;font-weight:700;color:var(--g);letter-spacing:.07em;text-transform:uppercase;margin-bottom:10px}
.schouw-app [data-mc] *, .schouw-app [data-mc] *::before, .schouw-app [data-mc] *::after{box-sizing:border-box;margin:0;padding:0}
.schouw-app [data-mc]{font-family:inherit;color:var(--z);border-radius:12px;overflow:hidden;border:1px solid var(--r);background:var(--bg)}
.schouw-app [data-mc] .mh{background:var(--g);padding:12px 15px;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.schouw-app [data-mc] .mhl{display:flex;align-items:center;gap:9px}.schouw-app [data-mc] .mhi{width:30px;height:30px;background:rgba(255,255,255,.2);border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.schouw-app [data-mc] .mht{font-size:12px;font-weight:800;color:#fff}.schouw-app [data-mc] .mhs{font-size:10px;color:rgba(255,255,255,.75);margin-top:1px}
.schouw-app [data-mc] .mlb{font-size:10px;font-weight:700;background:rgba(255,255,255,.18);color:#fff;border:1px solid rgba(255,255,255,.28);padding:3px 9px;border-radius:20px;white-space:nowrap}
.schouw-app [data-mc] .mtabs{display:flex;background:#fff;border-bottom:2px solid var(--r)}
.schouw-app [data-mc] .mtab{flex:1;font-family:inherit;font-size:12px;font-weight:600;padding:10px 8px;background:transparent;border:none;color:var(--gr);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:5px}
.schouw-app [data-mc] .mtab.on{color:var(--g);border-bottom-color:var(--g);font-weight:700}
.schouw-app [data-mc] .mpan{display:none;padding:15px}.schouw-app [data-mc] .mpan.on{display:block}
.schouw-app [data-mc] .mres{display:none;border-radius:10px;border:2px solid;padding:12px;margin-bottom:12px}
.schouw-app [data-mc] .mres.ok{background:var(--ob);border-color:var(--or2)}.schouw-app [data-mc] .mres.warn{background:var(--wb);border-color:var(--wr)}.schouw-app [data-mc] .mres.err{background:var(--eb);border-color:var(--er)}
.schouw-app [data-mc] .mrt{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:7px}
.schouw-app [data-mc] .mbdg{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:3px 10px;border-radius:20px}
.schouw-app [data-mc] .mres.ok .mbdg{background:#C0EDD8;color:var(--ot)}.schouw-app [data-mc] .mres.warn .mbdg{background:#FDE9B0;color:var(--wt)}.schouw-app [data-mc] .mres.err .mbdg{background:#FDD0CE;color:var(--et)}
.schouw-app [data-mc] .mstip{width:7px;height:7px;border-radius:50%}.schouw-app [data-mc] .mres.ok .mstip{background:var(--g)}.schouw-app [data-mc] .mres.warn .mstip{background:#E09000}.schouw-app [data-mc] .mres.err .mstip{background:#C02020}
.schouw-app [data-mc] .memj{font-size:18px;line-height:1}.schouw-app [data-mc] .mnm{font-size:15px;font-weight:800;margin-bottom:2px}
.schouw-app [data-mc] .mres.ok .mnm{color:var(--ot)}.schouw-app [data-mc] .mres.warn .mnm{color:var(--wt)}.schouw-app [data-mc] .mres.err .mnm{color:var(--et)}
.schouw-app [data-mc] .mmk{font-size:11px;margin-bottom:8px}.schouw-app [data-mc] .mres.ok .mmk{color:#2E8055}.schouw-app [data-mc] .mres.warn .mmk{color:#8A6500}.schouw-app [data-mc] .mres.err .mmk{color:#9A2820}
.schouw-app [data-mc] .mln{height:1px;margin-bottom:8px}.schouw-app [data-mc] .mres.ok .mln{background:var(--or2)}.schouw-app [data-mc] .mres.warn .mln{background:var(--wr)}.schouw-app [data-mc] .mres.err .mln{background:var(--er)}
.schouw-app [data-mc] .mrdn{font-size:12px;line-height:1.6;margin-bottom:8px}.schouw-app [data-mc] .mres.ok .mrdn{color:#1E6A40}.schouw-app [data-mc] .mres.warn .mrdn{color:#7A5500}.schouw-app [data-mc] .mres.err .mrdn{color:#8C1F1A}
.schouw-app [data-mc] .mcks{display:flex;flex-direction:column;gap:5px}.schouw-app [data-mc] .mck{display:flex;align-items:flex-start;gap:7px;font-size:12px;color:var(--ot);line-height:1.4}
.schouw-app [data-mc] .madv{font-size:12px;font-weight:700;padding:9px 11px;border-radius:8px;line-height:1.55}.schouw-app [data-mc] .mres.warn .madv{background:rgba(232,192,58,.12);color:var(--wt)}.schouw-app [data-mc] .mres.err .madv{background:rgba(192,32,32,.08);color:var(--et)}
.schouw-app [data-mc] .mzv{display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--rs);border-radius:10px;padding:5px 5px 5px 12px;margin-bottom:7px;transition:all .15s}
.schouw-app [data-mc] .mzv:focus-within{border-color:var(--g)}.schouw-app [data-mc] .mzi{flex:1;font-family:inherit;font-size:14px;border:none;background:transparent;color:var(--z);outline:none;padding:8px 0;min-width:0}
.schouw-app [data-mc] .mzi::placeholder{color:var(--gr)}.schouw-app [data-mc] .mwis{font-family:inherit;font-size:12px;font-weight:600;color:var(--gr);background:var(--bg);border:1px solid var(--r);border-radius:8px;padding:7px 11px;cursor:pointer}
.schouw-app [data-mc] .mhint{font-size:11px;color:var(--gr);text-align:center;margin-bottom:10px}
.schouw-app [data-mc] .msuglist{display:flex;flex-direction:column;gap:5px}.schouw-app [data-mc] .msug{width:100%;font-family:inherit;text-align:left;background:#fff;border:1px solid var(--r);border-radius:9px;padding:9px 12px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:9px;transition:all .12s}
.schouw-app [data-mc] .msug:hover{border-color:var(--g)}.schouw-app [data-mc] .msug-nm{font-size:13px;font-weight:700;color:var(--z);display:block}.schouw-app [data-mc] .msug-mk{font-size:11px;color:var(--gr);display:block;margin-top:1px}
.schouw-app [data-mc] .msp{width:9px;height:9px;border-radius:50%;flex-shrink:0}.schouw-app [data-mc] .msp.ok{background:var(--g)}.schouw-app [data-mc] .msp.warn{background:#E09000}.schouw-app [data-mc] .msp.err{background:#E0342D}
.schouw-app [data-mc] .mnf{font-size:12px;color:var(--gr);text-align:center;padding:13px;background:#fff;border:1px solid var(--r);border-radius:9px}
.schouw-app [data-mc] .mfilts{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:9px}
.schouw-app [data-mc] .mfbtn{font-family:inherit;font-size:11px;font-weight:600;padding:5px 10px;border-radius:20px;border:1.5px solid var(--r);background:#fff;color:var(--gr);cursor:pointer;transition:all .12s}
.schouw-app [data-mc] .mfbtn.fa{background:var(--z);color:#fff;border-color:var(--z)}.schouw-app [data-mc] .mfbtn.fo{background:var(--ob);color:var(--ot);border-color:var(--or2)}.schouw-app [data-mc] .mfbtn.fw{background:var(--wb);color:var(--wt);border-color:var(--wr)}.schouw-app [data-mc] .mfbtn.fe{background:var(--eb);color:var(--et);border-color:var(--er)}
.schouw-app [data-mc] .mcount{font-size:11px;color:var(--gr);margin-bottom:6px}.schouw-app [data-mc] .mlist{background:#fff;border:1px solid var(--r);border-radius:10px;overflow:hidden}
.schouw-app [data-mc] .mitem{display:flex;align-items:center;padding:10px 13px;border-bottom:1px solid var(--r);cursor:pointer;transition:background .1s;gap:10px;width:100%;font-family:inherit;background:#fff;border-left:none;border-right:none;border-top:none;text-align:left}
.schouw-app [data-mc] .mitem:last-child{border-bottom:none}.schouw-app [data-mc] .mitem:hover{background:var(--bg)}
.schouw-app [data-mc] .mbalk{width:4px;border-radius:3px;align-self:stretch;min-height:26px;flex-shrink:0}.schouw-app [data-mc] .mbalk.ok{background:var(--g)}.schouw-app [data-mc] .mbalk.warn{background:#E09000}.schouw-app [data-mc] .mbalk.err{background:#E0342D}
.schouw-app [data-mc] .minfo{flex:1;min-width:0}.schouw-app [data-mc] .mnaam{font-size:13px;font-weight:700;color:var(--z)}.schouw-app [data-mc] .mmerk{font-size:11px;color:var(--gr);margin-top:1px}
.schouw-app [data-mc] .mchip{font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;flex-shrink:0;white-space:nowrap}
.schouw-app [data-mc] .mchip.ok{background:var(--ob);color:var(--ot)}.schouw-app [data-mc] .mchip.warn{background:var(--wb);color:var(--wt)}.schouw-app [data-mc] .mchip.err{background:var(--eb);color:var(--et)}
.schouw-app [data-mc] .mfoot{font-size:10px;color:var(--gr);text-align:center;padding:8px 13px;border-top:1px solid var(--r);background:#fff}
.schouw-app .chero{background:linear-gradient(135deg,#1A4A38,#256B56,#389F80);padding:20px 20px 42px}
.schouw-app .chero-in{max-width:660px;margin:0 auto}.schouw-app .chdg{display:inline-flex;align-items:center;gap:5px;background:rgba(232,192,58,.2);border:1px solid rgba(232,192,58,.4);border-radius:99px;padding:3px 10px;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--y);margin-bottom:10px}
.schouw-app .chero h1{font-size:18px;font-weight:800;color:#fff;margin-bottom:4px}.schouw-app .chero p{font-size:12px;color:rgba(255,255,255,.6)}
.schouw-app .chcon{max-width:660px;margin:0 auto;padding:0 16px;display:flex;flex-direction:column;height:calc(100vh - 155px)}
.schouw-app .chmsgs{flex:1;overflow-y:auto;padding:14px 0;display:flex;flex-direction:column;gap:10px}
.schouw-app .msg{display:flex;gap:8px;align-items:flex-start}.schouw-app .msg.u{flex-direction:row-reverse}
.schouw-app .mav{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}
.schouw-app .mav.b{background:var(--g);color:#fff}.schouw-app .mav.u{background:var(--y);color:var(--z)}
.schouw-app .mbub{max-width:82%;padding:10px 14px;border-radius:12px;font-size:13px;line-height:1.6}
.schouw-app .mbub.b{background:#fff;border:1px solid var(--r);color:var(--z);border-radius:4px 12px 12px 12px;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.schouw-app .mbub.u{background:var(--g);color:#fff;border-radius:12px 4px 12px 12px}
.schouw-app .mbub pre{white-space:pre-wrap;font-family:inherit;font-size:12px;background:var(--bg);border:1px solid var(--r);border-radius:7px;padding:10px;margin-top:8px;color:var(--z);line-height:1.7}
.schouw-app .typ{display:flex;align-items:center;gap:4px;padding:10px 14px;background:#fff;border:1px solid var(--r);border-radius:4px 12px 12px 12px;width:fit-content}
.schouw-app .typ span{width:6px;height:6px;background:#94A3B8;border-radius:50%;animation:bo .9s infinite}
.schouw-app .typ span:nth-child(2){animation-delay:.15s}.schouw-app .typ span:nth-child(3){animation-delay:.3s}
@keyframes bo{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-5px)}}
.schouw-app .chirow{display:flex;gap:8px;background:#fff;border:2px solid var(--r);border-radius:12px;padding:7px 7px 7px 15px;transition:border .15s}
.schouw-app .chirow:focus-within{border-color:var(--g)}
.schouw-app .chiin{flex:1;border:none;outline:none;font-family:inherit;font-size:13px;color:var(--z);background:transparent;resize:none;min-height:22px;max-height:120px;line-height:1.5;padding:2px 0}
.schouw-app .chsend{width:35px;height:35px;background:var(--g);border:none;border-radius:9px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s;align-self:flex-end}
.schouw-app .chsend:hover{background:var(--gd)}.schouw-app .chsend:disabled{background:var(--r);cursor:not-allowed}
.schouw-app .chrbtn{width:100%;padding:8px;background:transparent;border:1px solid var(--r);border-radius:9px;font-size:11px;color:#94A3B8;cursor:pointer;margin-top:6px;font-family:inherit}
.schouw-app .chnote{text-align:center;font-size:10px;color:#94A3B8;padding:6px 0;border-top:1px solid var(--r);margin-top:4px}
.schouw-app .opslagrow{display:flex;gap:10px;align-items:center;padding:9px 12px;background:var(--bg);border:1.5px solid var(--r);border-radius:10px;margin-bottom:7px}
.schouw-app .opslaglbl{font-size:12px;font-weight:600;color:var(--z);flex:1}
.schouw-app .opslagunit{font-size:11px;color:var(--gr);white-space:nowrap}
.schouw-app .opslagin{width:90px!important;padding:6px 10px!important;text-align:right;font-family:monospace!important}
@media(max-width:480px){.schouw-app .g2, .schouw-app .kg, .schouw-app .krgrid, .schouw-app .mppt-grid, .schouw-app .prodgrid{grid-template-columns:1fr}}
@media print{.schouw-app .tb, .schouw-app .tabs, .schouw-app .nav, .schouw-app .btnr, .schouw-app .btnpdf{display:none!important}.schouw-app{background:#fff!important}.schouw-app .card{box-shadow:none!important;border:none!important;margin-top:0!important}.schouw-app .main{padding:0!important}}

/* Override to ensure the embedded bundle plays nice inside our platform */
.schouw-app { min-height: auto !important; background: transparent !important; }
.schouw-app .card { margin-top: 0 !important; }

/* ===================================================================
   POLISH PASS ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â‚¬Å¾Ã‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â¦ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Â¦Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â design tokens, a11y, consistent interactions
   =================================================================== */

:root {
  /* Spacing scale (4/8pt grid) */
  --s-1: 4px;
  --s-2: 8px;
  --s-3: 12px;
  --s-4: 16px;
  --s-5: 20px;
  --s-6: 24px;
  --s-7: 32px;
  --s-8: 40px;

  /* Type scale */
  --t-xs: 11px;
  --t-sm: 12px;
  --t-base: 13px;
  --t-md: 14px;
  --t-lg: 16px;
  --t-xl: 20px;
  --t-2xl: 24px;

  /* Radius scale */
  --r-sm: 6px;
  --r-md: 10px;
  --r-lg: 14px;

  /* Focus ring (A11y ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â‚¬Å¾Ã‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â¦ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Â¦Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â WCAG 2.4.7) */
  --focus-ring: 0 0 0 2px var(--surface), 0 0 0 4px #4A7CFF;
  --focus-ring-green: 0 0 0 2px var(--surface), 0 0 0 4px var(--gv-green);
}

/* A11y: consistent focus-visible voor toetsenbord-gebruikers (niet voor muis) */
*:focus { outline: none; }
*:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
  border-radius: var(--r-sm);
}
button:focus-visible,
.sidebar-link:focus-visible,
.back-btn:focus-visible,
.ev-btn:focus-visible,
.formhub-btn:focus-visible {
  box-shadow: var(--focus-ring-green);
}
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  box-shadow: 0 0 0 3px rgba(53,170,130,0.25);
  border-color: var(--gv-green) !important;
}

/* A11y: screenreader-only helper */
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

/* A11y: respecteer reduced-motion voorkeur */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* Empty state pattern ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â‚¬Å¾Ã‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â¦ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Â¦Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â consistent over de hele app */
.gv-empty {
  text-align: center;
  padding: var(--s-7) var(--s-5);
  background: var(--surface);
  border: 1px dashed var(--line);
  border-radius: var(--r-lg);
  margin: var(--s-3) 0;
}
.gv-empty-icon {
  width: 56px; height: 56px;
  margin: 0 auto var(--s-4);
  border-radius: 50%;
  background: rgba(53,170,130,0.08);
  color: var(--gv-green-dark);
  display: flex; align-items: center; justify-content: center;
}
.gv-empty-title {
  font-family: 'Archivo', sans-serif;
  font-size: var(--t-lg);
  font-weight: 700;
  color: var(--ink);
  margin: 0 0 var(--s-2);
}
.gv-empty-desc {
  font-size: var(--t-base);
  color: var(--ink-muted);
  line-height: 1.55;
  margin: 0 auto var(--s-4);
  max-width: 360px;
}
.gv-empty-cta {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  background: var(--gv-green);
  color: white;
  border: none;
  padding: 10px 18px;
  border-radius: var(--r-md);
  font-family: inherit;
  font-size: var(--t-base);
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s;
}
.gv-empty-cta:hover { background: var(--gv-green-dark); }
.gv-empty-hint {
  margin-top: var(--s-3);
  font-size: var(--t-sm);
  color: var(--ink-muted);
}

/* Sidebar: subtieler tonen van secties */
.sidebar-section {
  font-size: 10.5px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  color: var(--ink-muted) !important;
  padding: var(--s-5) var(--s-4) var(--s-2) !important;
  margin-top: var(--s-2) !important;
  opacity: 0.75;
}
.sidebar-section:first-of-type {
  margin-top: 0 !important;
  padding-top: var(--s-3) !important;
}

/* Button hiÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â‚¬Å¾Ã‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¾Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Â¦Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â«rarchie verduidelijken */
.back-btn, .ev-btn, .formhub-btn {
  transition: all 0.15s ease;
}
.back-btn-primary,
.ev-btn-primary {
  font-weight: 600 !important;
  letter-spacing: 0.1px;
}

/* Toasts: z-index boven alles zetten (vaak onder modals verdwenen) */
.toast-container,
#toastContainer {
  z-index: 1000 !important;
}

/* Modals: consistente scrim + smooth fade */
.crm-modal,
.ev-modal {
  transition: opacity 0.18s ease;
}

/* Content links binnen prose klikbaar houden */
a:focus-visible {
  outline: 2px solid var(--gv-green);
  outline-offset: 2px;
  border-radius: 2px;
}

/* ===================================================================
   POLISH PASS 2 ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â‚¬Å¾Ã‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â¦ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Â¦Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â Google-style UX audit fixes
   =================================================================== */

/* Globale override: intro-label (de decoratieve groene pill) ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â‚¬Å¾Ã‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Â¦Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Â¦Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Â¦Ãƒâ€šÃ‚Â¾ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ subtiel label */
.intro .intro-label,
.home-intro .home-label,
.picker-intro .picker-label {
  background: none !important;
  border: none !important;
  padding: 0 !important;
  color: var(--ink-muted) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 1.2px !important;
  text-transform: uppercase !important;
  display: inline-block !important;
  margin-bottom: var(--s-2) !important;
}
.intro .intro-label::before,
.home-intro .home-label::before,
.picker-intro .picker-label::before {
  content: none !important;
  display: none !important;
}

/* Globale override: h1 accent-span niet meer kleuren (die "Le-ads" split) */
.intro h1 .accent,
.home-intro h1 .accent,
.picker-intro h1 .accent {
  color: inherit !important;
  background: none !important;
  -webkit-text-fill-color: inherit !important;
}

/* Intro compacter over heel de app */
.intro,
.home-intro,
.picker-intro {
  margin-bottom: var(--s-4) !important;
}
.intro h1,
.home-intro h1,
.picker-intro h1 {
  font-size: 24px !important;
  line-height: 1.2 !important;
  margin: 0 0 var(--s-2) !important;
  letter-spacing: -0.3px;
}
.intro p,
.home-intro p,
.picker-intro p {
  font-size: 13.5px !important;
  line-height: 1.5 !important;
  color: var(--ink-muted) !important;
  margin: 0 !important;
  max-width: 560px;
}

/* Dashboard sectie-heads uniform */
.dashboard-section {
  margin-bottom: var(--s-6);
}
.dashboard-section h2,
.dashboard-section-head h2 {
  font-family: 'Archivo', sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--ink) !important;
  margin: 0 0 var(--s-3) !important;
  letter-spacing: -0.1px;
}
.dashboard-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--s-3);
}
.dashboard-section-head h2 {
  margin: 0 !important;
}
.link-btn {
  background: none;
  border: none;
  color: var(--gv-green-dark);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  padding: var(--s-2) 0;
  font-family: inherit;
}
.link-btn:hover { text-decoration: underline; }

/* Legacy empty-state classes ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â‚¬Å¾Ã‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Â¦Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Â¦Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Â¦Ãƒâ€šÃ‚Â¾ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ gelijkschakelen met nieuwe gv-empty */
.bes-empty,
.sales-empty {
  background: var(--surface) !important;
  border: 1px dashed var(--line) !important;
  border-radius: var(--r-lg) !important;
  padding: var(--s-7) var(--s-5) !important;
  text-align: center !important;
  color: var(--ink-muted) !important;
  margin: var(--s-3) 0 !important;
}

/* Back-btn primary opnieuw: uniforme hiÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â‚¬Å¾Ã‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¾Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Â¦Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â«rarchie */
.back-btn.back-btn-primary {
  background: var(--gv-green) !important;
  color: white !important;
  border: 1px solid var(--gv-green) !important;
  font-weight: 600;
}
.back-btn.back-btn-primary:hover {
  background: var(--gv-green-dark) !important;
  border-color: var(--gv-green-dark) !important;
}

.bes-stat[data-empty="true"] {
  border-color: var(--line, #E8EAED) !important;
  background: var(--surface, #FFFFFF) !important;
  color: var(--ink-muted, #5F6368) !important;
  box-shadow: none !important;
}

/* KPI-stat: betekenisloze "0" visueel zachter tonen via data attribute */
.bes-stat[data-empty="true"] .bes-stat-value {
  color: var(--ink-muted);
  font-weight: 500;
  opacity: 0.5;
}

/* Status-badges: kleurcontrast naar WCAG-AA (4.5:1) */
.lead-status.gebeld,
.bes-status.wacht-docs,
[class*="status"].warn {
  background: rgba(210, 138, 20, 0.12) !important;
  color: #8A5A0C !important;
}
.lead-status.nieuw,
.bes-status.nieuw,
[class*="status"].info {
  background: rgba(74, 124, 255, 0.12) !important;
  color: #2A4FA8 !important;
}

/* Toolbar-buttons compacter + consistent spacing */
.bes-toolbar,
.leads-toolbar {
  gap: var(--s-2);
  flex-wrap: wrap;
}
.bes-toolbar > button,
.leads-toolbar > button {
  margin-left: 0 !important;
}

/* Filters worden bij collapse uitgeschakeld via .is-hidden */
.is-hidden {
  display: none !important;
}

/* ===================================================================
   POLISH PASS 3 ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â‚¬Å¾Ã‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â¦ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Â¦Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â Google-stijl design refinement
   =================================================================== */

/* KPI stats: compacter en visueel rustiger.
   Google principle: informatie dichtheid zonder cognitieve overload */
.bes-stats {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)) !important;
  gap: var(--s-2) !important;
  margin-bottom: var(--s-4) !important;
}
.bes-stat {
  background: var(--surface) !important;
  border: 1px solid var(--line) !important;
  border-radius: var(--r-md) !important;
  padding: var(--s-3) var(--s-4) !important;
  position: relative;
}
.bes-stat-label {
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.4px !important;
  text-transform: uppercase !important;
  color: var(--ink-muted) !important;
  margin-bottom: 2px !important;
}
.bes-stat-value {
  font-family: 'Archivo', sans-serif !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  color: var(--ink) !important;
  line-height: 1.1 !important;
  letter-spacing: -0.4px !important;
}
/* Verberg subtiele zero-stats in small datasets (via data attribute) */
.bes-stat[data-zero="true"] {
  opacity: 0.5;
  background: transparent !important;
}
.bes-stat[data-zero="true"] .bes-stat-value {
  color: var(--ink-muted) !important;
  font-weight: 500 !important;
}

/* Alarm-stats gebruiken alleen subtle accent ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â‚¬Å¾Ã‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â¦ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Â¦Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â geen schreeuwende borders */
.bes-stat.warn {
  border-color: rgba(210, 138, 20, 0.3) !important;
  background: rgba(210, 138, 20, 0.04) !important;
}
.bes-stat.warn .bes-stat-value { color: #8A5A0C !important; }
.bes-stat.ready {
  border-color: rgba(53, 170, 130, 0.3) !important;
  background: rgba(53, 170, 130, 0.04) !important;
}
.bes-stat.ready .bes-stat-value { color: var(--gv-green-dark) !important; }

/* Toolbar buttons: Material-inspired hiÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â‚¬Å¾Ã‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¾Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Â¦Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â«rarchie */
.bes-toolbar button,
.leads-toolbar button {
  font-size: 13px !important;
  font-weight: 600 !important;
  padding: 9px 14px !important;
  border-radius: 999px !important;
  letter-spacing: 0.2px;
}
.bes-toolbar button.back-btn-primary,
.leads-toolbar button.back-btn-primary {
  background: var(--gv-green) !important;
  color: white !important;
  border-color: var(--gv-green) !important;
  box-shadow: 0 1px 2px rgba(11,18,32,0.12);
}
.bes-toolbar button:not(.back-btn-primary),
.leads-toolbar button:not(.back-btn-primary) {
  background: var(--surface) !important;
  color: var(--ink) !important;
  border: 1px solid var(--line) !important;
}
.bes-toolbar button:not(.back-btn-primary):hover,
.leads-toolbar button:not(.back-btn-primary):hover {
  background: var(--line-soft) !important;
}

/* View-toggle (Lijst/Kanban) compacter in Material Segmented Control stijl */
.bes-view-toggle {
  display: inline-flex !important;
  border: 1px solid var(--line) !important;
  border-radius: 999px !important;
  padding: 3px !important;
  background: var(--line-soft) !important;
  gap: 0 !important;
}
.bes-view-btn {
  background: transparent !important;
  border: none !important;
  padding: 6px 14px !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  color: var(--ink-muted) !important;
  border-radius: 999px !important;
  cursor: pointer;
  transition: all 0.15s !important;
}
.bes-view-btn.active {
  background: var(--surface) !important;
  color: var(--ink) !important;
  box-shadow: 0 1px 3px rgba(11,18,32,0.08);
}

/* is-hidden: moet specifieker zijn dan .bes-filters/toolbar met display:flex !important */
.is-hidden,
.bes-filters.is-hidden,
.leads-filters.is-hidden,
.bes-toolbar.is-hidden,
.leads-toolbar.is-hidden,
.bes-stats.is-hidden,
[id].is-hidden {
  display: none !important;
}

/* Back-bar (ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã‚Â ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬ÃƒÂ¢Ã¢â‚¬Å¾Ã‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€šÃ‚Â ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¾Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Â ÃƒÂ¢Ã¢â€šÂ¬Ã¢â€žÂ¢ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã¢â‚¬Â¦Ãƒâ€šÃ‚Â¡ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™Ãƒâ€ Ã¢â‚¬â„¢ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã†â€™Ãƒâ€šÃ‚Â¢ÃƒÆ’Ã‚Â¢ÃƒÂ¢Ã¢â‚¬Å¡Ã‚Â¬Ãƒâ€¦Ã‚Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â¬ÃƒÆ’Ã†â€™ÃƒÂ¢Ã¢â€šÂ¬Ã…Â¡ÃƒÆ’Ã¢â‚¬Å¡Ãƒâ€šÃ‚Â terug-knop): subtieler */
.back-bar {
  margin-bottom: var(--s-3) !important;
}
.back-bar .back-btn:not(.back-btn-primary) {
  background: transparent !important;
  border: 1px solid var(--line) !important;
  color: var(--ink-muted) !important;
  font-weight: 500 !important;
  padding: 7px 14px !important;
  font-size: 12.5px !important;
}
.back-bar .back-btn:not(.back-btn-primary):hover {
  background: var(--line-soft) !important;
  color: var(--ink) !important;
}

/* === LEAD SLOT PICKER === */
.lead-slot-dates {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  padding-bottom: 8px;
  margin-bottom: 12px;
  scrollbar-width: thin;
  -webkit-overflow-scrolling: touch;
}
.lead-slot-date {
  flex: 0 0 auto;
  min-width: 60px;
  padding: 8px 10px;
  border-radius: 10px;
  background: var(--surface);
  border: 1px solid var(--line);
  cursor: pointer;
  text-align: center;
  transition: all 0.15s;
  font-family: inherit;
}
.lead-slot-date:hover:not(.is-disabled) { border-color: var(--gv-green); }
.lead-slot-date.active {
  background: var(--gv-green);
  border-color: var(--gv-green);
  color: white;
}
.lead-slot-date.is-disabled {
  opacity: 0.35;
  cursor: not-allowed;
}
.lead-slot-date-day {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-bottom: 2px;
}
.lead-slot-date.active .lead-slot-date-day { color: rgba(255,255,255,0.85); }
.lead-slot-date-num {
  font-family: 'Archivo', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.1;
}
.lead-slot-date.active .lead-slot-date-num { color: white; }
.lead-slot-date-count {
  font-size: 10px;
  color: var(--ink-muted);
  margin-top: 3px;
  font-weight: 500;
}
.lead-slot-date.active .lead-slot-date-count { color: rgba(255,255,255,0.85); }

/* Tijdslots in grid */
.lead-slot-times {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(78px, 1fr));
  gap: 6px;
  min-height: 40px;
}
.lead-slot-time {
  padding: 9px 6px;
  border-radius: 8px;
  background: var(--surface);
  border: 1px solid var(--line);
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  font-family: inherit;
  text-align: center;
  color: var(--ink);
  transition: all 0.12s;
}
.lead-slot-time:hover:not(.is-booked) {
  border-color: var(--gv-green);
  background: rgba(53,170,130,0.04);
}
.lead-slot-time.active {
  background: var(--gv-green);
  color: white;
  border-color: var(--gv-green);
}
.lead-slot-time.is-booked {
  opacity: 0.35;
  cursor: not-allowed;
  text-decoration: line-through;
  background: var(--line-soft);
}
.lead-slot-empty {
  grid-column: 1 / -1;
  padding: 20px;
  text-align: center;
  color: var(--ink-muted);
  font-size: 12.5px;
  background: var(--line-soft);
  border-radius: 8px;
}

/* Lead status-indicator op de card */
.lead-status-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.2px;
  white-space: nowrap;
  border: 1px solid transparent;
}
.lead-status-chip.afspraak {
  background: #DBEAFE;
  color: #1E40AF;
  border-color: #BFDBFE;
}
.lead-status-chip.getekend {
  background: #D1FAE5;
  color: #065F46;
  border-color: #86EFAC;
}
.lead-status-chip.verloren {
  background: #FEE2E2;
  color: #991B1B;
  border-color: #FCA5A5;
}
.lead-status-chip.terugbellen {
  background: #FEF3C7;
  color: #92400E;
  border-color: #FDE68A;
}
.lead-status-chip.gebeld {
  background: #F1F5F9;
  color: #475569;
  border-color: #CBD5E1;
}

/* Hele kaart kleurt mee zodat status op het eerste oog leesbaar is */
.lead-card-getekend {
  background: linear-gradient(to right, #F0FDF4, #FFFFFF 60%);
  border-left: 4px solid #22C55E;
}
.lead-card-verloren {
  background: linear-gradient(to right, #FEF2F2, #FFFFFF 60%);
  border-left: 4px solid #DC2626;
  opacity: 0.85;
}
.lead-card-terugbellen {
  background: linear-gradient(to right, #FFFBEB, #FFFFFF 60%);
  border-left: 4px solid #F59E0B;
}
.lead-card-afspraak {
  background: linear-gradient(to right, #EFF6FF, #FFFFFF 60%);
  border-left: 4px solid #3B82F6;
}

/* Mobile: grote hit-targets (A11y WCAG 2.5.5 = 44x44 minimum) */
@media (pointer: coarse) {
  .sidebar-link,
  .back-btn,
  .ev-btn,
  button[type="button"] {
    min-height: 40px;
  }
}

/* === Producten-pagina: responsive kaart-view voor mobiel === */
/* Op breed scherm: tabel-view (al bestaand). Op smal scherm: kaart-view. */

/* Standaard tonen we de tabel, kaarten verbergen */
.prod-card-list { display: none; }

/* Op mobiel: kaarten tonen, tabel verbergen */
@media (max-width: 720px) {
  .prod-table-wrap { display: none !important; }
  .prod-card-list { display: flex; flex-direction: column; gap: 8px; }

  .prod-card {
    background: white;
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 12px 14px;
    display: flex;
    flex-direction: column;
    gap: 8px;
  }
  .prod-card-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
  }
  .prod-card-naam {
    font-weight: 600;
    color: var(--ink);
    font-size: 14px;
    line-height: 1.3;
    flex: 1;
  }
  .prod-card-meta {
    font-size: 11.5px;
    color: var(--ink-muted);
    margin-top: 2px;
  }
  .prod-card-prijzen {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 6px;
    padding-top: 8px;
    border-top: 1px solid var(--line-soft);
  }
  .prod-card-prijs-blok {
    display: flex;
    flex-direction: column;
    gap: 1px;
    font-variant-numeric: tabular-nums;
  }
  .prod-card-prijs-label {
    font-size: 10px;
    color: var(--ink-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
  }
  .prod-card-prijs-waarde {
    font-size: 13px;
    font-weight: 600;
    color: var(--ink);
  }
  .prod-card-edit {
    background: var(--line-soft);
    border: none;
    border-radius: 6px;
    padding: 6px 10px;
    cursor: pointer;
    color: var(--ink-muted);
    transition: all 0.15s;
  }
  .prod-card-edit:hover { background: var(--line); color: var(--ink); }

  /* Header: stack knop onder titel */
  .prod-section-head {
    flex-direction: column !important;
    align-items: stretch !important;
  }
  .prod-section-head .mt-add-btn {
    align-self: flex-start;
    margin-top: 4px;
  }

  /* Modal: full-width op mobiel */
  .crm-modal-box { max-width: 100% !important; margin: 8px; }
  .bl-form-grid-2 {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
  }
  /* Samenstelling-rij: dropdown + aantal + delete onder elkaar op mobiel */
  #prodSamenstellingEditor > div {
    flex-wrap: wrap;
  }
  #prodSamenstellingEditor select {
    flex-basis: 100% !important;
    margin-bottom: 4px;
  }
}
/* === End integrated legacy schouw styles === */


/* === Universal CRM page system 2026-05-12 === */
:root,
.crm-app {
  --color-primary: #1a73e8;
  --color-primary-light: #e8f0fe;
  --color-primary-dark: #1557b0;
  --color-success: #1e8e3e;
  --color-danger: #d93025;
  --color-warning: #f59e0b;
  --color-text-primary: #202124;
  --color-text-secondary: #5f6368;
  --color-text-tertiary: #80868b;
  --color-text-disabled: #bdc1c6;
  --color-surface: #ffffff;
  --color-bg: #f8f9fa;
  --color-border: #e0e3e7;
  --font-family: "Google Sans", "Roboto", "Segoe UI", system-ui, sans-serif;
  --font-size-xs: 11px;
  --font-size-sm: 12px;
  --font-size-base: 14px;
  --font-size-body: 16px;
  --font-size-subtitle: 16px;
  --font-size-h3: 18px;
  --font-size-h2: 22px;
  --font-size-h1: 34px;
  --font-weight-regular: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --line-height-tight: 1.2;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.75;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-7: 28px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-full: 9999px;
  --shadow-none: none;
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.08);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.10);
  --shadow-focus: 0 0 0 3px rgba(26, 115, 232, 0.20);
  --transition-fast: 0.12s cubic-bezier(0.2, 0, 0, 1);
  --transition-normal: 0.20s cubic-bezier(0.2, 0, 0, 1);
  --sidebar-width: 320px;
  --page-padding-x: 40px;
  --page-padding-top: 36px;
  --content-max-width: 1280px;
  --crm-font: var(--font-family);
  --crm-primary: var(--color-primary);
  --crm-primary-soft: var(--color-primary-light);
  --crm-primary-dark: var(--color-primary-dark);
  --crm-border: var(--color-border);
  --crm-text: var(--color-text-primary);
  --crm-muted: var(--color-text-secondary);
  --crm-subtle: var(--color-text-tertiary);
  --crm-page-top-pad: var(--page-padding-top);
  --crm-page-padding-x: var(--page-padding-x);
  --crm-page-title-size: var(--font-size-h1);
  --crm-page-title-line: 40px;
  --crm-page-copy-size: var(--font-size-subtitle);
  --crm-page-copy-line: 24px;
  --crm-page-label-size: var(--font-size-sm);
  --md-primary: var(--color-primary);
  --md-primary-container: var(--color-primary-light);
  --md-outline: var(--color-border);
  --md-outline-variant: var(--color-border);
  --md-on-surface: var(--color-text-primary);
  --md-on-surface-variant: var(--color-text-secondary);
  --font-sans: var(--font-family);
}

html body :is(.crm-app,#app) {
  background: var(--color-bg);
  color: var(--color-text-primary);
  font-family: var(--crm-font);
}

.crm-app .main-content > .page,
.crm-app .crm-main > .page,
.crm-app .page-wrapper {
  box-sizing: border-box !important;
  max-width: var(--content-max-width) !important;
  padding: var(--crm-page-top-pad) var(--crm-page-padding-x) 60px !important;
  width: 100% !important;
}

.crm-app [id^="view-"] > :is(.intro, .home-intro, .page-header, .crm-page-header, .td-header, .lead-page-header, .customer-page-header, .formhub-header, .operations-header) {
  font-family: var(--crm-font) !important;
  margin: 0 !important;
  min-height: auto !important;
}

.crm-app :is(.page-back-bar, .back-bar) {
  align-items: center !important;
  display: flex !important;
  margin: 0 0 20px !important;
  min-height: auto !important;
  padding-top: 0 !important;
}

.crm-app :is(.page-back-btn, .back-btn:not(.back-btn-primary)) {
  align-items: center !important;
  background: transparent !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-full) !important;
  box-shadow: none !important;
  color: var(--color-text-secondary) !important;
  cursor: pointer !important;
  display: inline-flex !important;
  font-family: var(--crm-font) !important;
  font-size: 13px !important;
  font-weight: var(--font-weight-medium) !important;
  gap: 4px !important;
  line-height: 20px !important;
  min-height: 30px !important;
  padding: 4px 12px !important;
  text-decoration: none !important;
}

.crm-app :is(.page-back-btn, .back-btn:not(.back-btn-primary)):hover,
.crm-app :is(.page-back-btn, .back-btn:not(.back-btn-primary)):focus-visible {
  background: var(--color-primary-light) !important;
  border-color: #c5d8fb !important;
  color: var(--color-primary) !important;
}

.crm-app :is(.page-eyebrow, .home-label, .intro-label, .lead-workspace-eyebrow, .inventory-eyebrow, .formhub-eyebrow),
.crm-app [id^="view-"] > :is(.intro, .home-intro, .page-header, .crm-page-header, .td-header, .lead-page-header, .customer-page-header, .formhub-header, .operations-header) :is(.page-eyebrow, .home-label, .intro-label, .eyebrow) {
  color: var(--color-text-tertiary) !important;
  display: block !important;
  font-family: var(--crm-font) !important;
  font-size: 12px !important;
  font-weight: var(--font-weight-semibold) !important;
  letter-spacing: 0.08em !important;
  line-height: 16px !important;
  margin: 0 0 6px !important;
  text-transform: uppercase !important;
}

.crm-app :is(.section-label, .route-check-card .intro-label, .card-section-label) {
  color: var(--color-text-primary) !important;
  display: block !important;
  font-family: var(--crm-font) !important;
  font-size: 13px !important;
  font-weight: var(--font-weight-semibold) !important;
  letter-spacing: 0 !important;
  line-height: 20px !important;
  margin: 0 0 8px !important;
  text-transform: none !important;
}

.crm-app :is(.page-title, #homeGreeting),
.crm-app [id^="view-"] > :is(.intro, .home-intro, .page-header, .crm-page-header, .td-header, .lead-page-header, .customer-page-header, .formhub-header, .operations-header) h1,
.crm-app #view-todo .td-header :is(h1, h2),
.crm-app .schouw-app :is(.form-card h1, .schouw-page-title) {
  color: var(--color-text-primary) !important;
  font-family: var(--crm-font) !important;
  font-size: 34px !important;
  font-weight: var(--font-weight-medium) !important;
  letter-spacing: 0 !important;
  line-height: 40px !important;
  margin: 0 0 12px !important;
}

.crm-app :is(.page-title, #homeGreeting) :is(span, .accent),
.crm-app [id^="view-"] > :is(.intro, .home-intro, .page-header, .crm-page-header, .td-header, .lead-page-header, .customer-page-header, .formhub-header, .operations-header) h1 :is(span, .accent) {
  font-size: inherit !important;
  font-weight: inherit !important;
  line-height: inherit !important;
}

.crm-app :is(.page-subtitle, #homeSubtitle, .td-header-sub),
.crm-app [id^="view-"] > :is(.intro, .home-intro, .page-header, .crm-page-header, .td-header, .lead-page-header, .customer-page-header, .formhub-header, .operations-header) > p,
.crm-app .schouw-app :is(.page-subtitle, .form-card > p, .schouw-page-subtitle) {
  color: var(--color-text-secondary) !important;
  font-family: var(--crm-font) !important;
  font-size: 16px !important;
  font-weight: var(--font-weight-regular) !important;
  line-height: 24px !important;
  margin: 0 0 28px !important;
  max-width: 820px;
}

.crm-app :is(.page-actionbar, .lead-toolbar, .customer-toolbar, .ticket-toolbar, .td-lists-bar, .agenda-toolbar, .formhub-toolbar) {
  align-items: center !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}

.crm-app :is(.btn-primary, .crm-primary-btn, .primary-btn, .ticket-primary-btn, .td-list-new-btn, .agenda-new-btn, .leads-primary-btn, .customer-primary-btn, .formhub-primary-btn, .gv-empty-cta:not(.secondary), .schouw-app .client-primary-btn, .schouw-app .form-primary-btn, button[data-variant="primary"]) {
  align-items: center !important;
  background: var(--color-primary) !important;
  border: 0 !important;
  border-radius: var(--radius-full) !important;
  box-shadow: none !important;
  color: #ffffff !important;
  cursor: pointer !important;
  display: inline-flex !important;
  font-family: var(--crm-font) !important;
  font-size: 14px !important;
  font-weight: var(--font-weight-medium) !important;
  gap: 6px !important;
  justify-content: center !important;
  line-height: 20px !important;
  min-height: 36px !important;
  padding: 8px 20px !important;
  text-decoration: none !important;
  transition: background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast) !important;
}

.crm-app :is(.btn-primary, .crm-primary-btn, .primary-btn, .ticket-primary-btn, .td-list-new-btn, .agenda-new-btn, .leads-primary-btn, .customer-primary-btn, .formhub-primary-btn, .gv-empty-cta:not(.secondary), .schouw-app .client-primary-btn, .schouw-app .form-primary-btn, button[data-variant="primary"]):hover,
.crm-app :is(.btn-primary, .crm-primary-btn, .primary-btn, .ticket-primary-btn, .td-list-new-btn, .agenda-new-btn, .leads-primary-btn, .customer-primary-btn, .formhub-primary-btn, .gv-empty-cta:not(.secondary), .schouw-app .client-primary-btn, .schouw-app .form-primary-btn, button[data-variant="primary"]):focus-visible {
  background: var(--color-primary-dark) !important;
  color: #ffffff !important;
}

.crm-app :is(.btn-secondary, .crm-secondary-btn, .secondary-btn, .leads-secondary-btn, .ticket-secondary-btn, .agenda-secondary-btn, .formhub-secondary-btn, .schouw-app .client-secondary-btn, .schouw-app .form-secondary-btn, button[data-variant="secondary"]) {
  align-items: center !important;
  background: transparent !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-full) !important;
  box-shadow: none !important;
  color: var(--color-text-primary) !important;
  cursor: pointer !important;
  display: inline-flex !important;
  font-family: var(--crm-font) !important;
  font-size: 14px !important;
  font-weight: var(--font-weight-medium) !important;
  gap: 6px !important;
  justify-content: center !important;
  line-height: 20px !important;
  min-height: 36px !important;
  padding: 8px 16px !important;
  text-decoration: none !important;
}

.crm-app :is(.page-tabs, .lead-workspace-tabs, .client-picker-tabs, .qt-client-tabs, .tg-view-switch, .bes-segment, .customer-view-toggle, .invoice-filter-group, .product-page-tabs, .schouw-app .client-picker-tabs) {
  align-items: center !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 4px !important;
  margin-bottom: 24px !important;
}

.crm-app :is(.page-tab, .lead-workspace-tabs button, .client-picker-tabs button, .client-tab, .qt-client-tab, .tg-view-btn, .bes-segment button, .customer-view-toggle button, .invoice-filter-chip, .ticket-filter-chip, .td-list-chip, .product-page-tabs button, .schouw-app .client-tab) {
  align-items: center !important;
  background: transparent !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-full) !important;
  box-shadow: none !important;
  color: var(--color-text-secondary) !important;
  cursor: pointer !important;
  display: inline-flex !important;
  font-family: var(--crm-font) !important;
  font-size: 14px !important;
  font-weight: var(--font-weight-medium) !important;
  gap: 6px !important;
  line-height: 20px !important;
  min-height: 34px !important;
  padding: 6px 16px !important;
  text-decoration: none !important;
}

.crm-app :is(.page-tab.active, .page-tab[aria-selected="true"], .lead-workspace-tabs button.active, .client-picker-tabs button.active, .client-tab.active, .client-tab[aria-selected="true"], .qt-client-tab.active, .tg-view-btn.active, .bes-segment button.active, .customer-view-toggle button.active, .invoice-filter-chip.active, .ticket-filter-chip.active, .td-list-chip.active, .product-page-tabs button.active, .schouw-app .client-tab.active) {
  background: var(--color-primary-light) !important;
  border-color: #c5d8fb !important;
  color: var(--color-primary) !important;
  font-weight: var(--font-weight-semibold) !important;
}

.crm-app :is(.page-tab-badge, .tab-badge, .lead-workspace-tabs .badge, .client-tab .badge) {
  background: var(--color-primary) !important;
  border-radius: 10px !important;
  color: #ffffff !important;
  display: inline-flex !important;
  font-size: 11px !important;
  font-weight: var(--font-weight-bold) !important;
  justify-content: center !important;
  line-height: 16px !important;
  min-width: 18px !important;
  padding: 1px 6px !important;
  text-align: center !important;
}

.crm-app :is(.card, .crm-card, .form-card, .manual-form-card, .dashboard-stat, .quick-action, .route-check-card, .td-kpi, .ticket-stat-card, .ticket-board-card, .formhub-card, .gv-card, .customer-card, .customer-detail-section, .lead-report-card, .ops-panel, .energy-panel, .schouw-app .client-result, .schouw-app .form-card) {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
}

.crm-app :is(.card, .crm-card, .form-card, .manual-form-card, .dashboard-stat, .quick-action, .route-check-card, .td-kpi, .ticket-stat-card, .ticket-board-card, .formhub-card, .gv-card, .customer-card, .customer-detail-section, .lead-report-card, .ops-panel, .energy-panel):not(.card--compact):not(.card--large) {
  padding: 20px !important;
}

.crm-app .card--compact {
  padding: 16px !important;
}

.crm-app .card--large {
  padding: 28px !important;
}

.crm-app :is(.field-label, label.field-label, .crm-field-label, .form-field label, .schouw-app label) {
  color: var(--color-text-primary) !important;
  display: block !important;
  font-family: var(--crm-font) !important;
  font-size: 13px !important;
  font-weight: var(--font-weight-semibold) !important;
  line-height: 18px !important;
  margin: 0 0 6px !important;
}

.crm-app :is(.field-input, input:not([type="checkbox"]):not([type="radio"]):not([type="file"]), select) {
  background: #ffffff !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
  color: var(--color-text-primary) !important;
  font-family: var(--crm-font) !important;
  font-size: 14px !important;
  font-weight: var(--font-weight-regular) !important;
  height: 44px !important;
  line-height: 20px !important;
  max-width: 100% !important;
  outline: none !important;
  padding: 10px 14px !important;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast) !important;
}

.crm-app textarea,
.crm-app .field-textarea {
  background: #ffffff !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
  color: var(--color-text-primary) !important;
  font-family: var(--crm-font) !important;
  font-size: 14px !important;
  line-height: 20px !important;
  min-height: 96px !important;
  outline: none !important;
  padding: 10px 14px !important;
}

.crm-app :is(.field-input, input:not([type="checkbox"]):not([type="radio"]):not([type="file"]), select, textarea):focus {
  border-color: var(--color-primary) !important;
  box-shadow: var(--shadow-focus) !important;
}

.crm-app .field-search {
  position: relative !important;
}

.crm-app .field-search .field-input,
.crm-app .field-search input {
  padding-left: 40px !important;
}

.crm-app .field-search-icon,
.crm-app .search-icon {
  color: var(--color-text-tertiary) !important;
  font-size: 20px !important;
  left: 12px !important;
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
}

.crm-app :is(.empty-state, .gv-empty, .ticket-empty, .td-empty, .crm-empty-state) {
  align-items: center !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 60px 40px !important;
  text-align: center !important;
}

.crm-app :is(.empty-state-icon, .gv-empty-icon, .ticket-empty-icon, .crm-empty-icon) {
  align-items: center !important;
  background: #f1f3f4 !important;
  border-radius: 50% !important;
  color: var(--color-primary) !important;
  display: flex !important;
  font-size: 28px !important;
  height: 64px !important;
  justify-content: center !important;
  margin-bottom: 20px !important;
  width: 64px !important;
}

.crm-app :is(.empty-state-title, .gv-empty-title, .ticket-empty-title, .td-empty-title, .crm-empty-title) {
  color: var(--color-text-primary) !important;
  font-family: var(--crm-font) !important;
  font-size: 18px !important;
  font-weight: var(--font-weight-semibold) !important;
  line-height: 24px !important;
  margin: 0 0 8px !important;
}

.crm-app :is(.empty-state-desc, .gv-empty-desc, .ticket-empty-desc, .td-empty-desc, .crm-empty-desc) {
  color: var(--color-text-secondary) !important;
  font-family: var(--crm-font) !important;
  font-size: 14px !important;
  font-weight: var(--font-weight-regular) !important;
  line-height: 22px !important;
  margin: 0 auto 24px !important;
  max-width: 380px !important;
}

.crm-app :is(.status-success, .badge-success, .chip-success, .is-success) {
  color: var(--color-success) !important;
}

.crm-app :is(.status-danger, .badge-danger, .chip-danger, .is-danger) {
  color: var(--color-danger) !important;
}

@media (max-width: 768px) {
  .crm-app .main-content > .page,
  .crm-app .crm-main > .page,
  .crm-app .page-wrapper {
    padding: 24px 20px 48px !important;
  }

  .crm-app :is(.page-title, #homeGreeting),
  .crm-app [id^="view-"] > :is(.intro, .home-intro, .page-header, .crm-page-header, .td-header, .lead-page-header, .customer-page-header, .formhub-header, .operations-header) h1,
  .crm-app #view-todo .td-header :is(h1, h2) {
    font-size: 28px !important;
    line-height: 36px !important;
  }

  .crm-app :is(.page-subtitle, #homeSubtitle, .td-header-sub),
  .crm-app [id^="view-"] > :is(.intro, .home-intro, .page-header, .crm-page-header, .td-header, .lead-page-header, .customer-page-header, .formhub-header, .operations-header) > p {
    font-size: 15px !important;
    line-height: 22px !important;
  }
}
/* === End universal CRM page system 2026-05-12 === */


/* === Universal CRM route hardening 2026-05-12 === */
body :is(.page-eyebrow, #view-home .home-label, #view-home .page-eyebrow, #view-todo .td-header-main .page-eyebrow, [id^="view-"] > .intro .intro-label, #view-schouw .intro-label, #view-formhub .intro-label, #view-werkvoorbereiding .intro-label, #view-bestellingen .intro-label) {
  color: #80868b !important;
  display: block !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  line-height: 16px !important;
  margin: 0 0 6px !important;
  text-transform: uppercase !important;
}

body :is(.section-label, #view-team-agenda .route-check-card .intro-label, #view-team-agenda .route-check-card .section-label) {
  color: #202124 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  line-height: 20px !important;
  margin: 0 0 8px !important;
  text-transform: none !important;
}

body :is(#view-home #homeGreeting, #view-home .page-title, #view-team-agenda > .intro h1, #view-todo .td-header-main h1, #view-tickets > .intro h1, #view-leads > .intro h1, #view-bestellingen > .intro h1, #view-formhub > .intro h1, #view-werkvoorbereiding > .intro h1, #view-schouw > .intro h1, [id^="view-"] .page-title) {
  color: #202124 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 34px !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 40px !important;
  margin: 0 0 12px !important;
}

body :is(#view-home #homeSubtitle, #view-home .page-subtitle, #view-todo .td-header-sub, [id^="view-"] > .intro > p, #view-schouw > .intro > p, #view-formhub > .intro > p, #view-werkvoorbereiding > .intro > p) {
  color: #5f6368 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 24px !important;
  margin: 0 0 28px !important;
  max-width: 820px !important;
}

body :is(.page-back-bar, [id^="view-"] > .back-bar) {
  margin: 0 0 20px !important;
  padding-top: 0 !important;
}

body :is(.page-back-btn, [id^="view-"] > .back-bar .back-btn) {
  align-items: center !important;
  background: transparent !important;
  border: 1px solid #e0e3e7 !important;
  border-radius: 20px !important;
  color: #5f6368 !important;
  display: inline-flex !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  gap: 4px !important;
  line-height: 20px !important;
  min-height: 30px !important;
  padding: 4px 12px !important;
}

body :is(.btn-primary, #view-team-agenda .agenda-new-btn:not(.agenda-access-btn), #view-tickets .ticket-primary-btn, #view-todo .td-list-new-btn, #view-leads .leads-primary-btn, #view-schouw .btn-primary) {
  align-items: center !important;
  background: #1a73e8 !important;
  border: 0 !important;
  border-color: #1a73e8 !important;
  border-radius: 20px !important;
  color: #ffffff !important;
  display: inline-flex !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  gap: 6px !important;
  justify-content: center !important;
  line-height: 20px !important;
  min-height: 36px !important;
  padding: 8px 20px !important;
}

body :is(.btn-primary, #view-team-agenda .agenda-new-btn:not(.agenda-access-btn), #view-tickets .ticket-primary-btn, #view-todo .td-list-new-btn, #view-leads .leads-primary-btn, #view-schouw .btn-primary):hover {
  background: #1557b0 !important;
}

body :is(.btn-secondary, #view-team-agenda .agenda-access-btn) {
  align-items: center !important;
  background: transparent !important;
  border: 1px solid #e0e3e7 !important;
  border-radius: 20px !important;
  color: #202124 !important;
  display: inline-flex !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  gap: 6px !important;
  justify-content: center !important;
  line-height: 20px !important;
  min-height: 36px !important;
  padding: 8px 16px !important;
}

body :is(.page-tab, #view-leads .lead-workspace-tabs button, #view-schouw .client-tab, #view-tickets .client-tab, #view-todo .td-list-chip, #view-team-agenda .tg-view-btn, .bes-segment button, .customer-view-toggle button, .invoice-filter-chip) {
  align-items: center !important;
  background: transparent !important;
  border: 1px solid #e0e3e7 !important;
  border-radius: 20px !important;
  box-shadow: none !important;
  color: #5f6368 !important;
  display: inline-flex !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  gap: 6px !important;
  line-height: 20px !important;
  min-height: 34px !important;
  padding: 6px 16px !important;
}

body :is(.page-tab.active, .page-tab[aria-selected="true"], #view-leads .lead-workspace-tabs button.active, #view-schouw .client-tab.active, #view-schouw .client-tab[aria-selected="true"], #view-tickets .client-tab.active, #view-todo .td-list-chip.active, #view-team-agenda .tg-view-btn.active, .bes-segment button.active, .customer-view-toggle button.active, .invoice-filter-chip.active) {
  background: #e8f0fe !important;
  border-color: #c5d8fb !important;
  color: #1a73e8 !important;
  font-weight: 600 !important;
}

body [id^="view-"] :is(input:not([type="checkbox"]):not([type="radio"]):not([type="file"]):not([type="hidden"]), select) {
  background: #ffffff !important;
  border: 1px solid #e0e3e7 !important;
  border-radius: 8px !important;
  box-shadow: none !important;
  color: #202124 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  height: 44px !important;
  line-height: 20px !important;
  min-height: 44px !important;
  padding: 10px 14px !important;
}

body [id^="view-"] textarea {
  background: #ffffff !important;
  border: 1px solid #e0e3e7 !important;
  border-radius: 8px !important;
  box-shadow: none !important;
  color: #202124 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 14px !important;
  line-height: 20px !important;
  min-height: 96px !important;
  padding: 10px 14px !important;
}

body [id^="view-"] :is(input:not([type="checkbox"]):not([type="radio"]):not([type="file"]):not([type="hidden"]), select, textarea):focus {
  border-color: #1a73e8 !important;
  box-shadow: 0 0 0 3px rgba(26, 115, 232, 0.20) !important;
}

body :is(#view-home .dashboard-stat, #view-home .quick-action, #view-team-agenda .route-check-card, #view-todo .td-kpi, #view-tickets .ticket-stat-card, #view-formhub .formhub-card, #view-schouw .form-card, #view-schouw .client-result, #view-leads .lead-report-card, #view-leads .ops-panel) {
  background: #ffffff !important;
  border: 1px solid #e0e3e7 !important;
  border-radius: 12px !important;
  box-shadow: none !important;
}

body :is(#view-werkvoorbereiding .gv-empty, #view-tickets .ticket-empty, #view-todo .td-empty, .empty-state, .crm-empty-state) {
  align-items: center !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 60px 40px !important;
  text-align: center !important;
}
/* === End universal CRM route hardening 2026-05-12 === */


/* === Universal CRM specificity completion 2026-05-12 === */
body :is(#view-team-agenda .intro .intro-label, #view-leads .intro .intro-label, #view-bestellingen .intro .intro-label, #view-formhub .intro .intro-label, #view-werkvoorbereiding .intro .intro-label, #view-schouw .intro .intro-label, #view-tickets .intro .intro-label) {
  color: #80868b !important;
  display: block !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  line-height: 16px !important;
  margin: 0 0 6px !important;
  text-transform: uppercase !important;
}

body :is(#view-tickets .intro h1, #view-tickets #ticketListStep .intro h1) {
  color: #202124 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 34px !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 40px !important;
  margin: 0 0 12px !important;
}

body :is(#view-tickets .intro > p, #view-tickets #ticketListStep .intro > p) {
  color: #5f6368 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 24px !important;
  margin: 0 0 28px !important;
}

body :is(#view-leads, #view-tickets, #view-bestellingen, #view-team-agenda, #view-schouw, #view-todo) :is(input:not([type="checkbox"]):not([type="radio"]):not([type="file"]):not([type="hidden"]), select) {
  background: #ffffff !important;
  border: 1px solid #e0e3e7 !important;
  border-radius: 8px !important;
  box-shadow: none !important;
  color: #202124 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  height: 44px !important;
  line-height: 20px !important;
  min-height: 44px !important;
  padding: 10px 14px !important;
}
/* === End universal CRM specificity completion 2026-05-12 === */


/* === Universal CRM final eyebrow override 2026-05-12 === */
body #view-team-agenda#view-team-agenda .intro .intro-label,
body #view-leads#view-leads .intro .intro-label,
body #view-bestellingen#view-bestellingen .intro .intro-label,
body #view-formhub#view-formhub .intro .intro-label,
body #view-werkvoorbereiding#view-werkvoorbereiding .intro .intro-label,
body #view-schouw#view-schouw .intro .intro-label,
body #view-tickets#view-tickets .intro .intro-label,
body #view-home#view-home .home-label,
body #view-todo#view-todo .page-eyebrow {
  color: #80868b !important;
  display: block !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  line-height: 16px !important;
  margin: 0 0 6px !important;
  text-transform: uppercase !important;
}
/* === End universal CRM final eyebrow override 2026-05-12 === */


/* === Universal CRM deel 2 completion 2026-05-12 === */
body :is(.crm-app,#app) .view.active.view.active :is(.crm-intro h1, .intro h1, .crm-page-header h1, .page-header h1) {
  color: #202124 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 34px !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 40px !important;
  margin: 0 0 12px !important;
}

body :is(.crm-app,#app) .view.active.view.active.view.active :is(.page-eyebrow, .intro .intro-label, .crm-intro .picker-label, .picker-intro .picker-label, .eyebrow, .inventory-eyebrow, .ea-eyebrow, .energy-command-eyebrow, .formhub-eyebrow) {
  color: #80868b !important;
  display: block !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  line-height: 16px !important;
  margin: 0 0 6px !important;
  text-transform: uppercase !important;
}

body :is(.crm-app,#app) .view.active.view.active :is(.crm-intro > p, .intro > p, .crm-page-header > p, .page-header > p, .page-subtitle) {
  color: #5f6368 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 24px !important;
  margin: 0 0 28px !important;
  max-width: 820px !important;
}

body :is(.crm-app,#app) .view.active :is(.ea-hero h2, .inventory-hero h2, .energy-command-main h2, .module-title) {
  color: #202124 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 24px !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 30px !important;
  margin: 0 0 12px !important;
}

body :is(.crm-app,#app) .view.active :is(.ea-hero p, .inventory-hero p, .energy-command-main p, .module-lead) {
  color: #5f6368 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 24px !important;
}

body :is(.crm-app,#app) .view.active :is(.btn-primary, .ev-btn-primary, .back-btn-primary, .back-btn.back-btn-primary, .ea-btn.primary, .crm-primary-btn, .leads-primary-btn, .ticket-primary-btn, .td-list-new-btn) {
  align-items: center !important;
  background: #1a73e8 !important;
  border: 0 !important;
  border-color: #1a73e8 !important;
  border-radius: 20px !important;
  box-shadow: none !important;
  color: #ffffff !important;
  display: inline-flex !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  gap: 6px !important;
  justify-content: center !important;
  line-height: 20px !important;
  min-height: 36px !important;
  padding: 8px 20px !important;
}

body :is(.crm-app,#app) .view.active :is(.btn-primary, .ev-btn-primary, .back-btn-primary, .back-btn.back-btn-primary, .ea-btn.primary, .crm-primary-btn, .leads-primary-btn, .ticket-primary-btn, .td-list-new-btn):hover {
  background: #1557b0 !important;
}

body :is(.crm-app,#app) .view.active :is(.btn-secondary, .ea-btn.ghost, .ev-btn:not(.ev-btn-primary), .ops-panel-head button:not(.btn-primary):not(.ev-btn-primary)) {
  align-items: center !important;
  background: transparent !important;
  border: 1px solid #e0e3e7 !important;
  border-radius: 20px !important;
  box-shadow: none !important;
  color: #202124 !important;
  display: inline-flex !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  gap: 6px !important;
  justify-content: center !important;
  line-height: 20px !important;
  min-height: 36px !important;
  padding: 8px 16px !important;
}

body :is(.crm-app,#app) .view.active :is(.page-tabs, .crm-type-tabs, .product-page-tabs, .comm-tabs, .klanten-hub-tabs, .client-picker-tabs) {
  align-items: center !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 4px !important;
  margin-bottom: 24px !important;
}

body :is(.crm-app,#app) .view.active :is(.page-tab, .product-page-tab, .crm-type-tab, .comm-tab, .klanten-hub-tab, .client-tab, .ticket-stat-card, .td-list-chip, .tg-view-btn) {
  align-items: center !important;
  background: transparent !important;
  border: 1px solid #e0e3e7 !important;
  border-radius: 20px !important;
  box-shadow: none !important;
  color: #5f6368 !important;
  display: inline-flex !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  gap: 6px !important;
  line-height: 20px !important;
  min-height: 34px !important;
  padding: 6px 16px !important;
}

body :is(.crm-app,#app) .view.active :is(.page-tab.active, .page-tab[aria-selected="true"], .product-page-tab.active, .product-page-tab[aria-selected="true"], .crm-type-tab.active, .comm-tab.active, .klanten-hub-tab.active, .client-tab.active, .ticket-stat-card.active, .td-list-chip.active, .tg-view-btn.active) {
  background: #e8f0fe !important;
  border-color: #c5d8fb !important;
  color: #1a73e8 !important;
  font-weight: 600 !important;
}

body :is(.crm-app,#app) #view-products .product-sticky-nav {
  display: none !important;
}

body :is(.crm-app,#app) .view.active :is(.kpi-block, .crm-stat, .product-stat-card, .invoice-kpi-card, .comm-kpi-card, .fin-stat, .bes-stat, .ea-metric, .ops-kpis > div) {
  background: #ffffff !important;
  border: 1px solid #e0e3e7 !important;
  border-radius: 12px !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}

body :is(.crm-app,#app) .view.active :is(.kpi-value, .crm-stat strong, .product-stat-card strong, .invoice-kpi-card strong, .comm-kpi-card strong, .comm-kpi strong, .fin-stat-value, .bes-stat-value, .ea-metric strong, .ea-hero-panel strong, .ops-kpis strong) {
  color: #202124 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 32px !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 32px !important;
}

body :is(.crm-app,#app) .view.active :is(.kpi-label, .crm-stat span, .product-stat-card span, .invoice-kpi-card span, .comm-kpi-label, .fin-stat-label, .bes-stat-label, .ea-metric small, .ea-hero-panel span, .ops-kpis span) {
  color: #5f6368 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  line-height: 20px !important;
}

body :is(.crm-app,#app) #view-academy :is(.aca-mod-num, .aca-mod-title, .aca-progress-label, .num, summary, strong),
body :is(.crm-app,#app) #view-role-perms :is(.rp-perm-label, .rp-risk, .rp-cat-bulk-btn, .rp-cat-head-title, .rp-cat-head-count, .rp-cat-bulk, .rp-cat-bulk span, .rp-btn, .rp-profile-eyebrow, .rp-role-inspector-kicker, .rp-role-inspector-title),
body :is(.crm-app,#app) #view-users :is(strong, b, h2, span:not(.material-symbols-rounded)),
body :is(.crm-app,#app) #view-products span:not(.material-symbols-rounded),
body :is(.crm-app,#app) #view-health-check :is(strong, b, h2, span:not(.material-symbols-rounded)) {
  font-weight: 600 !important;
}

body :is(.crm-app,#app) #view-academy :is(.aca-mod-num, .aca-mod-title, .aca-progress-label) {
  font-size: 13px !important;
  line-height: 18px !important;
}

body :is(.crm-app,#app) #view-academy .aca-mod-status {
  font-weight: 500 !important;
}
/* === End universal CRM deel 2 completion 2026-05-12 === */


/* === Universal CRM deel 2 route hardening 2026-05-12 === */
body #view-crm#view-crm .crm-intro h1,
body :is(#view-products#view-products, #view-salesdock-mappings#view-salesdock-mappings, #view-voorraad#view-voorraad, #view-installatie-tarieven#view-installatie-tarieven, #view-financiering#view-financiering, #view-facturen#view-facturen, #view-sales-commissions#view-sales-commissions, #view-email-automations#view-email-automations, #view-audit#view-audit, #view-health-check#view-health-check, #view-role-perms#view-role-perms, #view-users#view-users, #view-academy#view-academy, #view-energie-klanten#view-energie-klanten, #view-energy-finance#view-energy-finance, #view-energy-anomalies#view-energy-anomalies) .intro h1 {
  color: #202124 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 34px !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 40px !important;
  margin: 0 0 12px !important;
}

body #view-crm#view-crm .crm-intro :is(.picker-label, .page-eyebrow),
body :is(#view-products#view-products, #view-salesdock-mappings#view-salesdock-mappings, #view-voorraad#view-voorraad, #view-installatie-tarieven#view-installatie-tarieven, #view-financiering#view-financiering, #view-facturen#view-facturen, #view-sales-commissions#view-sales-commissions, #view-email-automations#view-email-automations, #view-audit#view-audit, #view-health-check#view-health-check, #view-role-perms#view-role-perms, #view-users#view-users, #view-academy#view-academy, #view-energie-klanten#view-energie-klanten, #view-energy-finance#view-energy-finance, #view-energy-anomalies#view-energy-anomalies) :is(.intro .intro-label, .page-eyebrow, .inventory-eyebrow, .ea-eyebrow, .energy-command-eyebrow, .eyebrow) {
  color: #80868b !important;
  display: block !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  line-height: 16px !important;
  margin: 0 0 6px !important;
  text-transform: uppercase !important;
}

body #view-crm#view-crm .crm-intro > p,
body :is(#view-financiering#view-financiering, #view-facturen#view-facturen, #view-sales-commissions#view-sales-commissions, #view-email-automations#view-email-automations, #view-audit#view-audit, #view-health-check#view-health-check, #view-users#view-users, #view-academy#view-academy) .intro > p {
  color: #5f6368 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 24px !important;
  margin: 0 0 28px !important;
  max-width: 820px !important;
}

body #view-email-automations#view-email-automations .ea-hero h2,
body #view-voorraad#view-voorraad .inventory-hero h2,
body :is(#view-energie-klanten#view-energie-klanten, #view-energy-finance#view-energy-finance, #view-energy-anomalies#view-energy-anomalies) .energy-command-main h2,
body #view-academy#view-academy .module-title {
  color: #202124 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 24px !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 30px !important;
  margin: 0 0 12px !important;
}

body #view-email-automations#view-email-automations .ea-hero p,
body #view-voorraad#view-voorraad .inventory-hero p,
body :is(#view-energie-klanten#view-energie-klanten, #view-energy-finance#view-energy-finance, #view-energy-anomalies#view-energy-anomalies) .energy-command-main p,
body #view-academy#view-academy .module-lead {
  color: #5f6368 !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 24px !important;
}

body :is(#view-products#view-products, #view-salesdock-mappings#view-salesdock-mappings, #view-voorraad#view-voorraad, #view-financiering#view-financiering, #view-users#view-users, #view-academy#view-academy, #view-email-automations#view-email-automations) :is(.btn-primary, .ev-btn-primary, .back-btn-primary, .back-btn.back-btn-primary, .ea-btn.primary) {
  align-items: center !important;
  background: #1a73e8 !important;
  border: 0 !important;
  border-color: #1a73e8 !important;
  border-radius: 20px !important;
  box-shadow: none !important;
  color: #ffffff !important;
  display: inline-flex !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  gap: 6px !important;
  justify-content: center !important;
  line-height: 20px !important;
  min-height: 36px !important;
  padding: 8px 20px !important;
}

body :is(#view-products#view-products, #view-salesdock-mappings#view-salesdock-mappings, #view-installatie-tarieven#view-installatie-tarieven) :is(.btn-secondary, .ops-panel-head button, .ev-btn:not(.ev-btn-primary)) {
  align-items: center !important;
  background: transparent !important;
  border: 1px solid #e0e3e7 !important;
  border-radius: 20px !important;
  box-shadow: none !important;
  color: #202124 !important;
  display: inline-flex !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  gap: 6px !important;
  justify-content: center !important;
  line-height: 20px !important;
  min-height: 36px !important;
  padding: 8px 16px !important;
}

body :is(#view-crm#view-crm, #view-products#view-products, #view-sales-commissions#view-sales-commissions, #view-energie-klanten#view-energie-klanten, #view-energy-finance#view-energy-finance, #view-energy-anomalies#view-energy-anomalies, #view-schouw#view-schouw) :is(.page-tabs, .crm-type-tabs, .product-page-tabs, .comm-tabs, .klanten-hub-tabs, .client-picker-tabs) {
  align-items: center !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 4px !important;
  margin-bottom: 24px !important;
}

body :is(#view-crm#view-crm, #view-products#view-products, #view-sales-commissions#view-sales-commissions, #view-energie-klanten#view-energie-klanten, #view-energy-finance#view-energy-finance, #view-energy-anomalies#view-energy-anomalies, #view-schouw#view-schouw) :is(.page-tab, .crm-type-tab, .product-page-tab, .comm-tab, .klanten-hub-tab, .client-tab) {
  align-items: center !important;
  background: transparent !important;
  border: 1px solid #e0e3e7 !important;
  border-radius: 20px !important;
  box-shadow: none !important;
  color: #5f6368 !important;
  display: inline-flex !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  gap: 6px !important;
  line-height: 20px !important;
  min-height: 34px !important;
  padding: 6px 16px !important;
}

body :is(#view-crm#view-crm, #view-products#view-products, #view-sales-commissions#view-sales-commissions, #view-energie-klanten#view-energie-klanten, #view-energy-finance#view-energy-finance, #view-energy-anomalies#view-energy-anomalies, #view-schouw#view-schouw) :is(.page-tab.active, .page-tab[aria-selected="true"], .crm-type-tab.active, .product-page-tab.active, .product-page-tab[aria-selected="true"], .comm-tab.active, .klanten-hub-tab.active, .client-tab.active) {
  background: #e8f0fe !important;
  border-color: #c5d8fb !important;
  color: #1a73e8 !important;
  font-weight: 600 !important;
}

body #view-products#view-products .product-sticky-nav {
  display: none !important;
}

body :is(#view-crm#view-crm, #view-products#view-products, #view-salesdock-mappings#view-salesdock-mappings, #view-financiering#view-financiering, #view-facturen#view-facturen, #view-sales-commissions#view-sales-commissions, #view-health-check#view-health-check, #view-audit#view-audit, #view-email-automations#view-email-automations) :is(.kpi-value, .crm-stat strong, .product-stat-card strong, .ops-kpis strong, .invoice-kpi-card strong, .comm-kpi-card strong, .comm-kpi strong, .fin-stat-value, .bes-stat-value, .ea-metric strong, .ea-hero-panel strong) {
  color: #202124 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 32px !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  line-height: 32px !important;
}

body :is(#view-crm#view-crm, #view-products#view-products, #view-salesdock-mappings#view-salesdock-mappings, #view-financiering#view-financiering, #view-facturen#view-facturen, #view-sales-commissions#view-sales-commissions, #view-health-check#view-health-check, #view-audit#view-audit, #view-email-automations#view-email-automations) :is(.kpi-label, .crm-stat span, .product-stat-card span, .ops-kpis span, .invoice-kpi-card span, .comm-kpi-label, .fin-stat-label, .bes-stat-label, .ea-metric small, .ea-hero-panel span) {
  color: #5f6368 !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  line-height: 20px !important;
}

body #view-academy#view-academy :is(.aca-mod-num, .aca-mod-title, .aca-progress-label, .num, summary, strong),
body #view-role-perms#view-role-perms :is(.rp-perm-label, .rp-risk, .rp-cat-bulk-btn, .rp-cat-head-title, .rp-cat-head-count, .rp-cat-bulk, .rp-cat-bulk span, .rp-btn, .rp-profile-eyebrow, .rp-role-inspector-kicker, .rp-role-inspector-title),
body #view-users#view-users :is(strong, b, h2, span:not(.material-symbols-rounded)),
body #view-products#view-products span:not(.material-symbols-rounded),
body #view-health-check#view-health-check :is(strong, b, h2, span:not(.material-symbols-rounded)) {
  font-weight: 600 !important;
}

body #view-academy#view-academy :is(.aca-mod-num, .aca-mod-title, .aca-progress-label) {
  font-size: 13px !important;
  line-height: 18px !important;
}
/* === End universal CRM deel 2 route hardening 2026-05-12 === */

/* === Universal CRM deel 2 final polish 2026-05-12 === */
body #view-products#view-products :is(.kpi-label, .product-stat-card span, .ops-kpis span) {
  font-weight: 400 !important;
}

body #view-voorraad#view-voorraad .ops-panel-head :is(.btn-secondary, .ev-btn, button),
body #view-academy#view-academy .aca-admin-btn,
body #view-academy#view-academy .aca-assignment-state,
body #view-academy#view-academy .aca-reader-actions > span {
  font-weight: 500 !important;
}
/* === End universal CRM deel 2 final polish 2026-05-12 === */

/* === Universal CRM deel 2 extended route polish 2026-05-12 === */
body #view-team-agenda#view-team-agenda :is(.tg-mm-day, .tg-week-day-head .daynum),
body #view-leads#view-leads .lead-workspace-tabs b,
body #view-installatie-tarieven#view-installatie-tarieven :is(.ops-panel-head span, .ops-rate-toolbar > span) {
  font-weight: 500 !important;
}

body #view-tickets#view-tickets .ticket-stats {
  align-items: center !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 4px !important;
  margin-bottom: 24px !important;
}

body #view-tickets#view-tickets .ticket-stat-card {
  align-items: center !important;
  background: transparent !important;
  border: 1px solid #e0e3e7 !important;
  border-radius: 20px !important;
  box-shadow: none !important;
  color: #5f6368 !important;
  display: inline-flex !important;
  flex-direction: row !important;
  font-family: var(--crm-font, "Google Sans", Roboto, "Segoe UI", system-ui, sans-serif) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  gap: 6px !important;
  line-height: 20px !important;
  min-height: 34px !important;
  padding: 6px 16px !important;
}

body #view-tickets#view-tickets .ticket-stat-card.active {
  background: #e8f0fe !important;
  border-color: #c5d8fb !important;
  color: #1a73e8 !important;
  font-weight: 600 !important;
}

body #view-tickets#view-tickets .ticket-stat-card strong {
  background: #1a73e8 !important;
  border-radius: 10px !important;
  color: #ffffff !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  line-height: 16px !important;
  min-width: 18px !important;
  padding: 1px 6px !important;
  text-align: center !important;
}

body #view-tickets#view-tickets .ticket-stat-card span {
  color: inherit !important;
  font-size: 14px !important;
  font-weight: inherit !important;
  line-height: 20px !important;
}

body #view-lead-sale-matching#view-lead-sale-matching h1 {
  font-size: 34px !important;
  font-weight: 500 !important;
  line-height: 40px !important;
  margin: 0 0 12px !important;
}

body #view-lead-sale-matching#view-lead-sale-matching .eyebrow {
  color: #80868b !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  line-height: 16px !important;
  margin: 0 0 6px !important;
  text-transform: uppercase !important;
}

body #view-lead-sale-matching#view-lead-sale-matching .lead-sale-kpis article strong,
body #view-bestellingen#view-bestellingen .bes-stats .bes-stat-value,
body :is(#view-energie-klanten#view-energie-klanten, #view-energy-finance#view-energy-finance, #view-energy-anomalies#view-energy-anomalies) .energy-kpi-card strong {
  color: #202124 !important;
  font-size: 32px !important;
  font-weight: 400 !important;
  line-height: 32px !important;
}

body #view-lead-sale-matching#view-lead-sale-matching .lead-sale-kpis article span,
body #view-bestellingen#view-bestellingen .bes-stats .bes-stat > span,
body :is(#view-energie-klanten#view-energie-klanten, #view-energy-finance#view-energy-finance, #view-energy-anomalies#view-energy-anomalies) .energy-kpi-card small {
  color: #5f6368 !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  line-height: 20px !important;
}

body #view-lead-sale-matching#view-lead-sale-matching .lead-sale-panel-head h2 {
  font-size: 18px !important;
  font-weight: 600 !important;
  line-height: 24px !important;
}

body #view-bestellingen#view-bestellingen .bes-toolbar .back-btn-primary {
  background: #1a73e8 !important;
  border-color: #1a73e8 !important;
  color: #ffffff !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  line-height: 20px !important;
}

body #view-bestellingen#view-bestellingen :is(.bes-more-filter-btn, .bes-more-filter-btn span:not(.material-symbols-rounded), .bes-filter-summary, .bes-coverage-strip span, .bes-coverage-strip strong, .bes-product-chip b, .bes-open-action) {
  font-weight: 500 !important;
}
/* === End universal CRM deel 2 extended route polish 2026-05-12 === */

/* === CRM vertical rhythm hard lock 2026-05-12 === */
body :is(
  #view-home,
  #view-team-agenda,
  #view-todo,
  #view-tickets,
  #view-leads,
  #view-bestellingen,
  #view-formhub,
  #view-werkvoorbereiding,
  #view-schouw,
  #view-lead-sale-matching,
  #view-energie-klanten,
  #view-energy-finance,
  #view-energy-anomalies,
  #view-crm,
  #view-products,
  #view-salesdock-mappings,
  #view-voorraad,
  #view-installatie-tarieven,
  #view-financiering,
  #view-facturen,
  #view-sales-commissions,
  #view-email-automations,
  #view-audit,
  #view-health-check,
  #view-role-perms,
  #view-users,
  #view-academy
) {
  --crm-rhythm-x: 24px;
  position: relative !important;
  padding-left: var(--crm-rhythm-x) !important;
  padding-right: var(--crm-rhythm-x) !important;
  padding-top: 0 !important;
}

body :is(
  #view-team-agenda,
  #view-todo,
  #view-tickets,
  #view-leads,
  #view-bestellingen,
  #view-formhub,
  #view-werkvoorbereiding,
  #view-schouw,
  #view-lead-sale-matching,
  #view-energie-klanten,
  #view-energy-finance,
  #view-energy-anomalies,
  #view-crm,
  #view-products,
  #view-salesdock-mappings,
  #view-voorraad,
  #view-installatie-tarieven,
  #view-financiering,
  #view-facturen,
  #view-sales-commissions,
  #view-email-automations,
  #view-audit,
  #view-health-check,
  #view-role-perms,
  #view-users,
  #view-academy
) :is(.page-back-bar, .back-bar) {
  align-items: flex-start !important;
  display: flex !important;
  height: 40px !important;
  justify-content: flex-end !important;
  left: auto !important;
  margin: 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
  pointer-events: none !important;
  position: absolute !important;
  right: 24px !important;
  top: 0 !important;
  width: auto !important;
  z-index: 8 !important;
}

body :is(
  #view-team-agenda,
  #view-todo,
  #view-tickets,
  #view-leads,
  #view-bestellingen,
  #view-formhub,
  #view-werkvoorbereiding,
  #view-schouw,
  #view-lead-sale-matching,
  #view-energie-klanten,
  #view-energy-finance,
  #view-energy-anomalies,
  #view-crm,
  #view-products,
  #view-salesdock-mappings,
  #view-voorraad,
  #view-installatie-tarieven,
  #view-financiering,
  #view-facturen,
  #view-sales-commissions,
  #view-email-automations,
  #view-audit,
  #view-health-check,
  #view-role-perms,
  #view-users,
  #view-academy
) :is(.page-back-btn, .back-btn) {
  pointer-events: auto !important;
}

body :is(
  #view-home,
  #view-team-agenda,
  #view-todo,
  #view-tickets,
  #view-leads,
  #view-bestellingen,
  #view-formhub,
  #view-werkvoorbereiding,
  #view-schouw,
  #view-lead-sale-matching,
  #view-energie-klanten,
  #view-energy-finance,
  #view-energy-anomalies,
  #view-crm,
  #view-products,
  #view-salesdock-mappings,
  #view-voorraad,
  #view-installatie-tarieven,
  #view-financiering,
  #view-facturen,
  #view-sales-commissions,
  #view-email-automations,
  #view-audit,
  #view-health-check,
  #view-role-perms,
  #view-users,
  #view-academy
) :is(.home-header, .page-header, .intro, .td-header, .ticket-header, .crm-intro, .page-head) {
  margin-top: 0 !important;
}

body :is(
  #view-team-agenda,
  #view-todo,
  #view-tickets,
  #view-leads,
  #view-bestellingen,
  #view-formhub,
  #view-werkvoorbereiding,
  #view-schouw,
  #view-lead-sale-matching,
  #view-energie-klanten,
  #view-energy-finance,
  #view-energy-anomalies,
  #view-crm,
  #view-products,
  #view-salesdock-mappings,
  #view-voorraad,
  #view-installatie-tarieven,
  #view-financiering,
  #view-facturen,
  #view-sales-commissions,
  #view-email-automations,
  #view-audit,
  #view-health-check,
  #view-role-perms,
  #view-users,
  #view-academy
) :is(.intro, .td-header, .ticket-header, .crm-intro, .page-head):first-of-type {
  padding-top: 0 !important;
}

@media (max-width: 768px) {
  body :is(
    #view-home,
    #view-team-agenda,
    #view-todo,
    #view-tickets,
    #view-leads,
    #view-bestellingen,
    #view-formhub,
    #view-werkvoorbereiding,
    #view-schouw,
    #view-lead-sale-matching,
    #view-energie-klanten,
    #view-energy-finance,
    #view-energy-anomalies,
    #view-crm,
    #view-products,
    #view-salesdock-mappings,
    #view-voorraad,
    #view-installatie-tarieven,
    #view-financiering,
    #view-facturen,
    #view-sales-commissions,
    #view-email-automations,
    #view-audit,
    #view-health-check,
    #view-role-perms,
    #view-users,
    #view-academy
  ) {
    --crm-rhythm-x: 14px;
  }

  body :is(
    #view-team-agenda,
    #view-todo,
    #view-tickets,
    #view-leads,
    #view-bestellingen,
    #view-formhub,
    #view-werkvoorbereiding,
    #view-schouw,
    #view-lead-sale-matching,
    #view-energie-klanten,
    #view-energy-finance,
    #view-energy-anomalies,
    #view-crm,
    #view-products,
    #view-salesdock-mappings,
    #view-voorraad,
    #view-installatie-tarieven,
    #view-financiering,
    #view-facturen,
    #view-sales-commissions,
    #view-email-automations,
    #view-audit,
    #view-health-check,
    #view-role-perms,
    #view-users,
    #view-academy
  ) :is(.page-back-bar, .back-bar) {
    right: 20px !important;
    top: -52px !important;
  }
}
/* === End CRM vertical rhythm hard lock 2026-05-12 === */

/* === CRM canonical design system pass 2026-05-13 === */
:root {
  --font-sans: "Google Sans", "Roboto", "Segoe UI", system-ui, sans-serif;
  --font-sans-enterprise: var(--font-sans);

  --color-primary: #1a73e8;
  --color-primary-light: #e8f0fe;
  --color-primary-dark: #1557b0;
  --color-danger: #d93025;
  --color-success: #1e8e3e;
  --color-warning: #f59e0b;
  --color-text-primary: #202124;
  --color-text-secondary: #5f6368;
  --color-text-tertiary: #80868b;
  --color-surface: #ffffff;
  --color-surface-sunken: #f8f9fa;
  --color-border: #e0e3e7;
  --color-border-strong: #c7ccd1;
  --color-status-success-bg: #e6f4ea;
  --color-status-success-fg: #137333;
  --color-status-warning-bg: #fef7e0;
  --color-status-warning-fg: #7b5800;
  --color-status-danger-bg: #fce8e6;
  --color-status-danger-fg: #c5221f;
  --color-status-info-bg: #e8f0fe;
  --color-status-info-fg: #1557b0;

  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;

  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-pill: 9999px;
  --r-pill: var(--radius-pill);

  --shadow-1: 0 1px 3px rgba(60, 64, 67, .10);
  --shadow-2: 0 4px 12px rgba(60, 64, 67, .14);
  --shadow-3: 0 18px 56px rgba(32, 33, 36, .22);
  --shadow-focus: 0 0 0 3px rgba(26, 115, 232, .18);

  --page-max: 1280px;
  --page-padding-x: 32px;
  --page-padding-top: 32px;
  --header-gap: 24px;

  --crm-font: var(--font-sans);
  --crm-primary: var(--color-primary);
  --crm-border: var(--color-border);
  --crm-text: var(--color-text-primary);
  --crm-page-max: var(--page-max);
  --crm-page-pad: var(--page-padding-x);
  --content-max-width: var(--page-max);
  --md-primary: var(--color-primary);
  --md-primary-container: var(--color-primary-light);
  --md-on-surface: var(--color-text-primary);
  --md-on-surface-variant: var(--color-text-secondary);
  --md-outline: var(--color-border);
  --md-outline-variant: var(--color-border);
  --md-surface: var(--color-surface);
  --md-surface-container: var(--color-surface-sunken);
}

@media (max-width: 767px) {
  :root { --page-padding-x: 24px; }
}

@media (min-width: 1536px) {
  :root { --page-padding-x: 48px; }
}

body :is(.crm-app,#app),
body :is(.crm-app,#app) :where(button, input, textarea, select, a, p, span, small, strong, b, em, h1, h2, h3, h4, h5, h6, label, div) {
  font-family: var(--font-sans) !important;
  font-variant-numeric: tabular-nums lining-nums;
}

body :is(.crm-app,#app) .material-symbols-rounded,
body :is(.crm-app,#app) .material-symbols-outlined {
  font-family: "Material Symbols Rounded" !important;
  font-variation-settings: "FILL" 0, "wght" 400, "GRAD" 0, "opsz" 20 !important;
  font-size: 20px !important;
  line-height: 1 !important;
}

body :is(.crm-app,#app) .main-content > .page {
  box-sizing: border-box !important;
  width: min(100%, var(--page-max)) !important;
  max-width: var(--page-max) !important;
  margin-inline: auto !important;
  padding: var(--page-padding-top) var(--page-padding-x) 96px !important;
}

body :is(
  #view-home, #view-team-agenda, #view-todo, #view-tickets,
  #view-leads, #view-bestellingen, #view-formhub, #view-rma-picker,
  #view-troubleshoot, #view-werkvoorbereiding, #view-schouw,
  #view-service, #view-oplever, #view-form-rma,
  #view-lead-sale-matching, #view-energie-klanten, #view-energy-finance,
  #view-energy-anomalies, #view-crm, #view-products,
  #view-salesdock-mappings, #view-voorraad, #view-installatie-tarieven,
  #view-financiering, #view-facturen, #view-sales-commissions,
  #view-email-automations, #view-audit, #view-health-check,
  #view-role-perms, #view-users, #view-academy
) {
  box-sizing: border-box !important;
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow-x: clip !important;
}

body :is(
  #view-team-agenda, #view-todo, #view-tickets,
  #view-leads, #view-bestellingen, #view-formhub, #view-rma-picker,
  #view-troubleshoot, #view-werkvoorbereiding, #view-schouw,
  #view-service, #view-oplever, #view-form-rma,
  #view-lead-sale-matching, #view-energie-klanten, #view-energy-finance,
  #view-energy-anomalies, #view-crm, #view-products,
  #view-salesdock-mappings, #view-voorraad, #view-installatie-tarieven,
  #view-financiering, #view-facturen, #view-sales-commissions,
  #view-email-automations, #view-audit, #view-health-check,
  #view-role-perms, #view-users, #view-academy
) :is(.page-back-bar, .back-bar) {
  position: static !important;
  inset: auto !important;
  display: flex !important;
  justify-content: flex-start !important;
  align-items: center !important;
  width: 100% !important;
  height: 32px !important;
  min-height: 32px !important;
  margin: 0 0 var(--header-gap) !important;
  padding: 0 !important;
  pointer-events: auto !important;
  z-index: auto !important;
}

body :is(.crm-app,#app) :is(.page-back-btn, .back-btn, .page-home-self-link) {
  appearance: none !important;
  background: transparent !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-pill) !important;
  color: var(--color-text-secondary) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: var(--space-2) !important;
  min-height: 32px !important;
  height: 32px !important;
  padding: 0 var(--space-4) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  line-height: 20px !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

body :is(.crm-app,#app) :is(.page-back-btn, .back-btn, .page-home-self-link):hover {
  background: var(--color-surface-sunken) !important;
  color: var(--color-primary-dark) !important;
}

body #view-home .home-intro .page-home-self-link {
  margin: 0 0 var(--header-gap) !important;
}

body :is(.crm-app,#app) :is(
  .home-intro, .intro, .crm-intro, .td-header, .crm-page-header,
  .page-header, .page-head, .lead-page-header, .customer-page-header,
  .formhub-header, .operations-header
) {
  display: block !important;
  min-height: 0 !important;
  margin: 0 0 32px !important;
  padding: 0 !important;
}

body :is(.crm-app,#app) :is(.page-eyebrow, .intro-label, .home-label, .picker-label, .eyebrow, .ea-eyebrow, .inventory-eyebrow, .energy-command-eyebrow) {
  color: var(--color-text-secondary) !important;
  display: block !important;
  font-family: var(--font-sans) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: .08em !important;
  line-height: 16px !important;
  margin: 0 0 6px !important;
  text-transform: uppercase !important;
}

body :is(.crm-app,#app) :is(.page-title, #homeGreeting, .intro h1, .home-intro h1, .crm-intro h1, .td-header h1, .td-header h2, .crm-page-header h1, .page-header h1, .page-head h1, .academy-title) {
  color: var(--color-text-primary) !important;
  font-family: var(--font-sans) !important;
  font-size: 28px !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 36px !important;
  margin: 0 0 12px !important;
  min-height: 0 !important;
}

@media (min-width: 1280px) {
  body :is(.crm-app,#app) :is(.page-title, #homeGreeting, .intro h1, .home-intro h1, .crm-intro h1, .td-header h1, .td-header h2, .crm-page-header h1, .page-header h1, .page-head h1, .academy-title) {
    font-size: 34px !important;
    line-height: 40px !important;
  }
}

body :is(.crm-app,#app) :is(.page-title, #homeGreeting, .intro h1, .home-intro h1, .crm-intro h1, .td-header h1, .td-header h2, .crm-page-header h1, .page-header h1, .page-head h1, .academy-title) :is(span, em, .accent) {
  color: inherit !important;
  font: inherit !important;
  letter-spacing: inherit !important;
}

body :is(.crm-app,#app) :is(.page-subtitle, .intro p, .home-intro p, .crm-intro p, .td-header-subtitle, .crm-page-header p, .page-header p, .page-head p) {
  color: var(--color-text-secondary) !important;
  font-family: var(--font-sans) !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 24px !important;
  margin: 0 !important;
  max-width: 720px !important;
}

body :is(.crm-app,#app) :is(.dashboard-stats, .td-kpi-grid, .td-kpis, .comm-kpi-grid, .invoice-kpi-grid, .crm-stats, .bes-stats, .ops-kpi-grid, .inventory-kpis, .energy-command-kpis, .product-compact-kpis) {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: var(--space-5) !important;
  align-items: stretch !important;
}

@media (max-width: 1100px) {
  body :is(.crm-app,#app) :is(.dashboard-stats, .td-kpi-grid, .td-kpis, .comm-kpi-grid, .invoice-kpi-grid, .crm-stats, .bes-stats, .ops-kpi-grid, .inventory-kpis, .energy-command-kpis, .product-compact-kpis) {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 640px) {
  body :is(.crm-app,#app) :is(.dashboard-stats, .td-kpi-grid, .td-kpis, .comm-kpi-grid, .invoice-kpi-grid, .crm-stats, .bes-stats, .ops-kpi-grid, .inventory-kpis, .energy-command-kpis, .product-compact-kpis) {
    grid-template-columns: 1fr !important;
  }
}

body :is(.crm-app,#app) :is(.dashboard-stat, .td-kpi, .td-kpi-card, .comm-kpi-card, .invoice-kpi-card, .crm-stat, .bes-stat, .ops-kpi, .inventory-kpis > div, .energy-command-kpis > div, .product-compact-kpis > div) {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-1) !important;
  box-sizing: border-box !important;
  min-height: 112px !important;
  padding: var(--space-5) !important;
}

body :is(.crm-app,#app) :is(.dashboard-stat strong, .td-kpi-val, .comm-kpi-card strong, .invoice-kpi-card strong, .crm-stat strong, .bes-stat-value, .ops-kpi strong, .inventory-kpis strong, .energy-command-kpis strong, .product-compact-kpis strong) {
  color: var(--color-text-primary) !important;
  font-size: 34px !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  line-height: 1 !important;
}

body :is(.crm-app,#app) :is(.dashboard-stat span, .td-kpi-lbl, .comm-kpi-label, .invoice-kpi-card span, .crm-stat span, .bes-stat-label, .ops-kpi span, .inventory-kpis span, .inventory-kpis small, .energy-command-kpis span, .product-compact-kpis span) {
  color: var(--color-text-secondary) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: .08em !important;
  line-height: 16px !important;
  margin-top: 4px !important;
  text-transform: uppercase !important;
}

body :is(.crm-app,#app) :is(.btn, .btn-primary, .btn-secondary, .btn--primary, .btn--secondary, .ev-btn, .ticket-primary-btn, .td-list-new-btn, .gv-empty-cta, .link-btn, .back-btn-primary, .ticket-create-submit, button[class*="primary"]) {
  border-radius: var(--radius-pill) !important;
  box-shadow: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: var(--space-2) !important;
  min-height: 40px !important;
  height: 40px !important;
  padding: 0 var(--space-5) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  line-height: 20px !important;
}

body :is(.crm-app,#app) :is(.btn-primary, .btn.btn-primary, .btn--primary, .ev-btn-primary, .ticket-primary-btn, .td-list-new-btn, .gv-empty-cta, .back-btn-primary, button[class*="primary"]:not(.page-back-btn):not(.back-btn)) {
  background: var(--color-primary) !important;
  border: 1px solid var(--color-primary) !important;
  color: #fff !important;
}

body :is(.crm-app,#app) :is(.btn-secondary, .btn.btn-secondary, .btn--secondary, .ev-btn-secondary, .td-btn-secondary, .link-btn) {
  background: transparent !important;
  border: 1px solid var(--color-border-strong) !important;
  color: var(--color-text-primary) !important;
}

body :is(.crm-app,#app) :is(.btn-danger, .btn--danger, .ev-btn-danger, button[class*="danger"]) {
  background: var(--color-danger) !important;
  border-color: var(--color-danger) !important;
  color: #fff !important;
}

body :is(.crm-app,#app) :is(.page-tabs, .lead-tabs, .client-picker-tabs, .product-page-tabs, .comm-tabs, .crm-type-tabs, .klanten-hub-tabs) {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: var(--space-2) !important;
  margin: 0 0 var(--space-6) !important;
}

body :is(.crm-app,#app) :is(.page-tab, .lead-tab, .client-tab, .product-page-tab, .comm-tab, .crm-type-tab, .klanten-hub-tab, .ticket-stat-card) {
  background: transparent !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-pill) !important;
  color: var(--color-text-secondary) !important;
  min-height: 36px !important;
  padding: 0 var(--space-4) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  line-height: 20px !important;
}

body :is(.crm-app,#app) :is(.page-tab.active, .page-tab[aria-selected="true"], .lead-tab.active, .client-tab.active, .product-page-tab.active, .comm-tab.active, .crm-type-tab.active, .klanten-hub-tab.active, .ticket-stat-card.active) {
  background: var(--color-primary-light) !important;
  border-color: var(--color-primary-light) !important;
  color: var(--color-primary-dark) !important;
  font-weight: 600 !important;
}

body :is(.crm-app,#app) :is(.form-card, .card, .quick-action, .dashboard-section, .ops-panel, .lead-report-card, .crm-card, .customer-card, .invoice-panel, .comm-panel, .inventory-table-card, .inventory-detail-card, .energy-report-panel, .modal-card) {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-1) !important;
  box-sizing: border-box !important;
  padding: var(--space-5) !important;
}

body :is(.crm-app,#app) :is(input:not([type="checkbox"]):not([type="radio"]), select, textarea, .form-input, .form-select, .field-input) {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  color: var(--color-text-primary) !important;
  min-height: 40px !important;
  padding: 8px 12px !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 20px !important;
  outline: none !important;
}

body :is(.crm-app,#app) :is(input:not([type="checkbox"]):not([type="radio"]), select, textarea, .form-input, .form-select, .field-input):focus {
  border-color: var(--color-primary) !important;
  box-shadow: var(--shadow-focus) !important;
}

body :is(.crm-app,#app) :is(label, .field-label, .oplever-field label, .ev-field label) {
  color: var(--color-text-secondary) !important;
  display: block !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: .08em !important;
  line-height: 16px !important;
  margin: 0 0 6px !important;
  text-transform: uppercase !important;
}

body :is(.crm-app,#app) :is(.empty-state, .gv-empty, .client-search-empty, .dashboard-empty-recent) {
  align-items: center !important;
  display: flex !important;
  flex-direction: column !important;
  gap: var(--space-3) !important;
  justify-content: center !important;
  min-height: 220px !important;
  padding: var(--space-16) var(--space-10) !important;
  text-align: center !important;
}

body :is(.crm-app,#app) :is(.empty-state-icon, .gv-empty-icon) {
  align-items: center !important;
  background: var(--color-primary-light) !important;
  border-radius: var(--radius-pill) !important;
  color: var(--color-primary-dark) !important;
  display: flex !important;
  height: 48px !important;
  justify-content: center !important;
  width: 48px !important;
}

body :is(.crm-app,#app) :is(.empty-state-title, .gv-empty-title) {
  color: var(--color-text-primary) !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  line-height: 24px !important;
  margin: 0 !important;
}

body :is(.crm-app,#app) :is(.empty-state-desc, .gv-empty-desc) {
  color: var(--color-text-secondary) !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 22px !important;
  margin: 0 !important;
  max-width: 420px !important;
}

body :is(.crm-app,#app) :is(.crm-modal, .modal, .simple-modal, [role="dialog"]) :is(.modal-content, .modal-card, .simple-modal-card, .crm-modal-card) {
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-3) !important;
  max-width: 720px !important;
}

body :is(.crm-app,#app) :is(.badge, .status-pill, .chip, [class*="status"], [class*="badge"]) {
  border-radius: var(--radius-pill) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  line-height: 18px !important;
  min-height: 22px !important;
}

body :is(.crm-app,#app) :is(table, .crm-table, .invoice-table, .product-legacy-table) {
  border-collapse: collapse !important;
  width: 100% !important;
}

body :is(.crm-app,#app) :is(th, .table-head, .product-legacy-row-head) {
  color: var(--color-text-secondary) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: .08em !important;
  line-height: 16px !important;
  text-transform: uppercase !important;
}

body :is(.crm-app,#app) :is(td, th) {
  border-bottom: 1px solid var(--color-border) !important;
  height: 48px !important;
  padding-left: 14px !important;
  padding-right: 14px !important;
}

body :is(.crm-app,#app) :is(tr:hover, .crm-row:hover, .product-legacy-row:hover, .invoice-row:hover) {
  background: var(--color-surface-sunken) !important;
}

body :is(.crm-app,#app) .qt-fab {
  display: none !important;
}

@media (min-width: 769px) {
  body :is(.crm-app,#app) .sidebar:not(.is-collapsed) .nav-submenu,
  body :is(.crm-app,#app) .sidebar:not(.is-collapsed) .sidebar-group-links {
    display: block !important;
    height: auto !important;
    max-height: none !important;
    opacity: 1 !important;
    overflow: visible !important;
    visibility: visible !important;
  }
}

body :is(.crm-app,#app) :is(.sidebar-group-toggle.active, .sidebar-group-toggle.is-active, .sidebar-link.active, .nav-item.active, .sidebar-nav-group.is-active > .sidebar-group-toggle) {
  background: var(--color-primary-light) !important;
  color: var(--color-primary-dark) !important;
}

body :is(.crm-app,#app) :is(.sidebar-count, .topbar-badge) {
  background: var(--color-primary) !important;
  color: #fff !important;
}

body :is(.crm-app,#app) :is(.sidebar-user-avatar, .user-chip-avatar, .ticket-check-avatar) {
  background: var(--color-primary) !important;
  color: #fff !important;
}
/* === End CRM canonical design system pass 2026-05-13 === */
/* === CRM final symmetry hard lock 2026-05-13 === */
:root {
  --font-sans: "Google Sans", "Roboto", "Segoe UI", system-ui, sans-serif;
  --crm-font: var(--font-sans);
  --font-sans-enterprise: var(--font-sans);
  --color-primary: #1a73e8;
  --color-primary-light: #e8f0fe;
  --color-primary-dark: #1557b0;
  --color-success: #1e8e3e;
  --color-danger: #d93025;
  --color-warning: #f59e0b;
  --color-surface: #ffffff;
  --color-surface-sunken: #f8f9fa;
  --color-border: #e0e3e7;
  --color-border-strong: #c8ccd2;
  --color-text-primary: #202124;
  --color-text-secondary: #5f6368;
  --color-text-tertiary: #80868b;
  --ink: var(--color-text-primary);
  --ink-muted: var(--color-text-secondary);
  --crm-primary: var(--color-primary);
  --crm-primary-soft: var(--color-primary-light);
  --crm-border: var(--color-border);
  --crm-text: var(--color-text-primary);
  --crm-muted: var(--color-text-secondary);
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-pill: 9999px;
  --shadow-1: 0 1px 3px rgba(32,33,36,.08);
  --shadow-2: 0 6px 18px rgba(32,33,36,.10);
  --shadow-3: 0 18px 48px rgba(32,33,36,.18);
  --shadow-focus: 0 0 0 3px rgba(26,115,232,.18);
  --page-max: 1280px;
  --crm-page-max: var(--page-max);
  --content-max-width: var(--page-max);
  --page-padding-x: 32px;
  --crm-page-pad: var(--page-padding-x);
  --page-padding-top: 32px;
  --crm-page-top-pad: var(--page-padding-top);
  --header-gap: 24px;
}

html body,
html body :is(.crm-app,#app),
html body :is(.crm-app,#app) *:not(.material-symbols-rounded):not(.material-symbols-outlined):not(.material-icons) {
  font-family: var(--font-sans) !important;
  font-variant-numeric: tabular-nums lining-nums !important;
}

html body :is(.crm-app,#app) .main-content > .page {
  box-sizing: border-box !important;
  margin-inline: auto !important;
  max-width: var(--page-max) !important;
  padding: var(--page-padding-top) var(--page-padding-x) 96px !important;
  width: min(100%, var(--page-max)) !important;
}

html body :is(#view-home,#view-team-agenda,#view-todo,#view-tickets,#view-leads,#view-lead-sale-matching,#view-lead-duplicates,#view-bestellingen,#view-energie,#view-werkvoorbereiding,#view-formhub,#view-rma-picker,#view-troubleshoot,#view-products,#view-salesdock-mappings,#view-voorraad,#view-installatie-tarieven,#view-financiering,#view-facturen,#view-sales-commissions,#view-email-automations,#view-crm,#view-audit,#view-health-check,#view-role-perms,#view-users,#view-academy,#view-marketing) {
  box-sizing: border-box !important;
  margin: 0 !important;
  max-width: none !important;
  padding: 0 !important;
  width: 100% !important;
}

html body :is(#view-team-agenda,#view-todo,#view-tickets,#view-leads,#view-lead-sale-matching,#view-lead-duplicates,#view-bestellingen,#view-energie,#view-werkvoorbereiding,#view-formhub,#view-rma-picker,#view-troubleshoot,#view-products,#view-salesdock-mappings,#view-voorraad,#view-installatie-tarieven,#view-financiering,#view-facturen,#view-sales-commissions,#view-email-automations,#view-crm,#view-audit,#view-health-check,#view-role-perms,#view-users,#view-academy,#view-marketing) :is(.page-back-bar,.back-bar),
html body #view-home .home-intro .page-home-self-link {
  align-items: center !important;
  display: inline-flex !important;
  height: 32px !important;
  inset: auto !important;
  justify-content: flex-start !important;
  margin: 0 0 var(--header-gap) 0 !important;
  padding: 0 !important;
  position: static !important;
  transform: none !important;
}

html body :is(.crm-app,#app) :is(.page-back-btn,.back-btn,.page-home-self-link) {
  align-items: center !important;
  background: transparent !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-pill) !important;
  box-shadow: none !important;
  color: var(--color-text-secondary) !important;
  display: inline-flex !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  gap: 8px !important;
  height: 32px !important;
  line-height: 20px !important;
  padding: 0 14px !important;
  text-decoration: none !important;
}

html body :is(.crm-app,#app) :is(.home-intro,.intro,.picker-intro,.crm-intro,.td-header,.crm-page-header,.page-header,.page-head,.page-intro,.lead-page-header,.customer-page-header,.formhub-header,.operations-header,.product-page-header,.finance-header,.invoice-header,.commission-header) {
  margin: 0 0 32px 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
}

html body :is(#view-home,#view-team-agenda,#view-todo,#view-tickets,#view-leads,#view-lead-sale-matching,#view-lead-duplicates,#view-bestellingen,#view-energie,#view-werkvoorbereiding,#view-formhub,#view-rma-picker,#view-troubleshoot,#view-products,#view-salesdock-mappings,#view-voorraad,#view-installatie-tarieven,#view-financiering,#view-facturen,#view-sales-commissions,#view-email-automations,#view-crm,#view-audit,#view-health-check,#view-role-perms,#view-users,#view-academy,#view-marketing) :is(.page-eyebrow,.intro-label,.home-label,.picker-label,.eyebrow,.ea-eyebrow,.inventory-eyebrow,.energy-command-eyebrow,.formhub-eyebrow) {
  color: var(--color-text-tertiary) !important;
  display: block !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: .08em !important;
  line-height: 16px !important;
  margin: 0 0 6px 0 !important;
  text-transform: uppercase !important;
}

html body :is(#view-home,#view-team-agenda,#view-todo,#view-tickets,#view-leads,#view-lead-sale-matching,#view-lead-duplicates,#view-bestellingen,#view-energie,#view-werkvoorbereiding,#view-formhub,#view-rma-picker,#view-troubleshoot,#view-products,#view-salesdock-mappings,#view-voorraad,#view-installatie-tarieven,#view-financiering,#view-facturen,#view-sales-commissions,#view-email-automations,#view-crm,#view-audit,#view-health-check,#view-role-perms,#view-users,#view-academy,#view-marketing) :is(.home-intro,.intro,.picker-intro,.crm-intro,.td-header,.crm-page-header,.page-header,.page-head,.page-intro,.lead-page-header,.customer-page-header,.formhub-header,.operations-header,.product-page-header,.finance-header,.invoice-header,.commission-header) :is(h1,h2,.page-title),
html body :is(#view-home #homeGreeting,#view-todo .td-header h1,#view-todo .td-header h2,#view-rma-picker .picker-intro h1) {
  color: var(--color-text-primary) !important;
  font-size: 34px !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  line-height: 40px !important;
  margin: 0 0 12px 0 !important;
}

html body :is(#view-home,#view-team-agenda,#view-todo,#view-tickets,#view-leads,#view-lead-sale-matching,#view-lead-duplicates,#view-bestellingen,#view-energie,#view-werkvoorbereiding,#view-formhub,#view-rma-picker,#view-troubleshoot,#view-products,#view-salesdock-mappings,#view-voorraad,#view-installatie-tarieven,#view-financiering,#view-facturen,#view-sales-commissions,#view-email-automations,#view-crm,#view-audit,#view-health-check,#view-role-perms,#view-users,#view-academy,#view-marketing) :is(.home-intro,.intro,.picker-intro,.crm-intro,.td-header,.crm-page-header,.page-header,.page-head,.page-intro,.lead-page-header,.customer-page-header,.formhub-header,.operations-header,.product-page-header,.finance-header,.invoice-header,.commission-header) > p,
html body :is(#view-home .home-intro > p,#view-todo .td-header > p,#view-rma-picker .picker-intro > p) {
  color: var(--color-text-secondary) !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  line-height: 24px !important;
  margin: 0 !important;
  max-width: 720px !important;
}

html body :is(.crm-app,#app) :is(.ea-hero h2,.inventory-hero h2,.energy-command-center h2,.marketing-hero h2) {
  font-size: 24px !important;
  font-weight: 400 !important;
  line-height: 32px !important;
}

html body :is(.crm-app,#app) :is(.dashboard-stats,.td-kpi-grid,.comm-kpi-grid,.invoice-kpi-grid,.crm-stats,.bes-stats,.stats-grid,.kpi-grid) {
  display: grid !important;
  gap: 20px !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

html body :is(.crm-app,#app) :is(.dashboard-stat,.td-kpi,.comm-kpi,.invoice-kpi-card,.crm-stat,.bes-stat,.card,.form-card,.route-check-card,.ticket-stat-card,.brand-card,.product-card,.customer-card) {
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-1) !important;
  box-sizing: border-box !important;
}

html body :is(.crm-app,#app) :is(.btn,.btn-primary,.btn--primary,.ticket-primary-btn,.td-list-new-btn,.ev-btn-primary,.back-btn-primary,.primary-btn,.crm-primary-btn) {
  border-radius: var(--radius-pill) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  min-height: 40px !important;
}

html body :is(.crm-app,#app) :is(.btn-primary,.btn--primary,.ticket-primary-btn,.td-list-new-btn,.ev-btn-primary,.back-btn-primary,.primary-btn,.crm-primary-btn) {
  background: var(--color-primary) !important;
  border-color: var(--color-primary) !important;
  color: #fff !important;
}

html body :is(.crm-app,#app) :is(.page-tabs,.lead-tabs,.client-picker-tabs,.customer-tabs,.product-page-tabs,.comm-tabs,.crm-type-tabs) :is(button,a,.page-tab,.client-tab,.product-page-tab,.comm-tab,.crm-type-tab),
html body :is(.crm-app,#app) :is(.page-tab,.client-tab,.product-page-tab,.comm-tab,.crm-type-tab,.klanten-hub-tab) {
  align-items: center !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-pill) !important;
  color: var(--color-text-secondary) !important;
  display: inline-flex !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  height: 36px !important;
  padding: 0 16px !important;
}

html body :is(.crm-app,#app) :is(.page-tab.active,.page-tab[aria-selected="true"],.client-tab.active,.product-page-tab.active,.comm-tab.active,.crm-type-tab.active,.klanten-hub-tab.active,.lead-tabs .active) {
  background: var(--color-primary-light) !important;
  border-color: #c5d8fb !important;
  color: var(--color-primary-dark) !important;
  font-weight: 600 !important;
}

html body :is(.crm-app,#app) :is(input:not([type="checkbox"]):not([type="radio"]),select,textarea,.field-input,.search-input) {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: none !important;
  color: var(--color-text-primary) !important;
  font-size: 14px !important;
  min-height: 40px !important;
}

html body :is(.crm-app,#app) :is(input:not([type="checkbox"]):not([type="radio"]),select,textarea,.field-input,.search-input):focus {
  border-color: var(--color-primary) !important;
  box-shadow: var(--shadow-focus) !important;
  outline: none !important;
}

html body :is(.crm-app,#app) :is(.kpi-value,.td-kpi-val,.crm-stat-value,.bes-stat-value,.comm-kpi strong,.dashboard-stat strong,.invoice-kpi-value) {
  color: var(--color-text-primary) !important;
  font-size: 32px !important;
  font-weight: 400 !important;
  line-height: 1 !important;
}

html body :is(.crm-app,#app) :is(.kpi-label,.td-kpi-lbl,.crm-stat-label,.bes-stat-label,.comm-kpi-label,.dashboard-stat span,.invoice-kpi-label) {
  color: var(--color-text-secondary) !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  line-height: 18px !important;
}

html body :is(.crm-app,#app) :is(.qt-fab,button.qt-fab,#qtFab,.quick-ticket-fab,.floating-chat-bubble) {
  display: none !important;
  opacity: 0 !important;
  pointer-events: none !important;
  visibility: hidden !important;
}

@media (max-width: 1279px) {
  html body :is(#view-home,#view-team-agenda,#view-todo,#view-tickets,#view-leads,#view-lead-sale-matching,#view-lead-duplicates,#view-bestellingen,#view-energie,#view-werkvoorbereiding,#view-formhub,#view-rma-picker,#view-troubleshoot,#view-products,#view-salesdock-mappings,#view-voorraad,#view-installatie-tarieven,#view-financiering,#view-facturen,#view-sales-commissions,#view-email-automations,#view-crm,#view-audit,#view-health-check,#view-role-perms,#view-users,#view-academy,#view-marketing) :is(.home-intro,.intro,.picker-intro,.crm-intro,.td-header,.crm-page-header,.page-header,.page-head,.page-intro,.lead-page-header,.customer-page-header,.formhub-header,.operations-header,.product-page-header,.finance-header,.invoice-header,.commission-header) :is(h1,h2,.page-title),
  html body :is(#view-home #homeGreeting,#view-todo .td-header h1,#view-todo .td-header h2,#view-rma-picker .picker-intro h1) {
    font-size: 28px !important;
    line-height: 36px !important;
  }
}

@media (max-width: 900px) {
  html body :is(.crm-app,#app) .main-content > .page {
    padding: 24px 24px 72px !important;
  }
  html body :is(.crm-app,#app) :is(.dashboard-stats,.td-kpi-grid,.comm-kpi-grid,.invoice-kpi-grid,.crm-stats,.bes-stats,.stats-grid,.kpi-grid) {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
/* === End CRM final symmetry hard lock 2026-05-13 === */
/* === CRM final backbar geometry lock 2026-05-13 === */
html body #app :is(#view-team-agenda,#view-todo,#view-tickets,#view-leads,#view-lead-sale-matching,#view-lead-duplicates,#view-bestellingen,#view-energie,#view-energie-klanten,#view-werkvoorbereiding,#view-formhub,#view-rma-picker,#view-troubleshoot,#view-products,#view-salesdock-mappings,#view-voorraad,#view-installatie-tarieven,#view-financiering,#view-facturen,#view-sales-commissions,#view-email-automations,#view-crm,#view-audit,#view-health-check,#view-role-perms,#view-users,#view-academy,#view-marketing) > :is(.page-back-bar.back-bar,.page-back-bar,.back-bar) {
  align-items: center !important;
  box-sizing: border-box !important;
  display: flex !important;
  height: 32px !important;
  line-height: 32px !important;
  margin: 0 0 24px 0 !important;
  max-height: 32px !important;
  min-height: 32px !important;
  padding: 0 !important;
  position: static !important;
  transform: none !important;
}

html body #app :is(#view-team-agenda,#view-todo,#view-tickets,#view-leads,#view-lead-sale-matching,#view-lead-duplicates,#view-bestellingen,#view-energie,#view-energie-klanten,#view-werkvoorbereiding,#view-formhub,#view-rma-picker,#view-troubleshoot,#view-products,#view-salesdock-mappings,#view-voorraad,#view-installatie-tarieven,#view-financiering,#view-facturen,#view-sales-commissions,#view-email-automations,#view-crm,#view-audit,#view-health-check,#view-role-perms,#view-users,#view-academy,#view-marketing) > :is(.page-back-bar.back-bar,.page-back-bar,.back-bar) > :is(.page-back-btn.back-btn,.page-back-btn,.back-btn),
html body #app #view-home .home-intro > .page-home-self-link {
  align-items: center !important;
  box-sizing: border-box !important;
  display: inline-flex !important;
  height: 32px !important;
  line-height: 20px !important;
  margin: 0 0 24px 0 !important;
  max-height: 32px !important;
  min-height: 32px !important;
  padding: 0 14px !important;
  width: max-content !important;
}
/* === End CRM final backbar geometry lock 2026-05-13 === */
/* === CRM sidebar and RMA correction 2026-05-13 === */
html body #app > .sidebar .sidebar-nav,
html body .crm-app .sidebar .sidebar-nav {
  align-content: flex-start !important;
  align-items: stretch !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  height: auto !important;
  justify-content: flex-start !important;
  min-height: 0 !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  padding: 8px 10px 14px !important;
}

html body #app > .sidebar .sidebar-nav-group,
html body .crm-app .sidebar .sidebar-nav-group {
  flex: 0 0 auto !important;
  margin: 0 !important;
  min-height: 0 !important;
  width: 100% !important;
}

html body #app > .sidebar .sidebar-nav-group:not(.is-open) > .nav-submenu,
html body .crm-app .sidebar .sidebar-nav-group:not(.is-open) > .nav-submenu,
html body #app > .sidebar .sidebar-nav-group:not(.is-open) > .sidebar-group-links,
html body .crm-app .sidebar .sidebar-nav-group:not(.is-open) > .sidebar-group-links {
  display: none !important;
  height: 0 !important;
  margin: 0 !important;
  max-height: 0 !important;
  opacity: 0 !important;
  overflow: hidden !important;
  padding: 0 !important;
  visibility: hidden !important;
}

html body #app > .sidebar .sidebar-nav-group.is-open > .nav-submenu,
html body .crm-app .sidebar .sidebar-nav-group.is-open > .nav-submenu,
html body #app > .sidebar .sidebar-nav-group.is-open > .sidebar-group-links,
html body .crm-app .sidebar .sidebar-nav-group.is-open > .sidebar-group-links {
  display: grid !important;
  height: auto !important;
  margin: 2px 0 4px !important;
  max-height: none !important;
  opacity: 1 !important;
  overflow: hidden !important;
  padding: 0 !important;
  visibility: visible !important;
}

html body #app > .sidebar .nav-submenu-inner,
html body .crm-app .sidebar .nav-submenu-inner {
  height: auto !important;
  overflow: visible !important;
}

html body #app > .sidebar .sidebar-link,
html body .crm-app .sidebar .sidebar-link {
  transform: none !important;
}

html body #view-rma-picker .picker-intro h1 {
  max-width: 720px !important;
}

html body #view-rma-picker .brand-grid {
  display: grid !important;
  gap: 20px !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  margin: 0 !important;
}

html body #view-rma-picker .brand-card {
  align-items: stretch !important;
  background: var(--color-surface) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-1) !important;
  color: var(--color-text-primary) !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 16px !important;
  min-height: 220px !important;
  padding: 20px !important;
  text-align: left !important;
  transform: none !important;
}

html body #view-rma-picker .brand-card:hover {
  box-shadow: var(--shadow-2) !important;
  transform: none !important;
}

html body #view-rma-picker .brand-card-head {
  align-items: center !important;
  display: flex !important;
  gap: 12px !important;
  justify-content: space-between !important;
}

html body #view-rma-picker .brand-logo {
  align-items: center !important;
  background: var(--color-primary-light) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: none !important;
  color: var(--color-primary-dark) !important;
  display: inline-flex !important;
  flex: 0 0 40px !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  height: 40px !important;
  justify-content: center !important;
  width: 40px !important;
}

html body #view-rma-picker .brand-card-type {
  align-items: center !important;
  background: var(--color-surface-sunken) !important;
  border-radius: var(--radius-pill) !important;
  color: var(--color-text-secondary) !important;
  display: inline-flex !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  height: 22px !important;
  letter-spacing: .08em !important;
  line-height: 16px !important;
  padding: 0 10px !important;
  text-transform: uppercase !important;
}

html body #view-rma-picker .brand-card-name {
  color: var(--color-text-primary) !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  line-height: 24px !important;
  margin: 0 !important;
}

html body #view-rma-picker .brand-card-desc {
  color: var(--color-text-secondary) !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 22px !important;
  margin: 0 !important;
}

html body #view-rma-picker .brand-card-foot {
  align-items: center !important;
  color: var(--color-primary-dark) !important;
  display: flex !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  justify-content: space-between !important;
  line-height: 20px !important;
  margin-top: auto !important;
}

html body #view-rma-picker .brand-card-arrow {
  align-items: center !important;
  background: var(--color-primary-light) !important;
  border-radius: var(--radius-pill) !important;
  color: var(--color-primary-dark) !important;
  display: inline-flex !important;
  height: 28px !important;
  justify-content: center !important;
  width: 28px !important;
}

html body #view-rma-picker .page-footer {
  display: none !important;
}

@media (max-width: 1100px) {
  html body #view-rma-picker .brand-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 700px) {
  html body #view-rma-picker .brand-grid {
    grid-template-columns: 1fr !important;
  }
  html body #view-rma-picker .brand-card {
    min-height: 0 !important;
  }
}
/* === End CRM sidebar and RMA correction 2026-05-13 === */
/* === CRM sidebar has-open override 2026-05-13 === */
html body #app > .sidebar .sidebar-nav:has(.sidebar-nav-group.is-open),
html body .crm-app .sidebar .sidebar-nav:has(.sidebar-nav-group.is-open),
html body #app > .sidebar.open .sidebar-nav:has(.sidebar-nav-group.is-open),
html body .crm-app .sidebar.open .sidebar-nav:has(.sidebar-nav-group.is-open) {
  align-content: flex-start !important;
  align-items: stretch !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  justify-content: flex-start !important;
}
/* === End CRM sidebar has-open override 2026-05-13 === */
/* === CRM sidebar shell motion restore 2026-05-13 === */
html body #app > .sidebar,
html body .crm-app .sidebar {
  bottom: 0 !important;
  display: grid !important;
  grid-template-rows: 84px 44px minmax(0, 1fr) 76px !important;
  height: 100dvh !important;
  left: 0 !important;
  max-height: none !important;
  min-height: 100vh !important;
  overflow: hidden !important;
  position: fixed !important;
  top: 0 !important;
  transition: transform 250ms cubic-bezier(0.4, 0, 0.2, 1), width 250ms cubic-bezier(0.4, 0, 0.2, 1) !important;
  will-change: transform, width !important;
}

html body #app > .sidebar .sidebar-nav,
html body .crm-app .sidebar .sidebar-nav {
  align-content: flex-start !important;
  align-items: stretch !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  height: 100% !important;
  justify-content: flex-start !important;
  min-height: 0 !important;
  overflow-x: hidden !important;
  overflow-y: auto !important;
  padding: 8px 10px 14px !important;
  scroll-behavior: smooth !important;
}

html body #app > .sidebar .sidebar-foot,
html body .crm-app .sidebar .sidebar-foot {
  align-self: stretch !important;
  min-height: 76px !important;
}

html body #sidebarOverlay,
html body .sidebar-overlay {
  bottom: 0 !important;
  height: 100dvh !important;
  inset: 0 !important;
  min-height: 100vh !important;
  position: fixed !important;
  transition: opacity 250ms cubic-bezier(0.4, 0, 0.2, 1), visibility 250ms cubic-bezier(0.4, 0, 0.2, 1) !important;
}

html body #app > .sidebar .sidebar-nav-group:not(.is-open) > .nav-submenu,
html body .crm-app .sidebar .sidebar-nav-group:not(.is-open) > .nav-submenu,
html body #app > .sidebar .sidebar-nav-group:not(.is-open) > .sidebar-group-links,
html body .crm-app .sidebar .sidebar-nav-group:not(.is-open) > .sidebar-group-links {
  border-left: 1px solid var(--md-outline-variant, var(--color-border)) !important;
  display: grid !important;
  grid-template-rows: 0fr !important;
  height: auto !important;
  margin: 0 0 0 18px !important;
  max-height: none !important;
  opacity: 0 !important;
  overflow: hidden !important;
  padding: 0 0 0 8px !important;
  pointer-events: none !important;
  visibility: visible !important;
  transition: grid-template-rows 240ms cubic-bezier(0.2, 0, 0, 1), opacity 160ms ease-out, margin-block 240ms cubic-bezier(0.2, 0, 0, 1) !important;
}

html body #app > .sidebar .sidebar-nav-group.is-open > .nav-submenu,
html body .crm-app .sidebar .sidebar-nav-group.is-open > .nav-submenu,
html body #app > .sidebar .sidebar-nav-group.is-open > .sidebar-group-links,
html body .crm-app .sidebar .sidebar-nav-group.is-open > .sidebar-group-links {
  border-left: 1px solid var(--md-outline-variant, var(--color-border)) !important;
  display: grid !important;
  grid-template-rows: 1fr !important;
  height: auto !important;
  margin: 4px 0 8px 18px !important;
  max-height: none !important;
  opacity: 1 !important;
  overflow: hidden !important;
  padding: 0 0 0 8px !important;
  pointer-events: auto !important;
  visibility: visible !important;
  transition: grid-template-rows 240ms cubic-bezier(0.2, 0, 0, 1), opacity 160ms ease-out, margin-block 240ms cubic-bezier(0.2, 0, 0, 1) !important;
}

html body #app > .sidebar .nav-submenu > .nav-submenu-inner,
html body .crm-app .sidebar .nav-submenu > .nav-submenu-inner,
html body #app > .sidebar .sidebar-group-links > .nav-submenu-inner,
html body .crm-app .sidebar .sidebar-group-links > .nav-submenu-inner {
  display: grid !important;
  gap: 2px !important;
  min-height: 0 !important;
  overflow: hidden !important;
}

html body #app > .sidebar .nav-submenu .nav-item,
html body .crm-app .sidebar .nav-submenu .nav-item,
html body #app > .sidebar .sidebar-group-links .nav-item,
html body .crm-app .sidebar .sidebar-group-links .nav-item {
  opacity: 0 !important;
  transform: translateY(-4px) !important;
  transition: opacity 180ms ease-out, transform 180ms ease-out, background-color 150ms ease, color 150ms ease !important;
}

html body #app > .sidebar .sidebar-nav-group.is-open > .nav-submenu .nav-item,
html body .crm-app .sidebar .sidebar-nav-group.is-open > .nav-submenu .nav-item,
html body #app > .sidebar .sidebar-nav-group.is-open > .sidebar-group-links .nav-item,
html body .crm-app .sidebar .sidebar-nav-group.is-open > .sidebar-group-links .nav-item {
  opacity: 1 !important;
  transform: none !important;
  transition-delay: calc(var(--i, 0) * 30ms), calc(var(--i, 0) * 30ms), 0ms, 0ms !important;
}

@media (max-width: 767px) {
  html body #app > .sidebar,
  html body .crm-app .sidebar {
    max-width: calc(100vw - 16px) !important;
    transform: translateX(-106%) !important;
    width: min(88vw, 320px) !important;
  }

  html body #app > .sidebar.open,
  html body .crm-app .sidebar.open {
    transform: translateX(0) !important;
  }
}
/* === End CRM sidebar shell motion restore 2026-05-13 === */
/* === CRM tablet offcanvas sidebar restore 2026-05-13 === */
html body #sidebarOverlay,
html body .sidebar-overlay {
  bottom: 0 !important;
  height: 100dvh !important;
  inset: 0 !important;
  min-height: 100vh !important;
  opacity: 0 !important;
  pointer-events: none !important;
  position: fixed !important;
  transition: opacity 250ms cubic-bezier(0.4, 0, 0.2, 1), visibility 250ms cubic-bezier(0.4, 0, 0.2, 1) !important;
  visibility: hidden !important;
}

html body #sidebarOverlay.show,
html body .sidebar-overlay.show {
  opacity: 1 !important;
  pointer-events: auto !important;
  visibility: visible !important;
}

@media (max-width: 1024px) {
  html body #app > .mobile-topbar,
  html body .crm-app .mobile-topbar,
  html body .mobile-topbar {
    align-items: center !important;
    background: var(--color-surface, #fff) !important;
    border-bottom: 1px solid var(--color-border, #e0e3e7) !important;
    box-sizing: border-box !important;
    display: flex !important;
    height: 64px !important;
    justify-content: space-between !important;
    left: 0 !important;
    padding: 0 16px !important;
    position: fixed !important;
    right: 0 !important;
    top: 0 !important;
    width: 100vw !important;
    z-index: 1100 !important;
  }

  html body #app > .sidebar,
  html body .crm-app .sidebar,
  html body #app > .sidebar.is-collapsed,
  html body .crm-app .sidebar.is-collapsed {
    bottom: 0 !important;
    display: grid !important;
    grid-template-rows: 84px 44px minmax(0, 1fr) 76px !important;
    height: 100dvh !important;
    left: 0 !important;
    max-height: none !important;
    max-width: calc(100vw - 16px) !important;
    min-height: 100vh !important;
    overflow: hidden !important;
    position: fixed !important;
    top: 0 !important;
    transform: translateX(-106%) !important;
    transition: transform 250ms cubic-bezier(0.4, 0, 0.2, 1), width 250ms cubic-bezier(0.4, 0, 0.2, 1) !important;
    width: min(88vw, 320px) !important;
    will-change: transform !important;
    z-index: 1200 !important;
  }

  html body #app > .sidebar.open,
  html body .crm-app .sidebar.open,
  html body #app > .sidebar.open.is-collapsed,
  html body .crm-app .sidebar.open.is-collapsed {
    transform: translateX(0) !important;
  }

  html body #app > .sidebar.open .brand-text,
  html body .crm-app .sidebar.open .brand-text,
  html body #app > .sidebar.open .nav-label,
  html body .crm-app .sidebar.open .nav-label,
  html body #app > .sidebar.open .sidebar-user-body,
  html body .crm-app .sidebar.open .sidebar-user-body,
  html body #app > .sidebar.open .sidebar-link > span:not(.material-symbols-rounded),
  html body .crm-app .sidebar.open .sidebar-link > span:not(.material-symbols-rounded),
  html body #app > .sidebar.open .sidebar-group-toggle > span:not(.material-symbols-rounded:first-child),
  html body .crm-app .sidebar.open .sidebar-group-toggle > span:not(.material-symbols-rounded:first-child) {
    max-width: none !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    visibility: visible !important;
  }

  html body #app > .sidebar.open .sidebar-nav,
  html body .crm-app .sidebar.open .sidebar-nav {
    align-items: stretch !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
    height: 100% !important;
    justify-content: flex-start !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    padding: 8px 10px 14px !important;
  }

  html body #app > .sidebar.open .sidebar-group-toggle,
  html body .crm-app .sidebar.open .sidebar-group-toggle,
  html body #app > .sidebar.open .sidebar-link,
  html body .crm-app .sidebar.open .sidebar-link {
    display: grid !important;
    grid-template-columns: 28px minmax(0, 1fr) 22px !important;
    justify-content: stretch !important;
    width: 100% !important;
  }

  html body #app > .sidebar.open .sidebar-user,
  html body .crm-app .sidebar.open .sidebar-user {
    display: grid !important;
    grid-template-columns: 44px minmax(0, 1fr) 16px !important;
    width: 100% !important;
  }

  html body #app > .sidebar ~ .main-content,
  html body .crm-app .sidebar ~ .main-content,
  html body #app > .main-content,
  html body .crm-app .main-content,
  html body .main-content {
    margin-left: 0 !important;
    max-width: 100vw !important;
    padding-top: 64px !important;
    width: 100vw !important;
  }
}
/* === End CRM tablet offcanvas sidebar restore 2026-05-13 === */
/* === CRM open collapsed labels restore 2026-05-13 === */
@media (max-width: 1024px) {
  html body #app > .sidebar.open.is-collapsed .brand-text,
  html body .crm-app .sidebar.open.is-collapsed .brand-text,
  html body #app > .sidebar.open.is-collapsed .nav-label,
  html body .crm-app .sidebar.open.is-collapsed .nav-label,
  html body #app > .sidebar.open.is-collapsed .sidebar-user-body,
  html body .crm-app .sidebar.open.is-collapsed .sidebar-user-body {
    display: block !important;
    height: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    opacity: 1 !important;
    overflow: hidden !important;
    pointer-events: auto !important;
    visibility: visible !important;
    width: auto !important;
  }

  html body #app > .sidebar.open.is-collapsed .sidebar-link,
  html body .crm-app .sidebar.open.is-collapsed .sidebar-link,
  html body #app > .sidebar.open.is-collapsed .nav-item,
  html body .crm-app .sidebar.open.is-collapsed .nav-item {
    max-width: 100% !important;
    min-width: 0 !important;
    width: 100% !important;
  }

  html body #app > .sidebar.open.is-collapsed .sidebar-group-toggle,
  html body .crm-app .sidebar.open.is-collapsed .sidebar-group-toggle {
    grid-template-columns: 28px minmax(0, 1fr) 22px !important;
  }

  html body #app > .sidebar.open.is-collapsed .sidebar-link,
  html body .crm-app .sidebar.open.is-collapsed .sidebar-link {
    grid-template-columns: 28px minmax(0, 1fr) 22px !important;
  }

  html body #app > .sidebar.open .sidebar-nav-group.is-active > .nav-submenu,
  html body .crm-app .sidebar.open .sidebar-nav-group.is-active > .nav-submenu,
  html body #app > .sidebar.open .sidebar-nav-group.is-active > .sidebar-group-links,
  html body .crm-app .sidebar.open .sidebar-nav-group.is-active > .sidebar-group-links {
    border-left: 1px solid var(--md-outline-variant, var(--color-border)) !important;
    display: grid !important;
    grid-template-rows: 1fr !important;
    height: auto !important;
    margin: 4px 0 8px 18px !important;
    max-height: none !important;
    opacity: 1 !important;
    overflow: hidden !important;
    padding: 0 0 0 8px !important;
    pointer-events: auto !important;
    visibility: visible !important;
  }

  html body #app > .sidebar.open .sidebar-nav-group.is-active > .nav-submenu .nav-item,
  html body .crm-app .sidebar.open .sidebar-nav-group.is-active > .nav-submenu .nav-item,
  html body #app > .sidebar.open .sidebar-nav-group.is-active > .sidebar-group-links .nav-item,
  html body .crm-app .sidebar.open .sidebar-nav-group.is-active > .sidebar-group-links .nav-item {
    opacity: 1 !important;
    transform: none !important;
  }
}
/* === End CRM open collapsed labels restore 2026-05-13 === */
/* === CRM open drawer wins over collapsed rail 2026-05-13 === */
@media (max-width: 1024px) {
  html body #app > .sidebar.open,
  html body .crm-app .sidebar.open,
  html body #app > .sidebar.open.is-collapsed,
  html body .crm-app .sidebar.open.is-collapsed,
  html body #app > .sidebar.open[data-collapsed="true"],
  html body .crm-app .sidebar.open[data-collapsed="true"] {
    align-items: stretch !important;
    display: grid !important;
    grid-template-rows: 84px 44px minmax(0, 1fr) 76px !important;
    height: 100dvh !important;
    max-height: none !important;
    min-height: 100vh !important;
    overflow: hidden !important;
    transform: translateX(0) !important;
    width: min(88vw, 320px) !important;
  }

  html body #app > .sidebar.open .sidebar-brand,
  html body .crm-app .sidebar.open .sidebar-brand,
  html body #app > .sidebar.open.is-collapsed .sidebar-brand,
  html body .crm-app .sidebar.open.is-collapsed .sidebar-brand {
    display: grid !important;
    grid-template-columns: 56px minmax(0, 1fr) !important;
    justify-content: flex-start !important;
    padding: 16px !important;
  }

  html body #app > .sidebar.open :is(.brand-text, .nav-label, .sidebar-user-body),
  html body .crm-app .sidebar.open :is(.brand-text, .nav-label, .sidebar-user-body),
  html body #app > .sidebar.open[data-labels-hidden="true"] :is(.brand-text, .nav-label, .sidebar-user-body),
  html body .crm-app .sidebar.open[data-labels-hidden="true"] :is(.brand-text, .nav-label, .sidebar-user-body),
  html body #app > .sidebar.open[data-collapsed="true"] :is(.brand-text, .nav-label, .sidebar-user-body),
  html body .crm-app .sidebar.open[data-collapsed="true"] :is(.brand-text, .nav-label, .sidebar-user-body),
  html body #app > .sidebar.open.is-collapsed :is(.brand-text, .nav-label, .sidebar-user-body),
  html body .crm-app .sidebar.open.is-collapsed :is(.brand-text, .nav-label, .sidebar-user-body) {
    display: block !important;
    max-width: none !important;
    min-width: 0 !important;
    opacity: 1 !important;
    overflow: hidden !important;
    pointer-events: auto !important;
    text-overflow: ellipsis !important;
    visibility: visible !important;
    white-space: nowrap !important;
    width: auto !important;
  }

  html body #app > .sidebar.open .sidebar-group-toggle,
  html body .crm-app .sidebar.open .sidebar-group-toggle,
  html body #app > .sidebar.open.is-collapsed .sidebar-group-toggle,
  html body .crm-app .sidebar.open.is-collapsed .sidebar-group-toggle,
  html body #app > .sidebar.open .sidebar-link,
  html body .crm-app .sidebar.open .sidebar-link,
  html body #app > .sidebar.open.is-collapsed .sidebar-link,
  html body .crm-app .sidebar.open.is-collapsed .sidebar-link {
    align-items: center !important;
    display: grid !important;
    gap: 12px !important;
    grid-template-columns: 28px minmax(0, 1fr) 22px !important;
    justify-content: stretch !important;
    justify-items: stretch !important;
    margin-inline: 0 !important;
    max-width: 100% !important;
    min-height: 44px !important;
    min-width: 0 !important;
    padding: 0 14px !important;
    width: 100% !important;
  }

  html body #app > .sidebar.open .sidebar-link > .nav-label,
  html body .crm-app .sidebar.open .sidebar-link > .nav-label,
  html body #app > .sidebar.open .sidebar-group-toggle > .nav-label,
  html body .crm-app .sidebar.open .sidebar-group-toggle > .nav-label {
    display: block !important;
    justify-self: start !important;
  }

  html body #app > .sidebar.open .sidebar-group-chevron,
  html body .crm-app .sidebar.open .sidebar-group-chevron,
  html body #app > .sidebar.open .expand-chevron,
  html body .crm-app .sidebar.open .expand-chevron {
    display: inline-flex !important;
    justify-self: end !important;
    opacity: 1 !important;
    visibility: visible !important;
  }

  html body #app > .sidebar.open .sidebar-user,
  html body .crm-app .sidebar.open .sidebar-user,
  html body #app > .sidebar.open.is-collapsed .sidebar-user,
  html body .crm-app .sidebar.open.is-collapsed .sidebar-user {
    align-items: center !important;
    display: grid !important;
    grid-template-columns: 44px minmax(0, 1fr) 16px !important;
    min-width: 0 !important;
    padding: 12px 16px !important;
    width: 100% !important;
  }
}
/* === End CRM open drawer wins over collapsed rail 2026-05-13 === */
/* === CRM emergency full-cover sidebar drawer 2026-05-13 === */
@media (max-width: 1024px) {
  html body #app > .sidebar,
  html body .crm-app .sidebar,
  html body #app > .sidebar.is-collapsed,
  html body .crm-app .sidebar.is-collapsed,
  html body #app > .sidebar.open,
  html body .crm-app .sidebar.open,
  html body #app > .sidebar.open.is-collapsed,
  html body .crm-app .sidebar.open.is-collapsed {
    background: var(--color-surface, #ffffff) !important;
    border-right: 0 !important;
    box-sizing: border-box !important;
    height: 100dvh !important;
    max-height: none !important;
    max-width: 100vw !important;
    min-height: 100vh !important;
    width: 100vw !important;
  }

  html body #app > .sidebar.open,
  html body .crm-app .sidebar.open,
  html body #app > .sidebar.open.is-collapsed,
  html body .crm-app .sidebar.open.is-collapsed {
    left: 0 !important;
    transform: translateX(0) !important;
  }

  html body #app > .sidebar:not(.open),
  html body .crm-app .sidebar:not(.open) {
    transform: translateX(-104vw) !important;
  }

  html body #app > .sidebar .sidebar-nav,
  html body .crm-app .sidebar .sidebar-nav,
  html body #app > .sidebar.open .sidebar-nav,
  html body .crm-app .sidebar.open .sidebar-nav {
    padding: 12px 18px 20px !important;
  }

  html body #app > .sidebar .sidebar-brand,
  html body .crm-app .sidebar .sidebar-brand,
  html body #app > .sidebar.open .sidebar-brand,
  html body .crm-app .sidebar.open .sidebar-brand {
    grid-template-columns: 92px minmax(0, 1fr) !important;
    padding: 16px 24px !important;
  }

  html body #app > .sidebar .sidebar-group-toggle,
  html body .crm-app .sidebar .sidebar-group-toggle,
  html body #app > .sidebar.open .sidebar-group-toggle,
  html body .crm-app .sidebar.open .sidebar-group-toggle,
  html body #app > .sidebar.open.is-collapsed .sidebar-group-toggle,
  html body .crm-app .sidebar.open.is-collapsed .sidebar-group-toggle {
    column-gap: 16px !important;
    grid-template-columns: 64px minmax(0, 1fr) 40px !important;
    min-height: 56px !important;
    padding: 0 24px !important;
  }

  html body #app > .sidebar .sidebar-link,
  html body .crm-app .sidebar .sidebar-link,
  html body #app > .sidebar.open .sidebar-link,
  html body .crm-app .sidebar.open .sidebar-link,
  html body #app > .sidebar.open.is-collapsed .sidebar-link,
  html body .crm-app .sidebar.open.is-collapsed .sidebar-link {
    column-gap: 16px !important;
    grid-template-columns: 64px minmax(0, 1fr) 40px !important;
    min-height: 48px !important;
    padding: 0 24px !important;
  }

  html body #app > .sidebar .sidebar-group-toggle > .material-symbols-rounded:first-child,
  html body .crm-app .sidebar .sidebar-group-toggle > .material-symbols-rounded:first-child,
  html body #app > .sidebar .sidebar-link > .material-symbols-rounded:first-child,
  html body .crm-app .sidebar .sidebar-link > .material-symbols-rounded:first-child {
    justify-self: center !important;
  }

  html body #app > .sidebar.open :is(.nav-label, .brand-text, .sidebar-user-body),
  html body .crm-app .sidebar.open :is(.nav-label, .brand-text, .sidebar-user-body),
  html body #app > .sidebar.open.is-collapsed :is(.nav-label, .brand-text, .sidebar-user-body),
  html body .crm-app .sidebar.open.is-collapsed :is(.nav-label, .brand-text, .sidebar-user-body) {
    clip-path: none !important;
    display: block !important;
    max-width: none !important;
    opacity: 1 !important;
    overflow: visible !important;
    text-overflow: clip !important;
    visibility: visible !important;
    white-space: nowrap !important;
  }

  html body #app > .sidebar.open .sidebar-group-toggle > .nav-label,
  html body .crm-app .sidebar.open .sidebar-group-toggle > .nav-label,
  html body #app > .sidebar.open.is-collapsed .sidebar-group-toggle > .nav-label,
  html body .crm-app .sidebar.open.is-collapsed .sidebar-group-toggle > .nav-label {
    line-height: 24px !important;
    min-width: 0 !important;
    padding-left: 0 !important;
  }

  html body #app > .sidebar .sidebar-user,
  html body .crm-app .sidebar .sidebar-user,
  html body #app > .sidebar.open .sidebar-user,
  html body .crm-app .sidebar.open .sidebar-user {
    grid-template-columns: 56px minmax(0, 1fr) 32px !important;
    padding: 12px 32px !important;
  }
}
/* === End CRM emergency full-cover sidebar drawer 2026-05-13 === */
/* === CRM customers filterbar repair 2026-05-13 === */
html body #app #view-bestellingen .bes-filters,
html body .crm-app #view-bestellingen .bes-filters {
  align-items: center !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
  column-gap: 12px !important;
  display: grid !important;
  grid-template-columns: minmax(360px, 1.35fr) repeat(4, minmax(170px, 1fr)) !important;
  margin: 0 0 20px !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow: visible !important;
  padding: 0 !important;
  row-gap: 12px !important;
  width: 100% !important;
}

html body #app #view-bestellingen .bes-filters > *,
html body .crm-app #view-bestellingen .bes-filters > * {
  box-sizing: border-box !important;
  min-width: 0 !important;
}

html body #app #view-bestellingen .bes-filters .bes-search,
html body .crm-app #view-bestellingen .bes-filters .bes-search {
  align-items: center !important;
  align-self: stretch !important;
  background: var(--color-surface, #ffffff) !important;
  border: 1px solid var(--color-border, #e0e3e7) !important;
  border-radius: 12px !important;
  box-shadow: none !important;
  color: var(--color-text-secondary, #5f6368) !important;
  display: grid !important;
  flex: initial !important;
  gap: 10px !important;
  grid-template-columns: 20px minmax(0, 1fr) !important;
  height: 48px !important;
  line-height: 20px !important;
  margin: 0 !important;
  max-height: 48px !important;
  min-height: 48px !important;
  min-width: 0 !important;
  overflow: hidden !important;
  padding: 0 14px !important;
  width: 100% !important;
}

html body #app #view-bestellingen .bes-filters .bes-search:focus-within,
html body .crm-app #view-bestellingen .bes-filters .bes-search:focus-within {
  border-color: var(--color-primary, #1a73e8) !important;
  box-shadow: var(--shadow-focus, 0 0 0 3px rgba(26, 115, 232, 0.18)) !important;
}

html body #app #view-bestellingen .bes-filters .bes-search svg,
html body .crm-app #view-bestellingen .bes-filters .bes-search svg {
  color: var(--color-text-tertiary, #80868b) !important;
  display: block !important;
  flex: 0 0 20px !important;
  height: 20px !important;
  margin: 0 !important;
  pointer-events: none !important;
  width: 20px !important;
}

html body #app #view-bestellingen .bes-filters .bes-search input,
html body #app #view-bestellingen .bes-filters .bes-search input:focus,
html body #app #view-bestellingen .bes-filters .bes-search input:focus-visible,
html body .crm-app #view-bestellingen .bes-filters .bes-search input,
html body .crm-app #view-bestellingen .bes-filters .bes-search input:focus,
html body .crm-app #view-bestellingen .bes-filters .bes-search input:focus-visible {
  appearance: none !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  color: var(--color-text-primary, #202124) !important;
  display: block !important;
  font-family: var(--font-sans, var(--crm-font)) !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  height: 46px !important;
  line-height: 20px !important;
  margin: 0 !important;
  max-height: 46px !important;
  min-height: 0 !important;
  min-width: 0 !important;
  outline: 0 !important;
  overflow: hidden !important;
  padding: 0 !important;
  text-overflow: ellipsis !important;
  width: 100% !important;
}

html body #app #view-bestellingen .bes-filters .bes-search input::placeholder,
html body .crm-app #view-bestellingen .bes-filters .bes-search input::placeholder {
  color: var(--color-text-tertiary, #80868b) !important;
  opacity: 1 !important;
}

html body #app #view-bestellingen .bes-filters .form-select,
html body .crm-app #view-bestellingen .bes-filters .form-select {
  align-self: stretch !important;
  background-color: var(--color-surface, #ffffff) !important;
  border: 1px solid var(--color-border, #e0e3e7) !important;
  border-radius: 12px !important;
  box-shadow: none !important;
  color: var(--color-text-primary, #202124) !important;
  flex: initial !important;
  font-family: var(--font-sans, var(--crm-font)) !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  height: 48px !important;
  line-height: 20px !important;
  margin: 0 !important;
  max-width: none !important;
  min-height: 48px !important;
  min-width: 0 !important;
  padding: 0 40px 0 16px !important;
  width: 100% !important;
}

html body #app #view-bestellingen .bes-more-filter-btn,
html body .crm-app #view-bestellingen .bes-more-filter-btn,
html body #app #view-bestellingen .bes-filter-reset,
html body .crm-app #view-bestellingen .bes-filter-reset {
  align-items: center !important;
  align-self: center !important;
  background: var(--color-surface, #ffffff) !important;
  border: 1px solid var(--color-border, #e0e3e7) !important;
  border-radius: 999px !important;
  box-shadow: none !important;
  color: var(--color-text-primary, #202124) !important;
  display: inline-flex !important;
  font-family: var(--font-sans, var(--crm-font)) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  gap: 8px !important;
  grid-column: auto !important;
  height: 40px !important;
  justify-content: center !important;
  justify-self: start !important;
  line-height: 20px !important;
  margin: 0 !important;
  min-height: 40px !important;
  padding: 0 16px !important;
  position: static !important;
  white-space: nowrap !important;
  width: max-content !important;
  z-index: auto !important;
}

html body #app #view-bestellingen .bes-more-filter-btn,
html body .crm-app #view-bestellingen .bes-more-filter-btn {
  grid-column: 1 / 2 !important;
}

html body #app #view-bestellingen .bes-filter-summary,
html body .crm-app #view-bestellingen .bes-filter-summary {
  align-self: center !important;
  color: var(--color-text-secondary, #5f6368) !important;
  display: block !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  grid-column: 3 / -1 !important;
  justify-self: end !important;
  line-height: 20px !important;
  margin: 0 !important;
  min-width: 0 !important;
  position: static !important;
  text-align: right !important;
  white-space: nowrap !important;
}

@media (max-width: 1320px) {
  html body #app #view-bestellingen .bes-filters,
  html body .crm-app #view-bestellingen .bes-filters {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  html body #app #view-bestellingen .bes-filters .bes-search,
  html body .crm-app #view-bestellingen .bes-filters .bes-search {
    grid-column: 1 / -1 !important;
  }

  html body #app #view-bestellingen .bes-filter-summary,
  html body .crm-app #view-bestellingen .bes-filter-summary {
    grid-column: 1 / -1 !important;
    justify-self: start !important;
    text-align: left !important;
  }
}

@media (max-width: 720px) {
  html body #app #view-bestellingen .bes-filters,
  html body .crm-app #view-bestellingen .bes-filters {
    grid-template-columns: 1fr !important;
  }

  html body #app #view-bestellingen .bes-more-filter-btn,
  html body .crm-app #view-bestellingen .bes-more-filter-btn,
  html body #app #view-bestellingen .bes-filter-reset,
  html body .crm-app #view-bestellingen .bes-filter-reset {
    justify-self: stretch !important;
    width: 100% !important;
  }
}
/* === End CRM customers filterbar repair 2026-05-13 === */

/* === CRM Demo Center 2026-05-13 === */
.demo-center{display:flex;flex-direction:column;gap:24px}.demo-center,.demo-center *{box-sizing:border-box}.demo-center__header-actions,.demo-center__section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.demo-center__header-actions .material-symbols-rounded,.demo-center__reset-list .material-symbols-rounded{font-size:18px;line-height:1}.demo-center__danger-arm{background:var(--color-danger,#d93025)!important;border-color:var(--color-danger,#d93025)!important;color:#fff!important}.demo-center__status-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.demo-center__status-card,.demo-center__section,.demo-center__role-card,.demo-center__workflow-card,.demo-center__route-card,.demo-center__reset-panel{background:var(--color-surface,#fff);border:1px solid var(--color-border,#e0e3e7);border-radius:var(--radius-md,10px);box-shadow:var(--shadow-1,0 1px 3px rgba(0,0,0,.08))}.demo-center__status-card{min-height:116px;padding:20px}.demo-center__status-label,.demo-center__route-group{display:block;color:var(--color-text-secondary,#5f6368);font-size:12px;font-weight:600;letter-spacing:.08em;line-height:16px;text-transform:uppercase}.demo-center__status-card strong{display:block;margin-top:10px;color:var(--color-text-primary,#202124);font-size:28px;font-weight:500;line-height:34px;font-variant-numeric:tabular-nums lining-nums}.demo-center__status-card p,.demo-center__workflow-card p,.demo-center__steps p,.demo-center__reset-panel p{margin:6px 0 0;color:var(--color-text-secondary,#5f6368);font-size:14px;line-height:22px}.demo-center__section{padding:24px}.demo-center__section h2,.demo-center__workflow-card h3,.demo-center__role-card h3,.demo-center__reset-panel h2{margin:0;color:var(--color-text-primary,#202124);font-size:22px;font-weight:500;line-height:28px}.demo-center__role-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:18px}.demo-center__role-card{padding:18px}.demo-center__role-card h3{font-size:18px;line-height:24px}.demo-center__account-list{display:grid;gap:8px;margin-top:14px}.demo-center__account{display:grid;grid-template-columns:38px minmax(0,1fr);align-items:center;gap:12px;width:100%;min-height:54px;padding:8px 10px;color:var(--color-text-primary,#202124);text-align:left;background:transparent;border:1px solid transparent;border-radius:var(--radius-md,10px);cursor:pointer}.demo-center__account:hover,.demo-center__account.is-active{background:var(--color-primary-light,#e8f0fe);border-color:#c5d8fb;color:var(--color-primary-dark,#1557b0)}.demo-center__avatar{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;color:#fff;border-radius:999px;font-size:13px;font-weight:700;line-height:1}.demo-center__account strong,.demo-center__account em{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.demo-center__account strong{font-size:14px;font-weight:600}.demo-center__account em{margin-top:2px;color:var(--color-text-secondary,#5f6368);font-size:12px;font-style:normal;font-weight:500}.demo-center__workflow-layout{display:grid;grid-template-columns:320px minmax(0,1fr);gap:18px;margin-top:18px}.demo-center__workflow-tabs{display:grid;gap:8px;align-content:start}.demo-center__workflow-tabs button{display:grid;gap:2px;width:100%;padding:14px 16px;color:var(--color-text-primary,#202124);text-align:left;background:transparent;border:1px solid var(--color-border,#e0e3e7);border-radius:var(--radius-md,10px);cursor:pointer}.demo-center__workflow-tabs button.active,.demo-center__workflow-tabs button:hover{background:var(--color-primary-light,#e8f0fe);border-color:#c5d8fb}.demo-center__workflow-tabs span{font-size:14px;font-weight:600}.demo-center__workflow-tabs em{color:var(--color-text-secondary,#5f6368);font-size:12px;font-style:normal;font-weight:500}.demo-center__workflow-card{padding:22px}.demo-center__workflow-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.demo-center__steps{display:grid;gap:10px;margin:20px 0 0;padding:0;list-style:none}.demo-center__steps li{display:grid;grid-template-columns:34px minmax(0,1fr) auto;align-items:center;gap:14px;min-height:64px;padding:12px;border:1px solid var(--color-border,#e0e3e7);border-radius:var(--radius-md,10px)}.demo-center__step-index{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;color:var(--color-primary-dark,#1557b0);background:var(--color-primary-light,#e8f0fe);border-radius:999px;font-size:14px;font-weight:700}.demo-center__steps strong{display:block;color:var(--color-text-primary,#202124);font-size:15px;font-weight:600;line-height:20px}.demo-center__route-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:18px}.demo-center__route-card{display:grid;gap:8px;min-height:112px;padding:16px;text-align:left;cursor:pointer}.demo-center__route-card:hover{border-color:#c5d8fb;box-shadow:var(--shadow-2,0 4px 12px rgba(0,0,0,.10))}.demo-center__route-card strong{color:var(--color-text-primary,#202124);font-size:15px;font-weight:600;line-height:21px}.demo-center__route-status{align-self:end;width:max-content;max-width:100%;padding:3px 9px;border-radius:999px;font-size:12px;font-weight:600;line-height:16px}.demo-center__route-status.ok{color:#137333;background:#e6f4ea}.demo-center__route-status.blocked{color:#8a5b00;background:#fff7d6}.demo-center__reset-panel{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:20px;align-items:center;padding:24px}.demo-center__reset-list{display:grid;gap:8px;justify-items:start;padding:16px;background:#f8fafd;border:1px solid var(--color-border,#e0e3e7);border-radius:var(--radius-md,10px)}.demo-center__reset-list strong{color:var(--color-text-primary,#202124);font-size:34px;font-weight:500;line-height:40px;font-variant-numeric:tabular-nums lining-nums}.demo-center__reset-list span{color:var(--color-text-secondary,#5f6368);font-size:13px;font-weight:500}@media (max-width:1320px){.demo-center__status-grid,.demo-center__route-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.demo-center__role-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.demo-center__workflow-layout{grid-template-columns:1fr}}@media (max-width:760px){.demo-center__status-grid,.demo-center__role-grid,.demo-center__route-grid,.demo-center__reset-panel{grid-template-columns:1fr}.demo-center__workflow-card-head,.demo-center__steps li{grid-template-columns:1fr}.demo-center__steps li{justify-items:start}}
body.demo-center-runtime-active #app .main-content{display:none!important}body.demo-center-runtime-active #demo-center-runtime-root .main-content{display:block!important;visibility:visible!important;height:auto!important;overflow:visible!important}
/* === End CRM Demo Center 2026-05-13 === */

/* === CRM readable light-mode guard 2026-05-13 === */
html,body,:root,:root[data-theme=dark],html[data-theme=dark],html.dark{color-scheme:only light!important;--color-bg:#f8f9fa!important;--color-surface:#fff!important;--color-surface-base:#fff!important;--color-surface-raised:#fff!important;--color-surface-sunken:#f8fafc!important;--color-surface-overlay:#fff!important;--color-text-primary:#202124!important;--color-text-secondary:#5f6368!important;--color-text-tertiary:#80868b!important;--color-border:#e0e3e7!important;--color-border-default:#e0e3e7!important;--color-border-strong:#c7ccd1!important;--crm-bg:#f8f9fa!important;--crm-surface:#fff!important;--crm-card:#fff!important;--crm-text:#202124!important;--crm-muted:#5f6368!important;--crm-border:#e0e3e7!important;--md-surface:#fff!important;--md-surface-container:#fff!important;--md-surface-container-low:#f8f9fa!important;--md-surface-variant:#f8f9fa!important;--md-on-surface:#202124!important;--md-on-surface-variant:#5f6368!important;--md-outline:#e0e3e7!important;--md-outline-variant:#e0e3e7!important;--ink:#202124!important;--ink-muted:#5f6368!important;--ink-soft:#80868b!important;--surface:#fff!important;--bg:#f8f9fa!important;--line:#e0e3e7!important;--line-soft:#eef1f4!important}@media (prefers-color-scheme:dark){:root,html,body{color-scheme:only light!important;--color-bg:#f8f9fa!important;--color-surface:#fff!important;--color-surface-base:#fff!important;--color-surface-raised:#fff!important;--color-surface-sunken:#f8fafc!important;--color-surface-overlay:#fff!important;--color-text-primary:#202124!important;--color-text-secondary:#5f6368!important;--color-text-tertiary:#80868b!important;--color-border:#e0e3e7!important;--color-border-default:#e0e3e7!important;--color-border-strong:#c7ccd1!important}}html body,html body #app,html body .crm-app,html body .main-content,html body .view,html body [id^=view-]{background-color:#f8f9fa!important;color:#202124!important}html body :is(.sidebar,.mobile-topbar){background:#fff!important;color:#202124!important;border-color:#e0e3e7!important}html body .sidebar :is(.sidebar-brand,.sidebar-user,.sidebar-nav-group,.sidebar-section,.sidebar-group-toggle,.sidebar-link,.nav-item,a,button,span,strong,small,.material-symbols-rounded,.material-symbols-outlined){color:inherit!important;opacity:1!important}html body .sidebar :is(.sidebar-link,.nav-item,.sidebar-group-toggle){background:transparent!important;border-color:transparent!important}html body .sidebar :is(.sidebar-link.active,.nav-item.active,.sidebar-group-toggle.active,.sidebar-nav-group.is-active>.sidebar-group-toggle,.sidebar-nav-group.is-open>.sidebar-group-toggle){background:#e8f0fe!important;color:#3f5fb8!important}html body :is(.card,.crm-card,.dashboard-section,.dashboard-stat,.quick-action,.route-check-card,.td-kpi,.ticket-stat-card,.ticket-board-card,.form-card,.formhub-card,.gv-card,.lead-report-card,.lead-kpi-card,.lead-filter-stack,.lead-list,.lead-data-table-wrap,.crm-table-card,.ops-panel,.product-page-card,.invoice-table-card,.comm-section,.bes-list,.bes-customer-list,.bes-customer-row,.customer-card,.customer-detail-section,.customer-detail-grid section,.customer-detail-hero,.energy-card,.energy-panel,.inventory-card,.agenda-visibility,.tg-sidepanel,.tg-minimonth,.tg-main,.tg-week,.tg-month,.tg-day,.crm-modal-box,.modal-card){background:#fff!important;color:#202124!important;border-color:#e0e3e7!important}html body #view-leads .lead-data-table tr.lead-click-row,html body #view-leads .lead-data-table tbody,html body #view-leads .lead-data-table td,html body #view-leads .lead-data-table th{background:#fff!important;color:#202124!important;border-color:#e0e3e7!important;opacity:1!important}html body #view-leads .lead-data-table tr.lead-click-row :is(strong,span,small,em,div,p,td),html body #view-leads :is(.lead-list-summary,.lead-filterbar,.lead-filter-stack,.lead-report-card,.lead-mini-table,.lead-mini-row,.lead-mini-head) :is(strong,span,small,em,label,p,div){color:#202124!important;opacity:1!important}html body #view-leads :is(.lead-data-table th,.lead-data-table small,.lead-filterbar label,.lead-mini-head,.lead-mini-head span,.lead-list-summary span){color:#5f6368!important}html body #view-team-agenda :is(.agenda-visibility,.agenda-visibility-head,.agenda-visibility-body,.agenda-visibility-section,.agenda-vis-row,.agenda-vis-name,.agenda-vis-role,.agenda-vis-actions,.tg-minimonth,.tg-main,.tg-week,.tg-week-header,.tg-week-grid,.tg-week-col,.tg-week-cell,.tg-month,.tg-month-grid,.tg-month-cell,.tg-day,.tg-day-grid,.tg-day-col){background-color:#fff!important;color:#202124!important;border-color:#e0e3e7!important;opacity:1!important}html body #view-team-agenda :is(.agenda-visibility *,.tg-minimonth *,.tg-week *,.tg-month *,.tg-day *){opacity:1!important}html body #view-team-agenda :is(.tg-week-hour,.tg-week-day-head,.tg-week-day-head .dayname,.tg-mm-hd,.tg-mm-day.out,.agenda-vis-role,.agenda-visibility-section){color:#5f6368!important}html body #view-team-agenda :is(.tg-week-day-head.today,.tg-week-col.today,.tg-mm-day.today){background-color:#f8fbff!important;color:#1e8e3e!important}html body :is(input,select,textarea,.field-input,.lead-filter-control,.bes-search,.ta-search-row input,.route-check-form input,.route-check-form select){background:#fff!important;color:#202124!important;border-color:#e0e3e7!important}html body :is(input,textarea)::placeholder{color:#80868b!important;opacity:1!important}html body :is(.material-symbols-rounded,.material-symbols-outlined){color:currentColor;opacity:1}
/* === End CRM readable light-mode guard 2026-05-13 === */

.demo-center-toast{position:fixed;right:24px;bottom:24px;z-index:10000;display:grid;gap:4px;max-width:360px;padding:14px 16px;color:var(--color-text-primary,#202124);background:var(--color-surface,#fff);border:1px solid var(--color-border,#e0e3e7);border-radius:var(--radius-md,10px);box-shadow:var(--shadow-2,0 4px 12px rgba(0,0,0,.10))}.demo-center-toast strong{font-size:14px;font-weight:700}.demo-center-toast span{color:var(--color-text-secondary,#5f6368);font-size:13px;line-height:19px}

/* === CRM schouw visual alignment 2026-05-14 === */
html body .crm-app .schouw-app{--g:#1a73e8!important;--gd:#1557b0!important;--gl:#e8f0fe!important;--y:#f59e0b!important;--z:#202124!important;--gr:#5f6368!important;--bg:#f8f9fa!important;--r:#e0e3e7!important;--rs:#c5d8fb!important;--ob:#f8fafd!important;--or2:#c5d8fb!important;--ot:#1557b0!important;--wb:#fff7ed!important;--wr:#fed7aa!important;--wt:#9a3412!important;--eb:#fef2f2!important;--er:#fecaca!important;--et:#991b1b!important;--w:#fff!important;background:#f8f9fa!important;color:#202124!important;font-family:"Google Sans","Roboto","Segoe UI",system-ui,sans-serif!important;font-variant-numeric:tabular-nums lining-nums}
html body .crm-app .schouw-app :is(.hero,.chero){background:#fff!important;border-bottom:1px solid #e0e3e7!important;padding:28px 32px 36px!important}
html body .crm-app .schouw-app :is(.hero-in,.chero-in,.main,.chcon){max-width:1280px!important}
html body .crm-app .schouw-app :is(.hbadge,.chdg,.slbl){background:transparent!important;border:0!important;color:#80868b!important;font-size:12px!important;font-weight:600!important;letter-spacing:.08em!important;text-transform:uppercase!important}
html body .crm-app .schouw-app :is(.hero h1,.chero h1){color:#202124!important;font-size:34px!important;font-weight:500!important;line-height:40px!important;margin:0 0 8px!important}
html body .crm-app .schouw-app .hero h1 span{color:#1a73e8!important}
html body .crm-app .schouw-app :is(.hero p,.chero p){color:#5f6368!important;font-size:16px!important;line-height:24px!important}
html body .crm-app .schouw-app .card{margin-top:24px!important;border:1px solid #e0e3e7!important;border-radius:14px!important;box-shadow:0 1px 3px rgba(60,64,67,.12)!important}
html body .crm-app .schouw-app .progbar{background:#1a73e8!important}
html body .crm-app .schouw-app :is(.spill.cur,.btnp,.btnsave,.chsend,[data-mc] .mh){background:#1a73e8!important;color:#fff!important}
html body .crm-app .schouw-app :is(.btnp:hover,.btnsave:hover,.chsend:hover){background:#1557b0!important}
html body .crm-app .schouw-app .prodgrid{grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:16px!important}
html body .crm-app .schouw-app :is(.prodcard,.rb,input[type=text],input[type=tel],input[type=date],input[type=number],input[type=email],textarea,select,.gebdat-sel,.opslagrow,.sbox,.krcard,[data-mc],[data-mc] .msug,[data-mc] .mlist){border-color:#e0e3e7!important;border-radius:10px!important}
html body .crm-app .schouw-app :is(input[type=text],input[type=tel],input[type=date],input[type=number],input[type=email],textarea,select,.gebdat-sel){min-height:40px!important;background:#fff!important;color:#202124!important;font-size:14px!important}
html body .crm-app .schouw-app :is(input:focus,textarea:focus,select:focus,.gebdat-sel:focus){border-color:#1a73e8!important;box-shadow:0 0 0 3px rgba(26,115,232,.16)!important}
html body .crm-app .schouw-app :is(.prodcard.on,.rb.on,.spill.done){background:#e8f0fe!important;border-color:#c5d8fb!important;color:#1557b0!important}
html body .crm-app .schouw-app .prodcard .pico{color:#1a73e8!important;font-size:28px!important;line-height:1!important}
html body .crm-app .schouw-app .prodcard .pico .material-symbols-rounded{font-size:30px!important;line-height:1!important}
html body .crm-app .schouw-app :is(.prodcard .pnm,.ql,.sttl){color:#202124!important}
html body .crm-app .schouw-app :is(.prodcard .pchk,.chkbox,.dot){border-color:#cfd6df!important}
html body .crm-app .schouw-app :is(.prodcard.on .pchk,.chkbox.on,.rb.on .dot){background:#1a73e8!important;border-color:#1a73e8!important}
html body .crm-app .schouw-app .good{background:#eef4ff!important;border-color:#c5d8fb!important;color:#1557b0!important}
html body .crm-app .schouw-app .info{background:#fff7ed!important;border-color:#fed7aa!important;color:#9a3412!important}
html body .crm-app .schouw-app .warn{background:#fff7ed!important;border-color:#fdba74!important;color:#9a3412!important}
html body .crm-app .schouw-app .blok{background:#fef2f2!important;border-color:#fecaca!important;color:#991b1b!important}
html body .crm-app .schouw-app .er{display:flex!important;align-items:flex-start!important;gap:8px!important;margin-top:8px!important;padding:10px 12px!important;background:#fef2f2!important;border:1px solid #fecaca!important;border-radius:10px!important;color:#991b1b!important;font-size:13px!important;font-weight:600!important;line-height:18px!important}
html body .crm-app .schouw-app .er .material-symbols-rounded{font-size:18px!important;line-height:18px!important;color:#d93025!important;flex:0 0 auto!important}
html body .crm-app .schouw-app .split-toggle{display:inline-flex!important;align-items:center!important;justify-content:center!important;width:max-content!important;margin-top:10px!important;min-height:36px!important;padding:0 14px!important;background:#fff!important;color:#1557b0!important;border:1px solid #c5d8fb!important;border-radius:999px!important;font-size:13px!important;font-weight:600!important}
html body .crm-app .schouw-app .split-toggle:hover{background:#e8f0fe!important;color:#1557b0!important}
html body .crm-app .schouw-app .maand-split{margin-top:12px!important}
html body .crm-app .schouw-app .photo-preview{background:#fff!important;border-color:#e0e3e7!important;border-radius:14px!important;box-shadow:0 1px 3px rgba(60,64,67,.12)!important;height:320px!important;max-height:48vh!important;display:flex!important;align-items:center!important;justify-content:center!important;overflow:hidden!important}
html body .crm-app .schouw-app .photo-preview img{width:100%!important;height:100%!important;max-width:100%!important;max-height:100%!important;object-fit:contain!important;background:#fff!important}
@media(max-width:700px){html body .crm-app .schouw-app .photo-preview{height:240px!important;max-height:42vh!important}}
.form-row-pdf-btn{margin-top:8px;border:1px solid #c5d8fb;background:#e8f0fe;color:#1a73e8;border-radius:999px;padding:6px 12px;font:600 12px/16px var(--crm-font,"Google Sans","Roboto","Segoe UI",system-ui,sans-serif);cursor:pointer;white-space:nowrap}
.form-row-pdf-btn:hover{background:#d8e7fd;border-color:#a8c7fa;color:#1557b0}
html body .crm-app .schouw-app .fl{background:#fff!important;border:1px dashed #c5d8fb!important;color:#1557b0!important;border-radius:10px!important;min-height:44px!important;font-size:14px!important;font-weight:600!important}
@media(max-width:900px){html body .crm-app .schouw-app .prodgrid{grid-template-columns:1fr!important}html body .crm-app .schouw-app :is(.hero,.chero){padding:24px 20px 32px!important}}
/* === End CRM schouw visual alignment 2026-05-14 === */

/* === CRM lead register readable cards 2026-05-14 === */
html body[data-active-view="view-leads"] #view-leads .lead-data-table-wrap,
html body #view-leads .lead-data-table-wrap {
  overflow-x: hidden !important;
  overflow-y: visible !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-data-table,
html body[data-active-view="view-leads"] #view-leads .lead-data-table tbody,
html body #view-leads .lead-data-table,
html body #view-leads .lead-data-table tbody {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  height: auto !important;
  max-height: none !important;
  overflow: visible !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-data-table tbody,
html body #view-leads .lead-data-table tbody {
  display: grid !important;
  gap: 14px !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-data-table thead,
html body #view-leads .lead-data-table thead {
  display: none !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-data-table tr.lead-click-row,
html body #view-leads .lead-data-table tr.lead-click-row {
  display: grid !important;
  grid-template-columns: minmax(270px, 1.25fr) minmax(190px, .95fr) minmax(180px, .85fr) minmax(210px, .9fr) !important;
  grid-template-areas:
    "customer source product status"
    "customer ids date calls"
    "customer cost province calls" !important;
  align-items: start !important;
  gap: 12px 18px !important;
  width: 100% !important;
  min-height: 178px !important;
  height: auto !important;
  max-height: none !important;
  padding: 18px 20px !important;
  overflow: visible !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-data-table tr.lead-click-row > td,
html body #view-leads .lead-data-table tr.lead-click-row > td {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
  align-content: initial !important;
  gap: 3px !important;
  width: auto !important;
  min-width: 0 !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  padding: 0 !important;
  border-bottom: 0 !important;
  line-height: 20px !important;
  overflow: visible !important;
  white-space: normal !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-data-table tr.lead-click-row > td::before,
html body #view-leads .lead-data-table tr.lead-click-row > td::before {
  display: block !important;
  flex: 0 0 auto !important;
  margin: 0 0 2px !important;
  color: #80868b !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: .08em !important;
  line-height: 16px !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
  overflow: visible !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(1),
html body #view-leads .lead-data-table td:nth-child(1) { grid-area: source !important; }
html body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(2),
html body #view-leads .lead-data-table td:nth-child(2) { grid-area: ids !important; }
html body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(3),
html body #view-leads .lead-data-table td:nth-child(3) { grid-area: date !important; }
html body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(4),
html body #view-leads .lead-data-table td:nth-child(4) { grid-area: cost !important; }
html body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(5),
html body #view-leads .lead-data-table td:nth-child(5) { grid-area: product !important; }
html body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(6),
html body #view-leads .lead-data-table td:nth-child(6) { grid-area: province !important; }
html body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(7),
html body #view-leads .lead-data-table td:nth-child(7) {
  grid-area: customer !important;
  gap: 2px !important;
  padding-right: 18px !important;
  border-right: 1px solid #e0e3e7 !important;
}
html body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(8),
html body #view-leads .lead-data-table td:nth-child(8) { grid-area: calls !important; }
html body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(9),
html body #view-leads .lead-data-table td:nth-child(9) { grid-area: status !important; }

html body[data-active-view="view-leads"] #view-leads .lead-data-table tr.lead-click-row > td > *,
html body #view-leads .lead-data-table tr.lead-click-row > td > * {
  max-width: 100% !important;
  min-width: 0 !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-data-table tr.lead-click-row :is(strong, small, a, span, b),
html body #view-leads .lead-data-table tr.lead-click-row :is(strong, small, a, span, b) {
  line-height: 20px !important;
  max-height: none !important;
  opacity: 1 !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-customer-cell strong,
html body #view-leads .lead-customer-cell strong {
  display: block !important;
  font-size: 17px !important;
  font-weight: 700 !important;
  line-height: 22px !important;
  margin: 0 0 2px !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-customer-cell :is(a, small),
html body #view-leads .lead-customer-cell :is(a, small) {
  display: block !important;
  line-height: 20px !important;
  min-height: 20px !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

html body[data-active-view="view-leads"] #view-leads :is(.lead-source-chip, .lead-status-chip),
html body #view-leads :is(.lead-source-chip, .lead-status-chip) {
  display: inline-flex !important;
  align-items: center !important;
  width: max-content !important;
  max-width: 100% !important;
  min-height: 28px !important;
  height: auto !important;
  line-height: 18px !important;
  overflow: visible !important;
  white-space: normal !important;
}

html body[data-active-view="view-leads"] #view-leads .lead-call-cell strong,
html body #view-leads .lead-call-cell strong {
  display: block !important;
  font-size: 17px !important;
  font-weight: 600 !important;
  line-height: 22px !important;
}

@media (max-width: 1180px) {
  html body[data-active-view="view-leads"] #view-leads .lead-data-table tr.lead-click-row,
  html body #view-leads .lead-data-table tr.lead-click-row {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-template-areas:
      "customer customer"
      "source status"
      "product calls"
      "ids date"
      "cost province" !important;
    min-height: 0 !important;
  }

  html body[data-active-view="view-leads"] #view-leads .lead-data-table td:nth-child(7),
  html body #view-leads .lead-data-table td:nth-child(7) {
    padding-right: 0 !important;
    padding-bottom: 12px !important;
    border-right: 0 !important;
    border-bottom: 1px solid #e0e3e7 !important;
  }
}

@media (max-width: 760px) {
  html body[data-active-view="view-leads"] #view-leads .lead-data-table tr.lead-click-row,
  html body #view-leads .lead-data-table tr.lead-click-row {
    grid-template-columns: 1fr !important;
    grid-template-areas:
      "customer"
      "source"
      "status"
      "product"
      "ids"
      "date"
      "cost"
      "province"
      "calls" !important;
    padding: 16px !important;
  }
}
/* === End CRM lead register readable cards 2026-05-14 === */

/* === CRM customer dossier action buttons 2026-05-14 === */
html body #view-bestellingen .bes-customer-actions {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}

html body #view-bestellingen .bes-icon-action,
html body #view-bestellingen .bes-open-action {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  min-height: 40px !important;
  height: 40px !important;
  width: auto !important;
  min-width: 96px !important;
  max-width: 100% !important;
  padding: 0 16px !important;
  border: 1px solid #d7dce2 !important;
  border-radius: 999px !important;
  background: #fff !important;
  color: #202124 !important;
  box-shadow: none !important;
  font-family: var(--crm-font, "Google Sans", "Roboto", "Segoe UI", system-ui, sans-serif) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  line-height: 20px !important;
  letter-spacing: 0 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  overflow: visible !important;
}

html body #view-bestellingen .bes-open-action {
  min-width: 138px !important;
}

html body #view-bestellingen .bes-icon-action:hover,
html body #view-bestellingen .bes-icon-action:focus-visible,
html body #view-bestellingen .bes-open-action:hover,
html body #view-bestellingen .bes-open-action:focus-visible {
  border-color: #c5d8fb !important;
  background: #e8f0fe !important;
  color: #1557b0 !important;
}

html body #view-bestellingen .bes-icon-action svg {
  display: block !important;
  flex: 0 0 18px !important;
  width: 18px !important;
  height: 18px !important;
  color: #1a73e8 !important;
  stroke: currentColor !important;
  overflow: visible !important;
}

html body #view-bestellingen .bes-icon-action .material-symbols-rounded {
  width: 18px !important;
  height: 18px !important;
  color: #1a73e8 !important;
  font-size: 18px !important;
  line-height: 18px !important;
  overflow: visible !important;
}

html body #view-bestellingen .bes-icon-action .material-symbols-rounded::before {
  background-color: #1a73e8 !important;
}

html body #view-bestellingen .bes-icon-action .bes-action-label {
  display: inline !important;
}

html body #view-bestellingen .bes-icon-action[href^="tel:"]::after {
  content: "Bellen" !important;
}

html body #view-bestellingen .bes-icon-action[href^="mailto:"]::after {
  content: "Mailen" !important;
}

html body #view-bestellingen .bes-icon-action:has(.bes-action-label)::after {
  content: none !important;
}

@media (max-width: 980px) {
  html body #view-bestellingen .bes-customer-actions {
    justify-content: flex-start !important;
  }
}
/* === End CRM customer dossier action buttons 2026-05-14 === */

/* === CRM customer quick actions neutral icon fix 2026-05-14 === */
html body #view-bestellingen .bes-icon-action[href^="tel:"],
html body #view-bestellingen .bes-icon-action[href^="mailto:"] {
  background: #ffffff !important;
  color: #202124 !important;
}

html body #view-bestellingen .bes-icon-action[href^="tel:"] svg,
html body #view-bestellingen .bes-icon-action[href^="mailto:"] svg {
  display: block !important;
  width: 18px !important;
  height: 18px !important;
  flex: 0 0 18px !important;
  color: #1a73e8 !important;
  stroke: #1a73e8 !important;
  fill: none !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  filter: none !important;
}

html body #view-bestellingen .bes-icon-action[href^="tel:"] svg *,
html body #view-bestellingen .bes-icon-action[href^="mailto:"] svg * {
  stroke: #1a73e8 !important;
  fill: none !important;
}

html body #view-bestellingen .bes-icon-action[href^="tel:"]::before,
html body #view-bestellingen .bes-icon-action[href^="mailto:"]::before,
html body #view-bestellingen .bes-icon-action[href^="tel:"] svg::before,
html body #view-bestellingen .bes-icon-action[href^="mailto:"] svg::before {
  content: none !important;
  display: none !important;
}

html body #view-bestellingen .bes-icon-action[href^="tel:"] .bes-action-label,
html body #view-bestellingen .bes-icon-action[href^="mailto:"] .bes-action-label {
  color: #202124 !important;
}
/* === End CRM customer quick actions neutral icon fix 2026-05-14 === */

/* === CRM customer quick actions legacy bundle icon fix 2026-05-14 === */
html body #view-bestellingen .bes-icon-action[href^="tel:"] .material-symbols-rounded,
html body #view-bestellingen .bes-icon-action[href^="mailto:"] .material-symbols-rounded {
  display: none !important;
}

html body #view-bestellingen .bes-icon-action[href^="tel:"]::before,
html body #view-bestellingen .bes-icon-action[href^="mailto:"]::before {
  content: "" !important;
  display: block !important;
  width: 18px !important;
  height: 18px !important;
  flex: 0 0 18px !important;
  background: #1a73e8 !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  filter: none !important;
  -webkit-mask-position: center !important;
  -webkit-mask-repeat: no-repeat !important;
  -webkit-mask-size: 18px 18px !important;
  mask-position: center !important;
  mask-repeat: no-repeat !important;
  mask-size: 18px 18px !important;
}

html body #view-bestellingen .bes-icon-action[href^="tel:"]::before {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2 19.8 19.8 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6A19.8 19.8 0 0 1 2.12 4.18 2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72c.13.96.35 1.89.66 2.78a2 2 0 0 1-.45 2.11L8.09 9.84a16 16 0 0 0 6.07 6.07l1.23-1.23a2 2 0 0 1 2.11-.45c.89.31 1.82.53 2.78.66A2 2 0 0 1 22 16.92z'/%3E%3C/svg%3E") !important;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2 19.8 19.8 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6A19.8 19.8 0 0 1 2.12 4.18 2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72c.13.96.35 1.89.66 2.78a2 2 0 0 1-.45 2.11L8.09 9.84a16 16 0 0 0 6.07 6.07l1.23-1.23a2 2 0 0 1 2.11-.45c.89.31 1.82.53 2.78.66A2 2 0 0 1 22 16.92z'/%3E%3C/svg%3E") !important;
}

html body #view-bestellingen .bes-icon-action[href^="mailto:"]::before {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='20' height='16' x='2' y='4' rx='2'/%3E%3Cpath d='m22 7-8.97 5.7a2 2 0 0 1-2.06 0L2 7'/%3E%3C/svg%3E") !important;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='20' height='16' x='2' y='4' rx='2'/%3E%3Cpath d='m22 7-8.97 5.7a2 2 0 0 1-2.06 0L2 7'/%3E%3C/svg%3E") !important;
}

html body #view-bestellingen .bes-icon-action[href^="tel:"]:has(svg)::before,
html body #view-bestellingen .bes-icon-action[href^="mailto:"]:has(svg)::before {
  content: none !important;
  display: none !important;
}
/* === End CRM customer quick actions legacy bundle icon fix 2026-05-14 === */
