@font-face {
    font-family: 'Lexend';
    src: url('../fonts/Lexend/LexendVariable.ttf') format('truetype');
    font-weight: 100 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Baskerville';
    src: url('../fonts/librebaskerville/LibreBaskerville-Regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
}

@font-face {
    font-family: 'Libre Baskerville';
    src: url('../fonts/librebaskerville/LibreBaskerville-Bold.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
}

@font-face {
    font-family: 'Libre Baskerville';
    src: url('../fonts/librebaskerville/LibreBaskerville-Italic.ttf') format('truetype');
    font-weight: 400;
    font-style: italic;
}

@media (min-width: 1500px) {

    .container,
    .container-lg,
    .container-md,
    .container-sm,
    .container-xl,
    .container-xxl {
        max-width: 1420px;
    }
}

@media (min-width: 1600px) {

    .container,
    .container-lg,
    .container-md,
    .container-sm,
    .container-xl,
    .container-xxl {
        max-width: 1520px;
    }
}

@media (min-width: 1700px) {

    .container,
    .container-lg,
    .container-md,
    .container-sm,
    .container-xl,
    .container-xxl {
        max-width: 1620px;
    }
}

@media (min-width: 576px) {
    .card-group>.card {
        margin-bottom: 0;
    }
}

:root {
    --bs-body-bg: #FAF9F5;
    --bs-dark-bg: #000;
    --bs-dark-text: #fff;
    --bs-body-color: #212529;
    --bs-secondary-bg: #ffffff;
    --bs-tertiary-bg: #f5f4ed;
    --bs-border-color: #e0ded5;
    --bs-link-color: #0056b3;
    --bs-link-hover-color: #003d82;
    --bs-code-color: #e91e63;
    --bs-primary: #0056b3;
    --bs-primary-bg-subtle: #e8f0f8;
    --bs-secondary-bg-subtle: #f5f5f5;
    --bs-success-bg-subtle: #e8f5e9;
    --bs-info-bg-subtle: #e8f0f8;
    --bs-warning-bg-subtle: #fff8e1;
    --bs-danger-bg-subtle: #ffebee;
    --bs-light-bg-subtle: #fafafa;
    --bs-dark-bg-subtle: #f0f0f0;
    --bs-primary-border-subtle: #b8d4e8;
    --bs-secondary-border-subtle: #e0e0e0;
    --bs-success-border-subtle: #c8e6c9;
    --bs-info-border-subtle: #b8d4e8;
    --bs-warning-border-subtle: #ffe0a0;
    --bs-danger-border-subtle: #f5c6cb;
    --bs-light-border-subtle: #e8e8e8;
    --bs-dark-border-subtle: #d0d0d0;
    --bs-primary-text-emphasis: #003d82;
    --bs-secondary-text-emphasis: #41464b;
    --bs-success-text-emphasis: #0f5132;
    --bs-info-text-emphasis: #003d82;
    --bs-warning-text-emphasis: #664d03;
    --bs-danger-text-emphasis: #842029;
    --bs-light-text-emphasis: #495057;
    --bs-dark-text-emphasis: #1a1e21;
}

[data-bs-theme="light"] .milkdown-theme-frame .milkdown {
    --crepe-color-background: var(--bs-body-bg) !important;
    --crepe-color-on-background: var(--bs-body-color) !important;
    --crepe-color-surface: var(--bs-tertiary-bg) !important;
    --crepe-color-surface-low: var(--bs-tertiary-bg) !important;
    --crepe-color-on-surface: var(--bs-body-color) !important;
    --crepe-color-on-surface-variant: var(--bs-secondary-color) !important;
    --crepe-color-outline: var(--bs-secondary-color) !important;
    --crepe-color-primary: var(--bs-body-color) !important;
    --crepe-color-secondary: var(--bs-border-color) !important;
    --crepe-color-on-secondary: var(--bs-secondary-color) !important;
    --crepe-color-inverse: var(--bs-tertiary-bg) !important;
    --crepe-color-on-inverse: var(--bs-body-color) !important;
    --crepe-color-inline-code: var(--bs-code-color) !important;
    --crepe-color-error: var(--bs-danger-text-emphasis) !important;
    --crepe-color-hover: var(--bs-tertiary-bg) !important;
    --crepe-color-selected: var(--bs-border-color) !important;
    --crepe-color-inline-area: var(--bs-border-color) !important;
    --crepe-font-title: "Libre Baskerville", Cambria, "Times New Roman", Times, serif !important;
    --crepe-font-default: "Lexend", Arial, Helvetica, sans-serif !important;
    --crepe-font-code: "Courier New", Courier, monospace !important;
    --crepe-shadow-1: var(--bs-box-shadow) !important;
    --crepe-shadow-2: var(--bs-box-shadow) !important;
}

[data-bs-theme="light"] form .milkdown-theme-frame .milkdown {
    --crepe-color-background: var(--bs-secondary-bg) !important;
}


[data-bs-theme="dark"] {
    --bs-body-bg: rgb(9, 9, 11);
    --bs-dark-bg: #fff;
    --bs-dark-text: #000;
    --bs-body-color: rgb(158, 158, 158);
    --bs-secondary-bg: rgb(9, 9, 11);
    --bs-tertiary-bg: rgb(6, 6, 7);
    --bs-border-color: rgb(38 38 43);
    --bs-border-color-translucent: rgba(38, 38, 43, 0.8);
    --bs-link-color: #6ea8fe;
    --bs-link-hover-color: #9ec5fe;
    --bs-code-color: #f472b6;
    --bs-primary: #6ea8fe;
    --bs-emphasis-color: #d2d2d2;
    --bs-heading-color: #d2d2d2;
    --bs-secondary-color: #a0a0a0;
    --bs-tertiary-color: #707070;
    --bs-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.5);
    --bs-primary-bg-subtle: #0b1320;
    --bs-secondary-bg-subtle: #1f1f1f;
    --bs-success-bg-subtle: rgb(10, 27, 23);
    --bs-info-bg-subtle: #0b1320;
    --bs-warning-bg-subtle: #1e1a0d;
    --bs-danger-bg-subtle: #181010;
    --bs-light-bg-subtle: #1a1a1a;
    --bs-dark-bg-subtle: #252525;
    --bs-primary-border-subtle: #2a3a52;
    --bs-secondary-border-subtle: #3a3a3a;
    --bs-success-border-subtle: rgba(16, 185, 129, 0.3);
    --bs-info-border-subtle: #1e2734;
    --bs-warning-border-subtle: #343022;
    --bs-danger-border-subtle: #2e1b1b;
    --bs-light-border-subtle: #2a2a2a;
    --bs-dark-border-subtle: #3a3a3a;
    --bs-primary-text-emphasis: #9ec5fe;
    --bs-secondary-text-emphasis: #a7acb1;
    --bs-success-text-emphasis: rgb(162, 236, 201);
    --bs-info-text-emphasis: #9ec5fe;
    --bs-warning-text-emphasis: #ffda6a;
    --bs-danger-text-emphasis: #ea868f;
    --bs-light-text-emphasis: #f8f9fa;
    --bs-dark-text-emphasis: #dee2e6;
}

[data-bs-theme="dark"] .milkdown-theme-frame .milkdown {
    --crepe-color-background: var(--bs-body-bg) !important;
    --crepe-color-on-background: var(--bs-body-color) !important;
    --crepe-color-surface: var(--bs-tertiary-bg) !important;
    --crepe-color-surface-low: var(--bs-tertiary-bg) !important;
    --crepe-color-on-surface: var(--bs-body-color) !important;
    --crepe-color-on-surface-variant: var(--bs-secondary-color) !important;
    --crepe-color-outline: var(--bs-secondary-color) !important;
    --crepe-color-primary: var(--bs-body-color) !important;
    --crepe-color-secondary: var(--bs-border-color) !important;
    --crepe-color-on-secondary: var(--bs-secondary-color) !important;
    --crepe-color-inverse: var(--bs-tertiary-bg) !important;
    --crepe-color-on-inverse: var(--bs-body-color) !important;
    --crepe-color-inline-code: var(--bs-code-color) !important;
    --crepe-color-error: var(--bs-danger-text-emphasis) !important;
    --crepe-color-hover: var(--bs-tertiary-bg) !important;
    --crepe-color-selected: var(--bs-border-color) !important;
    --crepe-color-inline-area: var(--bs-tertiary-bg) !important;
    --crepe-font-title: "Libre Baskerville", Cambria, "Times New Roman", Times, serif !important;
    --crepe-font-default: "Lexend", Arial, Helvetica, sans-serif !important;
    --crepe-font-code: "Courier New", Courier, monospace !important;
    --crepe-shadow-1: var(--bs-box-shadow) !important;
    --crepe-shadow-2: var(--bs-box-shadow) !important;
}

[data-bs-theme="dark"] .btn-primary, [data-bs-theme="light"] .btn-primary {
  --bs-btn-bg: #325d9c;
  --bs-btn-border-color: #325d9c;
  --bs-btn-hover-bg: #274b7a;
  --bs-btn-hover-border-color: #274b7a;
}



/* Firefox scrollbar styling */
* {
    scrollbar-width: thin;
    scrollbar-color: var(--bs-border-color) transparent;
}

body {
    font-family: 'Lexend', sans-serif;
    font-size: 0.875rem;
}

.offcanvas-body {
    min-height: 400px;
}

/* CodeMirror word wrap */
.cm-editor .cm-scroller {
    overflow-x: hidden !important;
}

.cm-editor .cm-content,
.cm-editor .cm-line {
    white-space: pre-wrap !important;
    word-wrap: break-word !important;
    word-break: break-all !important;
    overflow-wrap: break-word !important;
    max-width: 100% !important;
}

.codemirror-host {
    overflow-x: hidden !important;
    max-width: 100% !important;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: 'Libre Baskerville', serif;
    font-weight: 600;
}

h1 {
    font-size: 1.5rem !important;
}

h2 {
    font-size: 1.375rem !important;
}

h3 {
    font-size: 1.25rem !important;
}

h4 {
    font-size: 1.125rem !important;
}

h5 {
    font-size: 1rem !important;
}

h6 {
    font-size: 0.875rem !important;
}

.milkdown strong {
    color: var(--bs-emphasis-color);
}

footer {
    padding: 2rem 0;
}

footer .footer-copyright {
    border-top: 1px solid var(--bs-border-color);
    padding-top: 1.5rem;
    font-size: 0.875rem;
}

/* Footer logos with background images */
.footer-logo {
    display: inline-block;
    height: 30px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    opacity: 0.7;
}

.footer-logo-lutece {
    width: 80px;
    background-image: url('../images/lutece.svg');
}

.footer-logo-multiwiki {
    width: 100px;
    background-image: url('../images/multiwiki.svg');
}

[data-bs-theme="dark"] .footer-logo-lutece {
    background-image: url('../images/lutece-dark.svg');
}

[data-bs-theme="dark"] .footer-logo-multiwiki {
    background-image: url('../images/multiwiki-dark.svg');
}

main {
    min-height: 78.7vh;
}

/* Sidebar sticky positioning */
.sticky-top {
    top: 20px !important;
    max-height: calc(100vh - 40px);
    overflow-y: auto;
}

/* Breadcrumb styling - normal text style */
.breadcrumb {
    background-color: transparent;
    padding: 0.5rem 0;
}

.breadcrumb-item {
    font-size: 0.875rem;
}

.breadcrumb-item a {
    color: var(--bs-secondary-color);
    text-decoration: none;
}

.breadcrumb-item a:hover {
    color: var(--bs-link-color);
    text-decoration: underline;
}

.breadcrumb-item.active {
    color: var(--bs-body-color);
    font-weight: 500;
}

.breadcrumb-item+.breadcrumb-item::before {
    color: var(--bs-secondary-color);
    content: "/";
    padding: 0 0.5rem;
}

/* Button style matching breadcrumb items */
.btn {
    border-radius: 20px;
    padding: 0.45rem 1rem;
    font-size: 0.875rem;
    text-decoration: none !important;
    transition: all 0.3s ease;
    font-family: 'Lexend', sans-serif;
    corner-shape: squircle
}

.btn-sm,
.btn-group-sm > .btn {
    padding: 0.2rem 0.8rem;
    font-size: 0.875rem;
    line-height: 1.4rem;
    border-radius: 15px;
}

.btn-light {
    background-color: var(--bs-secondary-bg);
    color: var(--bs-body-color);
    border: 1px solid var(--bs-border-color);
}

.btn-dark {
    background-color: var(--bs-dark-bg);
    color: var(--bs-dark-text);
    border: 1px solid var(--bs-dark-bg);
}

.btn-outline-dark,
.btn-outline-secondary,
.btn-secondary {
    background-color: var(--bs-body-bg);
    color: var(--bs-body-color);
    border: 1px solid var(--bs-border-color);
}

.btn:hover {
    box-shadow: none;
}

/* Remove list markers from li elements used outside of lists */
.d-flex li {
    list-style: none;
    list-style-type: none;
}

/* Specific style for login area in header */
.navbar .d-flex li {
    list-style: none;
    list-style-type: none;
    display: inline-block;
    margin: 0 0.25rem;
}

header .btn,
.card-header .btn,
.list-group-item .btn,
.alert .btn,
.offcanvas-body .btn
{
    padding: 0.2rem 0.8rem;
    line-height: 1.4rem;
}

.wiki-book-actions .btn, .wiki-category-actions .btn, .wiki-page-actions .btn, .wiki-chapter-actions .btn, .wiki-space-actions .btn {
    padding: 0.2rem;
    font-size: 0.75rem;
    line-height: 1.2rem;
}

/* List group styles matching the overall vibe */
.list-group {
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid var(--bs-border-color);
    background-color: transparent;
}

.list-group-item {
    background-color: var(--bs-secondary-bg);
    border: none;
    border-bottom: 1px solid var(--bs-border-color);
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    color: var(--bs-body-color);
    transition: all 0.3s ease;
}

.list-group-item:first-child {
    border-top-left-radius: 20px;
    border-top-right-radius: 20px;
}

.list-group-item:last-child {
    border-bottom-left-radius: 20px;
    border-bottom-right-radius: 20px;
    border-bottom: none;
}

.list-group-item:hover {
    background-color: var(--bs-tertiary-bg);
}

.list-group-item.active {
    background-color: var(--bs-secondary-bg);
    color: var(--bs-body-color);
    border-color: var(--bs-border-color);
    font-weight: 600;
}

.list-group-item.active:hover {
    background-color: var(--bs-border-color);
    color: var(--bs-body-color);
}

.list-group-item-action,
.wiki-page-link:hover {
    color: var(--bs-emphasis-color);
    text-decoration: none;
}

.list-group-item-action:hover {
    color: var(--bs-link-color);
    text-decoration: none;
}

.card {
    background-color: var(--bs-secondary-bg);
    border-radius: 20px;
    border: 1px solid var(--bs-border-color);
    box-shadow: none;
    transition: all 0.3s ease;
    overflow: hidden;
}

.card-space:hover {
    border-color: var(--bs-emphasis-color);
}

.card-header {
    background-color: var(--bs-tertiary-bg);
}

.card-body {
    padding: 1rem;
}

.card-title {
    font-size: 1.125rem;
    font-weight: 600;
    margin-bottom: 0.75rem;
    color: var(--bs-body-color);
}

.card-space .card-title {
    font-family: 'Lexend', sans-serif;
    margin: 0;
}

.card-space .card-body {
    padding: 1.5rem;
}

/* Dropdown styles matching cards */
.dropdown-menu {
    background-color: var(--bs-body-bg);
    border-radius: 20px;
    border: 1px solid var(--bs-border-color);
    box-shadow: var(--bs-box-shadow);
    padding: 0;
    overflow: hidden;
}

.dropdown-item {
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    color: var(--bs-body-color);
    transition: all 0.2s ease;
}

.dropdown-item:hover,
.dropdown-item:focus {
    background-color: var(--bs-tertiary-bg);
    color: var(--bs-body-color);
}

.dropdown-item:active {
    background-color: var(--bs-primary);
    color: var(--bs-white);
}

.dropdown-divider {
    border-color: var(--bs-border-color);
    margin: 0.5rem 0;
}

.card-text {
    color: var(--bs-body-color);
    font-size: 0.875rem;
}

/* Input and form control styles matching the overall vibe */
.form-control,
.form-select,
#editor-container,
input[type="text"],
textarea,
select {
    background-color: var(--bs-secondary-bg);
    border-radius: 20px;
    border: 1px solid var(--bs-border-color);
    padding: 0.375rem 1rem;
    font-size: 0.875rem;
    color: var(--bs-body-color);
    transition: all 0.3s ease;
}

.form-select {
    padding-right: 2.5rem;
}

/* Search bar */
.input-search {
    border-radius: 50px;
    overflow: hidden;
    border: 1px solid var(--bs-border-color);
    background-color: var(--bs-secondary-bg);
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
}

.input-search:focus-within {
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.15);
}

