/* ══════════════════════════════════════════════════════════════
   NDMA KnowledgeWebPro — Design System
   Aesthetic: Command Deck — Horizontal Navigation
   Palette: Deep Navy + Warm Amber + Crisp White
   ══════════════════════════════════════════════════════════════ */

:root {
    /* ── Core Palette ── */
    --kw-navy-900: #0A1628;
    --kw-navy-800: #0D1F3C;
    --kw-navy-700: #132D50;
    --kw-navy-600: #1A3A64;
    --kw-navy-500: #1E4D8C;
    --kw-navy-400: #2563A8;
    --kw-navy-300: #3B82C4;
    --kw-navy-200: #6BA3DB;
    --kw-navy-100: #B8D4EE;
    --kw-navy-50: #E8F1FA;

    --kw-amber-500: #E8920C;
    --kw-amber-400: #F5A623;
    --kw-amber-300: #FBBF4E;
    --kw-amber-200: #FCD88A;
    --kw-amber-100: #FEF0CD;

    --kw-teal-500: #0D9488;
    --kw-teal-400: #14B8A6;
    --kw-emerald-500: #059669;
    --kw-rose-500: #E11D48;
    --kw-violet-500: #7C3AED;

    /* ── Surface & Text ── */
    --kw-surface: #FFFFFF;
    --kw-surface-raised: #FFFFFF;
    --kw-surface-muted: #F7F9FC;
    --kw-surface-hover: #EEF2F9;
    --kw-border: #E2E8F0;
    --kw-border-subtle: #F1F5F9;
    --kw-text-primary: #1E293B;
    --kw-text-secondary: #64748B;
    --kw-text-muted: #94A3B8;

    /* ── Spacing ── */
    --kw-radius-sm: 6px;
    --kw-radius-md: 10px;
    --kw-radius-lg: 14px;
    --kw-radius-xl: 20px;

    /* ── Layout ── */
    --kw-topbar-h: 52px;
    --kw-navrail-h: 44px;
    --kw-header-total: calc(var(--kw-topbar-h) + var(--kw-navrail-h));

    /* ── Shadows ── */
    --kw-shadow-sm: 0 1px 3px rgba(15, 23, 42, 0.04), 0 1px 2px rgba(15, 23, 42, 0.06);
    --kw-shadow-md: 0 4px 12px rgba(15, 23, 42, 0.06), 0 2px 4px rgba(15, 23, 42, 0.04);
    --kw-shadow-lg: 0 12px 40px rgba(15, 23, 42, 0.08), 0 4px 12px rgba(15, 23, 42, 0.04);
    --kw-shadow-card: 0 1px 3px rgba(15, 23, 42, 0.03), 0 6px 24px rgba(15, 23, 42, 0.06);
    --kw-shadow-card-hover: 0 4px 8px rgba(15, 23, 42, 0.04), 0 12px 40px rgba(15, 23, 42, 0.10);

    /* ── Transitions ── */
    --kw-ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --kw-ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
    --kw-duration-fast: 150ms;
    --kw-duration-normal: 250ms;
    --kw-duration-slow: 400ms;
}

/* ── Dark mode overrides ── */
.mud-theme-dark {
    --kw-surface: #141824;
    --kw-surface-raised: #1C2233;
    --kw-surface-muted: #111520;
    --kw-surface-hover: #232940;
    --kw-border: #2A3149;
    --kw-border-subtle: #1E2438;
    --kw-text-primary: #E8ECF4;
    --kw-text-secondary: #8B95AD;
    --kw-text-muted: #5A6478;
    --kw-shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.2);
    --kw-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.25);
    --kw-shadow-lg: 0 12px 40px rgba(0, 0, 0, 0.3);
    --kw-shadow-card: 0 2px 8px rgba(0, 0, 0, 0.2), 0 8px 32px rgba(0, 0, 0, 0.15);
    --kw-shadow-card-hover: 0 4px 12px rgba(0, 0, 0, 0.25), 0 16px 48px rgba(0, 0, 0, 0.2);
}

/* ══════════════════════════════════════════════════════════════
   Global Resets & Base
   ══════════════════════════════════════════════════════════════ */

html {
    scroll-behavior: smooth;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

body {
    background: var(--kw-surface-muted);
    color: var(--kw-text-primary);
    margin: 0;
}

h1:focus { outline: none; }

::selection {
    background: var(--kw-navy-200);
    color: var(--kw-navy-900);
}

.mud-theme-dark ::selection {
    background: var(--kw-navy-600);
    color: var(--kw-navy-50);
}

/* ══════════════════════════════════════════════════════════════
   Shell — Stacked Layout (no sidebar)
   ══════════════════════════════════════════════════════════════ */

.kw-shell {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

/* ══════════════════════════════════════════════════════════════
   Top Brand Bar
   ══════════════════════════════════════════════════════════════ */

.kw-topbar {
    height: var(--kw-topbar-h);
    background: linear-gradient(135deg, var(--kw-navy-900) 0%, var(--kw-navy-800) 100%);
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
    position: sticky;
    top: 0;
    z-index: 1100;
    flex-shrink: 0;
}

.kw-topbar-inner {
    max-width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 24px;
}

/* Brand */
.kw-brand {
    display: flex;
    align-items: center;
    gap: 12px;
}

.kw-logo-mark {
    width: 32px;
    height: 32px;
    border-radius: 9px;
    background: linear-gradient(135deg, var(--kw-amber-400), var(--kw-amber-500));
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'Outfit', sans-serif;
    font-weight: 800;
    font-size: 0.9rem;
    color: var(--kw-navy-900);
    flex-shrink: 0;
    box-shadow: 0 2px 10px rgba(232, 146, 12, 0.35);
    transition: transform var(--kw-duration-normal) var(--kw-ease-spring);
}

.kw-logo-mark:hover {
    transform: rotate(-6deg) scale(1.05);
}

.kw-brand-text {
    display: flex;
    align-items: center;
    gap: 10px;
}

.kw-brand-name {
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    font-size: 1.1rem;
    color: rgba(255, 255, 255, 0.92);
    letter-spacing: -0.01em;
}

.kw-brand-accent {
    color: var(--kw-amber-300);
}

.kw-brand-badge {
    padding: 2px 9px;
    border-radius: 100px;
    font-family: 'DM Sans', sans-serif;
    font-size: 0.58rem;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.55);
    border: 1px solid rgba(255, 255, 255, 0.06);
    line-height: 1.6;
}

/* Topbar Actions */
.kw-topbar-actions {
    display: flex;
    align-items: center;
    gap: 4px;
}

.kw-topbar-btn {
    width: 36px;
    height: 36px;
    border-radius: 8px;
    border: none;
    background: transparent;
    color: rgba(255, 255, 255, 0.55);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all var(--kw-duration-fast) var(--kw-ease-out);
    position: relative;
}

.kw-topbar-btn:hover {
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.9);
}

.kw-topbar-btn--notif {
    position: relative;
}

.kw-notif-dot {
    position: absolute;
    top: 7px;
    right: 8px;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--kw-amber-400);
    border: 2px solid var(--kw-navy-900);
    animation: kw-pulse 2s ease-in-out infinite;
}

@keyframes kw-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.4; }
}

.kw-topbar-divider {
    width: 1px;
    height: 24px;
    background: rgba(255, 255, 255, 0.08);
    margin: 0 8px;
}

.kw-avatar-btn {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    border: 2px solid rgba(255, 255, 255, 0.12);
    background: linear-gradient(135deg, var(--kw-navy-600), var(--kw-navy-500));
    color: rgba(255, 255, 255, 0.85);
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    font-size: 0.78rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--kw-duration-fast) var(--kw-ease-out);
}

.kw-avatar-btn:hover {
    border-color: var(--kw-amber-400);
    transform: scale(1.06);
}

/* ══════════════════════════════════════════════════════════════
   Navigation Rail — Horizontal
   ══════════════════════════════════════════════════════════════ */

.kw-nav-rail {
    height: var(--kw-navrail-h);
    background: var(--kw-surface);
    border-bottom: 1px solid var(--kw-border);
    position: sticky;
    top: var(--kw-topbar-h);
    z-index: 1090;
    flex-shrink: 0;
}

.mud-theme-dark .kw-nav-rail {
    background: var(--kw-surface-raised);
    border-bottom-color: var(--kw-border);
}

.kw-nav-rail-inner {
    height: 100%;
    display: flex;
    align-items: center;
    padding: 0 20px;
}

.kw-nav-items {
    display: flex;
    align-items: center;
    gap: 2px;
    height: 100%;
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.kw-nav-items::-webkit-scrollbar {
    display: none;
}

.kw-nav-item {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 0 14px;
    height: 34px;
    border-radius: 8px;
    font-family: 'DM Sans', sans-serif;
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--kw-text-secondary);
    text-decoration: none;
    white-space: nowrap;
    transition: all var(--kw-duration-fast) var(--kw-ease-out);
    position: relative;
    flex-shrink: 0;
}

.kw-nav-item:hover {
    background: var(--kw-surface-hover);
    color: var(--kw-text-primary);
}

.kw-nav-item.active {
    background: var(--kw-navy-50);
    color: var(--kw-navy-600);
    font-weight: 600;
}

.mud-theme-dark .kw-nav-item.active {
    background: rgba(59, 130, 196, 0.12);
    color: var(--kw-navy-200);
}

/* Active indicator line */
.kw-nav-item.active::after {
    content: '';
    position: absolute;
    bottom: -5px;
    left: 14px;
    right: 14px;
    height: 2px;
    border-radius: 2px 2px 0 0;
    background: var(--kw-navy-500);
}

.mud-theme-dark .kw-nav-item.active::after {
    background: var(--kw-navy-300);
}

.kw-nav-item .mud-icon-root {
    font-size: 1.15rem;
    opacity: 0.7;
    transition: opacity var(--kw-duration-fast);
}

.kw-nav-item:hover .mud-icon-root,
.kw-nav-item.active .mud-icon-root {
    opacity: 1;
}

.kw-nav-sep {
    width: 1px;
    height: 20px;
    background: var(--kw-border);
    margin: 0 6px;
    flex-shrink: 0;
}

/* Nav toggle (expandable section) */
.kw-nav-toggle {
    position: relative;
}

.kw-nav-chevron {
    font-size: 0.9rem !important;
    opacity: 0.5;
    margin-left: -2px;
}

/* Nav sub-items (admin sub-routes) */
.kw-nav-sub {
    font-size: 0.72rem !important;
    padding: 4px 8px !important;
    opacity: 0.85;
}

.kw-nav-sub .mud-icon-root {
    font-size: 0.95rem !important;
}

.kw-nav-sub.active {
    opacity: 1;
}

