/**
 * theme.css: page look & feel
 *
 * @author Graham Eddy <ge@geddy.au>
 * @copyright (c)2021 Graham Eddy <ge@geddy.au>
 * @license GPLv3 https://www.gnu.org/licenses/gpl-3.0.en.html
 * @version 2025-03-12
 */

:root {
  --cfa-color: rgb(202,20,35); /* official CFA color #CA1423 */
  --light-cfa-color: rgba(202,20,35, 0.85);
  --pale-cfa-color: rgba(202,20,35, 0.2);
  --very-pale-cfa-color: rgba(202,20,35, 0.02);
  --pale-white: rgba(255,255,255, 0.8);

  --gap-sz: 1em;
  --pad-sz: 0.4em;
}

html {
  font-family: Geneva, Verdana, Arial, sans-serif;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
li, ol {
  margin-left: 1em;
}

body {
    display: grid;
    height: 100vh;
    grid-template-areas:
      "header header"
      "sidebar main"
      "footer footer";
    grid-template-rows: auto 1fr auto;
    grid-template-columns: max-content 1fr;
}
header { grid-area: header; }
#sidebar { grid-area: sidebar; }
main { grid-area: main; }
footer { grid-area: footer; }

noscript {
  background: red;
  color: black;
  font-weight: bold;
}
noscript::after {
  content: " Please enable javascript";
}

body > :not(header) a:not([rel*="external"]) {
  color: var(--cfa-color);
}
  a.fb:not(.button)::before {
    content: "";
    padding-left: 1.6em;
    margin-left: -0.4em;
    background-image: url(/static/images/fb-logo.png);
    background-size: cover;
  }
a[href$="TODO"] {
  text-decoration: dotted;
}

.avoid-break {
  break-inside: avoid/*-column*/;
}

/**********************************************************************/

header {
  display: grid;
  /*
  grid-template-areas:
    "logo title    menu cfa-logo"
    ".    subtitle menu .       ";
  grid-template-columns: 6em max-content 1fr 3.5em;
  */
  grid-template-areas:
    "logo           logo title    menu cfa-logo"
    "sidebar-toggle .    subtitle menu .       ";
  grid-template-columns: 0.5em 5.5em max-content 1fr 3.5em;
  padding: var(--gap-sz);
  background: var(--cfa-color);
  color: white;
}
  header #logo { grid-area: logo; }
  header #title { grid-area: title; }
  header #subtitle { grid-area: subtitle; }
  header #menu { grid-area: menu; }
  header #cfa-logo { grid-area: cfa-logo; }
  header #sidebar-toggle { grid-area: sidebar-toggle; }

  header h1 {
    font-size: 2.6em;
    white-space: nowrap;
  }
  header h2 {
  }
    header h2 time {
      font-size: 60%;
    }
      header h2 time::before {
        content: " ";
      }
  header img {
    height: 3.5em;
  }
  header nav {
    justify-self: center;
    align-self: center;
  }
    header nav ul {
      margin: 0;
      display: flex;
      align-items: flex-end;
      font-size: 120%;
    }
    header nav li {
      list-style: none;
      border-bottom: 0.1em solid var(--pale-white);
      padding-bottom: 0.2em;
    }
    header nav li.active {
      border-bottom: 0.3em solid var(--pale-white);
      padding-bottom: 0;
    }
    header nav li:first-of-type {
      margin-left: 0;
      padding-left: 0;
    }
    header nav a {
      color: var(--pale-white);
      text-decoration: none;
    }
    header nav img {
      height: 3em;
    }
  header #sidebar-toggle {
    justify-self: start;
  }

/**********************************************************************/

#sidebar {
  margin: var(--pad-sz) var(--gap-sz);
  color: var(--cfa-color);
}
  #sidebar section {
    margin-left: var(--pad-sz);
  }
  #sidebar h3 {
    margin: var(--pad-sz) 0;
  }
  #sidebar ul {
    margin-bottom: var(--pad-sz);
  }
  #sidebar li {
    margin-left: 0;
    list-style: none;
  }
  #sidebar figure {
    width: 12em;
  }
    #sidebar figure img {
      width: 100%;
    }

/**********************************************************************/