.input-search .form-control {
    border: none;
    background: transparent;
    border-radius: 0;
    padding: 0.35rem 1rem;
    font-size: 0.875rem;
}

.input-search .form-control:focus {
    box-shadow: none;
    border: none;
    background: transparent;
}

.input-search .btn {
    border: none;
    border-radius: 0;
    padding: 0.35rem 1rem;
    font-size: 0.875rem;
}

.input-search.input-group-lg .form-control {
    padding: 0.6rem 1.5rem;
    font-size: 1rem;
}

.input-search.input-group-lg .btn {
    padding: 0.6rem 1.25rem;
    font-size: 1.1rem;
}

#editor-container .milkdown {
    background-color: var(--bs-secondary-bg);
}

.form-control:focus,
.form-select:focus,
input:focus,
textarea:focus,
select:focus {
    background-color: var(--bs-secondary-bg);
    border-color: var(--bs-primary);
    box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.25);
    outline: none;
}

.form-control:hover,
.form-select:hover,
input:hover,
textarea:hover,
select:hover {
    background-color: var(--bs-secondary-bg);
    border-color: var(--bs-border-color);
}

.form-control::placeholder,
input::placeholder,
textarea::placeholder {
    color: var(--bs-tertiary-color);
    font-size: 0.875rem;
}

