/* =============================================================
   style.css  –  BTL Group Call Insights Portal
   Load tokens.css first. This file contains component styles.
   ============================================================= */

/* ── Icon sizing (replace inline width/height) ───────────────── */
.icon-sm { width: 12px; height: 12px; }
.icon-md { width: 16px; height: 16px; }
.icon-lg { width: 20px; height: 20px; }
.icon-xl { width: 24px; height: 24px; }

/* ── Co-mode toggle (Inbound/Outbound) – shared ─────────────── */
.co-mode-toggle {
    display: inline-flex;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    overflow: hidden;
}
.co-mode-btn {
    padding: .38rem .85rem;
    font-size: .82rem;
    font-weight: 500;
    border: none;
    background: var(--card-bg);
    color: var(--text-mid);
    cursor: pointer;
    border-right: 1px solid var(--border);
    transition: background .15s, color .15s;
}
.co-mode-btn:last-child { border-right: none; }
.co-mode-btn.active { background: var(--blue); color: var(--on-primary); }
.co-mode-btn:hover:not(.active) { background: rgba(0,149,200,.07); color: var(--blue); }

/* VIP Top 10 mode toggle (Inbound/Outbound/All) */
.vip-top10-mode-toggle {
    display: inline-flex;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    overflow: hidden;
}
.vip-top10-mode-toggle .co-mode-btn {
    padding: .38rem .85rem;
    font-size: .82rem;
    font-weight: 500;
    border: none;
    background: var(--card-bg);
    color: var(--text-mid);
    cursor: pointer;
    border-right: 1px solid var(--border);
    transition: background .15s, color .15s;
}
.vip-top10-mode-toggle .co-mode-btn:last-child { border-right: none; }
.vip-top10-mode-toggle .co-mode-btn.active { background: var(--blue); color: var(--on-primary); }
.vip-top10-mode-toggle .co-mode-btn[data-mode="outbound"].active { background: var(--indigo); color: var(--on-primary); }
.vip-top10-mode-toggle .co-mode-btn[data-mode="all"].active { background: var(--text-light); color: var(--on-primary); }
.vip-top10-mode-toggle .co-mode-btn:hover:not(.active) { background: rgba(0,149,200,.07); color: var(--blue); }

/* ── Multiselect (extensions, dashboard) ───────── */
.multiselect { position: relative; min-width: 220px; }
.multiselect-btn {
  width: 100%; text-align: left; display: flex; align-items: center; justify-content: space-between; gap: .5rem;
}
/* Remove filter-select background chevron — multiselect uses Lucide icon */
.multiselect-btn.filter-select {
  background-image: none !important;
  padding-right: 0.65rem;
}
.multiselect-menu {
  display: none; position: absolute; top: calc(100% + 6px); left: 0;
  width: min(380px, 70vw); background: var(--card-bg); border: 1px solid var(--border);
  border-radius: 10px; box-shadow: var(--card-shadow); padding: .5rem; z-index: 50;
}
.multiselect.open .multiselect-menu { display: block; }
.multiselect-options { max-height: 280px; overflow: auto; padding: .25rem; }
.multiselect-opt {
  display: flex; align-items: center; gap: .55rem; padding: .35rem .4rem; border-radius: 8px;
}
.multiselect-opt:hover { background: var(--grey-100); }

/* Footer row — Select all / Select none */
.multiselect-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start;
    gap: 0.5rem;
    padding: 0.4rem 0.25rem 0.1rem;
}

/* ── Sentiment card (AI transcript modal) ──────────────────── */
.sentiment-backdrop {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 9998;
    background: rgba(0, 0, 0, .45);
}
.sentiment-card {
    display: none;
    flex-direction: column;
    position: fixed;
    z-index: 9999;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: min(960px, 96vw);
    max-height: 88vh;
    background: var(--card-bg);
    color: var(--text-dark);
    border-radius: var(--radius);
    box-shadow: 0 8px 32px rgba(0, 0, 0, .22), 0 2px 8px rgba(0, 0, 0, .12);
    border: 1px solid var(--border);
    overflow: hidden;
    font-size: var(--font-size-md, .875rem);
}
.sentiment-card[style*="display: block"],
.sentiment-card[style*="display: flex"] {
    display: flex !important;
}

/* Header — neutral card bar (excl-modal style) */
.sentiment-card .sc-header {
    padding: 14px 18px;
    display: flex;
    align-items: center;
    gap: 12px;
    border-bottom: 1px solid var(--border);
    background: var(--card-bg);
}
.sentiment-card .sc-header-main {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
    flex: 1;
}
.sentiment-card .sc-header-titles { min-width: 0; }
.sentiment-card .sc-label {
    font-weight: var(--font-weight-bold, 700);
    font-size: var(--font-size-lg, .9rem);
    color: var(--text-dark);
}
.sentiment-card .sc-subtitle {
    font-size: var(--font-size-sm, .75rem);
    color: var(--text-light);
    margin-top: 2px;
}
.sentiment-card .sc-sentiment-pill {
    flex-shrink: 0;
    padding: 4px 10px;
    border-radius: 999px;
    font-size: var(--font-size-sm, .75rem);
    font-weight: var(--font-weight-semibold, 600);
    border: 1px solid var(--border);
    background: var(--page-bg);
    color: var(--text-dark);
}
.sentiment-card .sc-sentiment-pill[data-score="5"],
.sentiment-card .sc-sentiment-pill[data-score="10"],
.sentiment-card .sc-sentiment-pill[data-score="9"],
.sentiment-card .sc-sentiment-pill[data-score="8"],
.sentiment-card .sc-sentiment-pill[data-score="7"],
.sentiment-card .sc-sentiment-pill[data-score="6"] {
    background: var(--sc-bg-5);
    color: var(--sc-fg-5);
    border-color: transparent;
}
.sentiment-card .sc-sentiment-pill[data-score="4"] { background: var(--sc-bg-4); color: var(--sc-fg-4); border-color: transparent; }
.sentiment-card .sc-sentiment-pill[data-score="3"] { background: var(--sc-bg-3); color: var(--sc-fg-3); border-color: transparent; }
.sentiment-card .sc-sentiment-pill[data-score="2"] { background: var(--sc-bg-2); color: var(--sc-fg-2); border-color: transparent; }
.sentiment-card .sc-sentiment-pill[data-score="1"] { background: var(--sc-bg-1); color: var(--sc-fg-1); border-color: transparent; }
.sentiment-card .sc-header[data-score=""] { background: var(--card-bg); }

.sentiment-card .sc-close {
    margin-left: auto;
    background: none;
    border: none;
    cursor: pointer;
    color: var(--text-light);
    font-size: 1.35rem;
    line-height: 1;
    padding: 4px;
    border-radius: var(--radius-sm);
}
.sentiment-card .sc-close:hover { color: var(--text-dark); background: var(--page-bg); }

.sentiment-card .sc-body {
    padding: 0;
    flex: 1 1 auto;
    min-height: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.sentiment-card .sc-layout {
    display: flex;
    flex-direction: row;
    min-height: 0;
    flex: 1;
    overflow: hidden;
}

/* Split-panel layout — context sidebar + main content */
.sentiment-card .sc-context-panel {
    width: 260px;
    flex-shrink: 0;
    padding: 16px 14px;
    border-right: 1px solid var(--border);
    background: var(--page-bg);
    overflow-y: auto;
}
.sentiment-card .sc-kpi-strip {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-bottom: 14px;
}
.sentiment-card .sc-main-panel {
    flex: 1;
    min-width: 0;
    padding: 16px 18px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

/* KPI mini cards */
.sentiment-card .sc-kpi {
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 8px 10px;
    min-width: 0;
}
.sentiment-card .sc-kpi-value {
    font-weight: var(--font-weight-bold, 700);
    font-size: var(--font-size-base, .9375rem);
    color: var(--text-dark);
    line-height: 1.2;
}
.sentiment-card .sc-kpi-sub {
    font-size: var(--font-size-xs, .65rem);
    color: var(--text-light);
    margin-top: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.sentiment-card .sc-kpi-label {
    font-size: var(--font-size-xs, .65rem);
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--text-light);
    margin-top: 4px;
}
.sentiment-card .sc-kpi-direction.sc-dir-Inbound { color: var(--blue); }
.sentiment-card .sc-kpi-direction.sc-dir-Outbound { color: var(--indigo); }
.sentiment-card .sc-kpi-direction.sc-dir-Internal { color: var(--purple); }

.sentiment-card .sc-party-row {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    text-align: left;
    width: 100%;
    font-size: var(--font-size-sm, .75rem);
    color: var(--text-mid);
}
.sentiment-card .sc-party-line {
    width: 100%;
    line-height: 1.35;
}
.sentiment-card .sc-party-label {
    display: block;
    color: var(--text-light);
    font-weight: var(--font-weight-medium, 500);
    font-size: var(--font-size-xs, .65rem);
    text-transform: uppercase;
    letter-spacing: .03em;
    margin-bottom: 3px;
}
.sentiment-card .sc-party-value {
    display: block;
    font-weight: var(--font-weight-semibold, 600);
    color: var(--text-dark);
    font-size: var(--font-size-base, .9375rem);
}
.sentiment-card .sc-context-extras { margin-top: 10px; }

.sentiment-card .sc-section { margin-bottom: 14px; }
.sentiment-card .sc-section-title {
    font-weight: var(--font-weight-semibold, 600);
    font-size: var(--font-size-xs, .65rem);
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--text-light);
    margin-bottom: 8px;
}
.sentiment-card .sc-summary-card {
    background: var(--page-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 12px 14px;
    line-height: 1.55;
    color: var(--text-dark);
}
.sentiment-card .sc-summary { color: var(--text-dark); line-height: 1.5; }

/* Yeastar-style section headers in summary */
.sentiment-card .sc-summary p:has(+ ul) {
    font-weight: var(--font-weight-bold, 700);
    font-size: var(--font-size-md, .875rem);
    color: var(--sc-fg-default);
    margin: 14px 0 8px 0;
    padding: 8px 12px;
    background: var(--sc-bg-default);
    border-radius: var(--radius-sm);
    border-left: 4px solid var(--sc-fg-default);
}
.sentiment-card .sc-summary p:has(+ ul):first-of-type { margin-top: 0; }
.sentiment-card[data-platform="yeastar"] .sc-summary p:has(+ ul):nth-of-type(1)::before { content: "📄 "; opacity: .9; }
.sentiment-card[data-platform="yeastar"] .sc-summary p:has(+ ul):nth-of-type(2)::before { content: "🔑 "; opacity: .9; }
.sentiment-card[data-platform="yeastar"] .sc-summary p:has(+ ul):nth-of-type(3)::before { content: "✓ "; font-weight: 700; margin-right: 2px; }

.sentiment-card .sc-transcript-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 8px;
    flex-wrap: wrap;
}
.sentiment-card .sc-transcript-toolbar .sc-section-title { margin-bottom: 0; }
.sentiment-card .sc-transcript-search {
    flex: 0 1 220px;
    min-width: 140px;
    padding: 6px 10px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--card-bg);
    color: var(--text-dark);
    font-size: var(--font-size-sm, .75rem);
}
.sentiment-card .sc-transcript-search:focus {
    outline: none;
    border-color: var(--blue);
    box-shadow: 0 0 0 2px rgba(0, 149, 200, .15);
}

