:root {
    --brand-ink: #0f0144;
    --brand-purple: #250088;
    --brand-blue: #007cff;
    --brand-mint: #8ed6c0;
    --brand-white: #ffffff;
    --brand-page: #f6f9fd;
    --brand-blue-soft: #e7f2ff;
    --brand-mint-soft: #e8f8f3;
    --brand-purple-soft: #f0ebff;
    --brand-border: #d9e5f1;
    --brand-text: #172033;
    --brand-muted: #64748b;
    --brand-warning: #f0b429;
    --brand-warning-soft: #fff7dc;
    --brand-critical: #5b3b00;
    --brand-critical-soft: #fff1bf;
    --brand-shadow: rgba(15, 1, 68, 0.08);
    --brand-shadow-strong: rgba(15, 1, 68, 0.18);
    --kendo-color-primary: var(--brand-blue);
    --kendo-color-primary-hover: #0066d6;
    --kendo-color-primary-active: #0058ba;
    --kendo-color-primary-subtle: var(--brand-blue-soft);
    --kendo-color-primary-emphasis: rgba(0, 124, 255, 0.32);
    --kendo-color-on-primary: var(--brand-white);
    --kendo-color-success: var(--brand-mint);
    --kendo-color-success-subtle: var(--brand-mint-soft);
    --kendo-color-warning: var(--brand-warning);
    --kendo-color-warning-subtle: var(--brand-warning-soft);
}

html, body {
    background: var(--brand-page);
    color: var(--brand-text);
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

h1:focus {
    outline: none;
}

a, .btn-link {
    color: var(--brand-blue);
}

.btn-primary {
    color: var(--brand-white);
    background-color: var(--brand-blue);
    border-color: var(--brand-blue);
    box-shadow: 0 8px 18px rgba(0, 124, 255, 0.18);
}

.btn-primary:hover,
.btn-primary:focus {
    color: var(--brand-white);
    background-color: #006fe6;
    border-color: #006fe6;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem var(--brand-white), 0 0 0 0.25rem rgba(142, 214, 192, 0.72);
}

.content {
    padding-top: 1.1rem;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid var(--brand-mint);
}

.invalid {
    outline: 1px solid var(--brand-warning);
}

.validation-message {
    color: var(--brand-critical);
}

.app-modal-backdrop {
    position: fixed;
    inset: 0;
    z-index: 1040;
    background: rgba(15, 23, 42, 0.42);
}

.app-modal-shell {
    position: fixed;
    inset: 0;
    z-index: 1050;
    display: grid;
    place-items: center;
    padding: 1rem;
}

.app-modal-panel {
    width: min(32rem, 100%);
    max-height: min(90vh, 42rem);
    overflow: hidden;
    border-radius: 0.5rem;
    background: #ffffff;
    border: 1px solid var(--brand-border);
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.28);
}

.app-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid #e2e8f0;
}

.app-modal-header h5 {
    margin: 0;
}

.app-modal-close {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    border: 1px solid #cbd5e1;
    border-radius: 0.35rem;
    background: #ffffff;
    color: #334155;
    font-size: 1.25rem;
    line-height: 1;
}

.app-modal-body {
    padding: 1.25rem;
}

.app-modal-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
    padding: 0.85rem 1.25rem;
    border-top: 1px solid #e2e8f0;
    background: #f8fafc;
}

.k-dialog-actions,
.k-window-actions {
    justify-content: flex-end;
}

#blazor-error-ui {
    color-scheme: light only;
    background: var(--brand-warning-soft);
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }

.blazor-error-boundary {
    background: var(--brand-critical-soft);
    padding: 1rem 1rem 1rem 3.7rem;
    color: var(--brand-critical);
    border-left: 0.35rem solid var(--brand-warning);
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

.app-startup-shell {
    align-items: center;
    background: var(--brand-page);
    display: flex;
    justify-content: center;
    min-height: 100vh;
    padding: 1.5rem;
}

.app-startup-card {
    align-items: center;
    background: var(--brand-white);
    border: 1px solid var(--brand-border);
    border-radius: 8px;
    box-shadow: 0 18px 48px var(--brand-shadow);
    display: grid;
    gap: 1rem;
    justify-items: center;
    max-width: 26rem;
    padding: 2rem;
    text-align: center;
    width: 100%;
}

.app-startup-card h1 {
    color: var(--brand-ink);
    font-size: 1.4rem;
    margin: 0;
}

.app-startup-card p {
    color: var(--brand-muted);
    margin: 0.25rem 0 0;
}

.app-startup-mark,
.auth-status-mark {
    align-items: center;
    background: linear-gradient(135deg, var(--brand-ink) 0%, var(--brand-blue) 100%);
    border-radius: 8px;
    color: var(--brand-white);
    display: inline-flex;
    font-weight: 800;
    height: 3rem;
    justify-content: center;
    letter-spacing: 0.04em;
    width: 3rem;
}

.loading-progress {
    display: block;
    height: 4.75rem;
    margin: 0.25rem auto 0;
    width: 4.75rem;
}

    .loading-progress circle {
        fill: none;
        stroke: #e0e0e0;
        stroke-width: 0.6rem;
        transform-origin: 50% 50%;
        transform: rotate(-90deg);
    }

        .loading-progress circle:last-child {
            stroke: var(--brand-blue);
            stroke-dasharray: calc(3.141 * var(--blazor-load-percentage, 0%) * 0.8), 500%;
            transition: stroke-dasharray 0.05s ease-in-out;
        }

.loading-progress-text {
    text-align: center;
    font-weight: bold;
}

    .loading-progress-text:after {
        content: var(--blazor-load-percentage-text, "Loading");
    }

.auth-status-panel {
    align-items: center;
    background: var(--brand-white);
    border: 1px solid var(--brand-border);
    border-radius: 8px;
    box-shadow: 0 12px 30px var(--brand-shadow);
    display: flex;
    gap: 1rem;
    margin: 2rem auto;
    max-width: 42rem;
    padding: 1.25rem;
}

.auth-status-panel h3 {
    color: var(--brand-ink);
    margin: 0 0 0.25rem;
}

code {
    color: var(--brand-purple);
}

.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;
}

.branch-detail-page {
    display: grid;
    gap: 1.5rem;
}

.branch-detail-hero {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem 1.5rem;
    border-radius: 1rem;
    background: linear-gradient(135deg, #f4f8fb 0%, #e2edf5 100%);
    border: 1px solid #d3e1ec;
}

.branch-detail-hero-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 4.25rem;
    height: 4.25rem;
    border-radius: 1rem;
    background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-mint) 100%);
    box-shadow: 0 14px 28px rgba(14, 107, 168, 0.18);
}

.branch-detail-hero-icon svg {
    width: 2.4rem;
    height: 2.4rem;
    fill: #ffffff;
}

.branch-detail-hero-copy h3 {
    margin: 0;
}

.branch-detail-hero-copy p {
    margin: 0.35rem 0 0;
}

.branch-detail-eyebrow {
    display: inline-block;
    margin-bottom: 0.35rem;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--brand-blue);
}

.branch-detail-sections {
    display: grid;
    gap: 1rem;
}

.terminal-detail-nav-row {
    position: sticky;
    top: 4.75rem;
    z-index: 80;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.35rem;
    border: 1px solid #dbeafe;
    border-radius: 0.5rem;
    background: #f8fafc;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
}

.terminal-detail-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    min-width: 0;
}

.terminal-detail-tab {
    min-height: 2.25rem;
    padding: 0.35rem 0.8rem;
    border: 1px solid transparent;
    border-radius: 0.4rem;
    background: transparent;
    color: #334155;
    font-weight: 800;
}

.terminal-detail-tab:hover {
    background: #ffffff;
    border-color: #cbd5e1;
}

.terminal-detail-tab.active {
    color: #0f0144;
    background: #ffffff;
    border-color: rgba(0, 124, 255, 0.28);
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.07);
}

.branch-detail-section,
.branch-edit-form,
.branch-map-panel {
    padding: 1.25rem 1.5rem;
    border-radius: 1rem;
    background: #ffffff;
    border: 1px solid #e2e8f0;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.05);
}

