/*
:filename: wexa_statics/css/wexa.css
:author: Brigitte Bigi
:contact: contact@sppas.org
:summary: a CSS framework to make nice accessible web content

-------------------------------------------------------------------------

This file is part of Whakerexa: https://whakerexa.sf.net/

Copyright (C) 2023-2024 Brigitte Bigi, CNRS
Laboratoire Parole et Langage, Aix-en-Provence, France

This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU Affero General Public License for more details.

You should have received a copy of the GNU Affero General Public License
along with this program.  If not, see <https://www.gnu.org/licenses/>.

This banner notice must not be removed.

-------------------------------------------------------------------------

*/

/* =======================================================================
                              FONTS DEFINITIONS

  See here: https://v-fonts.com/licenses/open-source for a list of open
  source variable fonts.

  Most of the time, the font size is calculated with the global --font-size
  variable. For example, this CSS is defining:
        font-size: calc(1.7 * var(--font-size));
  because when using "font-size: 1.7rem;" instead, the size of the font is
  not changed when switching to the contrast view.

  ======================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Commissioner:wght@100..900&family=JetBrains+Mono:ital,wght@0,100..800;1,100..800&family=Noto+Sans+Mono:wght@100..900&family=Noto+Serif:ital,wght@0,100..900;1,100..900');

@font-face {
    font-family: SansFont;
    src: url('../fonts/Commissioner.ttf') format('truetype');
}

@font-face {
    font-family: SerifFont;
    src: url('../fonts/SourceSerifPro.ttf') format('truetype');
}

@font-face {
    font-family: MonoFont;
    src: url('../fonts/FiraCode.ttf') format('truetype');
}

@font-face {
    font-family: PreFont;
    src: url('../fonts/NotoSansMono.ttf') format('truetype');
}

@font-face {
    font-family: ContrastFont;
    src: url("../fonts/AccessibleDfA-Regular.woff2");
    font-style: normal;
    font-weight: normal;
}

@font-face {
    font-family: ContrastFont;
    src: url("../fonts/AccessibleDfA-Italic.woff2");
    font-weight: normal;
    font-style: italic;
}

@font-face {
    font-family: ContrastFont;
    src: url("../fonts/AccessibleDfA-Bold.woff2");
    font-style: normal;
    font-weight: bold;
}

/* =======================================================================
                              OTHER DEFINITIONS
  ========================================================================
 */

@keyframes slideInFromLeft {
    0% {
        transform: translateX(-100%);
    }
    100% {
        transform: translateX(0);
    }
}
@keyframes slideInFromRight {
    0% {
        transform: translateX(100%);
    }
    100% {
        transform: translateX(0);
    }
}
@keyframes slideInFromTop {
    0% {
        transform: translateY(-100%);
    }
    100% {
        transform: translateX(0);
    }
}
@keyframes slideInFromBottom {
    0% {
        transform: translateY(100%);
    }
    100% {
        transform: translateX(0);
    }
}
@keyframes animDisabled {
    100% {
        transform: none;
    }
}

@keyframes fadeIn {
    0% {
        opacity: 0;
        transform: scaleY(0);
        display: none;
    }

    100% {
        opacity: 1;
        transform: scaleY(1);
        display: block;
    }
}

@keyframes fadeOut {
    0% {
        opacity: 1;
        transform: scaleY(1);
    }
    100% {
        opacity: 0;
        transform: scaleY(0);
    }
}

@keyframes animprogress {
    from { background-color: var(--progress-bg-color); }
    to { background-color: var(--footer-bg-color); }
}

/* =======================================================================
                            VARIABLE DEFINITIONS
  ======================================================================== */

:root {
    --size-divisor: 1;
    --fontsize-divisor: 1;
}

@media screen and (max-width: 540px) {
    :root {
        --size-divisor: 2.75;
        --fontsize-divisor: 1.5;
    }
}

@media screen and (min-width: 540px) {
    :root {
        --size-divisor: 2.5;
        --fontsize-divisor: 1.25;
    }
}

@media screen and (min-width: 620px) {
    :root {
        --size-divisor: 1.75;
        --fontsize-divisor: 1.18;
    }
}

@media screen and (min-width: 768px) {
    :root {
        --size-divisor: 1.5;
        --fontsize-divisor: 1.1;
    }
}

@media screen and (min-width: 896px) {
    :root {
        --size-divisor: 1.25;
        --fontsize-divisor: 1.05;
    }
}

@media screen and (min-width: 1100px) {
    :root {
        --size-divisor: 1;
    }
}

@media screen and (min-width: 1200px) {
    :root {
        --size-divisor: 0.9;
        --fontsize-divisor: 0.95;
    }
}

@media screen and (min-width: 1400px) {
    :root {
        --size-divisor: 0.8;
        --fontsize-divisor: 0.9;
    }
}

@media screen and (min-width: 1600px) {
    :root {
        --size-divisor: 0.75;
        --fontsize-divisor: 0.85;
    }
}

/* All global variables for any screen or condition */
/* ------------------------------------------------ */

@media not print {
    :root {
        /* Sizes */
        --screen-width: calc(1024px / var(--size-divisor));
        /* Animations and transitions */
        --header-slidein: slideInFromBottom;
        --footer-slidein: animDisabled;
        --transition: 0.4s ease-in-out;
    }
}

@media print {
    :root {
        /* Sizes */
        --screen-width: 720px;
        /* Animations and transitions */
        --header-slidein: none;
        --footer-slidein: none;
        --transition: none;
    }
}

