﻿:root {
    --admin-accent: #6366f1;
    --admin-card: #1e293b;
    --admin-border: rgba(148, 163, 184, 0.15);
    --admin-text: #e2e8f0;
    --admin-muted: #64748b;
}

html {
    overflow-x: hidden;
    min-height: 100%;
}

body {
    min-height: 100%;
}

h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}

.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: #fff;
}

.blazor-error-boundary::after {
    content: "An error has occurred.";
}

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.rrh-page-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.rrh-loading-tile {
    min-height: 110px;
    justify-content: center;
}

.rrh-kpi-card {
    gap: 0.5rem;
}

.rrh-kpi-value {
    margin: 0;
    font-size: 1.5rem;
    line-height: 1.1;
}

.rrh-kpi-sub {
    margin: 0;
    font-size: 0.8rem;
    color: var(--text-secondary);
}

.rrh-progress-shell {
    gap: 0.6rem;
}

.rrh-progress-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.35rem;
}

.rrh-progress-track {
    height: 6px;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.08);
    overflow: hidden;
    margin-bottom: 0.15rem;
}

.rrh-progress-fill {
    height: 100%;
    border-radius: 999px;
}

.rrh-selectable-row {
    cursor: pointer;
}

.rrh-summary-ellipsis {
    max-width: 260px;
    display: block;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.rrh-inline-detail {
    border-radius: 12px;
    padding: 0.85rem;
    background: rgba(0, 0, 0, 0.03);
}

.rrh-btn-xs {
    padding: 0.1rem 0.35rem;
    font-size: 0.75rem;
    line-height: 1.4;
    border-radius: 0.2rem;
}


.rrh-auth-loading,
.rrh-auth-redirect {
    min-height: 100dvh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2rem;
    color: var(--text-secondary, #94a3b8);
    font-size: 0.95rem;
}

[data-theme="dark"] body,
[data-theme="dark"] .glass-container,
[data-theme="dark"] .layout-body,
[data-theme="dark"] .glass-main {
    background-color: #081122;
}

[data-theme="dark"] .glass-container,
[data-theme="dark"] .layout-body,
[data-theme="dark"] .glass-main {
    min-height: 100dvh;
}

[data-theme="dark"] .glass-main,
[data-theme="dark"] .layout-body {
    background: transparent !important;
}

.docs-modal-backdrop {
    background: rgba(0, 0, 0, 0.5);
}

.docs-preview-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.docs-preview-frame {
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 12px;
    padding: 0.75rem;
    background: rgba(248, 250, 252, 0.95);
}

.docs-preview-image {
    display: block;
    width: 100%;
    max-height: 70vh;
    object-fit: contain;
}

.rrh-sync-card {
    gap: 0.75rem;
}

.rrh-sync-dl {
    margin: 0;
    display: grid;
    gap: 0.55rem;
}

.rrh-sync-dl > div {
    display: grid;
    grid-template-columns: 150px 1fr;
    gap: 0.4rem;
}

.rrh-sync-dl dt {
    margin: 0;
    font-weight: 600;
    color: var(--text-secondary);
}

.rrh-sync-dl dd {
    margin: 0;
}

.rrh-sync-dl-wide > div {
    grid-template-columns: 180px 1fr;
}

.rrh-path {
    overflow-wrap: anywhere;
    word-break: break-word;
}

@media (max-width: 768px) {
    .rrh-sync-dl > div,
    .rrh-sync-dl-wide > div {
        grid-template-columns: 1fr;
    }

    .rrh-chat-bubble {
        max-width: 100%;
    }

    .bulk-processing-controls {
        backdrop-filter: none;
        background: var(--color-bg-primary);
    }

    .glass-blur {
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
    }

    * {
        -webkit-tap-highlight-color: transparent;
    }

    .rrh-page-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.5rem;
    }

    .rrh-kpi-value {
        font-size: 1.3rem;
    }

    .rrh-kpi-sub {
        font-size: 0.75rem;
    }

    .rrh-summary-ellipsis {
        max-width: 160px;
    }

    .rrh-inline-detail {
        padding: 0.65rem;
    }

    .no-outer-scroll {
        height: auto;
        max-height: calc(100dvh - 120px);
    }

    .invoice-table-container {
        -webkit-overflow-scrolling: touch;
    }

    .invoice-table tbody tr {
        min-height: 44px;
    }

    .invoice-table td {
        padding: 0.45rem 0.5rem;
    }

    .section-label {
        font-size: 0.8rem;
    }

    .glass-tile {
        padding: 0.75rem;
    }

    .mobile-toggle-container button {
        min-height: 44px;
        min-width: 44px;
        padding: 0.5rem 0.75rem;
    }

    .mobile-menu-toggle {
        border-radius: 12px !important;
    }

    .mobile-menu-toggle i {
        margin: 0 !important;
    }

    .form-control,
    .form-select {
        font-size: 16px;
        min-height: 44px;
    }

    .rrh-btn-xs {
        min-height: 32px;
        padding: 0.2rem 0.45rem;
        font-size: 0.78rem;
    }
}

@media (max-width: 480px) {
    .rrh-kpi-value {
        font-size: 1.15rem;
    }

    .glass-tile {
        padding: 0.6rem;
        border-radius: 10px;
    }

    .rrh-progress-row span.small {
        font-size: 0.72rem;
    }
}

[data-theme="dark"] .rrh-kpi-sub,
[data-theme="dark"] .rrh-sync-dl dt {
    color: #9ca3af;
}

[data-theme="dark"] .rrh-progress-track {
    background: rgba(255, 255, 255, 0.1);
}

[data-theme="dark"] .rrh-inline-detail {
    background: rgba(255, 255, 255, 0.06);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

/* -- Chat shell mode — hide AppShell chrome ------------------- */
body.chat-shell-mode .sidebar-nav,
body.chat-shell-mode .sidebar,
body.chat-shell-mode .glass-sidebar,
body.chat-shell-mode .mobile-toggle-container {
    display: none !important;
}

body.chat-shell-mode .glass-container {
    padding: 0 !important;
}

body.chat-shell-mode .glass-main {
    width: 100%;
    max-width: 100%;
}

body.chat-shell-mode .layout-body {
    padding: 0 !important;
}

/* Login page — full-screen, no sidebar */
.login-fullscreen {
    position: fixed;
    inset: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #111318;
    z-index: 9999;
}

.login-card {
    width: min(360px, calc(100% - 2rem));
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.login-brand {
    font-size: 1.5rem;
    font-weight: 700;
    color: #f1f5f9;
    text-align: center;
    margin-bottom: 0.5rem;
    letter-spacing: -0.01em;
}

.login-input {
    width: 100%;
    box-sizing: border-box;
    border: 1px solid rgba(148, 163, 184, 0.3);
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.06);
    color: #f1f5f9;
    padding: 0.75rem 0.85rem;
    font-size: 1rem;
    outline: none;
    transition: border-color 0.15s;
}

.login-input:focus {
    border-color: rgba(148, 163, 184, 0.6);
}

.login-input::placeholder {
    color: rgba(148, 163, 184, 0.5);
}

.login-btn {
    width: 100%;
    border: 1px solid rgba(148, 163, 184, 0.25);
    border-radius: 10px;
    background: #e2e8f0;
    color: #0f172a;
    padding: 0.75rem;
    font-size: 0.95rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s;
}

.login-btn:hover:not(:disabled) {
    background: #f1f5f9;
}

.login-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.login-btn-back {
    width: 100%;
    border: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: 10px;
    background: transparent;
    color: rgba(148, 163, 184, 0.7);
    padding: 0.6rem;
    font-size: 0.85rem;
    font-weight: 500;
    cursor: pointer;
}

.login-btn-back:hover:not(:disabled) {
    color: #f1f5f9;
}

/* -- Command Center ------------------------------------------ */

.cc-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.cc-chip {
    display: inline-flex;
    align-items: center;
    padding: 0.3rem 0.85rem;
    border-radius: 9999px;
    font-size: 0.8rem;
    font-weight: 600;
    text-decoration: none;
    transition: opacity 0.15s;
}

.cc-chip:hover { opacity: 0.8; }

.cc-chip.chip-critical {
    background: rgba(220, 38, 38, 0.18);
    color: #f87171;
    border: 1px solid rgba(220, 38, 38, 0.35);
}

.cc-chip.chip-high {
    background: rgba(234, 179, 8, 0.18);
    color: #facc15;
    border: 1px solid rgba(234, 179, 8, 0.35);
}

.cc-chip.chip-medium {
    background: rgba(14, 165, 233, 0.15);
    color: #38bdf8;
    border: 1px solid rgba(14, 165, 233, 0.25);
}

.cc-chip.chip-value {
    background: rgba(34, 197, 94, 0.15);
    color: #4ade80;
    border: 1px solid rgba(34, 197, 94, 0.25);
}

/* Command Center action cards */
.cc-action-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1rem 1.25rem;
    border-radius: 12px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.04);
    transition: transform 0.15s, box-shadow 0.15s, border-color 0.15s;
    min-height: 90px;
    color: inherit;
}