.branch-detail-section h5,
.branch-map-panel h5 {
    margin-bottom: 1rem;
}

.branch-detail-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1rem;
}

.branch-detail-grid {
    display: grid;
    grid-template-columns: minmax(9rem, 12rem) 1fr;
    gap: 0.65rem 1rem;
    margin: 0;
}

.branch-detail-grid dt {
    margin: 0;
    font-weight: 700;
    color: var(--brand-text);
}

.branch-detail-grid dd {
    margin: 0;
    color: #0f172a;
}

.branch-detail-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.terminal-detail-action-bar {
    flex: 0 0 auto;
    justify-content: flex-end;
    gap: 0.5rem;
}

.terminal-edit-action-row {
    justify-content: flex-end;
}

.session-action-ribbon {
    position: sticky;
    top: 4.75rem;
    z-index: 80;
    display: grid;
    justify-items: end;
    padding: 0.35rem;
    border: 1px solid #dbeafe;
    border-radius: 0.5rem;
    background: #f8fafc;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08);
}

.session-action-ribbon .branch-detail-actions {
    width: auto;
    justify-content: flex-end;
}

.session-action-ribbon .session-back-action {
    margin-left: auto;
}

.branch-edit-layout {
    display: grid;
    gap: 1rem;
    align-items: start;
}

.branch-map-frame {
    overflow: hidden;
    border-radius: 0.9rem;
    border: 1px solid #dbe4ee;
    background: #edf4f9;
}

.branch-map-frame iframe {
    display: block;
    width: 100%;
    min-height: 22rem;
    border: 0;
}

.branch-map-frame-compact iframe {
    min-height: 18rem;
}

.branch-map-caption {
    margin: 0.85rem 0 0;
    color: #475569;
}

.branch-terminal-groups {
    display: grid;
    gap: 1rem;
}

.branch-terminal-group {
    display: grid;
    gap: 0.75rem;
}

.branch-terminal-group-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.branch-terminal-group-header h6 {
    margin: 0;
    font-size: 0.98rem;
}

.branch-terminal-list {
    display: grid;
    gap: 0.65rem;
}

.branch-terminal-link-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    padding: 0.9rem 1rem;
    border-radius: 0.9rem;
    background: #f8fbfd;
    border: 1px solid #dce7ef;
    color: inherit;
    text-decoration: none;
    transition: transform 120ms ease, box-shadow 120ms ease, border-color 120ms ease;
}

.branch-terminal-link-card:hover {
    transform: translateY(-1px);
    border-color: #a8c8de;
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.06);
    color: inherit;
}

.branch-terminal-link-copy {
    display: grid;
    gap: 0.2rem;
}

.branch-terminal-link-copy span {
    color: #64748b;
    font-size: 0.92rem;
}

