/* =============================================================================
   Brand color application — sidebar gradient on primary CTAs + active states
   Loaded last so it overrides all earlier component styles.
   ========================================================================== */

/* ── Primary buttons ──────────────────────────────────────── */
.btn-primary {
    --bs-btn-color: #fff;
    --bs-btn-bg: var(--brand-solid);
    --bs-btn-border-color: var(--brand-solid);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--brand-solid-deep);
    --bs-btn-hover-border-color: var(--brand-solid-deep);
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: var(--brand-solid-deep);
    --bs-btn-active-border-color: var(--brand-solid-deep);
    --bs-btn-focus-shadow-rgb: 10, 79, 122;
    background: var(--brand-gradient);
    background-size: 100% 100%;
    border-color: transparent;
    box-shadow: var(--brand-shadow);
    color: #fff;
}
.btn-primary:hover,
.btn-primary:focus-visible {
    background: var(--brand-gradient-hover);
    border-color: transparent;
    color: #fff;
    box-shadow: 0 8px 18px -8px rgba(6, 42, 71, .65);
}
.btn-primary:active,
.btn-primary.active,
.btn-primary:focus:not(:focus-visible) {
    background: var(--brand-gradient-active) !important;
    border-color: transparent !important;
    color: #fff !important;
}
.btn-primary:disabled,
.btn-primary.disabled {
    background: var(--brand-solid);
    border-color: var(--brand-solid);
    opacity: 0.55;
}

.btn-outline-primary {
    --bs-btn-color: var(--brand-solid);
    --bs-btn-border-color: var(--brand-solid);
    --bs-btn-hover-color: #fff;
    --bs-btn-hover-bg: var(--brand-solid);
    --bs-btn-hover-border-color: var(--brand-solid);
    --bs-btn-active-color: #fff;
    --bs-btn-active-bg: var(--brand-solid-deep);
    --bs-btn-active-border-color: var(--brand-solid-deep);
}
.btn-outline-primary:hover {
    background: var(--brand-gradient);
    border-color: transparent;
    color: #fff;
}
.btn-outline-primary.active,
.btn-outline-primary:active,
.btn-check:checked + .btn-outline-primary {
    background: var(--brand-gradient-active);
    border-color: transparent;
    color: #fff;
}

/* Existing gradient utility now resolves to the brand gradient */
.btn-gradient-primary {
    background: var(--brand-gradient);
    border: none;
    color: #fff;
    box-shadow: var(--brand-shadow);
}
.btn-gradient-primary:hover,
.btn-gradient-primary:focus-visible {
    background: var(--brand-gradient-hover);
    color: #fff;
}

/* ── Empty-state primary CTA (copl) ──────────────────────────
   Soft-tinted brand button. Lighter, modern feel — keeps the brand
   hue but drops the heavy gradient so it pairs nicely next to the
   neutral secondary action ("Browse clinics"). */
