/* cmsms stylesheet: ALFAC Paged Reset modified: Monday, January 19, 2026 11:18:34 PM */
/*! normalize.css v7.0.0 | MIT License | github.com/necolas/normalize.css */

/* Document
   ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in
 *	IE on Windows Phone and in iOS.
 */

html {
  // line-height: 1.15; /* 1 */
  -ms-text-size-adjust: 100%; /* 2 */
  -webkit-text-size-adjust: 100%; /* 2 */
}

/* Sections
   ========================================================================== */

/**
 * Remove the margin in all browsers (opinionated).
 */

body {
  margin: 0;
}

/**
 * Add the correct display in IE 9-.
 */

article,
aside,
footer,
header,
nav,
section {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 * 1. Add the correct display in IE.
 */

figcaption,
figure,
main { /* 1 */
  display: block;
}

/**
 * Add the correct margin in IE 8.
 */

figure {
  margin: 1em 40px;
}

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */

hr {
  box-sizing: content-box; /* 1 */
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/* Text-level semantics
   ========================================================================== */

/**
 * 1. Remove the gray background on active links in IE 10.
 * 2. Remove gaps in links underline in iOS 8+ and Safari 8+.
 */

a {
  background-color: transparent; /* 1 */
  -webkit-text-decoration-skip: objects; /* 2 */
}

/**
 * 1. Remove the bottom border in Chrome 57- and Firefox 39-.
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */

abbr[title] {
  border-bottom: none; /* 1 */
  text-decoration: underline; /* 2 */
  text-decoration: underline dotted; /* 2 */
}

/**
 * Prevent the duplicate application of `bolder` by the next rule in Safari 6.
 */

b,
strong {
  font-weight: inherit;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */

b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */

code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}

/**
 * Add the correct font style in Android 4.3-.
 */

dfn {
  font-style: italic;
}

/**
 * Add the correct background and color in IE 9-.
 */

mark {
  background-color: #ff0;
  color: #000;
}

/**
 * Add the correct font size in all browsers.
 */

small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 */

audio,
video {
  display: inline-block;
}

/**
 * Add the correct display in iOS 4-7.
 */

audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Remove the border on images inside links in IE 10-.
 */

img {
  border-style: none;
}

/**
 * Hide the overflow in IE.
 */

svg:not(:root) {
  overflow: hidden;
}

/* Forms
   ========================================================================== */

/**
 * 1. Change the font styles in all browsers (opinionated).
 * 2. Remove the margin in Firefox and Safari.
 */

button,
input,
optgroup,
select,
textarea {
  font-family: sans-serif; /* 1 */
  font-size: 100%; /* 1 */
  line-height: 1.15; /* 1 */
  margin: 0; /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */

button,
input { /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */

button,
select { /* 1 */
  text-transform: none;
}

/**
 * 1. Prevent a WebKit bug where (2) destroys native `audio` and `video`
 *	controls in Android 4.
 * 2. Correct the inability to style clickable types in iOS and Safari.
 */

button,
html [type="button"], /* 1 */
[type="reset"],
[type="submit"] {
  -webkit-appearance: button; /* 2 */
}

/**
 * Remove the inner border and padding in Firefox.
 */

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */

fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *	`fieldset` elements in all browsers.
 */

legend {
  box-sizing: border-box; /* 1 */
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  padding: 0; /* 3 */
  white-space: normal; /* 1 */
}

/**
 * 1. Add the correct display in IE 9-.
 * 2. Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */

progress {
  display: inline-block; /* 1 */
  vertical-align: baseline; /* 2 */
}

/**
 * Remove the default vertical scrollbar in IE.
 */

textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10-.
 * 2. Remove the padding in IE 10-.
 */

[type="checkbox"],
[type="radio"] {
  box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */

[type="search"] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/**
 * Remove the inner padding and cancel buttons in Chrome and Safari on macOS.
 */

[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/* Interactive
   ========================================================================== */

/*
 * Add the correct display in IE 9-.
 * 1. Add the correct display in Edge, IE, and Firefox.
 */

details, /* 1 */
menu {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */

summary {
  display: list-item;
}

/* Scripting
   ========================================================================== */

/**
 * Add the correct display in IE 9-.
 */

canvas {
  display: inline-block;
}

/**
 * Add the correct display in IE.
 */

template {
  display: none;
}

/* Hidden
   ========================================================================== */

/**
 * Add the correct display in IE 10-.
 */

[hidden] {
  display: none;
}
/* cmsms stylesheet: ALFAC - Interface modified: Sunday, January 18, 2026 2:27:20 PM */
/* CSS for Paged.js interface – v0.4 */

/* Change the look */
:root {
    --color-background: whitesmoke;
    --color-pageSheet: #cfcfcf;
    --color-pageBox: violet;
    --color-paper: white;
    --color-marginBox: transparent;
    --pagedjs-crop-color: black;
    --pagedjs-crop-shadow: white;
    --pagedjs-crop-stroke: 1px;
}

/* To define how the book look on the screen: */

/* Réduire la qualité pour le preview */
@media screen {
  img {
    image-rendering: optimizeSpeed;
  }
}


@media screen, pagedjs-ignore {
    body {
        background-color: var(--color-background);
    }

    .pagedjs_pages {
        display: flex;
        width: calc(var(--pagedjs-width) * 2);
        flex: 0;
        flex-wrap: wrap;
        margin: 0 auto;
    }

    .pagedjs_page {
        background-color: var(--color-paper);
        box-shadow: 0 0 0 1px var(--color-pageSheet);
        margin: 0;
        flex-shrink: 0;
        flex-grow: 0;
        margin-top: 10mm;
    }

    .pagedjs_first_page {
        margin-left: var(--pagedjs-width);
    }

    .pagedjs_page:last-of-type {
        margin-bottom: 10mm;
    }

    .pagedjs_pagebox{
        box-shadow: 0 0 0 1px var(--color-pageBox);
    }

    .pagedjs_left_page{
        z-index: 20;
        width: calc(var(--pagedjs-bleed-left) + var(--pagedjs-pagebox-width))!important;
    }

    .pagedjs_left_page .pagedjs_bleed-right .pagedjs_marks-crop {
        border-color: transparent;
    }
    
    .pagedjs_left_page .pagedjs_bleed-right .pagedjs_marks-middle{
        width: 0;
    } 

    .pagedjs_right_page{
        z-index: 10;
        position: relative;
        left: calc(var(--pagedjs-bleed-left)*-1);
    }

    /* show the margin-box */

    .pagedjs_margin-top-left-corner-holder,
    .pagedjs_margin-top,
    .pagedjs_margin-top-left,
    .pagedjs_margin-top-center,
    .pagedjs_margin-top-right,
    .pagedjs_margin-top-right-corner-holder,
    .pagedjs_margin-bottom-left-corner-holder,
    .pagedjs_margin-bottom,
    .pagedjs_margin-bottom-left,
    .pagedjs_margin-bottom-center,
    .pagedjs_margin-bottom-right,
    .pagedjs_margin-bottom-right-corner-holder,
    .pagedjs_margin-right,
    .pagedjs_margin-right-top,
    .pagedjs_margin-right-middle,
    .pagedjs_margin-right-bottom,
    .pagedjs_margin-left,
    .pagedjs_margin-left-top,
    .pagedjs_margin-left-middle,
    .pagedjs_margin-left-bottom {
        box-shadow: 0 0 0 1px inset var(--color-marginBox);
    }

    /* uncomment this part for recto/verso book : ------------------------------------ */

    /*
    .pagedjs_pages {
        flex-direction: column;
        width: 100%;
    }

    .pagedjs_first_page {
        margin-left: 0;
    }

    .pagedjs_page {
        margin: 0 auto;
        margin-top: 10mm;
    } 

    .pagedjs_left_page{
        width: calc(var(--pagedjs-bleed-left) + var(--pagedjs-pagebox-width) + var(--pagedjs-bleed-left))!important;
    }

    .pagedjs_left_page .pagedjs_bleed-right .pagedjs_marks-crop{
        border-color: var(--pagedjs-crop-color);
    }

    .pagedjs_left_page .pagedjs_bleed-right .pagedjs_marks-middle{
        width: var(--pagedjs-cross-size)!important;
    } 

    .pagedjs_right_page{
        left: 0; 
    } 
    */
    
    

    /*--------------------------------------------------------------------------------------*/



    /* uncomment this par to see the baseline : -------------------------------------------*/

    
    /* .pagedjs_pagebox {
        --pagedjs-baseline: 22px;
        --pagedjs-baseline-position: 5px;
        --pagedjs-baseline-color: cyan;
        background: linear-gradient(transparent 0%, transparent calc(var(--pagedjs-baseline) - 1px), var(--pagedjs-baseline-color) calc(var(--pagedjs-baseline) - 1px), var(--pagedjs-baseline-color) var(--pagedjs-baseline)), transparent;
        background-size: 100% var(--pagedjs-baseline);
        background-repeat: repeat-y;
        background-position-y: var(--pagedjs-baseline-position);
    }  */
   

    /*--------------------------------------------------------------------------------------*/
}





/* Marks (to delete when merge in paged.js) */

.pagedjs_marks-crop{
    z-index: 999999999999;
  
}

.pagedjs_bleed-top .pagedjs_marks-crop, 
.pagedjs_bleed-bottom .pagedjs_marks-crop{
    box-shadow: 1px 0px 0px 0px var(--pagedjs-crop-shadow);
}  

.pagedjs_bleed-top .pagedjs_marks-crop:last-child,
.pagedjs_bleed-bottom .pagedjs_marks-crop:last-child{
    box-shadow: -1px 0px 0px 0px var(--pagedjs-crop-shadow);
}  

.pagedjs_bleed-left .pagedjs_marks-crop,
.pagedjs_bleed-right .pagedjs_marks-crop{
    box-shadow: 0px 1px 0px 0px var(--pagedjs-crop-shadow);
}

.pagedjs_bleed-left .pagedjs_marks-crop:last-child,
.pagedjs_bleed-right .pagedjs_marks-crop:last-child{
    box-shadow: 0px -1px 0px 0px var(--pagedjs-crop-shadow);
}
/* cmsms stylesheet: ALFAC Paged style-print modified: Monday, January 19, 2026 12:10:43 AM */
@media print {
  /* ==========================================
     PAGE SETUP
     ========================================== */
  
  @page {
    size: 210mm 297mm;
    margin-top: 20mm;
    margin-bottom: 20mm;
    font-family: 'Noto Sans';
    color: #000059;
    hyphens: auto;
    orphans: 2;
    widows: 2;
  }
  
  /* BLEED (commented out - uncomment if needed) */
  /* @page {
    marks: crop;
    bleed: 5mm;
  } */
  
  /* ==========================================
     LEFT PAGES
     ========================================== */
  
  @page:left {
    margin-left: 20mm;
    margin-right: 20mm;
    
    @bottom-left {
      content: counter(page);
      width: 30px;
      font-size: 10px;
    }
    
    @bottom-center {
      content: "Aquatic Literacy For All Children";
      text-align: left;
      font-size: 10px;
    }
  }
  
  /* ==========================================
     RIGHT PAGES
     ========================================== */
  
  @page:right {
    margin-left: 20mm;
    margin-right: 20mm;
    
    @bottom-right {
      content: counter(page);
      width: 30px;
      font-size: 10px;
    }
    
    @bottom-center {
      content: string(chapTitle);
      text-align: right;
      font-size: 10px;
    }
  }
  
  /* Set chapter title for running headers */
  .chapter h2 {
    string-set: chapTitle content(text);
  }
  
  /* ==========================================
     BLANK PAGES
     ========================================== */
  
  @page:blank {
    @bottom-left { content: none; }
    @bottom-center { content: none; }
    @bottom-right { content: none; }
  }
  
  .empty-page {
    page-break-after: always;
  }
  
  /* ==========================================
     COVER PAGE
     ========================================== */
  
  @page:first {
    margin: 10mm 10mm;
    background-color: var(--white);
    background-image: url("https://alfac.eu/uploads/alfac/images/Alfac_Book_Images/Couv.jpg");
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    
    @bottom-left { content: none; }
    @bottom-center { content: none; }
    @bottom-right { content: none; }
  }
  
  #cover {
    break-after: right;
  }
  
  #cover img {
    mix-blend-mode: lighten;
  }
  
  /* ==========================================
     INNER COVERS (CHAPTER PAGES)
     ========================================== */
  
  @page inner-cover {
    margin: 10mm 10mm;
    background-color: var(--alice-blue);
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    
    @bottom-left { content: none; }
    @bottom-center { content: none; }
    @bottom-right { content: none; }
  }
  
  #inner_cover_02,
  #inner_cover_03,
  #inner_cover_04,
  #inner_cover_05,
  #inner_cover_06,
  #inner_cover_07,
  #inner_cover_08,
  #inner_cover_09,
  #inner_cover_10,
  #inner_cover_11,
  #inner_cover_12 {
    page: inner-cover;
    break-after: right;
  }
  
  /* ==========================================
     SECTION BREAKS
     ========================================== */
  
  .chapter {
    break-before: right;
  }
  
  /* ==========================================
     CSS VARIABLES
     ========================================== */
  
  :root {
    --midnight-blue: #000059;
    --royal-blue: #347bfc;
    --white: white;
    --gold: #ffcc01;
    --dodger-blue: #57acf8;
    --dark-slate-blue: #374568;
    --alice-blue: #f0f5fa;
    --light-steel-blue: #c5d8fc;
    --light-grey: #eaecf0;
    --midnight-blue-2: #202442;
  }
  
  /* ==========================================
     GLOBAL ELEMENTS
     ========================================== */
  
  .navbar,
  .section_header {
    display: none;
  }
  
  figure,
  img {
    width: 100%;
  }
  
  /* ==========================================
     TYPOGRAPHY - HEADINGS
     ========================================== */
  
  h1.couv_title {
    color: var(--royal-blue);
    text-align: right;
    float: right;
    width: 100%;
    margin: 0 0 10px 0;
    letter-spacing: -2px;
    font-size: 60px;
    font-weight: 800;
    line-height: 65px;
  }
  
  h1.sub_title {
    color: var(--midnight-blue);
    text-align: right;
    float: right;
    width: 100%;
    margin: 10mm 0 0 0;
    letter-spacing: -1px;
    font-size: 20px;
    font-weight: 400;
    line-height: 22px;
  }
  
  h1.top {
    color: var(--royal-blue);
    text-align: right;
    float: right;
    width: 100%;
    margin-top: 20mm;
    margin-bottom: 0mm;
    padding: 0;
    letter-spacing: -2px;
    font-size: 32px;
    font-weight: 800;
    line-height: 36px;
  }
  
  h2 {
    float: left;
    color: var(--midnight-blue);
    text-align: left;
    width: 100%;
    margin: 20mm 0 0 0;
    padding: 0;
    font-size: 32px;
    font-weight: 400;
    line-height: 36px;
  }
  
  h3 {
    float: left;
    color: var(--royal-blue);
    text-align: left;
    width: 100%;
    margin: 5mm 0;
    font-size: 24px;
    font-weight: bold;
    line-height: 30px;
  }
  
  h4 {
    float: left;
    border-top: 1px solid var(--royal-blue);
    text-align: left;
    width: 100%;
    margin: 10px 0;
    padding: 10px 0 0 0;
    font-size: 16px;
    font-weight: bold;
    line-height: 24px;
  }
  
  h4.top {
    float: left;
    border-top: 1px solid var(--royal-blue);
    text-align: left;
    width: 100%;
    margin: 0 0 10px 0;
    padding: 10px;
    font-size: 16px;
    font-weight: bold;
    line-height: 26px;
  }
  
  h5,
  h6 {
    float: left;
    text-align: left;
    width: 100%;
    margin: 10px 0;
    padding: 0 10px;
    font-size: 12px;
    font-weight: 700;
    line-height: 16px;
  }
  
  /* ==========================================
     TYPOGRAPHY - PARAGRAPHS
     ========================================== */
  
  p {
    width: 100%;
    float: left;
    color: var(--midnight-blue);
    font-size: 12px;
    line-height: 16px;
  }
  
  strong {
    color: var(--royal-blue);
    font-weight: 700;
  }
  
  /* ==========================================
     LISTS
     ========================================== */
  
  .list {
    list-style-type: none;
  }
  
  ul {
    margin: 0;
    font-size: 12px;
    line-height: 18px;
  }
  
  ol {
    font-size: 12px;
    line-height: 18px;
  }
  
  li {
    margin-bottom: 10px;
    padding: 0 10px;
    font-size: 12px;
    line-height: 18px;
  }
  
  /* ==========================================
     TABLES - BASE STYLES
     ========================================== */
  
  .table {
    border-collapse: collapse;
    width: 100%;
    border: 1px solid var(--royal-blue);
    margin: 0 0 20px 0;
    font-size: 12px;
    line-height: 16px;
  }
  
  .table_cs {
    border-collapse: collapse;
    width: 100%;
    border: 1px solid var(--royal-blue);
    margin: 0 0 10px 0;
    font-size: 12px;
    line-height: 16px;
    break-before: page;
  }
  
  .caption {
    caption-side: top;
    text-align: left;
    margin: 0 0 10px 10px;
    line-height: 16px;
    font-weight: bold;
  }
  
  thead[id] {
    display: none;
  }
  
  thead {
    --pagedjs-table-repeat: repeat;
  }
  
  /* ==========================================
     TABLES - CELLS
     ========================================== */
  
  .th {
    border: 1px solid var(--royal-blue);
    vertical-align: top;
    text-align: center;
    padding: 10px;
    font-size: 12px;
    line-height: 16px;
  }
  
  .th.left {
    border-right: 1px solid var(--royal-blue);
    width: 30%;
  }
  
  .th.blue {
    background-color: var(--light-steel-blue);
    font-weight: 700;
  }
  
  .td {
    border: 1px solid var(--royal-blue);
    vertical-align: top;
    text-align: left;
    padding: 10px;
  }
  
  .td.left {
    border-right: 1px solid var(--royal-blue);
  }
  
  .td.illustration {
    vertical-align: top;
    border-color: var(--white);
    text-align: center;
  }
  
  .td.picture {
    border-bottom: 1px solid var(--royal-blue);
    text-align: center;
  }
  
  .td.blue {
    background-color: var(--light-steel-blue);
    font-weight: 700;
  }
  
  .td.alice {
    background-color: var(--alice-blue);
  }
  
  .td.grey {
    background-color: var(--light-grey);
  }
  
  /* ==========================================
     TABLES - WIDTH UTILITIES
     ========================================== */
  
  .th._10, .td._10 { width: 10%; }
  .th._20, .td._20 { width: 20%; }
  .th._30, .td._30 { width: 30%; }
  .th._33, .td._33 { width: 33.33%; }
  .th._40, .td._40 { width: 40%; }
  .th._50, .td._50 { width: 50%; }
  .th._70, .td._70 { width: 70%; }
  .th._75, .td._75 { width: 75%; }
  .th._80, .td._80 { width: 80%; }
  
  .td._10,
  .td._20 {
    text-align: center;
    font-weight: 700;
  }
  
  /* ==========================================
     TABLES - CONTENT
     ========================================== */
  
  .table p,
  .table_cs p {
    margin: 0;
    font-size: 12px;
    line-height: 16px;
    width: 100%;
    float: left;
  }
  
  p.table_p {
    float: left;
    padding: 0;
    width: 100%;
    margin: 0;
    line-height: 16px;
  }
  
  .table_p.foot {
    padding: 10px 0;
    font-style: italic;
  }
  
  .table_p.foot.center {
    text-align: center;
    font-style: normal;
    font-weight: 700;
  }
  
  .table_p._50 {
    width: 50%;
  }
  
  /* ==========================================
     TABLES - SPECIAL CASES
     ========================================== */
  
  .table.rotate {
    transform: rotate(-90deg);
  }
  
  .table_illustration {
    min-width: 100%;
  }
  
  .table_img {
    max-width: 50%;
  }
  
  .table_block {
    float: left;
    align-items: center;
    width: 100%;
    display: block;
  }
  
  .div_table_block {
    float: left;
    align-items: center;
    width: 100%;
    display: flex;
  }
  
  .div_table_foot {
    width: 100%;
    float: left;
  }
  
  /* ==========================================
     UTILITY BLOCKS
     ========================================== */
  
  .div_page_break {
    float: left;
    background-color: #fff;
    width: 100%;
    height: 5px;
    break-after: always;
  }
  
  .div_title {
    float: right;
    width: 100%;
    margin-top: 184mm;
    padding-right: 10mm;
    position: static;
  }
  
  .attention_block {
    float: left;
    text-align: center;
    width: 100%;
    padding-top: 20px;
  }
  
  .top_block {
    border: 1px solid var(--royal-blue);
    text-align: center;
    padding: 0 10px 10px 10px;
  }
  
  .big_block_picto {
    float: left;
    text-align: center;
    width: 100%;
  }
  
  /* ==========================================
     IMAGES & ICONS
     ========================================== */
  
  .img_picto {
    width: 40px;
    height: 40px;
    margin-right: 0;
  }
  
  .img_picto.big {
    width: 80px;
    height: 80px;
  }
  
  /* ==========================================
     LOGO & FORMS
     ========================================== */
  
  .div_logo_form {
    text-align: right;
    width: 100%;
  }
  
  .logo_form_img {
    text-align: right;
    width: 25%;
    margin-right: 0.5cm;
  }
  
  .linkcc {
    width: 150px;
    float: left;
  }
  
  /* ==========================================
     TABLE OF CONTENTS (TOC)
     ========================================== */
  
  /* Container principal de la TOC */
  #my-toc-content {
    break-after: avoid !important;
    page-break-after: avoid !important;
    break-inside: auto;
  }
  
  /* Élément qui suit la TOC */
  #my-toc-content + * {
    break-before: auto !important;
    page-break-before: auto !important;
  }
  
  /* Liste générée de la TOC */
  #list-toc-generated {
    list-style: none;
    overflow-x: hidden;
    counter-reset: counterTocLevel1;
    break-inside: auto;
    page-break-inside: auto;
  }
  
  /* Éléments de la TOC */
  .toc-element {
    display: flex;
    break-inside: avoid;
    page-break-inside: avoid;
  }
  
  /* Liens dans la TOC */
  .toc-element a {
    text-decoration: none;
    color: var(--midnight-blue);
    right: 0;
  }
  
  /* Numéro de page après le lien */
  .toc-element a::after {
    content: " p. " target-counter(attr(href), page);
    position: absolute;
    right: 0;
    float: right;
    background-color: white;
    padding-left: 6px;
  }
  
  /* Points de suite (leaders hack) */
  .toc-element::after {
    content: ".................................................................................................................................................";
    float: left;
    width: 0;
    padding-left: 5px;
    letter-spacing: 2px;
  color: var(--royal-blue);
  }
  
  /* TOC Niveau 1 (h2) */
  .toc-element-level-1 {
    margin-top: 25px;
    font-weight: bold;
    counter-increment: counterTocLevel1;
    counter-reset: counterTocLevel2;
    break-inside: avoid;
    page-break-inside: avoid;
  }
  
  .toc-element-level-1::before {
    content: counter(counterTocLevel1) ". ";
    padding-right: 5px;
  }
  
  /* TOC Niveau 2 (h3) */
  .toc-element-level-2 {
    margin-left: 25px;
    counter-increment: counterTocLevel2;
    break-inside: avoid;
    page-break-inside: avoid;
  }
  
  .toc-element-level-2::before {
    content: counter(counterTocLevel1) ". " counter(counterTocLevel2) ". ";
    padding-right: 5px;
  }
  
  /* TOC Niveau 3 (h4) */
  .toc-element-level-3,
  .toc-element-level-h4 {
    font-weight: normal;
    margin-left: 60px;
    break-inside: avoid;
    page-break-inside: avoid;
  }
  
  /* Orphans & Widows pour TOC */
  #list-toc-generated li {
    orphans: 2;
    widows: 2;
  }
}

/* ==========================================
   DEVELOPMENT ONLY (visible in screen mode)
   ========================================== */

.toc-ignore {
  background: orange;
}