.branch-terminal-link-arrow {
    color: var(--brand-blue);
    font-size: 0.88rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

@media (min-width: 992px) {
    .branch-edit-layout {
        grid-template-columns: minmax(0, 1.7fr) minmax(18rem, 1fr);
    }

    .branch-terminal-groups {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        align-items: start;
    }
}

@media (max-width: 767.98px) {
    .branch-detail-hero {
        padding: 1rem;
        flex-direction: column;
    }

    .terminal-detail-hero-specs {
        grid-template-columns: 1fr;
    }

    .terminal-detail-hero-media {
        align-self: auto;
        flex-basis: auto;
        min-height: 8rem;
        width: 100%;
    }

    .branch-detail-grid {
        grid-template-columns: 1fr;
        gap: 0.35rem;
    }

    .branch-detail-section-header {
        align-items: flex-start;
        flex-direction: column;
    }

    .terminal-detail-nav-row {
        align-items: stretch;
        flex-direction: column;
        top: 7.5rem;
    }

    .terminal-detail-tabs {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .terminal-detail-action-bar {
        justify-content: flex-start;
    }
}

.branch-list-page {
    display: grid;
    gap: 1.25rem;
}

.branch-list-hero {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 1rem;
    padding: 1.25rem 1.5rem;
    border-radius: 1rem;
    background: linear-gradient(135deg, #f9fbfc 0%, #edf4f8 100%);
    border: 1px solid #d9e4eb;
}

.branch-list-toolbar {
    display: grid;
    gap: 1rem;
}

.session-list-controls {
    display: grid;
    gap: 1rem;
}

.session-list-summary {
    display: grid;
    gap: 1rem;
}

.session-list-summary-card {
    min-height: 0;
}

.session-list-filters {
    display: grid;
    gap: 1rem;
}

.session-list-range-card {
    min-width: 0;
}

.session-date-range-control {
    position: relative;
    width: 100%;
}

.session-date-range-trigger {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    min-height: 3rem;
    width: 100%;
    padding: 0.55rem 0.7rem;
    border: 1px solid #cbd5e1;
    border-radius: 0.45rem;
    background: #ffffff;
    color: #0f172a;
    text-align: left;
    transition: border-color 120ms ease, box-shadow 120ms ease;
}

.session-date-range-trigger:hover,
.session-date-range-trigger:focus {
    border-color: var(--brand-blue);
    box-shadow: 0 0 0 0.18rem rgba(0, 124, 255, 0.16);
    outline: 0;
}

.session-date-range-trigger-icon {
    position: relative;
    flex: 0 0 2rem;
    width: 2rem;
    height: 2rem;
    border: 1px solid rgba(0, 124, 255, 0.35);
    border-radius: 0.4rem;
    background: var(--brand-blue-soft);
}

.session-date-range-trigger-icon::before,
.session-date-range-trigger-icon::after {
    content: "";
    position: absolute;
    left: 0.4rem;
    right: 0.4rem;
}

.session-date-range-trigger-icon::before {
    top: 0.42rem;
    height: 0.18rem;
    border-radius: 999px;
    background: var(--brand-blue);
    box-shadow: 0 0.48rem 0 rgba(0, 124, 255, 0.55);
}

.session-date-range-trigger-icon::after {
    bottom: 0.38rem;
    height: 0.36rem;
    border-radius: 0.18rem;
    background: var(--brand-mint);
}

.session-date-range-trigger-copy {
    display: grid;
    gap: 0.05rem;
    min-width: 0;
}

.session-date-range-trigger-copy span,
.session-date-range-trigger-copy small {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.session-date-range-trigger-copy span {
    font-weight: 800;
}

.session-date-range-trigger-copy small {
    color: #64748b;
    font-size: 0.82rem;
}

.session-date-range-popover {
    position: absolute;
    top: calc(100% + 0.45rem);
    left: 0;
    z-index: 95;
    display: grid;
    gap: 0.85rem;
    width: min(28rem, calc(100vw - 2rem));
    padding: 1rem;
    border: 1px solid var(--brand-border);
    border-radius: 0.5rem;
    background: #ffffff;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.18);
}

.session-date-range-fields {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem;
}

.session-date-range-fields label {
    display: grid;
    gap: 0.3rem;
}

.session-date-range-fields span {
    color: #64748b;
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.session-date-range-error {
    margin: 0;
    color: var(--brand-critical);
    font-size: 0.9rem;
    font-weight: 700;
}

.session-date-range-presets {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
}

.session-date-range-presets button {
    min-height: 2rem;
    padding: 0.25rem 0.65rem;
    border: 1px solid rgba(0, 124, 255, 0.22);
    border-radius: 999px;
    background: var(--brand-blue-soft);
    color: var(--brand-ink);
    font-weight: 700;
}

.session-date-range-actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

@media (max-width: 520px) {
    .session-date-range-popover {
        position: fixed;
        top: auto;
        right: 1rem;
        bottom: 1rem;
        left: 1rem;
        width: auto;
    }

    .session-date-range-fields {
        grid-template-columns: 1fr;
    }
}

.branch-list-stat-card,
.branch-list-state-card {
    padding: 1rem 1.25rem;
    border-radius: 1rem;
    background: #ffffff;
    border: 1px solid #e2e8f0;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.04);
}

.branch-list-stat-card strong {
    display: block;
    margin-top: 0.2rem;
    font-size: 1.65rem;
    line-height: 1.1;
    color: #0f172a;
}

.branch-list-stat-label {
    display: inline-block;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #64748b;
}

.branch-list-search-card .form-label {
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #64748b;
}

.branch-grid-identity {
    display: flex;
    align-items: center;
    gap: 0.85rem;
}

.branch-grid-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.7rem;
    height: 2.7rem;
    border-radius: 0.85rem;
    background: linear-gradient(135deg, var(--brand-blue) 0%, var(--brand-mint) 100%);
    box-shadow: 0 10px 20px rgba(14, 107, 168, 0.16);
}

.branch-grid-badge svg {
    width: 1.45rem;
    height: 1.45rem;
    fill: #ffffff;
}

.branch-grid-name {
    font-weight: 700;
    color: #0f172a;
    display: flex;
    align-items: center;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.entity-status-pill {
    display: inline-flex;
    align-items: center;
    min-height: 1.35rem;
    padding: 0.1rem 0.45rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 700;
    line-height: 1;
}

.entity-status-disabled {
    color: var(--brand-critical);
    background: var(--brand-critical-soft);
    border: 1px solid rgba(240, 180, 41, 0.55);
}

.terminal-transit-supported {
    color: #065f46;
    background: var(--brand-mint-soft);
    border: 1px solid rgba(16, 185, 129, 0.35);
}

.terminal-transit-not-supported {
    color: #334155;
    background: #e2e8f0;
    border: 1px solid #cbd5e1;
}

.user-enabled-toggle {
    max-width: 18rem;
}

.branch-grid-meta {
    font-size: 0.92rem;
    color: #64748b;
}

.branch-grid-location {
    display: grid;
    gap: 0.15rem;
}

.branch-grid-actions {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.terminal-list-row-actions {
    flex-wrap: wrap;
}

.terminal-list-page {
    display: grid;
    gap: 1.25rem;
}

.terminal-grid-identity {
    display: flex;
    align-items: center;
    gap: 0.85rem;
}

.terminal-grid-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.7rem;
    height: 2.7rem;
    border-radius: 0.85rem;
    background: linear-gradient(135deg, var(--brand-purple) 0%, var(--brand-mint) 100%);
    box-shadow: 0 10px 20px rgba(15, 118, 110, 0.16);
}

.terminal-grid-badge svg {
    width: 1.45rem;
    height: 1.45rem;
    fill: #ffffff;
}

.terminal-grid-model-image {
    align-items: center;
    background: #f8fafc;
    border: 1px solid #dbe4ee;
    border-radius: 8px;
    display: flex;
    height: 3.25rem;
    justify-content: center;
    overflow: hidden;
    padding: 0.25rem;
    width: 3.25rem;
}

.terminal-grid-model-image img {
    height: 100%;
    max-width: 100%;
    object-fit: contain;
}

.terminal-detail-page {
    display: grid;
    gap: 1.5rem;
}

.terminal-detail-page .branch-detail-hero {
    align-items: center;
    gap: 1.5rem;
}

.terminal-detail-hero-media {
    align-items: center;
    align-self: stretch;
    background: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(0, 124, 255, 0.14);
    border-radius: 0.75rem;
    display: flex;
    flex: 0 0 8.75rem;
    justify-content: center;
    min-height: 9.5rem;
    overflow: hidden;
    padding: 0.7rem;
}

.terminal-detail-hero-media img {
    height: 100%;
    max-height: 11.5rem;
    max-width: 100%;
    object-fit: contain;
}

.terminal-detail-hero-media svg {
    fill: var(--brand-blue);
    height: 4rem;
    width: 4rem;
}

.terminal-detail-page .branch-detail-hero-copy {
    flex: 1 1 auto;
    min-width: 0;
}

.terminal-detail-model-capacity {
    color: var(--brand-ink);
    font-weight: 700;
    margin: 0.25rem 0 0;
}

.terminal-detail-hero-title-block {
    align-items: baseline;
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem 0.75rem;
    margin-top: 0.8rem;
}

.terminal-detail-hero-title-block strong {
    color: var(--brand-ink);
    font-size: 1rem;
}

.terminal-detail-hero-title-block span {
    color: var(--brand-muted);
}

.terminal-detail-hero-specs {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(9rem, 1fr));
    gap: 0.45rem 0.9rem;
    margin: 1rem 0 0;
    padding: 0.85rem;
    border: 1px solid rgba(0, 124, 255, 0.14);
    border-radius: 0.5rem;
    background: rgba(255, 255, 255, 0.72);
}

.terminal-detail-hero-specs dt {
    color: var(--brand-muted);
    font-size: 0.74rem;
    font-weight: 800;
    text-transform: uppercase;
}

.terminal-detail-hero-specs dd {
    min-width: 0;
    margin: 0;
    overflow-wrap: anywhere;
    color: var(--brand-ink);
    font-weight: 700;
}

.terminal-cert-list {
    display: grid;
    gap: 0.85rem;
}

.terminal-cert-card {
    padding: 1rem 1.1rem;
    border-radius: 0.85rem;
    background: #f8fbfc;
    border: 1px solid #dce7ec;
}

.terminal-cert-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    margin-bottom: 0.85rem;
}

.terminal-cert-header-actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    align-items: center;
    flex-wrap: wrap;
}

.terminal-cert-code {
    overflow-wrap: anywhere;
    font-family: Consolas, "Courier New", monospace;
    font-size: 0.92rem;
}

.terminal-cert-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 0.75rem;
    margin-bottom: 0.9rem;
}

.terminal-cert-details {
    flex: 1 1 22rem;
}

.terminal-cert-details summary {
    cursor: pointer;
    color: var(--brand-blue);
    font-weight: 600;
    list-style: none;
}

.terminal-cert-details summary::-webkit-details-marker {
    display: none;
}

.terminal-cert-pem {
    margin: 0.75rem 0 0;
    padding: 0.85rem 1rem;
    border-radius: 0.8rem;
    background: #0f172a;
    color: #e2e8f0;
    overflow-x: auto;
    white-space: pre-wrap;
    word-break: break-word;
    font-family: Consolas, "Courier New", monospace;
    font-size: 0.84rem;
}

.terminal-branch-selector {
    display: grid;
    gap: 0.45rem;
}

.terminal-branch-selector-hint {
    margin: 0;
    color: #64748b;
    font-size: 0.92rem;
}

.terminal-model-selector {
    display: grid;
    gap: 0.75rem;
}

.terminal-model-preview {
    align-items: center;
    border: 1px solid #d7dde8;
    border-radius: 8px;
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(88px, 120px) minmax(0, 1fr);
    padding: 0.875rem;
}

.terminal-model-image-wrap {
    align-items: center;
    aspect-ratio: 1 / 1;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 6px;
    display: flex;
    justify-content: center;
    overflow: hidden;
}

.terminal-model-image-wrap img {
    height: 100%;
    max-width: 100%;
    object-fit: contain;
}

.terminal-model-preview-copy {
    display: grid;
    gap: 0.25rem;
    min-width: 0;
}

.terminal-model-preview-copy strong {
    color: #0f172a;
}

.terminal-model-preview-copy span {
    color: #64748b;
    font-size: 0.875rem;
}

.terminal-detail-model-hero {
    align-items: center;
    border: 1px solid #d7dde8;
    border-radius: 8px;
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(104px, 144px) minmax(0, 1fr);
    margin-bottom: 1rem;
    padding: 1rem;
}

.terminal-detail-model-hero-compact {
    margin-bottom: 0;
    background: rgba(255, 255, 255, 0.78);
    border-color: rgba(0, 124, 255, 0.14);
    grid-template-columns: minmax(72px, 96px) minmax(0, 1fr);
    padding: 0.85rem;
}

.terminal-detail-model-image,
.terminal-detail-model-generic {
    align-items: center;
    aspect-ratio: 1 / 1;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
    border-radius: 6px;
    display: flex;
    justify-content: center;
    overflow: hidden;
}

.terminal-detail-model-image img {
    height: 100%;
    max-width: 100%;
    object-fit: contain;
}

.terminal-detail-model-generic {
    background: linear-gradient(135deg, var(--brand-purple) 0%, var(--brand-mint) 100%);
}

.terminal-detail-model-generic svg {
    fill: #ffffff;
    height: 3rem;
    width: 3rem;
}

.terminal-detail-model-copy {
    display: grid;
    gap: 0.25rem;
    min-width: 0;
}

.terminal-detail-model-copy strong {
    color: #0f172a;
    font-size: 1rem;
}

.terminal-detail-model-copy span {
    color: #64748b;
    font-size: 0.92rem;
}

.user-list-page,
.user-detail-page {
    display: grid;
    gap: 1.25rem;
}

.user-grid-identity {
    display: flex;
    align-items: center;
    gap: 0.85rem;
}

.user-grid-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.7rem;
    height: 2.7rem;
    border-radius: 0.9rem;
    background: linear-gradient(135deg, var(--brand-purple) 0%, var(--brand-blue) 100%);
    color: #ffffff;
    font-size: 0.92rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    box-shadow: 0 10px 20px rgba(37, 99, 235, 0.18);
}