.sentiment-card .sc-transcript-wrap {
    max-height: min(420px, 45vh);
    overflow-y: auto;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--page-bg);
}

.sentiment-card .sc-toast {
    margin-bottom: 0;
    padding: 0;
    max-height: 0;
    overflow: hidden;
    border-radius: var(--radius-sm);
    font-size: var(--font-size-md, .875rem);
    font-weight: var(--font-weight-medium, 500);
    transition: max-height .25s, margin .25s, padding .25s;
}
.sentiment-card .sc-toast.show {
    margin: 0 0 12px 0;
    padding: 10px 14px;
    max-height: 120px;
}
.sentiment-card .sc-toast[data-variant="ok"] {
    background: rgba(22, 163, 74, .22);
    color: #065f46;
    border: 1px solid rgba(22, 163, 74, .4);
}
[data-theme="dark"] .sentiment-card .sc-toast[data-variant="ok"] {
    background: rgba(22, 163, 74, .25);
    color: #86efac;
}
.sentiment-card .sc-toast[data-variant="error"] {
    background: rgba(239, 68, 68, .12);
    color: #991b1b;
    border: 1px solid rgba(239, 68, 68, .3);
}
[data-theme="dark"] .sentiment-card .sc-toast[data-variant="error"] {
    background: rgba(239, 68, 68, .2);
    color: #fca5a5;
}