/* ══════════════════════════════════════════════════════════════
   Two-tier contextual navigation (module bar + context bar)
   Each module carries its signature colour via the --kw-mod var.
   ══════════════════════════════════════════════════════════════ */
.kw-mod {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 0 14px;
    height: 34px;
    border: none;
    background: transparent;
    border-radius: 8px;
    cursor: pointer;
    font-family: 'DM Sans', sans-serif;
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--kw-text-secondary);
    white-space: nowrap;
    flex-shrink: 0;
    transition: all var(--kw-duration-fast) var(--kw-ease-out);
}
.kw-mod .mud-icon-root { font-size: 1.15rem; opacity: 0.7; }
.kw-mod:hover { background: var(--kw-surface-hover); color: var(--kw-text-primary); }
.kw-mod:hover .mud-icon-root { opacity: 1; }
.kw-mod.active {
    color: var(--kw-mod);
    background: color-mix(in srgb, var(--kw-mod) 12%, transparent);
    font-weight: 600;
}
.kw-mod.active .mud-icon-root { opacity: 1; }

.kw-nav-context {
    position: sticky;
    top: var(--kw-header-total);
    z-index: 1089;
    height: 40px;
    box-sizing: border-box;
    background: var(--kw-surface);
    border-bottom: 1px solid var(--kw-border);
    border-top: 2px solid color-mix(in srgb, var(--kw-mod) 55%, transparent);
    flex-shrink: 0;
}
.mud-theme-dark .kw-nav-context { background: var(--kw-surface-raised); }
.kw-nav-context-inner {
    height: 100%;
    display: flex;
    align-items: center;
    gap: 2px;
    padding: 0 24px;
    overflow-x: auto;
    scrollbar-width: none;
}
.kw-nav-context-inner::-webkit-scrollbar { display: none; }

.kw-ctx {
    display: flex;
    align-items: center;
    gap: 5px;
    padding: 0 12px;
    height: 28px;
    border: none;
    background: transparent;
    border-radius: 7px;
    cursor: pointer;
    font-family: 'DM Sans', sans-serif;
    font-size: 0.78rem;
    font-weight: 500;
    color: var(--kw-text-secondary);
    white-space: nowrap;
    flex-shrink: 0;
    transition: all var(--kw-duration-fast) var(--kw-ease-out);
}
.kw-ctx .mud-icon-root { font-size: 1rem; opacity: 0.65; }
.kw-ctx:hover { background: var(--kw-surface-hover); color: var(--kw-text-primary); }
.kw-ctx:hover .mud-icon-root { opacity: 1; }
.kw-ctx.active {
    color: var(--kw-mod);
    background: color-mix(in srgb, var(--kw-mod) 14%, transparent);
    font-weight: 600;
}
.kw-ctx.active .mud-icon-root { opacity: 1; }
.kw-ctx-chev { font-size: 0.85rem !important; opacity: 0.55; margin-left: -1px; }
.kw-ctx-bracket { width: 1px; height: 16px; background: var(--kw-border); margin: 0 6px; flex: 0 0 auto; }
.kw-ctx-sub { height: 26px; font-size: 0.76rem; }

/* Mobile drawer items */
.kw-mobile-nav-item { width: 100%; border: none; background: transparent; text-align: left; cursor: pointer; }
.kw-mobile-nav-sub2 { padding-left: 48px !important; font-size: 0.78rem; opacity: 0.82; }

/* Native <details> dropdown menus (avatar + More) — no popover/JS dependency */
.kw-menu { position: relative; }
.kw-menu > summary { list-style: none; cursor: pointer; }
.kw-menu > summary::-webkit-details-marker { display: none; }
.kw-menu > summary::marker { content: ""; font-size: 0; }
.kw-nav-more { flex-shrink: 0; }
.kw-menu-pop {
    position: absolute;
    top: calc(100% + 8px);
    z-index: 1300;
    min-width: 232px;
    padding: 6px;
    background: var(--kw-surface);
    border: 1px solid var(--kw-border);
    border-radius: 12px;
    box-shadow: 0 12px 32px rgba(15, 23, 42, 0.18);
}
.kw-menu-pop--right { right: 0; }
.kw-menu-pop--left { left: 0; }
.mud-theme-dark .kw-menu-pop { background: var(--kw-surface-raised); }
.kw-menu-head { padding: 10px 12px 12px; border-bottom: 1px solid var(--kw-border); margin-bottom: 4px; }
.kw-menu-name { font-weight: 600; font-size: 0.9rem; color: var(--kw-text-primary); }
.kw-menu-email { font-size: 0.78rem; color: var(--kw-text-secondary); margin-top: 2px; word-break: break-all; }
.kw-menu-item {
    display: flex; align-items: center; gap: 12px;
    width: 100%; box-sizing: border-box;
    padding: 9px 12px; border: none; background: transparent;
    border-radius: 8px; cursor: pointer; text-align: left; text-decoration: none;
    font-family: 'DM Sans', sans-serif; font-size: 0.85rem; color: var(--kw-text-primary);
}
.kw-menu-item .mud-icon-root { font-size: 1.15rem; opacity: 0.7; }
.kw-menu-item:hover { background: var(--kw-surface-hover); }
.kw-menu-divider { height: 1px; background: var(--kw-border); margin: 4px 0; }

/* nav items are now <a> — strip link underline */
.kw-mod, .kw-ctx, .kw-mobile-nav-item { text-decoration: none; }

/* Mobile nav sub-items */
.kw-mobile-nav-sub {
    padding-left: 32px !important;
    font-size: 0.85rem;
}

.kw-mobile-nav-sep {
    height: 1px;
    background: var(--kw-border);
    margin: 4px 8px;
}

/* Mobile toggle (hidden on desktop) */
.kw-mobile-toggle {
    display: none;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    border: none;
    background: transparent;
    color: var(--kw-text-secondary);
    cursor: pointer;
    align-items: center;
    justify-content: center;
    margin-left: auto;
    transition: background var(--kw-duration-fast);
}

.kw-mobile-toggle:hover {
    background: var(--kw-surface-hover);
}

/* Mobile nav dropdown */
.kw-mobile-nav {
    display: none;
    position: absolute;
    top: var(--kw-navrail-h);
    left: 0;
    right: 0;
    background: var(--kw-surface);
    border-bottom: 1px solid var(--kw-border);
    box-shadow: var(--kw-shadow-lg);
    padding: 8px;
    animation: kw-slideDown 200ms var(--kw-ease-out);
    z-index: 1089;
}

.mud-theme-dark .kw-mobile-nav {
    background: var(--kw-surface-raised);
}

@keyframes kw-slideDown {
    from { opacity: 0; transform: translateY(-8px); }
    to { opacity: 1; transform: translateY(0); }
}

.kw-mobile-nav-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-radius: 8px;
    font-family: 'DM Sans', sans-serif;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--kw-text-secondary);
    text-decoration: none;
    transition: all var(--kw-duration-fast);
}

.kw-mobile-nav-item:hover {
    background: var(--kw-surface-hover);
    color: var(--kw-text-primary);
}

.kw-mobile-nav-item.active {
    background: var(--kw-navy-50);
    color: var(--kw-navy-600);
    font-weight: 600;
}

.mud-theme-dark .kw-mobile-nav-item.active {
    background: rgba(59, 130, 196, 0.12);
    color: var(--kw-navy-200);
}

/* ── Responsive: collapse nav to hamburger ── */
@media (max-width: 900px) {
    .kw-nav-items {
        display: none;
    }

    .kw-nav-context {
        display: none;
    }

    .kw-mobile-toggle {
        display: flex;
    }

    .kw-mobile-nav {
        display: block;
    }

    .kw-brand-name {
        font-size: 0.95rem;
    }

    .kw-brand-badge {
        display: none;
    }
}

/* ══════════════════════════════════════════════════════════════
   Main Content Area — Full Width
   ══════════════════════════════════════════════════════════════ */

.kw-content {
    flex: 1;
    padding: 28px 32px 40px;
    background: var(--kw-surface-muted);
    max-width: 1440px;
    width: 100%;
    margin: 0 auto;
    box-sizing: border-box;
}

.mud-theme-dark .kw-content {
    background: var(--kw-surface-muted);
}

@media (max-width: 600px) {
    .kw-content {
        padding: 16px;
    }
}

/* ══════════════════════════════════════════════════════════════
   Dashboard Page Header
   ══════════════════════════════════════════════════════════════ */

.kw-page-header {
    background: linear-gradient(135deg, var(--kw-navy-900) 0%, var(--kw-navy-700) 50%, var(--kw-navy-600) 100%);
    border-radius: var(--kw-radius-lg);
    padding: 36px 40px;
    position: relative;
    overflow: hidden;
    margin-bottom: 28px;
}

.kw-page-header::before {
    content: '';
    position: absolute;
    top: -60%;
    right: -10%;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(245, 166, 35, 0.12) 0%, transparent 70%);
    pointer-events: none;
}

.kw-page-header::after {
    content: '';
    position: absolute;
    bottom: -40%;
    left: 20%;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(59, 130, 196, 0.10) 0%, transparent 70%);
    pointer-events: none;
}

.kw-page-header-title {
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    font-size: 1.75rem;
    color: #FFFFFF;
    margin-bottom: 6px;
    position: relative;
    z-index: 1;
}

.kw-page-header-subtitle {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.95rem;
    color: rgba(255, 255, 255, 0.65);
    position: relative;
    z-index: 1;
}

.kw-page-header-date {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.45);
    position: relative;
    z-index: 1;
    margin-top: 4px;
}

/* ══════════════════════════════════════════════════════════════
   Stat Cards
   ══════════════════════════════════════════════════════════════ */

.kw-stat-card {
    background: var(--kw-surface-raised);
    border: 1px solid var(--kw-border-subtle);
    border-radius: var(--kw-radius-lg);
    padding: 24px;
    box-shadow: var(--kw-shadow-card);
    transition: all var(--kw-duration-normal) var(--kw-ease-out);
    position: relative;
    overflow: hidden;
    cursor: default;
}

.kw-stat-card:hover {
    box-shadow: var(--kw-shadow-card-hover);
    transform: translateY(-3px);
    border-color: var(--kw-border);
}

.kw-stat-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4px;
    height: 100%;
    border-radius: 4px 0 0 4px;
    transition: width var(--kw-duration-normal) var(--kw-ease-out);
}

.kw-stat-card:hover::before {
    width: 6px;
}

.kw-stat-card--investments::before { background: linear-gradient(180deg, var(--kw-navy-400), var(--kw-navy-500)); }
.kw-stat-card--documents::before { background: linear-gradient(180deg, var(--kw-emerald-500), var(--kw-teal-500)); }
.kw-stat-card--workplans::before { background: linear-gradient(180deg, var(--kw-teal-400), var(--kw-teal-500)); }
.kw-stat-card--approvals::before { background: linear-gradient(180deg, var(--kw-amber-400), var(--kw-amber-500)); }