:root {
    /* Sizes */
    --header-height: 60vh;
    --footer-height: 20vh;

    /* Font definitions */
    --font-family-sans: SansFont, Commissioner, 'Verdana', sans-serif;
    --font-family-serif: SerifFont, 'Noto Serif', 'Times New Roman', serif;
    --font-family-mono: MonoFont, JetBrains, 'Courier New', monospace;
    --font-family-pre: PreFont, 'Noto Sans', monospace, 'Courier New';

    /* Pictures */
    --external-link-icon: url("");
    --input-search-icon: url("");
    --checked-icon: url("");

    /* Focus & Hover */
    --outline-focus-style: outset;
    --outline-hover-style: inset;

    /* dialogs */
    --dialog-border-width: 2px;
    --dialog-border-radius: 4px;
    --dialog-box-shadow: -0.2rem 0.2rem 0.6rem 0.2rem rgba(128, 128, 128, 0.5);

}

/* Variables overridden by "contrast" */
:root:not(.contrast) {

    /* Font properties */
    /* CSS3 requires to choose 100 or 200. Intermediate values are not supported */
    --font-weight-thin: 200;
    --font-weight-semithin: 300;
    --font-weight-normal: 400;
    --font-weight-semibold: 500;
    --font-weight-bold: 600;
    --font-weight-black: 750;
    --font-size: calc(14px / var(--fontsize-divisor));
    --line-height: 1.2;
    --typography-spacing-vertical: calc(1.2 * 14px / var(--size-divisor));
    --typography-spacing-horizontal: calc(0.8 * 14px / var(--size-divisor));
    --letter-spacing: 0.04rem;
    --word-spacing: 0.06rem;

    /* Thin borders */
    --border-width: 1px;
    --border-radius: 2px;
    --table-border-width: 1px;
    --outline-size: 2px;
}

/* Re-define some global variables for disabilities */
.contrast {
    --header-slidein: animDisabled;
    --footer-slidein: animDisabled;

    /* Font properties (source: WCAG 2.1 - section 1.4.12 Text Spacing):
       - Line height (line spacing) to at least 1.5 times the font size;
       - Spacing following paragraphs to at least 2 times the font size;
       - Letter spacing (tracking) to at least 0.12 times the font size;
       - Word spacing to at least 0.16 times the font size.

    Conforming to this criteria provides accommodation for people to modify
    their text styles according to their needs. */

    --font-family-sans: ContrastFont, SansFont, 'Verdana', sans-serif;
    --font-weight-thin: 300;
    --font-weight-semithin: 400;
    --font-weight-normal: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 750;
    --font-weight-black: 800;
    --line-height: 1.5;
    --letter-spacing: 0.12rem;
    --word-spacing: 0.16rem;

    /* Larger borders */
    --border-width: 2px;
    --border-radius: 4px;
    --table-border-width: 2px;
    --outline-size: 3px;
}

/* ------------------------------------------------ */
/*      COLORS: Default color scheme is light       */
/* ------------------------------------------------ */

:root:not([data-theme=dark]), [data-theme=light], .light {
    /* Main colors */
    --bg-color: rgb(250, 250, 252);
    --bg-color-alt: rgb(240, 240, 240);
    --fg-color: rgb(0, 5, 10);
    --fg-color-alt: rgb(28, 28, 28);
    --border-color: rgb(60, 60, 90);
    --border-color-alt: rgba(28, 28, 28, 0.5);
    --outline-color: rgba(0, 191, 255, 0.8);

    /* Background colors */
    --header-bg-color: radial-gradient(circle, rgba(14, 18, 48, 0.9), rgb(24, 28, 38));
    --nav-bg-color: rgba(14, 18, 48, 0.7);
    --footer-bg-color: rgb(24, 28, 38);
    --buttons-bg-color: rgb(225, 225, 220);
    --progress-bg-color: rgb(49, 47, 85);
    --mark-bg-color: rgba(255, 250, 100, 0.5);
    --inputs-bg-color: rgba(225, 225, 220, 0.5);

    /* Foreground colors */
    --header-fg-color: rgb(241, 241, 245);
    --nav-fg-color: rgb(231, 231, 235);
    --footer-fg-color: rgb(241, 241, 245);
    --progress-fg-color: rgb(20, 25, 30);
    --buttons-fg-color: rgb(20, 25, 30);
    --mark-fg-color: rgb(20, 25, 30);
    --h1-color: rgb(20, 25, 30);
    --h2-color: rgb(30, 35, 45);
    --h3-color: rgb(40, 45, 60);
    --h4-color: rgb(40, 45, 60);
    --h5-color: rgb(50, 55, 75);
    --h6-color: rgb(60, 65, 90);

    /* Table colors */
    --table-border-color: rgba(110, 120, 140, 0.5);
    --table-row-stripped-bg-color: rgba(210, 212, 222, 0.4);
    --table-head-bg-color: rgb(204, 202, 212);
    --table-head-fg-color: rgb(14, 12, 22);
    --table-caption-bg-color: rgba(110, 120, 140, 0.5);
    --table-caption-fg-color: rgb(14, 12, 22);

    /* Other colors */
    --a-color: rgb(0, 120, 200);
    --ins-color: rgba(20, 200, 20, 0.8);
    --del-color: rgba(240, 40, 40, 0.8);
    --s-color: rgb(100, 100, 100);
    --blockquote-border-color: rgb(80, 25, 40);
    --blockquote-footer-color: rgb(80, 25, 40);
    --li-color: rgb(140, 40, 40);
    --shadow-color: rgba(110, 120, 140, 0.8);

    /* Alerts */
    --question-color: rgb(180, 80, 220);
    --question-bg-color: rgb(255, 210, 255);
    --tips-color: rgb(220, 180, 80);
    --tips-bg-color: rgb(240, 230, 210);
    --success-color: rgb(0, 150, 0);
    --success-bg-color: rgb(220, 255, 220);
    --error-color: rgb(200, 40, 10);
    --error-bg-color: rgb(255, 220, 220);
    --warning-color: rgb(255, 100, 20);
    --warning-bg-color: rgb(250, 215, 190);
    --info-color: rgb(40, 40, 200);
    --info-bg-color: rgb(220, 220, 255);
}