.sentiment-card .sc-footer {
    margin-top: auto;
    padding-top: 12px;
    border-top: 1px solid var(--border);
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
    align-items: center;
}
.sentiment-card .sc-play-recording {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 14px;
    border-radius: var(--radius-sm);
    font-size: var(--font-size-sm, .8rem);
    font-weight: var(--font-weight-semibold, 600);
    background: var(--indigo, #4f46e5);
    color: #fff;
    border: none;
    cursor: pointer;
    margin-left: auto;
}
.sentiment-card .sc-play-recording:hover { opacity: .92; }
.sentiment-card .sc-play-recording[hidden] { display: none !important; }
.sentiment-card .sc-recording-player {
    flex-shrink: 0;
    padding: 14px 0 4px;
    border-top: 1px solid var(--border);
    background: var(--page-bg);
}
.sentiment-card .sc-recording-player audio {
    display: block;
    width: 100%;
    min-height: 44px;
}
.sentiment-card .sc-download {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 14px;
    border-radius: var(--radius-sm);
    font-size: var(--font-size-sm, .8rem);
    font-weight: var(--font-weight-semibold, 600);
    background: var(--blue);
    color: var(--on-primary);
    text-decoration: none;
}
.sentiment-card .sc-download:hover { opacity: .9; }
.sentiment-card .sc-footer .btn-secondary-custom.btn-sm-custom {
    padding: 7px 14px;
    font-size: var(--font-size-sm, .8rem);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

/* Transcript table rows */
.sc-transcript-row {
    padding: 8px 12px;
    display: flex;
    gap: 10px;
    align-items: flex-start;
    border-bottom: 1px solid var(--border);
}
.sc-transcript-row:last-child { border-bottom: none; }
.sc-transcript-row:nth-child(odd) { background: var(--grey-100, rgba(0, 0, 0, .02)); }
[data-theme="dark"] .sc-transcript-row:nth-child(odd) { background: rgba(255, 255, 255, .03); }
.sc-transcript-time {
    color: var(--text-light);
    font-size: var(--font-size-xs, .7rem);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
    padding-top: 3px;
    min-width: 58px;
    flex-shrink: 0;
}
.sc-transcript-icon {
    flex-shrink: 0;
    width: 32px;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding-top: 1px;
}
.sc-transcript-icon .avatar-sm { width: 28px !important; height: 28px !important; font-size: .65rem !important; }
.sc-transcript-body { flex: 1; line-height: 1.45; min-width: 0; }
.sc-transcript-speaker {
    font-weight: var(--font-weight-semibold, 600);
    font-size: var(--font-size-sm, .8rem);
    margin-bottom: 2px;
}
.sc-transcript-speaker.internal { color: var(--blue); }
.sc-transcript-speaker.external { color: var(--text-mid); }
.sc-transcript-text { color: var(--text-dark); font-size: var(--font-size-md, .875rem); word-break: break-word; }
.sc-transcript-empty { padding: 12px 14px; color: var(--text-light); }
.sc-transcript-plain { padding: 12px 14px; line-height: 1.6; color: var(--text-dark); font-size: var(--font-size-md, .875rem); }
.sc-transcript-plain p { margin: 0 0 6px 0; }
.sc-transcript-icon-emoji { font-size: .85rem; line-height: 1; }

@media (max-width: 720px) {
    .sentiment-card .sc-layout { flex-direction: column; }
    .sentiment-card .sc-context-panel {
        width: 100%;
        border-right: none;
        border-bottom: 1px solid var(--border);
    }
    .sentiment-card .sc-kpi-strip {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .sentiment-card .sc-play-recording { margin-left: 0; }
}

/* Batch confirm modal (marketing-analytics) */
.batch-confirm-modal {
    display: none;
    position: fixed;
    z-index: 9999;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    width: min(420px, calc(100vw - 32px));
    background: var(--card-bg);
    color: var(--text-dark);
    border-radius: var(--radius);
    box-shadow: 0 8px 32px rgba(0,0,0,.22);
    border: 1px solid var(--border);
    overflow: hidden;
    font-size: .875rem;
}
.batch-confirm-modal .batch-confirm-header {
    padding: 16px 20px;
    border-bottom: 1px solid var(--border);
}
.batch-confirm-modal .batch-confirm-title { margin: 0 0 4px 0; font-size: 1.1rem; font-weight: 600; }
.batch-confirm-modal .batch-confirm-desc { margin: 0; font-size: .8rem; color: var(--text-light); }
.batch-confirm-modal .batch-confirm-body { padding: 16px 20px; }
.batch-confirm-modal .batch-confirm-content { margin-bottom: 16px; line-height: 1.6; color: var(--text-dark); }
.batch-confirm-modal .batch-confirm-note { margin: 0 0 12px 0; font-size: .75rem; color: var(--text-light); }
.batch-confirm-modal .batch-confirm-actions { display: flex; gap: 10px; justify-content: flex-end; }

/* ── 1. RESET / BASE ─────────────────────────────────────────
   Minimal base styles that complement Bootstrap.
   ---------------------------------------------------------- */

/* Remove default margin/padding on everything */
*, *::before, *::after {
    box-sizing: border-box;
}

/* Body defaults – font, background and no overflow bleed */
body {
    margin: 0;
    font-family: var(--font);
    background: var(--page-bg);
    color: var(--text-dark);
    font-size: 0.9375rem;
}

/* Prevent any child from pushing the page wider than the viewport */
.app {
    display: flex;
    min-height: 100vh;
    width: 100%;
    overflow-x: hidden;
}


/* ── 3. SIDEBAR ──────────────────────────────────────────────
   Left navigation panel. Grey (#4a5568) full-height column.
   ---------------------------------------------------------- */

/* Wrapper needed to position the collapse toggle button */
.sidebar-wrapper {
    position: relative;
    flex-shrink: 0;
}

/* The sidebar panel itself */
.sidebar {
    width: var(--sidebar-width);
    min-width: var(--sidebar-width);
    background: var(--sidebar-bg-gradient, var(--sidebar-bg));
    color: var(--on-primary);
    height: 100%;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    transition: width 0.3s cubic-bezier(0.4, 0, 0.2, 1), min-width 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    box-shadow: 4px 0 20px rgba(0,0,0,.06);
    border-right: 1px solid rgba(0,0,0,.08);
}

/* Collapsed state – icons only, labels hidden */
.sidebar.collapsed {
    width: var(--sidebar-collapsed-width);
    min-width: var(--sidebar-collapsed-width);
}

/* Hide text labels when collapsed (nav-label becomes hover tooltip, see below) */
.sidebar.collapsed .sidebar-brand-text,
.sidebar.collapsed .nav-section-label {
    display: none;
}

/* Centre icons when collapsed */
.sidebar.collapsed .nav-item {
    justify-content: center;
    padding: 0.65rem 0;
    position: relative;
}

/* Collapsed: hide nav-label (tooltip shown via JS, appended to body) */
.sidebar.collapsed .nav-label {
    display: none;
}

/* Sidebar nav tooltip – rendered by JS, appended to body, slides out to the right */
.sidebar-nav-tooltip {
    position: fixed;
    padding: 0.45rem 0.85rem;
    background: #4f5b6a;
    color: var(--on-primary);
    font-size: 0.8rem;
    font-weight: 500;
    white-space: nowrap;
    border-radius: 0 6px 6px 0;
    box-shadow: 0 4px 14px rgba(0,0,0,.25);
    z-index: 10000;
    pointer-events: auto;
    opacity: 0;
    transform: translateY(-50%) translateX(-12px);
    transition: opacity 0.2s ease, transform 0.25s ease-out;
}
.sidebar-nav-tooltip.sidebar-nav-tooltip-visible {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
}

/* Centre the logo area when collapsed */
.sidebar.collapsed .sidebar-logo-area {
    justify-content: center;
    padding: 1rem 0;
}


/* ── 3a. Sidebar toggle button (chevron circle) ────────────── */

/* Small circle button sitting on the right edge of the sidebar */
.sidebar-toggle {
    position: absolute;
    right: -13px;
    top: 50px;
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: var(--card-bg);
    border: 1px solid var(--border);
    box-shadow: 0 2px 8px rgba(0,0,0,.12);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: var(--text-mid);
    z-index: 20;
    transition: color 0.2s, box-shadow 0.2s, border-color 0.2s;
}
.sidebar-toggle .sidebar-toggle-icon {
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
}
.sidebar-toggle .sidebar-toggle-icon [data-lucide],
.sidebar-toggle .sidebar-toggle-icon svg {
    width: 13px;
    height: 13px;
}

[data-theme="dark"] .sidebar-toggle {
    color: rgba(255,255,255,.85);
    background: var(--card-bg);
    border-color: rgba(255,255,255,.2);
    box-shadow: 0 2px 12px rgba(0,0,0,.4);
}
/* Highlight on hover */
.sidebar-toggle:hover {
    color: var(--blue);
    box-shadow: 0 3px 12px rgba(0,149,200,.2);
}
[data-theme="dark"] .sidebar-toggle:hover {
    color: var(--blue);
    border-color: var(--blue);
}


/* ── 3b. Sidebar logo area ─────────────────────────────────── */

/* Logo + brand name at the top of the sidebar — clickable link to dashboard */
.sidebar-logo-area {
    display: flex;
    color: inherit;
    text-decoration: none;
    align-items: center;
    gap: 0.6rem;
    padding: 1.2rem 1.25rem 1rem;
    border-bottom: 1px solid rgba(255,255,255,.1);
    flex-shrink: 0;
}

/* Small logo image (white version on grey sidebar) */
.sidebar-logo-img {
    width: 36px;
    height: 36px;
    border-radius: 6px;
    object-fit: contain;
    background: rgba(255,255,255,.1);
    padding: 4px;
    flex-shrink: 0;
}

/* Custom uploaded main logo — don't apply the icon box styles */
.sidebar-logo-custom {
    width: auto;
    height: auto;
    max-height: 48px;
    max-width: 200px;
    border-radius: 0;
    background: transparent;
    padding: 0;
}

/* Collapsed-state icon — only shown when sidebar is collapsed */
.sidebar-logo-collapsed {
    display: none;
}
.sidebar.collapsed .sidebar-logo-collapsed {
    display: flex;
    align-items: center;
    justify-content: center;
}
/* Hide the main logo when collapsed (custom or default) */
.sidebar.collapsed .sidebar-logo-img {
    display: none;
}

/* Brand name text block */
.sidebar-brand-text {
    font-weight: 700;
    font-size: 0.9rem;
    line-height: 1.2;
    color: rgba(255,255,255,.95);
    white-space: nowrap;
}

/* Smaller sub-title under brand name */
.sidebar-brand-text small {
    display: block;
    font-size: 0.68rem;
    font-weight: 400;
    color: rgba(255,255,255,.5);
    letter-spacing: 0.03em;
}


/* ── 3c. Sidebar navigation items ─────────────────────────── */

/* Nav scroll container */
.sidebar-nav {
    padding: 0.75rem 0.6rem;
    flex: 1;
    overflow-y: auto;
}

/* Section label (e.g. "Reports", "Admin") */
.nav-section-label {
    padding: 0.5rem 0.75rem 0.2rem;
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: rgba(255,255,255,.4);
    white-space: nowrap;
}

/* Collapsible section toggle (e.g. "Reports") */
.nav-section-toggle {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem 0.2rem;
    background: transparent;
    border: none;
    cursor: pointer;
    color: rgba(255,255,255,.4);
    font-size: 0.65rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
}

.nav-section-toggle:hover {
    color: rgba(255,255,255,.65);
}

.nav-section-toggle-icon {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
    opacity: 0.9;
}

.nav-section-content {
    padding-top: 0.15rem;
}

/* When sidebar is collapsed: hide section headers/dividers but keep nav items (icons) visible */
.sidebar.collapsed .nav-section-toggle,
.sidebar.collapsed .nav-divider,
.sidebar.collapsed .nav-section-label {
    display: none !important;
}
/* Force all section content visible when collapsed (override JS section-toggle state) */
.sidebar.collapsed .nav-section-content {
    display: block !important;
}
/* Allow tooltip to extend outside sidebar when collapsed */
.sidebar.collapsed {
    overflow: visible;
    z-index: 100;
}
.sidebar.collapsed .sidebar-nav {
    overflow-x: visible;
}

/* Better rendering for grouped header tables */
table.ext-summary-table thead th {
    background: transparent;
}

/* Individual nav link */
.nav-item {
    display: flex;
    align-items: center;
    gap: 0.7rem;
    padding: 0.55rem 0.75rem;
    color: rgba(255,255,255,.8);
    text-decoration: none;
    border-radius: var(--radius-sm);
    margin-bottom: 1px;
    font-size: 0.875rem;
    transition: background 0.15s, color 0.15s;
    white-space: nowrap;
}

/* Hover state */
.nav-item:hover {
    background: rgba(255,255,255,.1);
    color: var(--on-primary);
}

/* Active / selected page */
.nav-item.active {
    background: var(--sidebar-active);
    color: var(--on-primary);
    box-shadow: 0 2px 8px rgba(0,149,200,.35);
}

/* Icon inside nav item */
.nav-item i,
.nav-item svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

/* Thin rule to separate nav groups */
.nav-divider {
    border: none;
    border-top: 1px solid rgba(255,255,255,.1);
    margin: 0.5rem 0.6rem;
}


/* ── 4. MAIN CONTENT WRAPPER ─────────────────────────────────
   The flex sibling of the sidebar that fills remaining width.
   ---------------------------------------------------------- */

/* Main area — takes all remaining horizontal space */
.main {
    flex: 1;
    min-width: 0;              /* prevents flex overflow */
    background: var(--page-bg);
    overflow-x: hidden;
    display: flex;
    flex-direction: column;
}

/* Widget Boards standalone (no left sidebar) */
.widgets-app {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
.widgets-app .widgets-main {
  flex: 1;
  min-width: 0;
  width: 100%;
}


/* ── 5. PAGE HEADER ──────────────────────────────────────────
   Top bar inside the main area with page title and controls.
   ---------------------------------------------------------- */

/* Header row: user pill fixed top-right, page content flows left inline */
.header-row {
  position: relative;
  background: transparent;
  padding: 0.6rem 1.25rem;
  margin: 0.5rem 1rem 0.4rem;
  display: flex;
  align-items: center;
  flex-wrap: nowrap;
  flex-shrink: 0;
  min-height: 44px;
}
body.user-menu-hidden .header-row { display: none; }

/* Page content slot – takes remaining space, never wraps below pill */
.header-row-left {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: nowrap;
  padding-right: 0;
}
body:not(.user-menu-hidden) .header-row-left {
  padding-right: 180px; /* Reserve space for user pill – keeps content inline */
}

/* User pill: always top-right, never drops to new line, above all content */
.header-row-right {
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  flex-shrink: 0;
  z-index: 9999;
}

/* User menu dropdown – inline pill trigger */
.user-menu .user-pill-trigger {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.2rem 0.5rem 0.2rem 0.35rem;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  font-size: 0.8rem;
  color: var(--text-mid);
  cursor: pointer;
  transition: border-color 0.2s, box-shadow 0.2s;
  text-decoration: none;
  width: fit-content;
}
.user-menu .user-pill-trigger:hover {
  border-color: var(--blue);
  color: var(--text-dark);
}
.user-menu .user-pill-trigger:focus {
  outline: none;
  box-shadow: 0 0 0 2px rgba(0, 149, 200, 0.25);
}
.user-pill-label {
  white-space: nowrap;
}
.avatar-user-sm {
  width: 22px;
  height: 22px;
  font-size: 0.58rem;
  background: var(--blue) !important;
  color: var(--on-primary) !important;
}
.user-pill-chevron {
  width: 14px;
  height: 14px;
  color: var(--text-light);
  flex-shrink: 0;
  transition: transform 0.2s;
}
.user-menu.show .user-pill-chevron { transform: rotate(180deg); }

/* Hide Bootstrap's dropdown caret — user pill uses Lucide chevron */
.user-pill-trigger.dropdown-toggle::after {
  display: none;
}

/* User dropdown menu – professional styling */
.user-dropdown-menu {
  min-width: 200px;
  padding: 0.4rem;
  border-radius: 10px;
  box-shadow: var(--card-shadow);
  border: 1px solid var(--border);
  background: var(--card-bg);
  margin-top: 0.3rem;
}
.user-dropdown-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.4rem 0.65rem;
  border-radius: 10px;
  font-size: 0.88rem;
  color: var(--text-dark);
}
.user-dropdown-item:hover {
  background: var(--blue-pale, #e0f4fb);
  color: var(--blue);
}
.user-dropdown-icon {
  width: 15px;
  height: 15px;
  flex-shrink: 0;
  color: var(--blue);
}
.user-dropdown-logout:hover { color: var(--red, #ef4444) !important; }
.user-dropdown-menu .dropdown-divider { margin: 0.35rem 0; border-color: var(--border); }

/* Bootstrap dropdown dark mode – ensure theme-aware when user menu open */
[data-theme="dark"] .dropdown-menu {
  background: var(--card-bg);
  border-color: var(--border);
}
[data-theme="dark"] .dropdown-divider {
  border-color: var(--border);
}

/* Bootstrap form controls dark mode */
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
  background: var(--card-bg);
  color: var(--text-dark);
  border-color: var(--border);
}
[data-theme="dark"] .form-control::placeholder {
  color: var(--text-light);
}

/* Bootstrap text-muted: use theme-aware colour in dark mode */
[data-theme="dark"] .text-muted {
  color: var(--text-mid) !important;
}

/* Hide page-header until JS moves it into slot (avoids double header flash) */
.content.with-header-row .page-header,
.content.with-header-row .v2-page-header,
.content.with-header-row .wb-page-header { display: none !important; }

/* Header strip (page-level, moved into slot) */
  .page-header {
    background: transparent;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
    flex-shrink: 0;
    margin-bottom: 0 !important;
    width: 100%;
}
#page-header-slot .page-header,
.wb-header-slot-inner .page-header { background: transparent; }

/* Slot receives page-header content – same layout, never wraps */
#page-header-slot,
.wb-header-slot-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: nowrap;
  min-width: 0;
}
#page-header-slot { width: 100%; }
.wb-header-slot-inner { flex: 1; width: 100%; }

/* Hide legacy user block (avatar + email) – user pill lives in header-row-right only */
#page-header-slot .avatar-user,
#page-header-slot .user-pill:not(.user-pill-trigger),
#page-header-slot .header-controls > *:has(.avatar-user),
.wb-header-slot-inner .avatar-user,
.wb-header-slot-inner .user-pill:not(.user-pill-trigger),
.wb-header-slot-inner .header-controls > *:has(.avatar-user) {
  display: none !important;
}

/* Page title (h1 inside header) */
.page-header h1,
#page-header-slot h1,
.wb-header-slot-inner h1 {
    margin: 0;
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--text-dark);
}

/* Right-side controls cluster */
.header-controls {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    flex-wrap: wrap;
}

/* Header buttons: match user pill (settings dropdown) shape and height */
.header-controls .btn-primary-custom,
.header-controls .btn-secondary-custom,
.header-controls .dropdown-toggle.btn-primary-custom,
.header-controls .dropdown-toggle.btn-secondary-custom {
    padding: 0.45rem 0.85rem;
    border-radius: 10px;
    font-size: 0.8rem;
    min-height: 32px;
}

/* Override btn-sm-custom when it's in header-controls */
.header-controls .btn-sm-custom {
    padding: 0.45rem 0.85rem;
    border-radius: 10px;
    font-size: 0.8rem;
    min-height: 32px;
}

/* Date range picker pill */
.date-nav {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    background: var(--card-bg);
    padding: 0.35rem 0.75rem;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    font-size: 0.875rem;
    color: var(--text-mid);
    cursor: pointer;
    transition: border-color 0.2s;
    text-decoration: none;
}

/* Highlight date picker on hover/focus */
.date-nav:hover,
.date-nav:focus {
    border-color: var(--blue);
    color: var(--text-dark);
    outline: none;
}

/* User avatar + name cluster */
.user-pill {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* Circular user avatar (initials fallback) */
.avatar-user {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--blue), var(--indigo));
    color: var(--on-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.7rem;
    font-weight: 700;
    flex-shrink: 0;
}

/* Photo avatar (when a real image is available) */
.avatar-user img {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    object-fit: cover;
}


/* ── 6. BUTTONS ──────────────────────────────────────────────
   Reusable button styles used across all pages.
   ---------------------------------------------------------- */

/* Primary action button (blue) */
.btn-primary-custom {
    background: var(--blue);
    color: var(--on-primary);
    border: none;
    padding: 0.4rem 1rem;
    border-radius: var(--radius-sm);
    font-weight: 500;
    font-size: 0.875rem;
    cursor: pointer;
    transition: background 0.2s;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.btn-primary-custom:hover {
    background: var(--blue-mid);
    color: var(--on-primary);
}

/* Secondary / outline button */
.btn-secondary-custom {
    background: var(--card-bg);
    color: var(--text-mid);
    border: 1px solid var(--border);
    padding: 0.4rem 1rem;
    border-radius: var(--radius-sm);
    font-weight: 500;
    font-size: 0.875rem;
    cursor: pointer;
    transition: border-color 0.2s, color 0.2s;
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.btn-secondary-custom:hover {
    border-color: var(--blue);
    color: var(--blue);
}

/* Danger / destructive button */
.btn-danger-custom {
    background: var(--yellow);
    color: var(--on-primary);
    border: none;
    padding: 0.4rem 1rem;
    border-radius: var(--radius-sm);
    font-weight: 500;
    font-size: 0.875rem;
    cursor: pointer;
}

.btn-danger-custom:hover {
    background: var(--yellow-dark);
}

/* Small variant for all button types */
.btn-sm-custom {
    padding: 0.25rem 0.65rem;
    font-size: 0.8rem;
}

/* Icon-only button (used in ai-call-report, agent-coaching, ai-coaching admin) */
.btn-icon-custom {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 4px 6px;
    border-radius: 6px;
    border: 1px solid var(--border);
    background: var(--card-bg);
    color: var(--text-mid);
    cursor: pointer;
    font-size: .8rem;
    line-height: 1;
    text-decoration: none;
    transition: background .15s, color .15s, border-color .15s;
}
.btn-icon-custom:hover {
    background: var(--blue-pale);
    color: var(--blue);
    border-color: var(--blue);
}
.btn-icon-custom.active {
    background: var(--blue-pale);
    color: var(--blue);
    border-color: var(--blue);
}


/* ── 7. PAGE CONTENT WRAPPER ─────────────────────────────────
   Padding and width constraints for the body of each page.
   ---------------------------------------------------------- */

/* Inner content padding */
.content {
    padding: 1.25rem 1.5rem;
    flex: 1;
}


/* ── 8. CARDS ────────────────────────────────────────────────
   White rounded panels used for KPIs, charts and tables.
   ---------------------------------------------------------- */

/* Standard card / panel */
.card-box {
    background: var(--card-bg);
    border-radius: var(--radius);
    padding: 1.25rem;
    box-shadow: var(--card-shadow);
    border: 1px solid var(--border);
    margin-bottom: 1.25rem;
}

/* Card heading */
.card-box h3 {
    font-size: 0.9rem;
    margin: 0 0 1rem;
    font-weight: 600;
    color: var(--text-dark);
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* Small pill label inside a card heading */
.card-badge {
    font-size: 0.68rem;
    font-weight: 500;
    padding: 0.15rem 0.5rem;
    border-radius: 20px;
    background: var(--blue-pale);
    color: var(--blue-deep);
}

/* Yellow variant of card badge (for "Needs Callback" etc) */
.card-badge.amber {
    background: var(--yellow-pale);
    color: var(--yellow-dark);
}

/* Muted variant – softer, fits modern dashboards */
.card-badge--muted {
    background: var(--grey-100);
    color: var(--text-mid);
}


/* ── 9. KPI CARDS ────────────────────────────────────────────
   Large metric cards across the top of the dashboard.
   ---------------------------------------------------------- */

/* Grid that holds all KPI cards – 8 equal columns, full width */
.kpi-grid {
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    gap: 1rem;
    margin-bottom: 1.25rem;
    width: 100%;
}

/* Dashboard: 7 KPI cards (matches todays-performance-style metrics; no Talk Time tile) */
.kpi-grid-dashboard {
    grid-template-columns: repeat(7, 1fr);
}
@media (max-width: 1400px) {
    .kpi-grid-dashboard {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Individual KPI card */
.kpi-card {
    background: var(--card-bg);
    border-radius: var(--radius);
    padding: 1.1rem 1.25rem;
    box-shadow: var(--card-shadow);
    border: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    align-items: center;
    text-align: center;
}

/* Coloured icon square inside KPI card */
.icon-wrap {
    width: 42px;
    height: 42px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 0.3rem;
    flex-shrink: 0;
}

/* Icon colour variants */
.icon-wrap.ib  { background: var(--blue-pale);     color: var(--blue);      }  /* Inbound */
.icon-wrap.ob  { background: var(--indigo-pale);   color: var(--indigo);    }  /* Outbound */
.icon-wrap.tk  { background: var(--purple-pale);   color: var(--purple);    }  /* Talk time (avg) */
.icon-wrap.tt  { background: rgba(13,148,136,.12); color: #0d9488; }         /* Total talk time */
.icon-wrap.in  { background: var(--lavender-pale); color: var(--lavender);  }  /* Internal */
.icon-wrap.ms  { background: rgba(220,38,38,.1);   color: var(--error); } /* Missed */

/* Large number */
.kpi-value {
    font-size: 1.65rem;
    font-weight: 700;
    color: var(--text-dark);
    line-height: 1;
}

/* KPI value colour matches icon – Total Calls, Inbound, Talk Time, etc. */
.kpi-card:has(.icon-wrap.ib) .kpi-value  { color: var(--blue); }
.kpi-card:has(.icon-wrap.ob) .kpi-value  { color: var(--indigo); }
.kpi-card:has(.icon-wrap.tk) .kpi-value { color: var(--purple); }
.kpi-card:has(.icon-wrap.tt) .kpi-value { color: #0d9488; }
.kpi-card:has(.icon-wrap.in) .kpi-value  { color: var(--lavender); }
.kpi-card:has(.icon-wrap.ms) .kpi-value  { color: var(--error); }
/* Performer cards (avatar when present) – use class when no icon-wrap */
.kpi-card.kpi-icon-ib .kpi-value  { color: var(--blue); }
.kpi-card.kpi-icon-ob .kpi-value  { color: var(--indigo); }

/* Missed calls number (red) – kept for .amber class where used */
.kpi-value.amber {
    color: var(--error);
}

/* Label below the number – same size/style as card-box h3 */
.kpi-label {
    font-size: 1.2rem;
    font-weight: 600;
    color: var(--text-dark);
}

/* Small supplementary line (e.g. "20 answered · 6 missed") */
.kpi-sub {
    font-size: 0.73rem;
    color: var(--text-light);
}

/* Missed rate sub-text (red) */
.kpi-sub.amber {
    color: var(--error);
}

/* Top performer cards – circular avatar (42px, same height as icon-wrap) */
.kpi-performer .kpi-performer-avatar {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    overflow: hidden;
    margin-bottom: 0.3rem;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.kpi-performer .kpi-performer-avatar .avatar-sm {
    width: 42px !important;
    height: 42px !important;
    font-size: 0.8rem;
}
.kpi-performer .kpi-performer-avatar .icon-wrap {
    width: 42px;
    height: 42px;
    border-radius: 50%;
}

/* VIP page: 6 KPI cards, equal width, centered content */
.kpi-grid-vip {
    grid-template-columns: repeat(6, 1fr);
    width: 100%;
}
.kpi-grid-vip .kpi-card {
    align-items: center;
    text-align: center;
    justify-content: center;
}


/* ── 10. CHART CONTAINERS ────────────────────────────────────
   Sizing for Chart.js canvas elements.
   ---------------------------------------------------------- */

/* Standard chart height */
.chart-container {
    position: relative;
    height: 230px;
}

/* Donut charts – center the chart in the container */
.chart-container--donut {
    display: flex;
    align-items: center;
    justify-content: center;
}
.chart-container--donut canvas {
    max-width: 100%;
    max-height: 100%;
}

/* Dashboard charts row – equal card heights, larger chart area */
.charts-row .col-lg-4 {
    display: flex;
}
.charts-row .chart-card {
    display: flex;
    flex-direction: column;
    flex: 1;
    width: 100%;
}
.charts-row .chart-card .chart-container {
    height: 280px;
}

/* Dashboard tables row – Top Extensions + Top Locations equal height */
.dash-tables-row {
    --dash-topext-visible-rows: 7;
    --dash-topext-row-height: 3rem;
    --dash-topext-head-height: 2.75rem;
    --dash-topext-body-height: calc(var(--dash-topext-head-height) + var(--dash-topext-visible-rows) * var(--dash-topext-row-height));
}
.dash-tables-row > [class*="col-"] {
    display: flex;
}
.dash-panel-card {
    display: flex;
    flex-direction: column;
    flex: 1;
    width: 100%;
}
.dash-panel-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: var(--dash-topext-body-height);
}
.dash-topext-panel .dash-topext-scroll {
    flex: 1;
    min-height: 0;
    max-height: var(--dash-topext-body-height);
    overflow-y: auto;
    overflow-x: auto;
}
.dash-locations-body {
    min-height: 0;
}
.dash-locations-chart {
    flex: 1;
    min-height: var(--dash-topext-body-height);
    height: auto !important;
}
.dash-panel-card > .empty-state {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: var(--dash-topext-body-height);
}

/* Taller chart variant (e.g. call log timeline) */
.chart-container.tall {
    height: 320px;
}


/* ── 11. TABLES ──────────────────────────────────────────────
   Consistent table styling across all report pages.
   ---------------------------------------------------------- */

/* Scroll wrapper – handles horizontal overflow on small screens */
.tbl-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

/* Max-height with vertical scroll for long lists */
.tbl-wrap.scrollable {
    max-height: 320px;
    overflow-y: auto;
}

/* Scrollbar only visible when hovering over the container */
.scroll-on-hover {
    scrollbar-width: none;
    -ms-overflow-style: none;
}
.scroll-on-hover::-webkit-scrollbar { width: 0; height: 0; }
.scroll-on-hover:hover {
    scrollbar-width: thin;
    -ms-overflow-style: auto;
}
.scroll-on-hover:hover::-webkit-scrollbar { width: 8px; height: 8px; }
.scroll-on-hover:hover::-webkit-scrollbar-track { background: rgba(0,0,0,.04); border-radius: 4px; }
.scroll-on-hover:hover::-webkit-scrollbar-thumb { background: rgba(0,0,0,.2); border-radius: 4px; }

/* Dashboard Top Extensions: gutter always reserved; thumb hidden until container hover (no layout shift) */
.dash-topext-scrollbar-stable {
    scrollbar-gutter: stable;
    scrollbar-width: thin;
    /* Firefox: invisible thumb/track until hover — space still reserved via scrollbar-gutter */
    scrollbar-color: transparent transparent;
}
.dash-topext-scrollbar-stable:hover {
    scrollbar-color: rgba(0, 0, 0, 0.28) rgba(0, 0, 0, 0.05);
}
.dash-topext-scrollbar-stable::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}
.dash-topext-scrollbar-stable::-webkit-scrollbar-track {
    background: transparent;
    border-radius: 4px;
}
.dash-topext-scrollbar-stable::-webkit-scrollbar-thumb {
    background: transparent;
    border-radius: 4px;
}
.dash-topext-scrollbar-stable:hover::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.04);
}
.dash-topext-scrollbar-stable:hover::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.28);
}
[data-theme="dark"] .dash-topext-scrollbar-stable {
    scrollbar-color: transparent transparent;
}
[data-theme="dark"] .dash-topext-scrollbar-stable:hover {
    scrollbar-color: rgba(255, 255, 255, 0.32) rgba(255, 255, 255, 0.06);
}
[data-theme="dark"] .dash-topext-scrollbar-stable::-webkit-scrollbar-track {
    background: transparent;
}
[data-theme="dark"] .dash-topext-scrollbar-stable::-webkit-scrollbar-thumb {
    background: transparent;
}
[data-theme="dark"] .dash-topext-scrollbar-stable:hover::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.06);
}
[data-theme="dark"] .dash-topext-scrollbar-stable:hover::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.32);
}

/* Live Queue Summary — same 7-row hover scroll as dashboard Top Extensions */
.lq-queue-summary-panel {
    --dash-topext-visible-rows: 7;
    --dash-topext-row-height: 3rem;
    --dash-topext-head-height: 2.75rem;
    --dash-topext-body-height: calc(var(--dash-topext-head-height) + var(--dash-topext-visible-rows) * var(--dash-topext-row-height));
    display: flex;
    flex-direction: column;
}
.lq-queue-summary-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-height: 0;
}
.lq-queue-summary-body .dash-topext-scroll {
    flex: 1;
    min-height: 0;
    max-height: var(--dash-topext-body-height);
    overflow-y: auto;
    overflow-x: auto;
}

