.df-nav-menu .mud-nav-item {
    min-height: 40px;
}

.interactable-outline:hover {
    border-color: var(--mud-palette-primary-lighten);
}

body {
    --mud-default-borderradius: 18px;
}

.console-spinner {
    background-color: #000;
    color: #00ff00;
    font-family: "Courier New", monospace;
    padding: 0.25rem 0.5rem;
    border-radius: 3px;
}

.spinner {
    position: fixed;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    background-color: rgb(0, 0, 0, 0.25);
    z-index: 10000;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}


.ts-terminal-window {
    background-color: #1e1e1e;
    border-radius: 8px;
    font-family: "Courier New", monospace;
    color: #00ff00;
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.5);
    overflow: hidden;
}

.ts-terminal-header {
    background-color: #2d2d2d;
    padding: 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.4rem;
    position: relative;
}

.ts-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    display: inline-block;
}

.ts-red { background: #ff5f56; }
.ts-yellow { background: #ffbd2e; }
.ts-green { background: #27c93f; }

.ts-terminal-title {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    color: #ccc;
    font-size: 0.85rem;
}

.ts-terminal-body {
    padding: 1rem;
    font-size: 1rem;
    white-space: nowrap;
}

console-spinner {
    vertical-align: middle;
}



/* ─────────── DARK‑RED MINIMAL ─────────── */
:root {
    --bg: rgba(244, 67, 54, 1); /* deep red-black backdrop */
    --fg: #ffffff; /* text + outline colour   */
    --accent: #ff4d4d; /* solid red fill on hover */
    --popup-backdrop: rgba(0, 0, 0, 0.4);
    --popup-bg: #ffffff;
    --popup-fg: #1f2937; /* neutral-800 */
    --popup-muted: #6b7280; /* neutral-500 */
    --popup-primary: #2563eb; /* blue-600 */
    --popup-primary-hover: #1d4ed8; /* blue-700 */
}
/* Backdrop overlay (hidden by default) */
#blazor-error-ui.overlay,
#components-reconnect-modal.overlay {
    background: var(--popup-backdrop) !important;
    color: var(--popup-fg) !important;
}

/* Full-screen overlay container */
.overlay {
    position: fixed;
    inset: 0;
    z-index: 2147483647;
    display: none; /* Hide by default */
    background: var(--popup-backdrop);
    color: var(--popup-fg);
    font-family: system-ui, sans-serif;
    font-size: 16px;
    font-weight: 500;

    /* center using grid for better accessibility with focus trap later if needed */
    display: none;
    place-items: center;
    padding: 1rem;
}

/* Show the overlay when Blazor adds its classes or an inline style */
#blazor-error-ui[style*="display: block"],
#components-reconnect-modal.components-reconnect-show,
#components-reconnect-modal.components-reconnect-failed,
#components-reconnect-modal.components-reconnect-rejected {
    display: grid !important; /* Makes the overlay visible and centers content */
}

/* Popup card */
.overlay .popup-card {
    width: 100%;
    max-width: 420px;
    background: var(--popup-bg);
    color: var(--popup-fg);
    border-radius: 14px;
    box-shadow:
            0 10px 25px rgba(0, 0, 0, 0.15),
            0 2px 8px rgba(0, 0, 0, 0.08);
    padding: 1.25rem 1.25rem 1rem;
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
    grid-column-gap: 0.75rem;
    grid-row-gap: 0.5rem;
    align-items: start;
    animation: popup-in .16s ease-out;
}

/* Icon */
.overlay .popup-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    background: #eef2ff; /* indigo-50 */
    color: #4338ca;      /* indigo-700 */
    display: grid;
    place-items: center;
    grid-row: 1 / span 2;
}

.overlay .popup-icon i {
    font-size: 20px;
    line-height: 1;
}

/* Button styles */
.jrnm-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: .6rem 1rem;
    border-radius: 10px;
    border: 1px solid transparent;
    text-decoration: none;
    font-weight: 600;
    cursor: pointer;
    transition: background-color .15s ease, color .15s ease, border-color .15s ease, box-shadow .15s ease;
}

.jrnm-btn.primary {
    background: var(--popup-primary);
    color: #fff;
    border-color: var(--popup-primary);
}

.jrnm-btn.primary:hover,
.jrnm-btn.primary:focus {
    background: var(--popup-primary-hover);
    border-color: var(--popup-primary-hover);
    color: #fff;
    outline: none;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.25);
}

/* Keyframes */
@keyframes popup-in {
    from { transform: translateY(6px); opacity: 0; }
    to   { transform: translateY(0);   opacity: 1; }
}


/* Remove previous aggressive red overlay rules */
#blazor-error-ui.overlay,
#components-reconnect-modal.overlay {
    /* previously forced red background; now handled by --popup-backdrop */
}

/* Ensure old "overlay-content" layout doesn't fight with new card */
.overlay-content { display: contents; }







@media (prefers-reduced-motion: reduce) {
    .transition, .duration-150, .duration-200, .duration-300 { transition: none !important; }
}
@keyframes popup-fade {
    0% { opacity: 0; transform: scale(0.95); }
    100% { opacity: 1; transform: scale(1); }
}





.fakeButtons {
    height: 10px;
    width: 10px;
    border-radius: 50%;
    border: 1px solid #000;
    position: relative;
    top: 1px;
    left: 6px;
    background-color: #5f5f5f;
    border-color: #333333;
    display: inline-block;
}

.fakeMinimize {
    left: 11px;
    background-color: #5f5f5f;
    border-color: #333333;
}

.fakeZoom {
    left: 16px;
    background-color: #00d742;
    border-color: #049931;
}

.fakeMenu {
    width: 100%;
    box-sizing: border-box;
    height: 25px;
    background-color: #bbb;
    border-top-right-radius: 5px;
    border-top-left-radius: 5px;
}

.fakeScreen {
    background-color: #151515;
    box-sizing: border-box;
    padding: 0;
    border-bottom-left-radius: 5px;
    border-bottom-right-radius: 5px;
    flex-grow: 1;
    display: flex;
}

.fakeScreen > div {
    flex-grow: 1;
}

.fullscreen {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    height: 100%;
    z-index: 2000;
}

.shell-container {
    width: 100%;
    padding: 0;
    margin: 0;
    min-height: 500px;
    display: flex;
    flex-direction: column;
}




/* Secret wrapper */
.jrnm-secret {
    position: relative;
    color: transparent;
}

.jrnm-secret::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 0.35em;
    background-image:
            linear-gradient(
                    135deg,
                    rgb(38, 64, 64) 25%,
                    transparent 25%,
                    transparent 50%,
                    rgb(38, 64, 64) 50%,
                    rgb(38, 64, 64) 75%,
                    transparent 75%,
                    transparent
            );
    background-size: 8px 8px;
    background-color: rgba(241, 245, 249, 0.95);
    box-shadow: 0 0 0 1px rgba(38, 64, 64, 0.5);
    transition: opacity 0.15s ease-out;
}

.jrnm-secret::after {
    content: "🔒";
    position: absolute;
    left: 0.3em;
    top: 50%;
    transform: translateY(-50%);
    font-size: 0.8em;
    opacity: 0.8;
    pointer-events: none;
    transition: opacity 0.15s ease-out;
}

.js-shell-card:hover .jrnm-secret {
    color: inherit;
}

.js-shell-card:hover .jrnm-secret::before,
.js-shell-card:hover .jrnm-secret::after {
    opacity: 0;
}