/*
================================================================================
THEIDGUYS.TECH - CUSTOM STYLES
================================================================================
Table of Contents:
1. CSS Variables & Root Settings
2. Base Typography & Layout
3. Theme Transitions & Animations
4. Bootstrap Dark Mode O.theme-toggle .sun-and-moon > .moon > circle {
    transform: translateX(7px);
}

/* Enhanced hover and focus effects - removed to avoid conflicts */

/* Dark theme overrides */
[data-bs-theme="dark"] .theme-toggle {
    color: var(--icon-fill) !important;
}

[data-bs-theme="dark"] .theme-toggle:hover .sun-and-moon > .sun {
    transform: scale(1.85) !important;
}

[data-bs-theme="dark"] .theme-toggle .sun-and-moon > .sun {
    transform: scale(1.75) !important;
    fill: #ffffff !important; /* White for dark mode */
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ================================================================================
   CSS TABLE OF CONTENTS
================================================================================
1. CSS Variables & Root Settings
2. Base HTML Elements
3. Bootstrap Overrides
4. View Transitions & Theme System
5. Navigation & Header Components
6. Blog Content & Typography
7. Code Blocks & Copy Functionality
8. Forms & Input Components
9. Cards & Content Containers
10. Utility & Helper Classes
11. Responsive Design
================================================================================
*/

/* =========================
   1. CSS Variables & Root Settings
   ========================= */
:root {
    /* Theme transition settings */
    --transition-duration: 0.3s;
    --transition-easing: cubic-bezier(0.4, 0.0, 0.2, 1);
    
    /* Custom color palette */
    --brand-warning: #ffc107;
    --brand-warning-hover: #ffcd39;
    --brand-warning-subtle: rgba(255, 193, 7, 0.1);
    
    /* Theme toggle icon colors */
    --icon-fill: #ffa500;
    --icon-fill-hover: #ff9500;
    
    /* Z-index scale */
    --z-navbar: 1030;
    --z-copy-button: 10;
    --z-transitions: 9999;
}

/* Dark theme color overrides */
[data-bs-theme="dark"] {
    --icon-fill: #ffffff;
    --icon-fill-hover: #e0e0e0;
}

/* =========================
   2. Base Typography & Layout
   ========================= */
html, body {
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

.content {
    padding-top: 1.1rem;
}

/* Focus styles */
h1:focus {
    outline: none;
}

/* Utility classes */
.cursor-pointer {
    cursor: pointer;
}

/* =========================
   3. Theme Transitions & Animations
   ========================= */
/* View transition animations for theme switching */
[data-bs-theme="dark"]::view-transition-new(root) {
    animation: circle-in-dark 0.5s ease-out forwards;
    z-index: var(--z-transitions);
}

[data-bs-theme="light"]::view-transition-new(root) {
    animation: circle-in-light 0.5s ease-out forwards;
    z-index: var(--z-transitions);
}

@keyframes circle-in-dark {
    from { clip-path: circle(0% at 50% 0%); }
    to { clip-path: circle(150% at 50% 0%); }
}

@keyframes circle-in-light {
    from { clip-path: circle(0% at 50% 100%); }
    to { clip-path: circle(150% at 50% 100%); }
}

::view-transition-old(root) {
    animation-delay: 0.5s;
    z-index: 1;
}

/* =========================
   4. Bootstrap Dark Mode Overrides
   ========================= */
[data-bs-theme="dark"] {
    color-scheme: dark;
    --bs-body-color: #dee2e6;
    --bs-body-bg: #212529;
    --bs-emphasis-color: #fff;
    --bs-secondary-color: rgba(222, 226, 230, 0.75);
    --bs-secondary-bg: #343a40;
    --bs-tertiary-color: rgba(222, 226, 230, 0.5);
    --bs-tertiary-bg: #2b3035;
    --bs-border-color: #495057;
    --bs-border-color-translucent: rgba(255, 255, 255, 0.15);
}

/* Body styles for both themes */
[data-bs-theme="dark"] body {
    background-color: var(--bs-body-bg) !important;
    color: var(--bs-body-color) !important;
}

[data-bs-theme="light"] body {
    background-color: var(--bs-light, #f8f9fa) !important;
    color: var(--bs-dark, #212529) !important;
}

/* Bootstrap component overrides for dark theme */
[data-bs-theme="dark"] .card {
    background-color: var(--bs-secondary-bg) !important;
    border-color: var(--bs-border-color) !important;
    color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .card-header {
    background-color: var(--bs-tertiary-bg) !important;
    border-color: var(--bs-border-color) !important;
}

[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] textarea.form-control {
    background-color: var(--bs-secondary-bg) !important;
    color: var(--bs-body-color) !important;
    border-color: var(--bs-border-color) !important;
}

/* Alert and utility overrides */
[data-bs-theme="dark"] .alert-info {
    --bs-alert-color: #6edff6;
    --bs-alert-bg: #032830;
    --bs-alert-border-color: #087990;
}

[data-bs-theme="dark"] .alert-light {
    background-color: var(--bs-secondary-bg);
    border-color: var(--bs-border-color);
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] .bg-light {
    background-color: var(--bs-dark, #212529) !important;
}

[data-bs-theme="dark"] .text-body-secondary {
    color: var(--bs-secondary-color) !important;
}

[data-bs-theme="dark"] .border-top {
    border-color: var(--bs-border-color) !important;
}

[data-bs-theme="dark"] .shadow-lg {
    box-shadow: 0 1rem 3rem rgba(255, 255, 255, 0.1) !important;
}

[data-bs-theme="light"] .shadow-lg {
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.175) !important;
}

/* Footer logo theme switching */
.footer-logo {
    width: 32px;
    height: 32px;
    background-image: url('/img/IdGuys/IdGuysLogo-white.png');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}

/* Footer social icons hover effects */
footer .bi {
    transition: all 0.3s ease;
    display: inline-block;
}

footer .bi:hover {
    transform: translateY(-2px) scale(1.1);
}

/* =========================
   5. Navigation & Header Components
   ========================= */
/* Main navbar - always dark theme */
#main-navbar {
    background-color: #343a40 !important;
    border-color: #495057 !important;
    position: relative;
}

#main-navbar .navbar-brand,
#main-navbar .nav-link,
#main-navbar .navbar-nav .nav-link,
#main-navbar .dropdown-item {
    color: var(--brand-warning) !important;
}

#main-navbar .nav-link,
#main-navbar .navbar-nav .nav-link {
    margin: 0 0.5rem;
    transition: transform 0.2s ease;
}

#main-navbar .nav-link:hover,
#main-navbar .navbar-nav .nav-link:hover {
    background-color: transparent !important;
    color: var(--brand-warning) !important;
    transform: translateY(-1px);
    border-radius: var(--bs-border-radius, 0.375rem);
}

/* Active nav link styling */
.navbar-nav .nav-link.active,
#main-navbar .nav-link.active,
#main-navbar .navbar-nav .nav-link.active {
    background-color: var(--brand-warning-subtle) !important;
    color: var(--brand-warning) !important;
    border-radius: var(--bs-border-radius, 0.375rem);
    border-bottom: none !important;
    box-shadow: none !important;
}