/* Base table */
table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.875rem;
    min-width: 340px;        /* prevents columns collapsing to nothing */
}

/* Header row */
thead th {
    text-align: left;
    padding: 0.55rem 0.75rem;
    color: var(--text-light);
    font-weight: 500;
    border-bottom: 2px solid var(--border);
    white-space: nowrap;
    background: var(--card-bg);
    position: sticky;
    top: 0;
    z-index: 1;
    vertical-align: middle;
}

/* Right-aligned numeric/status columns */
thead th.col-right,
tbody td.col-right {
    text-align: right;
}

/* Call log / AI call report: keep duration & outcome left-aligned */
#cr-results-card .tbl-wrap table thead th.col-right,
#cr-results-card .tbl-wrap table tbody td.col-right,
#cl-results-card .tbl-wrap table thead th.col-right,
#cl-results-card .tbl-wrap table tbody td.col-right {
    text-align: left;
}

/* Destination column: pill style for queue / group numbers */
td.col-dept {
    color: var(--text-mid);
    font-size: .84rem;
}
.dept-pill {
    display: inline-block;
    padding: .2rem .55rem;
    border-radius: 999px;
    background: var(--border);
    color: var(--text-mid);
    font-size: 0.73rem;
    font-weight: 600;
    margin-right: 0.5rem;
}