.kw-stat-icon-wrap {
    width: 48px;
    height: 48px;
    border-radius: var(--kw-radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: transform var(--kw-duration-normal) var(--kw-ease-spring);
}

.kw-stat-card:hover .kw-stat-icon-wrap {
    transform: scale(1.08);
}

.kw-stat-icon-wrap--investments {
    background: linear-gradient(135deg, rgba(37, 99, 168, 0.10), rgba(37, 99, 168, 0.05));
    color: var(--kw-navy-400);
}

.kw-stat-icon-wrap--documents {
    background: linear-gradient(135deg, rgba(5, 150, 105, 0.10), rgba(5, 150, 105, 0.05));
    color: var(--kw-emerald-500);
}

.kw-stat-icon-wrap--workplans {
    background: linear-gradient(135deg, rgba(20, 184, 166, 0.10), rgba(20, 184, 166, 0.05));
    color: var(--kw-teal-400);
}

.kw-stat-icon-wrap--approvals {
    background: linear-gradient(135deg, rgba(232, 146, 12, 0.10), rgba(232, 146, 12, 0.05));
    color: var(--kw-amber-500);
}

.kw-stat-value {
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    font-size: 1.85rem;
    line-height: 1;
    color: var(--kw-text-primary);
    letter-spacing: -0.02em;
}

.kw-stat-label {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--kw-text-secondary);
    margin-top: 4px;
}

.kw-stat-trend {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.72rem;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 2px 8px;
    border-radius: 100px;
    margin-top: 8px;
}

.kw-stat-trend--up {
    background: rgba(5, 150, 105, 0.08);
    color: var(--kw-emerald-500);
}

.kw-stat-trend--neutral {
    background: rgba(100, 116, 139, 0.08);
    color: var(--kw-text-secondary);
}

/* ══════════════════════════════════════════════════════════════
   Info / Status Panel
   ══════════════════════════════════════════════════════════════ */

.kw-info-panel {
    background: var(--kw-surface-raised);
    border: 1px solid var(--kw-border-subtle);
    border-radius: var(--kw-radius-lg);
    padding: 28px 32px;
    box-shadow: var(--kw-shadow-sm);
    position: relative;
    overflow: hidden;
}

.kw-info-panel::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--kw-navy-500), var(--kw-amber-400), var(--kw-teal-400));
}

.kw-info-panel-title {
    font-family: 'Outfit', sans-serif;
    font-weight: 600;
    font-size: 1.05rem;
    color: var(--kw-text-primary);
    margin-bottom: 8px;
}

.kw-info-panel-text {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.875rem;
    color: var(--kw-text-secondary);
    line-height: 1.65;
}

/* ══════════════════════════════════════════════════════════════
   Quick Action Cards
   ══════════════════════════════════════════════════════════════ */

.kw-action-card {
    background: var(--kw-surface-raised);
    border: 1px solid var(--kw-border-subtle);
    border-radius: var(--kw-radius-lg);
    padding: 24px;
    box-shadow: var(--kw-shadow-sm);
    transition: all var(--kw-duration-normal) var(--kw-ease-out);
    cursor: pointer;
    text-decoration: none;
    display: block;
    color: inherit;
}

.kw-action-card:hover {
    box-shadow: var(--kw-shadow-md);
    transform: translateY(-2px);
    border-color: var(--kw-navy-100);
}

.mud-theme-dark .kw-action-card:hover {
    border-color: var(--kw-navy-600);
}

.kw-action-card-icon {
    width: 42px;
    height: 42px;
    border-radius: var(--kw-radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 14px;
    font-size: 1.3rem;
    transition: transform var(--kw-duration-normal) var(--kw-ease-spring);
}

.kw-action-card:hover .kw-action-card-icon {
    transform: scale(1.1) rotate(-3deg);
}

.kw-action-card-title {
    font-family: 'DM Sans', sans-serif;
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--kw-text-primary);
    margin-bottom: 4px;
}

.kw-action-card-desc {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.78rem;
    color: var(--kw-text-muted);
    line-height: 1.5;
}

/* ══════════════════════════════════════════════════════════════
   Staggered Entrance Animations
   ══════════════════════════════════════════════════════════════ */

@keyframes kw-fadeInUp {
    from {
        opacity: 0;
        transform: translateY(16px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes kw-fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}

@keyframes kw-scaleIn {
    from {
        opacity: 0;
        transform: scale(0.95);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

.kw-animate-in {
    animation: kw-fadeInUp var(--kw-duration-slow) var(--kw-ease-out) both;
}

.kw-animate-in--d1 { animation-delay: 0ms; }
.kw-animate-in--d2 { animation-delay: 60ms; }
.kw-animate-in--d3 { animation-delay: 120ms; }
.kw-animate-in--d4 { animation-delay: 180ms; }
.kw-animate-in--d5 { animation-delay: 240ms; }
.kw-animate-in--d6 { animation-delay: 300ms; }
.kw-animate-in--d7 { animation-delay: 360ms; }
.kw-animate-in--d8 { animation-delay: 420ms; }

/* ══════════════════════════════════════════════════════════════
   Activity / Timeline
   ══════════════════════════════════════════════════════════════ */

.kw-activity-item {
    display: flex;
    gap: 14px;
    padding: 14px 0;
    border-bottom: 1px solid var(--kw-border-subtle);
    transition: background var(--kw-duration-fast);
}

.kw-activity-item:last-child {
    border-bottom: none;
}

.kw-activity-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    flex-shrink: 0;
    margin-top: 5px;
}

.kw-activity-text {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.84rem;
    color: var(--kw-text-secondary);
    line-height: 1.5;
}

.kw-activity-time {
    font-size: 0.72rem;
    color: var(--kw-text-muted);
    margin-top: 2px;
}

/* ══════════════════════════════════════════════════════════════
   Divider with Label
   ══════════════════════════════════════════════════════════════ */

.kw-section-label {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 28px 0 18px;
    font-family: 'DM Sans', sans-serif;
    font-size: 0.75rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--kw-text-muted);
}

.kw-section-label::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--kw-border);
}

/* ══════════════════════════════════════════════════════════════
   Blazor / Validation Defaults (preserved)
   ══════════════════════════════════════════════════════════════ */

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid var(--kw-rose-500);
}

.validation-message {
    color: var(--kw-rose-500);
    font-family: 'DM Sans', sans-serif;
    font-size: 0.82rem;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
    border-radius: var(--kw-radius-sm);
}

.blazor-error-boundary::after {
    content: "An error has occurred."
}

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.form-floating > .form-control-plaintext::placeholder,
.form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder,
.form-floating > .form-control:focus::placeholder {
    text-align: start;
}

/* ══════════════════════════════════════════════════════════════
   MudBlazor Overrides (minimal, surgical)
   ══════════════════════════════════════════════════════════════ */

.mud-table-root {
    border-radius: var(--kw-radius-lg) !important;
    overflow: hidden;
    border: 1px solid var(--kw-border-subtle) !important;
}

.mud-table-head .mud-table-cell {
    font-family: 'DM Sans', sans-serif;
    font-weight: 600;
    font-size: 0.78rem;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: var(--kw-text-muted);
}

.mud-table-body .mud-table-cell {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.875rem;
}

.mud-button-root {
    font-family: 'DM Sans', sans-serif !important;
    font-weight: 600 !important;
    letter-spacing: 0.01em;
    border-radius: var(--kw-radius-sm) !important;
}

.mud-chip {
    font-family: 'DM Sans', sans-serif !important;
    font-weight: 500;
}

/* ══════════════════════════════════════════════════════════════
   Scrollbar Styling
   ══════════════════════════════════════════════════════════════ */

::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

::-webkit-scrollbar-track {
    background: transparent;
}

::-webkit-scrollbar-thumb {
    background: var(--kw-text-muted);
    border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--kw-text-secondary);
}

/* ══════════════════════════════════════════════════════════════
   Auth Layout — Split-Screen Brand + Form
   ══════════════════════════════════════════════════════════════ */

.kw-auth-shell {
    display: flex;
    min-height: 100vh;
}

/* ── Left Brand Panel ── */
.kw-auth-brand-panel {
    width: 420px;
    min-height: 100vh;
    background: linear-gradient(160deg, var(--kw-navy-900) 0%, var(--kw-navy-800) 40%, var(--kw-navy-700) 100%);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 48px 40px;
    position: relative;
    overflow: hidden;
    flex-shrink: 0;
}

.kw-auth-brand-panel::before {
    content: '';
    position: absolute;
    top: -30%;
    right: -30%;
    width: 500px;
    height: 500px;
    background: radial-gradient(circle, rgba(245, 166, 35, 0.08) 0%, transparent 70%);
    pointer-events: none;
}

.kw-auth-brand-panel::after {
    content: '';
    position: absolute;
    bottom: -20%;
    left: -20%;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(59, 130, 196, 0.06) 0%, transparent 70%);
    pointer-events: none;
}

.kw-auth-brand-content {
    position: relative;
    z-index: 1;
}

.kw-auth-brand-title {
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    font-size: 2rem;
    color: rgba(255, 255, 255, 0.95);
    margin-bottom: 8px;
    letter-spacing: -0.02em;
}

.kw-auth-brand-subtitle {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.92rem;
    color: rgba(255, 255, 255, 0.55);
    margin-bottom: 28px;
}

.kw-auth-brand-desc {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.88rem;
    color: rgba(255, 255, 255, 0.45);
    line-height: 1.7;
    margin-bottom: 36px;
}

.kw-auth-brand-features {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.kw-auth-feature {
    display: flex;
    align-items: center;
    gap: 12px;
    font-family: 'DM Sans', sans-serif;
    font-size: 0.84rem;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.6);
}

.kw-auth-feature .mud-icon-root {
    color: var(--kw-amber-300);
    font-size: 1.1rem;
}

.kw-auth-brand-footer {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.75rem;
    color: rgba(255, 255, 255, 0.3);
    position: relative;
    z-index: 1;
}

/* ── Right Form Panel ── */
.kw-auth-form-panel {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 48px;
    background: var(--kw-surface-muted);
    position: relative;
}

.kw-auth-form-wrapper {
    width: 100%;
    max-width: 440px;
}

.kw-auth-theme-toggle {
    display: flex;
    justify-content: flex-end;
    margin-bottom: 16px;
}

/* ── Auth Form ── */
.kw-auth-form {
    width: 100%;
}

.kw-auth-form-header {
    margin-bottom: 32px;
}