/*
@media screen,handheld,projection,tv,tty
or (prefers-color-scheme: dark)
*/
@media not print {
    .dark {
        /* Main colors */
        --bg-color: rgb(24, 28, 38);
        --bg-color-alt: rgb(38, 42, 54);
        --fg-color: rgb(255, 255, 255);
        --fg-color-alt: rgb(255, 255, 255);
        --border-color: rgb(228, 228, 228);
        --border-color-alt: rgba(228, 228, 228, 0.5);
        --outline-color: rgba(0, 191, 255, 0.8);

        /* Background colors */
        --header-bg-color: radial-gradient(circle, rgb(167, 187, 207), rgba(167, 187, 207, 0.7));
        --nav-bg-color: rgba(167, 187, 207, 0.7);
        --footer-bg-color: rgb(167, 187, 207);
        --buttons-bg-color: rgb(80, 80, 70);
        --progress-bg-color: rgb(67, 77, 97);
        --inputs-bg-color: rgba(80, 80, 70, 0.5);

        /* Foreground colors */
        --header-fg-color: rgb(41, 41, 45);
        --nav-fg-color: rgb(31, 31, 35);
        --footer-fg-color: rgb(41, 41, 45);
        --buttons-fg-color: rgb(225, 225, 215);
        --progress-fg-color: rgb(226, 226, 248);
        --h1-color: rgb(190, 204, 255);
        --h2-color: rgb(190, 204, 223);
        --h3-color: rgb(174, 190, 208);
        --h4-color: rgb(174, 190, 208);
        --h5-color: rgb(170, 180, 208);
        --h6-color: rgb(180, 190, 218);

        /* Table colors */
        --table-border-color: rgba(110, 120, 140, 0.5);
        --table-row-stripped-bg-color: rgb(42, 46, 59);
        --table-head-bg-color: rgb(8, 16, 10);
        --table-head-fg-color: rgb(204, 202, 212);
        --table-caption-bg-color: rgba(110, 120, 140, 0.5);
        --table-caption-fg-color: rgb(204, 202, 212);

        /* Other colors */
        --a-color: rgb(25, 195, 255);
        --s-color: rgb(180, 180, 180);
        --blockquote-border-color: rgb(200, 180, 200);
        --blockquote-footer-color: rgb(200, 180, 200);

        /* Alerts */
        --question-color: rgb(215, 115, 255);
        --question-bg-color: rgb(60, 0, 100);
        --tips-color: rgb(255, 215, 115);
        --tips-bg-color: rgb(110, 80, 0);
        --success-color: rgb(35, 185, 35);
        --success-bg-color: rgb(0, 80, 20);
        --error-color: rgb(235, 85, 55);
        --error-bg-color: rgb(80, 0, 0);
        --warning-color: rgb(255, 140, 60);
        --warning-bg-color: rgb(80, 20, 20);
        --info-color: rgb(110, 110, 255);
        --info-bg-color: rgb(0, 0, 80);
    }
}

/* Increase the bg/fg contrast of some colors in the default mode */
.contrast:not(.dark) {
    --a-color: rgb(10, 80, 120);
}

/* Font properties for a local context usage */
/* ----------------------------------------- */

.font-sans {
    font-family: var(--font-family-sans);
}

.font-serif {
    font-family: var(--font-family-serif);
}

.font-mono {
    font-family: var(--font-family-mono);
}

.font-pre {
    font-family: var(--font-family-pre);
}

.font-weight-thin {
    font-weight: var(--font-weight-thin);
}

.font-weight-normal {
    font-weight: var(--font-weight-normal);
}

.font-weight-semibold {
    font-weight: var(--font-weight-semibold);
}

.font-weight-bold {
    font-weight: var(--font-weight-bold);
}

.font-weight-black {
    font-weight: var(--font-weight-black);
}


/* =======================================================================
                       ACCESSIBILITY SPECIFIC STYLING
  ======================================================================== */

:is(a, video, input, area, select, button, input, textarea, summary) {
    --outline-offset: 0;
}

:is(a, video, input, area, select, button, input, textarea, summary):focus {
    outline: var(--outline-size) var(--outline-focus-style) var(--outline-color);
    outline-offset: var(--outline-offset, var(--outline-size));
}

:is(a, video, input, area, select, button, input, textarea, summary):focus-visible {
    outline: var(--outline-size) var(--outline-focus-style) var(--outline-color);
    outline-offset: var(--outline-offset, var(--outline-size));
}

:is(a, video, input, area, select, button, input, textarea, summary):focus:not(:focus-visible) {
    outline: none;
}

:is(a, video, input, area, select, button, input, textarea, summary):hover {
    outline: var(--outline-size) var(--outline-hover-style) var(--outline-color);
    outline-offset: var(--outline-offset, var(--outline-size));
    transition: none;
}


/* =======================================================================
                            HTML PAGE STYLING
  ======================================================================== */

* {
    margin: 0;
    padding: 0;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;

    background-color: var(--bg-color);
    color: var(--fg-color);

    font-size: var(--font-size);
    font-family: var(--font-family-sans);
    font-weight: var(--font-weight-normal);
    line-height: var(--line-height);
    letter-spacing: var(--letter-spacing) !important;
    word-spacing: var(--word-spacing) !important;
}