/* Date/time cell: date normal, time lighter and slightly smaller */
.dt-date { font-variant-numeric: tabular-nums; }
.dt-sep { color: var(--text-light); opacity: .7; }
.dt-time { color: var(--text-light); font-size: .9em; font-variant-numeric: tabular-nums; }

/* Direction icons for Called By / Received By (match todays-performance) */
.ext-cell-icon {
  width: 30px;
  height: 30px;
  min-width: 30px;
  padding: 6px;
  box-sizing: border-box;
  border-radius: 50%;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.ext-cell-icon i {
  width: 10px;
  height: 10px;
}
.ext-cell-icon-outbound {
  background: rgba(2,132,199,.1);
  color: var(--blue-mid);
}
.ext-cell-icon-inbound {
  background: rgba(22,163,74,.1);
  color: var(--success);
}
.ext-cell-icon-inbound-missed {
  background: rgba(220,38,38,.1);
  color: var(--error);
}

/* External caller avatar — neutral grey phone icon */
.avatar-phone {
    width: 30px;
    height: 30px;
    min-width: 30px;
    border-radius: 50%;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--border);
    color: var(--text-mid);
}

/* Touchpoint avatars: incoming call (replaces ?? for external callers) */
.avatar-incoming {
    background: linear-gradient(135deg, var(--blue-mid), var(--blue)) !important;
    color: var(--on-primary) !important;
}

/* Touchpoint avatars: play prompt answered (music icon) */
.avatar-music {
    background: linear-gradient(135deg, var(--purple), var(--indigo)) !important;
    color: var(--on-primary) !important;
}

/* Data cells */
tbody td {
    padding: 0.55rem 0.75rem;
    border-bottom: 1px solid var(--border);
    color: var(--text-dark);
    vertical-align: middle;
}

/* Subtle hover highlight on rows */
tbody tr:hover td {
    background: var(--grey-100);
}

/* Extension name cell with avatar */
.ext-cell {
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

/* Small circular avatar inside a table row */
.avatar-sm {
    width: 30px;
    height: 30px;
    border-radius: 50%;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.65rem;
    font-weight: 700;
    color: var(--on-primary);
    background: none;
    overflow: hidden;
}

/* Avatar photo image */
.avatar-sm img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

/* Table pagination controls */
.pagination-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 0 0;
    flex-wrap: wrap;
    gap: 0.5rem;
    font-size: 0.85rem;
    color: var(--text-light);
}

/* Pagination page link */
.page-link-custom {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    border-radius: 6px;
    border: 1px solid var(--border);
    color: var(--text-mid);
    text-decoration: none;
    font-size: 0.825rem;
    transition: background 0.15s, border-color 0.15s;
}

/* Active page number */
.page-link-custom.active {
    background: var(--blue);
    border-color: var(--blue);
    color: var(--on-primary);
}