.cc-action-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0,0,0,0.25);
    text-decoration: none;
    color: inherit;
}

.cc-card-icon {
    font-size: 1.75rem;
    opacity: 0.75;
    flex-shrink: 0;
}

.cc-card-count {
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1;
}

.cc-card-label {
    font-size: 0.85rem;
    font-weight: 600;
    margin-top: 0.1rem;
}

.cc-card-sub {
    font-size: 0.72rem;
    color: var(--text-muted, #9ca3af);
    margin-top: 0.1rem;
}

.cc-card-alert {
    border-color: rgba(220, 38, 38, 0.3);
    background: rgba(220, 38, 38, 0.08);
}

.cc-card-alert .cc-card-count { color: #f87171; }
.cc-card-alert .cc-card-icon { color: #f87171; }

.cc-card-warn {
    border-color: rgba(234, 179, 8, 0.3);
    background: rgba(234, 179, 8, 0.07);
}

.cc-card-warn .cc-card-count { color: #facc15; }
.cc-card-warn .cc-card-icon { color: #facc15; }

.cc-card-ok {
    opacity: 0.65;
}

.cc-card-neutral {
    border-color: rgba(255, 255, 255, 0.12);
}

/* ----------------------------------------------------------- */

.login-error {
    border: 1px solid rgba(239, 68, 68, 0.3);
    background: rgba(239, 68, 68, 0.1);
    color: #fca5a5;
    border-radius: 10px;
    padding: 0.65rem 0.85rem;
    font-size: 0.85rem;
    text-align: center;
}

/* -- Charcoal override — strips sky-blue brand accent throughout the app -- */
:root {
    --brand-accent: #6e7b8a;
    --brand-accent-dark: #5c6878;
    --brand-logo-gradient: linear-gradient(145deg, #252930, #1a1e25);
    --brand-logo-shadow: 0 8px 24px rgba(0, 0, 0, 0.45);
    --appshell-background: #111318;
}

/* Primary button — charcoal instead of azure */
[data-theme="dark"] .modern-btn-primary,
[data-theme="dark"] .btn-primary {
    background: #383d47 !important;
    border-color: rgba(255, 255, 255, 0.18) !important;
    color: #e0e5ec !important;
}
[data-theme="dark"] .modern-btn-primary:hover,
[data-theme="dark"] .btn-primary:hover {
    background: #424850 !important;
}

/* Count/badge pills */
/* Attention chip — medium severity uses blue by default; neutralize */
.cc-chip.chip-medium {
    background: rgba(100, 112, 128, 0.18);
    color: #94a3b8;
    border: 1px solid rgba(100, 112, 128, 0.28);
}

/* ------------------------------------------
   Emma Action Modal (emod-*)
   Neutral tokenized surfaces for Email / Slack / Text
   ------------------------------------------ */

.emod-overlay {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.56);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    animation: emod-fade 0.16s ease;
}



body.emod-open {
    overflow: hidden;
}

@keyframes emod-fade {
    from { opacity: 0; }
    to   { opacity: 1; }
}

.emod {
    width: 92%;
    max-width: 460px;
    background: var(--bg-card, #161616);
    border: 1px solid var(--border, #2a2a2a);
    border-radius: 8px;
    box-shadow: 0 24px 56px rgba(0, 0, 0, 0.5);
    overflow: hidden;
    animation: emod-up 0.2s cubic-bezier(0.32, 0.72, 0, 1);
}

@keyframes emod-up {
    from { transform: translateY(16px) scale(0.98); opacity: 0; }
    to   { transform: translateY(0) scale(1); opacity: 1; }
}

.emod-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.9rem 1.15rem;
    border-bottom: 1px solid var(--border-subtle, #1f1f1f);
    background: var(--bg-surface, #111111);
}

.emod-title {
    font-size: 0.68rem;
    font-weight: 600;
    font-family: var(--font-mono, 'JetBrains Mono', monospace);
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--text-secondary, #777777);
    margin: 0;
}

.emod-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: var(--bg-elevated, #1a1a1a);
    border: 1px solid var(--border, #2a2a2a);
    border-radius: 6px;
    color: var(--text-secondary, #777777);
    font-size: 1rem;
    cursor: pointer;
    transition: color 0.12s, background 0.12s;
    line-height: 1;
}

.emod-close:hover {
    color: var(--accent-blue, #e8a838);
    border-color: var(--accent-blue, #e8a838);
    background: var(--bg-card-hover, #1e1e1e);
}

.emod-body {
    padding: 1rem 1.15rem 1.25rem;
}

.emod-form {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
}

.emod-label {
    font-size: 0.62rem;
    font-weight: 600;
    font-family: var(--font-mono, 'JetBrains Mono', monospace);
    color: var(--text-muted, #444444);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: -0.25rem;
}

.emod-input {
    width: 100%;
    padding: 0.6rem 0.8rem;
    font-size: 0.8rem;
    font-family: var(--font-sans, 'DM Sans', sans-serif);
    color: var(--text-primary, #d4d4d4);
    background: var(--bg-elevated, #1a1a1a);
    border: 1px solid var(--border, #2a2a2a);
    border-radius: 8px;
    outline: none;
    transition: border-color 0.15s, box-shadow 0.15s;
    box-sizing: border-box;
    -webkit-appearance: none;
}

.emod-input:focus {
    border-color: var(--accent-blue, #e8a838);
    box-shadow: 0 0 0 2px var(--accent-blue-dim, #2b2214);
}

.emod-textarea {
    resize: vertical;
    min-height: 88px;
    max-height: 220px;
    line-height: 1.55;
    scrollbar-width: thin;
    scrollbar-color: rgba(255, 255, 255, 0.06) transparent;
}

select.emod-input {
    cursor: pointer;
    background-image: none;
    background-repeat: no-repeat;
    background-position: right 10px center;
    padding-right: 2rem;
}

.emod-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
    margin-top: 0.5rem;
    padding-top: 0.5rem;
    border-top: 1px solid var(--border-subtle, #1f1f1f);
}

.emod-cancel {
    padding: 0.48rem 0.95rem;
    font-size: 0.68rem;
    font-family: var(--font-mono, 'JetBrains Mono', monospace);
    font-weight: 500;
    color: var(--text-secondary, #777777);
    background: var(--bg-elevated, #1a1a1a);
    border: 1px solid var(--border, #2a2a2a);
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.12s;
}

.emod-cancel:hover {
    color: var(--accent-blue, #e8a838);
    border-color: var(--accent-blue, #e8a838);
    background: var(--bg-card-hover, #1e1e1e);
}

.emod-submit {
    padding: 0.48rem 1.1rem;
    font-size: 0.68rem;
    font-weight: 600;
    font-family: var(--font-mono, 'JetBrains Mono', monospace);
    letter-spacing: 0.01em;
    color: var(--text-secondary, #777777);
    background: var(--bg-elevated, #1a1a1a);
    border: 1px solid var(--border, #2a2a2a);
    border-radius: 6px;
    cursor: pointer;
    transition: all 0.15s;
    box-shadow: none;
}

.emod-submit:hover {
    border-color: var(--accent-blue, #e8a838);
    color: var(--accent-blue, #e8a838);
    background: var(--bg-card-hover, #1e1e1e);
    transform: translateY(-1px);
}

.emod-submit:active {
    transform: translateY(0);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.25);
}

.emod-submit:disabled {
    opacity: 0.5;
    pointer-events: none;
    transform: none;
}

/* -- Toast -- */

.emod-toast {
    position: fixed;
    bottom: 1.5rem;
    left: 50%;
    transform: translateX(-50%);
    padding: 0.6rem 1.15rem;
    font-size: 0.82rem;
    font-weight: 500;
    color: var(--accent-green, #3cba6f);
    background: var(--accent-green-dim, #162b1e);
    border: 1px solid var(--accent-green, #3cba6f);
    border-radius: 8px;
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.35);
    z-index: 10000;
    animation: emod-toast-in 0.22s cubic-bezier(0.32, 0.72, 0, 1);
    font-family: var(--font-mono, 'JetBrains Mono', monospace);
}

.emod-toast-err {
    color: var(--accent-red, #e85454);
    background: var(--accent-red-dim, #2b1414);
    border-color: var(--accent-red, #e85454);
}

.emod-toast-out {
    animation: emod-toast-out 0.3s ease forwards;
}

@keyframes emod-toast-in {
    from { opacity: 0; transform: translateX(-50%) translateY(10px) scale(0.96); }
    to   { opacity: 1; transform: translateX(-50%) translateY(0) scale(1); }
}

@keyframes emod-toast-out {
    to { opacity: 0; transform: translateX(-50%) translateY(10px) scale(0.96); }
}