.form-control:disabled,
.form-select:disabled,
input:disabled,
textarea:disabled,
select:disabled {
    background-color: var(--bs-tertiary-bg);
    border-color: var(--bs-border-color);
    cursor: not-allowed;
    opacity: 0.6;
}

.form-label,
label {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--bs-body-color);
    margin-bottom: 0.25rem;
}

.form-check-input {
    width: 1.25rem;
    height: 1.25rem;
    border-radius: 10px;
    border: 1px solid var(--bs-border-color);
    background-color: var(--bs-body-bg);
    transition: all 0.3s ease;
}

.form-check-input:checked {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
}

.form-check-input:focus {
    box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.25);
    border-color: var(--bs-primary);
}

/* Alert styles with GitHub-style icons */
.alert {
    border-radius: 20px;
    border: 1px solid;
    padding: 0.75rem 1rem 0.75rem 2.75rem;
    font-size: 0.875rem;
    position: relative;
    margin-bottom: 1rem;
}

/* Add icon as pseudo-element */
.alert::before {
    content: "";
    position: absolute;
    top: 0.8rem;
    left: 0.75rem;
    width: 1.25rem;
    height: 1.25rem;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    pointer-events: none;
}

.offcanvas-body .alert::before {
    display: none;
}

.offcanvas-body .alert {
    padding: 0.75rem 1rem;
}


