/* ── CloudReviewer brand tokens (shared with SRLicenseWebAdmin) ─────── */
:root {
    --cr-bg:        #0b0b14;
    --cr-surface:   #0e0e1c;
    --cr-surface2:  #13131f;
    --cr-border:    #ffffff17;
    --cr-text:      #eaeaf4;
    --cr-muted:     #7878a0;
    --cr-green:     #5cb85c;
    --cr-green-dim: #5cb85c24;
    --cr-blue:      #5b9bd5;
    --cr-red:       #e05252;
    --cr-yellow:    #fc940e;
    --cr-cyan:      #61ffca;
    --cr-radius:    18px;
    --cr-radius-sm: 10px;
}

/* ── Base ──────────────────────────────────────────────────────────── */
html, body {
    font-family: 'Inter', ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    background: var(--cr-bg);
    color: var(--cr-text);
    color-scheme: dark;
    font-size: 0.97rem;
    letter-spacing: -0.01em;
    min-height: 100vh;
}

/* ── Navbar ────────────────────────────────────────────────────────── */
.navbar { background: #000 !important; border-bottom: 1px solid var(--cr-border) !important; }
.nav-link { color: var(--cr-muted) !important; border-radius: var(--cr-radius-sm); transition: all 0.15s; }
.nav-link:hover { color: var(--cr-text) !important; background: #ffffff0d; }
.nav-link.active { color: var(--cr-text) !important; }

/* ── Cards ─────────────────────────────────────────────────────────── */
.card {
    background: var(--cr-surface);
    border: 1px solid var(--cr-border);
    border-radius: var(--cr-radius);
    box-shadow: 0 4px 24px #00000040, inset 0 1px #ffffff0f;
    color: var(--cr-text);
}
.card-header {
    background: var(--cr-surface2);
    border-bottom: 1px solid var(--cr-border);
    border-radius: var(--cr-radius) var(--cr-radius) 0 0 !important;
    font-weight: 600;
    color: var(--cr-text);
}

/* ── Tables ────────────────────────────────────────────────────────── */
.table { color: var(--cr-text); border-color: var(--cr-border); }
.table th { font-size: 0.8rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--cr-muted); border-color: var(--cr-border); }
.table td { border-color: var(--cr-border); vertical-align: middle; }
.table-striped > tbody > tr:nth-of-type(odd) > * { background-color: #ffffff06; color: var(--cr-text); }
.table-hover > tbody > tr:hover > * { background-color: #ffffff0d; color: var(--cr-text); }

/* ── Inputs ────────────────────────────────────────────────────────── */
.form-control, .form-select { background: var(--cr-surface2); border: 1px solid var(--cr-border); color: var(--cr-text); border-radius: var(--cr-radius-sm); }
.form-control:focus, .form-select:focus { background: var(--cr-surface2); border-color: var(--cr-green); color: var(--cr-text); box-shadow: 0 0 0 3px var(--cr-green-dim); }
.form-control::placeholder { color: var(--cr-muted); }

/* ── Buttons ───────────────────────────────────────────────────────── */
.btn-primary { background: var(--cr-green); border-color: var(--cr-green); color: #0b0b14; font-weight: 600; border-radius: var(--cr-radius-sm); }
.btn-primary:hover, .btn-primary:focus { background: #6dcf6d; border-color: #6dcf6d; color: #0b0b14; }
.btn-outline-primary { border-color: var(--cr-green); color: var(--cr-green); border-radius: var(--cr-radius-sm); }
.btn-outline-primary:hover { background: var(--cr-green); color: #0b0b14; }
.btn-outline-secondary { border-color: var(--cr-border); color: var(--cr-muted); border-radius: var(--cr-radius-sm); }
.btn-outline-secondary:hover { background: #ffffff14; border-color: var(--cr-border); color: var(--cr-text); }
.btn-outline-danger { border-color: var(--cr-red); color: var(--cr-red); border-radius: var(--cr-radius-sm); }
.btn-danger { background: var(--cr-red); border-color: var(--cr-red); border-radius: var(--cr-radius-sm); }
.btn-sm { font-size: 0.8rem; }

/* ── Badges ────────────────────────────────────────────────────────── */
.badge.bg-success  { background: var(--cr-green-dim) !important; color: var(--cr-green) !important; border: 1px solid var(--cr-green); }
.badge.bg-danger   { background: #e0525224 !important; color: var(--cr-red) !important; border: 1px solid var(--cr-red); }
.badge.bg-warning  { background: #fc940e1f !important; color: var(--cr-yellow) !important; border: 1px solid var(--cr-yellow); }
.badge.bg-info     { background: #5b9bd51f !important; color: var(--cr-blue) !important; border: 1px solid var(--cr-blue); }
.badge.bg-secondary { background: #ffffff14 !important; color: var(--cr-muted) !important; border: 1px solid var(--cr-border); }

/* ── Alerts ────────────────────────────────────────────────────────── */
.alert-danger   { background: #e0525218; border-color: var(--cr-red);    color: #f08080; }
.alert-warning  { background: #fc940e14; border-color: var(--cr-yellow); color: #f0b060; }
.alert-success  { background: var(--cr-green-dim); border-color: var(--cr-green); color: var(--cr-green); }
.alert-info     { background: #5b9bd514; border-color: var(--cr-blue);   color: var(--cr-blue); }

/* ── List groups ───────────────────────────────────────────────────── */
.list-group-item { background: var(--cr-surface); border-color: var(--cr-border); color: var(--cr-text); border-radius: var(--cr-radius-sm) !important; margin-bottom: 4px; transition: background 0.15s; }
.list-group-item-action:hover { background: var(--cr-surface2) !important; color: var(--cr-green) !important; border-color: var(--cr-green) !important; }
.list-group { gap: 2px; }

/* ── Dropdowns ─────────────────────────────────────────────────────── */
.dropdown-menu { background: var(--cr-surface); border: 1px solid var(--cr-border); border-radius: var(--cr-radius-sm); }
.dropdown-item { color: var(--cr-text); }
.dropdown-item:hover { background: #ffffff0d; color: var(--cr-text); }
.dropdown-item.active { background: var(--cr-green-dim); color: var(--cr-green); }

/* ── Dashboard tiles ───────────────────────────────────────────────── */
.dc-tile {
    border-color: var(--cr-border) !important;
    transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
}
.dc-tile:hover {
    border-color: var(--tile-color, var(--cr-green)) !important;
    transform: translateY(-3px);
    box-shadow: 0 8px 32px #00000050, inset 0 1px #ffffff0f !important;
}
.dc-tile-icon {
    width: 48px; height: 48px;
    border-radius: 12px;
    background: #ffffff0d;
    border: 1px solid var(--cr-border);
    display: flex; align-items: center; justify-content: center;
}

/* ── Misc ──────────────────────────────────────────────────────────── */
h1, h2, h3, h4, h5 { font-weight: 700; letter-spacing: -0.03em; }
.text-muted { color: var(--cr-muted) !important; }
code { background: #ffffff0d; border: 1px solid var(--cr-border); border-radius: 6px; padding: 1px 6px; color: var(--cr-cyan); font-size: 0.85em; }
hr { border-color: var(--cr-border); }

/* ── Focus indicators (WCAG 2.1 AA: 2.4.7 Focus Visible) ──────────── */
.btn:focus-visible,
.form-control:focus-visible,
.form-select:focus-visible,
.list-group-item-action:focus-visible,
a:focus-visible { outline: 2px solid var(--cr-cyan); outline-offset: 2px; }

/* ── Color contrast fix: table headers use full text color ────────── */
.table th { color: var(--cr-text); }

/* ── Login page tokens (replaces inline styles on /login, /login-otp) */
.login-card { background: var(--cr-surface); border: 1px solid var(--cr-border); border-radius: var(--cr-radius); box-shadow: 0 32px 80px #000000b3, inset 0 1px #ffffff0f; }
.login-label { color: var(--cr-muted); font-size: 0.82rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; }
.login-subtitle { color: var(--cr-green); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.1em; }
.otp-input { font-size: 1.5rem; letter-spacing: 0.35em; text-align: center; font-variant-numeric: tabular-nums; }
.otp-hint { color: var(--cr-muted); font-size: 0.82rem; }
.back-link { color: var(--cr-muted); font-size: 0.82rem; text-decoration: none; }
.back-link:hover { color: var(--cr-green); }

/* ── Blue dim for Download All button ─────────────────────────────── */
:root { --cr-blue-dim: #1a2a3a; }
