:root {
    --term-bg:    #0d120f;
    --term-bg2:   #121a15;
    --term-panel: #141d18;
    --term-line:  #294035;
    --term-fg:    #dfe8e2;   /* primary text: high-contrast, near-white */
    --term-green: #5fe39a;   /* accent (borders, buttons, headings) */
    --term-dim:   #8aa596;   /* muted/secondary text, still legible */
    --term-amber: #f0c453;
    --term-red:   #ff8585;
    --term-cyan:  #7fd6e6;
    --term-mono:  'JetBrains Mono', 'Fira Code', ui-monospace, SFMono-Regular, Menlo, Consolas, 'Liberation Mono', monospace;

    /* Point Bootstrap's theme variables at the terminal palette so components
       (cards, labels, muted text, borders) stop using the light-theme dark greys. */
    --bs-body-color: #dfe8e2;
    --bs-body-color-rgb: 223, 232, 226;
    --bs-body-bg: #0d120f;
    --bs-emphasis-color: #ffffff;
    --bs-secondary-color: #8aa596;
    --bs-tertiary-color: #8aa596;
    --bs-border-color: #294035;
    --bs-secondary-bg: #141d18;
    --bs-tertiary-bg: #121a15;
}

html, body {
    font-family: var(--term-mono);
    background: var(--term-bg);
    color: var(--term-fg);
    font-size: 14.5px;
    line-height: 1.5;
    letter-spacing: .1px;
}

a, .btn-link { color: var(--term-cyan); text-decoration: none; }
a:hover, .btn-link:hover { color: var(--term-green); }

h1, h2, h3, h4, h5 { color: var(--term-green); }
.text-muted { color: var(--term-dim) !important; }
code, pre, .font-monospace { font-family: var(--term-mono); color: var(--term-cyan); }