.alert p,
.alert p:last-child {
    margin-bottom: 0;
}

/* Alert dismissible - add padding for close button */
.alert-dismissible {
    padding-right: 3rem;
}

.alert-dismissible .btn-close {
    padding: 0.25rem;
    top: 50%;
    right: 1rem;
    transform: translateY(-50%);
    font-size: 0.75rem;
}

/* INFO Alert - Cyan/Blue */
.alert-info {
    background-color: var(--bs-info-bg-subtle);
    border-color: var(--bs-info-border-subtle) !important;
    color: var(--bs-info-text-emphasis) !important;
}

.alert-warning {
    background-color: var(--bs-warning-bg-subtle);
    border-color: var(--bs-warning-border-subtle) !important;
    color: var(--bs-warning-text-emphasis) !important;
}

.alert-success {
    background-color: var(--bs-success-bg-subtle);
    border-color: var(--bs-success-border-subtle) !important;
    color: var(--bs-success-text-emphasis) !important;
}

.alert-danger {
    background-color: var(--bs-danger-bg-subtle);
    border-color: var(--bs-danger-border-subtle) !important;
    color: var(--bs-danger-text-emphasis) !important;
}

/* Reset Milkdown default blockquote::before for alerts */
.milkdown .ProseMirror blockquote:before,
.milkdown .ProseMirror blockquote.alert::before {
    content: "" !important;
    position: absolute !important;
    top: 1rem !important;
    left: 0.75rem !important;
    bottom: auto !important;
    width: 1.25rem !important;
    height: 1.25rem !important;
    background-color: transparent !important;
    background-size: contain !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    border-radius: 0 !important;
}

