/* ── Design tokens ─────────────────────────────────────────── */
:root {
    --clr-bg:           #1a1b26;
    --clr-surface:      #24253a;
    --clr-surface-alt:  #2d2e45;
    --clr-border:       #363755;
    --clr-text:         #c0c2d8;
    --clr-text-dim:     #6e6f85;
    --clr-accent:       #5c9cf5;
    --clr-accent-hover: #4a88e0;
    --clr-danger:       #e05c6e;
    --clr-danger-hover: #c74a5b;
    --clr-success:      #5cba7d;
    --clr-warning:      #e0a45c;

    --radius:    0.25rem;
    --radius-lg: 0.375rem;

    font-size: 13px; /* 1rem = 13px — keeps everything compact */
}

/* ── Reset & base ──────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html, body {
    height: 100%;
    overflow: hidden;
}

body {
    font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
    margin: 0;
    padding: 0;
    background-color: var(--clr-bg);
    color: var(--clr-text);
    font-size: 1rem;
    line-height: 1.45;
    display: flex;
    flex-direction: column;
}

#app {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

/* Tab container — the raw <div> wrapping tab-header + tab-content */
#app > div {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    overflow: hidden;
}

/* ── Scrollbars ────────────────────────────────────────────── */
::-webkit-scrollbar       { width: 0.4rem; height: 0.4rem; }
::-webkit-scrollbar-track { background: var(--clr-bg); }
::-webkit-scrollbar-thumb { background: var(--clr-border); border-radius: 0.25rem; }
::-webkit-scrollbar-thumb:hover { background: var(--clr-text-dim); }

::selection { background-color: var(--clr-accent); color: #fff; }

/* ── Buttons ───────────────────────────────────────────────── */
button {
    background-color: var(--clr-surface-alt);
    border: 1px solid var(--clr-border);
    color: var(--clr-text);
    border-radius: var(--radius);
    padding: 0.26rem 0.7rem;
    font-size: 0.92rem;
    font-family: inherit;
    cursor: pointer;
    transition: background-color 0.15s, border-color 0.15s, color 0.15s;
    white-space: nowrap;
    line-height: 1.4;
}

button:hover:not(:disabled) {
    background-color: var(--clr-accent);
    border-color: var(--clr-accent);
    color: #fff;
}

button:disabled {
    opacity: 0.38;
    cursor: not-allowed;
}

button.btn-primary {
    background-color: var(--clr-accent);
    border-color: var(--clr-accent);
    color: #fff;
}

button.btn-primary:hover:not(:disabled) {
    background-color: var(--clr-accent-hover);
    border-color: var(--clr-accent-hover);
}

button.btn-edit {
    background-color: transparent;
    border-color: var(--clr-accent);
    color: var(--clr-accent);
    padding: 0.15rem 0.55rem;
    font-size: 0.8rem;
}

button.btn-edit:hover:not(:disabled) {
    background-color: var(--clr-accent);
    color: #fff;
}

button.btn-delete {
    background-color: transparent;
    border-color: var(--clr-danger);
    color: var(--clr-danger);
    padding: 0.15rem 0.55rem;
    font-size: 0.8rem;
}

button.btn-delete:hover:not(:disabled) {
    background-color: var(--clr-danger);
    border-color: var(--clr-danger);
    color: #fff;
}

/* ── Toolbar ───────────────────────────────────────────────── */
.toolbar {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.4rem 0.65rem;
    background-color: var(--clr-surface);
    border-bottom: 1px solid var(--clr-border);
    flex-wrap: wrap;
}

.toolbar select { min-width: 9rem; }

/* ── Login ─────────────────────────────────────────────────── */
.login-container {
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 1;
    min-height: 0;
}

.login-card {
    background-color: var(--clr-surface);
    border: 1px solid var(--clr-border);
    border-radius: var(--radius-lg);
    padding: 2rem 2.5rem;
    width: 22rem;
    max-width: 100%;
}

.login-card h2 {
    margin: 0 0 1.5rem;
    font-size: 1.2rem;
    color: var(--clr-text);
    text-align: center;
}

.login-card button[type="submit"] {
    width: 100%;
    margin-top: 0.4rem;
    padding: 0.45rem 0.7rem;
    background-color: var(--clr-accent);
    border-color: var(--clr-accent);
    color: #fff;
}

.login-card button[type="submit"]:hover:not(:disabled) {
    background-color: var(--clr-accent-hover);
    border-color: var(--clr-accent-hover);
}

