html, body {
    font-family: 'Lora', serif;
}

/* Dark slate gradient background with subtle memorial image overlay */
body.rz-dark-mode {
    background: linear-gradient(to bottom, #0F172A 0%, #1E293B 50%, #0F172A 100%);
    background-attachment: fixed;
    position: relative;
}

body.rz-dark-mode::before {
    content: '';
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: url('/img/memorial_room_background.jpg');
    background-size: cover;
    background-position: center;
    opacity: 0.15;
    z-index: -1;
    pointer-events: none;
}

/* Hebrew text support - use Arial first for better Hebrew glyph coverage */
.hebrew-text {
    font-family: Arial, 'Segoe UI', Tahoma, 'Noto Sans Hebrew', sans-serif;
    color: #fbbf24;
}


/* Cinzel font for all H1 and H2 headers, including Radzen components */
h1,
.rz-text-h1,
.rz-text-display-1,
h2,
.rz-text-h2,
.rz-text-display-2 {
    font-family: 'Cinzel', serif !important;
    font-weight: 600 !important;
}


/* Override Radzen Card for Home Hero - Slate gradient with amber accents */
.rz-card.home-hero-card {
    background: linear-gradient(135deg, #1E293B 0%, #0F172A 100%) !important;
    border: 1px solid rgba(71, 85, 105, 0.5) !important;
    border-radius: 24px !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6) !important;
    color: #F1F5F9 !important;
}

body.rz-dark-mode .rz-card.home-hero-card {
    background: linear-gradient(135deg, #1E293B 0%, #0F172A 100%) !important;
    border: 1px solid rgba(71, 85, 105, 0.5) !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6) !important;
}


/* Override Radzen Card for ViewCandle Hero - Slate with amber accents */
.rz-card.view-candle-hero {
    background: rgba(30, 41, 59, 0.85) !important;
    border: 1px solid rgba(71, 85, 105, 0.5) !important;
    border-radius: 24px !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6) !important;
    backdrop-filter: blur(10px) !important;
    color: #F1F5F9 !important;
}

/* Improve text readability on ViewCandle page */
.view-candle-hero .rz-text-h6,
.view-candle-hero h6 {
    color: #F1F5F9 !important;
}

.view-candle-hero .rz-color-secondary {
    color: #CBD5E1 !important;
}

.view-candle-hero .rz-text {
    color: #F1F5F9 !important;
}


/* ============================================ */
/* ViewCandles Page - Memorial Room Background */
/* ============================================ */

/* Override Radzen theme background when ViewCandles page is active */
body:has(.view-candles-wrapper) {
    background-image: url('/img/memorial_room_background.jpg') !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    background-attachment: fixed !important;
    --rz-body-background-color: transparent !important;
    --rz-base-background-color: transparent !important;
}

body.rz-dark-mode:has(.view-candles-wrapper) {
    --rz-body-background-color: transparent !important;
    --rz-base-background-color: transparent !important;
}

/* Remove article/content padding on ViewCandles page */
body:has(.view-candles-wrapper) .content {
    padding: 0 !important;
}

body:has(.view-candles-wrapper) article {
    padding: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    background: transparent !important;
}

/* Override media query padding from MainLayout */
@media (min-width: 641px) {
    body:has(.view-candles-wrapper) article {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
}

/* Override Radzen Cards for ViewCandles page */
.rz-card.view-candles-header-card {
    background: rgba(30, 41, 59, 0.95) !important;
    border: 1px solid rgba(251, 146, 60, 0.3) !important;
    border-radius: 16px !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.6) !important;
    backdrop-filter: blur(10px) !important;
}

.view-candles-header-card .rz-text,
.view-candles-header-card h1,
.view-candles-header-card .rz-text-h2 {
    color: #FCD34D !important;
}

.rz-card.view-candles-empty-card {
    background: rgba(30, 41, 59, 0.95) !important;
    border: 1px solid rgba(71, 85, 105, 0.5) !important;
    border-radius: 16px !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.6) !important;
    backdrop-filter: blur(10px) !important;
}

.view-candles-empty-card .rz-text,
.view-candles-empty-card h5 {
    color: #F1F5F9 !important;
}



/* ============================================ */
/* MyCandles Page - Memorial Room Background    */
/* ============================================ */

/* Override Radzen theme background when MyCandles page is active */
body:has(.my-candles-wrapper) {
    background-image: url('/img/memorial_room_background.jpg') !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    background-attachment: fixed !important;
    --rz-body-background-color: transparent !important;
    --rz-base-background-color: transparent !important;
}

body.rz-dark-mode:has(.my-candles-wrapper) {
    --rz-body-background-color: transparent !important;
    --rz-base-background-color: transparent !important;
}

/* Remove article/content padding on MyCandles page */
body:has(.my-candles-wrapper) .content {
    padding: 0 !important;
}

body:has(.my-candles-wrapper) article {
    padding: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    background: transparent !important;
}