/* Success/TIP - Lightbulb icon */
.alert-success::before,
.milkdown .ProseMirror blockquote.alert-success::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%230f5132' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M3 12h1m8 -9v1m8 8h1m-15.4 -6.4l.7 .7m12.1 -.7l-.7 .7' /%3E%3Cpath d='M9 16a5 5 0 1 1 6 0a3.5 3.5 0 0 0 -1 3a2 2 0 0 1 -4 0a3.5 3.5 0 0 0 -1 -3' /%3E%3Cpath d='M9.7 17l4.6 0' /%3E%3C/svg%3E");
}

/* Info/NOTE - Info circle icon */
.alert-info::before,
.milkdown .ProseMirror blockquote.alert-info::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23003d82' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M3 12a9 9 0 1 0 18 0a9 9 0 0 0 -18 0' /%3E%3Cpath d='M12 9h.01' /%3E%3Cpath d='M11 12h1v4h1' /%3E%3C/svg%3E");
}

/* Warning - Info circle icon */
.alert-warning::before,
.milkdown .ProseMirror blockquote.alert-warning::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23664d03' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M3 12a9 9 0 1 0 18 0a9 9 0 0 0 -18 0' /%3E%3Cpath d='M12 9h.01' /%3E%3Cpath d='M11 12h1v4h1' /%3E%3C/svg%3E");
}