*, *:before, *:after {
    box-sizing: inherit;
}

*, ::after, ::before {
    box-sizing: border-box;
    background-repeat: no-repeat
}

*:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

*[aria-disabled=true] {
    opacity: 0.4;
    cursor: not-allowed;
    overflow: unset;
}

*[aria-disabled=true],
*[aria-disabled=true]:focus {
    opacity: 0.4;
    cursor: not-allowed;
}

::after, ::before {
    text-decoration: inherit;
    vertical-align: inherit
}

html {
    height: 100%;
    margin: auto;
    scroll-behavior: smooth;
    scrollbar-gutter: stable;
    overflow-x: hidden;
    overflow-y: scroll !important;

    /* The HTML background must be the same as the one of the body element
     even when switching the whole document to "dark" color theme. Turn it
     into transparent is an easy path to that! */
    background-color: rgba(255, 255, 255, 0);
}

body {
    margin: 0 auto;
    width: var(--screen-width);
    position: relative;
    cursor: default;

    background-color: var(--bg-color);
    background-clip: content-box;
    transition: all var(--border-color) 0.3s;
    transition-duration: 0.4s;

    -webkit-tap-highlight-color: transparent;
    -webkit-text-size-adjust: 100%;
    -moz-text-size-adjust: 100%;

    text-rendering: optimizeLegibility;
    overflow-wrap: break-word;

    -moz-tab-size: 4;
    tab-size: 4;
    flex-direction: column;
}


/* =======================================================================
                     HTML DOCUMENT STRUCTURE
   ======================================================================= */

header {
    color: var(--header-fg-color);
    background: var(--header-bg-color);
}

nav {
    color: var(--nav-fg-color);
    background: var(--nav-bg-color);
}

footer {
    background: var(--footer-bg-color);
    color: var(--footer-fg-color);
}

body > header {
    z-index: 10;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: none;
    margin: auto;
    text-align: center;
    min-height: var(--header-height);
    padding-bottom: var(--typography-spacing-vertical);
    animation: 1s ease-out 0s 1 var(--header-slidein);
}

body > header > nav {
    position: absolute;
    top: 2rem;
    right: 2.5rem;
}

/* Always visible navigation bar */
body > nav {
    z-index: 10;
    color: inherit;
    position: -webkit-sticky;  /* Safari */
    position: sticky;   /* is positioned based on the user's scroll position */
    top: 0;
    margin: auto;
    overflow: unset;
    /* box-shadow: [h-offset] [v-offset] [blur-radius] [spread-radius] [color]; */
    box-shadow: 0 0.3rem 0.4rem 0.2rem var(--shadow-color);
}

body > main {
    z-index: 1;
    /*background-color: var(--bg-color);*/
    margin-top: var(--typography-spacing-vertical);
    margin-bottom: var(--typography-spacing-vertical);
}

body > footer {
    z-index: 10;
    text-align: center;
    margin: auto;
    padding-top: var(--typography-spacing-vertical);
    min-height: var(--footer-height);
    animation: 1s ease-out 0s 1 var(--footer-slidein);
}

/* Elements inside */
/* All elements in any header/footer/nav must have same colors than the parent.
It also means that links won't be blue! */

header *, body > header * {
    color: var(--header-fg-color);
    background-color: transparent;
}

nav *, body > nav * {
    color: var(--nav-fg-color);
    background-color: transparent;
}

footer *, body > footer * {
    color: var(--footer-fg-color);
    background-color: transparent;
}

body > header > *,  body > footer > * {
    z-index: 1;
    text-align: center;
    padding-top: var(--typography-spacing-vertical);
}



/* =======================================================================
                       HTML ELEMENTS STYLING
  ======================================================================== */

/* -------------------------------- menu --------------------------------- */

nav {
    text-align: center;
    margin: auto;
    padding-left: var(--typography-spacing-horizontal);
    padding-right: var(--typography-spacing-horizontal);
    min-height: calc(4rem / var(--size-divisor));
    display: flex;
    justify-content: space-evenly;
    align-items: center;
    flex-wrap: wrap;
    row-gap: calc(1rem / var(--size-divisor));
    column-gap: calc(1rem / var(--size-divisor));
}

nav * {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    flex-direction: row;
    row-gap: 0.3rem;
    column-gap: 0.3rem;
}

nav ul, nav dl {
    list-style: none;
    margin: 0;
    text-align: center;
}

nav li, nav dt, nav dd, nav a {
    padding: calc(var(--typography-spacing-horizontal) * 0.35) calc(var(--typography-spacing-vertical) * 0.35);
    margin: 0;
}

[role=menuitem] {
    text-decoration: none;
}

/* ---------------------------- section/article ------------------------------ */

main > section,
main > * section {
    padding-top: var(--typography-spacing-vertical);
    padding-bottom: var(--typography-spacing-vertical);
    padding-left: var(--typography-spacing-horizontal);
    padding-right: var(--typography-spacing-horizontal);
}

/* ---------------------------- Head titles ------------------------------ */

h1, h2, h3, h4, h5, h6 {
    margin-top: var(--typography-spacing-vertical);
    margin-bottom: var(--typography-spacing-vertical);
    font: var(--font-family-sans);
}

h1 {
    color: var(--h1-color);
    font-weight: var(--font-weight-bold);
    letter-spacing: calc(4*var(--letter-spacing));
}

body > header > h1,
body > footer > h1,
body > footer > * h1
{
    font-size: calc(3 * var(--font-size));
}