.user-detail-hero-icon {
    background: linear-gradient(135deg, var(--brand-purple) 0%, var(--brand-blue) 100%);
    box-shadow: 0 14px 28px rgba(37, 99, 235, 0.2);
}

.user-detail-hero-icon span {
    color: #ffffff;
    font-size: 1.15rem;
    font-weight: 800;
    letter-spacing: 0.04em;
}

.user-edit-layout {
    display: grid;
    gap: 1rem;
    align-items: start;
}

.user-side-panels {
    display: grid;
    gap: 1rem;
}

.user-selection-grid {
    display: grid;
    gap: 0.65rem;
}

.user-selection-card {
    display: grid;
    gap: 0.2rem;
    padding: 0.85rem 0.95rem;
    border-radius: 0.85rem;
    background: #f8fbfd;
    border: 1px solid #dce7ef;
    cursor: pointer;
}

.user-selection-card input {
    margin-bottom: 0.15rem;
}

.user-selection-card span {
    font-weight: 600;
    color: #0f172a;
}

.user-selection-card small {
    color: #64748b;
}

.session-list-page,
.session-detail-page {
    display: grid;
    gap: 1.25rem;
}

.session-detail-hero-icon {
    background: linear-gradient(135deg, var(--brand-purple) 0%, var(--brand-blue) 100%);
    box-shadow: 0 14px 28px rgba(124, 58, 237, 0.2);
}

.session-detail-hero-icon svg {
    width: 2.1rem;
    height: 2.1rem;
    fill: #ffffff;
}

.session-terminal-selector {
    display: grid;
    gap: 0.5rem;
}

.session-terminal-hint {
    margin: 0;
    color: #64748b;
    font-size: 0.92rem;
}

.session-terminal-preview {
    display: grid;
    grid-template-columns: 5.25rem minmax(0, 1fr);
    gap: 0.85rem;
    align-items: center;
    padding: 0.9rem;
    border: 1px solid #dbe4ee;
    border-radius: 0.75rem;
    background: #f8fbfd;
}

.session-terminal-preview-image,
.session-terminal-preview-badge {
    display: grid;
    place-items: center;
    width: 5.25rem;
    height: 5.25rem;
    overflow: hidden;
    border-radius: 0.65rem;
    background: #ffffff;
    border: 1px solid #dbe4ee;
}

.session-terminal-preview-image img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.session-terminal-preview-badge svg {
    width: 3.3rem;
    height: 3.3rem;
    fill: #0f766e;
}

.session-terminal-preview-copy {
    display: grid;
    gap: 0.2rem;
}

.session-terminal-preview-copy span {
    color: #64748b;
    font-size: 0.92rem;
}

.session-quick-schedule-note {
    display: grid;
    gap: 0.2rem;
    padding: 0.85rem 1rem;
    border: 1px solid #dbeafe;
    border-radius: 0.75rem;
    background: #f8fafc;
}

.session-create-flow {
    display: grid;
    gap: 1rem;
}

.session-create-step {
    display: grid;
    gap: 1rem;
    padding: 1.15rem;
    border: 1px solid #dbe4ee;
    border-radius: 0.9rem;
    background: #ffffff;
}

.session-create-step.is-pending {
    background: #f8fafc;
}

.session-create-step-header {
    display: flex;
    align-items: flex-start;
    gap: 0.9rem;
}

.session-create-step-header h5 {
    margin: 0 0 0.2rem;
}

.session-create-step-header p,
.session-create-step-hint,
.session-create-choice span {
    color: #64748b;
}

.session-create-step-number {
    display: grid;
    place-items: center;
    flex: 0 0 2rem;
    width: 2rem;
    height: 2rem;
    border-radius: 999px;
    background: #dbeafe;
    color: #0f4c81;
    font-weight: 700;
}

.session-create-step-body {
    display: grid;
    gap: 1rem;
}

.session-create-user {
    padding: 0.8rem 0.9rem;
    border-radius: 0.75rem;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
}

