/* Enhanced Help Articles Styling - Bootstrap Documentation Style */

/* Base Typography and Layout - Bootstrap Documentation Style */
.help-article-container {
    max-width: 1140px;
    margin: 0 auto;
    padding: 0 15px;
}

.help-article-content {
    font-family: var(--bs-font-sans-serif);
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: var(--bs-body-color);
    text-align: left;
}

/* Bootstrap Documentation Style Headers */
.markdown-content h1 {
    font-size: calc(1.375rem + 1.5vw);
    font-weight: 500;
    line-height: 1.2;
    margin-top: 0;
    margin-bottom: 0.5rem;
    color: var(--bs-heading-color);
}

.markdown-content h2 {
    font-size: calc(1.325rem + 0.9vw);
    font-weight: 500;
    line-height: 1.2;
    margin-top: 0;
    margin-bottom: 0.5rem;
    color: var(--bs-heading-color);
    padding-top: 1rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--bs-border-color);
}

.markdown-content h3 {
    font-size: calc(1.3rem + 0.6vw);
    font-weight: 500;
    line-height: 1.2;
    margin-top: 0;
    margin-bottom: 0.5rem;
    color: var(--bs-heading-color);
}

.markdown-content h4 {
    font-size: calc(1.275rem + 0.3vw);
    font-weight: 500;
    line-height: 1.2;
    margin-top: 0;
    margin-bottom: 0.5rem;
    color: var(--bs-heading-color);
}

.markdown-content h5 {
    font-size: 1.25rem;
    font-weight: 500;
    line-height: 1.2;
    margin-top: 0;
    margin-bottom: 0.5rem;
    color: var(--bs-heading-color);
}

.markdown-content h6 {
    font-size: 1rem;
    font-weight: 500;
    line-height: 1.2;
    margin-top: 0;
    margin-bottom: 0.5rem;
    color: var(--bs-heading-color);
}

/* Bootstrap Documentation Style Paragraphs and Text */
.markdown-content p {
    margin-top: 0;
    margin-bottom: 1rem;
}

.markdown-content p:last-child {
    margin-bottom: 0;
}

/* Bootstrap Lead Text */
.markdown-content .lead {
    font-size: 1.25rem;
    font-weight: 300;
    margin-bottom: 1rem;
}

/* Bootstrap Documentation Style Lists */
.markdown-content ul,
.markdown-content ol {
    margin-top: 0;
    margin-bottom: 1rem;
    padding-left: 2rem;
}

.markdown-content li {
    margin-bottom: 0.25rem;
}

.markdown-content li>ul,
.markdown-content li>ol {
    margin-top: 0.25rem;
    margin-bottom: 0;
}

/* Bootstrap Documentation Style Code Blocks */
.markdown-content code {
    font-family: var(--bs-font-monospace);
    font-size: 0.875em;
    color: var(--bs-code-color);
    background-color: var(--bs-gray-100);
    padding: 0.125rem 0.25rem;
    border-radius: var(--bs-border-radius-sm);
    word-wrap: break-word;
}

.markdown-content pre {
    font-family: var(--bs-font-monospace);
    font-size: 0.875em;
    background-color: var(--bs-gray-100);
    border: 1px solid var(--bs-border-color);
    border-radius: var(--bs-border-radius);
    padding: 1rem;
    margin-top: 0;
    margin-bottom: 1rem;
    overflow-x: auto;
    line-height: 1.45;
}

.markdown-content pre code {
    background-color: transparent;
    color: inherit;
    padding: 0;
    border-radius: 0;
    word-wrap: normal;
}

/* Bootstrap Documentation Style Blockquotes */
.markdown-content blockquote {
    margin: 0 0 1rem;
    padding: 0.5rem 1rem;
    border-left: 0.25rem solid var(--bs-border-color-translucent);
    background-color: var(--bs-gray-100);
}

.markdown-content blockquote p {
    margin-bottom: 0;
}

.markdown-content blockquote cite {
    font-style: normal;
    font-weight: 600;
    color: var(--bs-secondary-color);
}

/* Bootstrap Documentation Style Tables */
.markdown-content table {
    width: 100%;
    margin-bottom: 1rem;
    color: var(--bs-body-color);
    vertical-align: top;
    border-color: var(--bs-border-color);
    caption-side: bottom;
    border-collapse: collapse;
    display: block;
    overflow-x: auto;
    white-space: nowrap;
    /* Force scrollbar to always be visible */
    scrollbar-width: thin;
    scrollbar-color: #adb5bd #f8f9fa;
}

/* Webkit scrollbar styling for Chrome/Safari/Edge */
.markdown-content table::-webkit-scrollbar {
    height: 12px;
}

.markdown-content table::-webkit-scrollbar-track {
    background: #f8f9fa;
    border-radius: 6px;
}

.markdown-content table::-webkit-scrollbar-thumb {
    background-color: #adb5bd;
    border-radius: 6px;
    border: 2px solid #f8f9fa;
}

.markdown-content table::-webkit-scrollbar-thumb:hover {
    background-color: #6c757d;
}