/* Danger/CAUTION - Info circle icon */
.alert-danger::before,
.milkdown .ProseMirror blockquote.alert-danger::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23842029' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M3 12a9 9 0 1 0 18 0a9 9 0 0 0 -18 0' /%3E%3Cpath d='M12 9h.01' /%3E%3Cpath d='M11 12h1v4h1' /%3E%3C/svg%3E");
}

/* Light - Info circle icon */
.alert-light::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%236c757d' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M3 12a9 9 0 1 0 18 0a9 9 0 0 0 -18 0' /%3E%3Cpath d='M12 9h.01' /%3E%3Cpath d='M11 12h1v4h1' /%3E%3C/svg%3E");
}

/* Dark theme icons */
[data-bs-theme="dark"] .alert-success::before,
[data-bs-theme="dark"] .milkdown .ProseMirror blockquote.alert-success::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2375b798' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M3 12h1m8 -9v1m8 8h1m-15.4 -6.4l.7 .7m12.1 -.7l-.7 .7' /%3E%3Cpath d='M9 16a5 5 0 1 1 6 0a3.5 3.5 0 0 0 -1 3a2 2 0 0 1 -4 0a3.5 3.5 0 0 0 -1 -3' /%3E%3Cpath d='M9.7 17l4.6 0' /%3E%3C/svg%3E");
}

[data-bs-theme="dark"] .alert-info::before,
[data-bs-theme="dark"] .milkdown .ProseMirror blockquote.alert-info::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%239ec5fe' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M3 12a9 9 0 1 0 18 0a9 9 0 0 0 -18 0' /%3E%3Cpath d='M12 9h.01' /%3E%3Cpath d='M11 12h1v4h1' /%3E%3C/svg%3E");
}

[data-bs-theme="dark"] .alert-warning::before,
[data-bs-theme="dark"] .milkdown .ProseMirror blockquote.alert-warning::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23ffda6a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M3 12a9 9 0 1 0 18 0a9 9 0 0 0 -18 0' /%3E%3Cpath d='M12 9h.01' /%3E%3Cpath d='M11 12h1v4h1' /%3E%3C/svg%3E");
}

[data-bs-theme="dark"] .alert-danger::before,
[data-bs-theme="dark"] .milkdown .ProseMirror blockquote.alert-danger::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23ea868f' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M3 12a9 9 0 1 0 18 0a9 9 0 0 0 -18 0' /%3E%3Cpath d='M12 9h.01' /%3E%3Cpath d='M11 12h1v4h1' /%3E%3C/svg%3E");
}