main {
  margin: var(--gap-sz);
}
  main h3 {
    font-size: 150%;
    /*white-space: nowrap;*/
  }
  main p {
    margin-bottom: var(--pad-sz);
    text-align: justify;
  }
  main p + ul {
    margin-top: calc(-1*var(--pad-sz));
  }
  main ul + p {
    margin-top: var(--pad-sz);
  }
  main aside {  /* float to right side */
    float: right;
    margin-left: var(--gap-sz);
    margin-right: 0;
  }
  main aside.contrary { /* float to left side */
    float: left;
    margin-left: 0;
    margin-right: var(--gap-sz);
  }
  main .fig-list { /* wrapping row of figures */
    /* figure content can be <h3> or <img> */
    margin: var(--gap-sz) 0;
    display: flex;
    flex-flow: row wrap;
    justify-content: space-evenly;
  }
    main aside p,
    main aside ul {
      margin: var(--pad-sz) 0 var(--pad-sz) var(--pad-sz);
      border-left: solid var(--pad-sz) var(--pale-cfa-color);
      padding-left: var(--pad-sz);
      font-size: 80%;
    }
    main aside p + ul {
      margin-top: calc(-1*var(--pad-sz));
    }
    main aside ul + p {
      margin-top: var(--pad-sz);
    }
    main aside p,
    main aside ul,
    main aside figure,
    main .fig-list figure {
      max-width: 28em;
      break-inside: avoid;
    }
      main aside figure img,
      main .fig-list figure img {
        width: 100%;
      }
      main aside figure figcaption,
      main .fig-list figure figcaption {
        width: 100%;
        font-size: 80%;
        font-style: italic;
      }
      main .fig-list figure h4 ~ figcaption {
        font-size: 100%;
        font-style: normal;
      }
  main .text-block { /* columnated large slab of text */
    columns: 28em;
    column-gap: 2em;
  }
    main .text-block h3 {
      break-after: avoid-column;
    }
  main ul.action-list {
    list-style: none;
    text-indent: 1.5em hanging;
  }
      main ul.action-list > li::before {
        content: "\2610\00A0";
      }
  main video {
    display: block;
    width: 100%;
    max-width: 50em;
    margin: auto;
  }
    main video p { }

/**********************************************************************/

footer {
  display: grid;
  grid-template-areas:
    "about-you contact-us ack-country"
    "about-us  contact-us ack-country"
    "copyright copyright  copyright";
  grid-template-columns: 1fr minmax(max-content, 1fr) minmax(22em, 1fr);
  margin: 0 var(--pad-sz);
  gap: var(--gap-sz);
  border: solid var(--pad-sz) var(--cfa-color);
  padding: var(--gap-sz) var(--gap-sz) 0 var(--gap-sz);
  background: var(--very-pale-cfa-color);
  color: var(--cfa-color);
  font-size: 95%;
}
  footer #about-you { grid-area: about-you; }
  footer #about-us { grid-area: about-us; }
  footer #contact-us { grid-area: contact-us; }
  footer #ack-country { grid-area: ack-country; }
  footer #copyright { grid-area: copyright; }

  footer h3 {
    margin-bottom: var(--pad-sz);
  }
  footer em {
    font-weight: bold;
  }
  footer p,
  footer ul {
    margin-bottom: var(--pad-sz);
  }
  footer ul,
  footer li {
    list-style: none;
    margin-left: 0;
  }
  footer #about-you,
  footer #about-us {
    width: 100%;
  }
    footer #about-you ul,
    footer #about-us ul {
      columns: 7em;
      column-gap: var(--pad-sz);
    }
    footer #about-you ul {
      columns: 8em;
    }
      footer #about-you li,
      footer #about-us li {
        margin-left: 0;
        white-space: nowrap;
      }
  footer #contact-us {
    justify-self: center;
  }
    footer #contact-us p {
      border: dotted 0.1em /*var(--pale-white);*/ var(--light-cfa-color);
      text-align: center;
      color: /*white;*/ var(--cfa-color);
    }
    footer #contact-us a {
      white-space: nowrap;
    }
    footer #ack-country figure {
      justify-self: end;
      display: flex;
      align-items: center;
      gap: 0.8em;
    }
    footer #ack-country figcaption {
      text-align: center;
    }
    footer #ack-country img {
      height: 2.4em;
      border: solid rgba(255,255,255, 0.5) 0.05em;
    }
  footer #copyright {
    text-align: center;
    color: /*white;*/ var(--cfa-color);
  }

/**********************************************************************/

@media (max-width: 1086px) {
  footer {
    grid-template-areas:
      "about-you  about-us"
      "contact-us about-us"
      "contact-us ack-country"
      "copyright  copyright";
    grid-template-columns: 1fr minmax(22em, 1fr);
  }
}
@media (max-width: 1056px) {
  header {
    /*
    grid-template-areas:
      "logo     title    cfa-logo"
      "menu     menu     menu    "
      "subtitle subtitle .       ";
    grid-template-columns: 6em 1fr 3.5em;
    */
    grid-template-areas:
      "logo           logo     title    cfa-logo"
      "menu           menu     menu     menu    "
      "sidebar-toggle .        subtitle subtitle";
    grid-template-columns: 1em 5em 1fr 3.5em;
  }
}
@media (max-width: 700px) {
  body {
    grid-template-areas:
      "header"
      "main"
      "sidebar"
      "footer";
    grid-template-rows: auto 1fr fit-content auto;
    grid-template-columns: 1fr;
  }
  #sidebar {
    border-top: solid 0.1em var(--pale-cfa-color);
  }
@media (max-width: 666px) {
  footer {
    grid-template-areas:
      "about-you"
      "contact-us"
      "about-us"
      "ack-country"
      "copyright";
    grid-template-columns: 1fr;
    justify-items: center;
}
@media (max-width: 594px) {
  header {
    font-size: 80%;
  }
}
@media (max-width: 478px) {
  header h1 {
    font-size: 200%;
  }
}
