/*
 * cnam.css
 * Thème Cnam pour Sphinx
 * Basé sur agogo, adapté à la charte graphique Cnam 2024
 * Version 2.0
 */

/* ============================================================
   POLICES OFFICIELLES CNAM
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Raleway:ital,wght@0,400;0,600;0,700;1,400&family=Crimson+Pro:ital,wght@0,400;0,600;1,400&display=swap');

@font-face {
    font-family: 'Montserrat';
    font-style: normal;
    font-weight: 400;
    src: url("fonts/Montserrat-Regular.ttf");
}
@font-face {
    font-family: 'Montserrat Bold';
    font-style: normal;
    font-weight: 700;
    src: url("fonts/Montserrat-Bold.ttf");
}

/* ============================================================
   VARIABLES CNAM (couleurs de la charte)
   ============================================================ */

:root {
    --cnam-rouge:      #C1002A;
    --cnam-bleu-fonce: #11304C;
    --cnam-bleu-moyen: #4485C5;
    --cnam-bleu-clair: #A1D6DF;
    --cnam-gris:       #405A68;
    --cnam-lime:       #DDDC00;
    --blanc:           #ffffff;
    --gris-clair:      #f5f5f5;
    --gris-bordure:    #dddddd;
}

/* ============================================================
   RESET
   ============================================================ */

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

/* ============================================================
   CORPS DE PAGE
   ============================================================ */

body {
    font-family: "Crimson Pro", Georgia, serif;
    font-size: 1.15em;
    line-height: 1.7em;
    color: #222222;
    background-color: #f0f2f4;
}

/* ============================================================
   MISE EN PAGE GÉNÉRALE
   ============================================================ */

div.header, div.content, div.footer {
    max-width: 90em;
    margin-left: auto;
    margin-right: auto;
}

/* ============================================================
   EN-TÊTE
   ============================================================ */

div.header-wrapper {
    background: var(--cnam-bleu-fonce);
}