.kw-auth-title {
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    font-size: 1.65rem;
    color: var(--kw-text-primary);
    margin: 0 0 6px;
    letter-spacing: -0.02em;
}

.kw-auth-subtitle {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.9rem;
    color: var(--kw-text-secondary);
    margin: 0;
    line-height: 1.5;
}

.kw-auth-fields {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

.kw-auth-input .mud-input-outlined-border {
    border-radius: var(--kw-radius-md) !important;
}

.kw-auth-options {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: -4px 0;
}

.kw-auth-checkbox .mud-typography {
    font-size: 0.84rem;
    color: var(--kw-text-secondary);
}

.kw-auth-link {
    font-family: 'DM Sans', sans-serif !important;
    font-size: 0.84rem !important;
    font-weight: 600 !important;
}

.kw-auth-alert {
    border-radius: var(--kw-radius-md) !important;
}

.kw-auth-error-list {
    margin: 0;
    padding-left: 18px;
    font-size: 0.84rem;
    line-height: 1.6;
}

.kw-auth-submit {
    margin-top: 4px;
    height: 48px !important;
    font-size: 0.92rem !important;
    letter-spacing: 0.02em;
    border-radius: var(--kw-radius-md) !important;
    background: linear-gradient(135deg, var(--kw-navy-700), var(--kw-navy-600)) !important;
    box-shadow: 0 2px 12px rgba(26, 58, 100, 0.25) !important;
    transition: all var(--kw-duration-normal) var(--kw-ease-out) !important;
}

.kw-auth-submit:hover {
    box-shadow: 0 4px 20px rgba(26, 58, 100, 0.35) !important;
    transform: translateY(-1px);
}

/* Passkey button: outlined variant — keep the sizing but NOT the dark gradient bg,
   so MudBlazor's native (theme-aware, visible) outlined colours show through. */
.kw-auth-passkey {
    margin-top: 4px;
    height: 48px !important;
    font-size: 0.92rem !important;
    letter-spacing: 0.02em;
    border-radius: var(--kw-radius-md) !important;
    transition: all var(--kw-duration-normal) var(--kw-ease-out) !important;
}
.kw-auth-passkey:hover {
    transform: translateY(-1px);
}

.kw-auth-footer {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin-top: 28px;
    padding-top: 24px;
    border-top: 1px solid var(--kw-border-subtle);
    font-family: 'DM Sans', sans-serif;
    font-size: 0.84rem;
    color: var(--kw-text-muted);
}

/* ── Icon circle for forgot/reset password ── */
.kw-auth-icon-circle {
    width: 64px;
    height: 64px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(26, 58, 100, 0.08), rgba(26, 58, 100, 0.04));
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 20px;
    color: var(--kw-navy-500);
}

.kw-auth-icon-circle--success {
    background: linear-gradient(135deg, rgba(5, 150, 105, 0.10), rgba(5, 150, 105, 0.04));
    color: var(--kw-emerald-500);
}

/* ── Auth Layout Responsive ── */
@media (max-width: 900px) {
    .kw-auth-shell {
        flex-direction: column;
    }

    .kw-auth-brand-panel {
        width: 100%;
        min-height: auto;
        padding: 32px 24px;
    }

    .kw-auth-brand-desc,
    .kw-auth-brand-features {
        display: none;
    }

    .kw-auth-form-panel {
        padding: 32px 24px;
    }
}

@media (max-width: 480px) {
    .kw-auth-form-panel {
        padding: 24px 16px;
    }

    .kw-auth-title {
        font-size: 1.4rem;
    }
}

/* ══════════════════════════════════════════════════════════════
   Public Layout
   ══════════════════════════════════════════════════════════════ */

.kw-public-shell {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

.kw-public-header {
    height: 64px;
    background: linear-gradient(135deg, var(--kw-navy-900) 0%, var(--kw-navy-800) 100%);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 32px;
    position: sticky;
    top: 0;
    z-index: 1100;
    border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.kw-public-header-actions {
    display: flex;
    align-items: center;
    gap: 8px;
}

.kw-public-nav {
    display: flex;
    align-items: center;
    gap: 4px;
}

.kw-public-nav-item {
    padding: 0 16px;
    height: 36px;
    border-radius: 8px;
    font-family: 'DM Sans', sans-serif;
    font-size: 0.85rem;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.6);
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 6px;
    transition: all var(--kw-duration-fast) var(--kw-ease-out);
}

.kw-public-nav-item:hover {
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.9);
}

.kw-public-nav-item.active {
    background: rgba(255, 255, 255, 0.08);
    color: rgba(255, 255, 255, 0.95);
    font-weight: 600;
}

.kw-public-content {
    flex: 1;
    background: var(--kw-surface-muted);
}

.kw-public-footer {
    background: var(--kw-navy-900);
    padding: 32px;
    border-top: 1px solid rgba(255, 255, 255, 0.04);
}

.kw-public-footer-inner {
    max-width: 1200px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 16px;
}

.kw-public-footer-text {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.35);
}

.kw-public-footer-links {
    display: flex;
    gap: 24px;
}

.kw-public-footer-link {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.4);
    text-decoration: none;
    transition: color var(--kw-duration-fast);
}

.kw-public-footer-link:hover {
    color: rgba(255, 255, 255, 0.7);
}

@media (max-width: 600px) {
    .kw-public-header {
        padding: 0 16px;
    }

    .kw-public-nav {
        display: none;
    }

    .kw-public-footer-inner {
        flex-direction: column;
        text-align: center;
    }
}

/* ══════════════════════════════════════════════════════════════
   Phase 11 — Public Portal
   Citizen-trust aesthetic: generous typography, soft shadows,
   glass-morphism hero, search-first navigation.
   ══════════════════════════════════════════════════════════════ */

.kw-pub {
    font-family: 'DM Sans', sans-serif;
}

.kw-pub-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