.page-link-custom:hover:not(.active) {
    background: var(--blue-pale);
    border-color: var(--blue);
    color: var(--blue);
}

.pagination-bar .pagination-links {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    align-items: center;
}

.page-link-custom--muted {
    opacity: 0.45;
    cursor: default;
    user-select: none;
    pointer-events: none;
    background: transparent;
}


/* ── 12. BADGES ──────────────────────────────────────────────
   Small inline labels for outcomes, directions, etc.
   ---------------------------------------------------------- */

/* Base badge */
.badge-custom {
    display: inline-block;
    padding: 0.2rem 0.55rem;
    border-radius: 20px;
    font-size: 0.73rem;
    font-weight: 600;
    white-space: nowrap;
}

/* Answered (inbound) — light green */
.badge-custom.answered {
    background: var(--sc-bg-5);
    color: var(--sc-fg-5);
}

/* Missed (red, matches ai-call-report) */
.badge-custom.missed {
    background: rgba(220,38,38,.1);
    color: var(--error);
}

/* Voicemail — amber (missed for reporting, distinct display) */
.badge-custom.voicemail {
    background: rgba(217,119,6,.12);
    color: rgb(217,119,6);
}

[data-theme="dark"] .badge-custom.voicemail {
    background: rgba(217,119,6,.18);
    color: rgb(251,191,36);
}

/* Inbound direction — same green family as answered counts */
.badge-custom.inbound {
    background: var(--sc-bg-5);
    color: var(--sc-fg-5);
}

/* Outbound — blue (distinct from internal purple) */
.badge-custom.outbound {
    background: var(--blue-pale);
    color: var(--blue-deep);
}

/* Internal — purple */
.badge-custom.internal {
    background: var(--purple-pale);
    color: var(--purple);
}

/* Repeat missed caller (amber alert) */
.badge-custom.repeat {
    background: var(--yellow);
    color: var(--on-primary);
}

/* Zero count — neutral (distinct from answered / missed / outbound / internal pills) */
.badge-custom.count-zero,
.badge-custom.zero {
    background: rgba(100, 116, 139, .12);
    color: var(--text-mid);
}
[data-theme="dark"] .badge-custom.count-zero,
[data-theme="dark"] .badge-custom.zero {
    background: rgba(148, 163, 184, .16);
    color: var(--text-mid);
}

/* Transferred badge (success / green) */
.badge-custom.transferred {
    background: rgba(16, 185, 129, .14);
    color: #065f46;
}

/* Parked badge (amber) */
.badge-custom.call-event-parked {
    background: rgba(245, 158, 11, .14);
    color: #92400e;
}

/* Call Ended badge (neutral slate) */
.badge-custom.call-event-ended {
    background: rgba(100, 116, 139, .12);
    color: #334155;
}

[data-theme="dark"] .badge-custom.call-event-parked {
    background: rgba(245, 158, 11, .25);
    color: #fcd34d;
}
[data-theme="dark"] .badge-custom.call-event-ended {
    background: rgba(148, 163, 184, .2);
    color: var(--text-mid);
}
[data-theme="dark"] .badge-custom.transferred {
    background: rgba(16, 185, 129, .25);
    color: #6ee7b7;
}


/* ── Call Flow touchpoints ─────────────────────────────────── */
.cf-touchpoints {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.15rem;
    min-width: 0;
}
.cf-touchpoints .cf-tp-part {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.2rem 0.5rem;
    border-radius: 6px;
    font-size: 0.8rem;
    white-space: nowrap;
    flex-shrink: 0;
}
.cf-touchpoints .cf-tp-arrow {
    flex-shrink: 0;
}
.cf-touchpoints .cf-tp-part .avatar-sm {
    width: 22px;
    height: 22px;
    font-size: 0.6rem;
}
.cf-touchpoints .cf-tp-part .avatar-sm img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.cf-tp-arrow {
    display: inline-flex;
    align-items: center;
    margin: 0 0.2rem;
    color: var(--text-mid);
    font-size: 0.75rem;
}
.cf-tp-arrow::before {
    content: '';
    width: 16px;
    height: 10px;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='10' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14M12 5l7 7-7 7'/%3E%3C/svg%3E") no-repeat center;
    background-size: contain;
}
/* ── Call-log / VIP touchpoints dropdown (shared) ───────────────────── */
.cl-tp-cell {
    position: relative;
}
.cl-tp-btn {
    padding: 0.25rem 0.5rem;
    font-size: 0.8rem;
}
.cl-tp-dropdown {
    position: absolute;
    right: 0;
    top: 100%;
    margin-top: 0.25rem;
    padding: 0.75rem;
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: 0 4px 12px rgba(0,0,0,.12);
    z-index: 100;
    min-width: 200px;
    max-width: 360px;
}

/* Portaled to body — escape table .tbl-wrap overflow; max-height set in JS */
.cl-tp-dropdown.cl-tp-dropdown--floated {
    overflow-x: visible;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}
.cl-tp-dropdown .cl-tp-stack {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
}
.cl-tp-dropdown .cl-tp-stack.cf-touchpoints .cf-tp-part {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
    padding: 0.2rem 0.5rem;
    border-radius: 6px;
    font-size: 0.8rem;
    white-space: nowrap;
}

/* Down arrow for call-log touchpoints dropdown (vertical stack) */
.cf-tp-arrow-down {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0.15rem 0;
    color: var(--text-mid);
    transform: rotate(90deg);
}
.cf-tp-arrow-down::before {
    content: '';
    width: 16px;
    height: 10px;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='10' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14M12 5l7 7-7 7'/%3E%3C/svg%3E") no-repeat center;
    background-size: contain;
}
.cf-tp-arrow-inline {
    display: inline-block;
    width: 12px;
    height: 8px;
    margin: 0 0.15rem;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12h14M12 5l7 7-7 7'/%3E%3C/svg%3E") no-repeat center;
    background-size: contain;
    vertical-align: middle;
}
.cf-tp-answered {
    background: var(--blue-pale);
    color: var(--blue-deep);
}
.cf-tp-playprompt {
    background: var(--lavender-pale);
    color: var(--purple);
}
.cf-tp-parked {
    background: rgba(245, 158, 11, .14);
    color: #92400e;
}
.cf-tp-transferred {
    background: rgba(16, 185, 129, .14);
    color: #065f46;
}
.cf-tp-ended {
    background: rgba(100, 116, 139, .12);
    color: #334155;
}
.cf-tp-attended {
    background: var(--lavender-pale);
    color: var(--purple);
}
.cf-tp-pickedup {
    background: rgba(16, 185, 129, .14);
    color: #065f46;
}
[data-theme="dark"] .cf-tp-parked {
    background: rgba(245, 158, 11, .25);
    color: #fcd34d;
}
[data-theme="dark"] .cf-tp-transferred,
[data-theme="dark"] .cf-tp-pickedup {
    background: rgba(16, 185, 129, .25);
    color: #6ee7b7;
}
[data-theme="dark"] .cf-tp-ended {
    background: rgba(148, 163, 184, .2);
    color: var(--text-mid);
}
/* Call Flow: final “Ended by …” leg (3CX + Yeastar) */
.cf-touchpoints--call-flow > .cf-tp-part.cf-tp-ended:last-child {
    background: rgba(220, 38, 38, .12);
    color: var(--error);
    font-weight: 500;
}
[data-theme="dark"] .cf-touchpoints--call-flow > .cf-tp-part.cf-tp-ended:last-child {
    background: rgba(220, 38, 38, .22);
    color: #fca5a5;
}
.cf-tp-neutral {
    background: rgba(100, 116, 139, .08);
    color: var(--text-dark);
}
.cf-tp-empty {
    color: var(--text-light);
}


/* ── 13. FORM ELEMENTS ───────────────────────────────────────
   Filters on Call Log, Extensions and Missed Calls pages.
   ---------------------------------------------------------- */

/* Filter bar container */
.filter-bar {
    background: var(--card-bg);
    border-radius: var(--radius);
    padding: 1rem 1.25rem;
    margin-bottom: 1.25rem;
    border: 1px solid var(--border);
    box-shadow: var(--card-shadow);
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    align-items: flex-end;
}

/* Label above a filter input */
.filter-label {
    display: block;
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-light);
    margin-bottom: 0.25rem;
}

/* Select dropdowns and text inputs */
.filter-select,
.filter-input {
    padding: 0.375rem 0.65rem;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    font-size: 0.875rem;
    color: var(--text-dark);
    background: var(--card-bg);
    transition: border-color 0.2s;
    min-width: 130px;
}
/* Dropdown arrows: custom arrow with margin from right edge (matches calendar icon spacing) */
.filter-select,
.preset-select,
.tp-range-select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding-right: 2rem;
    background-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='%23475569' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 0.65rem center;
    background-size: 14px 14px;
}

.filter-select:focus,
.filter-input:focus {
    border-color: var(--blue);
    outline: none;
    box-shadow: 0 0 0 3px rgba(0,149,200,.1);
}

/* Phone autocomplete dropdown (call-log) */
.phone-suggestions {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    margin-top: 2px;
    background: var(--card-bg);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    box-shadow: 0 4px 12px rgba(0,0,0,.12);
    max-height: 200px;
    overflow-y: auto;
    z-index: 100;
}

.phone-suggestion-item {
    display: block;
    width: 100%;
    padding: 0.5rem 0.75rem;
    border: none;
    background: none;
    font-size: 0.875rem;
    color: var(--text-dark);
    text-align: left;
    cursor: pointer;
    transition: background 0.15s;
}

.phone-suggestion-item:hover {
    background: var(--blue-pale);
}


/* ── 13b. DATE PRESET DROPDOWN ───────────────────────────────
   Single select dropdown for quick date range selection.
   ---------------------------------------------------------- */

/* The preset select element */
.preset-select,
.tp-range-select {
    padding: 0.375rem 2rem 0.375rem 0.65rem;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border);
    font-size: 0.875rem;
    color: var(--text-dark);
    background-color: var(--card-bg);
    transition: border-color 0.2s;
    cursor: pointer;
    min-width: 140px;
}