.navbar-nav .nav-link.active:hover {
    background-color: var(--brand-warning-hover) !important;
    color: #000 !important;
}

/* Dropdown styling */
.dropdown-menu .dropdown-item.active,
#main-navbar .dropdown-item.active,
#main-navbar .dropdown-menu .dropdown-item.active {
    background-color: var(--brand-warning-subtle) !important;
    color: var(--brand-warning) !important;
}

.dropdown-menu .dropdown-item.active:hover {
    background-color: var(--brand-warning-hover) !important;
    color: #000 !important;
}

/* Navigation indicator (sliding underline) */
.navbar-nav {
    position: relative;
}

.nav-indicator {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 4px;
    background-color: var(--brand-warning);
    transition: all 0.4s var(--transition-easing);
    border-radius: 2px 2px 0 0;
    z-index: var(--z-copy-button);
    opacity: 1;
    box-shadow: 0 -1px 3px rgba(255, 193, 7, 0.5);
}

/* Navbar toggler */
#main-navbar .navbar-toggler {
    border-color: rgba(255, 255, 255, 0.1) !important;
}

#main-navbar .navbar-toggler-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.55%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}

/* Theme toggle button - restored to original working approach */
.theme-toggle {
    --size: 2rem;
    --icon-fill: #ffa500;
    --icon-fill-hover: #ff9500;
    background: none;
    border: none;
    padding: 0;
    inline-size: var(--size);
    block-size: var(--size);
    aspect-ratio: 1;
    border-radius: 50%;
    cursor: pointer;
    touch-action: manipulation;
    color: var(--icon-fill);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
}

