﻿:root {
    /* Extracted from nappr.io production bundle: /assets/index-BD3ncKsv.css */
    --nappr-primary: #11a5ea;
    --nappr-primary-dark: #0e93cf;
    --nappr-primary-deep: #1583ff;
    --nappr-sky: #8ec2ff;
    --nappr-sky-soft: #eaf3ff;
    --nappr-ink: #1f2937;
    --nappr-ink-strong: #0f172a;
    --nappr-muted: #6b7280;
    --nappr-background: #f7fafc;
    --nappr-card: #ffffff;
    --nappr-border: #e5e7eb;
    --nappr-success: #22c55e;
    --nappr-warning: #f59e0b;
    --nappr-danger: #b42318;
    --nappr-footer-dark: #2f2f2f;
    --bs-primary: var(--nappr-primary);
    --bs-primary-rgb: 17, 165, 234;
    --bs-body-bg: var(--nappr-background);
    --bs-body-color: var(--nappr-ink);
    --bs-link-color: var(--nappr-primary);
    --bs-link-hover-color: var(--nappr-primary-dark);
    --bs-border-radius: 0.75rem;
    --bs-font-sans-serif: "DM Sans", Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

html, body {
    min-height: 100%;
    font-family: var(--bs-font-sans-serif);
    background:
        radial-gradient(circle at top left, rgba(142, 194, 255, 0.42), transparent 34rem),
        linear-gradient(180deg, #f7fbff 0%, var(--nappr-background) 42%, #ffffff 100%);
}

.btn-primary {
    --bs-btn-bg: var(--nappr-primary);
    --bs-btn-border-color: var(--nappr-primary);
    --bs-btn-hover-bg: var(--nappr-primary-dark);
    --bs-btn-hover-border-color: var(--nappr-primary-dark);
    --bs-btn-active-bg: var(--nappr-primary-dark);
    --bs-btn-active-border-color: var(--nappr-primary-dark);
    box-shadow: 0 8px 20px rgba(17, 165, 234, 0.22);
}

.text-bg-warning {
    color: #0f172a !important;
    background-color: #cfe2ff !important;
}

.content {
    padding-top: 1.5rem;
}

.hero-card {
    color: #fff;
    background:
        linear-gradient(180deg, rgba(142, 194, 255, 0.95) 0%, rgba(30, 144, 255, 0.94) 58%, rgba(21, 131, 255, 0.96) 100%),
        radial-gradient(circle at 82% 12%, rgba(255, 255, 255, 0.38), transparent 20rem);
    overflow: hidden;
    position: relative;
    box-shadow: 0 24px 60px rgba(17, 165, 234, 0.22);
}

.hero-card::after {
    content: "";
    position: absolute;
    inset: auto -4rem -8rem auto;
    width: 18rem;
    height: 18rem;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.28);
    filter: blur(4px);
}

.hero-card > .row {
    position: relative;
    z-index: 1;
}

.hero-card .lead {
    color: rgba(255, 255, 255, 0.86);
    max-width: 46rem;
}

.hero-status-card {
    background: rgba(255, 255, 255, 0.94);
    color: var(--nappr-ink);
}

.nappr-badge {
    color: #083344;
    background: rgba(255, 255, 255, 0.92);
}

.nappr-badge.muted {
    color: #fff;
    background: rgba(255, 255, 255, 0.18);
    border: 1px solid rgba(255, 255, 255, 0.28);
}

.card {
    border-radius: 1.1rem;
    background: rgba(255, 255, 255, 0.94);
    border-color: rgba(15, 23, 42, 0.06) !important;
}

.metric-card {
    background: var(--nappr-card);
}

.metric-dot {
    width: 0.8rem;
    height: 0.8rem;
    border-radius: 999px;
    background: var(--nappr-primary);
    box-shadow: 0 0 0 0.3rem rgba(17, 165, 234, 0.14);
}

.metric-dot.success {
    background: var(--nappr-success);
    box-shadow: 0 0 0 0.3rem rgba(34, 197, 94, 0.12);
}

.metric-dot.accent {
    background: var(--nappr-primary-deep);
    box-shadow: 0 0 0 0.3rem rgba(21, 131, 255, 0.14);
}

.metric-dot.warning {
    background: var(--nappr-warning);
    box-shadow: 0 0 0 0.3rem rgba(245, 158, 11, 0.14);
}

.nappr-progress {
    height: 0.65rem;
    background: #eaf3ff;
    border-radius: 999px;
}

.nappr-progress.compact {
    height: 0.5rem;
}

.nappr-progress .progress-bar {
    background: linear-gradient(90deg, var(--nappr-primary), var(--nappr-primary-deep));
    border-radius: 999px;
}

.nappr-table thead th {
    color: var(--nappr-muted);
    font-size: 0.76rem;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border-bottom-color: var(--nappr-border);
}

.nappr-table td {
    border-bottom-color: #eef2f7;
}

.alert-card {
    background: #f7fbff;
    border: 1px solid #cfe2ff;
}

h1:focus {
    outline: none;
}

.blazor-error-boundary {
    background: #b42318;
    padding: 1rem;
    color: white;
}

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

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.login-shell {
    min-height: calc(100vh - 7rem);
    display: grid;
    align-items: center;
}

.login-card {
    width: min(100%, 32rem);
}

.form-control:focus {
    border-color: var(--nappr-primary);
    box-shadow: 0 0 0 0.25rem rgba(17, 165, 234, 0.18);
}