/* Also apply to help-article-content for consistency */
.help-article-content table {
    width: 100%;
    margin-bottom: 1rem;
    color: var(--bs-body-color);
    vertical-align: top;
    border-color: var(--bs-border-color);
    caption-side: bottom;
    border-collapse: collapse;
    display: block;
    overflow-x: auto;
    white-space: nowrap;
    /* Force scrollbar to always be visible */
    scrollbar-width: thin;
    scrollbar-color: #adb5bd #f8f9fa;
}

/* Webkit scrollbar styling for Chrome/Safari/Edge */
.help-article-content table::-webkit-scrollbar {
    height: 12px;
}

.help-article-content table::-webkit-scrollbar-track {
    background: #f8f9fa;
    border-radius: 6px;
}

.help-article-content table::-webkit-scrollbar-thumb {
    background-color: #adb5bd;
    border-radius: 6px;
    border: 2px solid #f8f9fa;
}

.help-article-content table::-webkit-scrollbar-thumb:hover {
    background-color: #6c757d;
}

.markdown-content table th,
.markdown-content table td {
    padding: 0.5rem 0.5rem;
    background-color: var(--bs-table-bg);
    border-bottom-width: 1px;
    box-shadow: inset 0 0 0 9999px var(--bs-table-accent-bg);
}

.help-article-content table th,
.help-article-content table td {
    padding: 0.5rem 0.5rem;
    background-color: var(--bs-table-bg);
    border-bottom-width: 1px;
    box-shadow: inset 0 0 0 9999px var(--bs-table-accent-bg);
}

.markdown-content table th {
    color: var(--bs-table-color);
    background-color: var(--bs-table-bg);
    border-bottom-color: var(--bs-table-border-color);
    font-weight: 600;
    vertical-align: bottom;
    border-bottom: 2px solid currentColor;
}

.help-article-content table th {
    color: var(--bs-table-color);
    background-color: var(--bs-table-bg);
    border-bottom-color: var(--bs-table-border-color);
    font-weight: 600;
    vertical-align: bottom;
    border-bottom: 2px solid currentColor;
}

.markdown-content table tbody {
    vertical-align: inherit;
}

.markdown-content table tbody tr:nth-of-type(odd)>* {
    --bs-table-accent-bg: var(--bs-table-striped-bg);
    color: var(--bs-table-striped-color);
}

/* Bootstrap Documentation Style Links */
.markdown-content a {
    color: var(--bs-link-color);
    text-decoration: underline;
}

.markdown-content a:hover {
    color: var(--bs-link-hover-color);
}

.markdown-content a:focus {
    color: var(--bs-link-hover-color);
}

/* Bootstrap Documentation Style Alerts/Callouts */
.markdown-content .alert {
    position: relative;
    padding: var(--bs-alert-padding-y) var(--bs-alert-padding-x);
    margin-bottom: 1rem;
    color: var(--bs-alert-color);
    background-color: var(--bs-alert-bg);
    border: var(--bs-alert-border-width) solid var(--bs-alert-border-color);
    border-radius: var(--bs-alert-border-radius);
}

.markdown-content .alert-primary {
    --bs-alert-color: var(--bs-primary-text-emphasis);
    --bs-alert-bg: var(--bs-primary-bg-subtle);
    --bs-alert-border-color: var(--bs-primary-border-subtle);
}

.markdown-content .alert-info {
    --bs-alert-color: var(--bs-info-text-emphasis);
    --bs-alert-bg: var(--bs-info-bg-subtle);
    --bs-alert-border-color: var(--bs-info-border-subtle);
}

.markdown-content .alert-warning {
    --bs-alert-color: var(--bs-warning-text-emphasis);
    --bs-alert-bg: var(--bs-warning-bg-subtle);
    --bs-alert-border-color: var(--bs-warning-border-subtle);
}

.markdown-content .alert-danger {
    --bs-alert-color: var(--bs-danger-text-emphasis);
    --bs-alert-bg: var(--bs-danger-bg-subtle);
    --bs-alert-border-color: var(--bs-danger-border-subtle);
}

.markdown-content .alert-success {
    --bs-alert-color: var(--bs-success-text-emphasis);
    --bs-alert-bg: var(--bs-success-bg-subtle);
    --bs-alert-border-color: var(--bs-success-border-subtle);
}

/* Bootstrap Documentation Style Images */
.markdown-content img {
    max-width: 100%;
    height: auto;
    vertical-align: middle;
}

/* Bootstrap Documentation Style Badges */
.markdown-content .badge {
    display: inline-block;
    padding: var(--bs-badge-padding-y) var(--bs-badge-padding-x);
    font-size: var(--bs-badge-font-size);
    font-weight: var(--bs-badge-font-weight);
    line-height: 1;
    color: var(--bs-badge-color);
    text-align: center;
    white-space: nowrap;
    vertical-align: baseline;
    border-radius: var(--bs-badge-border-radius);
}

.markdown-content .badge:empty {
    display: none;
}

/* Bootstrap Documentation Style Table of Contents */
.help-toc {
    background-color: var(--bs-gray-100);
    border: 1px solid var(--bs-border-color);
    border-radius: var(--bs-border-radius);
    padding: 1rem;
    margin-bottom: 1rem;
}