[data-bs-theme="dark"] .alert-light::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23adb5bd' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath stroke='none' d='M0 0h24v24H0z' fill='none'/%3E%3Cpath d='M3 12a9 9 0 1 0 18 0a9 9 0 0 0 -18 0' /%3E%3Cpath d='M12 9h.01' /%3E%3Cpath d='M11 12h1v4h1' /%3E%3C/svg%3E");
}

/* Code and pre elements matching the overall vibe */
code {
    background-color: var(--bs-tertiary-bg);
    color: var(--bs-code-color);
    padding: 0.125rem 0.375rem;
    border-radius: 10px;
    font-size: 0.875rem;
    font-family: 'Courier New', Courier, monospace;
    border: 1px solid var(--bs-border-color);
    word-wrap: break-word;
    word-break: break-all;
    white-space: normal;
    overflow-wrap: break-word;
}

/* Sidebar navigation with dot indicator - Wiki pages */
.wiki-page-list {
    position: relative;
    border-left: 1px solid var(--bs-border-color);
    margin-left: 0.75rem;
    padding-left: 0;
}

.wiki-page-item {
    margin: 0.25rem 0;
    position: relative;
}

.wiki-page-link {
    position: relative;
    display: block;
    padding: 0.375rem 0.75rem;
    padding-left: 1.25rem;
    font-size: 0.875rem;
    color: var(--bs-secondary-color);
    text-decoration: none;
    transition: all 0.2s ease;
}

.wiki-page-link::before {
    content: '';
    position: absolute;
    left: -4px;
    top: 50%;
    transform: translateY(-50%);
    width: 7px;
    height: 7px;
    border-radius: 50%;
    transition: all 0.2s ease;
    z-index: 1;
}

.wiki-page-link:hover::before {
    background-color: var(--bs-secondary-color);
    border: 1px solid var(--bs-secondary-color);
}

/* Active page indicator with blue dot */
.wiki-page-link.active {
    color: var(--bs-link-color);
    font-weight: 500;
}

.wiki-page-link.active::before,
.wiki-page-link.active:hover::before {
    background-color: var(--bs-link-color);
    border: 1px solid var(--bs-link-color);
}

.wiki-page-link.active:hover {
    color: var(--bs-link-color);
}

.text-primary {
    --bs-text-opacity: 1;
    color: var(--bs-link-color) !important;
}

/* Wiki Hero Section - Solid background */
.wiki-hero-section {
    border-radius: 3rem;
    position: relative;
    overflow: hidden;
}

.wiki-hero-title h1 {
    font-family: 'Libre Baskerville', serif;
    font-weight: 600;
    font-size: 2rem !important;
    color: var(--bs-emphasis-color);
}

.bg-primary {
    background: linear-gradient(135deg, rgb(0, 86, 179) 0%, rgb(0, 61, 130) 100%);
}

.badge {
    border-radius: 5rem;
    padding: 0.4em 0.8em;
    font-size: 0.8rem;
}

.table .badge {
    white-space: normal;
    text-align: left;
}

.navbar {
    background-color: var(--bs-body-bg);
}

/* Theme Switch */
.switch {
    display: block;
    --width-of-switch: 3.5em;
    --height-of-switch: 2.1em;
    --size-of-icon: 1.4em;
    --slider-offset: 0.3em;
    position: relative;
    width: var(--width-of-switch);
    height: var(--height-of-switch);
    margin: 0;
}

.switch input {
    opacity: 0;
    width: 0;
    height: 0;
}

.slider {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: var(--bs-secondary-bg);
    border: 1px solid var(--bs-border-color);
    transition: .4s;
    border-radius: 30px;
}