.session-create-choice-grid {
    display: grid;
    gap: 0.85rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.session-create-choice {
    display: grid;
    gap: 0.55rem;
    align-content: start;
    padding: 1rem;
    border: 1px solid #dbe4ee;
    border-radius: 0.8rem;
    background: #f8fbfd;
}

.session-create-choice .k-button {
    justify-self: end;
    margin-top: 0.15rem;
}

.session-create-choice-button.k-button,
.session-create-choice-button.k-button:hover,
.session-create-choice-button.k-button:focus {
    color: #ffffff !important;
}

.session-create-choice-button.k-button.k-disabled,
.session-create-choice-button.k-button:disabled {
    color: #ffffff !important;
}

.session-create-choice-button.k-button .k-button-text,
.session-create-choice-button.k-button.k-disabled .k-button-text,
.session-create-choice-button.k-button:disabled .k-button-text {
    color: #ffffff !important;
}

@media (max-width: 900px) {
    .session-create-choice-grid {
        grid-template-columns: 1fr;
    }
}

.session-readonly-field {
    display: grid;
    gap: 0.2rem;
}

.session-secret-warning {
    padding: 1rem 1.15rem;
    border-radius: 1rem;
    background: linear-gradient(135deg, #fff4d9 0%, #ffe7b0 100%);
    border: 1px solid #f3d27a;
    box-shadow: 0 12px 28px rgba(180, 120, 10, 0.08);
}

.session-secret-warning-compact {
    margin: 0;
}

.schedule-session-dialog-body {
    display: grid;
    gap: 1rem;
}

.schedule-session-dialog-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.session-secret-code {
    margin: 0.45rem 0 0.55rem;
    font-family: Consolas, "Courier New", monospace;
    font-size: 1.4rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    color: #8a4b08;
}

.terminal-cash-summary {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.terminal-cash-variance-ok {
    color: #047857;
}

.terminal-cash-variance-warning {
    color: #b45309;
}

.terminal-cash-overview {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 1rem;
    margin-bottom: 1rem;
}

.terminal-cash-overview-single {
    grid-template-columns: minmax(0, 1fr);
}

.terminal-cash-overview-panel {
    display: grid;
    gap: 0.75rem;
    padding: 1rem;
    border: 1px solid rgba(37, 0, 136, 0.1);
    border-radius: 0.5rem;
    background: #ffffff;
}

.terminal-cash-exception-panel {
    border-color: rgba(180, 83, 9, 0.28);
    background: #fffaf3;
}

.terminal-cash-overview-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.terminal-cash-chip-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.terminal-cash-denomination-chip {
    display: inline-flex;
    align-items: baseline;
    gap: 0.4rem;
    min-height: 2rem;
    padding: 0.35rem 0.6rem;
    border-radius: 999px;
    background: #eef8ff;
    color: #0f0144;
    font-size: 0.84rem;
}

.terminal-cash-denomination-chip span {
    color: #475569;
    font-weight: 700;
}

.terminal-cash-reconciliation-list {
    display: grid;
    gap: 0.45rem;
}

.terminal-cash-reconciliation-row {
    display: grid;
    grid-template-columns: minmax(90px, 1fr) minmax(95px, 0.8fr) minmax(95px, 0.8fr) minmax(64px, 0.5fr);
    gap: 0.55rem;
    align-items: center;
    padding: 0.5rem 0.6rem;
    border-radius: 0.45rem;
    background: #f8fafc;
    font-size: 0.84rem;
}

.terminal-cash-reconciliation-row strong {
    text-align: right;
}

.terminal-cash-reconciliation-row.balanced strong {
    color: #047857;
}

.terminal-cash-reconciliation-row.variance {
    background: #fff7ed;
}

.terminal-cash-reconciliation-row.variance strong {
    color: #b45309;
}

@media (max-width: 900px) {
    .terminal-cash-overview {
        grid-template-columns: 1fr;
    }
}

.terminal-cash-header-actions {
    display: flex;
    align-items: center;
    justify-content: end;
    flex-wrap: wrap;
    gap: 0.65rem;
}

.terminal-cash-view-toggle {
    display: inline-flex;
    padding: 0.2rem;
    border: 1px solid rgba(37, 0, 136, 0.14);
    border-radius: 0.5rem;
    background: #f8fafc;
}

.terminal-cash-toggle-button {
    min-height: 2rem;
    padding: 0.35rem 0.7rem;
    border: 0;
    border-radius: 0.35rem;
    background: transparent;
    color: #475569;
    font-weight: 700;
}

.terminal-cash-toggle-button.active {
    background: #ffffff;
    color: #0f0144;
    box-shadow: 0 6px 14px rgba(15, 23, 42, 0.08);
}

.terminal-cash-history-toolbar {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 1rem;
    align-items: end;
    margin-bottom: 1rem;
}

.terminal-cash-history-actions {
    display: flex;
    align-items: end;
}

.terminal-cash-history-quick-ranges {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin: -0.35rem 0 1rem;
}

.terminal-cash-history-summary {
    margin-top: 0.35rem;
}

.terminal-cash-history-dashboard {
    display: grid;
    gap: 1rem;
}

.terminal-cash-history-chart-panel {
    display: grid;
    gap: 0.85rem;
    padding: 1rem;
    border: 1px solid rgba(37, 0, 136, 0.12);
    border-radius: 0.5rem;
    background: #ffffff;
}

.terminal-cash-history-chart-header {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 1rem;
}

.terminal-cash-history-chart-header h6 {
    margin: 0 0 0.2rem;
    font-weight: 800;
}

.terminal-cash-history-mode-toggle {
    display: inline-flex;
    align-items: center;
    gap: 0.2rem;
    padding: 0.2rem;
    border: 1px solid rgba(37, 0, 136, 0.14);
    border-radius: 0.5rem;
    background: #f8fafc;
}

.terminal-cash-scaled-chart {
    display: grid;
    grid-template-columns: max-content minmax(0, 1fr);
    gap: 0.65rem;
    min-height: 260px;
}

.terminal-cash-chart-y-axis {
    display: grid;
    grid-template-rows: auto 1fr auto 1fr auto;
    min-width: 4.8rem;
    height: 220px;
    color: var(--brand-muted);
    font-size: 0.78rem;
    font-weight: 700;
    text-align: right;
}

.terminal-cash-chart-y-axis span:nth-child(1) {
    grid-row: 1;
}

.terminal-cash-chart-y-axis span:nth-child(2) {
    grid-row: 3;
}

.terminal-cash-chart-y-axis span:nth-child(3) {
    grid-row: 5;
}

.terminal-cash-chart-plot-wrap {
    position: relative;
    min-width: 0;
    overflow-x: auto;
}

.terminal-cash-chart-grid {
    position: absolute;
    inset: 0 0 2.3rem;
    border-left: 1px solid rgba(15, 23, 42, 0.1);
    border-bottom: 1px solid rgba(15, 23, 42, 0.18);
    background:
        linear-gradient(to top, rgba(15, 23, 42, 0.08) 1px, transparent 1px) 0 0 / 100% 50%;
    pointer-events: none;
}

.terminal-cash-chart-bars {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: end;
    gap: 0.6rem;
    height: 250px;
    min-width: max-content;
    padding: 0 0.6rem;
}

.terminal-cash-chart-column {
    display: grid;
    grid-template-rows: 220px 2rem;
    justify-items: center;
    align-items: end;
    min-width: 3.4rem;
}

.terminal-cash-chart-column .terminal-cash-history-bar {
    flex: none;
    width: 2.2rem;
    min-width: 2.2rem;
    max-width: 2.2rem;
    min-height: 2px;
}

.terminal-cash-history-denomination-bar span {
    display: block;
    width: 100%;
    min-height: 1px;
}

.terminal-cash-chart-x-label {
    align-self: start;
    max-width: 4.4rem;
    margin-top: 0.4rem;
    color: var(--brand-muted);
    font-size: 0.72rem;
    font-weight: 700;
    line-height: 1.15;
    text-align: center;
    white-space: normal;
}

.terminal-cash-history-chart {
    display: flex;
    align-items: end;
    gap: 0.35rem;
    height: 220px;
    min-height: 220px;
    padding: 0.75rem;
    border-radius: 0.45rem;
    background:
        linear-gradient(to top, rgba(15, 23, 42, 0.06) 1px, transparent 1px) 0 0 / 100% 25%,
        #f8fafc;
    overflow-x: auto;
}

.terminal-cash-history-bar {
    display: flex;
    flex-direction: column-reverse;
    justify-content: start;
    flex: 1 0 0.8rem;
    min-width: 0.8rem;
    max-width: 2.4rem;
    border: 0;
    border-radius: 0.25rem 0.25rem 0 0;
    padding: 0;
    background: transparent;
    overflow: hidden;
    cursor: pointer;
}

.terminal-cash-history-bar:hover,
.terminal-cash-history-bar:focus-visible {
    outline: 2px solid rgba(0, 124, 255, 0.35);
    outline-offset: 2px;
}

.terminal-cash-history-bar.attention {
    box-shadow: 0 0 0 2px rgba(180, 83, 9, 0.22);
}

.terminal-cash-history-bar-available,
.terminal-cash-history-bar-other {
    display: block;
    width: 100%;
    min-height: 2px;
}

.terminal-cash-history-bar-available {
    background: var(--brand-blue);
}

.terminal-cash-history-bar-other {
    background: var(--brand-mint);
}

.terminal-cash-history-chart-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 0.8rem;
    font-size: 0.84rem;
    color: var(--brand-muted);
}

.terminal-cash-history-chart-legend span {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.terminal-cash-history-chart-legend i {
    display: inline-block;
    width: 0.75rem;
    height: 0.75rem;
    border-radius: 0.2rem;
}

.terminal-cash-history-legend-available {
    background: var(--brand-blue);
}

.terminal-cash-history-legend-other {
    background: var(--brand-mint);
}

.terminal-cash-denomination-trends {
    display: grid;
    gap: 0.7rem;
}

.terminal-cash-denomination-trend-row {
    display: grid;
    grid-template-columns: minmax(120px, 0.7fr) minmax(220px, 2fr) minmax(72px, 0.35fr);
    gap: 0.9rem;
    align-items: center;
    padding: 0.65rem 0.75rem;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 0.45rem;
    background: #fbfdff;
}

.terminal-cash-denomination-trend-label {
    display: grid;
    gap: 0.15rem;
}

.terminal-cash-denomination-trend-label strong {
    color: #0f0144;
}

.terminal-cash-denomination-trend-label span,
.terminal-cash-denomination-trend-latest span {
    color: var(--brand-muted);
    font-size: 0.8rem;
    font-weight: 700;
}

.terminal-cash-denomination-sparkbars {
    display: flex;
    align-items: end;
    gap: 0.25rem;
    height: 70px;
    min-height: 70px;
    padding: 0.35rem;
    border-radius: 0.35rem;
    background:
        linear-gradient(to top, rgba(15, 23, 42, 0.05) 1px, transparent 1px) 0 0 / 100% 50%,
        #f8fafc;
    overflow-x: auto;
}

.terminal-cash-denomination-sparkbar {
    flex: 1 0 0.5rem;
    min-width: 0.5rem;
    max-width: 1.3rem;
    min-height: 3px;
    border: 0;
    border-radius: 0.2rem 0.2rem 0 0;
    padding: 0;
    background: linear-gradient(180deg, var(--brand-blue) 0%, var(--brand-mint) 100%);
    cursor: pointer;
}

.terminal-cash-denomination-sparkbar:hover,
.terminal-cash-denomination-sparkbar:focus-visible {
    outline: 2px solid rgba(0, 124, 255, 0.35);
    outline-offset: 2px;
}

.terminal-cash-denomination-sparkbar.attention {
    background: linear-gradient(180deg, #f59e0b 0%, var(--brand-blue) 100%);
}

.terminal-cash-denomination-trend-latest {
    display: grid;
    justify-items: end;
    gap: 0.15rem;
}

.terminal-cash-denomination-trend-latest strong {
    color: #0f0144;
}

@media (max-width: 760px) {
    .terminal-cash-denomination-trend-row {
        grid-template-columns: 1fr;
    }

    .terminal-cash-denomination-trend-latest {
        justify-items: start;
    }
}

.terminal-cash-history-table-wrap {
    overflow-x: auto;
}

.terminal-cash-history-table {
    width: 100%;
    min-width: 760px;
    border-collapse: collapse;
    font-size: 0.88rem;
}

.terminal-cash-history-table th,
.terminal-cash-history-table td {
    padding: 0.75rem;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
    vertical-align: top;
}

.terminal-cash-history-table th {
    background: #f8fafc;
    color: #0f0144;
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.terminal-cash-history-table tbody tr:not(.terminal-cash-history-detail-row) {
    cursor: pointer;
}

.terminal-cash-history-table tbody tr:not(.terminal-cash-history-detail-row):hover,
.terminal-cash-history-table tbody tr.selected {
    background: rgba(0, 124, 255, 0.06);
}

.terminal-cash-history-table td span {
    display: block;
    margin-top: 0.2rem;
    color: var(--brand-muted);
    font-size: 0.8rem;
}

.terminal-cash-history-table .numeric {
    text-align: right;
    white-space: nowrap;
}

.terminal-cash-history-detail-row td {
    padding: 1rem 0 0;
    background: #ffffff;
}

.terminal-cash-history-list {
    display: grid;
    gap: 1rem;
}

.cassette-event-list {
    display: grid;
    gap: 0.7rem;
    margin-top: 1rem;
}

.cassette-event-row {
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    align-items: center;
    padding: 0.85rem 1rem;
    border: 1px solid #dce7ec;
    border-radius: 0.5rem;
    background: #f8fbfc;
}

.terminal-cash-history-card {
    padding: 1rem;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 1rem;
    background: rgba(255, 255, 255, 0.7);
}

.terminal-cash-denomination-panel {
    display: grid;
    gap: 0.75rem;
    margin-bottom: 1rem;
    padding: 1rem;
    border: 1px solid rgba(37, 0, 136, 0.12);
    border-radius: 0.5rem;
    background: #ffffff;
}

.terminal-cash-denomination-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.terminal-cash-denomination-list {
    overflow-x: auto;
}

.terminal-cash-denomination-table-wrap {
    overflow-x: auto;
}

.terminal-cash-denomination-table {
    width: 100%;
    min-width: 520px;
    border-collapse: collapse;
    font-size: 0.88rem;
}

.terminal-cash-denomination-table th,
.terminal-cash-denomination-table td {
    padding: 0.45rem 0.55rem;
    border-bottom: 1px solid rgba(148, 163, 184, 0.22);
    text-align: left;
    white-space: nowrap;
}

.terminal-cash-denomination-table th {
    color: #475569;
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0;
}

.terminal-cash-denomination-table tr:last-child td {
    border-bottom: 0;
}

.terminal-cash-denomination-table .numeric {
    text-align: right;
}

.terminal-cash-denomination-table .strong {
    color: #0f0144;
    font-weight: 800;
}

.terminal-cash-denomination-meter {
    position: relative;
    height: 0.65rem;
    overflow: hidden;
    border-radius: 999px;
    background: #e6f7f1;
}

.terminal-cash-denomination-meter span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #007cff 0%, #8ed6c0 100%);
}

.terminal-cash-denomination-counts {
    display: grid;
    gap: 0.05rem;
    justify-items: end;
    font-weight: 700;
    color: #0f0144;
}

.terminal-cash-module-panel {
    display: grid;
    gap: 0.85rem;
    padding: 1rem;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 0.5rem;
    background: rgba(255, 255, 255, 0.78);
}

.terminal-cash-module-panel + .terminal-cash-module-panel {
    margin-top: 1rem;
}

.terminal-cash-module-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.terminal-cash-module-header h6 {
    margin: 0;
}

@media (max-width: 720px) {
    .terminal-cash-module-header {
        align-items: flex-start;
        flex-direction: column;
        gap: 0.25rem;
    }
}

.terminal-cash-group + .terminal-cash-group {
    margin-top: 1rem;
}

.terminal-cash-group {
    display: grid;
    gap: 0.85rem;
    padding: 1rem;
    border: 1px solid rgba(37, 0, 136, 0.1);
    border-radius: 0.5rem;
    background: #ffffff;
}

.terminal-cash-group-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.terminal-cash-collapse-button {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    min-height: 2rem;
    padding: 0;
    border: 0;
    background: transparent;
    color: #0f0144;
    font: inherit;
    font-weight: 800;
    text-align: left;
}

.terminal-cash-collapse-button span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.35rem;
    height: 1.35rem;
    border-radius: 999px;
    background: rgba(0, 124, 255, 0.1);
    color: #007cff;
    font-size: 0.82rem;
}

.terminal-cash-device-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 0.9rem;
}

.terminal-cash-table-wrap {
    overflow-x: auto;
}

.terminal-cash-table {
    width: 100%;
    min-width: 760px;
    border-collapse: collapse;
    font-size: 0.88rem;
}

.terminal-cash-table th,
.terminal-cash-table td {
    padding: 0.65rem 0.75rem;
    border-bottom: 1px solid rgba(148, 163, 184, 0.22);
    text-align: left;
    vertical-align: top;
}

.terminal-cash-table th {
    color: #0f0144;
    background: #f8fafc;
    font-size: 0.76rem;
    text-transform: uppercase;
}

.terminal-cash-table td {
    color: #1e293b;
}

.terminal-cash-device-card {
    display: grid;
    align-content: start;
    gap: 0.7rem;
    padding: 0.85rem;
    border-radius: 0.5rem;
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    border: 1px solid rgba(148, 163, 184, 0.25);
    box-shadow: 0 12px 26px rgba(15, 23, 42, 0.06);
}

.terminal-cash-device-card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
}

.terminal-cash-device-card-header strong {
    color: #0f0144;
}

.terminal-cassette-card-main {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(7rem, max-content);
    gap: 0.75rem;
    align-items: stretch;
    padding: 0.75rem;
    border-radius: 0.5rem;
    background:
        linear-gradient(135deg, rgba(0, 124, 255, 0.08) 0%, rgba(142, 214, 192, 0.16) 100%),
        #ffffff;
    border: 1px solid rgba(37, 0, 136, 0.12);
}

.terminal-cassette-primary {
    display: grid;
    align-content: start;
    gap: 0.25rem;
    min-width: 0;
}

.terminal-cassette-primary span {
    color: #475569;
    font-size: 0.74rem;
    font-weight: 800;
    line-height: 1;
    text-transform: uppercase;
}

.terminal-cassette-primary strong {
    color: #0f0144;
    font-size: 1.7rem;
    line-height: 1;
    overflow-wrap: anywhere;
}

.terminal-cassette-primary-count {
    justify-items: end;
    text-align: right;
}

.terminal-cassette-denomination-breakdown {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.terminal-cassette-denomination-breakdown span {
    display: inline-flex;
    gap: 0.25rem;
    padding: 0.25rem 0.45rem;
    border-radius: 999px;
    background: #eef8ff;
    color: #475569;
    font-size: 0.78rem;
    font-weight: 700;
}

.terminal-cassette-denomination-breakdown strong {
    color: #0f0144;
}

.terminal-cassette-meta {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem 0.75rem;
    margin: 0;
    font-size: 0.82rem;
}

.terminal-cassette-meta dt {
    color: #64748b;
    font-weight: 700;
    line-height: 1.1;
}

.terminal-cassette-meta dd {
    min-width: 0;
    margin: 0;
    overflow-wrap: anywhere;
    color: #1e293b;
    font-weight: 700;
}

.terminal-cash-status-pill {
    display: inline-flex;
    align-items: center;
    min-height: 1.5rem;
    padding: 0.2rem 0.5rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
}

.terminal-cash-status-ok {
    border-color: rgba(16, 185, 129, 0.35);
}

.terminal-cash-status-pill.terminal-cash-status-ok {
    color: #065f46;
    background: rgba(141, 214, 192, 0.35);
    border: 1px solid rgba(16, 185, 129, 0.35);
}

.terminal-cash-device-card.terminal-cash-status-warning {
    background: #fff8e6;
    border-color: #f0c85a;
}

.terminal-cash-device-card.terminal-cash-status-warning .terminal-cassette-card-main {
    border-color: #f0c85a;
    background:
        linear-gradient(135deg, rgba(255, 232, 163, 0.34) 0%, rgba(255, 248, 230, 0.94) 100%),
        #ffffff;
}

.terminal-cash-status-pill.terminal-cash-status-warning {
    color: #7a4d00;
    background: #ffe8a3;
    border: 1px solid #f0c85a;
}

.terminal-cash-device-card.terminal-cash-status-danger {
    background: var(--brand-critical-soft);
    border-color: var(--brand-warning);
}

.terminal-cash-device-card.terminal-cash-status-danger .terminal-cassette-card-main {
    border-color: rgba(240, 180, 41, 0.7);
    background:
        linear-gradient(135deg, rgba(240, 180, 41, 0.18) 0%, rgba(255, 247, 220, 0.96) 100%),
        var(--brand-white);
}

.terminal-cash-status-pill.terminal-cash-status-danger {
    color: var(--brand-critical);
    background: var(--brand-critical-soft);
    border: 1px solid var(--brand-warning);
}

.terminal-cash-device-card.terminal-cash-status-unknown {
    background: #f8fafc;
    border-color: rgba(15, 23, 42, 0.18);
}

.terminal-cash-status-pill.terminal-cash-status-unknown {
    color: var(--brand-text);
    background: #e2e8f0;
    border: 1px solid #cbd5e1;
}

.terminal-cash-role-pill {
    display: inline-flex;
    align-items: center;
    justify-self: start;
    min-height: 1.5rem;
    padding: 0.2rem 0.5rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 800;
    line-height: 1;
    white-space: nowrap;
}

.terminal-cash-role-cash-out {
    color: #0f3f71;
    background: rgba(0, 124, 255, 0.12);
    border: 1px solid rgba(0, 124, 255, 0.28);
}

.terminal-cash-role-cash-in {
    color: #065f46;
    background: rgba(141, 214, 192, 0.28);
    border: 1px solid rgba(16, 185, 129, 0.3);
}

.terminal-cash-role-recycling {
    color: #3b2f80;
    background: rgba(169, 139, 250, 0.18);
    border: 1px solid rgba(124, 58, 237, 0.25);
}

.terminal-cash-role-exception {
    color: #7a4d00;
    background: #fff1bf;
    border: 1px solid #f0c85a;
}

.terminal-cash-role-unknown {
    color: #334155;
    background: #e2e8f0;
    border: 1px solid #cbd5e1;
}

.dashboard-page {
    display: grid;
    gap: 1.25rem;
}

.dashboard-hero {
    align-items: center;
}

.dashboard-hero-actions {
    align-items: end;
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    justify-content: flex-end;
}

.dashboard-branch-filter {
    display: grid;
    gap: 0.25rem;
    min-width: min(18rem, 100%);
}

.dashboard-branch-filter .form-label {
    color: var(--brand-muted);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    margin: 0;
    text-transform: uppercase;
}

.dashboard-kpi-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 0.85rem;
}

.dashboard-kpi-critical {
    border-color: rgba(240, 180, 41, 0.65);
    background: var(--brand-critical-soft);
}

.dashboard-kpi-warning {
    border-color: rgba(240, 200, 90, 0.65);
    background: #fff8e6;
}

.dashboard-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(320px, 0.9fr);
    gap: 1rem;
    align-items: start;
}