.preset-select:focus,
.tp-range-select:focus {
    border-color: var(--blue);
    outline: none;
    box-shadow: 0 0 0 3px rgba(0,149,200,.1);
}


/* ── 14. LOGIN PAGE ──────────────────────────────────────────
   Centred login card on the index.php page.
   ---------------------------------------------------------- */

/* Full-screen background for the login page */
.login-page {
    min-height: 100vh;
    background: linear-gradient(135deg, var(--sidebar-bg) 0%, #2d3748 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1rem;
}

/* White login card */
.login-card {
    background: var(--card-bg);
    border-radius: var(--radius);
    padding: 2.5rem 2rem;
    width: 100%;
    max-width: 380px;
    box-shadow: 0 20px 60px rgba(0,0,0,.3);
}

/* Logo / brand inside the login card */
.login-logo {
    text-align: center;
    margin-bottom: 1.75rem;
}

.login-logo img {
    max-height: 56px;
    margin-bottom: 0.75rem;
}

.login-logo h1 {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--text-dark);
    margin: 0;
}

.login-logo p {
    font-size: 0.8rem;
    color: var(--text-light);
    margin: 0.25rem 0 0;
}

/* Labels in login form */
.login-card label {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--text-mid);
}

/* Inputs in login form */
.login-card input {
    width: 100%;
    padding: 0.55rem 0.75rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    font-size: 0.9rem;
    margin-top: 0.25rem;
    margin-bottom: 0.9rem;
    transition: border-color 0.2s;
}

.login-card input:focus {
    border-color: var(--blue);
    outline: none;
    box-shadow: 0 0 0 3px rgba(0,149,200,.1);
}

/* Remember me row – checkbox and label aligned */
.login-card .remember-me-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin: 0.25rem 0 0.75rem;
}

.login-card .remember-me-row input[type="checkbox"] {
    width: 1rem;
    height: 1rem;
    min-width: 1rem;
    margin: 0;
    padding: 0;
    border: none;
    flex-shrink: 0;
    cursor: pointer;
    accent-color: var(--blue);
    vertical-align: middle;
}

.login-card .remember-me-row label {
    margin: 0;
    font-size: 0.85rem;
    color: var(--text-mid);
    cursor: pointer;
    line-height: 1.25;
}

/* Login submit button */
.login-submit {
    width: 100%;
    padding: 0.65rem;
    background: var(--blue);
    color: var(--on-primary);
    border: none;
    border-radius: var(--radius-sm);
    font-weight: 600;
    font-size: 0.95rem;
    cursor: pointer;
    transition: background 0.2s;
}

.login-submit:hover {
    background: var(--blue-mid);
}

/* Error message on failed login */
.login-error {
    background: var(--yellow-pale);
    border: 1px solid var(--yellow);
    color: var(--yellow-dark);
    border-radius: var(--radius-sm);
    padding: 0.5rem 0.75rem;
    font-size: 0.85rem;
    margin-bottom: 1rem;
}

/* Success message on login / setup pages */
.login-success {
    background: #f0fdf4;
    border: 1px solid #86efac;
    color: #15803d;
    border-radius: var(--radius-sm);
    padding: 0.5rem 0.75rem;
    font-size: 0.85rem;
    margin-bottom: 1rem;
}

/* Verify page – resend code row (centered, tight spacing) */
.verify-resend-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    margin-top: 0.5rem;
    font-size: 0.85rem;
    color: var(--text-mid);
}

.verify-resend-form {
    display: inline;
}

.verify-resend-btn {
    background: none;
    border: none;
    padding: 0;
    color: var(--blue);
    font-size: 0.85rem;
    cursor: pointer;
    text-decoration: none;
}

.verify-resend-btn:hover {
    text-decoration: underline;
}

/* Inline alert banners used on admin pages */
.alert-success-custom {
    background: #f0fdf4;
    border: 1px solid #86efac;
    color: #15803d;
    border-radius: var(--radius-sm);
    padding: 0.6rem 1rem;
    font-size: 0.875rem;
    margin-bottom: 0.75rem;
}
.alert-danger-custom {
    background: var(--yellow-pale);
    border: 1px solid var(--yellow);
    color: var(--yellow-dark);
    border-radius: var(--radius-sm);
    padding: 0.6rem 1rem;
    font-size: 0.875rem;
    margin-bottom: 0.75rem;
}


/* ── 15. WALLBOARD PAGE ──────────────────────────────────────
   Full-screen auto-refresh display for wall screens.
   ---------------------------------------------------------- */

/* Wallboard body override – dark theme by default */
body.wallboard {
    background: #0f172a;
    color: var(--text-mid);
    overflow: hidden;
}

/* Light theme toggle for wallboard */
body.wallboard.light {
    background: #f8f9ff;
    color: var(--text-dark);
}

/* Wallboard outer grid */
.wallboard-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 1.25rem;
    padding: 1.5rem;
    height: 100vh;
    overflow: hidden;
}

/* Wallboard stat card */
.wall-card {
    background: rgba(255,255,255,.06);
    border-radius: var(--radius);
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    border: 1px solid rgba(255,255,255,.08);
}

/* Light theme wallboard card */
body.wallboard.light .wall-card {
    background: var(--card-bg);
    border-color: var(--border);
    box-shadow: var(--card-shadow);
}

/* Large headline number on wallboard */
.wall-value {
    font-size: 3rem;
    font-weight: 700;
    color: var(--blue);
    line-height: 1;
}

/* Wallboard label */
.wall-label {
    font-size: 0.875rem;
    color: rgba(255,255,255,.55);
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

body.wallboard.light .wall-label {
    color: var(--text-light);
}

/* Missed rate displayed in amber on wallboard */
.wall-value.amber {
    color: var(--yellow);
}

/* Theme toggle button on wallboard */
.wall-theme-toggle {
    position: fixed;
    top: 1rem;
    right: 1rem;
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.2);
    color: rgba(255,255,255,.8);
    border-radius: var(--radius-sm);
    padding: 0.35rem 0.75rem;
    font-size: 0.8rem;
    cursor: pointer;
    transition: background 0.2s;
}

.wall-theme-toggle:hover {
    background: rgba(255,255,255,.18);
}


/* ── 16. MANAGE EXTENSIONS PAGE ──────────────────────────────
   Admin appearance customisation for extensions.
   ---------------------------------------------------------- */

/* Grid of extension cards in the admin page */
.ext-admin-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1rem;
}

/* Single extension admin card */
.ext-admin-card {
    background: var(--card-bg);
    border-radius: var(--radius);
    padding: 1.25rem;
    box-shadow: var(--card-shadow);
    border: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

/* Avatar preview inside the admin card */
.ext-admin-avatar {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    object-fit: cover;
    background: var(--blue-pale);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--blue);
    flex-shrink: 0;
}

.ext-admin-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

/* Text and email input inside the admin card */
.ext-admin-card input[type="text"],
.ext-admin-card input[type="email"] {
    width: 100%;
    padding: 0.4rem 0.65rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    font-size: 0.875rem;
}

.ext-admin-card input[type="text"]:focus,
.ext-admin-card input[type="email"]:focus {
    border-color: var(--blue);
    outline: none;
    box-shadow: 0 0 0 3px rgba(0,149,200,.1);
}

/* Remove photo x button on avatar */
.ext-admin-avatar-wrap {
    position: relative;
}
.ext-admin-avatar {
    position: relative;
    overflow: visible;
}
.ext-admin-avatar-remove {
    position: absolute;
    top: -4px;
    right: -4px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--text-dark);
    color: #fff;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    font-size: 12px;
    line-height: 1;
    box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.ext-admin-avatar-remove:hover {
    background: #dc2626;
}
.ext-admin-avatar-remove i {
    width: 12px;
    height: 12px;
}

/* File upload input */
.ext-admin-card input[type="file"] {
    font-size: 0.8rem;
    color: var(--text-light);
}

.ext-admin-remove-btn {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    padding: 0;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--card-bg);
    color: var(--text-light);
    cursor: pointer;
}

.ext-admin-remove-btn:hover {
    color: #b91c1c;
    border-color: rgba(220, 38, 38, 0.25);
    background: rgba(220, 38, 38, 0.04);
}

.ext-admin-remove-btn i {
    width: 15px;
    height: 15px;
}


/* ── 17. EMPTY STATES ────────────────────────────────────────
   Placeholder when a table or report has no data.
   ---------------------------------------------------------- */

/* Centred empty state box */
.empty-state {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--text-light);
}

/* Icon for empty state */
.empty-state svg,
.empty-state i {
    width: 48px;
    height: 48px;
    margin-bottom: 0.75rem;
    color: var(--blue-pale);
    stroke: var(--blue);
    opacity: 0.5;
}

/* Heading inside empty state */
.empty-state h4 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-mid);
    margin-bottom: 0.25rem;
}

/* Sub-text inside empty state */
.empty-state p {
    font-size: 0.85rem;
    margin: 0;
}


/* ── 18. LOADING STATES ──────────────────────────────────────
   Skeleton placeholder while data is being fetched.
   ---------------------------------------------------------- */

/* Animated skeleton shimmer */
@keyframes shimmer {
    0%   { background-position: -600px 0; }
    100% { background-position: 600px 0; }
}