.btn-primary, .term-btn {
    color: #07150d;
    background: #41c47e;
    border: 1px solid #41c47e;
    font-weight: 600; letter-spacing: .2px;
}
.btn-primary:hover, .term-btn:hover { background: #5fe39a; border-color: #5fe39a; color: #07150d; }
.btn-outline-primary, .btn-outline-secondary, .btn-outline-light {
    color: var(--term-green); border-color: var(--term-line); background: transparent;
}
.btn-outline-primary:hover, .btn-outline-secondary:hover, .btn-outline-light:hover {
    color: #04120a; background: var(--term-green); border-color: var(--term-green);
}

.card {
    background: var(--term-panel);
    border: 1px solid var(--term-line);
    border-radius: 8px;
    box-shadow: 0 0 0 1px rgba(61,255,132,.04), 0 10px 30px rgba(0,0,0,.5);
}
.card-title { color: var(--term-green); }

.form-control, .form-select, textarea {
    background: #06100a; color: var(--term-fg);
    border: 1px solid var(--term-line); border-radius: 6px;
    font-family: var(--term-mono);
}
.form-control::placeholder { color: #3c5e46; }
.form-control:focus, .form-select:focus {
    background: #06100a; color: var(--term-fg);
    border-color: var(--term-green);
    box-shadow: 0 0 0 .15rem rgba(61,255,132,.2);
}
.form-label { color: var(--term-dim); text-transform: uppercase; font-size: .72rem; letter-spacing: .6px; }

.table { color: var(--term-fg); }
.table > :not(caption) > * > * { border-color: var(--term-line); }
.table-danger { --bs-table-bg: #2a0d0d; --bs-table-color: #ffb3b3; }
.table-warning { --bs-table-bg: #2a230a; --bs-table-color: var(--term-amber); }

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 .15rem rgba(61,255,132,.35);
}

.content {
    padding-top: 1.1rem;
}

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: white;
}

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

/* ---- Login ---- */
.empty-layout { min-height: 100vh; display: flex; align-items: center; justify-content: center;
    background: radial-gradient(1000px 500px at 50% -10%, #0c2417 0%, #081109 60%, #050805 100%); }
.login-wrap { width: 100%; max-width: 400px; padding: 1rem; }
.login-card {
    background: var(--term-panel); color: var(--term-fg);
    border: 1px solid var(--term-line); border-radius: 12px; padding: 2rem;
    box-shadow: 0 0 0 1px rgba(61,255,132,.05), 0 20px 60px rgba(0,0,0,.6);
}
.login-card h1, .login-card h2, .login-card h3 { color: var(--term-green); }

/* ---- Nav user / sign out ---- */
.nav-user { margin-top: auto; padding-top: 1rem; border-top: 1px solid rgba(255,255,255,.1); color: #d7d7d7; }

/* ---- Connector overview (radial) ---- */
.pg-pill { display: inline-block; font-size: .68rem; padding: .1rem .5rem; border-radius: 999px; letter-spacing: .3px; }
.pg-pill-green { background: #12301f; color: var(--term-green); border: 1px solid #1f6b3a; }
.pg-pill-amber { background: #2e2710; color: var(--term-amber); border: 1px solid #6b541f; }
.pg-pill-grey  { background: #1a221d; color: var(--term-dim); border: 1px solid var(--term-line); }

.pg-radial {
    position: relative;
    width: 100%;
    max-width: 760px;
    aspect-ratio: 1 / 1;
    margin: 1rem auto 0;
}

/* spokes from the hub to each connector */
.pg-spokes { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; }
.pg-spoke { stroke: var(--term-line); stroke-width: 2; }
.pg-spoke.is-active {
    stroke: var(--term-green); stroke-width: 2.5; stroke-dasharray: 5 6;
    filter: drop-shadow(0 0 3px rgba(95,227,154,.5));
    animation: pg-dash 1s linear infinite;
}
@keyframes pg-dash { to { stroke-dashoffset: -11; } }

/* DeriQ hub, centered */
.pg-hub-center {
    position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); z-index: 3;
    width: 150px; height: 150px; border-radius: 50%;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    background: radial-gradient(circle at 50% 35%, #14b677 0%, #0b5e40 72%);
    color: #fff; text-align: center;
    border: 1px solid rgba(95,227,154,.5);
    box-shadow: 0 0 40px rgba(13,120,82,.45), inset 0 0 24px rgba(0,0,0,.25);
}
.pg-hub-logo { font-size: 1.7rem; font-weight: 800; letter-spacing: .5px; }
.pg-hub-sub { font-size: .68rem; opacity: .85; margin-bottom: .25rem; }

/* connector nodes positioned around the circle (inline left/top %) */
.pg-conn {
    position: absolute; transform: translate(-50%, -50%); z-index: 2;
    width: 150px; text-align: center;
    background: var(--term-panel); border: 1px solid var(--term-line);
    border-radius: 12px; padding: .5rem .55rem;
}
.pg-conn.is-active { border-color: var(--term-green); box-shadow: 0 0 16px rgba(95,227,154,.22); }
.pg-conn.is-planned { opacity: .55; }
.pg-conn-name { font-weight: 600; color: var(--term-fg); }
.pg-conn-meta { font-size: .68rem; color: var(--term-dim); margin-top: .25rem; line-height: 1.3; }
.pg-conn-sync { color: var(--term-cyan); display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ---- Terminal shell (shared by Logs + Database) ---- */
.term-head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: .75rem; }
.term-title { font-size: 1.3rem; margin: 0; }
.term-actions { display: flex; align-items: center; gap: .6rem; }
.term-check { color: var(--term-dim); font-size: .8rem; display: inline-flex; align-items: center; gap: .3rem; }
.term-dim { color: var(--term-dim); }
.term-error { color: var(--term-red); background: #1a0808; border: 1px solid #5a1d1d; border-radius: 6px; padding: .6rem .8rem; white-space: pre-wrap; }
.term-btn { font-size: .78rem; padding: .15rem .6rem; }
.term-input { font-family: var(--term-mono); }

/* ---- Logs ---- */
.term-toolbar { display: flex; gap: .8rem; align-items: center; margin-bottom: .6rem; flex-wrap: wrap; }
.term-levels { display: flex; gap: .35rem; }
.term-pill {
    font-size: .72rem; letter-spacing: .5px; padding: .15rem .55rem; border-radius: 999px;
    background: transparent; border: 1px solid var(--term-line); color: var(--term-dim); cursor: pointer;
}
.term-pill.is-on { color: #04120a; background: var(--term-green); border-color: var(--term-green); font-weight: 700; }
.term-toolbar .term-input { flex: 1; min-width: 180px; }

.term-screen {
    background: #0a100c; border: 1px solid var(--term-line); border-radius: 8px;
    padding: .6rem .8rem; min-height: 50vh; max-height: 68vh; overflow-y: auto;
}
.term-line { display: grid; grid-template-columns: 11.5rem 7rem 10rem 1fr; gap: .6rem; padding: .12rem 0; align-items: baseline; border-bottom: 1px dotted rgba(61,255,132,.06); white-space: nowrap; }
.term-line .term-msg { white-space: pre-wrap; word-break: break-word; }
.term-ts { color: var(--term-dim); overflow: hidden; text-overflow: ellipsis; }
.term-cat { color: var(--term-cyan); overflow: hidden; text-overflow: ellipsis; }
.term-badge { overflow: hidden; text-overflow: ellipsis; }
.term-msg { color: var(--term-fg); }
.term-badge { font-size: .68rem; font-weight: 700; letter-spacing: .5px; }
.term-exc { grid-column: 4; }
.term-exc pre { color: var(--term-red); font-size: .76rem; margin: .3rem 0 0; white-space: pre-wrap; }
.term-foot { margin-top: .5rem; font-size: .78rem; }

/* per-level coloring */
.term-lvl-information .term-badge, .term-lvl-information .term-msg { color: var(--term-fg); }
.term-lvl-warning .term-badge, .term-lvl-warning .term-msg { color: var(--term-amber); }
.term-lvl-error .term-badge, .term-lvl-error .term-msg,
.term-lvl-critical .term-badge, .term-lvl-critical .term-msg { color: var(--term-red); }
.term-lvl-debug .term-msg, .term-lvl-trace .term-msg { color: var(--term-dim); }

/* ---- Database browser ---- */
.db-layout { display: grid; grid-template-columns: 220px 1fr; gap: 1rem; align-items: start; }
.db-tables { background: var(--term-panel); border: 1px solid var(--term-line); border-radius: 8px; padding: .6rem; max-height: 75vh; overflow-y: auto; }
.db-table {
    display: block; width: 100%; text-align: left; font-family: var(--term-mono); font-size: .82rem;
    background: transparent; color: var(--term-fg); border: 0; border-radius: 5px; padding: .25rem .45rem; cursor: pointer;
}
.db-table:hover { background: rgba(61,255,132,.08); }
.db-table.is-on { background: var(--term-green); color: #04120a; font-weight: 700; }
.db-main { min-width: 0; }
.db-sql { margin-bottom: .7rem; }
.db-sql-actions { display: flex; align-items: center; gap: .6rem; margin-top: .4rem; flex-wrap: wrap; }
.db-grid-wrap { overflow: auto; max-height: 65vh; border: 1px solid var(--term-line); border-radius: 8px; }
.db-grid { width: 100%; border-collapse: collapse; font-size: .8rem; }
.db-grid th, .db-grid td { border: 1px solid var(--term-line); padding: .25rem .5rem; text-align: left; white-space: nowrap; max-width: 32rem; overflow: hidden; text-overflow: ellipsis; }
.db-grid th { position: sticky; top: 0; background: #0b1a0f; color: var(--term-green); z-index: 1; }
.db-grid tbody tr:nth-child(odd), .db-grid tbody tr:nth-child(odd) { background: rgba(255,255,255,.012); }
.db-grid .db-null { color: #355a40; font-style: italic; }