.dashboard-simple-layout {
    display: grid;
    gap: 1rem;
}

.dashboard-attention-panel {
    align-self: stretch;
}

.dashboard-attention-list,
.dashboard-machine-list,
.dashboard-activity-list,
.dashboard-stale-list,
.dashboard-denomination-list {
    display: grid;
    gap: 0.65rem;
}

.dashboard-attention-row,
.dashboard-machine-row {
    display: grid;
    grid-template-columns: minmax(180px, 1.4fr) max-content minmax(110px, 0.7fr) minmax(110px, 0.7fr) minmax(90px, 0.6fr);
    gap: 0.75rem;
    align-items: center;
    width: 100%;
    padding: 0.75rem 0.85rem;
    border: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: 0.5rem;
    background: #ffffff;
    color: inherit;
    text-align: left;
}

.dashboard-attention-row > span:first-child,
.dashboard-machine-row > span:first-child {
    display: grid;
    gap: 0.1rem;
}

.dashboard-status-pill {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 1.6rem;
    padding: 0.25rem 0.55rem;
    border-radius: 999px;
    font-size: 0.76rem;
    font-weight: 800;
    white-space: nowrap;
}

.dashboard-severity-danger {
    color: var(--brand-critical);
    background: var(--brand-critical-soft);
    border: 1px solid var(--brand-warning);
}

