/* ------------------------------------------------ */
/*                 COLORS OVERRIDE                  */
/* ------------------------------------------------ */

/* surcharge palette Material */
[data-md-color-scheme="default"] {
    --md-primary-fg-color: #0891b2;
    --md-primary-fg-color--light: #22d3ee;
    --md-primary-fg-color--dark: #0e7490;

    --md-accent-fg-color: #1f6f77;
    --md-typeset-color: #475569;
}

/* hiérarchie des titres propre */
[data-md-color-scheme="default"] .md-typeset h1 {
    color: #1e293b;
}

[data-md-color-scheme="default"] .md-typeset h2 {
    color: #334155;
}

[data-md-color-scheme="default"] .md-typeset h3,
[data-md-color-scheme="default"] .md-typeset h4 {
    color: #475569;
}

/* (optionnel) séparation visible pour h2 en light mode */
[data-md-color-scheme="default"] .md-typeset h2 {
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
}
[data-md-color-scheme="slate"] {
    --md-primary-fg-color: #0891b2;
    --md-primary-fg-color--light: #22d3ee;
    --md-primary-fg-color--dark: #0e7490;
    --md-accent-fg-color: #1696ac;
    --md-typeset-color: #a1a1aa;
}

[data-md-color-scheme="slate"] .md-typeset h1,
[data-md-color-scheme="slate"] .md-typeset h2,
[data-md-color-scheme="slate"] .md-typeset h3,
[data-md-color-scheme="slate"] .md-typeset h4 {
    color: #d4d4d8;
}

/* ------------------------------------------------ */
/*                     SEARCH                       */
/* ------------------------------------------------ */

.md-search__form {
    border-radius: 8px !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
}

/* ------------------------------------------------ */
/*                     HEADER                       */
/* ------------------------------------------------ */

.md-header {
    background: rgba(15, 23, 42, 0.75);
    backdrop-filter: blur(6px);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.md-header__title {
    font-weight: 600;
    letter-spacing: 0.2px;
}

.md-header__button.md-logo img {
    width: 2rem;
    height: 2rem;
}

.md-header__button.md-icon {
    color: #cbd5f5;
    opacity: 0.85;
    transition: opacity 0.2s ease;
}

.md-header__button.md-icon:hover {
    opacity: 1;
}

/* ------------------------------------------------ */
/*                   SIDEBAR                       */
/* ------------------------------------------------ */

.md-nav__title {
    font-weight: 600;
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    opacity: 0.8;
}

.md-nav__link {
    border-radius: 6px;
}

.md-nav__link:hover {
    background: rgba(255, 255, 255, 0.05);
}

/* ------------------------------------------------ */
/*                   CONTENT                       */
/* ------------------------------------------------ */
.md-content {
    max-width: 900px;
}

/* ------------------------------------------------ */
/*                PERMALINK                        */
/* ------------------------------------------------ */

.headerlink,
.md-typeset .headerlink,
a.headerlink {
    display: none !important;
    visibility: hidden !important;
}

/* ------------------------------------------------ */
/*                TYPOGRAPHY                        */
/* ------------------------------------------------ */

.md-typeset {
    font-size: 0.70rem;
    line-height: 1.2;
}

.md-typeset h1 {
    font-size: 1.4rem;
    font-weight: 400;
    letter-spacing: -0.01em;
    margin-top: 1.6rem;
}

/*.md-typeset h2 {*/
/*    font-size: 1.4rem;*/
/*    font-weight: 550;*/
/*    margin-top: 1.4rem;*/
/*    border-bottom: 1px solid rgba(255,255,255,0.06);*/
/*    padding-bottom: 0.3rem;*/
/*}*/

/*.md-typeset h3 {*/
/*    font-size: 1.15rem;*/
/*    font-weight: 500;*/
/*    margin-top: 1.2rem;*/
/*}*/

/*.md-typeset h4 {*/
/*    font-size: 1rem;*/
/*    font-weight: 500;*/
/*}*/

/*!* code blocks *!*/

/*.md-typeset pre {*/
/*    border-radius: 8px;*/
/*    border: 1px solid rgba(255,255,255,0.06);*/
/*    padding: 1rem;*/
/*}*/

/*.md-typeset code {*/
/*    font-size: 0.85rem;*/
/*}*/

/*!* links *!*/

/*.md-typeset a {*/
/*    font-weight: 500;*/
/*    text-decoration: none;*/
/*}*/

/*.md-typeset a:hover {*/
/*    text-decoration: underline;*/
/*}*/

/*!* tables *!*/

/*.md-typeset table {*/
/*    font-size: 0.9rem;*/
/*}*/

/*.md-typeset p {*/
/*    margin: 0.8em 0;*/
/*}*/

/* cards grid pour la landing page */
.grid.cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
}