/* Override media query padding from MainLayout */
@media (min-width: 641px) {
    body:has(.my-candles-wrapper) article {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
}

/* Override Radzen Cards for MyCandles page - semi-transparent slate backgrounds */
body:has(.my-candles-wrapper) .rz-card {
    background: rgba(30, 41, 59, 0.85) !important;
    border: 1px solid rgba(71, 85, 105, 0.5) !important;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.6) !important;
    backdrop-filter: blur(10px) !important;
}

body:has(.my-candles-wrapper) .rz-card .rz-text,
body:has(.my-candles-wrapper) .rz-card h1,
body:has(.my-candles-wrapper) .rz-card h4,
body:has(.my-candles-wrapper) .rz-card h6 {
    color: #F1F5F9 !important;
}


/* ============================================ */
/* ViewCandle Page - Memorial Room Background   */
/* ============================================ */

/* Override Radzen theme background when ViewCandle page is active */
body:has(.view-candle-page) {
    background-image: url('/img/memorial_room_background.jpg') !important;
    background-size: cover !important;
    background-position: center !important;
    background-repeat: no-repeat !important;
    background-attachment: fixed !important;
    --rz-body-background-color: transparent !important;
    --rz-base-background-color: transparent !important;
}

body.rz-dark-mode:has(.view-candle-page) {
    --rz-body-background-color: transparent !important;
    --rz-base-background-color: transparent !important;
}

/* Remove article/content padding on ViewCandle page */
body:has(.view-candle-page) .content {
    padding: 0 !important;
}

body:has(.view-candle-page) article {
    padding: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    background: transparent !important;
}

/* Override media query padding from MainLayout */
@media (min-width: 641px) {
    body:has(.view-candle-page) article {
        padding-left: 0 !important;
        padding-right: 0 !important;
    }
}

/* Slate/Amber memorial theme - Dark elegant design
   Use Radzen CSS variables as the source of truth so Radzen components follow the palette.
*/
:root {
    --mc-bg: #FBF4E6;
    --mc-surface: #FFF9EE;
    --mc-text: #3A2B1F;
    --mc-muted: #6B5644;
    --mc-primary: #D97706;
    --mc-primary-hover: #B45309;
    --mc-accent: #FBBF24;

    /* Sidebar (nav) gradient: slate dark */
    --mc-nav-top: #0F172A;
    --mc-nav-bottom: #1E293B;

    --mc-nav-text: rgba(251, 191, 36, 0.92);
    --mc-nav-text-muted: rgba(203, 213, 225, 0.72);

    /* Radzen theme overrides */
    --rz-primary: var(--mc-primary);
    --rz-on-primary: #ffffff;
    --rz-link-color: var(--mc-primary);
    --rz-link-hover-color: var(--mc-primary-hover);

    --rz-body-background-color: var(--mc-bg);
    --rz-body-color: var(--mc-text);

    --rz-base-background-color: var(--mc-surface);
    --rz-base-foreground-color: var(--mc-text);

    --rz-secondary: var(--mc-muted);

    /* Bootstrap alignment */
    --bs-primary: var(--mc-primary);
    --bs-link-color: var(--mc-primary);
    --bs-link-hover-color: var(--mc-primary-hover);
}

/* Dark mode support - Slate/Amber elegant theme */
body.rz-dark-mode {
    --mc-bg: #0F172A;
    --mc-surface: #1E293B;
    --mc-text: #F1F5F9;
    --mc-muted: rgba(203, 213, 225, 0.75);
    --mc-primary: #F59E0B;
    --mc-primary-hover: #D97706;
    --mc-accent: #FBBF24;

    /* Sidebar (nav) gradient: deep slate */
    --mc-nav-top: #020617;
    --mc-nav-bottom: #0F172A;

    --mc-nav-text: rgba(251, 191, 36, 0.92);
    --mc-nav-text-muted: rgba(203, 213, 225, 0.70);

    /* Radzen uses the presence of .rz-dark-mode, but we still set vars so custom CSS aligns */
    --rz-body-background-color: var(--mc-bg);
    --rz-body-color: var(--mc-text);
    --rz-base-background-color: var(--mc-surface);
    --rz-base-foreground-color: var(--mc-text);
    --rz-primary: var(--mc-primary);
    --rz-link-color: var(--mc-primary);
    --rz-link-hover-color: var(--mc-primary-hover);

    --bs-primary: var(--mc-primary);
    --bs-link-color: var(--mc-primary);
    --bs-link-hover-color: var(--mc-primary-hover);
}


a, .btn-link {
    color: var(--mc-primary);
}

.btn-primary {
    color: #fff;
    background-color: var(--mc-primary);
    border-color: var(--mc-primary);
}

.btn-primary:hover {
    background-color: var(--mc-primary-hover);
    border-color: var(--mc-primary-hover);
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem color-mix(in srgb, var(--mc-primary) 55%, transparent);
}

.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,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1zbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA9NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDgCjYyLjAxODMgMjYzLjU4NiA2Ni4wMTgzIE0yNjMuNTc2IDg2LjA1NDdDMjYxLjA0OSA4Ni4wNTQ3IDI1OS43ODUgODcuMzAwMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA4OSw5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) 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;
}