.slider:before {
    position: absolute;
    content: "";
    height: var(--size-of-icon, 1.4em);
    width: var(--size-of-icon, 1.4em);
    border-radius: 20px;
    left: var(--slider-offset, 0.3em);
    top: 50%;
    transform: translateY(-50%);
    background: linear-gradient(40deg, #ff0080, #ff8c00 70%);
    transition: .4s;
}

input:checked+.slider {
    background-color: #303136;
}

input:checked+.slider:before {
    left: calc(100% - (var(--size-of-icon, 1.4em) + var(--slider-offset, 0.3em)));
    background: #303136;
    box-shadow: inset -3px -2px 5px -2px #8983f7, inset -10px -4px 0 0 #a3dafb;
}

[data-bs-theme="dark"] .bg-light {
    background-color: #141414 !important;
}

[data-bs-theme="dark"] .bg-white {
    background-color: #000 !important;
}

[data-bs-theme="dark"] .text-dark {
    color: var(--bs-body-color) !important;
}

.table-responsive {
    border-radius: 20px;
    overflow-x: auto;
    border: 1px solid var(--bs-border-color);
}

table,
.table {
    background-color: var(--bs-body-bg);
    border-collapse: separate;
    border-spacing: 0;
    font-size: 0.875rem;
    margin-bottom: 0;
    width: 100%;
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid var(--bs-border-color);
}

table > tbody > tr > td,
table > thead > tr > th,
.table > tbody > tr > td,
.table > thead > tr > th {
    padding: 0.5rem 1rem;
    border: none;
    border-bottom: 1px solid var(--bs-border-color);
    border-right: 1px solid var(--bs-border-color);
    color: var(--bs-body-color);
}

table > tbody > tr > td,
.table > tbody > tr > td {
    background-color: var(--bs-secondary-bg);
}

table > thead > tr > th,
.table > thead > tr > th {
    background-color: var(--bs-tertiary-bg);
    font-weight: 600;
}

table > tbody > tr > td:last-child,
table > thead > tr > th:last-child,
.table > tbody > tr > td:last-child,
.table > thead > tr > th:last-child {
    border-right: none;
}

table > tbody > tr:last-child > td,
.table > tbody > tr:last-child > td {
    border-bottom: none;
}

table > tbody > tr,
.table > tbody > tr {
    transition: all 0.3s ease;
}

table > tbody > tr:hover > td,
.table-hover > tbody > tr:hover > td {
    background-color: var(--bs-tertiary-bg);
}

/* Pagination */
.pagination {
    border-radius: 10px;
    overflow: hidden;
}

.page-item .page-link {
    background-color: var(--bs-secondary-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 0 !important;
    color: var(--bs-body-color);
    font-size: 0.875rem;
    padding: 0.375rem 0.75rem;
    transition: all 0.2s ease;
    margin-left: -1px;
}

.page-item:first-child .page-link {
    border-top-left-radius: 10px !important;
    border-bottom-left-radius: 10px !important;
    margin-left: 0;
}

.page-item:last-child .page-link {
    border-top-right-radius: 10px !important;
    border-bottom-right-radius: 10px !important;
}

.page-item .page-link:hover {
    background-color: var(--bs-tertiary-bg);
    border-color: var(--bs-border-color);
    color: var(--bs-emphasis-color);
    z-index: 1;
}

.page-item.active .page-link {
    background-color: var(--bs-emphasis-color);
    border-color: var(--bs-emphasis-color);
    color: var(--bs-body-bg);
    z-index: 2;
}

.page-item.disabled .page-link {
    background-color: var(--bs-tertiary-bg);
    border-color: var(--bs-border-color);
    color: var(--bs-tertiary-color);
    opacity: 0.6;
}

/* Wiki page items at root level - no dot indicator */
ul.list-unstyled:not(.wiki-page-list) > .wiki-page-item .wiki-page-link {
    padding-left: 0.75rem;
}

ul.list-unstyled:not(.wiki-page-list) > .wiki-page-item .wiki-page-link::before {
    display: none;
}

/* Sidebar toggle button in header */
.navbar .container > [data-bs-target="#sidebarOffcanvas"] {
    margin: 0 1rem 0 0;
}

/* Hide elements on mobile */
@media (max-width: 991.98px) {
    .navbar a[href*="page=mydashboard"],
    .navbar .navbar-brand {
        display: none;
    }

    .offcanvas-lg {
        width: 100% !important;
        transform: none !important;
        opacity: 0;
        visibility: hidden;
        transition: opacity 0.25s ease, visibility 0.25s ease !important;
    }

    .offcanvas-lg.showing,
    .offcanvas-lg.show:not(.hiding) {
        opacity: 1;
        visibility: visible;
    }

    .offcanvas-backdrop {
        transition: opacity 0.25s ease !important;
    }
}