:root {
    --bg: #0a0a0a;
    --surface: #111111;
    --card: #1a1a1a;
    --accent: #c026d3;
    --accent2: #7c3aed;
    --text: #ffffff;
    --muted: #a1a1aa;
    --border: rgba(255,255,255,0.08);
}

*, *::before, *::after {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

html, body {
    font-family: 'Montserrat', 'Helvetica Neue', Helvetica, Arial, sans-serif;
    background-color: var(--bg);
    color: var(--text);
    margin: 0;
    padding: 0;
}

a {
    color: var(--accent);
    text-decoration: none;
}

a:hover {
    color: var(--accent);
    opacity: 0.8;
}

h1:focus {
    outline: none;
}

/* Form validation */
.valid.modified:not([type=checkbox]) {
    outline: 1px solid #22c55e;
}

.invalid {
    outline: 1px solid #ef4444;
}

.validation-message {
    color: #ef4444;
    font-size: 0.8rem;
    margin-top: 0.25rem;
}

/* Blazor error boundary */
.blazor-error-boundary {
    background: #7c3aed;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

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

/* Bootstrap overrides for dark theme */
.form-control, .form-select {
    background-color: var(--card) !important;
    border-color: var(--border) !important;
    color: var(--text) !important;
}

.form-control:focus, .form-select:focus {
    background-color: var(--card) !important;
    border-color: var(--accent) !important;
    color: var(--text) !important;
    box-shadow: 0 0 0 0.2rem rgba(192, 38, 211, 0.25) !important;
}

.form-control::placeholder {
    color: var(--muted) !important;
}

.form-floating > label {
    color: var(--muted) !important;
}

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