/* ── HERO ── */
.kw-pub-hero {
    position: relative;
    color: #fff;
    padding: 72px 24px 96px;
    overflow: hidden;
    background:
        radial-gradient(1200px 600px at 80% -10%, rgba(245,158,11,0.18), transparent 55%),
        radial-gradient(900px 480px at 0% 110%, rgba(59,130,246,0.16), transparent 60%),
        linear-gradient(135deg, #0F172A 0%, #1E293B 100%);
}

.kw-pub-hero::before {
    content: '';
    position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
    background-size: 48px 48px;
    pointer-events: none;
    mask-image: radial-gradient(ellipse at center, black 30%, transparent 75%);
}

.kw-pub-hero-inner {
    position: relative;
    max-width: 1100px;
    margin: 0 auto;
    text-align: center;
}

.kw-pub-hero-badge {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 14px;
    border-radius: 999px;
    background: rgba(245,158,11,0.15);
    border: 1px solid rgba(245,158,11,0.3);
    color: #FCD34D;
    font-size: 0.75rem; font-weight: 600; letter-spacing: 0.04em;
    text-transform: uppercase;
    margin-bottom: 22px;
}

.kw-pub-hero-title {
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    font-size: clamp(2rem, 5vw, 3.6rem);
    line-height: 1.1;
    margin: 0 0 16px;
    letter-spacing: -0.02em;
}

.kw-pub-hero-title em {
    font-style: normal;
    background: linear-gradient(120deg, #F5A623 0%, #FCD34D 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
}

.kw-pub-hero-sub {
    font-size: clamp(0.95rem, 1.6vw, 1.2rem);
    color: rgba(255,255,255,0.78);
    max-width: 640px;
    margin: 0 auto 36px;
    line-height: 1.6;
}

.kw-pub-search {
    display: flex;
    max-width: 720px;
    margin: 0 auto;
    background: rgba(255,255,255,0.95);
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.35);
}
.kw-pub-search input {
    flex: 1;
    border: none;
    background: transparent;
    padding: 16px 22px;
    font-family: 'DM Sans', sans-serif;
    font-size: 1rem;
    color: var(--kw-text-primary);
}
.kw-pub-search input:focus { outline: none; }
.kw-pub-search button {
    border: none;
    background: linear-gradient(135deg, #F59E0B 0%, #EA580C 100%);
    color: #fff;
    padding: 0 24px;
    font-family: 'DM Sans', sans-serif;
    font-weight: 600;
    cursor: pointer;
    transition: transform 0.15s ease;
    display: flex; align-items: center; gap: 6px;
}
.kw-pub-search button:hover { transform: translateX(2px); }

/* ── IMPACT STATS BAR ── */
.kw-pub-impact {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
    max-width: 1100px;
    margin: -48px auto 64px;
    padding: 0 24px;
    position: relative;
    z-index: 2;
}
.kw-pub-impact-tile {
    background: #fff;
    border-radius: 18px;
    padding: 24px;
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.10);
    border-top: 4px solid var(--impact-color, #F59E0B);
    text-align: center;
}
.kw-pub-impact-icon {
    width: 48px; height: 48px;
    border-radius: 12px;
    background: color-mix(in srgb, var(--impact-color, #F59E0B) 14%, transparent);
    color: var(--impact-color, #F59E0B);
    display: inline-flex; align-items: center; justify-content: center;
    margin-bottom: 10px;
}
.kw-pub-impact-value {
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    font-size: 2.25rem;
    color: var(--kw-text-primary);
    letter-spacing: -0.02em;
    line-height: 1;
    margin-bottom: 4px;
}
.kw-pub-impact-label {
    font-size: 0.85rem;
    color: var(--kw-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 500;
}

/* ── SECTION BLOCKS ── */
.kw-pub-section {
    padding: 64px 0;
}
.kw-pub-section--alt { background: #fff; }

.kw-pub-section-head {
    max-width: 800px;
    margin: 0 auto 40px;
    text-align: center;
}
.kw-pub-section-eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-size: 0.75rem;
    font-weight: 600;
    color: #F59E0B;
    margin: 0 0 8px;
}
.kw-pub-section-title {
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    color: var(--kw-text-primary);
    margin: 0 0 12px;
    letter-spacing: -0.02em;
}
.kw-pub-section-sub {
    font-size: 1rem;
    color: var(--kw-text-muted);
    line-height: 1.65;
    margin: 0;
}

/* ── INVESTMENT/DOCUMENT CARDS ── */
.kw-pub-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 24px;
}
.kw-pub-card {
    background: #fff;
    border-radius: 18px;
    overflow: hidden;
    border: 1px solid var(--kw-line);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
    text-decoration: none;
    color: inherit;
    display: flex; flex-direction: column;
}
.kw-pub-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 40px rgba(15, 23, 42, 0.10);
    border-color: transparent;
}
.kw-pub-card-thumb {
    height: 8px;
    background: var(--card-color, linear-gradient(90deg, #1E40AF, #3B82F6));
}
.kw-pub-card-body { padding: 22px; flex: 1; display: flex; flex-direction: column; }
.kw-pub-card-meta {
    display: flex; flex-wrap: wrap; gap: 6px;
    font-size: 0.72rem; color: var(--kw-text-muted);
    margin-bottom: 10px;
}
.kw-pub-tag {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 0.7rem; font-weight: 600;
    letter-spacing: 0.04em;
    background: rgba(15,23,42,0.06);
    color: var(--kw-text-secondary);
}
.kw-pub-tag--accent { background: rgba(245,158,11,0.14); color: #B45309; }
.kw-pub-tag--success { background: rgba(16,185,129,0.14); color: #047857; }
.kw-pub-tag--info { background: rgba(59,130,246,0.14); color: #1D4ED8; }

.kw-pub-card-title {
    font-family: 'Outfit', sans-serif;
    font-weight: 600;
    font-size: 1.1rem;
    color: var(--kw-text-primary);
    line-height: 1.3;
    margin: 0 0 8px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.kw-pub-card-desc {
    font-size: 0.88rem;
    color: var(--kw-text-secondary);
    line-height: 1.5;
    flex: 1;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.kw-pub-card-foot {
    display: flex; align-items: center; justify-content: space-between;
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid var(--kw-line);
    font-size: 0.78rem; color: var(--kw-text-muted);
}
.kw-pub-card-foot-cta {
    color: #F59E0B;
    font-weight: 600;
    display: inline-flex; align-items: center; gap: 4px;
}

/* ── FILTER BAR ── */
.kw-pub-filterbar {
    background: #fff;
    border-radius: 14px;
    padding: 16px;
    box-shadow: 0 4px 16px rgba(15, 23, 42, 0.05);
    border: 1px solid var(--kw-line);
    margin-bottom: 28px;
    display: flex; gap: 12px; flex-wrap: wrap;
    align-items: center;
}
.kw-pub-filterbar-label {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--kw-text-muted);
    margin-right: 4px;
}

/* ── DETAIL HERO ── */
.kw-pub-detail-hero {
    background: linear-gradient(135deg, #0F172A 0%, #1E40AF 60%, #3B82F6 100%);
    color: #fff;
    padding: 56px 24px 40px;
    border-radius: 0 0 24px 24px;
    position: relative;
    overflow: hidden;
    margin-bottom: 32px;
}
.kw-pub-detail-hero::before {
    content: '';
    position: absolute; inset: 0;
    background: radial-gradient(circle at 90% 20%, rgba(245,158,11,0.18), transparent 50%);
    pointer-events: none;
}
.kw-pub-detail-hero-inner {
    position: relative;
    max-width: 1100px;
    margin: 0 auto;
}
.kw-pub-detail-hero-back {
    display: inline-flex; align-items: center; gap: 4px;
    color: rgba(255,255,255,0.7);
    text-decoration: none;
    font-size: 0.85rem;
    margin-bottom: 18px;
    transition: color 0.15s;
}
.kw-pub-detail-hero-back:hover { color: #fff; }
.kw-pub-detail-hero-title {
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    margin: 0 0 16px;
    line-height: 1.2;
    letter-spacing: -0.02em;
}
.kw-pub-detail-hero-meta {
    display: flex; flex-wrap: wrap; gap: 10px;
    color: rgba(255,255,255,0.85);
    font-size: 0.9rem;
}

.kw-pub-detail-hero-meta-item {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 14px;
    background: rgba(255,255,255,0.10);
    border-radius: 999px;
}

/* ── DETAIL BODY ── */
.kw-pub-detail-body {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 24px 64px;
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 32px;
}
.kw-pub-detail-main {
    background: #fff;
    border-radius: 18px;
    padding: 32px;
    border: 1px solid var(--kw-line);
}
.kw-pub-detail-side {
    display: flex; flex-direction: column; gap: 16px;
}
.kw-pub-detail-aside-card {
    background: #fff;
    border-radius: 14px;
    padding: 20px;
    border: 1px solid var(--kw-line);
}
.kw-pub-detail-aside-title {
    font-size: 0.85rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--kw-text-muted);
    margin: 0 0 12px;
    font-weight: 600;
}
@media (max-width: 900px) {
    .kw-pub-detail-body { grid-template-columns: 1fr; }
}

/* ── CTA BAND ── */
.kw-pub-cta {
    background: linear-gradient(135deg, #0F172A 0%, #1E40AF 100%);
    color: #fff;
    padding: 56px 24px;
    text-align: center;
    border-radius: 24px;
    margin: 64px 0;
    position: relative;
    overflow: hidden;
}
.kw-pub-cta::before {
    content: '';
    position: absolute; inset: 0;
    background: radial-gradient(circle at 20% 50%, rgba(245,158,11,0.15), transparent 50%);
    pointer-events: none;
}
.kw-pub-cta-title {
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    font-size: 1.8rem;
    margin: 0 0 12px;
    position: relative;
}
.kw-pub-cta-sub {
    font-size: 1rem;
    color: rgba(255,255,255,0.78);
    margin: 0 0 24px;
    max-width: 540px;
    margin-left: auto; margin-right: auto;
    position: relative;
}

/* ── SUBSCRIBE FORM ── */
.kw-pub-subscribe {
    max-width: 540px;
    margin: 0 auto;
    background: #fff;
    border-radius: 18px;
    padding: 36px 32px;
    box-shadow: 0 10px 40px rgba(15, 23, 42, 0.08);
}
.kw-pub-topic-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    margin-bottom: 20px;
}
.kw-pub-topic-tile {
    border: 1px solid var(--kw-line);
    border-radius: 12px;
    padding: 12px 14px;
    cursor: pointer;
    transition: all 0.15s ease;
    display: flex; align-items: center; gap: 8px;
    font-size: 0.88rem;
}
.kw-pub-topic-tile:hover { border-color: #F59E0B; }
.kw-pub-topic-tile.is-selected {
    background: rgba(245,158,11,0.08);
    border-color: #F59E0B;
    color: #B45309;
    font-weight: 600;
}

/* ── EMPTY STATE ── */
.kw-pub-empty {
    text-align: center;
    padding: 56px 24px;
    color: var(--kw-text-muted);
}

/* ── BREADCRUMBS ── */
.kw-pub-crumbs {
    font-size: 0.82rem;
    color: var(--kw-text-muted);
    margin-bottom: 16px;
}
.kw-pub-crumbs a { color: var(--kw-text-muted); text-decoration: none; }
.kw-pub-crumbs a:hover { color: #F59E0B; }
.kw-pub-crumbs-sep { margin: 0 6px; opacity: 0.5; }

/* ── SEARCH RESULTS ── */
.kw-pub-result {
    background: #fff;
    border-radius: 14px;
    padding: 20px 22px;
    border: 1px solid var(--kw-line);
    margin-bottom: 12px;
    transition: border-color 0.15s;
    text-decoration: none; color: inherit; display: block;
}
.kw-pub-result:hover { border-color: #F59E0B; }
.kw-pub-result-type {
    font-size: 0.72rem; font-weight: 700;
    letter-spacing: 0.08em; text-transform: uppercase;
    color: #F59E0B;
    margin-bottom: 4px;
}
.kw-pub-result-title {
    font-family: 'Outfit', sans-serif;
    font-weight: 600;
    font-size: 1.05rem;
    margin: 0 0 6px;
    color: var(--kw-text-primary);
}
.kw-pub-result-desc {
    font-size: 0.88rem; color: var(--kw-text-secondary);
    line-height: 1.5;
}

/* ── ANIMATIONS ── */
@keyframes kwPubFade {
    from { opacity: 0; transform: translateY(12px); }
    to { opacity: 1; transform: translateY(0); }
}
.kw-pub-section > * { animation: kwPubFade 0.5s ease both; }

/* ══════════════════════════════════════════════════════════════
   Phase 12 — Notification Center
   Bell badge animation, dropdown panel, list cards, preference toggles
   ══════════════════════════════════════════════════════════════ */

/* ── BELL BUTTON & BADGE ── */
.kw-notif-trigger {
    position: relative;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 10px;
    padding: 6px;
    color: rgba(255, 255, 255, 0.85);
    cursor: pointer;
    transition: background 0.15s ease;
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px;
}
.kw-notif-trigger:hover { background: rgba(255, 255, 255, 0.06); }
.kw-notif-badge {
    position: absolute;
    top: -2px; right: -2px;
    min-width: 18px; height: 18px;
    border-radius: 999px;
    background: linear-gradient(135deg, #F59E0B 0%, #EA580C 100%);
    color: #fff;
    font-size: 0.62rem;
    font-weight: 700;
    line-height: 18px;
    text-align: center;
    padding: 0 5px;
    box-shadow: 0 2px 8px rgba(245, 158, 11, 0.5);
    animation: kwNotifPulse 2s ease-in-out infinite;
}
@keyframes kwNotifPulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.08); }
}

/* ── DROPDOWN PANEL ── */
.kw-notif-panel {
    width: 380px;
    max-height: 540px;
    display: flex; flex-direction: column;
    background: var(--kw-surface);
    border: 1px solid var(--kw-line);
    border-radius: 14px;
    box-shadow: 0 24px 48px rgba(15, 23, 42, 0.18);
    overflow: hidden;
}
.kw-notif-panel-head {
    padding: 16px 18px;
    border-bottom: 1px solid var(--kw-line);
    background: var(--kw-surface-muted);
    display: flex; align-items: center; gap: 8px;
}
.kw-notif-panel-title {
    font-family: 'Outfit', sans-serif;
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--kw-text-primary);
    margin: 0;
    flex: 1;
}
.kw-notif-panel-action {
    background: transparent; border: none; cursor: pointer;
    color: #F59E0B;
    font-size: 0.78rem; font-weight: 600;
    padding: 4px 8px; border-radius: 6px;
    transition: background 0.15s ease;
}
.kw-notif-panel-action:hover { background: rgba(245, 158, 11, 0.08); }
.kw-notif-list {
    flex: 1;
    overflow-y: auto;
    max-height: 420px;
}
.kw-notif-item {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 12px;
    padding: 14px 18px 14px 24px;
    border-bottom: 1px solid var(--kw-line);
    cursor: pointer;
    transition: background 0.15s ease;
    text-decoration: none; color: inherit;
    position: relative;
}
.kw-notif-item:hover { background: var(--kw-surface-muted); }
.kw-notif-item.is-unread::before {
    content: '';
    position: absolute;
    left: 8px; top: 22px;
    width: 6px; height: 6px;
    border-radius: 50%;
    background: #F59E0B;
}
.kw-notif-item-icon {
    width: 36px; height: 36px;
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    background: color-mix(in srgb, var(--notif-color, #64748B) 14%, transparent);
    color: var(--notif-color, #64748B);
    flex-shrink: 0;
}
.kw-notif-item-body { min-width: 0; }
.kw-notif-item-title {
    font-size: 0.88rem;
    font-weight: 600;
    color: var(--kw-text-primary);
    margin: 0 0 2px;
    line-height: 1.3;
}
.kw-notif-item-msg {
    font-size: 0.78rem;
    color: var(--kw-text-muted);
    margin: 0;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}
.kw-notif-item-time {
    font-size: 0.7rem;
    color: var(--kw-text-muted);
    flex-shrink: 0;
    padding-top: 2px;
}
.kw-notif-panel-foot {
    padding: 12px 18px;
    text-align: center;
    border-top: 1px solid var(--kw-line);
    background: var(--kw-surface-muted);
}
.kw-notif-panel-foot a {
    color: var(--kw-text-secondary);
    font-size: 0.85rem; font-weight: 600;
    text-decoration: none;
    display: inline-flex; align-items: center; gap: 4px;
}
.kw-notif-panel-foot a:hover { color: #F59E0B; }
.kw-notif-empty {
    padding: 48px 20px;
    text-align: center;
    color: var(--kw-text-muted);
}
.kw-notif-empty-icon {
    font-size: 2.5rem;
    opacity: 0.35;
    margin-bottom: 10px;
}

/* ── PREFERENCES PAGE ── */
.kw-notif-pref-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}
.kw-notif-pref-row {
    display: grid;
    grid-template-columns: auto 1fr auto auto;
    gap: 14px;
    align-items: center;
    padding: 16px 20px;
    background: var(--kw-surface);
    border: 1px solid var(--kw-line);
    border-radius: 14px;
    transition: border-color 0.15s ease;
}
.kw-notif-pref-row:hover { border-color: color-mix(in srgb, var(--pref-color, #1A3A64) 50%, var(--kw-line)); }
.kw-notif-pref-icon {
    width: 44px; height: 44px;
    border-radius: 12px;
    background: color-mix(in srgb, var(--pref-color, #1A3A64) 14%, transparent);
    color: var(--pref-color, #1A3A64);
    display: flex; align-items: center; justify-content: center;
}
.kw-notif-pref-body { min-width: 0; }
.kw-notif-pref-title {
    font-weight: 600;
    color: var(--kw-text-primary);
    margin: 0 0 2px;
    font-size: 0.92rem;
}
.kw-notif-pref-desc {
    font-size: 0.78rem;
    color: var(--kw-text-muted);
    margin: 0;
}
.kw-notif-pref-toggle {
    display: flex; flex-direction: column; align-items: center;
    gap: 2px;
}
.kw-notif-pref-toggle-label {
    font-size: 0.68rem;
    color: var(--kw-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 600;
}

/* ── DIGEST CARD (preferences page top) ── */
.kw-notif-digest-card {
    background: linear-gradient(135deg, #0F172A 0%, #1E293B 100%);
    color: #fff;
    border-radius: 18px;
    padding: 28px;
    margin-bottom: 24px;
    position: relative;
    overflow: hidden;
}
.kw-notif-digest-card::before {
    content: '';
    position: absolute; inset: 0;
    background: radial-gradient(circle at 90% 10%, rgba(245,158,11,0.2), transparent 50%);
    pointer-events: none;
}
.kw-notif-digest-card-inner { position: relative; }
.kw-notif-digest-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    position: relative;
    margin-top: 18px;
}
.kw-notif-digest-tile {
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 12px;
    padding: 16px;
    display: flex; align-items: center; gap: 14px;
}
.kw-notif-digest-tile-info { flex: 1; }
.kw-notif-digest-tile-title {
    font-weight: 600;
    margin: 0 0 2px;
    color: rgba(255, 255, 255, 0.95);
    font-size: 0.92rem;
}
.kw-notif-digest-tile-desc {
    font-size: 0.78rem;
    color: rgba(255, 255, 255, 0.6);
    margin: 0;
}
@media (max-width: 600px) {
    .kw-notif-digest-grid { grid-template-columns: 1fr; }
    .kw-notif-pref-row { grid-template-columns: auto 1fr; }
    .kw-notif-pref-toggle { grid-column: 1 / -1; flex-direction: row; }
    .kw-notif-panel { width: calc(100vw - 32px); max-width: 380px; }
}

/* ══════════════════════════════════════════════════════════════
   Phase 13 — AI Knowledge Assistant
   Chat bubbles, citations, search results, suggestion chips
   ══════════════════════════════════════════════════════════════ */

.kw-ai-shell {
    display: grid;
    grid-template-rows: auto 1fr auto;
    height: calc(100vh - 180px);
    min-height: 540px;
    background: var(--kw-surface);
    border-radius: 18px;
    border: 1px solid var(--kw-line);
    overflow: hidden;
}

/* ── HERO header ── */
.kw-ai-hero {
    background:
        radial-gradient(800px 300px at 100% -20%, rgba(168,85,247,0.22), transparent 60%),
        radial-gradient(600px 300px at 0% 120%, rgba(245,158,11,0.15), transparent 60%),
        linear-gradient(135deg, #1E1B4B 0%, #312E81 60%, #4F46E5 100%);
    color: #fff;
    padding: 22px 28px;
    display: flex; align-items: center; gap: 16px;
}
.kw-ai-hero-avatar {
    width: 48px; height: 48px;
    border-radius: 14px;
    background: linear-gradient(135deg, #A855F7 0%, #6366F1 100%);
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 8px 24px rgba(168, 85, 247, 0.35);
    flex-shrink: 0;
}
.kw-ai-hero-title {
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    font-size: 1.3rem;
    margin: 0; line-height: 1.2;
}
.kw-ai-hero-sub {
    font-size: 0.85rem;
    color: rgba(255,255,255,0.7);
    margin: 4px 0 0;
}
.kw-ai-hero-status {
    margin-left: auto;
    display: inline-flex; align-items: center; gap: 6px;
    padding: 4px 12px;
    border-radius: 999px;
    background: rgba(255,255,255,0.1);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.04em;
}
.kw-ai-hero-status-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: #10B981;
    box-shadow: 0 0 0 4px rgba(16,185,129,0.18);
    animation: kwAiPulse 2s ease-in-out infinite;
}
@keyframes kwAiPulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.55; }
}

/* ── Conversation log ── */
.kw-ai-log {
    overflow-y: auto;
    padding: 24px 28px;
    background: var(--kw-surface-muted);
    display: flex; flex-direction: column; gap: 18px;
}
.kw-ai-row { display: flex; gap: 12px; }
.kw-ai-row--user { flex-direction: row-reverse; }
.kw-ai-bubble {
    max-width: min(720px, 80%);
    padding: 14px 18px;
    border-radius: 18px;
    line-height: 1.55;
    font-size: 0.93rem;
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
}
.kw-ai-bubble--user {
    background: linear-gradient(135deg, #6366F1 0%, #4F46E5 100%);
    color: #fff;
    border-bottom-right-radius: 6px;
}
.kw-ai-bubble--assistant {
    background: #fff;
    color: var(--kw-text-primary);
    border: 1px solid var(--kw-line);
    border-bottom-left-radius: 6px;
}
.kw-ai-avatar {
    width: 36px; height: 36px;
    border-radius: 12px;
    flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    color: #fff;
}
.kw-ai-avatar--assistant {
    background: linear-gradient(135deg, #A855F7 0%, #6366F1 100%);
    box-shadow: 0 4px 12px rgba(168,85,247,0.3);
}
.kw-ai-avatar--user {
    background: linear-gradient(135deg, #0F172A 0%, #1E293B 100%);
}

/* ── Citations ── */
.kw-ai-citations {
    margin-top: 12px;
    padding-top: 12px;
    border-top: 1px dashed var(--kw-line);
    display: flex; flex-direction: column; gap: 6px;
}
.kw-ai-citations-head {
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--kw-text-muted);
    margin-bottom: 4px;
}
.kw-ai-citation {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 10px;
    align-items: center;
    padding: 8px 12px;
    border-radius: 10px;
    background: var(--kw-surface-muted);
    border-left: 3px solid var(--cite-color, #A855F7);
    text-decoration: none; color: inherit;
    transition: transform 0.15s ease;
}
.kw-ai-citation:hover { transform: translateX(2px); }
.kw-ai-citation-icon {
    width: 28px; height: 28px;
    border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    background: color-mix(in srgb, var(--cite-color, #A855F7) 14%, transparent);
    color: var(--cite-color, #A855F7);
}
.kw-ai-citation-title {
    font-weight: 600;
    font-size: 0.85rem;
    color: var(--kw-text-primary);
    margin: 0;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.kw-ai-citation-snippet {
    font-size: 0.74rem;
    color: var(--kw-text-muted);
    margin: 0;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
}
.kw-ai-citation-score {
    font-size: 0.7rem; font-weight: 600;
    color: var(--cite-color, #A855F7);
    font-variant-numeric: tabular-nums;
}

/* ── Composer ── */
.kw-ai-composer {
    padding: 16px 20px;
    border-top: 1px solid var(--kw-line);
    background: var(--kw-surface);
    display: flex; flex-direction: column; gap: 10px;
}
.kw-ai-composer-input {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    align-items: end;
}
.kw-ai-textarea {
    background: var(--kw-surface-muted);
    border: 1px solid var(--kw-line);
    border-radius: 14px;
    padding: 12px 16px;
    font-family: 'DM Sans', sans-serif;
    font-size: 0.93rem;
    resize: none;
    min-height: 48px;
    max-height: 160px;
    color: var(--kw-text-primary);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.kw-ai-textarea:focus {
    outline: none;
    border-color: #6366F1;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.15);
}
.kw-ai-send {
    border: none;
    border-radius: 14px;
    background: linear-gradient(135deg, #6366F1 0%, #4F46E5 100%);
    color: #fff;
    padding: 0 20px;
    height: 48px;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex; align-items: center; gap: 6px;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.kw-ai-send:hover:not(:disabled) {
    transform: translateY(-1px);
    box-shadow: 0 8px 16px rgba(79, 70, 229, 0.35);
}
.kw-ai-send:disabled {
    background: var(--kw-surface-muted);
    color: var(--kw-text-muted);
    cursor: not-allowed;
}

.kw-ai-suggestions {
    display: flex; flex-wrap: wrap; gap: 6px;
}
.kw-ai-chip {
    background: var(--kw-surface-muted);
    border: 1px solid var(--kw-line);
    border-radius: 999px;
    padding: 6px 12px;
    font-size: 0.78rem;
    cursor: pointer;
    transition: border-color 0.15s ease, color 0.15s ease;
    color: var(--kw-text-secondary);
}
.kw-ai-chip:hover {
    border-color: #6366F1;
    color: #4F46E5;
}

/* ── Thinking indicator ── */
.kw-ai-thinking {
    display: inline-flex; gap: 4px; padding: 14px 20px;
    background: #fff;
    border: 1px solid var(--kw-line);
    border-radius: 18px;
    border-bottom-left-radius: 6px;
}
.kw-ai-thinking-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: #A855F7;
    animation: kwAiThink 1.4s infinite ease-in-out both;
}
.kw-ai-thinking-dot:nth-child(1) { animation-delay: -0.32s; }
.kw-ai-thinking-dot:nth-child(2) { animation-delay: -0.16s; }
@keyframes kwAiThink {
    0%, 80%, 100% { transform: scale(0.4); opacity: 0.5; }
    40% { transform: scale(1.0); opacity: 1; }
}

/* ── Search results page ── */
.kw-ai-search-result {
    display: grid;
    grid-template-columns: auto 1fr auto;
    gap: 14px;
    align-items: center;
    padding: 14px 18px;
    background: var(--kw-surface);
    border: 1px solid var(--kw-line);
    border-left: 3px solid var(--result-color, #6366F1);
    border-radius: 14px;
    margin-bottom: 10px;
    text-decoration: none; color: inherit;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.kw-ai-search-result:hover {
    transform: translateX(2px);
    box-shadow: 0 8px 16px rgba(15, 23, 42, 0.06);
}

/* ── Conversation history list ── */
.kw-ai-conv {
    display: grid;
    grid-template-columns: auto 1fr auto auto;
    gap: 14px;
    align-items: center;
    padding: 14px 18px;
    background: var(--kw-surface);
    border: 1px solid var(--kw-line);
    border-radius: 14px;
    margin-bottom: 10px;
    transition: border-color 0.15s ease;
}
.kw-ai-conv:hover { border-color: #6366F1; }
.kw-ai-conv-icon {
    width: 40px; height: 40px;
    border-radius: 12px;
    background: color-mix(in srgb, #6366F1 14%, transparent);
    color: #6366F1;
    display: flex; align-items: center; justify-content: center;
}
.kw-ai-conv-title {
    font-weight: 600;
    margin: 0;
    color: var(--kw-text-primary);
    font-size: 0.95rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.kw-ai-conv-meta {
    font-size: 0.78rem;
    color: var(--kw-text-muted);
    margin: 4px 0 0;
}

@media (max-width: 720px) {
    .kw-ai-bubble { max-width: 92%; }
    .kw-ai-shell { height: calc(100vh - 120px); border-radius: 0; }
}

/* ── 2FA Setup Page ── */
.kw-2fa-page {
    max-width: 680px;
    margin: 0 auto;
    padding: 2rem 1rem;
}

.kw-2fa-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 2rem;
}

.kw-2fa-header-icon {
    color: var(--mud-palette-primary);
}

.kw-2fa-title {
    font-family: 'Outfit', sans-serif;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--mud-palette-text-primary);
    margin: 0;
}

.kw-2fa-subtitle {
    font-size: 0.875rem;
    color: var(--mud-palette-text-secondary);
    margin: 0.25rem 0 0;
}

.kw-2fa-card {
    border: 1px solid var(--mud-palette-lines-default);
    border-radius: 12px;
    padding: 1.5rem;
}

.kw-2fa-manual-key {
    background: var(--mud-palette-background-grey);
    border-radius: 8px;
    padding: 1rem;
    margin-top: 0.5rem;
}

.kw-2fa-shared-key {
    display: block;
    font-family: 'DM Sans', monospace;
    font-size: 1.1rem;
    font-weight: 600;
    letter-spacing: 0.15em;
    color: var(--mud-palette-primary);
    margin-top: 0.5rem;
    word-break: break-all;
}

.kw-2fa-codes {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 0.5rem;
}

.kw-2fa-code {
    display: block;
    background: var(--mud-palette-background-grey);
    border-radius: 6px;
    padding: 0.5rem 0.75rem;
    font-family: 'DM Sans', monospace;
    font-size: 0.9rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    color: var(--mud-palette-text-primary);
    text-align: center;
}

/* ══════════════════════════════════════════════════════════════
   Approval Timeline
   ══════════════════════════════════════════════════════════════ */

.kw-approval-timeline {
    display: flex;
    flex-direction: column;
    gap: 0;
    position: relative;
    padding-left: 4px;
}

.kw-timeline-item {
    display: flex;
    gap: 16px;
    padding: 16px 0;
    position: relative;
}

.kw-timeline-item:not(:last-child)::before {
    content: '';
    position: absolute;
    left: 11px;
    top: 40px;
    bottom: 0;
    width: 2px;
    background: var(--kw-border);
}

.kw-timeline-marker {
    width: 24px;
    height: 24px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    z-index: 1;
    background: var(--kw-surface);
}

.kw-timeline-completed .kw-timeline-marker {
    color: var(--kw-emerald-500);
}

.kw-timeline-current .kw-timeline-marker {
    color: var(--kw-amber-500);
    animation: kw-pulse 2s ease-in-out infinite;
}

.kw-timeline-returned .kw-timeline-marker {
    color: var(--kw-rose-500);
}

.kw-timeline-upcoming .kw-timeline-marker {
    color: var(--kw-text-muted);
}

.kw-timeline-content {
    flex: 1;
    min-width: 0;
}

.kw-timeline-header {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 4px;
}

.kw-timeline-header strong {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.9rem;
    color: var(--kw-text-primary);
}

.kw-timeline-status-label {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.72rem;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 100px;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.kw-timeline-completed .kw-timeline-status-label {
    background: rgba(5, 150, 105, 0.08);
    color: var(--kw-emerald-500);
}

.kw-timeline-current .kw-timeline-status-label {
    background: rgba(232, 146, 12, 0.08);
    color: var(--kw-amber-500);
}

.kw-timeline-returned .kw-timeline-status-label {
    background: rgba(225, 29, 72, 0.08);
    color: var(--kw-rose-500);
}

.kw-timeline-upcoming .kw-timeline-status-label {
    background: rgba(100, 116, 139, 0.08);
    color: var(--kw-text-muted);
}

.kw-timeline-approvers {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.82rem;
    color: var(--kw-text-secondary);
    margin-bottom: 6px;
}

.kw-timeline-action {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: 'DM Sans', sans-serif;
    font-size: 0.8rem;
    margin-top: 6px;
}

.kw-timeline-action-by {
    font-weight: 600;
    color: var(--kw-text-primary);
}

.kw-timeline-action-type {
    color: var(--kw-text-secondary);
}

.kw-timeline-date {
    color: var(--kw-text-muted);
    font-size: 0.75rem;
}

.kw-timeline-comments {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.8rem;
    color: var(--kw-text-secondary);
    margin-top: 6px;
    padding: 8px 12px;
    background: var(--kw-surface-muted);
    border-radius: var(--kw-radius-sm);
    border-left: 3px solid var(--kw-border);
    font-style: italic;
}

/* ══════════════════════════════════════════════════════════════
   Module Page Headers (reusable across all modules)
   ══════════════════════════════════════════════════════════════ */

.kw-module-page {
    max-width: 1200px;
    margin: 0 auto;
}

.kw-module-header {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 28px 32px;
    border-radius: var(--kw-radius-lg);
    margin-bottom: 24px;
    position: relative;
    overflow: hidden;
}

.kw-module-header::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -10%;
    width: 300px;
    height: 300px;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.08) 0%, transparent 70%);
    pointer-events: none;
}

.kw-module-title {
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    font-size: 1.4rem;
    color: #FFFFFF;
    margin: 0;
    line-height: 1.2;
}

.kw-module-subtitle {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.6);
    margin: 4px 0 0;
}

/* ══════════════════════════════════════════════════════════════
   Phase 10 — Dashboards & Analytics
   Modern bento layout, gradient KPI tiles, sparklines, RAG bars
   ══════════════════════════════════════════════════════════════ */

.kw-dash {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding-bottom: 32px;
}

/* ── Hero header ── */
.kw-dash-hero {
    position: relative;
    border-radius: 24px;
    padding: 28px 32px;
    color: #fff;
    overflow: hidden;
    box-shadow: 0 12px 32px rgba(15, 23, 42, 0.12);
}
.kw-dash-hero::before {
    content: '';
    position: absolute; inset: 0;
    background: radial-gradient(circle at 88% -10%, rgba(255,255,255,0.18), transparent 55%),
                radial-gradient(circle at 5% 110%, rgba(255,255,255,0.10), transparent 60%);
    pointer-events: none;
}
.kw-dash-hero-inner {
    position: relative;
    display: flex; align-items: center; gap: 24px; flex-wrap: wrap;
}
.kw-dash-hero-eyebrow {
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-size: 0.7rem;
    color: rgba(255,255,255,0.7);
    margin: 0;
}
.kw-dash-hero-title {
    font-family: 'Outfit', sans-serif;
    font-weight: 700;
    font-size: 1.75rem;
    margin: 4px 0 6px;
    line-height: 1.15;
}
.kw-dash-hero-sub {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.9rem;
    color: rgba(255,255,255,0.78);
    margin: 0;
}
.kw-dash-hero-actions { margin-left: auto; display: flex; gap: 8px; }

/* ── KPI tile (modern stat card with sparkline) ── */
.kw-dash-kpi {
    background: var(--kw-surface);
    border: 1px solid var(--kw-line);
    border-radius: 18px;
    padding: 18px 20px 20px;
    position: relative;
    overflow: hidden;
    transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.kw-dash-kpi:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 32px rgba(15, 23, 42, 0.08);
}
.kw-dash-kpi::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--kpi-color, #1A3A64), transparent);
    opacity: 0.85;
}
.kw-dash-kpi-head {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 10px;
}
.kw-dash-kpi-label {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--kw-text-muted);
}
.kw-dash-kpi-icon {
    width: 36px; height: 36px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 10px;
    color: var(--kpi-color, #1A3A64);
    background: color-mix(in srgb, var(--kpi-color, #1A3A64) 12%, transparent);
}
.kw-dash-kpi-value {
    font-family: 'Outfit', sans-serif;
    font-size: 2rem;
    font-weight: 700;
    color: var(--kw-text-primary);
    line-height: 1.05;
    letter-spacing: -0.02em;
}
.kw-dash-kpi-sub {
    margin-top: 4px;
    font-size: 0.78rem;
    color: var(--kw-text-muted);
    display: flex; align-items: center; gap: 4px;
}

.kw-dash-trend {
    display: inline-flex; align-items: center; gap: 2px;
    font-size: 0.72rem; font-weight: 600;
    padding: 2px 6px; border-radius: 999px;
}
.kw-dash-trend--up { color: #047857; background: rgba(16,185,129,0.12); }
.kw-dash-trend--down { color: #B91C1C; background: rgba(239,68,68,0.12); }
.kw-dash-trend--flat { color: #475569; background: rgba(100,116,139,0.12); }

/* Inline SVG sparkline area — reserved width */
.kw-spark { display: block; width: 100%; height: 36px; margin-top: 10px; }

/* ── Bento grid panel ── */
.kw-dash-panel {
    background: var(--kw-surface);
    border: 1px solid var(--kw-line);
    border-radius: 18px;
    padding: 20px;
    display: flex; flex-direction: column; gap: 14px;
}
.kw-dash-panel-head {
    display: flex; align-items: center; gap: 10px;
}
.kw-dash-panel-title {
    font-family: 'Outfit', sans-serif;
    font-weight: 600;
    font-size: 1rem;
    margin: 0;
    color: var(--kw-text-primary);
}
.kw-dash-panel-sub {
    font-size: 0.78rem;
    color: var(--kw-text-muted);
    margin: 0;
}
.kw-dash-panel-actions { margin-left: auto; }

/* ── RAG status segmented bar ── */
.kw-rag-bar {
    display: flex; height: 8px; border-radius: 999px; overflow: hidden;
    background: var(--kw-line);
    margin: 6px 0 4px;
}
.kw-rag-bar-seg { height: 100%; transition: width 0.3s ease; }
.kw-rag-bar-seg--green { background: #10B981; }
.kw-rag-bar-seg--amber { background: #F59E0B; }
.kw-rag-bar-seg--red { background: #EF4444; }
.kw-rag-legend {
    display: flex; gap: 12px; font-size: 0.74rem; color: var(--kw-text-muted);
}
.kw-rag-legend-item { display: inline-flex; align-items: center; gap: 4px; }
.kw-rag-dot { width: 8px; height: 8px; border-radius: 50%; }

/* ── Activity feed ── */
.kw-dash-feed {
    display: flex; flex-direction: column; gap: 0;
    max-height: 420px; overflow-y: auto;
}
.kw-dash-feed-item {
    display: flex; gap: 12px; padding: 12px 0;
    border-bottom: 1px dashed var(--kw-line);
}
.kw-dash-feed-item:last-child { border-bottom: none; }
.kw-dash-feed-icon {
    width: 32px; height: 32px;
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    background: color-mix(in srgb, var(--feed-color, #64748B) 14%, transparent);
    color: var(--feed-color, #64748B);
    flex-shrink: 0;
}
.kw-dash-feed-content { flex: 1; min-width: 0; }
.kw-dash-feed-title {
    font-size: 0.88rem; font-weight: 600;
    color: var(--kw-text-primary);
    margin: 0 0 2px;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.kw-dash-feed-desc {
    font-size: 0.78rem; color: var(--kw-text-muted); margin: 0;
}
.kw-dash-feed-time {
    font-size: 0.72rem; color: var(--kw-text-muted);
    flex-shrink: 0; padding-top: 4px;
}

/* ── Distribution bars (horizontal category chart) ── */
.kw-dist-row {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 8px 12px;
    align-items: center;
    padding: 6px 0;
}
.kw-dist-label {
    font-size: 0.85rem;
    color: var(--kw-text-primary);
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.kw-dist-value {
    font-size: 0.82rem; font-weight: 600;
    font-variant-numeric: tabular-nums;
    color: var(--kw-text-secondary);
}
.kw-dist-bar {
    grid-column: 1 / 3;
    height: 6px; border-radius: 999px;
    background: var(--kw-line);
    overflow: hidden;
}
.kw-dist-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--bar-color, #1A3A64), color-mix(in srgb, var(--bar-color, #1A3A64) 60%, white));
    transition: width 0.4s ease;
}

/* ── Empty state ── */
.kw-dash-empty {
    text-align: center;
    padding: 32px 16px;
    color: var(--kw-text-muted);
}
.kw-dash-empty-icon {
    font-size: 2.5rem;
    opacity: 0.35;
    margin-bottom: 8px;
}

/* ── Pending action card (User dashboard) ── */
.kw-action-tile {
    border: 1px solid var(--kw-line);
    border-left: 3px solid var(--action-color, #1A3A64);
    border-radius: 12px;
    padding: 12px 14px;
    background: var(--kw-surface);
    display: flex; gap: 10px; align-items: flex-start;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
    text-decoration: none;
    color: inherit;
}
.kw-action-tile:hover {
    transform: translateX(2px);
    box-shadow: 0 6px 16px rgba(15, 23, 42, 0.08);
}
.kw-action-tile-body { flex: 1; min-width: 0; }
.kw-action-tile-title {
    font-size: 0.88rem; font-weight: 600;
    color: var(--kw-text-primary);
    margin: 0;
    overflow: hidden; text-overflow: ellipsis;
}
.kw-action-tile-desc {
    font-size: 0.75rem; color: var(--kw-text-muted);
    margin: 2px 0 0;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

/* ── Hero gradient variants per dashboard ── */
.kw-hero--executive { background: linear-gradient(135deg, #0F172A 0%, #1E40AF 60%, #0EA5E9 100%); }
.kw-hero--investments { background: linear-gradient(135deg, #1E40AF 0%, #2563EB 50%, #3B82F6 100%); }
.kw-hero--planning { background: linear-gradient(135deg, #115E59 0%, #0D9488 50%, #14B8A6 100%); }
.kw-hero--activities { background: linear-gradient(135deg, #9A3412 0%, #EA580C 50%, #F97316 100%); }
.kw-hero--resources { background: linear-gradient(135deg, #064E3B 0%, #047857 50%, #10B981 100%); }
.kw-hero--user { background: linear-gradient(135deg, #1E293B 0%, #334155 50%, #475569 100%); }
.kw-hero--admin { background: linear-gradient(135deg, #4C1D95 0%, #7C3AED 50%, #A855F7 100%); }
.kw-hero--tracker { background: linear-gradient(135deg, #1E3A8A 0%, #1D4ED8 50%, #6366F1 100%); }

/* ── Stagger fade-in animation ── */
@keyframes kwDashFade {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}
.kw-dash > * { animation: kwDashFade 0.4s ease both; }
.kw-dash > *:nth-child(2) { animation-delay: 0.06s; }
.kw-dash > *:nth-child(3) { animation-delay: 0.12s; }
.kw-dash > *:nth-child(4) { animation-delay: 0.18s; }
.kw-dash > *:nth-child(5) { animation-delay: 0.24s; }

/* Dark mode */
.mud-theme-dark .kw-dash-kpi,
.mud-theme-dark .kw-dash-panel,
.mud-theme-dark .kw-action-tile {
    background: rgba(255,255,255,0.02);
    border-color: rgba(255,255,255,0.08);
}

/* ──────────────────────────────────────────────────────────────
   Work-plan bulk grid editor (Excel-like): frozen panes + inline cells
   ────────────────────────────────────────────────────────────── */
.kw-grid-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    flex-wrap: wrap;
    margin-bottom: 8px;
}
.kw-grid-toolbar-info { display: flex; align-items: center; gap: 0.5rem; }
.kw-grid-toolbar-actions { display: flex; align-items: center; gap: 0.25rem; flex-wrap: wrap; }

.kw-grid-wrap {
    max-height: 65vh;
    overflow: auto;
    border: 1px solid var(--kw-line, #e2e8f0);
    border-radius: 8px;
    background: var(--mud-palette-surface, #fff);
}
.kw-grid {
    border-collapse: separate;
    border-spacing: 0;
    width: 100%;
    font-size: 0.8rem;
}
.kw-grid th, .kw-grid td {
    border-bottom: 1px solid var(--kw-line, #e2e8f0);
    border-right: 1px solid var(--kw-line, #eef2f7);
    padding: 2px 6px;
    white-space: nowrap;
    background: var(--mud-palette-surface, #fff);
}
.kw-grid thead th {
    position: sticky;
    top: 0;
    z-index: 3;
    background: var(--mud-palette-background-grey, #f1f5f9);
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.68rem;
    letter-spacing: 0.03em;
    color: var(--kw-text-muted, #64748b);
    text-align: left;
}
.kw-grid .kw-grid-num { text-align: right; }
.kw-grid th.kw-grid-num { text-align: right; }
.kw-grid .kw-grid-tint { background: var(--kw-amber-100, #fef3c7); }
.kw-grid thead th.kw-grid-tint { background: #fde9b8; }

/* frozen context columns (Activity, Indicator) */
.kw-grid .kw-grid-c1, .kw-grid .kw-grid-c2 {
    position: sticky;
    z-index: 2;
    overflow: hidden;
    text-overflow: ellipsis;
    font-weight: 500;
}
.kw-grid .kw-grid-c1 { left: 0; min-width: 170px; max-width: 170px; }
.kw-grid .kw-grid-c2 { left: 170px; min-width: 150px; max-width: 150px; }
.kw-grid thead th.kw-grid-c1, .kw-grid thead th.kw-grid-c2 { z-index: 4; }

.kw-grid tfoot td {
    font-weight: 700;
    background: var(--mud-palette-background-grey, #f8fafc);
    position: sticky;
    bottom: 0;
    z-index: 2;
}
.kw-grid tfoot td.kw-grid-c1, .kw-grid tfoot td.kw-grid-c2 { z-index: 3; }

.kw-grid-input {
    width: 100%;
    min-width: 64px;
    border: 1px solid transparent;
    background: transparent;
    padding: 3px 4px;
    font-size: 0.8rem;
    font-family: inherit;
    color: inherit;
    border-radius: 3px;
}
.kw-grid-num .kw-grid-input { text-align: right; }
.kw-grid-input:hover { border-color: var(--kw-line, #e2e8f0); }
.kw-grid-input:focus {
    outline: none;
    border-color: var(--kw-amber-400, #fbbf24);
    background: #fff;
    box-shadow: 0 0 0 2px rgba(245, 158, 11, 0.15);
}
.kw-grid-input.kw-grid-dirty { background: var(--kw-amber-100, #fef3c7); border-color: var(--kw-amber-300, #fcd34d); }
.kw-grid-input.kw-grid-invalid { background: #fee2e2; border-color: #ef4444; color: #b91c1c; }
.kw-grid-rowfail td { background: #fef2f2 !important; }
.kw-grid-empty { text-align: center; padding: 16px; color: var(--kw-text-muted, #94a3b8); }

.mud-theme-dark .kw-grid th,
.mud-theme-dark .kw-grid td { background: #1e293b; border-color: rgba(255,255,255,0.07); }
.mud-theme-dark .kw-grid thead th { background: #0f172a; }
.mud-theme-dark .kw-grid-input:focus { background: #0f172a; }