.copl-empty-action--primary {
    background: rgba(0, 105, 166, 0.10);
    border: 1px solid rgba(0, 105, 166, 0.22);
    color: #0a4f7a;
    box-shadow: 0 1px 2px rgba(0, 105, 166, 0.06);
}
.copl-empty-action--primary:hover {
    background: rgba(0, 105, 166, 0.18);
    border-color: rgba(0, 105, 166, 0.32);
    color: #0a4f7a;
    box-shadow: 0 4px 10px -6px rgba(0, 105, 166, 0.30);
}
.copl-empty-action--primary,
.copl-empty-action--primary > span,
.copl-empty-action--primary > i.bi { color: #0a4f7a; }
.copl-empty-action--primary:hover,
.copl-empty-action--primary:hover > span,
.copl-empty-action--primary:hover > i.bi { color: #0a4f7a; }

[data-theme="dark"] .copl-empty-action--primary {
    background: rgba(56, 189, 248, 0.14);
    border-color: rgba(56, 189, 248, 0.30);
    color: #7dd3fc;
}
[data-theme="dark"] .copl-empty-action--primary > span,
[data-theme="dark"] .copl-empty-action--primary > i.bi { color: #7dd3fc; }
[data-theme="dark"] .copl-empty-action--primary:hover {
    background: rgba(56, 189, 248, 0.22);
    border-color: rgba(56, 189, 248, 0.45);
    color: #bae6fd;
}

/* ── Bootstrap nav pills + tabs active state ─────────────── */
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
    background: var(--brand-gradient);
    color: #fff;
    box-shadow: var(--brand-shadow);
}
.nav-tabs .nav-link.active {
    color: var(--brand-solid);
    border-bottom-color: var(--brand-solid);
}

/* ── EHR / clinic-hub / dashboard custom segmented controls ─ */
.ehr-loc-toolbar__density-btn.is-active,
.ehr-pat-toolbar__chip.is-active,
.ehr-clinic-switcher.is-scoped .ehr-clinic-switcher__trigger,
.copl-tab.is-active,
.cdir-toolbar-btn.is-active,
.tab-pill.is-active,
[data-segment].is-active,
.btn-segment.is-active {
    background: var(--brand-soft);
    color: var(--brand-solid);
    border-color: var(--brand-soft-border);
    box-shadow: none;
}
.ehr-loc-toolbar__density-btn.is-active i,
.ehr-pat-toolbar__chip.is-active i,
.copl-tab.is-active i,
.cdir-toolbar-btn.is-active i,
.tab-pill.is-active i,
[data-segment].is-active i,
.btn-segment.is-active i { color: var(--brand-solid); }

.cdir-toolbar-btn.is-active .cdir-toolbar-btn-count,
.cdir-toolbar-btn[aria-expanded="true"] .cdir-toolbar-btn-count {
    background: var(--brand-soft-strong);
    color: var(--brand-solid);
}
.cdir-toolbar-btn.is-active:hover,
.cdir-toolbar-btn[aria-expanded="true"]:hover {
    background: var(--brand-soft-strong);
    border-color: var(--brand-soft-border);
    color: var(--brand-solid);
}

/* ── Filter dropdown trigger when an option is selected ──── */
.ehr-filter-dd.is-active .ehr-filter-dd__trigger {
    border-color: var(--brand-solid);
    box-shadow: 0 0 0 3px rgba(10, 79, 122, .15);
}
.ehr-filter-dd__count {
    background: var(--brand-soft-strong);
    color: var(--brand-solid);
}
.ehr-filter-dd__item.is-active {
    background: rgba(10, 79, 122, .08);
    color: var(--brand-solid);
}

/* ── Active-filter chip strip ────────────────────────────── */
.ehr-active-filter {
    border-color: rgba(10, 79, 122, .25);
}
.ehr-active-filter:hover {
    background: rgba(10, 79, 122, .06);
    border-color: var(--brand-solid);
}

/* ── Form focus rings ────────────────────────────────────── */
.form-control:focus,
.form-select:focus,
.form-check-input:focus,
.btn-check:focus + .btn,
.cdir-toolbar-search input:focus {
    border-color: var(--brand-solid);
    box-shadow: var(--focus-ring);
}
.form-check-input:checked {
    background-color: var(--brand-solid);
    border-color: var(--brand-solid);
}

/* ── Pagination active page ──────────────────────────────── */
.page-item.active .page-link,
.copl-page-info strong,
.ehr-pager .page-item.active .page-link {
    background: var(--brand-gradient);
    border-color: transparent;
    color: #fff;
}

/* ── Stat-card primary tone aligned with brand ──────────── */
.ehr-stat-card--primary .ehr-stat-card__icon {
    background: var(--brand-gradient);
    color: #fff;
}

/* ── Badges (soft-primary + solid) ───────────────────────── */
.badge.bg-primary {
    background: var(--brand-gradient) !important;
    color: #fff;
}
.badge-soft-primary {
    background: rgba(10, 79, 122, .12);
    color: var(--brand-solid);
}

/* ── Links ───────────────────────────────────────────────── */
a:not(.btn):not(.nav-link):not(.dropdown-item) { color: var(--brand-solid); }
a:not(.btn):not(.nav-link):not(.dropdown-item):hover { color: var(--brand-solid-deep); }

/* ── cdir filter panel (collapsible, slide-out below toolbar) ─ */
.cdir-filter-panel {
    margin-top: .65rem;
    padding: 1rem 1.1rem;
    background: #fff;
    border: 1px solid var(--copl-border-strong, #e2e8f0);
    border-radius: 14px;
    box-shadow: 0 6px 20px -10px rgba(15, 23, 42, .08);
}
.cdir-filter-panel__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1rem 1.5rem;
}
.cdir-filter-panel__cell { display: flex; flex-direction: column; gap: .55rem; }
.cdir-filter-panel__label {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    font-size: .72rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--copl-sub, #64748b);
}
.cdir-filter-panel__label i { font-size: .85rem; color: var(--brand-solid); }
.cdir-filter-panel__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    background: var(--brand-gradient);
    color: #fff;
    border-radius: 9px;
    font-size: .65rem;
    font-weight: 700;
}
.cdir-filter-panel__options { display: flex; flex-wrap: wrap; gap: .4rem; align-items: center; }
.cdir-filter-panel__chip {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .35rem .8rem;
    min-height: 28px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid #e2e8f0;
    color: var(--copl-text, #1e293b);
    font-size: .76rem;
    font-weight: 500;
    line-height: 1;
    white-space: nowrap;
    text-decoration: none;
    transition: background .12s ease, border-color .12s ease, color .12s ease, box-shadow .12s ease;
}
.cdir-filter-panel__chip:hover {
    background: #f1f5ff;
    border-color: rgba(10, 79, 122, .35);
    color: var(--brand-solid);
}
.cdir-filter-panel__chip.is-active {
    background: var(--brand-solid);
    border-color: var(--brand-solid);
    color: #fff;
    font-weight: 600;
}
.cdir-filter-panel__chip.is-active:hover {
    background: var(--brand-solid-deep, #062a47);
    border-color: var(--brand-solid-deep, #062a47);
    color: #fff;
}
.cdir-filter-panel__chip-count {
    font-size: .68rem;
    font-weight: 600;
    padding: 0 .35rem;
    border-radius: 999px;
    background: rgba(15, 23, 42, .06);
    color: var(--copl-sub, #64748b);
}
.cdir-filter-panel__chip.is-active .cdir-filter-panel__chip-count {
    background: rgba(255, 255, 255, .22);
    color: #fff;
}
.cdir-filter-panel__more {
    align-self: center;
    font-size: .7rem;
    color: var(--copl-muted, #94a3b8);
    font-style: italic;
}
.cdir-filter-panel--rich { padding: 1.1rem 1.2rem; }
.cdir-filter-actions {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: .5rem;
    margin-top: 1.1rem;
    padding-top: .9rem;
    border-top: 1px dashed #e2e8f0;
}
.cdir-filter-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 36px;
    padding: 0 1.05rem;
    border-radius: 999px;
    font-size: .8rem;
    font-weight: 600;
    text-decoration: none;
    border: 1px solid transparent;
    cursor: pointer;
    transition: background .15s ease, border-color .15s ease, color .15s ease;
}
.cdir-filter-action--ghost {
    background: #fff;
    border-color: #e2e8f0;
    color: var(--copl-sub, #64748b);
}
.cdir-filter-action--ghost:hover {
    background: #f8fafc;
    color: var(--copl-text, #1e293b);
    border-color: rgba(15, 23, 42, .18);
}
.cdir-filter-action--primary {
    background: var(--brand-gradient);
    color: #fff;
    box-shadow: var(--brand-shadow);
    border: none;
}
.cdir-filter-action--primary:hover {
    background: var(--brand-gradient-hover);
    color: #fff;
}

/* ── Locations card grid ──────────────────────────────────── */
.loc-card {
    display: flex;
    flex-direction: column;
    gap: .8rem;
    height: 100%;
    padding: 1rem 1.05rem;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    text-decoration: none;
    color: inherit;
    transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}
.loc-card:hover {
    border-color: rgba(10, 79, 122, .25);
    box-shadow: 0 8px 22px -10px rgba(15, 23, 42, .12);
    transform: translateY(-1px);
    color: inherit;
}
.loc-card__head { display: flex; align-items: center; gap: .65rem; }
.loc-card__avatar {
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: rgba(10, 79, 122, .10);
    color: var(--brand-solid);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    flex-shrink: 0;
}
.loc-card__title { flex: 1 1 auto; min-width: 0; }
.loc-card__name {
    font-weight: 600;
    color: var(--copl-text, #1e293b);
    font-size: .88rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.loc-card__clinic {
    font-size: .72rem;
    color: var(--copl-sub, #64748b);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.loc-card__primary {
    color: #f59e0b;
    font-size: .9rem;
    flex-shrink: 0;
}
.loc-card__body { display: flex; flex-direction: column; gap: .55rem; flex: 1 1 auto; }
.loc-card__row {
    display: flex;
    align-items: center;
    gap: .4rem;
    font-size: .75rem;
    color: var(--copl-sub, #64748b);
}
.loc-card__row i { color: var(--brand-solid); font-size: .8rem; }
.loc-card__pills {
    display: flex;
    flex-wrap: wrap;
    gap: .3rem;
}
.loc-card__foot {
    display: flex;
    align-items: center;
    gap: .8rem;
    padding-top: .65rem;
    border-top: 1px dashed #e5e7eb;
    font-size: .75rem;
    color: var(--copl-text, #1e293b);
}
.loc-card__metric {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    font-weight: 600;
}
.loc-card__metric i { color: var(--brand-solid); font-size: .8rem; }
.loc-card__metric small { font-weight: 500; color: var(--copl-sub, #64748b); }
.loc-card__open {
    margin-left: auto;
    width: 26px;
    height: 26px;
    border-radius: 8px;
    background: rgba(10, 79, 122, .08);
    color: var(--brand-solid);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: .75rem;
    transition: background .12s ease, color .12s ease;
}
.loc-card:hover .loc-card__open {
    background: var(--brand-gradient);
    color: #fff;
}

/* ── Feedback dashboard 2.0 — analytics, NPS pulse, comment cards ── */
.fb-active-filters__matches {
    display: inline-flex;
    align-items: center;
    margin-left: .25rem;
    padding: .25rem .65rem;
    border-radius: 999px;
    font-size: .72rem;
    font-weight: 600;
    background: var(--d-accent-soft, rgba(10, 79, 122, .08));
    color: var(--d-accent, #0a4f7a);
    white-space: nowrap;
}

.fb-analytics-row { margin-bottom: 0; }
.fb-analytics-card { border-radius: 14px; overflow: hidden; }

.fb-analytics-header,
.fb-feed-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.25rem;
    background: linear-gradient(180deg, var(--d-surface, #fff) 0%, var(--d-surface-soft, rgba(15, 23, 42, .015)) 100%);
}
.fb-analytics-title,
.fb-feed-title {
    display: flex;
    align-items: center;
    gap: .75rem;
    min-width: 0;
}
.fb-analytics-title h6,
.fb-feed-title h6 { font-size: .9rem; line-height: 1.25; }
.fb-analytics-title small,
.fb-feed-title small { display: block; font-size: .72rem; line-height: 1.35; margin-top: 1px; }

.fb-feed-header--compact {
    padding: .45rem .85rem;
    background: var(--d-surface, #fff);
}
.fb-feed-header--compact .fb-feed-title { gap: .5rem; }
.fb-feed-header--compact .fb-feed-title h6 { font-size: .82rem; }
.fb-feed-header--compact .fb-feed-title > i {
    font-size: .95rem;
    color: var(--d-accent, #0a4f7a);
    line-height: 1;
}
.card:has(> .fb-feed-header--compact) .ehr-loc-table thead th,
.card:has(> .fb-feed-header--compact) .ehr-loc-table tbody td {
    padding: .55rem .9rem;
}

.fb-analytics-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 10px;
    background: linear-gradient(135deg, #fffbeb 0%, #fef3c7 100%);
    color: #b45309;
    font-size: 1rem;
    flex-shrink: 0;
    box-shadow: 0 1px 0 rgba(245, 158, 11, .14) inset, 0 1px 2px rgba(245, 158, 11, .06);
}
.fb-analytics-icon--success {
    background: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);
    color: #047857;
    box-shadow: 0 1px 0 rgba(16, 185, 129, .16) inset, 0 1px 2px rgba(16, 185, 129, .06);
}
.fb-analytics-icon--accent {
    background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%);
    color: var(--d-accent, #0a4f7a);
    box-shadow: 0 1px 0 rgba(59, 130, 246, .14) inset, 0 1px 2px rgba(10, 79, 122, .06);
}

.fb-analytics-pill {
    display: inline-flex;
    align-items: baseline;
    gap: .2rem;
    padding: .35rem .7rem;
    border-radius: 999px;
    font-size: 1rem;
    font-weight: 700;
    line-height: 1;
    border: 1px solid transparent;
    flex-shrink: 0;
}
.fb-analytics-pill i { font-size: .85rem; align-self: center; }
.fb-analytics-pill__sub {
    font-size: .65rem;
    font-weight: 600;
    opacity: .75;
    margin-left: 1px;
}
.fb-analytics-pill--warning { background: #fffbeb; color: #b45309; border-color: rgba(245, 158, 11, .25); }
.fb-analytics-pill--success { background: #ecfdf5; color: #047857; border-color: rgba(16, 185, 129, .25); }
.fb-analytics-pill--danger  { background: #fef2f2; color: #b91c1c; border-color: rgba(239, 68, 68, .25); }

.fb-rating-body, .fb-nps-body { padding: 1rem 1.25rem 1.1rem; }

/* Make .feedback-rating-row act as a clickable filter pill */
.feedback-rating-row {
    text-decoration: none;
    color: inherit;
    padding: .35rem .55rem;
    margin: -.05rem -.55rem;
    border-radius: 10px;
    border: 1px solid transparent;
    transition: background-color .15s ease, border-color .15s ease;
    cursor: pointer;
}
.feedback-rating-row:hover {
    background: var(--d-surface-soft, rgba(15, 23, 42, .035));
    border-color: var(--d-border, rgba(15, 23, 42, .06));
}
.feedback-rating-row.is-active {
    background: rgba(245, 158, 11, .08);
    border-color: rgba(245, 158, 11, .35);
}
.feedback-rating-row.is-active .feedback-rating-count { color: #b45309; }

.fb-nps-tier-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: .65rem;
}
.fb-nps-tier {
    display: flex;
    flex-direction: column;
    gap: .15rem;
    padding: .85rem .75rem;
    border-radius: 12px;
    border: 1px solid var(--d-border, rgba(15, 23, 42, .08));
    background: var(--d-surface, #fff);
    text-decoration: none;
    color: inherit;
    text-align: center;
    transition: transform .12s ease, box-shadow .15s ease, border-color .15s ease;
    position: relative;
    overflow: hidden;
}
.fb-nps-tier::before {
    content: "";
    position: absolute;
    inset: 0 0 auto 0;
    height: 3px;
    background: currentColor;
    opacity: .8;
}
.fb-nps-tier:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(15, 23, 42, .06);
    border-color: var(--d-accent-soft, rgba(10, 79, 122, .25));
}
.fb-nps-tier__count {
    font-size: 1.45rem;
    font-weight: 700;
    line-height: 1.1;
    color: var(--d-text);
    margin-top: .1rem;
}
.fb-nps-tier__label {
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .03em;
    text-transform: uppercase;
    color: var(--d-sub, #64748b);
}
.fb-nps-tier__sub { font-size: .68rem; color: var(--d-muted); font-weight: 500; }
.fb-nps-tier--success { color: #10b981; }
.fb-nps-tier--success.is-active { background: #ecfdf5; border-color: rgba(16, 185, 129, .35); box-shadow: 0 0 0 3px rgba(16, 185, 129, .08); }
.fb-nps-tier--warning { color: #f59e0b; }
.fb-nps-tier--warning.is-active { background: #fffbeb; border-color: rgba(245, 158, 11, .35); box-shadow: 0 0 0 3px rgba(245, 158, 11, .08); }
.fb-nps-tier--danger  { color: #ef4444; }
.fb-nps-tier--danger.is-active  { background: #fef2f2; border-color: rgba(239, 68, 68, .35); box-shadow: 0 0 0 3px rgba(239, 68, 68, .08); }

.fb-recommend-bar {
    margin-top: 1rem;
    padding: .75rem .85rem;
    border-radius: 12px;
    background: var(--d-surface-soft, rgba(15, 23, 42, .025));
    border: 1px solid var(--d-border, rgba(15, 23, 42, .06));
}
.fb-recommend-bar__head {
    display: flex;
    align-items: center;
    gap: .5rem;
    margin-bottom: .5rem;
    font-size: .78rem;
}
.fb-recommend-bar__icon {
    display: inline-flex;
    width: 22px; height: 22px;
    border-radius: 50%;
    background: rgba(16, 185, 129, .12);
    color: #047857;
    align-items: center;
    justify-content: center;
    font-size: .7rem;
}
.fb-recommend-bar__label { color: var(--d-sub, #64748b); font-weight: 600; }
.fb-recommend-bar__value { margin-left: auto; color: var(--d-text); font-weight: 700; }
.fb-recommend-bar__track { height: 6px; border-radius: 999px; background: rgba(15, 23, 42, .06); overflow: hidden; }
.fb-recommend-bar__fill {
    height: 100%;
    background: linear-gradient(90deg, #34d399, #10b981);
    border-radius: 999px;
    transition: width .35s ease;
}

/* Sits inline in the analytics row now — no margin-top override. */
.fb-analytics-row .fb-heatmap-card { margin-top: 0; }
.fb-heatmap-body { padding: 1rem 1.25rem 1.25rem; }
.fb-analytics-row .fb-heatmap-body { padding: 0.85rem 1rem 1rem; }
.fb-analytics-row .fb-heatmap-card .fb-heatmap-grid { padding-bottom: 0.25rem; }
.fb-heatmap-legend {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-size: .68rem;
    color: var(--d-sub, #64748b);
    flex-shrink: 0;
}
.fb-heatmap-legend__label { font-weight: 600; letter-spacing: .02em; }
.fb-heatmap-grid {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 3px 6px;
    align-items: stretch;
}
.fb-heatmap-weekdays {
    display: grid;
    grid-template-rows: 12px repeat(7, 18px);
    gap: 3px;
    font-size: .62rem;
    font-weight: 600;
    color: var(--d-muted);
    text-align: right;
    align-items: center;
}
.fb-heatmap-weekday { line-height: 1; }
.fb-heatmap-weeks {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    gap: 3px;
    align-items: stretch;
    min-width: 0;
}
.fb-heatmap-week {
    display: grid;
    grid-template-rows: 12px repeat(7, 18px);
    gap: 3px;
    min-width: 0;
}
.fb-heatmap-month-label {
    font-size: .62rem;
    font-weight: 600;
    color: var(--d-muted);
    line-height: 14px;
    height: 14px;
    white-space: nowrap;
    letter-spacing: .03em;
    text-transform: uppercase;
}
.fb-heatmap-cell {
    width: 100%;
    height: 100%;
    border-radius: 3px;
    background: var(--d-surface-soft, rgba(15, 23, 42, .05));
    border: 1px solid rgba(15, 23, 42, .04);
    transition: transform .12s ease, box-shadow .12s ease;
}
.fb-heatmap-cell:hover {
    transform: scale(1.18);
    box-shadow: 0 2px 6px rgba(15, 23, 42, .18);
    position: relative;
    z-index: 2;
}
.fb-heatmap-cell--l0 { background: rgba(15, 23, 42, .045); }
.fb-heatmap-cell--l1 { background: rgba(10, 79, 122, .22); border-color: rgba(10, 79, 122, .12); }
.fb-heatmap-cell--l2 { background: rgba(10, 79, 122, .42); border-color: rgba(10, 79, 122, .18); }
.fb-heatmap-cell--l3 { background: rgba(10, 79, 122, .65); border-color: rgba(10, 79, 122, .25); }
.fb-heatmap-cell--l4 { background: var(--d-accent, #0a4f7a); border-color: rgba(10, 79, 122, .45); }
.fb-heatmap-cell--future { opacity: .3; }
.fb-heatmap-cell--today {
    box-shadow: 0 0 0 2px var(--d-accent, #0a4f7a), 0 0 0 3px #fff;
    position: relative;
    z-index: 1;
}
.fb-heatmap-legend .fb-heatmap-cell,
.fb-heatmap-today-marker .fb-heatmap-cell { width: 11px; height: 11px; aspect-ratio: auto; border-radius: 2px; }
.fb-heatmap-today-marker .fb-heatmap-cell--today { box-shadow: 0 0 0 1.5px var(--d-accent, #0a4f7a), 0 0 0 2.5px #fff; }

.fb-heatmap-stats {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .5rem .85rem;
    margin-top: .9rem;
    padding-top: .8rem;
    border-top: 1px dashed var(--d-border);
}
.fb-heatmap-stat { display: flex; flex-direction: column; gap: .1rem; min-width: 0; }
.fb-heatmap-stat__value {
    font-size: .92rem;
    font-weight: 700;
    color: var(--d-text);
    letter-spacing: .005em;
    line-height: 1.15;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.fb-heatmap-stat__total { font-size: .68rem; font-weight: 500; color: var(--d-muted); margin-left: .15rem; }
.fb-heatmap-stat__label { font-size: .65rem; color: var(--d-muted); text-transform: uppercase; letter-spacing: .04em; }
@media (min-width: 1200px) {
    .fb-heatmap-stats { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}

.fb-heatmap-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .75rem;
    margin-top: .75rem;
    font-size: .62rem;
    color: var(--d-muted);
    flex-wrap: wrap;
}
.fb-heatmap-today-marker {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-weight: 600;
    letter-spacing: .03em;
}

.fb-feed-card { border-radius: 14px; overflow: hidden; }
.fb-feed-badge {
    display: inline-flex;
    align-items: center;
    gap: .3rem;
    padding: .3rem .65rem;
    border-radius: 999px;
    font-size: .7rem;
    font-weight: 600;
    background: var(--d-accent-soft, rgba(10, 79, 122, .08));
    color: var(--d-accent, #0a4f7a);
}
.fb-feed-badge i { font-size: .7rem; }

.fb-comment-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: .85rem;
    padding: 1.1rem 1.25rem 1.25rem;
}
@media (max-width: 1399.98px) { .fb-comment-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (max-width: 1199.98px) { .fb-comment-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 575.98px)  { .fb-comment-grid { grid-template-columns: 1fr; } }

.comment-card { transition: border-color .15s ease, box-shadow .15s ease, transform .12s ease; }
.comment-card:hover { transform: translateY(-1px); box-shadow: 0 6px 18px rgba(15, 23, 42, .06); }
.comment-card__avatar { position: relative; }
.comment-card__avatar-icon {
    position: absolute;
    bottom: -2px;
    right: -2px;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: #fff;
    color: #f59e0b;
    font-size: .55rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 0 0 1.5px #fff;
}
.comment-card--rating-5 .comment-card__avatar,
.comment-card--rating-4 .comment-card__avatar {
    background: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);
    color: #047857;
    border-color: rgba(16, 185, 129, .22);
}
.comment-card--rating-5 .comment-card__avatar-icon,
.comment-card--rating-4 .comment-card__avatar-icon { color: #10b981; }
.comment-card--rating-3 .comment-card__avatar {
    background: linear-gradient(135deg, #fffbeb 0%, #fef3c7 100%);
    color: #b45309;
    border-color: rgba(245, 158, 11, .22);
}
.comment-card--rating-2 .comment-card__avatar,
.comment-card--rating-1 .comment-card__avatar {
    background: linear-gradient(135deg, #fef2f2 0%, #fee2e2 100%);
    color: #b91c1c;
    border-color: rgba(239, 68, 68, .22);
}
.comment-card--rating-2 .comment-card__avatar-icon,
.comment-card--rating-1 .comment-card__avatar-icon { color: #ef4444; }

.comment-card__nps-score {
    display: inline-flex;
    align-items: center;
    margin-left: .35rem;
    padding: .1rem .45rem;
    border-radius: 999px;
    font-weight: 700;
    font-size: .65rem;
    background: var(--d-surface-soft, rgba(15, 23, 42, .04));
    color: var(--d-sub, #64748b);
    letter-spacing: .02em;
}
.comment-card--promoter  .comment-card__nps-score { background: rgba(16, 185, 129, .12); color: #047857; }
.comment-card--passive   .comment-card__nps-score { background: rgba(245, 158, 11, .14); color: #92400e; }
.comment-card--detractor .comment-card__nps-score { background: rgba(239, 68, 68, .12);  color: #b91c1c; }

.comment-card__status--passive { color: #92400e; }
.comment-card__status--passive .ehr-loc-card__status-dot { background: #f59e0b; box-shadow: 0 0 0 2px rgba(245, 158, 11, .18); }
.comment-card__status--neutral { color: var(--d-muted); }
.comment-card__status--neutral .ehr-loc-card__status-dot { background: var(--d-muted); }

.comment-card__meta {
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: .25rem .35rem;
    margin-top: .35rem;
    font-size: .7rem;
    color: var(--d-muted);
}
.comment-card__meta i { font-size: .75rem; opacity: .85; }
.comment-card__meta-dot {
    width: 3px; height: 3px;
    border-radius: 50%;
    background: var(--d-muted);
    opacity: .55;
}
.comment-card__recommend {
    display: inline-flex;
    align-items: center;
    gap: .25rem;
    padding: .1rem .45rem;
    border-radius: 999px;
    font-size: .62rem;
    font-weight: 600;
    background: rgba(16, 185, 129, .12);
    color: #047857;
    border: 1px solid rgba(16, 185, 129, .22);
    text-transform: uppercase;
    letter-spacing: .03em;
}

[data-theme="dark"] .fb-analytics-header,
[data-theme="dark"] .fb-feed-header {
    background: linear-gradient(180deg, var(--d-surface, #1a1d27) 0%, rgba(255, 255, 255, .015) 100%);
}
[data-theme="dark"] .fb-nps-tier { background: var(--d-surface, #1a1d27); border-color: rgba(255, 255, 255, .07); }
[data-theme="dark"] .fb-recommend-bar { background: rgba(255, 255, 255, .03); border-color: rgba(255, 255, 255, .06); }
[data-theme="dark"] .fb-recommend-bar__track { background: rgba(255, 255, 255, .08); }
[data-theme="dark"] .feedback-rating-row:hover { background: rgba(255, 255, 255, .04); border-color: rgba(255, 255, 255, .07); }