.theme-toggle:hover {
    color: var(--icon-fill-hover);
    transform: scale(1.1);
}

.theme-toggle:active {
    transform: scale(0.95);
}

.theme-toggle > svg {
    inline-size: 100%;
    block-size: 100%;
    stroke-linecap: round;
}

/* Sun and Moon Animations - Use more specific selectors */
.theme-toggle .sun-and-moon > .moon,
.theme-toggle .sun-and-moon > .sun,
.theme-toggle .sun-and-moon > .sun-beams {
    transform-origin: center center;
}

.theme-toggle .sun-and-moon > .moon,
.theme-toggle .sun-and-moon > .sun {
    fill: #ffa500 !important; /* Orange for light mode */
    transition: transform 0.5s ease, fill 0.3s ease;
}

.theme-toggle .sun-and-moon > .sun-beams {
    stroke: #ffa500 !important; /* Orange for light mode */
    stroke-width: 2px !important;
    opacity: 1 !important;
    stroke-linecap: round;
    transform: rotateZ(0deg);
    transition: transform 0.5s ease, opacity 0.5s ease;
    fill: none !important;
}

.theme-toggle .sun-and-moon > .moon > circle {
    transition: transform 0.25s ease;
}

/* Dark theme overrides */
[data-bs-theme="dark"] .theme-toggle {
    color: var(--icon-fill) !important;
}

[data-bs-theme="dark"] .theme-toggle .sun-and-moon > .sun {
    transform: scale(1.75) !important;
    fill: #ffffff !important; /* White for dark mode */
}

[data-bs-theme="dark"] .theme-toggle .sun-and-moon > .sun-beams {
    opacity: 0 !important;
    transform: rotateZ(-25deg) !important;
    stroke: #ffffff !important; /* White for dark mode */
}

/* Light theme - ensure sun is normal size */
[data-bs-theme="light"] .theme-toggle {
    color: var(--icon-fill) !important;
}

[data-bs-theme="light"] .theme-toggle:hover .sun-and-moon > .sun {
    transform: scale(1.1) !important;
}

[data-bs-theme="light"] .theme-toggle:hover .sun-and-moon > .sun-beams {
    transform: rotateZ(5deg) !important;
}