.dashboard-severity-warning {
    color: #7a4d00;
    background: #ffe8a3;
}

.dashboard-severity-unknown {
    color: var(--brand-text);
    background: #e2e8f0;
}

.dashboard-severity-ok {
    color: #065f46;
    background: rgba(141, 214, 192, 0.35);
}

.dashboard-denomination-row {
    display: grid;
    grid-template-columns: minmax(130px, 0.85fr) minmax(160px, 1.4fr) minmax(110px, 0.7fr);
    gap: 0.75rem;
    align-items: center;
}

.dashboard-denomination-row > div:first-child {
    display: grid;
    gap: 0.1rem;
}

.dashboard-denomination-row span,
.dashboard-activity-item small,
.dashboard-stale-list span,
.dashboard-stale-list small {
    color: #64748b;
    font-size: 0.82rem;
}

.dashboard-denomination-meter {
    height: 0.65rem;
    overflow: hidden;
    border-radius: 999px;
    background: #e6f7f1;
}

.dashboard-denomination-meter span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #007cff 0%, #8ed6c0 100%);
}

.dashboard-side-rail {
    display: grid;
    gap: 1rem;
}

.dashboard-activity-item {
    display: grid;
    gap: 0.08rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid rgba(148, 163, 184, 0.18);
}

.dashboard-activity-item > span {
    color: #250088;
    font-size: 0.72rem;
    font-weight: 800;
    text-transform: uppercase;
}

.dashboard-stale-list button {
    display: grid;
    gap: 0.08rem;
    width: 100%;
    padding: 0.75rem 0.85rem;
    border: 1px solid rgba(148, 163, 184, 0.2);
    border-radius: 0.5rem;
    background: #ffffff;
    color: inherit;
    text-align: left;
}

@media (max-width: 980px) {
    .dashboard-layout {
        grid-template-columns: 1fr;
    }

    .dashboard-hero-actions {
        justify-content: stretch;
        width: 100%;
    }

    .dashboard-branch-filter {
        flex: 1 1 100%;
    }

    .dashboard-attention-row,
    .dashboard-machine-row,
    .dashboard-denomination-row {
        grid-template-columns: 1fr;
        gap: 0.45rem;
    }
}