body > main > h1,
body > main > * h1
{
    font-size: calc(2.25*var(--font-size));
    line-height: calc(2.25*var(--typography-spacing-vertical));
    padding-bottom: calc(1.5 * var(--typography-spacing-vertical));
}

h2 {
    color: var(--h2-color);
    font-weight: var(--font-weight-bold);
    letter-spacing: calc(3*var(--letter-spacing));
}

body > main > h2,
body > main > * h2 {
    font-size: calc(1.8 * var(--font-size));
    line-height: calc(1.8 * var(--typography-spacing-vertical));
    padding-bottom: var(--typography-spacing-vertical);
    position: relative;
}

body > header > h2,
body > footer > h2
{
    font-size: calc(1.8 * var(--font-size));
}

h3 {
    font-size: calc(1.5 * var(--font-size));
    line-height: calc(1.5 * var(--typography-spacing-vertical));
    font-weight: var(--font-weight-semibold);
    color: var(--h3-color);
    letter-spacing: calc(2*var(--letter-spacing));
}

h4 {
    font-size: calc(1.3 * var(--font-size));
    letter-spacing: calc(1.4*var(--letter-spacing));
    color: var(--h4-color);
    font-weight: var(--font-weight-semibold);
}

h5 {
    font-size: calc(1.1 * var(--font-size));
    letter-spacing: calc(1.2*var(--letter-spacing));
    color: var(--h5-color);
}

h6 {
    font-style: italic;
    color: var(--h6-color);
}

/* ---------------------- Text & inline text ----------------------------- */

p {
    font: inherit;
    padding-bottom: var(--typography-spacing-vertical) !important;
    display: block;
}

b {
    font: inherit;
    font-weight: var(--font-weight-bold);
}

strong {
    font: inherit;
    font-weight: var(--font-weight-black);
}

mark {
    font: inherit;
    border-radius: 0.2rem;
    background: var(--mark-bg-color);
    color: var(--mark-fg-color);
    padding: 0.1rem;
}

small {
    font: inherit;
    font-size: calc(0.8 * var(--font-size));
}

sub, sup {
    font: inherit;
    font-size: calc(0.75 * var(--font-size));
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -0.25em
}

sup {
    top: -0.5em
}

code, kbd, samp, var, output {
    font-family: var(--font-family-mono);
    font-size: calc(0.9 * var(--font-size));
}

kbd {
    border: 1px solid var(--border-color);
    border-radius: 3px;
    font-weight: bolder;
    border-bottom: 2px solid var(--border-color);
}

code {
    background: var(--table-row-stripped-bg-color);
    border-radius: 0.2rem;
    display: inline-block;
    line-height: 1.125rem;
    padding: 0.225rem 0.4rem 0.16rem
}

pre {
    font-family: var(--font-family-pre);
    font-size: calc(0.9 * var(--font-size));
    padding-top: calc(0.35*var(--typography-spacing-vertical));
    padding-bottom: calc(0.35*var(--typography-spacing-vertical));
    padding-left: var(--typography-spacing-horizontal);
    margin-left: var(--typography-spacing-horizontal);
    margin-bottom: var(--typography-spacing-horizontal);
    overflow: auto;
    border-left: calc(2*var(--border-width)) solid var(--shadow-color);
}

ins {
    color: var(--ins-color);
    text-decoration: none;
}

del {
    color: var(--del-color);
}

s {
    color: var(--s-color);
}

blockquote {
    /*background-color: var(--bg-color-alt);*/
    background-image: linear-gradient(to right, var(--bg-color-alt), var(--bg-color));
    display: block;
    padding: var(--typography-spacing-vertical);
    margin-top: calc(0.5*var(--typography-spacing-horizontal));
    margin-bottom: calc(1.5*var(--typography-spacing-vertical));
    margin-left: calc(2*var(--typography-spacing-horizontal));
    margin-right: calc(2*var(--typography-spacing-horizontal));
    border-right: none;
    border-top: 1px solid var(--blockquote-border-color);
    border-bottom: 1px solid var(--blockquote-border-color);
    border-left: 2rem solid var(--blockquote-border-color);
    border-inline-start: 0.25rem solid var(--blockquote-border-color);
    border-inline-end: none
}

blockquote > cite {
    display: block;
    margin-top: var(--typography-spacing-vertical);
    color: var(--blockquote-footer-color);
}

blockquote, blockquote > p, blockquote > a {
    font-weight: var(--font-weight-semibold);
}

blockquote * {
    background-color: transparent;
}

a, [role=link] {
    color: var(--a-color);
    -webkit-transition-duration: 0.2s;
    -moz-transition-duration: 0.2s;
    -o-transition-duration: 0.2s;
    transition-duration: 0.2s;
    line-height: calc(0.85*var(--line-height));
    opacity: 90%;
}

a > *, [role=link] > * {
    color: var(--a-color);
}

:where(a:not([role=button])), [role=link] {
    text-underline-offset: 0.25em;
}

a:hover {
    opacity: 100%;
}

a.external-link::after {
    position: relative;
    content: "";
    background-image: var(--external-link-icon);
    background-size: 100% 100%;
    display: inline-block;
    width: calc(0.85 * var(--font-size));
    height: calc(0.85 * var(--font-size));
    padding-top: calc(0.1 * var(--font-size));;
    margin-left: 0.2rem;
    margin-right: 0.2rem;
    text-decoration: underline;
}

/* ----------------- Button, Label and Input tags ----------------------- */

button, input, a[role=button], select, textarea {
    overflow: visible;
}