[data-bs-theme="light"] .theme-toggle .sun-and-moon > .sun {
    transform: scale(1) !important;
    fill: #ffa500 !important; /* Orange for light mode */
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

[data-bs-theme="light"] .theme-toggle .sun-and-moon > .sun-beams {
    opacity: 1 !important;
    transform: rotateZ(0deg) !important;
    stroke: #ffa500 !important; /* Orange for light mode */
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Light mode: moon mask circle is positioned outside, showing full sun with rays */
.theme-toggle .sun-and-moon > .moon > circle {
    transform: translateX(0);
}

html[data-bs-theme="light"] .theme-toggle .sun-and-moon > .moon > circle {
    transform: translateX(0) !important;
}

/* Dark mode: moon mask circle moves to create proper crescent moon effect */
[data-bs-theme="dark"] .theme-toggle .sun-and-moon > .moon > circle {
    transform: translateX(-12px);
}

/* Smooth animations for theme transitions */
@media (prefers-reduced-motion: no-preference) {
    .theme-toggle .sun-and-moon > .sun {
        transition: transform .5s cubic-bezier(.5, 1.25, .75, 1.25);
    }

    .theme-toggle .sun-and-moon > .sun-beams {
        transition: 
            transform .5s cubic-bezier(.5, 1.5, .75, 1.25),
            opacity .5s cubic-bezier(.25, 0, .3, 1);
    }

    .theme-toggle .sun-and-moon .moon > circle {
        transition: transform .25s cubic-bezier(.5, 0, .75, 0);
    }

    [data-bs-theme="dark"] .theme-toggle .sun-and-moon > .sun {
        transition-timing-function: cubic-bezier(.25, 0, .3, 1);
        transition-duration: .25s;
    }

    [data-bs-theme="dark"] .theme-toggle .sun-and-moon > .sun-beams {
        transition-duration: .15s;
    }

    [data-bs-theme="dark"] .theme-toggle .sun-and-moon > .moon > circle {
        transition-delay: .25s;
        transition-duration: .5s;
    }
}

/* =========================
   6. Blog Content & Typography
   ========================= */
.blog-content {
    font-size: 1.1rem;
    line-height: 1.7;
}

.blog-content h1,
.blog-content h2,
.blog-content h3,
.blog-content h4,
.blog-content h5,
.blog-content h6 {
    margin-top: 2rem;
    margin-bottom: 1rem;
}

.blog-content p {
    margin-bottom: 1.5rem;
}

.blog-content img {
    max-width: 100%;
    height: auto;
    border-radius: var(--bs-border-radius-lg, 0.5rem);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    margin: 1.5rem 0;
}

.blog-content blockquote {
    border-left: 4px solid var(--bs-primary, #007bff);
    padding: 1rem;
    margin: 1.5rem 0;
    font-style: italic;
    background-color: var(--bs-light, #f8f9fa);
    border-radius: 0 var(--bs-border-radius-lg, 0.5rem) var(--bs-border-radius-lg, 0.5rem) 0;
}

[data-bs-theme="dark"] .blog-content blockquote {
    background-color: var(--bs-secondary-bg);
    color: var(--bs-body-color);
    border-left-color: var(--bs-warning);
}

/* Inline code styling */
p:has(code) {
    background-color: var(--bs-gray-200, #e9ecef);
    border: 1px solid var(--bs-gray-400, #ced4da);
    padding: 0.5rem;
    margin-left: 1rem;
    border-radius: var(--bs-border-radius, 0.375rem);
}

[data-bs-theme="dark"] p:has(code) {
    background-color: var(--bs-secondary-bg);
    color: var(--bs-body-color);
    border: 1px solid var(--bs-border-color);
}

p > code {
    color: var(--bs-body-color);
}

[data-bs-theme="dark"] p > code {
    color: #dc3545 !important; /* Bootstrap danger color for emphasis */
}

/* YouTube Embeds */
.youtube-embed {
    position: relative;
    width: 100%;
    margin: 2rem 0;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
    transition: box-shadow 0.3s ease;
}

.youtube-embed:hover {
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}

[data-bs-theme="dark"] .youtube-embed {
    box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -1px rgba(0, 0, 0, 0.2);
}

[data-bs-theme="dark"] .youtube-embed:hover {
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.4), 0 4px 6px -2px rgba(0, 0, 0, 0.3);
}

/* =========================
   7. Code Blocks & Copy Functionality
   ========================= */
.blog-content pre,
.code-block {
    position: relative;
    margin: 1.5rem 0;
    padding: 1rem 80px 1rem 1rem !important;
    overflow-x: auto;
    border-radius: var(--bs-border-radius-lg, 0.5rem);
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
    border-left: 4px solid var(--bs-warning);
}

/* Light theme code blocks */
[data-bs-theme="light"] .blog-content pre,
[data-bs-theme="light"] .code-block {
    background-color: var(--bs-gray-200);
    color: var(--bs-gray-900, #212529);
    border: 1px solid var(--bs-gray-400);
}

/* Dark theme code blocks */
[data-bs-theme="dark"] .blog-content pre,
[data-bs-theme="dark"] .code-block {
    background-color: #1e1e1e;
    color: var(--bs-gray-200, #f8f9fa);
    border: 1px solid var(--bs-border-color);
}

.blog-content pre code {
    font-family: 'Consolas', 'Monaco', 'Courier New', monospace;
    font-size: 0.875rem;
    line-height: 1.5;
    background: transparent !important;
    color: inherit;
}

/* Code copy button */
.code-copy-btn {
    position: absolute;
    top: 8px;
    right: 8px;
    z-index: var(--z-copy-button);
    font-size: 0.75rem;
    padding: 0.25rem 0.5rem;
    border-radius: var(--bs-border-radius-sm, 0.25rem);
    transition: all 0.2s ease-in-out;
    opacity: 0.8;
    border: 1px solid;
    background: transparent;
}

.code-copy-btn:hover {
    opacity: 1;
    transform: translateY(-1px);
}

/* Light theme copy button */
[data-bs-theme="light"] .code-copy-btn {
    color: var(--bs-gray-900);
    border-color: var(--bs-gray-700);
}

[data-bs-theme="light"] .code-copy-btn:hover {
    color: var(--bs-gray-100);
    background-color: var(--bs-gray-900);

}

/* Dark theme copy button */
[data-bs-theme="dark"] .code-copy-btn {
    color: var(--brand-warning);
    border-color: var(--brand-warning);
}

[data-bs-theme="dark"] .code-copy-btn:hover {
    color: #000;
    background-color: var(--brand-warning);
}

/* Copy button states */
.code-copy-btn.success {
    color: #fff !important;
    background-color: var(--bs-success, #198754) !important;
    border-color: var(--bs-success, #198754) !important;
}

.code-copy-btn.error {
    color: #fff !important;
    background-color: var(--bs-danger, #dc3545) !important;
    border-color: var(--bs-danger, #dc3545) !important;
}

/* =========================
   8. Forms & Input Components
   ========================= */
.form-floating > .form-control::placeholder,
.form-floating > .form-control-plaintext::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control:focus::placeholder,
.form-floating > .form-control-plaintext:focus::placeholder {
    text-align: start;
}

[data-bs-theme="dark"] .form-floating > .form-control,
[data-bs-theme="dark"] .form-floating > textarea.form-control {
    background-color: var(--bs-secondary-bg) !important;
    color: var(--bs-body-color) !important;
    border-color: var(--bs-border-color) !important;
    caret-color: var(--bs-body-color) !important;
}

/* Form validation */
.valid.modified:not([type=checkbox]) {
    outline: 1px solid var(--bs-success, #198754);
}

.invalid {
    outline: 1px solid var(--bs-danger, #dc3545);
}

.validation-message {
    color: var(--bs-danger, #dc3545);
}

.darker-border-checkbox.form-check-input {
    border-color: var(--bs-gray-500, #adb5bd);
}

/* =========================
   9. Cards & Content Containers
   ========================= */
.fixed-height-card {
    height: 400px;
}

.fixed-height-card .card-body {
    height: calc(100% - 60px);
}

.fixed-height-card .card-text {
    max-height: 190px;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 6;
    line-clamp: 6;
    -webkit-box-orient: vertical;
}

.fixed-height-card .card-title {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* =========================
   10. Utility & Helper Classes
   ========================= */
/* Brand-specific classes */
.idguy-badge {
    height: 500px;
    background-image: url("/img/IdGuys/IdGuysLogo-white.png");
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}

[data-bs-theme="dark"] .idguy-badge {
    background-image: url("/img/IdGuys/IdGuysLogo-white.png");
}

/* Organization tree highlighting */
.org-tree .bg-warning-subtle {
    background-color: #fff3cd !important;
    color: #664d03 !important;
}

[data-bs-theme="dark"] .org-tree .bg-warning-subtle {
    background-color: #665c00 !important;
    color: #fffbe6 !important;
}

/* Preview content styling */
[data-bs-theme="dark"] .preview-content,
[data-bs-theme="dark"] #preview-container {
    background-color: var(--bs-secondary-bg) !important;
    color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .preview-content a {
    color: #6ec1ff !important;
}

[data-bs-theme="dark"] .preview-content code {
    background-color: #23272b !important;
    color: #ffe484 !important;
}

/* Error boundary (Blazor) */
.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

.blazor-error-boundary::after {
    content: "An error has occurred.";
}

/* =========================
   11. Responsive Design
   ========================= */
/* Mobile adjustments for code blocks and copy buttons */
@media (max-width: 768px) {
    .blog-content pre,
    .code-block {
        padding-right: 60px !important;
    }
    
    .code-copy-btn {
        font-size: 0.7rem;
        padding: 0.2rem 0.4rem;
        right: 6px;
        top: 6px;
    }
}

/* Hide navigation indicator on mobile */
@media (max-width: 991.98px) {
    .nav-indicator {
        display: none !important;
    }
    
    #main-navbar .nav-link.active,
    #main-navbar .navbar-nav .nav-link.active,
    .navbar-nav .nav-link.active {
        border-bottom: none !important;
        box-shadow: none !important;
    }
}

/* Touch device adjustments */
@media (hover: none) {
    .theme-toggle {
        --size: 48px;
    }
}

/* Reduced motion preferences */
@media (prefers-reduced-motion: no-preference) {
    .theme-toggle .sun-and-moon > .sun {
        transition: transform 0.5s cubic-bezier(0.5, 1.25, 0.75, 1.25);
    }

    .theme-toggle .sun-and-moon > .sun-beams {
        transition: 
            transform 0.5s cubic-bezier(0.5, 1.5, 0.75, 1.25),
            opacity 0.5s cubic-bezier(0.25, 0, 0.3, 1);
    }

    .theme-toggle .sun-and-moon .moon circle {
        transition: transform 0.25s cubic-bezier(0.5, 0, 0.75, 0);
        transform: translateX(-50px); /* Hide the mask circle by default */
    }

    [data-bs-theme="dark"] .theme-toggle .sun-and-moon > .sun {
        transition-timing-function: cubic-bezier(0.25, 0, 0.3, 1);
        transition-duration: 0.25s;
    }

    [data-bs-theme="dark"] .sun-and-moon > .sun-beams {
        transition-duration: 0.15s;
    }

    [data-bs-theme="dark"] .sun-and-moon > .moon > circle {
        transition-delay: 0.25s;
        transition-duration: 0.5s;
    }
}

/* =========================
   12. Additional Utility Classes
   ========================= */
/* Multi-line text truncation utility */
.text-truncate-multiline {
    display: -webkit-box;
    -webkit-line-clamp: 4;
    line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* =========================
   Footer Icon Hover Effects
   ========================= */
footer .nav a {
    transition: all 0.3s ease;
}

footer .nav a:hover {
    transform: translateY(-2px);
}

/* Light mode - black hover */
[data-bs-theme="light"] footer .nav a:hover .bi {
    color: #000000 !important;
}

/* Dark mode - white hover */
[data-bs-theme="dark"] footer .nav a:hover .bi {
    color: #ffffff !important;
}