.cassette-list-page,
.cassette-detail-page {
    display: grid;
    gap: 1.25rem;
}

.cassette-grid-identity {
    display: flex;
    align-items: center;
    gap: 0.85rem;
}

.cassette-grid-badge,
.cassette-detail-hero-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--brand-text) 0%, var(--brand-purple) 100%);
    box-shadow: 0 14px 28px rgba(15, 118, 110, 0.18);
}

.cassette-grid-badge {
    width: 2.7rem;
    height: 2.7rem;
    border-radius: 0.85rem;
}

.cassette-detail-hero-icon {
    width: 4.25rem;
    height: 4.25rem;
    border-radius: 1rem;
    flex: 0 0 auto;
}

.cassette-grid-badge svg,
.cassette-detail-hero-icon svg {
    fill: #ffffff;
}

.cassette-grid-badge svg {
    width: 1.45rem;
    height: 1.45rem;
}

.cassette-detail-hero-icon svg {
    width: 2.4rem;
    height: 2.4rem;
}

.cassette-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 5.5rem;
    padding: 0.32rem 0.6rem;
    border-radius: 999px;
    font-size: 0.84rem;
    font-weight: 700;
}

.cassette-status-enabled {
    background: var(--brand-mint-soft);
    color: #0b5c4c;
}

.cassette-status-disabled {
    background: var(--brand-critical-soft);
    color: var(--brand-critical);
}

.cassette-edit-layout {
    display: grid;
    gap: 1rem;
}

.cassette-edit-form {
    display: grid;
    gap: 1rem;
}

.cassette-form-grid {
    display: grid;
    gap: 1rem;
}

.cassette-toggle-row {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-weight: 600;
}

.cassette-field-hint {
    margin: 0.35rem 0 0;
    color: #64748b;
    font-size: 0.9rem;
}

.cassette-scan-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.cassette-serial-entry {
    display: grid;
    gap: 0.35rem;
}

.cassette-serial-input,
.cassette-serial-value {
    font-family: Consolas, "Courier New", monospace;
}

.cassette-scanner-panel {
    display: none;
    position: relative;
    overflow: hidden;
    margin-top: 1rem;
    border: 1px solid #cbd5e1;
    border-radius: 8px;
    background: #0f172a;
    aspect-ratio: 16 / 9;
    max-width: 42rem;
}

.cassette-scanner-panel-active {
    display: block;
}

.cassette-scanner-video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.cassette-scanner-frame {
    position: absolute;
    inset: 22%;
    border: 2px solid var(--brand-warning);
    border-radius: 8px;
    box-shadow: 0 0 0 999px rgba(15, 23, 42, 0.35);
    pointer-events: none;
}

@media (min-width: 768px) {
    .cassette-form-grid {
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
        align-items: end;
    }
}

@media (min-width: 768px) {
    .branch-list-toolbar {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        align-items: stretch;
    }

    .branch-list-search-card {
        grid-column: span 1;
    }

    .session-list-summary {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .session-list-filters {
        grid-template-columns: minmax(15rem, 1.05fr) minmax(24rem, 1.4fr) minmax(18rem, 1.15fr);
        align-items: stretch;
    }
}

@media (max-width: 767.98px) {
    .branch-list-hero {
        align-items: stretch;
        flex-direction: column;
    }
}

@media (min-width: 992px) {
    .user-edit-layout {
        grid-template-columns: minmax(0, 1.6fr) minmax(20rem, 1fr);
    }

}

.k-button-solid-primary,
.k-button.k-primary {
    background-color: var(--brand-blue);
    border-color: var(--brand-blue);
    color: var(--brand-white);
}

.k-button-solid-primary:hover,
.k-button.k-primary:hover {
    background-color: #006fe6;
    border-color: #006fe6;
}

.k-grid .k-table-th,
.k-grid-header,
.k-grid-header-wrap {
    background: var(--brand-blue-soft);
    color: var(--brand-ink);
}

.k-grid .k-selected,
.k-grid tr.k-selected > td {
    background-color: rgba(0, 124, 255, 0.1);
    color: var(--brand-ink);
}

.branch-detail-hero,
.branch-list-hero {
    background: linear-gradient(135deg, var(--brand-white) 0%, var(--brand-blue-soft) 58%, var(--brand-mint-soft) 100%);
    border-color: var(--brand-border);
}

.branch-detail-section,
.branch-edit-form,
.branch-map-panel,
.branch-list-stat-card,
.branch-list-state-card,
.terminal-cert-card,
.terminal-cash-denomination-panel,
.terminal-cash-module-panel,
.terminal-cash-group,
.terminal-cash-history-card,
.terminal-cash-history-chart-panel,
.cassette-event-row,
.user-selection-card,
.branch-terminal-link-card,
.dashboard-attention-row,
.dashboard-machine-row,
.dashboard-stale-list button {
    border-color: var(--brand-border);
    box-shadow: 0 12px 30px var(--brand-shadow);
}

.branch-detail-hero-icon,
.branch-grid-badge,
.terminal-grid-badge,
.terminal-detail-model-generic,
.user-grid-badge,
.user-detail-hero-icon,
.session-detail-hero-icon,
.cassette-grid-badge,
.cassette-detail-hero-icon {
    background: linear-gradient(135deg, var(--brand-ink) 0%, var(--brand-blue) 62%, var(--brand-mint) 100%);
    box-shadow: 0 14px 28px rgba(0, 124, 255, 0.18);
}

.branch-detail-eyebrow,
.branch-terminal-link-arrow,
.terminal-cert-details summary,
.dashboard-activity-item > span {
    color: var(--brand-blue);
}

.branch-list-stat-card strong,
.branch-grid-name,
.terminal-model-preview-copy strong,
.terminal-detail-model-copy strong,
.user-selection-card span,
.terminal-cash-toggle-button.active,
.terminal-cash-collapse-button,
.terminal-cash-table th,
.terminal-cash-device-card-header strong,
.terminal-cassette-primary strong,
.terminal-cash-denomination-counts {
    color: var(--brand-ink);
}

.branch-detail-grid dt,
.dashboard-severity-unknown {
    color: var(--brand-text);
}

.branch-map-caption,
.branch-grid-meta,
.terminal-branch-selector-hint,
.terminal-model-preview-copy span,
.terminal-detail-model-copy span,
.user-selection-card small,
.session-terminal-hint,
.terminal-cassette-meta dt,
.terminal-cash-denomination-label span,
.terminal-cash-denomination-counts span,
.dashboard-denomination-row span,
.dashboard-activity-item small,
.dashboard-stale-list span,
.dashboard-stale-list small,
.cassette-field-hint {
    color: var(--brand-muted);
}

.terminal-cash-toggle-button.active,
.dashboard-attention-row,
.dashboard-machine-row,
.dashboard-stale-list button {
    background: var(--brand-white);
}

.terminal-cash-view-toggle,
.terminal-cash-table th,
.terminal-grid-model-image,
.terminal-model-image-wrap,
.terminal-detail-model-image,
.branch-terminal-link-card,
.user-selection-card,
.cassette-scanner-panel {
    background: var(--brand-blue-soft);
}

.terminal-cash-denomination-meter,
.dashboard-denomination-meter {
    background: var(--brand-mint-soft);
}

.terminal-cash-denomination-meter span,
.dashboard-denomination-meter span {
    background: linear-gradient(90deg, var(--brand-blue) 0%, var(--brand-mint) 100%);
}

.terminal-cash-status-pill.terminal-cash-status-ok,
.dashboard-severity-ok {
    color: #0b5c4c;
    background: var(--brand-mint-soft);
    border: 1px solid rgba(142, 214, 192, 0.75);
}

.terminal-cash-device-card.terminal-cash-status-warning,
.dashboard-kpi-warning {
    background: var(--brand-warning-soft);
    border-color: rgba(240, 180, 41, 0.7);
}

.terminal-cash-status-pill.terminal-cash-status-warning,
.dashboard-severity-warning {
    color: var(--brand-critical);
    background: var(--brand-warning-soft);
    border: 1px solid rgba(240, 180, 41, 0.7);
}