button, select, a[role=button], select, textarea {
    text-transform: none;
    text-decoration: none;
}

button, [type=button], [type=reset], [type=submit], [role=button] {
    -webkit-appearance: button;
}

button, *[role=button], *[role=menuitem], summary {
    background-color: var(--buttons-bg-color);
    color: var(--buttons-fg-color);

    cursor: pointer;
    transition: all 0.4s;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    padding: 0.2rem;
    margin: 0;
}

button, *[role=button], *[role=menuitem] {
    border: var(--border-width) solid var(--border-color);
    border-radius: var(--border-radius);

    /* Ensure a minimum of character + padding */
    min-height: calc(var(--font-size) * 1.2);
    min-width: calc(var(--font-size) * 1.2);

    font-weight: normal;
    font-style: normal;
    font-variant: normal;
    font-size: 0.9rem;
    overflow: hidden;

    /* a button is a box with centered elements */
    display: inline-flex;
    justify-content: center;
    align-items: center;
    flex-direction: row;

    /* for the buttons embedded in a box */
    flex-grow: 0;      /* default is 0 */
    flex-shrink: 1;    /* default is 1 */
    flex-basis: auto;  /* default is auto */
}

[role=button]:is(:hover,:active,:focus),
[role=button]:is([aria-current]:not([aria-current=false])),
[type=button]:is(:hover,:active,:focus),
[type=button]:is([aria-current]:not([aria-current=false])),
[type=file]::file-selector-button:is(:hover,:active,:focus),
[type=file]::file-selector-button:is([aria-current]:not([aria-current=false])),
[type=reset]:is(:hover,:active,:focus),
[type=reset]:is([aria-current]:not([aria-current=false])),
[type=submit]:is(:hover,:active,:focus),
[type=submit]:is([aria-current]:not([aria-current=false])),
button:enabled:is(:hover,:active,:focus),
button:enabled:is([aria-current]:not([aria-current=false])),
summary:is(:hover,:active,:focus) {
    opacity: 75%;
}

button:enabled img:hover {
    /*transform: scale(1.2);*/
    opacity: 75%;
}

/* Propagate button colors to its children */
button *, *[role=button] *, *[role=menuitem] * {
    background-color: transparent;
    color: var(--buttons-fg-color);
}

/* --------------------------------- List(s) ----------------------------- */

ol, ul, dl {
    margin-bottom: var(--typography-spacing-vertical);
    background-color: unset;
    padding-left: calc(0.5*var(--typography-spacing-horizontal));
}

ul > li > ul {
    margin-bottom: 0;
}

ul > li > ul > li > ul {
    margin-bottom: 0;
}

/* Margin to right only from the 2nd level */
ul > li {
    list-style-type: none;
    list-style-position: outside;
    /*list-style-image: none;*/
    line-height: calc(1.2 * var(--line-height));
}

ul > li > ul > * {
    list-style-type: none;
    list-style-position: inside;
    list-style-image: none;
}

ul:not(nav *) > li:before {
    content: "■";
    padding-right: var(--typography-spacing-horizontal);
    color: var(--li-color);
}

ul:not(nav *) > li > ul > li:before {
    content: "◇";
    padding-right: var(--typography-spacing-horizontal);
    padding-left: var(--typography-spacing-horizontal);
    color: var(--li-color);
}

ul:not(nav *)  > li > ul> li> ul > li:before {
    content: "□";
    padding-right: var(--typography-spacing-horizontal);
    padding-left: calc(2 * var(--typography-spacing-horizontal));
    color: var(--li-color);
}

/* Add a dot after the item number */
ol {
    counter-reset: item;
}

ol > li {
    counter-increment: item;
    list-style-type: none; /* si nécessaire */
}

ol > li:before {
    content: counter(item) ". ";
    color: var(--li-color);
    font-weight: var(--font-weight-semibold);
}

dl {
    display: inline-block
}

dt {
    font-weight: var(--font-weight-semibold);
}

dd {
    padding-left: calc(0.5*var(--typography-spacing-horizontal));
}

dd:before {
    content: "➙ ";
    color: var(--li-color);
}

dd+dt {
    padding-top: calc(0.35*var(--typography-spacing-vertical));
}

/* -------------------------------- Table(s) ----------------------------- */

:where(table) {
    width: 100%;
    border-collapse: collapse;
    text-indent: 0;
    empty-cells: show;
    margin-bottom: var(--typography-spacing-vertical);
    caption-side: bottom;
    border: var(--table-border-width) solid var(--table-border-color);
}

td, th {
    padding: calc(var(--typography-spacing-horizontal) / 2) var(--typography-spacing-horizontal);
    color: var(--fg-color);
    font-weight: var(--font-weight-normal);
    font-size: var(--font-size);
    text-align: left;
    border-left: var(--table-border-width) dashed var(--table-border-color);
    border-bottom: var(--table-border-width) solid var(--table-border-color);
}

table[role=grid] thead * {
    background-color: var(--table-head-bg-color);
    color: var(--table-head-fg-color);
    font-weight: var(--font-weight-bold);
}

thead td, thead th {
    padding: var(--typography-spacing-horizontal) calc(var(--typography-spacing-vertical)) ;
}

tfoot td, tfoot th {
    border-top: var(--table-border-width) solid var(--table-border-color);
    border-bottom: 0;
}

table[role=grid] tbody tr:nth-child(even) * {
    background-color: var(--table-row-stripped-bg-color);
}

table caption {
    background-color: var(--table-caption-bg-color);
    color: var(--table-caption-fg-color);
    text-align: center;
    margin: auto;
}