.help-toc h5 {
    margin-bottom: 0.5rem;
    color: var(--bs-heading-color);
    font-weight: 500;
    font-size: 1.25rem;
}

.help-toc ul {
    list-style: none;
    padding-left: 0;
    margin-bottom: 0;
}

.help-toc li {
    margin-bottom: 0.25rem;
}

.help-toc a {
    display: block;
    padding: 0.25rem 0.5rem;
    color: var(--bs-link-color);
    text-decoration: none;
    border-radius: var(--bs-border-radius-sm);
    transition: all 0.15s ease-in-out;
}

.help-toc a:hover {
    background-color: var(--bs-tertiary-bg);
    color: var(--bs-link-hover-color);
}

.help-toc a.active {
    background-color: var(--bs-primary);
    color: var(--bs-white);
}

/* Nested TOC items */
.help-toc ul ul {
    padding-left: 1rem;
    margin-top: 0.125rem;
}

.help-toc ul ul a {
    font-size: 0.875rem;
    padding: 0.125rem 0.25rem;
}

/* Bootstrap Documentation Style Responsive Design */
@media (max-width: 991.98px) {
    .markdown-content table,
    .help-article-content table {
        font-size: 0.85rem;
    }
    
    .markdown-content table th,
    .markdown-content table td,
    .help-article-content table th,
    .help-article-content table td {
        padding: 0.4rem;
    }
}

@media (max-width: 767.98px) {
    .help-article-container {
        padding: 0 0.75rem;
    }

    .markdown-content h1 {
        font-size: calc(1.375rem + 1.5vw);
    }

    .markdown-content h2 {
        font-size: calc(1.325rem + 0.9vw);
    }

    .markdown-content h3 {
        font-size: calc(1.3rem + 0.6vw);
    }

    .markdown-content pre {
        padding: 0.75rem;
        font-size: 0.875rem;
    }

    .markdown-content table,
    .help-article-content table {
        font-size: 0.75rem;
    }
    
    .markdown-content table th,
    .markdown-content table td,
    .help-article-content table th,
    .help-article-content table td {
        padding: 0.3rem;
    }

    .help-toc {
        padding: 0.75rem;
    }
}

@media (min-width: 1200px) {
    .markdown-content h1 {
        font-size: 2.5rem;
    }

    .markdown-content h2 {
        font-size: 2rem;
    }

    .markdown-content h3 {
        font-size: 1.75rem;
    }
}

/* Smooth Scrolling and Anchor Offset */
html {
    scroll-behavior: smooth;
}

.markdown-content h1[id],
.markdown-content h2[id],
.markdown-content h3[id],
.markdown-content h4[id],
.markdown-content h5[id],
.markdown-content h6[id] {
    scroll-margin-top: 100px;
}

/* Print Styles */
@media print {
    .help-toc {
        display: none;
    }

    .markdown-content {
        font-size: 12pt;
        line-height: 1.4;
    }

    .markdown-content h1,
    .markdown-content h2,
    .markdown-content h3 {
        page-break-after: avoid;
    }

    .markdown-content pre,
    .markdown-content blockquote {
        page-break-inside: avoid;
    }
}

/* Enhanced Syntax Highlighting for Code Blocks */
.markdown-content .language-javascript,
.markdown-content .language-js {
    background-color: #f7df1e;
    color: #000;
}

.markdown-content .language-ruby,
.markdown-content .language-rb {
    background-color: #cc342d;
    color: #fff;
}

.markdown-content .language-css {
    background-color: #1572b6;
    color: #fff;
}

.markdown-content .language-html {
    background-color: #e34f26;
    color: #fff;
}

.markdown-content .language-sql {
    background-color: #336791;
    color: #fff;
}

/* Mermaid Diagram Enhancements */
.mermaid {
    text-align: center;
    margin: 2rem 0;
    padding: 1.5rem;
    background-color: #fff;
    border: 1px solid #e9ecef;
    border-radius: 0.5rem;
    box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
}

.mermaid svg {
    max-width: 100%;
    height: auto;
}

/* Enhanced Step-by-Step Guides */
.markdown-content .step-guide {
    counter-reset: step-counter;
}

.markdown-content .step-guide h3 {
    counter-increment: step-counter;
    position: relative;
    padding-left: 3rem;
}

.markdown-content .step-guide h3::before {
    content: counter(step-counter);
    position: absolute;
    left: 0;
    top: 0;
    width: 2rem;
    height: 2rem;
    background-color: #0d6efd;
    color: #fff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.875rem;
}

/* Bootstrap Documentation Style Keyboard Shortcuts */
.markdown-content kbd {
    padding: 0.1875rem 0.375rem;
    font-size: 0.875em;
    color: var(--bs-body-bg);
    background-color: var(--bs-body-color);
    border-radius: var(--bs-border-radius-sm);
}

.markdown-content kbd kbd {
    padding: 0;
    font-size: 1em;
}

/* Bootstrap Documentation Style Horizontal Rules */
.markdown-content hr {
    margin: 1rem 0;
    color: inherit;
    border: 0;
    border-top: 1px solid;
    opacity: 0.25;
}