.grid.cards > ul {
    display: contents;
    list-style: none;
    padding: 0;
    margin: 0;
}

.grid.cards > ul > li {
    border: 1px solid rgba(50, 99, 106, 0.08);
    border-radius: 6px;
    padding: 1.0rem;
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.grid.cards > ul > li:hover {
    border-color: var(--md-accent-fg-color);
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

[data-md-color-scheme="default"] .grid.cards > ul > li {
    border-color: rgba(0,0,0,0.1);
}

[data-md-color-scheme="default"] .grid.cards > ul > li:hover {
    border-color: var(--md-accent-fg-color);
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
}
.md-nav__item .md-nav__link.md-nav__link--active {
    color: #1696ac !important;
}
/*!* thème clair *!*/
/*[data-md-color-scheme="default"] {*/
/*    --md-typeset-a-color: #1696ac;*/
/*    --md-typeset-a-color--hover: #1696ac;*/
/*}*/

/*!* thème sombre *!*/
/*[data-md-color-scheme="slate"] {*/
/*    --md-typeset-a-color: #1696ac;*/
/*    --md-typeset-a-color--hover: #1696ac;*/
/*}*/
/* ------------------------------------------------ */
/*                    LAYOUT                       */
/* ------------------------------------------------ */

.md-grid {
    max-width: 1400px;
}

/* ------------------------------------------------ */
/*                    FONTS                        */
/* ------------------------------------------------ */

body {
    font-family: "Inter", system-ui, sans-serif;
}

code, pre {
    font-family: "JetBrains Mono", monospace;
}

/* ------------------------------------------------ */
/*                    FOOTER                       */
/* ------------------------------------------------ */

.md-footer {
    padding-top: 0.6rem;
    padding-bottom: 0.6rem;
    border-top: 1px solid rgba(255,255,255,0.05);
}
.md-footer,
.md-footer-meta {
    background-color: #34373e;
}

.md-footer-meta {
    font-size: 0.72rem;
    padding: 0.6rem 0;
    opacity: 0.7;
}

.md-footer-meta__inner {
    font-size: 0.5rem;
    opacity: 0.7;
}
.md-footer a {
    opacity: 0.8;
    text-decoration: none;
}

.md-footer a:hover {
    opacity: 1;
}
/* ------------------------------------------------ */
/*                    DARK/LIGHT                    */
/* ------------------------------------------------ */

.md-header__button.md-icon svg {
    width: 1.8rem;
    height: 1.8rem;
}
.md-header__button.md-icon {
    padding: 8px;
}

/* ------------------------------------------------ */
/*                    MERMAID                       */
/* ------------------------------------------------ */
/* Fix Mermaid diagrams width */
.mermaid {
    max-width: 100%;
    overflow-x: auto;
    text-align: center;
}
/* éviter que les diagrammes cassent le layout */
.mermaid svg {
    max-width: 100%;
    height: auto;
}

/* ------------------------------------------------ */
/*                    PRINT                         */
/* ------------------------------------------------ */
@media print {

    .mermaid {
        max-width: 90%;
        margin: auto;
    }

}