:root {
    --bg: #f4f7fb;
    --surface: #ffffff;
    --surface-2: #eef3f8;
    --text: #172033;
    --muted: #667085;
    --line: #d9e2ec;
    --blue: #1f6feb;
    --green: #0f9f6e;
    --orange: #e06b18;
    --red: #d92d20;
    --purple: #7c3aed;
    --shadow: 0 18px 45px rgba(28, 43, 68, .09);
}

[data-theme="dark"] {
    --bg: #10141d;
    --surface: #171c27;
    --surface-2: #202838;
    --text: #eef4ff;
    --muted: #a7b1c2;
    --line: #2d3748;
    --shadow: 0 18px 45px rgba(0, 0, 0, .24);
}

* { box-sizing: border-box; }
body { margin: 0; background: var(--bg); color: var(--text); font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; letter-spacing: 0; }
a { color: var(--blue); text-decoration: none; }
.public-page { min-height: 100vh; overflow-x: hidden; background: radial-gradient(circle at 12% 18%, rgba(31,111,235,.18), transparent 30%), radial-gradient(circle at 88% 38%, rgba(15,159,110,.18), transparent 28%), radial-gradient(circle at 44% 88%, rgba(124,58,237,.12), transparent 30%), linear-gradient(135deg, #eef5ff 0%, #f8fbff 48%, #edfdf7 100%); background-attachment: fixed; color: #152033; }
.landing-nav { position: sticky; top: 14px; width: min(1180px, calc(100% - 32px)); z-index: 100; display: flex; align-items: center; justify-content: space-between; gap: 16px; margin: 16px auto; padding: 10px; border: 1px solid rgba(255,255,255,.68); border-radius: 8px; background: rgba(255,255,255,.72); backdrop-filter: blur(22px) saturate(170%); -webkit-backdrop-filter: blur(22px) saturate(170%); box-shadow: 0 24px 70px rgba(28,43,68,.16); }
.landing-brand { display: flex; align-items: center; gap: 10px; color: #172033; min-width: 0; }
.landing-brand small { display: block; color: #667085; font-size: .78rem; }
.landing-nav nav { display: flex; align-items: center; gap: 8px; }
.landing-nav nav a { color: #40516d; font-weight: 700; padding: 9px 10px; border-radius: 8px; }
.landing-nav nav a:hover { background: #eef3f8; color: #172033; }
.landing-actions { display: flex; align-items: center; gap: 8px; }
.landing-hero { position: relative; min-height: calc(100vh - 112px); overflow: hidden; display: flex; align-items: center; padding: 94px max(24px, calc((100vw - 1180px) / 2)) 104px; background: #0f172a; color: white; }
.landing-hero::after { content: ""; position: absolute; inset: auto 0 0; height: 38%; background: linear-gradient(to bottom, rgba(15,23,42,0), rgba(15,23,42,.92)); pointer-events: none; }
.landing-hero-content { position: relative; z-index: 3; width: min(640px, 100%); display: grid; gap: 20px; }
.landing-hero h1 { font-size: clamp(4rem, 11vw, 8.4rem); line-height: .88; margin: 0; color: white; letter-spacing: 0; }
.landing-hero p:not(.eyebrow) { width: min(620px, 100%); font-size: clamp(1.08rem, 2vw, 1.38rem); line-height: 1.6; color: #dbe7f8; margin: 0; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.landing-hero .btn-light { color: #13233d; background: rgba(255,255,255,.92); border-color: rgba(255,255,255,.72); }
.hero-status-strip { width: min(620px, 100%); display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; margin-top: 6px; padding: 12px; border: 1px solid rgba(255,255,255,.22); border-radius: 8px; background: rgba(255,255,255,.1); box-shadow: 0 22px 60px rgba(0,0,0,.2); backdrop-filter: blur(18px) saturate(150%); -webkit-backdrop-filter: blur(18px) saturate(150%); }
.hero-status-strip div { display: grid; grid-template-columns: 12px minmax(0, 1fr) auto; gap: 8px; align-items: center; min-width: 0; color: #eef4ff; padding: 8px; border-radius: 8px; background: rgba(255,255,255,.07); }
.hero-status-strip b { width: 12px; height: 12px; border-radius: 999px; background: #0f9f6e; box-shadow: 0 0 0 5px rgba(15,159,110,.14); }
.hero-status-strip span { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hero-status-strip em { color: #c8d5e8; font-style: normal; font-size: .78rem; white-space: nowrap; }
.landing-hero-scene { position: absolute; inset: 0; overflow: hidden; background: radial-gradient(circle at 78% 22%, rgba(15,159,110,.34), transparent 25%), radial-gradient(circle at 80% 80%, rgba(224,107,24,.24), transparent 26%), linear-gradient(130deg, #0f172a 0%, #172033 48%, #1b3a55 100%); }
.scene-phone { position: absolute; right: max(32px, calc((100vw - 1180px) / 2)); top: 17%; width: min(360px, 30vw); min-width: 280px; display: grid; gap: 12px; padding: 18px; border: 1px solid rgba(255,255,255,.24); border-radius: 28px; background: rgba(255,255,255,.14); box-shadow: 0 36px 90px rgba(0,0,0,.32); backdrop-filter: blur(18px) saturate(150%); -webkit-backdrop-filter: blur(18px) saturate(150%); }
.scene-phone-head { width: 74px; height: 8px; border-radius: 999px; background: rgba(255,255,255,.52); justify-self: center; margin-bottom: 8px; }
.scene-phone article, .landing-proof article, .workflow-grid article, .platform-grid article { border: 1px solid rgba(255,255,255,.62); border-radius: 8px; background: linear-gradient(145deg, rgba(255,255,255,.58), rgba(255,255,255,.32)); box-shadow: 0 22px 60px rgba(28,43,68,.12); backdrop-filter: blur(18px) saturate(155%); -webkit-backdrop-filter: blur(18px) saturate(155%); }
.scene-phone article { display: grid; gap: 3px; padding: 14px; color: #172033; }
.scene-phone article span, .scene-phone article small { color: #667085; }
.scene-pulse { position: absolute; border: 1px solid rgba(255,255,255,.22); border-radius: 999px; animation: landingPulse 6s ease-in-out infinite; }
.scene-pulse.one { width: 220px; height: 220px; right: 12%; top: 12%; }
.scene-pulse.two { width: 360px; height: 360px; right: 24%; bottom: 4%; animation-delay: 1.6s; }
@keyframes landingPulse { 0%, 100% { transform: scale(.96); opacity: .54; } 50% { transform: scale(1.06); opacity: .18; } }
.landing-proof, .landing-stats, .landing-section, .landing-platform, .landing-footer { width: min(1180px, calc(100% - 32px)); margin-left: auto; margin-right: auto; }
.landing-proof { position: relative; z-index: 3; display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; margin-top: -46px; padding: 12px; border: 1px solid rgba(255,255,255,.5); border-radius: 8px; background: rgba(255,255,255,.18); box-shadow: 0 26px 70px rgba(28,43,68,.1); backdrop-filter: blur(18px) saturate(150%); -webkit-backdrop-filter: blur(18px) saturate(150%); }
.landing-proof article { padding: 18px; display: grid; gap: 6px; }
.landing-stats { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin-top: 24px; }
.landing-stats article, .role-path-grid article, .landing-contact-card, .landing-faq-contact details { border: 1px solid rgba(255,255,255,.62); border-radius: 8px; background: linear-gradient(145deg, rgba(255,255,255,.58), rgba(255,255,255,.3)); box-shadow: 0 22px 60px rgba(28,43,68,.1); backdrop-filter: blur(18px) saturate(155%); -webkit-backdrop-filter: blur(18px) saturate(155%); }
.landing-stats article { padding: 18px; display: grid; gap: 4px; }
.landing-stats strong { font-size: clamp(1.8rem, 4vw, 3.2rem); line-height: 1; color: #1f6feb; }
.landing-proof span, .landing-stats span, .workflow-grid span, .role-path-grid span, .landing-platform p, .landing-footer small, .landing-contact-card span, .landing-faq-contact p { color: #667085; }
.landing-section, .landing-platform { position: relative; margin-top: 72px; padding: clamp(28px, 4vw, 46px); border: 1px solid rgba(255,255,255,.62); border-radius: 8px; background: linear-gradient(145deg, rgba(255,255,255,.42), rgba(255,255,255,.22)); box-shadow: 0 30px 90px rgba(28,43,68,.12); backdrop-filter: blur(22px) saturate(155%); -webkit-backdrop-filter: blur(22px) saturate(155%); scroll-margin-top: 104px; }
.landing-section::before, .landing-platform::before { content: ""; position: absolute; inset: 0; border-radius: inherit; background: radial-gradient(circle at 12% 8%, rgba(255,255,255,.48), transparent 34%), radial-gradient(circle at 86% 90%, rgba(15,159,110,.12), transparent 35%); pointer-events: none; }
.landing-section > *, .landing-platform > * { position: relative; z-index: 1; }
.section-heading { display: grid; gap: 8px; margin-bottom: 22px; width: min(720px, 100%); }
.section-heading h2, .landing-platform h2 { font-size: clamp(2rem, 4vw, 3.6rem); line-height: 1.05; margin: 0; letter-spacing: 0; }
.workflow-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; }
.workflow-grid article { min-height: 230px; padding: 20px; display: grid; align-content: start; gap: 12px; }
.workflow-grid i { width: 42px; height: 42px; display: inline-grid; place-items: center; border-radius: 8px; color: white; background: #1f6feb; }
.workflow-grid article:nth-child(2) i { background: #0f9f6e; }
.workflow-grid article:nth-child(3) i { background: #e06b18; }
.workflow-grid article:nth-child(4) i { background: #7c3aed; }
.workflow-grid strong, .role-path-grid strong, .platform-grid strong { font-size: 1.08rem; }
.role-path-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.role-path-grid article { min-height: 190px; padding: 20px; display: grid; align-content: start; gap: 12px; }
.role-path-grid i { width: 42px; height: 42px; display: inline-grid; place-items: center; border-radius: 8px; color: white; background: #0f9f6e; }
.role-path-grid article:nth-child(2) i { background: #e06b18; }
.role-path-grid article:nth-child(3) i { background: #7c3aed; }
.landing-platform { display: grid; grid-template-columns: .9fr 1.1fr; gap: 22px; align-items: center; }
.landing-platform > div:first-child { display: grid; gap: 16px; justify-items: start; }
.platform-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.platform-grid article { min-height: 150px; padding: 20px; display: grid; align-content: space-between; }
.platform-grid span { color: #1f6feb; font-weight: 900; }
.platform-grid article:nth-child(2) span { color: #0f9f6e; }
.platform-grid article:nth-child(3) span { color: #e06b18; }
.platform-grid article:nth-child(4) span { color: #7c3aed; }
.landing-faq-contact { display: grid; grid-template-columns: 1fr .75fr; gap: 18px; align-items: start; }
.landing-faq-contact details { padding: 14px 16px; margin-top: 10px; }
.landing-faq-contact summary { cursor: pointer; font-weight: 900; }
.landing-faq-contact p { margin: 10px 0 0; }
.landing-contact-card { display: grid; gap: 12px; padding: 20px; }
.landing-footer { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 18px 20px; border: 1px solid rgba(255,255,255,.62); border-radius: 8px; background: rgba(255,255,255,.34); box-shadow: 0 20px 60px rgba(28,43,68,.1); backdrop-filter: blur(18px) saturate(150%); -webkit-backdrop-filter: blur(18px) saturate(150%); margin-top: 72px; margin-bottom: 28px; }
.app-shell { min-height: 100vh; display: flex; }
.sidebar { width: 280px; position: sticky; top: 0; height: 100vh; padding: 22px; background: var(--surface); border-right: 1px solid var(--line); display: flex; flex-direction: column; gap: 24px; }
.sidebar, .main, .brand span, .sidebar nav a span, .sidebar-toggle span { transition: width .2s ease, opacity .2s ease, padding .2s ease; }
.brand { display: flex; align-items: center; gap: 12px; color: var(--text); }
.brand small, .user-chip small, td small { display: block; color: var(--muted); font-size: .78rem; }
.brand-mark { width: 44px; height: 44px; display: inline-grid; place-items: center; border-radius: 8px; background: var(--blue); color: white; font-weight: 800; }
.brand-mark.xl { width: 72px; height: 72px; font-size: 1.5rem; margin-bottom: 18px; }
.sidebar nav { display: grid; gap: 6px; }
.sidebar nav a { color: var(--muted); display: flex; gap: 12px; align-items: center; padding: 11px 12px; border-radius: 8px; position: relative; }
.sidebar nav a:hover, .sidebar nav a.active { background: var(--surface-2); color: var(--text); }
.sidebar nav a.active { box-shadow: inset 3px 0 0 var(--blue); font-weight: 800; }
.sidebar nav i { width: 20px; text-align: center; }
.sidebar-toggle { border: 1px solid var(--line); background: var(--surface-2); color: var(--text); border-radius: 8px; min-height: 40px; display: flex; align-items: center; justify-content: center; gap: 10px; }
.nav-counter { margin-left: auto; min-width: 22px; height: 22px; border-radius: 999px; background: var(--red); color: white; display: inline-flex; align-items: center; justify-content: center; font-size: .72rem; padding: 0 6px; }
body.sidebar-collapsed .sidebar { width: 82px; padding: 18px 12px; align-items: center; }
body.sidebar-collapsed .brand span,
body.sidebar-collapsed .sidebar nav a span,
body.sidebar-collapsed .sidebar-toggle span { opacity: 0; width: 0; overflow: hidden; white-space: nowrap; }
body.sidebar-collapsed .sidebar nav a { width: 48px; height: 48px; justify-content: center; padding: 0; }
body.sidebar-collapsed .sidebar nav i { width: auto; }
body.sidebar-collapsed .sidebar-toggle { width: 48px; }
body.sidebar-collapsed .nav-counter { position: absolute; right: -4px; top: 4px; margin-left: 0; min-width: 18px; height: 18px; font-size: .65rem; }
.main { flex: 1; padding: 24px; min-width: 0; }
.topbar { position: sticky; top: 0; z-index: 1040; display: flex; align-items: center; justify-content: space-between; gap: 16px; margin: -24px -24px 22px; padding: 18px 24px; background: color-mix(in srgb, var(--bg) 92%, transparent); backdrop-filter: blur(14px); border-bottom: 1px solid transparent; }
.topbar-title { display: flex; align-items: center; gap: 12px; min-width: 0; }
.topbar-sidebar-toggle { display: none; flex: 0 0 40px; }
.topbar h1 { margin: 0; font-size: 1.7rem; line-height: 1.2; }
.eyebrow { color: var(--muted); text-transform: uppercase; font-weight: 700; font-size: .72rem; letter-spacing: .08em; margin: 0 0 4px; }
.topbar-actions { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.icon-button { width: 40px; height: 40px; border: 1px solid var(--line); background: var(--surface); color: var(--text); border-radius: 8px; position: relative; }
.dot { width: 9px; height: 9px; border-radius: 50%; background: var(--red); position: absolute; top: 8px; right: 9px; border: 2px solid var(--surface); }
.user-chip { display: flex; gap: 10px; align-items: center; border: 1px solid var(--line); background: var(--surface); padding: 6px 10px; border-radius: 8px; }
.user-chip > span { width: 32px; height: 32px; border-radius: 8px; display: grid; place-items: center; background: var(--green); color: white; font-weight: 800; }
.metrics-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; margin-bottom: 18px; }
.metric-card, .panel, .auth-card, .auth-visual { background: var(--surface); border: 1px solid var(--line); border-radius: 8px; box-shadow: var(--shadow); }
.metric-card { padding: 18px; display: grid; gap: 8px; min-height: 132px; }
.metric-card i { font-size: 1.4rem; }
.metric-card span { color: var(--muted); }
.metric-card strong { font-size: 1.45rem; }
.metric-card small { color: var(--muted); font-size: .78rem; }
.blue i, .blue h2 { color: var(--blue); } .green i, .green h2 { color: var(--green); } .orange i, .orange h2 { color: var(--orange); } .red i, .red h2 { color: var(--red); } .purple i, .purple h2 { color: var(--purple); }
.content-grid { display: grid; grid-template-columns: 1.4fr .8fr; gap: 16px; align-items: start; }
.panel { padding: 18px; overflow: hidden; }
.panel.wide { grid-column: span 1; }
.panel h2 { font-size: 1.05rem; margin: 0 0 14px; }
.panel-head { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 12px; }
.panel-head h2 { margin: 0; }
.panel-head span, .muted { color: var(--muted); }
.table { color: var(--text); --bs-table-bg: transparent; --bs-table-color: var(--text); --bs-table-border-color: var(--line); }
.table-tools,
.table-footer,
.table-filter-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
    margin: 10px 0;
}
.table-filter-bar {
    justify-content: flex-start;
    padding: 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-2);
}
.table-filter-bar .form-select {
    width: auto;
    min-width: 160px;
}
.table-search input {
    min-width: min(280px, 100%);
}
.dataTables_wrapper .dataTables_length,
.dataTables_wrapper .dataTables_filter,
.dataTables_wrapper .dataTables_info,
.dataTables_wrapper .dataTables_paginate {
    color: var(--muted) !important;
}
.dataTables_wrapper .dataTables_filter label,
.dataTables_wrapper .dataTables_length label {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--muted);
}
.dataTables_wrapper .dataTables_paginate .paginate_button {
    border-radius: 8px !important;
    border: 1px solid var(--line) !important;
    background: var(--surface) !important;
    color: var(--text) !important;
    margin: 0 2px !important;
}
.dataTables_wrapper .dataTables_paginate .paginate_button.current {
    background: var(--blue) !important;
    color: #fff !important;
    border-color: var(--blue) !important;
}
.status { display: inline-flex; padding: 5px 9px; border-radius: 999px; background: var(--surface-2); border: 1px solid var(--line); font-size: .78rem; font-weight: 700; }
.status-badge, .priority-badge {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 5px 10px;
    border-radius: 999px;
    border: 1px solid var(--line);
    font-size: .78rem;
    font-weight: 800;
    white-space: normal;
    max-width: 100%;
    line-height: 1.2;
    text-align: center;
}
.status-draft { color: #475467; background: #f2f4f7; border-color: #d0d5dd; }
.status-submitted { color: #175cd3; background: #eff8ff; border-color: #b2ddff; }
.status-awaiting-funding { color: #b54708; background: #fffaeb; border-color: #fedf89; }
.status-funded { color: #027a48; background: #ecfdf3; border-color: #abefc6; }
.status-assigned { color: #3538cd; background: #eef4ff; border-color: #c7d7fe; }
.status-accepted-pending-approval { color: #b54708; background: #fffaeb; border-color: #fedf89; }
.status-awaiting-client-payment { color: #b54708; background: #fffaeb; border-color: #fedf89; }
.status-approved { color: #027a48; background: #ecfdf3; border-color: #abefc6; }
.status-in-progress { color: #026aa2; background: #f0f9ff; border-color: #b9e6fe; }
.status-purchased { color: #6941c6; background: #f4f3ff; border-color: #d9d6fe; }
.status-delivered, .status-completed { color: #067647; background: #ecfdf3; border-color: #abefc6; }
.status-cancelled, .status-declined { color: #b42318; background: #fef3f2; border-color: #fecdca; }
.status-active { color: #067647; background: #ecfdf3; border-color: #abefc6; }
.status-disabled { color: #344054; background: #f2f4f7; border-color: #d0d5dd; }
.status-suspended { color: #b42318; background: #fef3f2; border-color: #fecdca; }
.status-under-review { color: #175cd3; background: #eff8ff; border-color: #b2ddff; }
.status-rejected { color: #b42318; background: #fef3f2; border-color: #fecdca; }
.status-disbursed { color: #026aa2; background: #f0f9ff; border-color: #b9e6fe; }
.status-reconciled { color: #067647; background: #ecfdf3; border-color: #abefc6; }
.status-pending-review { color: #b54708; background: #fffaeb; border-color: #fedf89; }
.status-paid { color: #067647; background: #ecfdf3; border-color: #abefc6; }
.status-pending, .status-not-started { color: #475467; background: #f2f4f7; border-color: #d0d5dd; }
.priority-low { color: #475467; background: #f2f4f7; border-color: #d0d5dd; }
.priority-normal { color: #175cd3; background: #eff8ff; border-color: #b2ddff; }
.priority-high { color: #b54708; background: #fffaeb; border-color: #fedf89; }
.priority-urgent { color: #b42318; background: #fef3f2; border-color: #fecdca; }
.notice-list, .stack-form, .chat-thread, .report-grid { display: grid; gap: 10px; }
.notice { padding: 12px; border-radius: 8px; background: var(--surface-2); border-left: 4px solid var(--blue); }
.notice span, .notice small, .chat-message span, .report-card span { display: block; color: var(--muted); }
.notice.success { border-color: var(--green); } .notice.warning { border-color: var(--orange); }
.kyc-access-banner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 18px;
    padding: 14px 16px;
    border: 1px solid #f5c46b;
    border-left: 5px solid var(--orange);
    border-radius: 8px;
    background: #fff7e8;
    color: #172033;
    box-shadow: 0 10px 24px rgba(245, 158, 11, 0.12);
}
.kyc-access-banner strong {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 1rem;
}
.kyc-access-banner span {
    display: block;
    margin-top: 3px;
    color: #5f4b1d;
}
.kyc-access-banner .btn {
    flex: 0 0 auto;
}
.rating-row { display: grid; grid-template-columns: 1fr auto; gap: 4px; padding: 12px 0; border-bottom: 1px solid var(--line); }
.rating-row small { color: var(--muted); grid-column: 1 / -1; }
.rating-row .link-button { grid-column: 1 / -1; justify-self: start; }
.star-display { color: #f59e0b; letter-spacing: .04em; }
.link-button { border: 0; background: transparent; padding: 0; color: var(--blue); font: inherit; }
.link-button:hover { text-decoration: underline; }
.panel:has(.table),
.modal-body:has(.table) {
    overflow: hidden;
}
#orderViewModal .modal-dialog {
    max-height: calc(100vh - 56px);
}
#orderViewModal .modal-content {
    max-height: calc(100vh - 56px);
    overflow: hidden;
}
#orderViewModal #orderViewBody {
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    max-height: calc(100vh - 132px);
    -webkit-overflow-scrolling: touch;
}
.table-scroll,
.dataTables_wrapper {
    max-width: 100%;
    min-width: 0;
}
.table-scroll {
    overflow-x: auto;
    overflow-y: visible;
    padding-bottom: 4px;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
}
.table-scroll > .table,
.dataTables_wrapper table.dataTable,
.table.data-table,
.workstation-table {
    min-width: 760px;
    width: 100% !important;
}
.dashboard-tracking-table { min-width: 860px; }
.table th,
.table td {
    vertical-align: middle;
}
.dashboard-tracking-table th:nth-child(1),
.dashboard-tracking-table td:nth-child(1) { width: 64px; white-space: nowrap; }
.dashboard-tracking-table th:nth-child(2),
.dashboard-tracking-table td:nth-child(2) { min-width: 250px; }
.dashboard-tracking-table th:nth-child(3),
.dashboard-tracking-table td:nth-child(3) { min-width: 110px; }
.dashboard-tracking-table th:nth-child(4),
.dashboard-tracking-table td:nth-child(4) { min-width: 120px; }
.dashboard-tracking-table th:nth-child(5),
.dashboard-tracking-table td:nth-child(5) { min-width: 118px; white-space: nowrap; }
.dashboard-tracking-table th:nth-child(6),
.dashboard-tracking-table td:nth-child(6) { min-width: 132px; }
.dashboard-tracking-table th:nth-child(7),
.dashboard-tracking-table td:nth-child(7) { min-width: 92px; }
.dataTables_scroll,
.dataTables_scrollHead,
.dataTables_scrollBody,
.dataTables_scrollHeadInner {
    width: 100% !important;
    max-width: 100% !important;
}
.dataTables_scrollBody {
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
}
.dataTables_scrollBody table {
    margin-bottom: 0 !important;
}
.dashboard-tracking-table tbody tr[data-dashboard-request] { cursor: pointer; }
.dashboard-tracking-table tbody tr[data-dashboard-request]:hover { background: var(--surface-2); }
.module-hero { border-radius: 8px; color: white; padding: 24px; margin-bottom: 16px; display: flex; justify-content: space-between; align-items: center; gap: 18px; background: var(--blue); }
.module-hero.green { background: var(--green); } .module-hero.orange { background: var(--orange); } .module-hero.red { background: var(--red); } .module-hero.purple { background: var(--purple); }
.module-hero h2 { margin: 0 0 8px; font-size: 1.9rem; }
.module-hero p { max-width: 780px; margin-bottom: 0; }
.module-hero .eyebrow { color: rgba(255,255,255,.74); }
.auth-main { min-height: 100vh; width: 100%; display: grid; place-items: center; padding: 24px; }
.auth-panel { width: min(1080px, 100%); display: grid; grid-template-columns: 1.1fr .8fr; gap: 18px; }
.auth-visual, .auth-card { padding: clamp(24px, 4vw, 44px); }
.auth-visual { position: relative; overflow: hidden; background: radial-gradient(circle at 16% 16%, rgba(31,111,235,.28), transparent 28%), radial-gradient(circle at 84% 76%, rgba(15,159,110,.22), transparent 30%), linear-gradient(135deg, #101827 0%, #13233d 52%, #173047 100%); color: white; min-height: 560px; display: flex; flex-direction: column; justify-content: center; }
.auth-visual::after { content: ""; position: absolute; inset: 18px; border: 1px solid rgba(255,255,255,.12); border-radius: 8px; pointer-events: none; }
.auth-visual p { color: #c8d5e8; font-size: 1.12rem; max-width: 560px; }
.auth-card { display: grid; align-content: center; gap: 12px; }
.auth-card h2, .auth-visual h1 { font-size: 2rem; margin: 0; }
.auth-card label { font-weight: 700; font-size: .9rem; }
.auth-highlight-grid { position: relative; z-index: 1; display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin: 22px 0; }
.auth-highlight-grid span { display: flex; align-items: center; gap: 9px; min-height: 48px; padding: 10px 12px; border: 1px solid rgba(255,255,255,.17); border-radius: 8px; background: rgba(255,255,255,.08); color: #eef4ff; font-weight: 700; font-size: .9rem; box-shadow: inset 0 1px 0 rgba(255,255,255,.08); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); }
.auth-highlight-grid i { color: #78d9b5; }
.auth-footnote { margin: 4px 0 0; color: var(--muted); font-size: .9rem; line-height: 1.5; }
.demo-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 8px; margin: 18px 0; }
.demo-grid span { background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15); padding: 8px; border-radius: 8px; font-size: .85rem; }
.chat-message, .report-card { border: 1px solid var(--line); background: var(--surface-2); border-radius: 8px; padding: 12px; }
.report-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.report-card { display: grid; gap: 8px; }
.workstation { padding: 20px; }
.full-workstation { width: 100%; }
.page-wide { grid-column: 1 / -1; max-width: none; }
.profile-workstation { display: grid; gap: 16px; }
.profile-summary-panel { display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.profile-identity { display: flex; align-items: center; gap: 16px; }
.profile-avatar.xl { width: 72px; height: 72px; font-size: 1.5rem; }
.profile-badge-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; }
.profile-info-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.profile-info-grid article span { display: block; color: var(--muted); font-size: .82rem; }
.profile-info-grid article strong { font-weight: 600; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.labeled-form label { display: grid; gap: 6px; font-weight: 700; font-size: .9rem; }
.span-2 { grid-column: span 2; }
.form-section-title { font-weight: 800; margin: 16px 0 10px; }
.kyc-preview-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; margin-top: 12px; }
#kycCompleteModal .modal-dialog {
    max-width: min(1280px, calc(100vw - 48px));
}
#kycCompleteModal .modal-body {
    overflow-x: hidden;
}
#kycCompleteModal .form-grid > label,
#kycCompleteModal .media-upload-field,
#kycCompleteModal .receipt-preview {
    min-width: 0;
}
#kycCompleteModal .receipt-preview {
    overflow: hidden;
}
#kycCompleteModal .receipt-preview img {
    aspect-ratio: 16 / 9;
    max-height: 220px;
    object-fit: cover;
}
#kycCompleteModal .receipt-preview span,
#kycCompleteModal .media-upload-name {
    word-break: break-word;
}
.dropdown-item i { width: 20px; }
.users-action-dropdown { position: relative; }
.users-action-menu {
    min-width: 220px;
    z-index: 1400;
    box-shadow: 0 14px 34px rgba(15, 23, 42, .16);
}
.users-action-dropdown.dropup .users-action-menu {
    margin-bottom: 8px !important;
}
.modal-tab-content { padding-top: 14px; }
.wallet-tabs-panel { display: grid; gap: 14px; }
.wallet-tabs { border-bottom: 1px solid var(--line); gap: 4px; }
.wallet-tabs .nav-link { color: var(--muted); border-radius: 8px 8px 0 0; display: inline-flex; align-items: center; gap: 8px; }
.wallet-tabs .nav-link.active { color: var(--blue); background: var(--surface-2); border-color: var(--line) var(--line) var(--surface-2); font-weight: 800; }
.wallet-tab-content { min-height: 360px; }
.wallet-tab-content .tab-pane,
.wallet-tab-content .dataTables_wrapper,
.wallet-tab-content .row,
.wallet-tab-content .col-sm-12 { width: 100%; }
.wallet-tab-content .dataTables_scroll,
.wallet-tab-content .dataTables_scrollHead,
.wallet-tab-content .dataTables_scrollBody,
.wallet-tab-content .dataTables_scrollHeadInner { width: 100% !important; }
.wallet-tab-content table.dataTable { width: 100% !important; }
.wallet-full-table { width: 100% !important; table-layout: auto; }
.transaction-summary-table td { vertical-align: top; }
.transaction-summary-table small { display: block; color: var(--muted); margin-top: 3px; }
.escrow-summary-table td { vertical-align: top; }
.escrow-summary-table small { display: block; color: var(--muted); margin-top: 3px; }
.amount-stack { min-width: 220px; display: grid; gap: 6px; }
.amount-stack span { display: grid; grid-template-columns: 74px minmax(0, 1fr); gap: 10px; align-items: baseline; }
.amount-stack em { color: var(--muted); font-style: normal; font-size: .78rem; }
.amount-stack strong { text-align: right; font-weight: 800; }
.amount-stack span:last-child { padding-top: 6px; border-top: 1px solid var(--line); }
.tab-pane-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; margin: 2px 0 14px; }
.tab-pane-head h3 { font-size: 1.02rem; margin: 0 0 4px; }
.tab-pane-head p { margin: 0; }
.kyc-review-summary { border: 1px solid var(--line); background: var(--surface-2); border-radius: 8px; padding: 12px; }
.workstation-head { align-items: flex-start; }
.toolbar-actions { display: flex; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.workstation-table th:last-child, .workstation-table td:last-child { width: 170px; }
.workstation-table th:nth-child(5), .workstation-table td:nth-child(5) { min-width: 210px; }
.request-title { display: block; font-weight: 500; color: var(--text); line-height: 1.35; }
.request-title-modal { font-weight: 500; line-height: 1.35; }
.request-title .request-unread-pill { margin-left: 8px; vertical-align: middle; }
.request-unread-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    border-radius: 999px;
    background: var(--red);
    color: #fff;
    font-size: .68rem;
    font-weight: 800;
    line-height: 1;
}
.request-chat-button { position: relative; overflow: visible; }
.request-chat-button .request-unread-pill {
    position: absolute;
    top: -10px;
    right: -12px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    font-size: .62rem;
    z-index: 2;
    border: 1px solid #fff;
    color: #fff;
    text-shadow: none;
}
.row-actions { display: flex; align-items: center; gap: 6px; }
.icon-button.danger { color: var(--red); }
.icon-button.success { color: var(--green); }
.icon-button.warning { color: var(--orange); }
.flow-stats { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; margin: 12px 0 16px; }
.flow-stats.wallet-stats { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.flow-stats article { border: 1px solid var(--line); background: var(--surface-2); border-radius: 8px; padding: 12px; }
.flow-stats span { display: block; color: var(--muted); font-size: .8rem; }
.flow-stats strong { font-size: 1.25rem; }
.request-status-stack { display: grid; gap: 6px; min-width: 190px; }
.request-status-stack span { display: grid; grid-template-columns: 58px minmax(0, 1fr); align-items: center; gap: 8px; }
.request-status-stack em { color: var(--muted); font-style: normal; font-size: .7rem; }
.request-status-stack .status-badge,
.request-status-stack .eta-badge { justify-self: start; min-height: 24px; padding: 3px 8px; font-size: .72rem; max-width: 128px; overflow-wrap: anywhere; }
.item-editor-head { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 10px; }
.item-editor-head h6 { margin: 0; font-weight: 800; }
.request-items { display: grid; gap: 8px; }
.request-item-row { display: grid; grid-template-columns: minmax(150px, 1fr) minmax(70px, 90px) minmax(110px, 140px) minmax(110px, 130px) 42px; gap: 8px; align-items: center; }
.request-item-row .item-total { text-align: right; }
.total-box { display: grid; grid-template-columns: 1fr auto; gap: 8px 12px; background: var(--surface-2); border: 1px solid var(--line); border-radius: 8px; padding: 14px; }
.total-box span { color: var(--muted); }
.total-box .grand { font-size: 1.1rem; color: var(--text); border-top: 1px solid var(--line); padding-top: 10px; margin-top: 2px; }
.detail-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; margin-bottom: 18px; }
.detail-grid.compact { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.detail-grid article { border: 1px solid var(--line); background: var(--surface-2); border-radius: 8px; padding: 12px; }
.detail-grid span { display: block; color: var(--muted); font-size: .82rem; }
.detail-grid .status-badge, .detail-grid .priority-badge { display: inline-flex; margin-top: 4px; }
.request-summary { display: grid; grid-template-columns: 1.2fr .9fr .75fr .75fr; gap: 0; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; margin-bottom: 10px; }
.request-summary div { min-width: 0; padding: 8px 12px; background: var(--surface-2); border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.request-summary div:nth-child(4n) { border-right: 0; }
.request-summary div:nth-last-child(-n+4) { border-bottom: 0; }
.request-summary .summary-main { grid-column: span 1; }
.request-summary span, .charge-breakdown span { display: block; color: var(--muted); font-size: .76rem; }
.request-summary strong, .charge-breakdown strong { display: block; margin-top: 2px; font-size: .92rem; line-height: 1.25; overflow-wrap: anywhere; }
.request-summary .status-badge, .request-summary .priority-badge { min-height: 24px; padding: 3px 8px; font-size: .72rem; }
.request-summary div:nth-child(7) strong {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 3px 8px;
    border-radius: 999px;
    color: #b54708;
    background: #fffaeb;
    border: 1px solid #fedf89;
    font-size: .78rem;
}
.charge-breakdown { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 0; border: 1px solid var(--line); border-radius: 8px; overflow: hidden; margin-bottom: 12px; }
.charge-breakdown div { min-width: 0; background: var(--surface); padding: 8px 12px; border-right: 1px solid var(--line); }
.charge-breakdown div:last-child { border-right: 0; }
.charge-breakdown .grand { background: var(--text); color: var(--surface); border-color: var(--text); }
.charge-breakdown .grand span { color: rgba(255,255,255,.72); }
.charge-breakdown .grand strong { font-size: 1rem; }
.payment-notice { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 4px 12px; margin-bottom: 16px; }
.payment-notice strong, .payment-notice span { grid-column: 1; }
.payment-notice .btn { grid-column: 2; grid-row: 1 / span 2; }
.payment-choice-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; }
.payment-choice-card { min-height: 132px; border: 1px solid var(--line); background: var(--surface-2); color: var(--text); border-radius: 8px; padding: 14px; text-align: left; display: grid; gap: 8px; align-content: start; }
.payment-choice-card i { color: var(--blue); font-size: 1.25rem; }
.payment-choice-card strong, .payment-choice-card span { display: block; }
.payment-choice-card span { color: var(--muted); font-size: .84rem; line-height: 1.35; }
.payment-choice-card.active { border-color: var(--blue); background: var(--surface); box-shadow: inset 3px 0 0 var(--blue); }
.payment-choice-card:disabled { opacity: .55; cursor: not-allowed; }
.payment-account-editor { display: grid; gap: 10px; }
.paystack-settings-card { --network-color: #00a3ff; display: grid; grid-template-columns: minmax(220px, 1fr) minmax(220px, 1fr) 140px; gap: 10px; align-items: end; border: 1px solid color-mix(in srgb, var(--network-color) 42%, var(--line)); background: var(--surface-2); border-radius: 8px; padding: 10px; margin-top: 12px; box-shadow: inset 4px 0 0 var(--network-color); }
.paystack-card-label { grid-column: 1 / -1; display: flex; flex-wrap: wrap; align-items: center; gap: 8px; color: var(--text); }
.paystack-card-label small { color: var(--muted); font-weight: 500; }
.paystack-dot { width: 12px; height: 12px; border-radius: 50%; background: var(--network-color); box-shadow: 0 0 0 2px color-mix(in srgb, var(--network-color) 22%, transparent); }
.paystack-settings-card .form-label { font-size: .76rem; margin-bottom: 4px; color: var(--muted); }
.payment-account-row { --network-color: var(--blue); display: grid; grid-template-columns: 140px repeat(3, minmax(140px, 1fr)) 110px 42px; gap: 8px; align-items: end; border: 1px solid color-mix(in srgb, var(--network-color) 42%, var(--line)); background: var(--surface-2); border-radius: 8px; padding: 10px; box-shadow: inset 4px 0 0 var(--network-color); }
.payment-account-row.payment-account-bank { --network-color: #475467; grid-template-columns: 140px repeat(2, minmax(160px, 1fr)) 110px 42px; }
.payment-account-row.network-mtn { --network-color: #ffcc00; }
.payment-account-row.network-telecel { --network-color: #e60000; }
.payment-account-row.network-at { --network-color: #005baa; }
.payment-account-row.network-g-money { --network-color: #00a651; }
.payment-account-row.network-zeepay { --network-color: #7c3aed; }
.payment-account-row .form-label { font-size: .76rem; margin-bottom: 4px; color: var(--muted); }
.payment-account-row > div,
.payment-account-row > label {
    min-width: 0;
}
.network-select-wrap { position: relative; }
.network-select-wrap .form-select { padding-left: 34px; }
.network-swatch { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); z-index: 2; width: 12px; height: 12px; border-radius: 50%; background: var(--network-color); box-shadow: 0 0 0 2px color-mix(in srgb, var(--network-color) 22%, transparent); }
.manual-account-preview { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; margin-top: 10px; }
.manual-account-preview article { border: 1px solid var(--line); background: var(--surface-2); border-radius: 8px; padding: 10px 12px; min-width: 0; }
.manual-account-preview .network-preview { border-color: color-mix(in srgb, var(--network-color) 46%, var(--line)); box-shadow: inset 4px 0 0 var(--network-color); }
.manual-account-preview .network-mtn { --network-color: #ffcc00; }
.manual-account-preview .network-telecel { --network-color: #e60000; }
.manual-account-preview .network-at { --network-color: #005baa; }
.manual-account-preview .network-g-money { --network-color: #00a651; }
.manual-account-preview .network-zeepay { --network-color: #7c3aed; }
.manual-account-preview span { display: block; color: var(--muted); font-size: .76rem; }
.manual-account-preview strong { display: block; overflow-wrap: anywhere; }
.modal-badge-preview { margin-top: 8px; }
.actual-item-row { display: grid; grid-template-columns: minmax(150px, 1fr) minmax(70px, 90px) minmax(110px, 130px) minmax(110px, 130px); gap: 8px; align-items: center; }
.actual-item-row small { color: var(--muted); }
.receipt-preview { margin-top: 10px; border: 1px solid var(--line); background: var(--surface-2); border-radius: 8px; padding: 10px; display: grid; gap: 8px; color: var(--muted); }
.receipt-preview.empty { min-height: 76px; place-items: center; }
.receipt-preview img { width: 100%; max-height: 280px; object-fit: contain; border-radius: 6px; background: var(--surface); }
.receipt-preview span { font-size: .88rem; color: var(--muted); }
.media-upload-field { display: grid; gap: 8px; }
.media-upload-input.visually-hidden-native {
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}
.media-upload-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}
.media-upload-actions .btn {
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    white-space: normal;
}
.media-upload-name {
    color: var(--muted);
    font-size: .8rem;
    line-height: 1.35;
    overflow-wrap: anywhere;
}
.media-capture-modal .modal-body { display: grid; gap: 12px; }
.media-capture-stage {
    position: relative;
    overflow: hidden;
    border-radius: 8px;
    border: 1px solid var(--line);
    background: #05070d;
    min-height: min(62vh, 520px);
    display: grid;
    place-items: center;
}
.media-capture-stage video,
.media-capture-stage canvas {
    width: 100%;
    height: 100%;
    max-height: min(62vh, 520px);
    object-fit: cover;
    background: #05070d;
}
.face-guide {
    position: absolute;
    inset: 0;
    display: grid;
    place-items: center;
    pointer-events: none;
}
.face-guide::after {
    content: "CENTER FACE";
    position: absolute;
    top: 14px;
    left: 50%;
    transform: translateX(-50%);
    border-radius: 999px;
    background: rgba(15, 23, 42, .76);
    color: #fff;
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .06em;
    padding: 7px 12px;
}
.face-guide span {
    width: min(52vw, 280px);
    aspect-ratio: 3 / 4;
    border: 3px solid rgba(255, 255, 255, .86);
    border-radius: 50%;
    box-shadow: 0 0 0 999px rgba(0, 0, 0, .24), 0 0 24px rgba(31, 111, 235, .32);
    transition: border-color .18s ease, box-shadow .18s ease;
}
.face-guide.missing span,
.face-guide.warning span {
    border-color: #f79009;
    box-shadow: 0 0 0 999px rgba(0, 0, 0, .3), 0 0 28px rgba(247, 144, 9, .46);
}
.face-guide.missing::after,
.face-guide.warning::after {
    content: "OUT OF FRAME";
    background: rgba(181, 71, 8, .92);
}
.face-guide.detected span {
    border-color: #12b76a;
    box-shadow: 0 0 0 999px rgba(0, 0, 0, .18), 0 0 28px rgba(18, 183, 106, .44);
}
.face-guide.detected::after {
    content: "IN FRAME";
    background: rgba(6, 118, 71, .92);
}
.media-capture-status {
    min-height: 42px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-2);
    color: var(--muted);
    padding: 10px 12px;
}
.media-capture-status.warning {
    color: #b54708;
    background: #fffaeb;
    border-color: #fedf89;
}
.media-capture-status.success {
    color: #067647;
    background: #ecfdf3;
    border-color: #abefc6;
}
.media-capture-status.danger {
    color: #b42318;
    background: #fef3f2;
    border-color: #fecdca;
}
.item-photo-preview { margin-top: 10px; display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; border: 1px solid var(--line); background: var(--surface-2); border-radius: 8px; padding: 10px; }
.item-photo-preview.empty { min-height: 76px; place-items: center; grid-template-columns: 1fr; color: var(--muted); }
.item-photo-preview figure { margin: 0; display: grid; gap: 6px; min-width: 0; }
.item-photo-preview img { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: 6px; background: var(--surface); border: 1px solid var(--line); }
.item-photo-preview figcaption { color: var(--muted); font-size: .76rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.modal-action-row { display: flex; justify-content: flex-end; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.party-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin-bottom: 18px; }
.party-card { position: relative; border: 1px solid var(--line); background: var(--surface-2); border-radius: 8px; padding: 12px 132px 12px 12px; }
.party-card span, .party-card small { display: block; color: var(--muted); }
.party-actions { position: absolute; top: 50%; right: 12px; transform: translateY(-50%); display: flex; align-items: center; gap: 12px; }
.party-card .contact-icon {
    width: auto;
    min-width: 0;
    height: auto;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    color: var(--text);
    font-size: 1.08rem;
    line-height: 1;
}
.party-card .contact-icon:hover {
    background: transparent;
    color: var(--blue);
}
.party-card .contact-icon.success {
    color: #16a34a;
}
.party-card .contact-icon.success:hover {
    color: #12823b;
}
.icon-button.disabled { opacity: .45; pointer-events: auto; cursor: not-allowed; }
.timeline-list { list-style: none; padding: 0; margin: 0 0 18px; display: grid; gap: 8px; }
.timeline-list li { border-left: 3px solid var(--blue); background: var(--surface-2); border-radius: 0 8px 8px 0; padding: 10px 12px; }
.timeline-list span { display: block; color: var(--muted); font-size: .82rem; }
.rating-strip { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }
.rating-pill { border: 1px solid var(--line); background: var(--surface-2); border-radius: 8px; padding: 8px 10px; }
.rating-pill span, .rating-pill small { display: block; color: var(--muted); font-size: .8rem; }
.rating-pill strong { color: #f59e0b; letter-spacing: .04em; }
.review-detail { text-align: left; border: 1px solid var(--line); border-radius: 8px; padding: 10px 12px; margin-bottom: 8px; }
.review-detail strong { color: #f59e0b; display: block; }
.review-detail span, .review-detail small { display: block; color: var(--muted); }
.chat-workspace { display: grid; grid-template-columns: 360px minmax(0, 1fr); gap: 16px; min-height: 640px; grid-column: 1 / -1; }
.chat-workspace + .panel,
.chat-workspace ~ .panel { display: none; }
.chat-sidebar-panel, .chat-conversation-panel { border: 1px solid var(--line); background: var(--surface); border-radius: 8px; box-shadow: var(--shadow); overflow: hidden; }
.chat-sidebar-panel { display: flex; flex-direction: column; min-height: 640px; }
.chat-panel-head, .chat-conversation-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; padding: 16px; border-bottom: 1px solid var(--line); }
.chat-panel-head h2, .chat-conversation-head h2 { margin: 0 0 4px; font-size: 1.05rem; }
.chat-panel-head p, .chat-conversation-head p { margin: 0; }
.chat-filters { display: flex; gap: 6px; padding: 10px; border-bottom: 1px solid var(--line); overflow-x: auto; }
.chat-filters button { display: inline-flex; align-items: center; gap: 7px; border: 1px solid var(--line); background: var(--surface-2); color: var(--muted); border-radius: 999px; padding: 6px 10px; font-weight: 700; font-size: .78rem; white-space: nowrap; }
.chat-filters button.active { color: white; background: var(--blue); border-color: var(--blue); }
.chat-filter-count {
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(31, 111, 235, .14);
    color: var(--blue);
    font-size: .72rem;
    font-weight: 900;
}
.chat-filters button.active .chat-filter-count {
    background: rgba(255, 255, 255, .22);
    color: #fff;
}
.chat-thread-list { padding: 10px; overflow: auto; display: grid; gap: 8px; }
.chat-thread-item { width: 100%; display: grid; grid-template-columns: 38px 1fr auto; gap: 10px; align-items: center; border: 1px solid var(--line); background: var(--surface-2); color: var(--text); border-radius: 8px; padding: 10px; text-align: left; }
.chat-thread-item.active { border-color: var(--blue); box-shadow: inset 3px 0 0 var(--blue); background: var(--surface); }
.chat-thread-icon { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 8px; color: var(--blue); background: rgba(31,111,235,.1); }
.chat-thread-copy { min-width: 0; display: grid; gap: 2px; }
.chat-thread-copy strong, .chat-thread-copy small, .chat-thread-copy em { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.chat-thread-copy small, .chat-thread-copy em { color: var(--muted); font-size: .78rem; font-style: normal; }
.chat-unread-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--red); }
.chat-empty-list, .chat-empty-state { color: var(--muted); text-align: center; padding: 28px 14px; }
.chat-empty-state { min-height: 260px; display: grid; place-items: center; align-content: center; gap: 8px; }
.chat-empty-state i { color: var(--blue); font-size: 2rem; }
.chat-conversation-panel { min-height: 640px; display: grid; grid-template-rows: auto minmax(0, 1fr) auto; }
.chat-status-pill { display: inline-flex; align-items: center; gap: 8px; border: 1px solid #abefc6; color: #067647; background: #ecfdf3; border-radius: 999px; padding: 6px 10px; font-size: .8rem; font-weight: 800; }
.chat-status-pill span { width: 8px; height: 8px; border-radius: 50%; background: #12b76a; }
.chat-messages { padding: 18px; overflow: auto; display: flex; flex-direction: column; gap: 10px; background: linear-gradient(180deg, var(--surface), var(--surface-2)); }
.chat-bubble { max-width: min(680px, 78%); border: 1px solid var(--line); border-radius: 8px; padding: 10px 12px; background: var(--surface); box-shadow: 0 8px 22px rgba(28,43,68,.06); }
.chat-bubble.mine { align-self: flex-end; background: var(--blue); border-color: var(--blue); color: white; }
.chat-bubble.theirs { align-self: flex-start; }
.chat-bubble p { margin: 6px 0 0; white-space: pre-wrap; }
.chat-bubble-meta { display: flex; justify-content: space-between; gap: 12px; font-size: .76rem; color: var(--muted); }
.chat-bubble.mine .chat-bubble-meta { color: rgba(255,255,255,.78); }
.chat-party-label { color: var(--party-color); font-weight: 800; }
.chat-bubble.mine .chat-party-label {
    display: inline-flex;
    align-items: center;
    padding: 1px 5px;
    border-radius: 999px;
    background: rgba(255, 255, 255, .92);
}
.chat-party-label em {
    display: inline-flex;
    align-items: center;
    margin-left: 5px;
    padding: 1px 6px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--party-color) 14%, transparent);
    color: var(--party-color);
    font-style: normal;
    font-size: .72em;
    font-weight: 800;
}
.chat-party-separator { color: var(--muted); }
.chat-composer { display: grid; grid-template-columns: 1fr 44px 52px; gap: 10px; padding: 12px; border-top: 1px solid var(--line); background: var(--surface); align-items: end; }
.chat-composer.disabled { opacity: .55; pointer-events: none; }
.chat-composer textarea { resize: none; min-height: 46px; max-height: 140px; }
.chat-compose-stack { display: grid; gap: 8px; }
.quick-reply-strip { display: flex; gap: 6px; flex-wrap: wrap; }
.quick-reply-strip button { border: 1px solid var(--line); background: var(--surface-2); color: var(--text); border-radius: 999px; min-height: 30px; padding: 4px 10px; font-size: .78rem; font-weight: 800; }
.quick-reply-strip button:hover { border-color: var(--blue); color: var(--blue); }
.chat-attach-button { display: inline-grid; place-items: center; margin: 0; cursor: pointer; }
.chat-attachment-preview { display: grid; grid-template-columns: repeat(5, minmax(0, 86px)); gap: 8px; }
.chat-attachment-preview.empty { display: none; }
.chat-attachment-preview figure { margin: 0; position: relative; }
.chat-attachment-preview img { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: 6px; border: 1px solid var(--line); background: var(--surface-2); }
.chat-attachment-preview figcaption { color: var(--muted); font-size: .68rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.chat-attachment-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 128px)); gap: 8px; margin-top: 8px; }
.chat-attachment-grid img { width: 100%; aspect-ratio: 1; object-fit: cover; border-radius: 6px; border: 1px solid rgba(255,255,255,.24); background: var(--surface-2); }
.chat-bubble.theirs .chat-attachment-grid img { border-color: var(--line); }
.secret-code-panel { display: flex; justify-content: space-between; align-items: center; gap: 12px; border: 1px solid #abefc6; background: #ecfdf3; border-radius: 8px; padding: 12px; margin-top: 12px; }
.secret-code-panel span, .secret-code-panel small { display: block; color: #067647; }
.secret-code-panel strong { font-size: 1.55rem; letter-spacing: .12em; color: #064e3b; }
.milestone-strip { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 8px; margin: 12px 0; }
.milestone-strip span { min-height: 42px; display: inline-flex; align-items: center; justify-content: center; gap: 7px; padding: 8px; border: 1px solid var(--line); border-radius: 8px; background: var(--surface-2); color: var(--muted); font-size: .8rem; font-weight: 800; text-align: center; }
.milestone-strip span.done { border-color: #abefc6; background: #ecfdf3; color: #067647; }
.milestone-strip i { font-size: .72rem; }
.profile-summary { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.profile-avatar { width: 48px; height: 48px; border-radius: 8px; display: grid; place-items: center; background: var(--green); color: white; font-weight: 800; }
.profile-summary h6, .profile-summary p { margin: 0; }
.profile-grid { grid-template-columns: 1fr 1fr; }
.star-input { display: flex; gap: 4px; margin-bottom: 14px; }
.star-input button { border: 0; background: transparent; color: #f59e0b; font-size: 1.8rem; padding: 2px; }
.star-input button.inactive { color: #d0d5dd; }
.code-block { background: #111827; color: #d1fae5; padding: 16px; border-radius: 8px; overflow: auto; margin-top: 16px; }
.toast-stack { position: fixed; right: 20px; bottom: 20px; display: grid; gap: 10px; z-index: 2000; }
.app-toast { background: var(--surface); border: 1px solid var(--line); border-left: 4px solid var(--green); box-shadow: var(--shadow); border-radius: 8px; padding: 12px 14px; min-width: 260px; }
.form-control, .form-select { background-color: var(--surface); color: var(--text); border-color: var(--line); }
.form-control:focus, .form-select:focus { background-color: var(--surface); color: var(--text); border-color: var(--blue); box-shadow: 0 0 0 .2rem rgba(31,111,235,.18); }
.form-control::placeholder { color: var(--muted); opacity: 1; }
.form-control:disabled, .form-control[readonly], .form-select:disabled { background-color: var(--surface-2); color: var(--muted); border-color: var(--line); opacity: 1; }
.modal-content { background: var(--surface); color: var(--text); border: 1px solid var(--line); box-shadow: var(--shadow); }
.modal-header, .modal-footer { border-color: var(--line); background: var(--surface); }
.modal-body { background: var(--surface); color: var(--text); }
#orderModal .modal-dialog,
#orderViewModal .modal-dialog {
    width: min(1180px, calc(100vw - 48px));
    max-width: none;
}
#paystackModal .modal-dialog {
    width: min(1120px, calc(100vw - 32px));
    max-width: none;
}
#orderModal .modal-content,
#orderViewModal .modal-content,
#paystackModal .modal-content {
    max-width: 100%;
}
#orderModal .modal-body,
#orderViewModal .modal-body {
    overflow-x: hidden;
}
.modal-title, .modal h1, .modal h2, .modal h3, .modal h4, .modal h5, .modal h6, .modal label, .form-label { color: var(--text); }
.modal .btn-close { filter: var(--close-filter, none); opacity: .78; }
.modal .btn-close:hover { opacity: 1; }
.modal .table { --bs-table-bg: transparent; --bs-table-color: var(--text); --bs-table-border-color: var(--line); color: var(--text); }
.modal .table th, .modal .table td { color: var(--text); border-color: var(--line); }
.modal .table thead th { color: var(--text); background: var(--surface); }
.modal .dropdown-menu { background: var(--surface); border-color: var(--line); color: var(--text); }
.modal .dropdown-item { color: var(--text); }
.modal .dropdown-item:hover { background: var(--surface-2); color: var(--text); }
.swal2-popup { background: var(--surface) !important; color: var(--text) !important; border: 1px solid var(--line); }
.swal2-title, .swal2-html-container { color: var(--text) !important; }
.swal2-input { background: var(--surface) !important; color: var(--text) !important; border-color: var(--line) !important; }

@media (min-width: 992px) {
    #userModal .modal-dialog,
    #userViewModal .modal-dialog,
    #kycReviewModal .modal-dialog,
    #kycQueueModal .modal-dialog {
        max-width: min(1040px, calc(100vw - 72px));
    }
    #userModal .modal-body,
    #userViewModal .modal-body,
    #kycReviewModal .modal-body,
    #kycQueueModal .modal-body {
        padding: 20px;
    }
}

[data-theme="dark"] { --close-filter: invert(1) grayscale(100%) brightness(180%); }
[data-theme="dark"] .modal-backdrop.show { opacity: .72; }
[data-theme="dark"] .form-select { background-image: var(--bs-form-select-bg-img); }

@media (max-width: 1120px) {
    .landing-nav {
        top: 10px;
        width: calc(100% - 20px);
    }
    .landing-nav nav {
        display: none;
    }
    .landing-hero {
        min-height: auto;
        padding: 86px 24px 82px;
    }
    .scene-phone {
        right: 18px;
        top: 118px;
        width: 310px;
        opacity: .34;
        transform: rotate(-4deg) scale(.96);
        transform-origin: top right;
    }
    .landing-proof,
    .landing-stats,
    .workflow-grid,
    .role-path-grid,
    .landing-faq-contact,
    .landing-platform {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .metrics-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .content-grid, .auth-panel { grid-template-columns: 1fr; }
    .auth-visual { min-height: auto; }
    #kycCompleteModal .modal-dialog {
        max-width: min(760px, calc(100vw - 28px));
        margin-left: auto;
        margin-right: auto;
    }
    #kycCompleteModal .modal-body {
        padding: 16px;
    }
    #kycCompleteModal .form-grid {
        grid-template-columns: 1fr;
    }
    #kycCompleteModal .span-2 {
        grid-column: auto;
    }
    #kycCompleteModal .kyc-preview-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    #kycCompleteModal .media-upload-actions {
        grid-template-columns: repeat(2, minmax(150px, 1fr));
    }
    .request-summary { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .request-summary div:nth-child(4n) { border-right: 1px solid var(--line); }
    .request-summary div:nth-child(2n) { border-right: 0; }
    .request-summary div:nth-last-child(-n+4) { border-bottom: 1px solid var(--line); }
    .request-summary div:nth-last-child(-n+2) { border-bottom: 0; }
}

@media (max-width: 992px) {
    #paystackModal .modal-dialog {
        width: calc(100vw - 24px);
        margin-left: auto;
        margin-right: auto;
    }
    #paystackModal .modal-body {
        overflow-x: hidden;
    }
    .paystack-settings-card {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        align-items: end;
        gap: 10px;
        padding: 12px;
    }
    .payment-account-row,
    .payment-account-row.payment-account-bank {
        grid-template-columns: repeat(2, minmax(0, 1fr)) 44px;
        align-items: end;
        gap: 10px;
        padding: 12px;
    }
    .paystack-card-label {
        grid-column: 1 / -1;
    }
    .paystack-settings-card > div:last-child {
        grid-column: 1 / -1;
    }
    .payment-account-row > div:first-of-type {
        grid-column: 1;
    }
    .payment-account-row .mobile-money-field,
    .payment-account-row .bank-field {
        grid-column: auto;
    }
    .payment-account-row > div:has(select[name="accounts[active][]"]) {
        grid-column: 1;
    }
    .payment-account-row .remove-payment-account {
        grid-column: 3;
        grid-row: 1;
        align-self: end;
    }
    .topbar-sidebar-toggle { display: inline-grid; place-items: center; }
    .didwa-sidebar-toggle,
    .mobile-sidebar-toggle {
        display: none !important;
    }
}

@media (max-width: 1100px) {
    #chatWorkstation .chat-sidebar-panel {
        position: fixed !important;
        top: 74px !important;
        bottom: 0 !important;
        left: 0 !important;
        width: min(420px, 100vw) !important;
        max-width: 100vw !important;
        height: auto !important;
        margin: 0 !important;
        border-radius: 0 8px 8px 0 !important;
        z-index: 1300 !important;
        transform: translateX(-105%) !important;
        transition: transform 180ms ease !important;
        background: var(--surface) !important;
    }

    #chatWorkstation.didwa-show-list .chat-sidebar-panel,
    #chatWorkstation.chat-list-open .chat-sidebar-panel {
        transform: translateX(0) !important;
    }

    #chatWorkstation .chat-thread-list {
        padding-left: 10px !important;
        margin-left: 0 !important;
    }
}

@media (max-width: 760px) {
    .landing-nav {
        position: sticky;
        top: 0;
        width: 100%;
        border-radius: 0;
        border-left: 0;
        border-right: 0;
        padding: 10px 14px;
    }
    .landing-brand small,
    .landing-actions .btn-outline-primary {
        display: none;
    }
    .landing-actions .btn {
        padding: 8px 10px;
    }
    .landing-hero {
        display: block;
        padding: 56px 18px 56px;
    }
    .landing-hero-content {
        position: relative;
        gap: 16px;
    }
    .landing-hero h1 {
        font-size: clamp(3.4rem, 18vw, 5.4rem);
    }
    .hero-actions .btn {
        width: 100%;
    }
    .hero-status-strip {
        grid-template-columns: 1fr;
    }
    .hero-status-strip div {
        grid-template-columns: 12px minmax(0, 1fr);
    }
    .hero-status-strip em {
        grid-column: 2;
    }
    .scene-phone {
        position: absolute;
        right: -118px;
        top: 190px;
        width: 330px;
        min-width: 0;
        transform: rotate(-5deg);
        opacity: .2;
    }
    .landing-hero-scene {
        position: absolute;
    }
    .landing-proof {
        margin-top: -18px;
    }
    .landing-proof,
    .landing-stats,
    .workflow-grid,
    .role-path-grid,
    .landing-faq-contact,
    .landing-platform,
    .platform-grid {
        grid-template-columns: 1fr;
    }
    .workflow-grid article {
        min-height: 0;
    }
    .landing-section,
    .landing-platform {
        padding-top: 54px;
    }
    .landing-footer {
        flex-direction: column;
        align-items: flex-start;
    }
    .party-grid { grid-template-columns: 1fr; }
    .party-card { padding-right: 118px; }
    .party-actions { gap: 10px; }
    .kyc-access-banner {
        align-items: flex-start;
        flex-direction: column;
    }
    .kyc-access-banner .btn {
        width: 100%;
        justify-content: center;
    }
    #orderModal .modal-dialog,
    #orderViewModal .modal-dialog,
    #paystackModal .modal-dialog {
        width: calc(100vw - 16px);
        margin-left: auto;
        margin-right: auto;
    }
    .payment-choice-grid,
    .manual-account-preview { grid-template-columns: 1fr; }
    .payment-notice { grid-template-columns: 1fr; }
    .payment-notice .btn { grid-column: 1; grid-row: auto; justify-self: start; }
    .milestone-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    #paystackModal .modal-body { padding: 14px; }
    #paystackModal .modal-footer { align-items: stretch; }
    #paystackModal .modal-footer .btn { width: 100%; }
    .paystack-settings-card,
    .payment-account-row,
    .payment-account-row.payment-account-bank {
        grid-template-columns: 1fr;
        gap: 10px;
    }
    .paystack-card-label,
    .paystack-settings-card > div:last-child,
    .payment-account-row > div:first-of-type,
    .payment-account-row > div:has(select[name="accounts[active][]"]),
    .payment-account-row .remove-payment-account {
        grid-column: 1;
        grid-row: auto;
    }
    .payment-account-row .icon-button { width: 100%; }
    .app-shell { display: block; }
    .sidebar { width: 100%; height: auto; position: static; }
    .sidebar nav { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .main { padding: 16px; }
    .topbar { margin: -16px -16px 16px; padding: 12px 16px; align-items: center; flex-direction: row; }
    .topbar-title { flex: 1 1 auto; }
    .topbar-sidebar-toggle { display: inline-grid; place-items: center; }
    .topbar-actions { justify-content: flex-end; gap: 8px; }
    .topbar-actions .user-chip { max-width: 170px; }
    .topbar-actions .user-chip div { display: none; }
    .module-hero { align-items: flex-start; flex-direction: column; }
    .metrics-grid, .report-grid { grid-template-columns: 1fr; }
    .flow-stats { grid-template-columns: 1fr; }
    .detail-grid { grid-template-columns: 1fr 1fr; }
    .request-summary { grid-template-columns: 1fr; }
    .request-summary div,
    .request-summary div:nth-child(2n),
    .request-summary div:nth-child(4n) { border-right: 0; }
    .request-summary div:nth-last-child(-n+2) { border-bottom: 1px solid var(--line); }
    .request-summary div:last-child { border-bottom: 0; }
    .charge-breakdown { grid-template-columns: 1fr; }
    .charge-breakdown div { border-right: 0; border-bottom: 1px solid var(--line); }
    .charge-breakdown div:last-child { border-bottom: 0; }
    .chat-workspace { grid-template-columns: 1fr; }
    .chat-sidebar-panel, .chat-conversation-panel { min-height: auto; }
    .chat-bubble { max-width: 92%; }
    .payment-notice { grid-template-columns: 1fr; }
    .payment-notice .btn { grid-column: 1; grid-row: auto; justify-self: start; }
    .actual-item-row { grid-template-columns: 1fr; border: 1px solid var(--line); border-radius: 8px; padding: 10px; }
    .item-photo-preview { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    #kycCompleteModal .modal-dialog {
        max-width: calc(100vw - 16px);
        margin: 8px auto;
    }
    #kycCompleteModal .modal-header,
    #kycCompleteModal .modal-footer {
        padding: 12px 16px;
    }
    #kycCompleteModal .modal-title {
        font-size: 1.1rem;
    }
    #kycCompleteModal .kyc-review-summary {
        display: none;
    }
    #kycCompleteModal .kyc-preview-grid {
        grid-template-columns: 1fr;
    }
    #kycCompleteModal .receipt-preview img {
        max-height: 240px;
    }
    .media-upload-actions { grid-template-columns: 1fr; }
    .media-capture-stage { min-height: 360px; }
    .request-item-row { grid-template-columns: 1fr; border: 1px solid var(--line); border-radius: 8px; padding: 10px; }
    .request-item-row .item-total { text-align: left; }
    .toolbar-actions { width: 100%; justify-content: stretch; }
    .toolbar-actions .btn { flex: 1 1 auto; }
    .profile-summary-panel, .profile-identity { align-items: flex-start; flex-direction: column; }
    .profile-info-grid, .form-grid, .kyc-preview-grid { grid-template-columns: 1fr; }
    .span-2 { grid-column: auto; }
    .demo-grid,
    .auth-highlight-grid { grid-template-columns: 1fr; }
    .table-tools,
    .table-footer,
    .table-filter-bar,
    .dataTables_wrapper .dataTables_filter label,
    .dataTables_wrapper .dataTables_length label {
        align-items: stretch;
        flex-direction: column;
        width: 100%;
    }
    .table-search,
    .table-search label,
    .table-search input,
    .table-length,
    .table-length label,
    .table-length select,
    .table-filter-bar .form-select {
        width: 100% !important;
        min-width: 0 !important;
    }
    .table-footer .dataTables_info,
    .table-footer .dataTables_paginate {
        width: 100%;
        text-align: left !important;
    }
}
/* Chat page full-width workspace overrides */
.content-grid:has(.chat-workspace) {
    grid-template-columns: minmax(0, 1fr) !important;
}

.module-grid:has(.chat-workspace),
.workspace-grid:has(.chat-workspace),
.dashboard-grid:has(.chat-workspace),
.module-body:has(.chat-workspace) {
    grid-template-columns: minmax(0, 1fr) !important;
}

.content-grid:has(.chat-workspace) > .panel:not(:has(.chat-workspace)) {
    display: none !important;
}

.module-grid:has(.chat-workspace) > .panel:not(:has(.chat-workspace)),
.workspace-grid:has(.chat-workspace) > .panel:not(:has(.chat-workspace)),
.dashboard-grid:has(.chat-workspace) > .panel:not(:has(.chat-workspace)),
.module-body:has(.chat-workspace) > .panel:not(:has(.chat-workspace)) {
    display: none !important;
}

.content-grid:has(.chat-workspace) > .panel:has(.chat-workspace) {
    grid-column: 1 / -1 !important;
    width: 100% !important;
    max-width: none !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

.module-grid:has(.chat-workspace) > .panel:has(.chat-workspace),
.workspace-grid:has(.chat-workspace) > .panel:has(.chat-workspace),
.dashboard-grid:has(.chat-workspace) > .panel:has(.chat-workspace),
.module-body:has(.chat-workspace) > .panel:has(.chat-workspace),
main:has(.chat-workspace) .panel:has(.chat-workspace) {
    grid-column: 1 / -1 !important;
    width: 100% !important;
    max-width: none !important;
}

main:has(.chat-workspace) .panel:has(.chat-workspace) ~ .panel {
    display: none !important;
}

.content-grid:has(.chat-workspace) > .panel:has(.chat-workspace) > .panel-head {
    display: none !important;
}

.chat-workspace.page-wide {
    display: grid !important;
    grid-template-columns: minmax(320px, 420px) minmax(0, 1fr) !important;
    width: 100% !important;
    max-width: none !important;
    min-height: calc(100vh - 290px) !important;
}

@media (max-width: 992px) {
    .chat-workspace.page-wide {
        grid-template-columns: minmax(0, 1fr) !important;
    }
}
/* Compact chat scrolling */
.chat-workspace,
.chat-workspace.page-wide {
    height: calc(100vh - 230px) !important;
    min-height: 660px !important;
    max-height: none !important;
    overflow: hidden !important;
}

.chat-sidebar,
.chat-panel {
    min-height: 0 !important;
    overflow: hidden !important;
}

.chat-sidebar {
    display: flex !important;
    flex-direction: column !important;
}

.chat-sidebar .chat-list,
.chat-sidebar .conversation-list,
.chat-sidebar [id*="ThreadList"],
.chat-sidebar [id*="threadList"],
.chat-sidebar [data-chat-thread-list] {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding-right: 6px !important;
}

.chat-panel {
    display: grid !important;
    grid-template-rows: auto minmax(0, 1fr) auto !important;
    height: 100% !important;
    min-height: 0 !important;
    overflow: hidden !important;
}

.chat-panel > :first-child {
    min-height: 0 !important;
}

.chat-panel > :nth-child(2) {
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
}

.chat-panel > :last-child {
    min-height: 96px !important;
    max-height: 170px !important;
    overflow: visible !important;
}

.chat-panel .chat-messages,
.chat-panel [id*="Messages"],
.chat-panel [id*="messages"],
.chat-panel [data-chat-messages] {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
}

.chat-composer,
.chat-panel form,
.chat-panel > :last-child {
    position: static !important;
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    width: 100% !important;
    min-height: 96px !important;
    padding: 18px !important;
    z-index: 2 !important;
    background: var(--surface) !important;
    border-top: 1px solid var(--border) !important;
    box-shadow: 0 -10px 24px rgba(15, 23, 42, 0.06) !important;
}

.chat-composer input,
.chat-composer textarea,
.chat-panel form input,
.chat-panel form textarea {
    min-width: 0 !important;
    min-height: 52px !important;
    font-size: 1rem !important;
    background: var(--surface) !important;
    border: 1px solid var(--border) !important;
    border-radius: 8px !important;
}

.chat-composer button,
.chat-panel form button {
    min-width: 52px !important;
    min-height: 52px !important;
    flex: 0 0 auto !important;
}

.chat-panel .empty-state,
.chat-panel .chat-empty {
    min-height: 0 !important;
}

@media (max-width: 992px) {
    .chat-workspace,
    .chat-workspace.page-wide {
        height: auto !important;
        max-height: none !important;
    }

    .chat-sidebar .chat-list,
    .chat-sidebar .conversation-list,
    .chat-sidebar [id*="ThreadList"],
    .chat-sidebar [id*="threadList"],
    .chat-sidebar [data-chat-thread-list] {
        max-height: 320px !important;
    }

    .chat-panel .chat-messages,
    .chat-panel [id*="Messages"],
    .chat-panel [id*="messages"],
    .chat-panel [data-chat-messages] {
        max-height: 520px !important;
    }
}
/* Chat composer width and mobile drawers */
.chat-panel form,
.chat-composer {
    width: 100% !important;
}

.chat-panel form > input,
.chat-panel form > textarea,
.chat-panel form .form-control,
.chat-composer > input,
.chat-composer > textarea,
.chat-composer .form-control {
    flex: 1 1 auto !important;
    width: 100% !important;
    max-width: none !important;
}

.chat-panel form > *:not(button):not(.btn),
.chat-composer > *:not(button):not(.btn) {
    flex: 1 1 auto !important;
    min-width: 0 !important;
    max-width: none !important;
}

.chat-panel form > *:has(i.fa-paperclip),
.chat-panel form > *:has(.fa-paperclip),
.chat-composer > *:has(i.fa-paperclip),
.chat-composer > *:has(.fa-paperclip),
.chat-panel form label,
.chat-composer label {
    flex: 0 0 44px !important;
    width: 44px !important;
    min-width: 44px !important;
    max-width: 44px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.chat-panel form > button,
.chat-panel form > .btn,
.chat-composer > button,
.chat-composer > .btn {
    flex: 0 0 auto !important;
}

.chat-panel .fa-paperclip,
.chat-composer .fa-paperclip {
    margin: 0 !important;
}

.chat-thread-toggle,
.mobile-sidebar-toggle {
    display: none;
}

@media (max-width: 1100px) {
    .chat-workspace,
    .chat-workspace.page-wide,
    .chat-workspace.didwa-chat-ready,
    #chatWorkstation.didwa-chat-ready {
        display: flex !important;
        flex-direction: column !important;
        position: relative !important;
        height: auto !important;
        min-height: 0 !important;
        max-height: none !important;
        overflow: visible !important;
    }

    .didwa-chat-message-pane,
    .chat-panel {
        position: relative !important;
        inset: auto !important;
        transform: none !important;
        display: grid !important;
        grid-template-rows: auto minmax(360px, 1fr) auto !important;
        width: 100% !important;
        min-height: 620px !important;
        height: auto !important;
        z-index: 1 !important;
    }

    .didwa-chat-list-pane,
    .chat-sidebar {
        position: fixed !important;
        top: 106px !important;
        bottom: 0 !important;
        left: 64px !important;
        z-index: 1180 !important;
        width: min(calc(100vw - 82px), 380px) !important;
        height: auto !important;
        max-height: calc(100vh - 106px) !important;
        overflow: hidden !important;
        transform: translateX(-115%) !important;
        transition: transform 180ms ease !important;
        background: var(--surface) !important;
        box-shadow: 14px 0 34px rgba(15, 23, 42, 0.2) !important;
    }

    .chat-workspace.didwa-show-list .didwa-chat-list-pane,
    .chat-workspace.chat-list-open .chat-sidebar,
    #chatWorkstation.didwa-show-list .didwa-chat-list-pane {
        transform: translateX(0) !important;
    }

    .chat-workspace.didwa-show-chat .didwa-chat-list-pane,
    .chat-workspace.chat-thread-active .chat-sidebar,
    #chatWorkstation.didwa-show-chat .didwa-chat-list-pane {
        transform: translateX(-115%) !important;
    }

    .didwa-thread-toggle,
    .chat-thread-toggle {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 42px !important;
        height: 42px !important;
        min-width: 42px !important;
        margin-right: 10px !important;
        border: 1px solid var(--border) !important;
        border-radius: 8px !important;
        background: var(--surface) !important;
        color: var(--text) !important;
    }
}

@media (max-width: 760px) {
    .didwa-chat-message-pane,
    .chat-panel {
        min-height: 560px !important;
        grid-template-rows: auto minmax(300px, 1fr) auto !important;
    }

    .didwa-chat-list-pane,
    .chat-sidebar {
        left: 64px !important;
        width: calc(100vw - 82px) !important;
    }
}

@media (max-width: 1100px) {
    .chat-workspace,
    .chat-workspace.page-wide {
        position: relative !important;
        display: block !important;
        height: calc(100vh - 210px) !important;
        min-height: 620px !important;
    }

    .chat-thread-toggle {
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        width: 42px;
        height: 42px;
        border: 1px solid var(--border);
        border-radius: 8px;
        background: var(--surface);
        color: var(--text);
        margin-right: 10px;
    }

    .chat-sidebar {
        position: absolute !important;
        inset: 0 !important;
        z-index: 20 !important;
        width: 100% !important;
        height: 100% !important;
        transform: translateX(0) !important;
        transition: transform 180ms ease !important;
        box-shadow: 16px 0 36px rgba(15, 23, 42, 0.18) !important;
    }

    .chat-workspace.chat-thread-active .chat-sidebar {
        transform: translateX(-110%) !important;
    }

    .chat-workspace.chat-list-open .chat-sidebar {
        transform: translateX(0) !important;
    }

    .chat-workspace:not(.chat-thread-active) .chat-panel {
        display: none !important;
    }

    .chat-workspace.chat-thread-active .chat-panel {
        display: grid !important;
    }

    .chat-panel {
        width: 100% !important;
        height: 100% !important;
    }
}

@media (max-width: 992px) {
    .mobile-sidebar-toggle {
        display: inline-flex !important;
        position: fixed;
        left: 14px;
        top: 112px;
        z-index: 1065;
        align-items: center;
        justify-content: center;
        width: 46px;
        height: 46px;
        border: 1px solid var(--border);
        border-radius: 8px;
        background: var(--surface);
        color: var(--text);
        box-shadow: var(--shadow);
    }

    body.sidebar-mobile-open .mobile-sidebar-toggle {
        left: min(calc(86vw + 10px), 310px);
    }

    .sidebar,
    .app-sidebar,
    .side-panel,
    .side-nav,
    .navigation-sidebar,
    .layout-nav,
    .app-nav,
    aside.sidebar,
    aside.app-sidebar,
    .app-shell > aside,
    .shell > aside,
    .layout-sidebar {
        position: fixed !important;
        top: 0 !important;
        bottom: 0 !important;
        left: 0 !important;
        z-index: 1060 !important;
        width: min(86vw, 300px) !important;
        max-width: 300px !important;
        transform: translateX(-110%) !important;
        transition: transform 190ms ease !important;
        overflow-y: auto !important;
        box-shadow: 18px 0 40px rgba(15, 23, 42, 0.18) !important;
    }

    body.sidebar-mobile-open .sidebar,
    body.sidebar-mobile-open .app-sidebar,
    body.sidebar-mobile-open .side-panel,
    body.sidebar-mobile-open .side-nav,
    body.sidebar-mobile-open .navigation-sidebar,
    body.sidebar-mobile-open .layout-nav,
    body.sidebar-mobile-open .app-nav,
    body.sidebar-mobile-open aside.sidebar,
    body.sidebar-mobile-open aside.app-sidebar,
    body.sidebar-mobile-open .app-shell > aside,
    body.sidebar-mobile-open .shell > aside,
    body.sidebar-mobile-open .layout-sidebar {
        transform: translateX(0) !important;
        visibility: visible !important;
        opacity: 1 !important;
        pointer-events: auto !important;
    }

    html.sidebar-mobile-open .sidebar,
    html.sidebar-mobile-open .app-sidebar,
    html.sidebar-mobile-open .side-panel,
    html.sidebar-mobile-open .side-nav,
    html.sidebar-mobile-open .navigation-sidebar,
    html.sidebar-mobile-open .layout-nav,
    html.sidebar-mobile-open .app-nav,
    html.sidebar-mobile-open aside.sidebar,
    html.sidebar-mobile-open aside.app-sidebar,
    html.sidebar-mobile-open .app-shell > aside,
    html.sidebar-mobile-open .shell > aside,
    html.sidebar-mobile-open .layout-sidebar {
        transform: translateX(0) !important;
        visibility: visible !important;
        opacity: 1 !important;
        pointer-events: auto !important;
    }

    body.sidebar-mobile-open .sidebar nav,
    body.sidebar-mobile-open .app-sidebar nav,
    body.sidebar-mobile-open .side-panel nav,
    body.sidebar-mobile-open .side-nav,
    body.sidebar-mobile-open .navigation-sidebar nav,
    body.sidebar-mobile-open .layout-nav,
    body.sidebar-mobile-open .app-nav,
    body.sidebar-mobile-open aside nav,
    body.sidebar-mobile-open .layout-sidebar nav,
    body.sidebar-mobile-open .sidebar-menu,
    body.sidebar-mobile-open .nav-menu {
        display: flex !important;
        flex-direction: column !important;
        grid-template-columns: none !important;
        gap: 8px !important;
        align-items: stretch !important;
    }

    body.sidebar-mobile-open .sidebar nav > *,
    body.sidebar-mobile-open .app-sidebar nav > *,
    body.sidebar-mobile-open .side-panel nav > *,
    body.sidebar-mobile-open .side-nav > *,
    body.sidebar-mobile-open .navigation-sidebar nav > *,
    body.sidebar-mobile-open .layout-nav > *,
    body.sidebar-mobile-open .app-nav > *,
    body.sidebar-mobile-open aside nav > *,
    body.sidebar-mobile-open .layout-sidebar nav > *,
    body.sidebar-mobile-open .sidebar-menu > *,
    body.sidebar-mobile-open .nav-menu > * {
        width: 100% !important;
        max-width: none !important;
    }

    body.sidebar-mobile-open .sidebar a,
    body.sidebar-mobile-open .app-sidebar a,
    body.sidebar-mobile-open .side-panel a,
    body.sidebar-mobile-open .side-nav a,
    body.sidebar-mobile-open .navigation-sidebar a,
    body.sidebar-mobile-open .layout-nav a,
    body.sidebar-mobile-open .app-nav a,
    body.sidebar-mobile-open aside a,
    body.sidebar-mobile-open .layout-sidebar a {
        display: flex !important;
        align-items: center !important;
        justify-content: flex-start !important;
        width: 100% !important;
        min-height: 48px !important;
        gap: 12px !important;
        text-align: left !important;
        white-space: normal !important;
    }

    body.sidebar-mobile-open::after {
        content: "";
        position: fixed;
        inset: 0;
        z-index: 1055;
        background: rgba(15, 23, 42, 0.38);
    }

    .main,
    .main-content,
    main,
    .workspace {
        margin-left: 0 !important;
        width: 100% !important;
    }
}
.didwa-fixed-chat-toggle {
    display: none;
}
.chat-list-toggle {
    display: none;
}

.didwa-thread-toggle {
    display: none !important;
}

@media (max-width: 1100px) {
    .didwa-fixed-chat-toggle {
        display: none !important;
        position: fixed !important;
        right: 18px !important;
        top: 214px !important;
        z-index: 1310 !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        min-width: 88px !important;
        height: 44px !important;
        padding: 0 12px !important;
        border: 1px solid var(--border) !important;
        border-radius: 8px !important;
        background: var(--surface) !important;
        color: var(--text) !important;
        box-shadow: var(--shadow) !important;
        font-weight: 700 !important;
    }

    #chatWorkstation .chat-list-toggle {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        width: auto !important;
        min-width: 84px !important;
        height: 40px !important;
        padding: 0 12px !important;
        flex: 0 0 auto !important;
        font-weight: 800 !important;
    }

    #chatWorkstation .chat-list-toggle span {
        display: inline !important;
    }

    #chatWorkstation .didwa-thread-toggle {
        display: none !important;
    }
}

@media (max-width: 640px) {
    #kycCompleteModal .modal-body {
        padding: 12px;
    }
    #kycCompleteModal .media-upload-actions .btn {
        min-height: 46px;
    }
    #kycCompleteModal .modal-footer .btn {
        width: 100%;
    }
    .didwa-fixed-chat-toggle {
        top: 236px !important;
        right: 14px !important;
    }
}

/* Runtime-labelled chat and mobile navigation fixes */
.didwa-chat-composer {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    width: 100% !important;
}

.didwa-chat-message-input {
    flex: 1 1 auto !important;
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
}

.didwa-chat-attach {
    flex: 0 0 44px !important;
    width: 44px !important;
    min-width: 44px !important;
    max-width: 44px !important;
    height: 44px !important;
    padding: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.didwa-chat-attach i,
.didwa-chat-attach svg {
    margin: 0 !important;
}

.didwa-sidebar-toggle {
    display: none;
}

.didwa-thread-toggle {
    display: none;
}

@media (max-width: 1100px) {
    .chat-workspace.didwa-chat-ready,
    #chatWorkstation.didwa-chat-ready {
        position: relative !important;
        display: block !important;
        height: calc(100vh - 160px) !important;
        min-height: 620px !important;
        overflow: hidden !important;
    }

    .didwa-chat-list-pane,
    .didwa-chat-message-pane {
        position: absolute !important;
        inset: 0 !important;
        width: 100% !important;
        height: 100% !important;
        transition: transform 180ms ease !important;
    }

    .didwa-chat-list-pane {
        z-index: 2 !important;
        transform: translateX(0) !important;
        overflow: hidden !important;
    }

    .didwa-chat-message-pane {
        z-index: 1 !important;
        transform: translateX(100%) !important;
        display: grid !important;
        grid-template-rows: auto minmax(0, 1fr) auto !important;
    }

    .didwa-show-chat .didwa-chat-list-pane {
        transform: translateX(-100%) !important;
    }

    .didwa-show-chat .didwa-chat-message-pane {
        transform: translateX(0) !important;
    }

    .didwa-show-list .didwa-chat-list-pane {
        transform: translateX(0) !important;
    }

    .didwa-show-list .didwa-chat-message-pane {
        transform: translateX(100%) !important;
    }

    .didwa-thread-toggle {
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        width: auto;
        min-width: 82px;
        height: 42px;
        margin-right: 10px;
        padding: 0 12px;
        border: 1px solid var(--border);
        border-radius: 8px;
        background: var(--surface);
        color: var(--text);
        gap: 8px;
        font-weight: 700;
    }
}

@media (min-width: 1101px) {
    .didwa-thread-toggle {
        display: none !important;
    }
}

@media (max-width: 992px) {
    .didwa-sidebar-toggle {
        display: inline-flex !important;
        position: fixed !important;
        left: 14px !important;
        top: 112px !important;
        z-index: 1200 !important;
        width: 46px !important;
        height: 46px !important;
        align-items: center !important;
        justify-content: center !important;
        border: 1px solid var(--border) !important;
        border-radius: 8px !important;
        background: var(--surface) !important;
        color: var(--text) !important;
        box-shadow: var(--shadow) !important;
    }

    .didwa-mobile-sidebar {
        position: fixed !important;
        top: 0 !important;
        bottom: 0 !important;
        left: 0 !important;
        z-index: 1190 !important;
        width: min(86vw, 300px) !important;
        max-width: 300px !important;
        transform: translateX(-110%) !important;
        transition: transform 190ms ease !important;
        overflow-y: auto !important;
        background: var(--surface) !important;
        box-shadow: 18px 0 40px rgba(15, 23, 42, 0.22) !important;
    }

    body.didwa-sidebar-open .didwa-mobile-sidebar {
        transform: translateX(0) !important;
    }

    body.didwa-sidebar-open .didwa-sidebar-toggle {
        left: min(calc(86vw + 10px), 310px) !important;
    }

    .didwa-mobile-sidebar nav,
    .didwa-mobile-sidebar .sidebar-menu,
    .didwa-mobile-sidebar .nav-menu,
    .didwa-mobile-sidebar ul {
        display: flex !important;
        flex-direction: column !important;
        grid-template-columns: none !important;
        gap: 8px !important;
        align-items: stretch !important;
    }

    .didwa-mobile-sidebar nav > *,
    .didwa-mobile-sidebar .sidebar-menu > *,
    .didwa-mobile-sidebar .nav-menu > *,
    .didwa-mobile-sidebar ul > * {
        width: 100% !important;
    }

    .didwa-mobile-sidebar a {
        display: flex !important;
        width: 100% !important;
        min-height: 48px !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 12px !important;
        text-align: left !important;
    }

    body.didwa-sidebar-open .sidebar.didwa-mobile-sidebar {
        padding: 22px !important;
        width: min(300px, 86vw) !important;
    }

    body.didwa-sidebar-open.sidebar-collapsed .sidebar.didwa-mobile-sidebar {
        width: 92px !important;
        min-width: 92px !important;
        max-width: 92px !important;
        padding: 18px 10px !important;
        align-items: center !important;
    }

    body.didwa-sidebar-open.sidebar-collapsed .sidebar.didwa-mobile-sidebar .brand span,
    body.didwa-sidebar-open.sidebar-collapsed .sidebar.didwa-mobile-sidebar nav a span {
        display: none !important;
        width: 0 !important;
        opacity: 0 !important;
    }

    body.didwa-sidebar-open.sidebar-collapsed .sidebar.didwa-mobile-sidebar nav a {
        width: 52px !important;
        min-height: 52px !important;
        justify-content: center !important;
        padding: 0 !important;
    }

    body.didwa-sidebar-open .sidebar.didwa-mobile-sidebar .sidebar-toggle {
        display: inline-flex !important;
        width: 100% !important;
        min-height: 44px !important;
        flex: 0 0 auto !important;
    }

    body.didwa-sidebar-open .sidebar.didwa-mobile-sidebar .drawer-close-button {
        display: inline-grid !important;
        place-items: center !important;
        align-self: flex-end !important;
        flex: 0 0 40px !important;
        width: 40px !important;
        height: 40px !important;
        margin-bottom: -8px !important;
    }

    body.didwa-sidebar-open.sidebar-collapsed .sidebar.didwa-mobile-sidebar .sidebar-toggle {
        width: 52px !important;
        min-width: 52px !important;
        padding: 0 !important;
    }

    body.didwa-sidebar-open.sidebar-collapsed .sidebar.didwa-mobile-sidebar .sidebar-toggle span {
        display: none !important;
    }

    body.didwa-sidebar-open.sidebar-collapsed .sidebar.didwa-mobile-sidebar .drawer-close-button {
        align-self: center !important;
        margin-bottom: 0 !important;
    }

    body.didwa-sidebar-open.sidebar-collapsed .sidebar.didwa-mobile-sidebar .brand {
        display: none !important;
    }

    body.didwa-sidebar-open.sidebar-collapsed .sidebar.didwa-mobile-sidebar nav {
        width: 52px !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
    }

    body.didwa-sidebar-open.sidebar-collapsed .sidebar.didwa-mobile-sidebar .nav-counter {
        right: -10px !important;
    }

    body.didwa-mobile-drawer-open.sidebar-collapsed #appSidebar.sidebar.didwa-mobile-sidebar {
        width: 92px !important;
        min-width: 92px !important;
        max-width: 92px !important;
        flex-basis: 92px !important;
    }
}
/* FINAL mobile chat/sidebar reset */
@media (max-width: 1100px) {
    #chatWorkstation,
    .chat-workspace {
        display: block !important;
        position: relative !important;
        height: auto !important;
        min-height: auto !important;
        max-height: none !important;
        overflow: visible !important;
    }

    #chatWorkstation > *,
    .chat-workspace > * {
        transform: none !important;
    }

    #chatWorkstation .chat-panel,
    #chatWorkstation .didwa-chat-message-pane,
    .chat-workspace .chat-panel,
    .chat-workspace .didwa-chat-message-pane {
        display: flex !important;
        flex-direction: column !important;
        position: relative !important;
        inset: auto !important;
        width: 100% !important;
        height: auto !important;
        min-height: 560px !important;
        overflow: hidden !important;
        z-index: 1 !important;
        background: var(--surface) !important;
    }

    #chatWorkstation .chat-sidebar,
    #chatWorkstation .didwa-chat-list-pane,
    .chat-workspace .chat-sidebar,
    .chat-workspace .didwa-chat-list-pane {
        display: flex !important;
        flex-direction: column !important;
        position: fixed !important;
        top: 96px !important;
        bottom: 0 !important;
        left: 64px !important;
        right: auto !important;
        width: min(380px, calc(100vw - 80px)) !important;
        height: auto !important;
        min-height: 0 !important;
        max-height: calc(100vh - 96px) !important;
        overflow: hidden !important;
        z-index: 1300 !important;
        transform: translateX(-120%) !important;
        transition: transform 180ms ease !important;
        background: var(--surface) !important;
        border: 1px solid var(--border) !important;
        box-shadow: 16px 0 36px rgba(15, 23, 42, 0.22) !important;
    }

    #chatWorkstation.didwa-show-list .chat-sidebar,
    #chatWorkstation.didwa-show-list .didwa-chat-list-pane,
    #chatWorkstation.chat-list-open .chat-sidebar,
    .chat-workspace.didwa-show-list .chat-sidebar,
    .chat-workspace.didwa-show-list .didwa-chat-list-pane,
    .chat-workspace.chat-list-open .chat-sidebar {
        transform: translateX(0) !important;
    }

    #chatWorkstation.didwa-show-chat .chat-sidebar,
    #chatWorkstation.didwa-show-chat .didwa-chat-list-pane,
    #chatWorkstation.chat-thread-active .chat-sidebar,
    .chat-workspace.didwa-show-chat .chat-sidebar,
    .chat-workspace.didwa-show-chat .didwa-chat-list-pane,
    .chat-workspace.chat-thread-active .chat-sidebar {
        transform: translateX(-120%) !important;
    }

    #chatWorkstation .chat-messages,
    #chatWorkstation [id*="Messages"],
    #chatWorkstation [id*="messages"],
    #chatWorkstation [data-chat-messages],
    .chat-workspace .chat-messages,
    .chat-workspace [id*="Messages"],
    .chat-workspace [id*="messages"],
    .chat-workspace [data-chat-messages] {
        flex: 1 1 auto !important;
        min-height: 360px !important;
        overflow-y: auto !important;
    }

    #chatWorkstation .chat-composer,
    #chatWorkstation .didwa-chat-composer,
    #chatWorkstation .chat-panel form,
    .chat-workspace .chat-composer,
    .chat-workspace .didwa-chat-composer,
    .chat-workspace .chat-panel form {
        display: flex !important;
        flex-direction: row !important;
        align-items: center !important;
        gap: 8px !important;
        width: 100% !important;
        padding: 12px !important;
        min-height: 72px !important;
        background: var(--surface) !important;
        border-top: 1px solid var(--border) !important;
    }

    #chatWorkstation .chat-composer input,
    #chatWorkstation .chat-composer textarea,
    #chatWorkstation .didwa-chat-message-input,
    #chatWorkstation .chat-panel form input,
    #chatWorkstation .chat-panel form textarea,
    .chat-workspace .chat-composer input,
    .chat-workspace .chat-composer textarea,
    .chat-workspace .didwa-chat-message-input,
    .chat-workspace .chat-panel form input,
    .chat-workspace .chat-panel form textarea {
        flex: 1 1 auto !important;
        width: 100% !important;
        min-width: 0 !important;
        max-width: none !important;
    }

    #chatWorkstation .didwa-chat-attach,
    #chatWorkstation .chat-panel form label,
    #chatWorkstation .chat-panel form button:not([type="submit"]),
    .chat-workspace .didwa-chat-attach,
    .chat-workspace .chat-panel form label,
    .chat-workspace .chat-panel form button:not([type="submit"]) {
        flex: 0 0 42px !important;
        width: 42px !important;
        min-width: 42px !important;
        max-width: 42px !important;
        height: 42px !important;
        padding: 0 !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    #chatWorkstation .chat-panel form button[type="submit"],
    .chat-workspace .chat-panel form button[type="submit"] {
        flex: 0 0 52px !important;
        width: 52px !important;
        min-width: 52px !important;
        height: 52px !important;
    }

    #chatWorkstation .didwa-thread-toggle,
    #chatWorkstation .chat-thread-toggle,
    .chat-workspace .didwa-thread-toggle,
    .chat-workspace .chat-thread-toggle {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        flex: 0 0 42px !important;
        width: 42px !important;
        height: 42px !important;
        min-width: 42px !important;
        padding: 0 !important;
        margin-right: 8px !important;
    }
}

@media (max-width: 992px) {
    aside.didwa-mobile-sidebar,
    nav.didwa-mobile-sidebar,
    .sidebar.didwa-mobile-sidebar,
    .app-sidebar.didwa-mobile-sidebar,
    .layout-sidebar.didwa-mobile-sidebar,
    .side-nav.didwa-mobile-sidebar,
    .side-panel.didwa-mobile-sidebar,
    .navigation-sidebar.didwa-mobile-sidebar {
        display: block !important;
        position: fixed !important;
        top: 0 !important;
        bottom: 0 !important;
        left: 0 !important;
        width: min(300px, 86vw) !important;
        max-width: 300px !important;
        height: 100vh !important;
        overflow-y: auto !important;
        z-index: 1290 !important;
        transform: translateX(-110%) !important;
        transition: transform 190ms ease !important;
        background: var(--surface) !important;
        box-shadow: 18px 0 40px rgba(15, 23, 42, 0.22) !important;
    }

    body.didwa-sidebar-open aside.didwa-mobile-sidebar,
    body.didwa-sidebar-open nav.didwa-mobile-sidebar,
    body.didwa-sidebar-open .sidebar.didwa-mobile-sidebar,
    body.didwa-sidebar-open .app-sidebar.didwa-mobile-sidebar,
    body.didwa-sidebar-open .layout-sidebar.didwa-mobile-sidebar,
    body.didwa-sidebar-open .side-nav.didwa-mobile-sidebar,
    body.didwa-sidebar-open .side-panel.didwa-mobile-sidebar,
    body.didwa-sidebar-open .navigation-sidebar.didwa-mobile-sidebar,
    body.sidebar-mobile-open aside.didwa-mobile-sidebar,
    body.sidebar-mobile-open nav.didwa-mobile-sidebar,
    body.sidebar-mobile-open .sidebar.didwa-mobile-sidebar,
    body.sidebar-mobile-open .app-sidebar.didwa-mobile-sidebar,
    body.sidebar-mobile-open .layout-sidebar.didwa-mobile-sidebar,
    body.sidebar-mobile-open .side-nav.didwa-mobile-sidebar,
    body.sidebar-mobile-open .side-panel.didwa-mobile-sidebar,
    body.sidebar-mobile-open .navigation-sidebar.didwa-mobile-sidebar,
    html.sidebar-mobile-open aside.didwa-mobile-sidebar,
    html.sidebar-mobile-open nav.didwa-mobile-sidebar,
    html.sidebar-mobile-open .sidebar.didwa-mobile-sidebar,
    html.sidebar-mobile-open .app-sidebar.didwa-mobile-sidebar,
    html.sidebar-mobile-open .layout-sidebar.didwa-mobile-sidebar,
    html.sidebar-mobile-open .side-nav.didwa-mobile-sidebar,
    html.sidebar-mobile-open .side-panel.didwa-mobile-sidebar,
    html.sidebar-mobile-open .navigation-sidebar.didwa-mobile-sidebar {
        transform: translateX(0) !important;
    }

    .didwa-sidebar-toggle,
    .mobile-sidebar-toggle {
        display: inline-flex !important;
        position: fixed !important;
        left: 14px !important;
        top: 112px !important;
        z-index: 1320 !important;
        align-items: center !important;
        justify-content: center !important;
        width: 46px !important;
        height: 46px !important;
        padding: 0 !important;
    }

    .didwa-mobile-sidebar nav,
    .didwa-mobile-sidebar ul,
    .didwa-mobile-sidebar .sidebar-menu,
    .didwa-mobile-sidebar .nav-menu {
        display: flex !important;
        flex-direction: column !important;
        grid-template-columns: none !important;
        gap: 8px !important;
    }

    .didwa-mobile-sidebar a {
        display: flex !important;
        width: 100% !important;
        min-height: 48px !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 12px !important;
        text-align: left !important;
    }
}
/* Wallet responsive containment */
@media (max-width: 992px) {
    .panel .dataTables_wrapper,
    .panel .dataTables_scroll,
    .panel .dataTables_scrollHead,
    .panel .dataTables_scrollBody,
    .panel .dataTables_scrollHeadInner {
        max-width: 100% !important;
        min-width: 0 !important;
    }

    .panel .dataTables_wrapper {
        overflow: hidden !important;
    }

    .panel .dataTables_wrapper .row {
        max-width: 100% !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .panel .dataTables_wrapper [class*="col-"] {
        min-width: 0 !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        overflow-x: auto !important;
    }

    .panel .dataTables_wrapper table.dataTable,
    .panel table.dataTable,
    .panel table.workstation-table {
        min-width: 760px !important;
        width: max-content !important;
    }

    .panel .dataTables_wrapper .dataTables_scrollBody,
    .panel .dataTables_wrapper > table,
    .panel .dataTables_wrapper .row + .row,
    .panel .dataTables_wrapper .table-responsive {
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch;
    }

    .panel:has(.dataTables_wrapper) {
        overflow: hidden !important;
    }

    .module-hero {
        min-height: auto !important;
        overflow: visible !important;
        padding: 18px !important;
    }

    .module-hero p,
    .module-hero h2 {
        max-width: 100% !important;
        overflow-wrap: anywhere !important;
    }

    .wallet-tabs-panel,
    .wallet-tab-content,
    .wallet-tab-content .tab-pane,
    .wallet-tab-content .dataTables_wrapper,
    .wallet-tab-content .table-responsive,
    .wallet-tab-content .row,
    .wallet-tab-content .col-sm-12,
    .wallet-full-table {
        max-width: 100% !important;
        min-width: 0 !important;
    }

    .wallet-tabs-panel {
        overflow: hidden !important;
    }

    .wallet-tabs-panel .panel-head,
    .wallet-tabs-panel .tab-pane-head,
    .panel:has(.wallet-tabs) .panel-head,
    .panel:has(.wallet-tabs) .toolbar-actions {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 10px !important;
        width: 100% !important;
    }

    .panel:has(.wallet-tabs) .toolbar-actions .btn,
    .wallet-tabs-panel .toolbar-actions .btn {
        width: 100% !important;
        justify-content: center !important;
    }

    .wallet-tabs {
        display: flex !important;
        flex-wrap: nowrap !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        max-width: 100% !important;
        padding-bottom: 2px !important;
        scrollbar-width: thin;
    }

    .wallet-tabs .nav-item,
    .wallet-tabs .nav-link {
        flex: 0 0 auto !important;
        white-space: nowrap !important;
    }

    .wallet-tab-content {
        overflow: hidden !important;
    }

    .wallet-tab-content table,
    .wallet-tab-content .table,
    .wallet-full-table {
        min-width: 720px !important;
        width: max-content !important;
    }

    .wallet-tab-content .escrow-summary-table {
        min-width: 560px !important;
        width: 100% !important;
    }

    .wallet-tab-content .transaction-summary-table {
        min-width: 620px !important;
        width: 100% !important;
    }

    .wallet-tab-content .tab-pane {
        overflow-x: auto !important;
        overflow-y: visible !important;
        -webkit-overflow-scrolling: touch;
    }

    .wallet-tab-content .dataTables_scroll,
    .wallet-tab-content .dataTables_scrollHead,
    .wallet-tab-content .dataTables_scrollBody,
    .wallet-tab-content .dataTables_scrollHeadInner {
        max-width: 100% !important;
        overflow-x: auto !important;
    }

    .wallet-tab-content .dataTables_wrapper .row {
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    .wallet-tab-content .dataTables_wrapper [class*="col-"] {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }

    .flow-stats.wallet-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 640px) {
    .panel .dataTables_wrapper table.dataTable,
    .panel table.dataTable,
    .panel table.workstation-table {
        min-width: 700px !important;
    }

    .flow-stats.wallet-stats {
        grid-template-columns: 1fr !important;
    }

    .wallet-tab-content table,
    .wallet-tab-content .table,
    .wallet-full-table {
        min-width: 680px !important;
    }

    .wallet-tab-content .escrow-summary-table {
        min-width: 520px !important;
    }

    .wallet-tab-content .transaction-summary-table {
        min-width: 560px !important;
    }
}

/* Reports and activity log */
.reports-workstation,
.activity-log-workstation {
    display: grid;
    gap: 14px;
}

.report-filter-panel {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr)) auto;
    gap: 10px;
    align-items: end;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-2);
}

.report-filter-panel.compact {
    grid-template-columns: repeat(4, minmax(0, 1fr)) auto;
}

.report-filter-panel label {
    display: grid;
    gap: 6px;
    min-width: 0;
    font-weight: 700;
    font-size: .88rem;
}

.report-filter-panel label span {
    color: var(--muted);
}

.report-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
}

.report-summary-grid article {
    border: 1px solid var(--line);
    background: var(--surface-2);
    border-radius: 8px;
    padding: 12px;
}

.report-summary-grid span {
    display: block;
    color: var(--muted);
    font-size: .82rem;
}

.report-summary-grid strong {
    display: block;
    font-size: 1.08rem;
    overflow-wrap: anywhere;
}

.report-actions {
    display: flex;
    justify-content: flex-end;
    gap: 8px;
    flex-wrap: wrap;
}

.report-builder-side {
    display: grid;
    align-content: start;
    gap: 14px;
}

.report-filter-panel.side,
.report-summary-grid.side,
.report-actions.side {
    width: 100%;
}

.report-filter-panel.side {
    grid-template-columns: 1fr;
}

.report-summary-grid.side {
    grid-template-columns: 1fr;
}

.report-actions.side {
    display: grid;
    grid-template-columns: 1fr;
}

.report-actions.side .btn {
    width: 100%;
    justify-content: center;
}

.report-preview-panel {
    overflow: hidden;
}

.reports-tab-workspace {
    display: grid;
    gap: 14px;
}

.reports-head {
    align-items: flex-start;
}

.report-tabs {
    margin-top: 4px;
}

.report-tab-content {
    min-height: 420px;
}

.report-tab-content .tab-pane {
    padding-top: 14px;
}

.report-tab-content .report-grid {
    margin: 0;
}

.report-tab-content .report-card {
    position: relative;
    min-height: 178px;
    align-content: start;
    gap: 10px;
    transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.report-tab-content .report-card:hover,
.report-tab-content .report-card.active {
    border-color: var(--blue);
    box-shadow: 0 12px 28px rgba(31, 111, 235, .12);
    transform: translateY(-1px);
}

.report-card-icon {
    width: 38px;
    height: 38px;
    border-radius: 8px;
    display: inline-grid;
    place-items: center;
    background: color-mix(in srgb, var(--blue) 12%, var(--surface));
    color: var(--blue);
}

.report-tab-content .report-card strong {
    font-size: 1.02rem;
}

.report-tab-content .report-card .btn {
    margin-top: auto;
}

.report-tab-content .report-filter-panel.side,
.report-tab-content .report-summary-grid.side,
.report-tab-content .report-actions.side {
    max-width: 760px;
}

.report-tab-content .report-summary-grid.side,
.report-tab-content .report-actions.side {
    margin-top: 12px;
}

.report-tab-content .report-actions.side {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.report-builder-current {
    display: grid;
    gap: 3px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
}

.report-builder-current span {
    color: var(--muted);
    font-size: .82rem;
}

.report-builder-current strong {
    font-size: 1.12rem;
}

.report-preview-panel .tab-pane-head {
    padding: 2px 0 10px;
}

/* Petty cash */
.petty-workstation {
    display: grid;
    gap: 14px;
    width: 100%;
}

.flow-stats.petty-stats {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin: 0;
}

.petty-toolbar {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-2);
}

.petty-toolbar h3 {
    margin: 0 0 3px;
    font-size: 1.02rem;
}

.petty-table-shell {
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.petty-table {
    width: 100% !important;
}

.petty-table td {
    vertical-align: top;
}

.petty-table td small {
    color: var(--muted);
    margin-top: 3px;
}

.petty-request-form label,
#pettyReconcileForm label {
    display: grid;
    gap: 6px;
    font-weight: 700;
    font-size: .9rem;
}

.petty-items-panel {
    display: grid;
    gap: 10px;
    padding: 12px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface-2);
}

.petty-items-head,
.petty-total-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.petty-items-head h6 {
    margin: 0 0 2px;
    font-weight: 800;
}

.petty-item-rows {
    display: grid;
    gap: 8px;
}

.petty-item-row {
    display: grid;
    grid-template-columns: minmax(180px, 1fr) 92px 140px 130px 44px;
    gap: 8px;
    align-items: center;
}

.petty-item-total {
    min-height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    padding: 0 10px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
}

.petty-total-row {
    padding-top: 10px;
    border-top: 1px solid var(--line);
}

.petty-total-row span {
    color: var(--muted);
    font-weight: 800;
}

.petty-total-row strong {
    font-size: 1.25rem;
}

.petty-receipt-preview,
.petty-receipt-display {
    border: 1px solid var(--line);
    background: var(--soft);
    border-radius: 8px;
    padding: 10px;
}

.petty-receipt-preview {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--muted);
}

.petty-receipt-preview img {
    width: 88px;
    height: 64px;
    object-fit: cover;
    border-radius: 6px;
    border: 1px solid var(--line);
    background: var(--surface);
}

.petty-receipt-display {
    display: grid;
    gap: 8px;
    margin-top: 12px;
}

.petty-reconciliation-grid {
    margin-top: 12px;
    margin-bottom: 10px;
}

.petty-variance-panel {
    display: grid;
    gap: 2px;
    border: 1px solid var(--line);
    border-radius: 8px;
    padding: 10px 12px;
    background: var(--soft);
}

.petty-variance-panel span,
.petty-variance-panel small {
    color: var(--muted);
}

.petty-variance-panel strong {
    font-size: 1.05rem;
}

.petty-variance-panel.is-balanced {
    border-color: #abefc6;
    background: #ecfdf3;
}

.petty-variance-panel.is-return {
    border-color: #b9e6fe;
    background: #f0f9ff;
}

.petty-variance-panel.is-over {
    border-color: #fedf89;
    background: #fffaeb;
}

.petty-variance-panel.is-balanced strong { color: #067647; }
.petty-variance-panel.is-return strong { color: #026aa2; }
.petty-variance-panel.is-over strong { color: #b54708; }

.petty-actual-panel {
    display: grid;
    gap: 8px;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--soft);
    padding: 10px;
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.petty-actual-head,
.petty-actual-row {
    display: grid;
    grid-template-columns: minmax(120px, 1fr) 56px 100px 110px 110px;
    gap: 8px;
    align-items: center;
    min-width: 560px;
}

.petty-actual-head {
    color: var(--muted);
    font-size: .78rem;
    font-weight: 800;
}

.petty-actual-row {
    padding-top: 8px;
    border-top: 1px solid var(--line);
}

.petty-actual-row > span:first-of-type {
    font-weight: 800;
}

#pettyReconcileModal .stack-form,
#pettyReconcileModal .stack-form > *,
#pettyReconcileModal .form-control,
#pettyReconcileModal .petty-variance-panel,
#pettyReconcileModal .petty-receipt-preview {
    min-width: 0;
    max-width: 100%;
}

#pettyReconcileModal .modal-content {
    overflow: hidden;
}

.petty-receipt-display img {
    width: min(100%, 420px);
    max-height: 320px;
    object-fit: contain;
    border-radius: 6px;
    border: 1px solid var(--line);
    background: var(--surface);
}

.petty-overage-summary {
    margin: 12px 0;
}

.petty-overage-review-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) minmax(280px, 0.8fr);
    gap: 12px;
    margin: 12px 0;
}

.petty-overage-section {
    min-width: 0;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--soft);
    padding: 12px;
}

.petty-overage-section .section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}

.petty-overage-section h6 {
    margin: 0;
    font-size: 1rem;
    font-weight: 800;
}

.petty-overage-section .section-head span {
    color: var(--muted);
    font-size: 0.9rem;
}

.petty-overage-table {
    min-width: 640px;
    margin-bottom: 0;
}

.petty-overage-table td,
.petty-overage-table th {
    vertical-align: middle;
}

.petty-variance-value.over {
    color: #b54708;
}

.petty-variance-value.under {
    color: #026aa2;
}

.petty-variance-value.balanced {
    color: #067647;
}

.petty-overage-receipt {
    display: grid;
    place-items: start;
    min-height: 180px;
}

.petty-overage-receipt-link {
    display: block;
    width: 100%;
}

.petty-overage-receipt img {
    width: min(100%, 520px);
    max-height: 520px;
    object-fit: contain;
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--surface);
}

#pettyOverageModal label {
    display: block;
    width: 100%;
}

#pettyOverageModal textarea {
    width: 100%;
    min-height: 110px;
}

#pettyReturnModal label {
    display: block;
    width: 100%;
}

#pettyReturnModal textarea {
    width: 100%;
    min-height: 110px;
}

@media (max-width: 900px) {
    .petty-overage-review-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .petty-overage-table {
        min-width: 560px;
    }

    #pettyOverageModal .modal-footer {
        align-items: stretch;
    }

    #pettyOverageModal .modal-footer .btn {
        width: 100%;
    }
}

.chat-unread-pill {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    min-width: 24px;
    height: 24px;
    padding: 0 7px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--blue);
    color: #fff;
    font-size: .72rem;
    font-weight: 800;
    box-shadow: 0 6px 16px rgba(31, 111, 235, .22);
}

.chat-thread-item:has(.chat-unread-pill) .chat-thread-copy {
    padding-right: 44px;
}

.chat-thread-item {
    position: relative;
    overflow: hidden;
}

.chat-thread-item .chat-unread-pill {
    z-index: 2;
}

/* Final chat independent scroll layout */
#chatWorkstation.chat-workspace.page-wide {
    height: clamp(620px, calc(100vh - 230px), 820px) !important;
    min-height: 620px !important;
    max-height: calc(100vh - 180px) !important;
    overflow: hidden !important;
    align-items: stretch !important;
}

#chatWorkstation .chat-sidebar-panel,
#chatWorkstation .chat-conversation-panel {
    height: 100% !important;
    min-height: 0 !important;
    max-height: 100% !important;
    overflow: hidden !important;
}

#chatWorkstation .chat-sidebar-panel {
    display: grid !important;
    grid-template-rows: auto auto minmax(0, 1fr) !important;
}

#chatWorkstation .chat-filters {
    display: flex !important;
    flex: 0 0 auto !important;
    gap: 8px !important;
    width: 100% !important;
    min-width: 0 !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scrollbar-width: thin;
}

#chatWorkstation .chat-filters button {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 7px !important;
    flex: 0 0 auto !important;
    width: auto !important;
    min-width: max-content !important;
    height: 38px !important;
    padding: 0 14px !important;
    white-space: nowrap !important;
}

#chatWorkstation .chat-thread-list {
    min-height: 0 !important;
    height: 100% !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    overscroll-behavior: contain;
}

#chatWorkstation .chat-conversation-panel {
    display: grid !important;
    grid-template-rows: auto minmax(0, 1fr) auto !important;
}

#chatWorkstation .chat-conversation-head,
#chatWorkstation .chat-composer {
    flex: 0 0 auto !important;
}

#chatWorkstation .chat-messages {
    min-height: 0 !important;
    height: 100% !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    overscroll-behavior: contain;
}

@media (max-width: 1100px) {
    #chatWorkstation.chat-workspace.page-wide {
        height: calc(100vh - 180px) !important;
        min-height: 620px !important;
        max-height: none !important;
    }

    #chatWorkstation .chat-sidebar-panel {
        max-height: 100% !important;
    }
}

@media (max-width: 760px) {
    #chatWorkstation.chat-workspace.page-wide {
        min-height: 650px !important;
    }
}

@media (max-width: 992px) {
    .flow-stats.petty-stats {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .petty-toolbar {
        flex-direction: column;
        align-items: stretch;
    }

    .petty-toolbar .toolbar-actions,
    .petty-toolbar .btn {
        width: 100%;
    }

    .petty-toolbar .toolbar-actions {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 8px;
    }

    .petty-toolbar .btn {
        justify-content: center;
    }

    .petty-table {
        min-width: 760px;
    }

    .petty-item-row {
        grid-template-columns: minmax(0, 1fr) 76px 120px 110px 42px;
    }
}

@media (max-width: 640px) {
    .flow-stats.petty-stats {
        grid-template-columns: 1fr;
    }

    .petty-toolbar .toolbar-actions,
    .petty-item-row {
        grid-template-columns: 1fr;
    }

    .petty-actual-head {
        display: none;
    }

    .petty-actual-row {
        grid-template-columns: 1fr;
        gap: 6px;
        min-width: 0;
    }

    .petty-actual-row > span,
    .petty-actual-row > strong {
        display: flex;
        justify-content: space-between;
        gap: 10px;
    }

    .petty-actual-row > span:nth-of-type(2)::before { content: "Qty"; color: var(--muted); }
    .petty-actual-row > span:nth-of-type(3)::before { content: "Budgeted"; color: var(--muted); }
    .petty-actual-row > strong::before { content: "Actual total"; color: var(--muted); font-weight: 700; }

    .petty-item-total {
        justify-content: flex-start;
    }
}

.report-preview-shell,
.activity-table-shell {
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

.report-preview-shell td,
.activity-log-table td {
    vertical-align: top;
}

.activity-log-workstation {
    overflow: hidden;
}

.activity-log-table {
    table-layout: fixed;
    width: 100% !important;
}

.activity-log-table th:nth-child(1),
.activity-log-table td:nth-child(1) {
    width: 21%;
}

.activity-log-table th:nth-child(2),
.activity-log-table td:nth-child(2) {
    width: 28%;
}

.activity-log-table th:nth-child(3),
.activity-log-table td:nth-child(3) {
    width: 18%;
}

.activity-log-table th:nth-child(4),
.activity-log-table td:nth-child(4) {
    width: 33%;
}

.activity-log-table td {
    overflow-wrap: anywhere;
    word-break: break-word;
}

.activity-log-table td > span,
.activity-log-table td > strong,
.activity-log-table td > small {
    display: block;
}

.activity-log-table td > small {
    color: var(--muted);
    margin-top: 4px;
}

.activity-primary {
    color: var(--text);
    font-weight: 800;
}

.activity-device {
    color: var(--text);
    line-height: 1.35;
}

.activity-table-shell {
    max-width: 100%;
    overflow-x: hidden;
}

@media (max-width: 1100px) {
    .report-filter-panel,
    .report-filter-panel.compact {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .report-filter-panel.side {
        grid-template-columns: 1fr;
    }

    .report-tab-content .report-actions.side {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .report-filter-panel .btn {
        grid-column: 1 / -1;
        width: 100%;
    }
}

@media (max-width: 640px) {
    .report-filter-panel,
    .report-filter-panel.compact,
    .report-summary-grid {
        grid-template-columns: 1fr;
    }

    .report-actions .btn {
        width: 100%;
        justify-content: center;
    }

    .report-tab-content .report-actions.side {
        grid-template-columns: 1fr;
    }

    .report-preview-shell table,
    .activity-table-shell table {
        min-width: 0;
    }

    .activity-table-shell {
        overflow-x: hidden;
    }

    .activity-log-table,
    .activity-log-table thead,
    .activity-log-table tbody,
    .activity-log-table tr,
    .activity-log-table th,
    .activity-log-table td {
        display: block;
        width: 100% !important;
    }

    .activity-log-table thead {
        display: none;
    }

    .activity-log-table tbody {
        display: grid;
        gap: 12px;
    }

    .activity-log-table tr {
        border: 1px solid var(--border);
        border-radius: 8px;
        background: var(--surface);
        overflow: hidden;
    }

    .activity-log-table td {
        display: grid;
        grid-template-columns: minmax(110px, 34%) minmax(0, 1fr);
        gap: 10px;
        padding: 10px 12px !important;
        border-bottom: 1px solid var(--line);
    }

    .activity-log-table td:last-child {
        border-bottom: 0;
    }

    .activity-log-table td::before {
        content: attr(data-label);
        color: var(--muted);
        font-size: .78rem;
        font-weight: 800;
        text-transform: uppercase;
        letter-spacing: .04em;
    }

    .activity-log-table td[colspan] {
        display: block;
        text-align: center;
    }

    .activity-log-table td[colspan]::before {
        content: none;
    }
}