div.header {
    padding: 16px 1.5em;
    font-family: "Raleway", sans-serif;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

div.header .headertitle {
    font-family: "Raleway", sans-serif;
    font-weight: 700;
    font-size: 150%;
    letter-spacing: .03em;
    margin-bottom: 0;
}

div.header .headertitle a {
    color: var(--blanc);
    text-decoration: none;
}

div.header div.rel {
    margin-top: .4em;
}

div.header div.rel a {
    color: rgba(255,255,255,0.85);
    letter-spacing: .08em;
    text-transform: uppercase;
    font-size: 0.78em;
    font-weight: 600;
    text-decoration: none;
}

div.header div.rel a:hover {
    color: var(--blanc);
}

p.logo {
    float: right;
    min-width: 8em;
    max-width: 14em;
    width: 20%;
    margin-left: 1em;
}

img.logo {
    border: 0;
    width: 100%;
}

/* ============================================================
   LIENS
   ============================================================ */

a {
    color: var(--cnam-rouge);
    transition: color 0.15s;
}

a:hover {
    color: var(--cnam-bleu-fonce);
}

div.bodywrapper a, div.footer a {
    text-decoration: underline;
}

/* ============================================================
   UTILITAIRES
   ============================================================ */

.clearer { clear: both; }
.left { float: left; }
.right { float: right; }

.line-block {
    display: block;
    margin-top: 1em;
    margin-bottom: 1em;
}

.line-block .line-block {
    margin-top: 0;
    margin-bottom: 0;
    margin-left: 1.5em;
}

/* ============================================================
   TITRES
   ============================================================ */

h1, h2, h3, h4, h5, h6 {
    font-family: "Raleway", sans-serif;
    font-weight: 700;
    margin-bottom: .7em;
    margin-top: 1.2em;
    text-align: left;
    line-height: 1.25em;
}

h1 {
    font-size: 1.9em;
    color: var(--cnam-bleu-fonce);
    border-bottom: 3px solid var(--cnam-rouge);
    padding-bottom: .3em;
    margin-top: 0;
}

h2 {
    font-size: 1.45em;
    color: var(--cnam-rouge);
    border-bottom: 1px solid var(--cnam-rouge);
    padding-bottom: .2em;
}

h3 {
    font-size: 1.2em;
    color: var(--cnam-bleu-fonce);
}

h4 {
    font-size: 1.05em;
    color: var(--cnam-gris);
}

a.headerlink {
    visibility: hidden;
    color: var(--gris-bordure);
    padding-left: .3em;
    font-size: 0.8em;
}

h1:hover > a.headerlink,
h2:hover > a.headerlink,
h3:hover > a.headerlink,
h4:hover > a.headerlink,
h5:hover > a.headerlink,
h6:hover > a.headerlink,
dt:hover > a.headerlink,
caption:hover > a.headerlink,
p.caption:hover > a.headerlink,
div.code-block-caption:hover > a.headerlink {
    visibility: visible;
}

img {
    border: 0;
    max-width: 100%;
}

/* ============================================================
   ADMONITIONS
   ============================================================ */

div.admonition {
    margin-top: 1em;
    margin-bottom: 1em;
    padding: 8px 12px;
    border-left: 4px solid var(--cnam-gris);
    background-color: #f9f9f9;
    border-radius: 0 4px 4px 0;
}

div.admonition.note {
    border-left-color: var(--cnam-bleu-moyen);
    background-color: #f0f6fb;
}

div.admonition.warning {
    border-left-color: var(--cnam-lime);
    background-color: #fdfdf0;
}

div.admonition.admonition-question {
    border-left-color: var(--cnam-rouge);
    background-color: #fdf5f7;
}

div.admonition.admonition-question > .admonition-title {
    color: var(--cnam-rouge);
}

div.admonition.admonition-correction > .admonition-title {
    color: #006e12;
}

div.admonition.admonition-correction {
    border-left-color: #006e12;
    background-color: #f5fdf5;
}

p.admonition-title {
    margin: 0 0 6px 0;
    font-weight: 700;
    font-family: "Raleway", sans-serif;
    font-size: 0.95em;
    text-transform: uppercase;
    letter-spacing: .05em;
}

dt:target, .highlighted {
    background-color: #fbe54e;
}

/* ============================================================
   CONTENU
   ============================================================ */

div.content-wrapper {
    background-color: var(--blanc);
    padding-top: 2em;
    padding-bottom: 2em;
    box-shadow: 0 1px 3px rgba(0,0,0,0.08);
}

div.document {
    width: 70%;
    float: left;
}

div.body {
    padding-right: 2em;
    padding-left: 2em;
    text-align: justify;
}

div.document ul {
    margin: 0.75em 1em 0.75em 1.5em;
    list-style-type: square;
}

div.document dd {
    margin-left: 1.2em;
    margin-top: .4em;
    margin-bottom: 1em;
}

div.document .section {
    margin-top: 2em;
}

div.document .section:first-child {
    margin-top: 0;
}

div.document p {
    margin-bottom: .7em;
}

div.document li.toctree-l1 {
    margin-bottom: 1em;
}

div.document .descname {
    font-weight: bold;
}

div.document .sig-paren {
    font-size: larger;
}

div.document blockquote {
    margin: 0.5em 0 0.5em 1.5em;
    padding-left: 1em;
    border-left: 3px solid var(--gris-bordure);
    color: var(--cnam-gris);
    font-style: italic;
}

div.document ol {
    margin: 0.75em 1em 0.75em 1.5em;
}

@media only screen and (max-width: 768px) {
    div.document {
        width: 100%;
    }
}

/* ============================================================
   BLOCS DE CODE
   ============================================================ */

div.document div.highlight {
    background-color: #f5f7fa;
    border-left: 4px solid var(--cnam-bleu-moyen);
    border-top: none;
    border-bottom: none;
    border-right: none;
    border-radius: 0 4px 4px 0;
    margin-top: 1em;
    margin-bottom: 1em;
    overflow: auto;
    padding: 12px 16px;
}

div.document div.highlight pre {
    color: #1e2a38;
    font-family: "Liberation Mono", "Courier New", monospace;
    font-size: 0.88em;
    line-height: 1.5em;
}

div.document div.literal-block-wrapper {
    margin-top: 1em;
    margin-bottom: 1em;
    border: 1px solid var(--gris-bordure);
    border-radius: 4px;
    overflow: hidden;
}

div.document div.literal-block-wrapper div.highlight {
    margin: 0;
    border-radius: 0;
}

div.document div.code-block-caption {
    background-color: var(--cnam-bleu-fonce);
    color: var(--blanc);
    padding: 4px 12px;
    font-family: "Raleway", sans-serif;
    font-size: 0.82em;
    font-weight: 600;
    letter-spacing: .05em;
}

div.document div.code-block-caption span.caption-number {
    padding: 0.1em 0.3em;
    font-style: italic;
}

div.document .docutils.literal {
    background-color: #f0f2f4;
    padding: 1px 5px;
    font-family: "Liberation Mono", monospace;
    font-size: 0.88em;
    border: 1px solid var(--gris-bordure);
    border-radius: 3px;
    color: var(--cnam-rouge);
}

div.document .docutils.xref.literal {
    background-color: transparent;
    padding: 0;
    border: none;
    color: inherit;
}

/* ============================================================
   BARRE LATÉRALE
   ============================================================ */

div.sidebar {
    width: 30%;
    padding-right: 1.5em;
    float: right;
    font-size: .9em;
    font-family: "Raleway", sans-serif;
}

div.sidebar a, div.header a {
    text-decoration: none;
}

div.sidebar a:hover {
    text-decoration: underline;
}

div.sidebar h3 {
    color: var(--cnam-gris);
    text-transform: uppercase;
    font-size: 0.85em;
    letter-spacing: .12em;
    font-family: "Raleway", sans-serif;
    font-weight: 700;
    margin-bottom: .6em;
    padding-bottom: .3em;
    border-bottom: 2px solid var(--cnam-rouge);
}

div.sidebar ul {
    list-style-type: none;
}

div.sidebar li.toctree-l1 a {
    display: block;
    padding: 5px 8px;
    border-left: 3px solid transparent;
    background-color: var(--gris-clair);
    margin-bottom: .3em;
    color: var(--cnam-bleu-fonce);
    border-radius: 0 3px 3px 0;
    font-weight: 600;
    font-size: 0.92em;
    transition: all 0.15s;
}

div.sidebar li.toctree-l1 a:hover {
    border-left-color: var(--cnam-rouge);
    background-color: #ffe8ec;
    text-decoration: none;
}

div.sidebar li.toctree-l2 a {
    background-color: transparent;
    border: none;
    border-left: 3px solid transparent;
    margin-left: 1em;
    font-weight: 400;
    color: var(--cnam-gris);
    border-radius: 0;
}

div.sidebar li.toctree-l2 a:hover {
    border-left-color: var(--cnam-bleu-moyen);
    background-color: #f0f6fb;
}

div.sidebar li.toctree-l3 a {
    background-color: transparent;
    border: none;
    margin-left: 2em;
    color: var(--cnam-gris);
}

div.sidebar li.toctree-l1.current > a {
    border-left: 3px solid var(--cnam-rouge);
    background-color: #fdf5f7;
    color: var(--cnam-rouge);
}

div.sidebar li.toctree-l1.current li.toctree-l2 a {
    border-left: 3px solid transparent;
}

div.sidebar form {
    text-align: center;
    margin-top: 1.5em;
}

div.sidebar input[type="text"] {
    min-width: 170px;
    width: 78%;
    min-height: 32px;
    vertical-align: top;
    border: 1px solid var(--gris-bordure);
    border-radius: 3px 0 0 3px;
    padding: 0 8px;
    font-family: "Raleway", sans-serif;
}

div.sidebar input[type="submit"] {
    width: 18%;
    vertical-align: top;
    min-height: 32px;
    background-color: var(--cnam-rouge);
    color: var(--blanc);
    border: none;
    cursor: pointer;
    border-radius: 0 3px 3px 0;
    font-family: "Raleway", sans-serif;
    font-weight: 600;
    transition: background-color 0.15s;
}

div.sidebar input[type="submit"]:hover {
    background-color: var(--cnam-bleu-fonce);
}

@media only screen and (max-width: 768px) {
    div.sidebar {
        float: none;
        width: 95%;
        margin: auto;
        padding-right: 0;
    }
}

/* ============================================================
   PIED DE PAGE
   ============================================================ */

div.footer-wrapper {
    background-color: var(--cnam-bleu-fonce);
    padding: 14px 0;
    min-height: 60px;
    font-family: "Raleway", sans-serif;
}

div.footer, div.footer a {
    color: var(--cnam-bleu-clair);
    font-size: 0.85em;
}

div.footer a:hover {
    color: var(--blanc);
}

div.footer .right {
    text-align: right;
}

div.footer .left {
    text-transform: uppercase;
    letter-spacing: .06em;
}

/* ============================================================
   ALIGNEMENTS IMAGES
   ============================================================ */

img.align-left, .figure.align-left, object.align-left {
    clear: left;
    float: left;
    margin-right: 1.5em;
    margin-bottom: .5em;
}

img.align-right, .figure.align-right, object.align-right {
    clear: right;
    float: right;
    margin-left: 1.5em;
    margin-bottom: .5em;
}

img.align-center, .figure.align-center, object.align-center {
    display: block;
    margin-left: auto;
    margin-right: auto;
}

.align-left  { text-align: left; }
.align-center { text-align: center; }
.align-right { text-align: right; }

/* ============================================================
   TABLEAUX
   ============================================================ */

table.docutils {
    border-collapse: collapse;
    width: 100%;
    margin-bottom: 1.2em;
    font-size: 0.95em;
}

table.docutils td, table.docutils th {
    padding: 8px 12px;
    border: 1px solid var(--gris-bordure);
}

table.docutils th {
    background-color: var(--cnam-bleu-fonce);
    color: var(--blanc);
    font-family: "Raleway", sans-serif;
    font-weight: 600;
    letter-spacing: .03em;
}

table.docutils tr:nth-child(even) td {
    background-color: #f8f9fa;
}

table.docutils tr:hover td {
    background-color: #f0f6fb;
}

table.footnote td, table.footnote th {
    border: 0 !important;
}

th {
    text-align: left;
}

table.citation {
    border-left: 3px solid var(--cnam-rouge);
    margin-left: 1px;
}

table.citation td {
    border-bottom: none;
}

/* ============================================================
   RECHERCHE
   ============================================================ */

ul.search {
    margin: 10px 0 0 20px;
    padding: 0;
}

ul.search li {
    padding: 5px 0 5px 20px;
    background-image: url(file.png);
    background-repeat: no-repeat;
    background-position: 0 7px;
}

ul.search li a {
    font-weight: bold;
}

ul.search li div.context {
    color: #888;
    margin: 2px 0 0 30px;
    text-align: left;
}

ul.keywordmatches li.goodmatch a {
    font-weight: bold;
}

/* ============================================================
   INDEX
   ============================================================ */

table.contentstable {
    width: 90%;
}

table.contentstable p.biglink {
    line-height: 150%;
}

a.biglink {
    font-size: 1.3em;
}

span.linkdescr {
    font-style: italic;
    padding-top: 5px;
    font-size: 90%;
}

table.indextable td {
    text-align: left;
    vertical-align: top;
}

table.indextable ul {
    margin-top: 0;
    margin-bottom: 0;
    list-style-type: none;
}

table.indextable > tbody > tr > td > ul {
    padding-left: 0;
}

table.indextable tr.pcap {
    height: 10px;
}

table.indextable tr.cap {
    margin-top: 10px;
    background-color: #f2f2f2;
}

/* ============================================================
   AFFICHAGE MATHÉMATIQUE
   ============================================================ */

div.body div.math p {
    text-align: center;
}

span.eqno {
    float: right;
}

/* ============================================================
   BOUTON NOTEBOOK JUPYTER
   ============================================================ */

.notebook {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.5em;
    margin: 0 0 1.5em 0;
    padding: 10px 16px;
    border: 1px solid var(--cnam-bleu-moyen);
    background: linear-gradient(135deg, #f0f6fb 0%, #ffffff 100%);
    border-radius: 4px;
    font-family: "Raleway", sans-serif;
    font-size: 0.92em;
}

.notebook > p {
    display: inline;
    margin: 0;
}

.notebook > p > a {
    text-decoration: none;
    color: var(--cnam-bleu-fonce);
    font-weight: 600;
    padding: 4px 12px;
    border-radius: 3px;
    border: 1px solid var(--cnam-bleu-moyen);
    transition: all 0.15s;
}

.notebook > p > a:hover {
    background-color: var(--cnam-rouge);
    color: var(--blanc);
    border-color: var(--cnam-rouge);
}

.svg-inline {
    height: 1em;
    margin-right: 0.4em;
    margin-bottom: -2px;
}