caption {
    padding-left: calc(2 * var(--table-border-width));
    text-align: left;
    padding-top: 0.3rem;
    padding-bottom: 0.3rem;
    font-size: 80%;
    font-weight: var(--font-weight-semibold);
}

caption span {
    font-style: italic;
    background-color: transparent;
    color: inherit;
}

[role=presentation], table[role=presentation] td {
    border: none;
    text-align: left;
}

table[role="grid"] {
    width: 100%;
    table-layout: fixed; /* All columns will have equal width based on the table width */
    border-collapse: collapse;
}

table[role="grid"] th,
table[role="grid"] td {
    width: 10%; /* Set a default width for each column */
    max-width: 50%; /* Limit the width of any column */
    overflow: hidden; /* Prevent content from overflowing */
    word-wrap: break-word; /* Break words to avoid overflow */
}

table {
    max-width: 100%;
    overflow-x: auto;
}


/* ----------------- media & figure ----------- */

figure {
    margin: auto;
    text-align: center;
}

figcaption {
    font-size: 0.9rem;
    text-align: center;
    color: var(--table-caption-bg-color);
}

video {
    margin: auto;
    max-width: 90%;
}

img {
    max-width: 100%;
}

/* ----------------- progress ----------- */

progress {
    width: 100%;
    height: 2rem;
    border: none;
    border-radius: var(--border-radius);
    background: var(--progress-bg-color);
    overflow: hidden;
    color: var(--progress-fg-color);
}

/* Background style for webkit */
progress::-webkit-progress-bar {
    background: var(--progress-bg-color);
    border-radius: var(--border-radius);
}
progress::-webkit-progress-value {
    background: var(--progress-bg-color);
    border-radius: var(--border-radius);
}

/* Background style for Firefox */
progress::-moz-progress-bar {
    background: var(--progress-bg-color);
    border-radius: var(--border-radius);
}

/* ----------------- others ----------- */

hr {
    box-sizing: content-box;
    height: 0;
    overflow: visible;
    border: 0;
    border-top: 1px solid rgba(128, 128, 128, 0.5);
    margin: 1rem 0
}

/* =======================================================================
                        Others
   ======================================================================= */

details {
    border: var(--border-width) solid var(--border-color-alt);
    border-radius: var(--border-radius);
    padding: 0;
    margin-bottom: var(--typography-spacing-vertical);
}

details > *:not(summary) {
    padding-left: var(--typography-spacing-horizontal);
}

summary {
    font-weight: var(--font-weight-semibold);
    border: none;
    margin: 0;
    vertical-align: middle;
    /*height: 2.4rem;*/

    /* Ensure a minimum of semibold-character + padding*/
    min-height: calc(var(--font-size) * 1.2);
    min-width: calc(var(--font-size) * 3);
}

details[open] summary {
    margin-bottom: var(--typography-spacing-vertical);
}

details[open] > *:not(summary) {
    -webkit-animation: fadeIn 0.2s linear forwards;
    animation: fadeIn 0.2s linear forwards;
}

/* Buttons inside a summary element are at right. */
summary button, summary a[role=button] {
    float: right;
    margin: 0;
    padding: 0;
    padding-left: 0.2rem;
    padding-right: 0.2rem;
    margin-left: 0.2rem;
    margin-rigth: 0.2rem;
    vertical-align: center;
    max-height: 90%;
    width: auto;
}


:where(svg:not([fill])) {
    fill:currentColor
}
svg:not(:root) {
    overflow:hidden
}

aside {
    float: right;
    width: calc(0.35*var(--screen-width));
}

/* -------------------- FORMS -------------------- */

form {
    margin-bottom: var(--typography-spacing-vertical);
}

form * {
    border-radius: var(--border-radius);
}

/* Form: fieldset */

fieldset {
    width: 100%;
    border: var(--border-width) solid var(--border-color);
    border-radius: var(--border-radius);
    padding: 0.5rem 1.5rem;
    margin: 0;
}

fieldset legend {
    max-width: 90%;
    display: block;
    margin-bottom: calc(var(--typography-spacing-vertical) * 0.5);
    font-weight: var(--font-weight-semibold);
    color: var(--bg-color-alt);
    background-color: var(--fg-color-alt);
    padding: 0.4rem;
    white-space: normal;
}

fieldset legend * {
    color: var(--bg-color-alt);
    background-color: transparent;
}

/* Form: label */

label {
    display: block;
    margin-bottom: calc(var(--typography-spacing-vertical) * 0.5);
}

label > :where(input, select, textarea) {
    margin-top: calc(var(--typography-spacing-vertical) * 0.25)
}

label:has([type=checkbox],[type=radio]) {
    width: -moz-fit-content;
    width: fit-content;
    cursor: pointer
}

/* Form: any type of inputs: input, select, textarea... */

button[type=submit], input:not([type=checkbox],[type=radio]), select, textarea {
    width: 80%
}

input, select, textarea {
    margin-bottom: var(--typography-spacing-vertical);
    padding-top: 0.3rem;
    padding-bottom: 0.3rem;
}

input:not([type=checkbox],[type=radio]), select, textarea {
    display: block;
    font-family: var(--font-family-serif);
    background-color: var(--inputs-bg-color);
    color: var(--fg-color-alt);
    border: var(--border-width) solid var(--border-color-alt);
    transition: 0.5s ease-in-out border-bottom;
}

input[type=text], select, option, optgroup, textarea {
    color: var(--fg-color-alt);
    padding-top: 0.3rem;
    padding-bottom: 0.3rem;
}

input:not([type=checkbox],[type=radio],[type=range],[type=file]), textarea {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding: calc(var(--typography-spacing-vertical) * 0.5) calc(var(--typography-spacing-horizontal) * 0.5)
}