.skeleton {
    border-radius: 6px;
    background: linear-gradient(90deg, #f0f4f8 25%, #e2eaf3 50%, #f0f4f8 75%);
    background-size: 600px 100%;
    animation: shimmer 1.4s infinite linear;
    display: inline-block;
}

/* Skeleton line widths */
.skeleton.h-20  { height: 20px; }
.skeleton.h-32  { height: 32px; }
.skeleton.h-48  { height: 48px; }
.skeleton.w-full{ width: 100%; display: block; }
.skeleton.w-60  { width: 60%; display: block; }
.skeleton.w-40  { width: 40%; display: block; }

[data-theme="dark"] .skeleton {
    background: linear-gradient(90deg, #334155 25%, #475569 50%, #334155 75%);
}


/* ── 19. ALERTS / NOTIFICATIONS ──────────────────────────────
   Flash messages for form submissions (save success, errors).
   ---------------------------------------------------------- */

/* Base alert */
.alert-custom {
    padding: 0.75rem 1rem;
    border-radius: var(--radius-sm);
    font-size: 0.875rem;
    margin-bottom: 1rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

/* Success alert */
.alert-custom.success {
    background: var(--blue-pale);
    color: var(--blue-deep);
    border: 1px solid var(--blue);
}

/* Warning / attention alert */
.alert-custom.warning {
    background: var(--yellow-pale);
    color: var(--yellow-dark);
    border: 1px solid var(--yellow);
}

/* Global toast (replaces alert() for success/error feedback) */
.app-toast {
    position: fixed;
    right: 18px;
    bottom: 18px;
    z-index: 9999;
    max-width: min(420px, calc(100vw - 36px));
    padding: 10px 14px;
    border-radius: 10px;
    font-size: .9rem;
    font-weight: 500;
    box-shadow: 0 10px 30px rgba(0,0,0,.12);
    backdrop-filter: blur(6px);
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    transition: opacity .25s, visibility .25s, transform .25s;
}
.app-toast.show {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.app-toast[data-variant="ok"] {
    border: 1px solid rgba(22, 163, 74, .3);
    background: rgba(22, 163, 74, .12);
    color: #065f46;
}
[data-theme="dark"] .app-toast[data-variant="ok"] {
    background: rgba(22, 163, 74, .2);
    color: #86efac;
}
.app-toast[data-variant="saving"] {
    border: 1px solid rgba(59, 130, 246, .3);
    background: rgba(59, 130, 246, .12);
    color: #1d4ed8;
}
[data-theme="dark"] .app-toast[data-variant="saving"] {
    background: rgba(59, 130, 246, .2);
    color: #93c5fd;
}
.app-toast[data-variant="error"] {
    border: 1px solid rgba(239, 68, 68, .3);
    background: rgba(239, 68, 68, .12);
    color: #991b1b;
}
[data-theme="dark"] .app-toast[data-variant="error"] {
    background: rgba(239, 68, 68, .2);
    color: #fca5a5;
}


/* ── 20. RESPONSIVE BREAKPOINTS ──────────────────────────────
   At tablet width and below, the sidebar collapses automatically
   and the content grids reduce column count.
   ---------------------------------------------------------- */

@media (max-width: 900px) {
    /* Reduce KPI grid to 3 columns */
    .kpi-grid {
        grid-template-columns: repeat(3, 1fr);
    }
    .kpi-grid-dashboard {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    /* Auto-collapse sidebar to icon-only on small screens (same as .collapsed) */
    .sidebar {
        width: var(--sidebar-collapsed-width) !important;
        min-width: var(--sidebar-collapsed-width) !important;
        overflow: visible;
        z-index: 100;
    }
    .sidebar .nav-section-toggle,
    .sidebar .nav-divider,
    .sidebar .nav-section-label,
    .sidebar .sidebar-brand-text {
        display: none !important;
    }
    .sidebar .nav-section-content {
        display: block !important;
    }
    .sidebar .nav-item {
        justify-content: center;
        padding: 0.65rem 0;
        position: relative;
    }
    .sidebar .nav-label {
        display: none;
    }
    .sidebar .sidebar-logo-area {
        justify-content: center;
    }

    /* Hide the toggle button on mobile (sidebar already auto-collapsed) */
    .sidebar-toggle {
        display: none;
    }

    /* Reduce to 2 KPI columns */
    .kpi-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    .kpi-grid-dashboard {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Stack filter bar items vertically */
    .filter-bar {
        flex-direction: column;
        align-items: stretch;
    }

    /* Full-width filter inputs */
    .filter-select,
    .filter-input {
        min-width: 100%;
    }

    /* Reduce content padding on small screens */
    .content {
        padding: 1rem;
    }

    /* Header wraps on small screens */
    .page-header {
        padding: 0.75rem 1rem;
    }
}

@media (max-width: 480px) {
    /* Single column KPI on mobile */
    .kpi-grid {
        grid-template-columns: 1fr 1fr;
    }
    .kpi-grid-dashboard {
        grid-template-columns: 1fr 1fr;
    }
}

/* ── VIP / Excluded Extensions modal (shared) ─────────────────
   Used by: vip/modals.php, admin/settings.php
   ---------------------------------------------------------- */
.excl-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(15,23,42,.4);
    backdrop-filter: blur(4px);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1050;
    padding: 1rem;
    opacity: 0;
    visibility: hidden;
    transition: opacity .2s, visibility .2s;
}
.excl-modal-overlay[data-open="true"] {
    opacity: 1;
    visibility: visible;
}
.excl-modal-overlay[hidden] { display: none !important; }
.excl-modal {
    background: var(--card-bg);
    border-radius: var(--radius);
    box-shadow: 0 25px 50px -12px rgba(0,0,0,.25);
    width: 100%;
    max-width: 480px;
    max-height: 85vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
.excl-modal-header {
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--border);
    position: relative;
}
.excl-modal-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--text-dark);
    margin: 0 0 .25rem;
}
.excl-modal-subtitle {
    font-size: .8rem;
    color: var(--text-mid);
    margin: 0;
}
.excl-modal-close {
    position: absolute;
    top: 1rem;
    right: 1rem;
    width: 36px;
    height: 36px;
    border: none;
    background: transparent;
    border-radius: 8px;
    cursor: pointer;
    color: var(--text-mid);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .15s, color .15s;
}
.excl-modal-close:hover {
    background: var(--grey-100);
    color: var(--text-dark);
}
.excl-modal-body {
    padding: 1rem 1.5rem 1.5rem;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    gap: .75rem;
}

/* Shared excl-modal list/search/row (VIP + Settings) */
.excl-modal-search {
    display: flex;
    align-items: center;
    gap: .5rem;
    padding: .375rem .65rem;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--card-bg);
    min-width: 0;
    transition: border-color 0.2s;
}
.excl-modal-search input {
    flex: 1;
    border: none;
    background: none;
    font-size: .875rem;
    color: var(--text-dark);
    outline: none;
}
.excl-modal-search input::placeholder {
    color: var(--text-light);
}
.excl-modal-search:focus-within {
    border-color: var(--blue);
    box-shadow: 0 0 0 3px rgba(0,149,200,.1);
}

.excl-modal-list {
    overflow-y: auto;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--card-bg);
}

.excl-modal-row {
    display: flex;
    align-items: center;
    gap: .75rem;
    padding: .6rem 1rem;
    border-bottom: 1px solid var(--border);
    transition: background .12s;
}
.excl-modal-row:last-child { border-bottom: none; }
.excl-modal-row:hover { background: var(--grey-100); }
.excl-modal-row.excl-row-hidden { display: none; }

.excl-modal-name {
    display: block;
    font-size: .9rem;
    font-weight: 500;
    color: var(--text-dark);
}
.excl-modal-ext {
    font-size: .75rem;
    color: var(--text-light);
}
.excl-modal-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .7rem;
    font-weight: 700;
    color: #fff;
    flex-shrink: 0;
    overflow: hidden;
}
.excl-avatar-included {
    background: linear-gradient(135deg, #22c55e, #16a34a);
}
.excl-avatar-excluded {
    background: linear-gradient(135deg, #fbbf24, #d97706);
}
.excl-modal-toggle {
    font-size: .8rem;
    font-weight: 500;
    padding: .35rem .65rem;
    border-radius: 6px;
    border: 1px solid;
    cursor: pointer;
    flex-shrink: 0;
    transition: background .15s, color .15s, border-color .15s;
    font-family: inherit;
}
.excl-toggle-excluded {
    background: rgba(220,38,38,.08);
    color: #dc2626;
    border-color: rgba(220,38,38,.3);
}
.excl-toggle-excluded:hover {
    background: rgba(220,38,38,.15);
}
.excl-toggle-included {
    background: rgba(22,163,74,.08);
    color: #16a34a;
    border-color: rgba(22,163,74,.3);
}
.excl-toggle-included:hover {
    background: rgba(22,163,74,.15);
}
.excl-modal-footer {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    align-items: center;
    justify-content: space-between;
    padding-top: .25rem;
}

/* Body scroll lock when modal open */
body.modal-open { overflow: hidden; }

/* VIP / Marketing manage modal – dark mode (fix poo colour blending) */
[data-theme="dark"] .vip-manage-tabs,
[data-theme="dark"] .vip-manage-tabs .vip-manage-tab {
    background: var(--page-bg);
    color: var(--text-mid);
}
[data-theme="dark"] .vip-manage-tabs .vip-manage-tab.active {
    background: var(--card-bg);
    color: var(--blue);
    border-bottom-color: var(--blue);
}
[data-theme="dark"] .excl-modal-search,
[data-theme="dark"] .filter-input,
[data-theme="dark"] .filter-select,
[data-theme="dark"] .preset-select {
    background-color: var(--card-bg);
    color: var(--text-dark);
    border-color: var(--border);
}
[data-theme="dark"] .filter-select,
[data-theme="dark"] .preset-select,
[data-theme="dark"] .tp-range-select {
    background-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='%2394a3b8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
}
[data-theme="dark"] .multiselect-btn.filter-select {
    background-image: none !important;
}
[data-theme="dark"] .filter-input::placeholder,
[data-theme="dark"] .preset-select option {
    color: var(--text-mid);
}
[data-theme="dark"] .vip-manage-add-fields .filter-input,
[data-theme="dark"] .vip-manage-add-fields .filter-select {
    background: var(--page-bg);
    border-color: var(--border);
    color: var(--text-dark);
}
[data-theme="dark"] .excl-modal-search input::placeholder {
    color: var(--text-mid);
}
[data-theme="dark"] .vip-manage-add,
[data-theme="dark"] .vip-manage-list .excl-modal-row {
    background: var(--page-bg);
    border-color: var(--border);
}
[data-theme="dark"] .vip-manage-list .excl-modal-row:hover {
    background: var(--grey-100);
}
[data-theme="dark"] .excl-modal-row .excl-modal-name {
    color: var(--text-dark);
}