textarea {
    display: block;
    resize: vertical;
    overflow: auto;
}

/* Form: select */

select::-ms-expand {
    border:0;
    background-color: transparent
}

select[multiple] option:checked {
    background: var(--buttons-bg-color);
}

select[multiple] option:checked::before {
    position: relative;
    content: "";
    background-image: var(--checked-icon);
    background-size: 100% 100%;
    display: inline-block;
    width: calc(0.85 * var(--font-size));
    height: calc(0.85 * var(--font-size));
    padding-top: calc(0.1 * var(--font-size));;
    margin-right: 0.3rem;
    text-decoration: underline;
}

select {
    padding: calc(var(--typography-spacing-vertical) * 0.25) calc(var(--typography-spacing-horizontal) * 0.25);
    text-transform: none;
}

select * {
    background-color: transparent;
}

/* Form: option/optgroup */

option {
    font-size: 1.1rem;
    font-family: var(--font-family-serif);
}

optgroup {
    font-weight: var(--font-weight-semibold);
    border-top: var(--border-width) solid var(--fg-color-alt);
}

option {
    border-top: var(--border-width) solid var(--fg-color-alt);
}

optgroup > option {
    border: none;
    padding-left: 1rem;
}

/* Form: input(s) */

input {
    overflow: visible
}

input[role="button"],
input[type="submit"],
input[type="search"],
input[name="search"],
input[type="reset"] {
    margin-top: var(--typography-spacing-vertical);
    margin-bottom: var(--typography-spacing-vertical);
}

input[type="checkbox"],
input[type="radio"] {
    margin-left: 0.5rem;
    margin-right: 0.5rem;
    margin-bottom: 0;
}

input[name=search] {
    box-sizing: border-box;
    background-image: var(--input-search-icon);
    background-position: left center;
    background-size: 1.5rem 1.5rem;
    background-repeat: no-repeat;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    padding-left: 2rem;
    transition: width 0.4s ease-in-out;
    vertical-align: center;
    width: 50%;
}

input[name=search]:hover {
    width: 80%;
}

[type=button], [type=reset], [type=submit] {
    margin-bottom:var(--typography-spacing-vertical)
}

:is(button,[type=submit],[type=button],[role=button]).secondary,[type=file]::file-selector-button,[type=reset] {
    cursor: pointer
}

[type=file], [type=range] {
    padding: 0;
    border-width: 0
}

input:not([type=checkbox],[type=radio],[type=range]) {
    height: calc(1rem * var(--line-height) + var(--typography-spacing-vertical) * 1.2 + var(--border-width) * 1.2)
}

/* Form: checkbox / radiobox */

[type=checkbox], [type=radio] {
    width: 1.1em;
    height: 1.1em;
    cursor: pointer;
    margin-right: 0.5rem;
}

[type=checkbox]~label, [type=radio]~label {
    display: inline-block;
    margin-bottom: 0;
    cursor: pointer
}

[type=checkbox]~label:not(:last-of-type),[type=radio]~label:not(:last-of-type) {
    margin-inline-end: 1em
}

/* =======================================================================
                           Dialogs
   ======================================================================= */


dialog {
    padding-left: var(--typography-spacing-horizontal);
    padding-right: var(--typography-spacing-horizontal);
    padding-top: var(--typography-spacing-vertical);
    padding-bottom: var(--typography-spacing-vertical);
    z-index: 20;
    border-radius: var(--dialog-border-radius);
    border: var(--dialog-border-width) solid var(--border-color);
    box-shadow: var(--dialog-box-shadow);
    margin: 0;
    margin-top: var(--typography-spacing-vertical);
    margin-bottom: var(--typography-spacing-vertical);
    animation: fadeOut 0.7s ease-out;
}

dialog[open] {
    opacity: 1;
    position: relative;
    margin: auto;
    animation: fadeIn 0.7s ease-out;
    overscroll-behavior: contain;
}

dialog[role=alertdialog] {
    display: block;
    position: relative;
    border-left: calc(4*var(--dialog-border-width)) solid;
}

dialog[role=alertdialog].hidden-alert {
    display: none;
    position: revert;
}

dialog[role=alertdialog] * {
    background: transparent;
}

/*
 * Select only the dialogs which are 'modal' (doesn't affect dialog open by default in the html).
 * The css 'position' of modal dialog doesn't have to be relative
 * to avoid the scroll at the top of the page !
 * Default css value for modal dialog is fixed.
:modal[open] {
    position: fixed;
}
*/
/* Everything behind an opened modal dialog */
::backdrop {
    backdrop-filter: grayscale(90%) blur(0.3rem);
}

/* =======================================================================
                           Printing rules
   ======================================================================= */

/* ------------ Override any already defined properties ------------------ */

@media print {

    html {
        background: white;  /* For toner saving */
    }

    body {
        background: white;  /* For toner saving */
        display: block;
    }

    main > section, main > * section {
        padding: 0;
    }

    figure, table, img, svg {
        break-inside: avoid;
        break-before: region;
    }

    section, article, article p {
        orphans: 2; /* no less than 2 lines at the bottom of the page */
        widows: 2;  /* no less than 2 lines at the top of next page */
    }

    /* ---------------- Optional formatting rules ------------------------ */

    /* Force a page break immediately prior to any "chapter" section. */
    .chapter {
        break-before: always;
    }

    /* For any element to force adding a blank page */
    .blank-page {
        page: blank;
        page-break-after: always;
    }

    /* For any element that will be hidden when printing: */
    .print-off {
        display: none;
    }

}
