﻿:root
{
  --fore-color: #111;
  --secondary-fore-color: #444;
  --back-color: #f8f8f8;
  --secondary-back-color: #f0f0f0;
  --blockquote-color: #f57c00;
  --pre-color: #1565c0;
  --border-color: #aaa;
  --secondary-border-color: #ddd;
  --heading-ratio: 1.3;
  --universal-margin: .45rem;
  --universal-padding: .45rem;
  --universal-border-radius: .125rem;
  --a-link-color: #0277bd;
  --a-visited-color: #01579b;
}

html
{
  font-size: 16px;
}

a,b,del,em,i,ins,q,span,strong,u
{
  font-size: 1em;
}

html,*
{
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Ubuntu, "Helvetica Neue", Helvetica, sans-serif;
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
}

*
{
  font-size: 1rem;
}

body
{
  margin: 0;
  color: var(--fore-color);
  background: var(--back-color);
}

details
{
  display: block;
}

summary
{
  display: list-item;
}

abbr[title]
{
  border-bottom: none;
  text-decoration: underline dotted;
}

input
{
  overflow: visible;
}

img
{
  max-width: 100%;
  height: auto;
}
img.left
{float:left;margin-right:2em}

h1,h2,h3,h4,h5,h6
{
  line-height: 1.2;
  margin: calc(1.5 * var(--universal-margin)) var(--universal-margin);
  font-weight: 500;

}

h1 small,h2 small,h3 small,h4 small,h5 small,h6 small
{
  color: var(--secondary-fore-color);
  display: block;
  margin-top: -.25rem;
}

h1
{
  font-size: calc(1rem * var(--heading-ratio) * var(--heading-ratio) * var(--heading-ratio) * var(--heading-ratio));
  font-family: 'Amatic SC', cursive;
}

h2
{
  font-size: calc(.9rem * var(--heading-ratio) * var(--heading-ratio) * var(--heading-ratio));
    font-family: 'Amatic SC', cursive;
}

h3
{
  font-size: calc(1rem * var(--heading-ratio) * var(--heading-ratio));
}

h4
{
  font-size: calc(1rem * var(--heading-ratio));
}

h5
{
  font-size: 1rem;
}

h6
{
  font-size: calc(1rem / var(--heading-ratio));
}

p
{
  margin: var(--universal-margin);
}

ol,ul
{
  margin: var(--universal-margin);
  padding-left: calc(2 * var(--universal-margin));
}

b,strong
{
  font-weight: 700;
}

hr
{
  box-sizing: content-box;
  border: 0;
  line-height: 1.25em;
  margin: var(--universal-margin);
  height: .0625rem;
  background: linear-gradient(to right, transparent, var(--border-color) 20%, var(--border-color) 80%, transparent);
}

blockquote
{
  display: block;
  position: relative;
  font-style: italic;
  color: var(--secondary-fore-color);
  margin: var(--universal-margin);
  padding: calc(3 * var(--universal-padding));
  border: .0625rem solid var(--secondary-border-color);
  border-left: .375rem solid var(--blockquote-color);
  border-radius: 0 var(--universal-border-radius) var(--universal-border-radius) 0;
}

blockquote:before
{
  position: absolute;
  top: calc(0rem - var(--universal-padding));
  left: 0;
  font-family: sans-serif;
  font-size: 3rem;
  font-weight: 700;
  content: "\201c";
  color: var(--blockquote-color);
}

blockquote[cite]:after
{
  font-style: normal;
  font-size: .75em;
  font-weight: 700;
  content: "\a—  " attr(cite);
  white-space: pre;
}

code,kbd,pre,samp
{
  font-family: Menlo, Consolas, monospace;
  font-size: .85em;
}

code
{
  background: var(--secondary-back-color);
  border-radius: var(--universal-border-radius);
  padding: calc(var(--universal-padding) / 4) calc(var(--universal-padding) / 2);
}

kbd
{
  background: var(--fore-color);
  color: var(--back-color);
  border-radius: var(--universal-border-radius);
  padding: calc(var(--universal-padding) / 4) calc(var(--universal-padding) / 2);
}

pre
{
  overflow: auto;
  background: var(--secondary-back-color);
  padding: calc(1.5 * var(--universal-padding));
  margin: var(--universal-margin);
  border: .0625rem solid var(--secondary-border-color);
  border-left: .25rem solid var(--pre-color);
  border-radius: 0 var(--universal-border-radius) var(--universal-border-radius) 0;
}

sup,sub,code,kbd
{
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

small,sup,sub,figcaption
{
  font-size: .75em;
}

sup
{
  top: -.5em;
}

sub
{
  bottom: -.25em;
}

figure
{
  margin: var(--universal-margin);
}

figcaption
{
  color: var(--secondary-fore-color);
}

a
{
  text-decoration: none;
}

a:link
{
  color: var(--a-link-color);
}

a:visited
{
  color: var(--a-visited-color);
}

a:hover,a:focus
{
  text-decoration: underline;
}

/*couleurs*/

.fd-gris{background-color:#f1f1f1}

/* grille*/
.comBox{margin: calc(6 * var(--universal-margin)) 0;border-top:1px dotted #ccc;padding-top:calc(var(--universal-padding) / 2);}
.container
{
  margin: 0 auto;
  padding: 0 calc(1.5 * var(--universal-padding));
  max-width:1080px;
}
.center
{text-align:center;}
.right
{text-align:right;width:100%}
.row
{
  box-sizing: border-box;
  display: flex;
  flex: 0 1 auto;
  flex-flow: row wrap;
}

.col-sm,[class^='col-sm-'],[class^='col-sm-offset-'],.row[class*='cols-sm-']>*
{
  box-sizing: border-box;
  flex: 0 0 auto;
  padding: 0 calc(var(--universal-padding) / 2);
}

.col-sm,.row.cols-sm>*
{
  max-width: 100%;
  flex-grow: 1;
  flex-basis: 0;
}

.col-sm-1,.row.cols-sm-1>*
{
  max-width: 8.33333%;
  flex-basis: 8.33333%;
}

.col-sm-offset-0
{
  margin-left: 0;
}

.col-sm-2,.row.cols-sm-2>*
{
  max-width: 16.66667%;
  flex-basis: 16.66667%;
}

.col-sm-offset-1
{
  margin-left: 8.33333%;
}

.col-sm-3,.row.cols-sm-3>*
{
  max-width: 25%;
  flex-basis: 25%;
}

.col-sm-offset-2
{
  margin-left: 16.66667%;
}

.col-sm-4,.row.cols-sm-4>*
{
  max-width: 33.33333%;
  flex-basis: 33.33333%;
}

.col-sm-offset-3
{
  margin-left: 25%;
}

.col-sm-5,.row.cols-sm-5>*
{
  max-width: 41.66667%;
  flex-basis: 41.66667%;
}

.col-sm-offset-4
{
  margin-left: 33.33333%;
}

.col-sm-6,.row.cols-sm-6>*
{
  max-width: 50%;
  flex-basis: 50%;
}

.col-sm-offset-5
{
  margin-left: 41.66667%;
}

.col-sm-7,.row.cols-sm-7>*
{
  max-width: 58.33333%;
  flex-basis: 58.33333%;
}

.col-sm-offset-6
{
  margin-left: 50%;
}

.col-sm-8,.row.cols-sm-8>*
{
  max-width: 66.66667%;
  flex-basis: 66.66667%;
}

.col-sm-offset-7
{
  margin-left: 58.33333%;
}

.col-sm-9,.row.cols-sm-9>*
{
  max-width: 75%;
  flex-basis: 75%;
}

.col-sm-offset-8
{
  margin-left: 66.66667%;
}

.col-sm-10,.row.cols-sm-10>*
{
  max-width: 83.33333%;
  flex-basis: 83.33333%;
}

.col-sm-offset-9
{
  margin-left: 75%;
}

.col-sm-11,.row.cols-sm-11>*
{
  max-width: 91.66667%;
  flex-basis: 91.66667%;
}

.col-sm-offset-10
{
  margin-left: 83.33333%;
}

.col-sm-12,.row.cols-sm-12>*
{
  max-width: 100%;
  flex-basis: 100%;
}

.col-sm-offset-11
{
  margin-left: 91.66667%;
}

.col-sm-normal
{
  order: initial;
}

.col-sm-first
{
  order: -999;
}

.col-sm-last
{
  order: 999;
}
.feature-header {
    text-align: center;
    margin-left: 0;
}

@media screen and (min-width: 768px)
{
  .col-md,[class^='col-md-'],[class^='col-md-offset-'],.row[class*='cols-md-']>*
  {
    box-sizing: border-box;
    flex: 0 0 auto;
    padding: 0 calc(var(--universal-padding) / 2);
  }

  .col-md,.row.cols-md>*
  {
    max-width: 100%;
    flex-grow: 1;
    flex-basis: 0;
  }

  .col-md-1,.row.cols-md-1>*
  {
    max-width: 8.33333%;
    flex-basis: 8.33333%;
  }

  .col-md-offset-0
  {
    margin-left: 0;
  }

  .col-md-2,.row.cols-md-2>*
  {
    max-width: 16.66667%;
    flex-basis: 16.66667%;
  }

  .col-md-offset-1
  {
    margin-left: 8.33333%;
  }

  .col-md-3,.row.cols-md-3>*
  {
    max-width: 25%;
    flex-basis: 25%;
  }

  .col-md-offset-2
  {
    margin-left: 16.66667%;
  }

  .col-md-4,.row.cols-md-4>*
  {
    max-width: 33.33333%;
    flex-basis: 33.33333%;
  }

  .col-md-offset-3
  {
    margin-left: 25%;
  }

  .col-md-5,.row.cols-md-5>*
  {
    max-width: 41.66667%;
    flex-basis: 41.66667%;
  }

  .col-md-offset-4
  {
    margin-left: 33.33333%;
  }

  .col-md-6,.row.cols-md-6>*
  {
    max-width: 50%;
    flex-basis: 50%;
  }

  .col-md-offset-5
  {
    margin-left: 41.66667%;
  }

  .col-md-7,.row.cols-md-7>*
  {
    max-width: 58.33333%;
    flex-basis: 58.33333%;
  }

  .col-md-offset-6
  {
    margin-left: 50%;
  }

  .col-md-8,.row.cols-md-8>*
  {
    max-width: 66.66667%;
    flex-basis: 66.66667%;
  }

  .col-md-offset-7
  {
    margin-left: 58.33333%;
  }

  .col-md-9,.row.cols-md-9>*
  {
    max-width: 75%;
    flex-basis: 75%;
  }

  .col-md-offset-8
  {
    margin-left: 66.66667%;
  }

  .col-md-10,.row.cols-md-10>*
  {
    max-width: 83.33333%;
    flex-basis: 83.33333%;
  }

  .col-md-offset-9
  {
    margin-left: 75%;
  }

  .col-md-11,.row.cols-md-11>*
  {
    max-width: 91.66667%;
    flex-basis: 91.66667%;
  }

  .col-md-offset-10
  {
    margin-left: 83.33333%;
  }

  .col-md-12,.row.cols-md-12>*
  {
    max-width: 100%;
    flex-basis: 100%;
  }

  .col-md-offset-11
  {
    margin-left: 91.66667%;
  }

  .col-md-normal
  {
    order: initial;
  }

  .col-md-first
  {
    order: -999;
  }

  .col-md-last
  {
    order: 999;
  }
}

@media screen and (min-width: 1280px)
{
  .col-lg,[class^='col-lg-'],[class^='col-lg-offset-'],.row[class*='cols-lg-']>*
  {
    box-sizing: border-box;
    flex: 0 0 auto;
    padding: 0 calc(var(--universal-padding) / 2);
  }

  .col-lg,.row.cols-lg>*
  {
    max-width: 100%;
    flex-grow: 1;
    flex-basis: 0;
  }

  .col-lg-1,.row.cols-lg-1>*
  {
    max-width: 8.33333%;
    flex-basis: 8.33333%;
  }

  .col-lg-offset-0
  {
    margin-left: 0;
  }

  .col-lg-2,.row.cols-lg-2>*
  {
    max-width: 16.66667%;
    flex-basis: 16.66667%;
  }

  .col-lg-offset-1
  {
    margin-left: 8.33333%;
  }

  .col-lg-3,.row.cols-lg-3>*
  {
    max-width: 25%;
    flex-basis: 25%;
  }

  .col-lg-offset-2
  {
    margin-left: 16.66667%;
  }

  .col-lg-4,.row.cols-lg-4>*
  {
    max-width: 33.33333%;
    flex-basis: 33.33333%;
  }

  .col-lg-offset-3
  {
    margin-left: 25%;
  }

  .col-lg-5,.row.cols-lg-5>*
  {
    max-width: 41.66667%;
    flex-basis: 41.66667%;
  }

  .col-lg-offset-4
  {
    margin-left: 33.33333%;
  }

  .col-lg-6,.row.cols-lg-6>*
  {
    max-width: 50%;
    flex-basis: 50%;
  }

  .col-lg-offset-5
  {
    margin-left: 41.66667%;
  }

  .col-lg-7,.row.cols-lg-7>*
  {
    max-width: 58.33333%;
    flex-basis: 58.33333%;
  }

  .col-lg-offset-6
  {
    margin-left: 50%;
  }

  .col-lg-8,.row.cols-lg-8>*
  {
    max-width: 66.66667%;
    flex-basis: 66.66667%;
  }

  .col-lg-offset-7
  {
    margin-left: 58.33333%;
  }

  .col-lg-9,.row.cols-lg-9>*
  {
    max-width: 75%;
    flex-basis: 75%;
  }

  .col-lg-offset-8
  {
    margin-left: 66.66667%;
  }

  .col-lg-10,.row.cols-lg-10>*
  {
    max-width: 83.33333%;
    flex-basis: 83.33333%;
  }

  .col-lg-offset-9
  {
    margin-left: 75%;
  }

  .col-lg-11,.row.cols-lg-11>*
  {
    max-width: 91.66667%;
    flex-basis: 91.66667%;
  }

  .col-lg-offset-10
  {
    margin-left: 83.33333%;
  }

  .col-lg-12,.row.cols-lg-12>*
  {
    max-width: 100%;
    flex-basis: 100%;
  }

  .col-lg-offset-11
  {
    margin-left: 91.66667%;
  }

  .col-lg-normal
  {
    order: initial;
  }

  .col-lg-first
  {
    order: -999;
  }

  .col-lg-last
  {
    order: 999;
  }
}

:root
{
  --card-back-color: #fcfcfc;
  --card-fore-color: #111;
  --card-border-color: #ddd;
}

.card
{
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-self: center;
  position: relative;
  width: 100%;
  background: var(--card-back-color);
  color: var(--card-fore-color);
  border: .0625rem solid var(--card-border-color);
  border-radius: var(--universal-border-radius);
  margin: var(--universal-margin);
  overflow: hidden;
}

@media screen and (min-width: 320px)
{
  .card
  {
    max-width: 320px;
  }
}

.card>.section
{
  background: var(--card-back-color);
  color: var(--card-fore-color);
  box-sizing: border-box;
  margin: 0;
  border: 0;
  border-radius: 0;
  border-bottom: .0625rem solid var(--card-border-color);
  padding: var(--universal-padding);
  width: 100%;
}

.card>.section.media
{
  height: 200px;
  padding: 0;
  -o-object-fit: cover;
  object-fit: cover;
}

.card>.section:last-child
{
  border-bottom: 0;
}

@media screen and (min-width: 240px)
{
  .card.small
  {
    max-width: 240px;
  }
}

@media screen and (min-width: 480px)
{
  .card.large
  {
    max-width: 480px;
  }
}

.card.fluid
{
  max-width: 100%;
  width: auto;
}

.card.warning
{
  --card-back-color: #ffca28;
  --card-border-color: #e8b825;
}

.card.error
{
  --card-back-color: #b71c1c;
  --card-fore-color: #f8f8f8;
  --card-border-color: #a71a1a;
}

.card>.section.dark
{
  --card-back-color: #e0e0e0;
}

.card>.section.double-padded
{
  padding: calc(1.5 * var(--universal-padding));
}

:root
{
  --form-back-color: #f0f0f0;
  --form-fore-color: #111;
  --form-border-color: #ddd;
  --input-back-color: #f8f8f8;
  --input-fore-color: #111;
  --input-border-color: #ddd;
  --input-focus-color: #0288d1;
  --input-invalid-color: #d32f2f;
  --button-back-color: #e2e2e2;
  --button-hover-back-color: #dcdcdc;
  --button-fore-color: #212121;
  --button-border-color: rgba(0,0,0,0);
  --button-hover-border-color: rgba(0,0,0,0);
  --button-group-border-color: rgba(124,124,124,0.54);
}

form
{
  background: var(--form-back-color);
  color: var(--form-fore-color);
  border: .0625rem solid var(--form-border-color);
  border-radius: var(--universal-border-radius);
  margin: var(--universal-margin);
  padding: calc(2 * var(--universal-padding)) var(--universal-padding);
}

fieldset
{
  border: .0625rem solid var(--form-border-color);
  border-radius: var(--universal-border-radius);
  margin: calc(var(--universal-margin) / 4);
  padding: var(--universal-padding);
}

legend
{
  box-sizing: border-box;
  display: table;
  max-width: 100%;
  white-space: normal;
  font-weight: 700;
  padding: calc(var(--universal-padding) / 2);
}

label
{
  padding: calc(var(--universal-padding) / 2) var(--universal-padding);
}

.input-group
{
  display: inline-block;
}

.input-group.fluid
{
  display: flex;
  align-items: center;
  justify-content: center;
}

.input-group.fluid>input
{
  max-width: 100%;
  flex-grow: 1;
  flex-basis: 0px;
}

@media screen and (max-width: 767px)
{
  .input-group.fluid
  {
    align-items: stretch;
    flex-direction: column;
  }
}

.input-group.vertical
{
  display: flex;
  align-items: stretch;
  flex-direction: column;
}

.input-group.vertical>input
{
  max-width: 100%;
  flex-grow: 1;
  flex-basis: 0px;
}

[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button
{
  height: auto;
}

[type="search"]
{
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type="search"]::-webkit-search-cancel-button,[type="search"]::-webkit-search-decoration
{
  -webkit-appearance: none;
}

input:not([type]),[type="text"],[type="email"],[type="number"],[type="search"],[type="password"],[type="url"],[type="tel"],[type="checkbox"],[type="radio"],textarea,select
{
  box-sizing: border-box;
  background: var(--input-back-color);
  color: var(--input-fore-color);
  border: .0625rem solid var(--input-border-color);
  border-radius: var(--universal-border-radius);
  margin: calc(var(--universal-margin) / 2);
  padding: var(--universal-padding) calc(1.5 * var(--universal-padding));
}

input:not([type="button"]):not([type="submit"]):not([type="reset"]):hover,input:not([type="button"]):not([type="submit"]):not([type="reset"]):focus,textarea:hover,textarea:focus,select:hover,select:focus
{
  border-color: var(--input-focus-color);
  box-shadow: none;
}

input:not([type="button"]):not([type="submit"]):not([type="reset"]):invalid,input:not([type="button"]):not([type="submit"]):not([type="reset"]):focus:invalid,textarea:invalid,textarea:focus:invalid,select:invalid,select:focus:invalid
{
  border-color: var(--input-invalid-color);
  box-shadow: none;
}

input:not([type="button"]):not([type="submit"]):not([type="reset"])[readonly],textarea[readonly],select[readonly]
{
  background: var(--secondary-back-color);
}

select
{
  max-width: 100%;
}

option
{
  overflow: hidden;
  text-overflow: ellipsis;
}

[type="checkbox"],[type="radio"]
{
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  position: relative;
  height: calc(1rem + var(--universal-padding) / 2);
  width: calc(1rem + var(--universal-padding) / 2);
  vertical-align: text-bottom;
  padding: 0;
  flex-basis: calc(1rem + var(--universal-padding) / 2) !important;
  flex-grow: 0 !important;
}

[type="checkbox"]:checked:before,[type="radio"]:checked:before
{
  position: absolute;
}

[type="checkbox"]:checked:before
{
  content: '\2713';
  font-family: sans-serif;
  font-size: calc(1rem + var(--universal-padding) / 2);
  top: calc(0rem - var(--universal-padding));
  left: calc(var(--universal-padding) / 4);
}

[type="radio"]
{
  border-radius: 100%;
}

[type="radio"]:checked:before
{
  border-radius: 100%;
  content: '';
  top: calc(.0625rem + var(--universal-padding) / 2);
  left: calc(.0625rem + var(--universal-padding) / 2);
  background: var(--input-fore-color);
  width: 0.5rem;
  height: 0.5rem;
}

:placeholder-shown
{
  color: var(--input-fore-color);
}

::-ms-placeholder
{
  color: var(--input-fore-color);
  opacity: 0.54;
}

button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner
{
  border-style: none;
  padding: 0;
}

button,html [type="button"],[type="reset"],[type="submit"]
{
  -webkit-appearance: button;
}

button
{
  overflow: visible;
  text-transform: none;
}

button,[type="button"],[type="submit"],[type="reset"],a.button,label.button,.button,a[role="button"],label[role="button"],[role="button"]
{
  display: inline-block;
  background: var(--button-back-color);
  color: var(--button-fore-color);
  border: .0625rem solid var(--button-border-color);
  border-radius: var(--universal-border-radius);
  padding: var(--universal-padding) calc(1.5 * var(--universal-padding));
  margin: var(--universal-margin);
  text-decoration: none;
  cursor: pointer;
  transition: background 0.3s;
}

button:hover,button:focus,[type="button"]:hover,[type="button"]:focus,[type="submit"]:hover,[type="submit"]:focus,[type="reset"]:hover,[type="reset"]:focus,a.button:hover,a.button:focus,label.button:hover,label.button:focus,.button:hover,.button:focus,a[role="button"]:hover,a[role="button"]:focus,label[role="button"]:hover,label[role="button"]:focus,[role="button"]:hover,[role="button"]:focus
{
  background: var(--button-hover-back-color);
  border-color: var(--button-hover-border-color);
}

input:disabled,input[disabled],textarea:disabled,textarea[disabled],select:disabled,select[disabled],button:disabled,button[disabled],.button:disabled,.button[disabled],[role="button"]:disabled,[role="button"][disabled]
{
  cursor: not-allowed;
  opacity: .75;
}

.button-group
{
  display: flex;
  border: .0625rem solid var(--button-group-border-color);
  border-radius: var(--universal-border-radius);
  margin: var(--universal-margin);
}

.button-group>button,.button-group [type="button"],.button-group>[type="submit"],.button-group>[type="reset"],.button-group>.button,.button-group>[role="button"]
{
  margin: 0;
  max-width: 100%;
  flex: 1 1 auto;
  text-align: center;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.button-group>:not(:first-child)
{
  border-left: .0625rem solid var(--button-group-border-color);
}

@media screen and (max-width: 767px)
{
  .button-group
  {
    flex-direction: column;
  }

  .button-group>:not(:first-child)
  {
    border: 0;
    border-top: .0625rem solid var(--button-group-border-color);
  }
}

button.primary,[type="button"].primary,[type="submit"].primary,[type="reset"].primary,.button.primary,[role="button"].primary
{
  --button-back-color: #1976d2;
  --button-fore-color: #f8f8f8;
}

button.primary:hover,button.primary:focus,[type="button"].primary:hover,[type="button"].primary:focus,[type="submit"].primary:hover,[type="submit"].primary:focus,[type="reset"].primary:hover,[type="reset"].primary:focus,.button.primary:hover,.button.primary:focus,[role="button"].primary:hover,[role="button"].primary:focus
{
  --button-hover-back-color: #1565c0;
}

button.secondary,[type="button"].secondary,[type="submit"].secondary,[type="reset"].secondary,.button.secondary,[role="button"].secondary
{
  --button-back-color: #d32f2f;
  --button-fore-color: #f8f8f8;
}

button.secondary:hover,button.secondary:focus,[type="button"].secondary:hover,[type="button"].secondary:focus,[type="submit"].secondary:hover,[type="submit"].secondary:focus,[type="reset"].secondary:hover,[type="reset"].secondary:focus,.button.secondary:hover,.button.secondary:focus,[role="button"].secondary:hover,[role="button"].secondary:focus
{
  --button-hover-back-color: #c62828;
}

button.tertiary,[type="button"].tertiary,[type="submit"].tertiary,[type="reset"].tertiary,.button.tertiary,[role="button"].tertiary
{
  --button-back-color: #308732;
  --button-fore-color: #f8f8f8;
}

button.tertiary:hover,button.tertiary:focus,[type="button"].tertiary:hover,[type="button"].tertiary:focus,[type="submit"].tertiary:hover,[type="submit"].tertiary:focus,[type="reset"].tertiary:hover,[type="reset"].tertiary:focus,.button.tertiary:hover,.button.tertiary:focus,[role="button"].tertiary:hover,[role="button"].tertiary:focus
{
  --button-hover-back-color: #277529;
}

button.inverse,[type="button"].inverse,[type="submit"].inverse,[type="reset"].inverse,.button.inverse,[role="button"].inverse
{
  --button-back-color: #212121;
  --button-fore-color: #f8f8f8;
}

button.inverse:hover,button.inverse:focus,[type="button"].inverse:hover,[type="button"].inverse:focus,[type="submit"].inverse:hover,[type="submit"].inverse:focus,[type="reset"].inverse:hover,[type="reset"].inverse:focus,.button.inverse:hover,.button.inverse:focus,[role="button"].inverse:hover,[role="button"].inverse:focus
{
  --button-hover-back-color: #111;
}

button.small,[type="button"].small,[type="submit"].small,[type="reset"].small,.button.small,[role="button"].small
{
  padding: calc(0.5 * var(--universal-padding)) calc(0.75 * var(--universal-padding));
  margin: var(--universal-margin);
}

button.large,[type="button"].large,[type="submit"].large,[type="reset"].large,.button.large,[role="button"].large
{
  padding: calc(1.5 * var(--universal-padding)) calc(2 * var(--universal-padding));
  margin: var(--universal-margin);
}

:root
{
  --header-back-color: #444;
  --header-hover-back-color: #ddd;
  --header-fore-color: #f3f3f3;
  --header-border-color: #ddd;
  --nav-back-color: #f8f8f8;
  --nav-hover-back-color: #f0f0f0;
  --nav-fore-color: #444;
  --nav-border-color: #ddd;
  --nav-link-color: #0277bd;
  --footer-fore-color: #444;
  --footer-back-color: #f8f8f8;
  --footer-border-color: #ddd;
  --footer-link-color: #dee;
  --drawer-back-color: #f8f8f8;
  --drawer-hover-back-color: #f0f0f0;
  --drawer-border-color: #ddd;
  --drawer-close-color: #444;
}

header
{
  background: var(--header-back-color);
  color: var(--header-fore-color);
  border-bottom: .0625rem solid var(--header-border-color);
  padding: calc(var(--universal-padding) / 4) 0;
  overflow-x: auto;
  overflow-y: hidden;
}

header.row
{
  box-sizing: content-box;
}

header .logo
{
  color: var(--header-fore-color);
  font-size: 1.75rem;
  padding: var(--universal-padding) calc(2 * var(--universal-padding));
  text-decoration: none;
}

header button,header [type="button"],header .button,header [role="button"]
{
  box-sizing: border-box;
  position: relative;
  top: calc(0rem - var(--universal-padding) / 4);
  height: calc(3.1875rem + var(--universal-padding) / 2);
  background: var(--header-back-color);
  line-height: calc(3.1875rem - var(--universal-padding) * 1.5);
  text-align: center;
  color: var(--header-fore-color);
  border: 0;
  border-radius: 0;
  margin: 0;
  text-transform: uppercase;
}

header button:hover,header button:focus,header [type="button"]:hover,header [type="button"]:focus,header .button:hover,header .button:focus,header [role="button"]:hover,header [role="button"]:focus
{
  background: var(--header-hover-back-color);
}

nav
{
  background: var(--nav-back-color);
  color: var(--nav-fore-color);
  border: .0625rem solid var(--nav-border-color);
  border-radius: var(--universal-border-radius);
  margin: var(--universal-margin);
}

nav *
{
  padding: var calc(0.2 * var(--universal-padding)) calc(1.5 * var(--universal-padding));
}

nav a,nav a:visited
{
  display: block;
  color: var(--nav-link-color);
  border-radius: var(--universal-border-radius);
  transition: background 0.3s;
}

nav a:hover,nav a:focus,nav a:visited:hover,nav a:visited:focus
{
  text-decoration: none;
  background: var(--nav-hover-back-color);
}

nav .sublink-1
{
  position: relative;
  margin-left: calc(2 * var(--universal-padding));
}

nav .sublink-1:before
{
  position: absolute;
  left: calc(var(--universal-padding) - 1 * var(--universal-padding));
  top: -.0625rem;
  content: '';
  height: 100%;
  border: .0625rem solid var(--nav-border-color);
  border-left: 0;
}

nav .sublink-2
{
  position: relative;
  margin-left: calc(4 * var(--universal-padding));
}

nav .sublink-2:before
{
  position: absolute;
  left: calc(var(--universal-padding) - 3 * var(--universal-padding));
  top: -.0625rem;
  content: '';
  height: 100%;
  border: .0625rem solid var(--nav-border-color);
  border-left: 0;
}

footer
{
  background: var(--footer-back-color);
  color: var(--footer-fore-color);
  border-top: .0625rem solid var(--footer-border-color);
  padding: calc(2 * var(--universal-padding)) var(--universal-padding);
  font-size: .875rem;
}

footer a,footer a:visited
{
  color: var(--footer-link-color);
}

header.sticky
{
  position: -webkit-sticky;
  position: sticky;
  z-index: 1101;
  top: 0;
}

footer.sticky
{
  position: -webkit-sticky;
  position: sticky;
  z-index: 1101;
  bottom: 0;
}

.drawer-toggle:before
{
  display: inline-block;
  position: relative;
  vertical-align: bottom;
  content: '\00a0\2261\00a0';
  font-family: sans-serif;
  font-size: 1.5em;
}

@media screen and (min-width: 768px)
{
  .drawer-toggle:not(.persistent)
  {
    display: none;
  }
}

[type="checkbox"].drawer
{
  height: 1px;
  width: 1px;
  margin: -1px;
  overflow: hidden;
  position: absolute;
  clip: rect(0 0 0 0);
  -webkit-clip-path: inset(100%);
  clip-path: inset(100%);
}

[type="checkbox"].drawer+*
{
  display: block;
  box-sizing: border-box;
  position: fixed;
  top: 0;
  width: 320px;
  height: 100vh;
  overflow-y: auto;
  background: var(--drawer-back-color);
  border: .0625rem solid var(--drawer-border-color);
  border-radius: 0;
  margin: 0;
  z-index: 1110;
  right: -320px;
  transition: right 0.3s;
}

[type="checkbox"].drawer+* .drawer-close
{
  position: absolute;
  top: var(--universal-margin);
  right: var(--universal-margin);
  z-index: 1111;
  width: 2rem;
  height: 2rem;
  border-radius: var(--universal-border-radius);
  padding: var(--universal-padding);
  margin: 0;
  cursor: pointer;
  transition: background 0.3s;
}

[type="checkbox"].drawer+* .drawer-close:before
{
  display: block;
  content: '\00D7';
  color: var(--drawer-close-color);
  position: relative;
  font-family: sans-serif;
  font-size: 2rem;
  line-height: 1;
  text-align: center;
}

[type="checkbox"].drawer+* .drawer-close:hover,[type="checkbox"].drawer+* .drawer-close:focus
{
  background: var(--drawer-hover-back-color);
}

@media screen and (max-width: 320px)
{
  [type="checkbox"].drawer+*
  {
    width: 100%;
  }
}

[type="checkbox"].drawer:checked+*
{
  right: 0;
}

@media screen and (min-width: 768px)
{
  [type="checkbox"].drawer:not(.persistent)+*
  {
    position: static;
    height: 100%;
    z-index: 1100;
  }

  [type="checkbox"].drawer:not(.persistent)+* .drawer-close
  {
    display: none;
  }
}

:root
{
  --table-border-color: #aaa;
  --table-border-separator-color: #666;
  --table-head-back-color: #e6e6e6;
  --table-head-fore-color: #111;
  --table-body-back-color: #f8f8f8;
  --table-body-fore-color: #111;
  --table-body-alt-back-color: #eee;
}

table
{
  border-collapse: separate;
  border-spacing: 0;
  margin: 0;
  display: flex;
  flex: 0 1 auto;
  flex-flow: row wrap;
  padding: var(--universal-padding);
  padding-top: 0;
}

table caption
{
  font-size: 1.5rem;
  margin: calc(2 * var(--universal-margin)) 0;
  max-width: 100%;
  flex: 0 0 100%;
}

table thead,table tbody
{
  display: flex;
  flex-flow: row wrap;
  border: .0625rem solid var(--table-border-color);
}

table thead
{
  z-index: 999;
  border-radius: var(--universal-border-radius) var(--universal-border-radius) 0 0;
  border-bottom: .0625rem solid var(--table-border-separator-color);
}

table tbody
{
  border-top: 0;
  margin-top: calc(0 - var(--universal-margin));
  border-radius: 0 0 var(--universal-border-radius) var(--universal-border-radius);
}

table tr
{
  display: flex;
  padding: 0;
}

table th,table td
{

}

table th
{
  text-align: left;
  background: var(--table-head-back-color);
  color: var(--table-head-fore-color);
}

table td
{
  background: var(--table-body-back-color);
  color: var(--table-body-fore-color);
  border-top: .0625rem solid var(--table-border-color);
}

table:not(.horizontal)
{
  overflow: auto;
}

table:not(.horizontal) thead,table:not(.horizontal) tbody
{
  max-width: 100%;
  flex: 0 0 100%;
}

table:not(.horizontal) tr
{
  flex-flow: row wrap;
  flex: 0 0 100%;
}

table:not(.horizontal) th,table:not(.horizontal) td
{
  flex: 1 0 0%;
  overflow: hidden;
  text-overflow: ellipsis;
}

table:not(.horizontal) thead
{
  position: sticky;
  top: 0;
}

table:not(.horizontal) tbody tr:first-child td
{
  border-top: 0;
}

table.horizontal
{
  border: 0;
}

table.horizontal thead,table.horizontal tbody
{
  border: 0;
  flex: .2 0 0;
  flex-flow: row nowrap;
}

table.horizontal tbody
{
  overflow: auto;
  justify-content: space-between;
  flex: .8 0 0;
  margin-left: 0;
  padding-bottom: calc(var(--universal-padding) / 4);
}

table.horizontal tr
{
  flex-direction: column;
  flex: 1 0 auto;
}

table.horizontal th,table.horizontal td
{
  width: auto;
  border: 0;
  border-bottom: .0625rem solid var(--table-border-color);
    border-left: .0625rem solid var(--table-border-color);
}

table.horizontal th:not(:first-child),table.horizontal td:not(:first-child)
{
  border-top: 0;
}

table.horizontal th
{
  text-align: right;
  border-left: .0625rem solid var(--table-border-color);
  border-right: .0625rem solid var(--table-border-separator-color);
}

table.horizontal thead tr:first-child
{
  padding-left: 0;
}

table.horizontal th:first-child,table.horizontal td:first-child
{
  border-top: .0625rem solid var(--table-border-color);
}

table.horizontal tbody tr:last-child td
{
  border-right: .0625rem solid var(--table-border-color);
}

table.horizontal tbody tr:last-child td:first-child
{
  border-top-right-radius: 0.25rem;
}

table.horizontal tbody tr:last-child td:last-child
{
  border-bottom-right-radius: 0.25rem;
}

table.horizontal thead tr:first-child th:first-child
{
  border-top-left-radius: 0.25rem;
}

table.horizontal thead tr:first-child th:last-child
{
  border-bottom-left-radius: 0.25rem;
}

@media screen and (max-width: 767px)
{
  table,table.horizontal
  {
    border-collapse: collapse;
    border: 0;
    width: 100%;
    display: table;
  }

  table thead,table th,table.horizontal thead,table.horizontal th
  {
    border: 0;
    height: 1px;
    width: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    clip: rect(0 0 0 0);
    -webkit-clip-path: inset(100%);
    clip-path: inset(100%);
  }

  table tbody,table.horizontal tbody
  {
    border: 0;
    display: table-row-group;
  }

  table tr,table.horizontal tr
  {
    display: block;
    border: .0625rem solid var(--table-border-color);
    border-radius: var(--universal-border-radius);
    background: #fafafa;
    padding: var(--universal-padding);
    margin: var(--universal-margin);
    margin-bottom: calc(2 * var(--universal-margin));
  }

  table th,table td,table.horizontal th,table.horizontal td
  {
    width: auto;
  }

  table td,table.horizontal td
  {
    display: block;
    border: 0;
    text-align: right;
  }

  table td:before,table.horizontal td:before
  {
    content: attr(data-label);
    float: left;
    font-weight: 600;
  }

  table th:first-child,table td:first-child,table.horizontal th:first-child,table.horizontal td:first-child
  {
    border-top: 0;
  }

  table tbody tr:last-child td,table.horizontal tbody tr:last-child td
  {
    border-right: 0;
  }
}

:root
{
  --table-body-alt-back-color: #eee;
}

table.striped tr:nth-of-type(2n)>td
{
  background: var(--table-body-alt-back-color);
}

@media screen and (max-width: 768px)
{
  table.striped tr:nth-of-type(2n)
  {
    background: var(--table-body-alt-back-color);
  }
}

:root
{
  --table-body-hover-back-color: #90caf9;
}

table.hoverable tr:hover,table.hoverable tr:hover>td,table.hoverable tr:focus,table.hoverable tr:focus>td
{
  background: var(--table-body-hover-back-color);
}

@media screen and (max-width: 768px)
{
  table.hoverable tr:hover,table.hoverable tr:hover>td,table.hoverable tr:focus,table.hoverable tr:focus>td
  {
    background: var(--table-body-hover-back-color);
  }
}

:root
{
  --mark-back-color: #0277bd;
  --mark-fore-color: #fafafa;
}

mark
{
  background: var(--mark-back-color);
  color: var(--mark-fore-color);
  font-size: .95em;
  line-height: 1em;
  border-radius: var(--universal-border-radius);
  padding: calc(var(--universal-padding) / 4) calc(var(--universal-padding) / 2);
}

mark.inline-block
{
  display: inline-block;
  font-size: 1em;
  line-height: 1.5;
  padding: calc(var(--universal-padding) / 2) var(--universal-padding);
}

:root
{
  --toast-back-color: #424242;
  --toast-fore-color: #fafafa;
}

.toast
{
  position: fixed;
  bottom: calc(var(--universal-margin) * 3);
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 1111;
  color: var(--toast-fore-color);
  background: var(--toast-back-color);
  border-radius: calc(var(--universal-border-radius) * 16);
  padding: var(--universal-padding) calc(var(--universal-padding) * 3);
}

:root
{
  --tooltip-back-color: #212121;
  --tooltip-fore-color: #fafafa;
}

.tooltip
{
  position: relative;
  display: inline-block;
}

.tooltip:before,.tooltip:after
{
  position: absolute;
  opacity: 0;
  clip: rect(0 0 0 0);
  -webkit-clip-path: inset(100%);
  clip-path: inset(100%);
  transition: all 0.3s;
  z-index: 1010;
  left: 50%;
}

.tooltip:not(.bottom):before,.tooltip:not(.bottom):after
{
  bottom: 75%;
}

.tooltip.bottom:before,.tooltip.bottom:after
{
  top: 75%;
}

.tooltip:hover:before,.tooltip:hover:after,.tooltip:focus:before,.tooltip:focus:after
{
  opacity: 1;
  clip: auto;
  -webkit-clip-path: inset(0%);
  clip-path: inset(0%);
}

.tooltip:before
{
  content: '';
  background: transparent;
  border: var(--universal-margin) solid transparent;
  left: calc(50% - var(--universal-margin));
}

.tooltip:not(.bottom):before
{
  border-top-color: #212121;
}

.tooltip.bottom:before
{
  border-bottom-color: #212121;
}

.tooltip:after
{
  content: attr(aria-label);
  color: var(--tooltip-fore-color);
  background: var(--tooltip-back-color);
  border-radius: var(--universal-border-radius);
  padding: var(--universal-padding);
  white-space: nowrap;
  transform: translateX(-50%);
}

.tooltip:not(.bottom):after
{
  margin-bottom: calc(2 * var(--universal-margin));
}

.tooltip.bottom:after
{
  margin-top: calc(2 * var(--universal-margin));
}

:root
{
  --modal-overlay-color: rgba(0,0,0,0.45);
  --modal-close-color: #444;
  --modal-close-hover-color: #f0f0f0;
}

[type="checkbox"].modal
{
  height: 1px;
  width: 1px;
  margin: -1px;
  overflow: hidden;
  position: absolute;
  clip: rect(0 0 0 0);
  -webkit-clip-path: inset(100%);
  clip-path: inset(100%);
}

[type="checkbox"].modal+div
{
  position: fixed;
  top: 0;
  left: 0;
  display: none;
  width: 100vw;
  height: 100vh;
  background: var(--modal-overlay-color);
}

[type="checkbox"].modal+div .card
{
  margin: 0 auto;
  max-height: 50vh;
  overflow: auto;
}

[type="checkbox"].modal+div .card .modal-close
{
  position: absolute;
  top: 0;
  right: 0;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: var(--universal-border-radius);
  padding: var(--universal-padding);
  margin: 0;
  cursor: pointer;
  transition: background 0.3s;
}

[type="checkbox"].modal+div .card .modal-close:before
{
  display: block;
  content: '\00D7';
  color: var(--modal-close-color);
  position: relative;
  font-family: sans-serif;
  font-size: 1.75rem;
  line-height: 1;
  text-align: center;
}

[type="checkbox"].modal+div .card .modal-close:hover,[type="checkbox"].modal+div .card .modal-close:focus
{
  background: var(--modal-close-hover-color);
}

[type="checkbox"].modal:checked+div
{
  display: flex;
  flex: 0 1 auto;
  z-index: 1200;
}

[type="checkbox"].modal:checked+div .card .modal-close
{
  z-index: 1211;
}

:root
{
  --collapse-label-back-color: #e8e8e8;
  --collapse-label-fore-color: #212121;
  --collapse-label-hover-back-color: #f0f0f0;
  --collapse-selected-label-back-color: #ececec;
  --collapse-border-color: #ddd;
  --collapse-content-back-color: #fafafa;
  --collapse-selected-label-border-color: #0277bd;
}

.collapse
{
  width: calc(100% - 2 * var(--universal-margin));
  opacity: 1;
  display: flex;
  flex-direction: column;
  margin: var(--universal-margin);
  border-radius: var(--universal-border-radius);
}

.collapse>[type="radio"],.collapse>[type="checkbox"]
{
  height: 1px;
  width: 1px;
  margin: -1px;
  overflow: hidden;
  position: absolute;
  clip: rect(0 0 0 0);
  -webkit-clip-path: inset(100%);
  clip-path: inset(100%);
}

.collapse>label
{
  flex-grow: 1;
  display: inline-block;
  height: 1.5rem;
  cursor: pointer;
  transition: background 0.3s;
  color: var(--collapse-label-fore-color);
  background: var(--collapse-label-back-color);
  border: .0625rem solid var(--collapse-border-color);
  padding: calc(1.5 * var(--universal-padding));
}

.collapse>label:hover,.collapse>label:focus
{
  background: var(--collapse-label-hover-back-color);
}

.collapse>label+div
{
  flex-basis: auto;
  height: 1px;
  width: 1px;
  margin: -1px;
  overflow: hidden;
  position: absolute;
  clip: rect(0 0 0 0);
  -webkit-clip-path: inset(100%);
  clip-path: inset(100%);
  transition: max-height 0.3s;
  max-height: 1px;
}

.collapse>:checked+label
{
  background: var(--collapse-selected-label-back-color);
  border-bottom-color: var(--collapse-selected-label-border-color);
}

.collapse>:checked+label+div
{
  box-sizing: border-box;
  position: relative;
  width: 100%;
  height: auto;
  overflow: auto;
  margin: 0;
  background: var(--collapse-content-back-color);
  border: .0625rem solid var(--collapse-border-color);
  border-top: 0;
  padding: var(--universal-padding);
  clip: auto;
  -webkit-clip-path: inset(0%);
  clip-path: inset(0%);
  max-height: 400px;
}

.collapse>label:not(:first-of-type)
{
  border-top: 0;
}

.collapse>label:first-of-type
{
  border-radius: var(--universal-border-radius) var(--universal-border-radius) 0 0;
}

.collapse>label:last-of-type:not(:first-of-type)
{
  border-radius: 0 0 var(--universal-border-radius) var(--universal-border-radius);
}

.collapse>label:last-of-type:first-of-type
{
  border-radius: var(--universal-border-radius);
}

.collapse>:checked:last-of-type:not(:first-of-type)+label
{
  border-radius: 0;
}

.collapse>:checked:last-of-type+label+div
{
  border-radius: 0 0 var(--universal-border-radius) var(--universal-border-radius);
}

mark.secondary
{
  --mark-back-color: #d32f2f;
}

mark.tertiary
{
  --mark-back-color: #308732;
}

mark.tag
{
  padding: calc(var(--universal-padding)/2) var(--universal-padding);
  border-radius: 1em;
}

:root
{
  --progress-back-color: #ddd;
  --progress-fore-color: #555;
}

progress
{
  display: block;
  vertical-align: baseline;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  height: .75rem;
  width: calc(100% - 2 * var(--universal-margin));
  margin: var(--universal-margin);
  border: 0;
  border-radius: calc(2 * var(--universal-border-radius));
  background: var(--progress-back-color);
  color: var(--progress-fore-color);
}

progress::-webkit-progress-value
{
  background: var(--progress-fore-color);
  border-top-left-radius: calc(2 * var(--universal-border-radius));
  border-bottom-left-radius: calc(2 * var(--universal-border-radius));
}

progress::-webkit-progress-bar
{
  background: var(--progress-back-color);
}

progress::-moz-progress-bar
{
  background: var(--progress-fore-color);
  border-top-left-radius: calc(2 * var(--universal-border-radius));
  border-bottom-left-radius: calc(2 * var(--universal-border-radius));
}

progress[value="1000"]::-webkit-progress-value
{
  border-radius: calc(2 * var(--universal-border-radius));
}

progress[value="1000"]::-moz-progress-bar
{
  border-radius: calc(2 * var(--universal-border-radius));
}

progress.inline
{
  display: inline-block;
  vertical-align: middle;
  width: 60%;
}

:root
{
  --spinner-back-color: #ddd;
  --spinner-fore-color: #555;
}

@keyframes spinner-donut-anim
{
  0%
  {
    transform: rotate(0deg);
  }

  100%
  {
    transform: rotate(360deg);
  }
}

.spinner
{
  display: inline-block;
  margin: var(--universal-margin);
  border: .25rem solid var(--spinner-back-color);
  border-left: .25rem solid var(--spinner-fore-color);
  border-radius: 50%;
  width: 1.25rem;
  height: 1.25rem;
  animation: spinner-donut-anim 1.2s linear infinite;
}

progress.primary
{
  --progress-fore-color: #1976d2;
}

progress.secondary
{
  --progress-fore-color: #d32f2f;
}

progress.tertiary
{
  --progress-fore-color: #308732;
}

.spinner.primary
{
  --spinner-fore-color: #1976d2;
}

.spinner.secondary
{
  --spinner-fore-color: #d32f2f;
}

.spinner.tertiary
{
  --spinner-fore-color: #308732;
}

span[class^='icon-']
{
  display: inline-block;
  height: 1em;
  width: 1em;
  vertical-align: -0.125em;
  background-size: contain;
  margin: 0 calc(var(--universal-margin) / 4);
}

span[class^='icon-'].secondary
{
  -webkit-filter: invert(25%);
  filter: invert(25%);
}

span[class^='icon-'].inverse
{
  -webkit-filter: invert(100%);
  filter: invert(100%);
}

span.icon-alert
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cline x1='12' y1='8' x2='12' y2='12'%3E%3C/line%3E%3Cline x1='12' y1='16' x2='12' y2='16'%3E%3C/line%3E%3C/svg%3E");
}

span.icon-bookmark
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M19 21l-7-5-7 5V5a2 2 0 0 1 2-2h10a2 2 0 0 1 2 2z'%3E%3C/path%3E%3C/svg%3E");
}

span.icon-calendar
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='16' y1='2' x2='16' y2='6'%3E%3C/line%3E%3Cline x1='8' y1='2' x2='8' y2='6'%3E%3C/line%3E%3Cline x1='3' y1='10' x2='21' y2='10'%3E%3C/line%3E%3C/svg%3E");
}

span.icon-credit
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='1' y='4' width='22' height='16' rx='2' ry='2'%3E%3C/rect%3E%3Cline x1='1' y1='10' x2='23' y2='10'%3E%3C/line%3E%3C/svg%3E");
}

span.icon-edit
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 14.66V20a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2h5.34'%3E%3C/path%3E%3Cpolygon points='18 2 22 6 12 16 8 16 8 12 18 2'%3E%3C/polygon%3E%3C/svg%3E");
}

span.icon-link
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'%3E%3C/path%3E%3Cpolyline points='15 3 21 3 21 9'%3E%3C/polyline%3E%3Cline x1='10' y1='14' x2='21' y2='3'%3E%3C/line%3E%3C/svg%3E");
}

span.icon-help
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3'%3E%3C/path%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cline x1='12' y1='17' x2='12' y2='17'%3E%3C/line%3E%3C/svg%3E");
}

span.icon-home
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 9l9-7 9 7v11a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z'%3E%3C/path%3E%3Cpolyline points='9 22 9 12 15 12 15 22'%3E%3C/polyline%3E%3C/svg%3E");
}

span.icon-info
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'%3E%3C/circle%3E%3Cline x1='12' y1='16' x2='12' y2='12'%3E%3C/line%3E%3Cline x1='12' y1='8' x2='12' y2='8'%3E%3C/line%3E%3C/svg%3E");
}

span.icon-lock
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='11' width='18' height='11' rx='2' ry='2'%3E%3C/rect%3E%3Cpath d='M7 11V7a5 5 0 0 1 10 0v4'%3E%3C/path%3E%3C/svg%3E");
}

span.icon-mail
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 4h16c1.1 0 2 .9 2 2v12c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V6c0-1.1.9-2 2-2z'%3E%3C/path%3E%3Cpolyline points='22,6 12,13 2,6'%3E%3C/polyline%3E%3C/svg%3E");
}

span.icon-location
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'%3E%3C/path%3E%3Ccircle cx='12' cy='10' r='3'%3E%3C/circle%3E%3C/svg%3E");
}

span.icon-phone
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6 19.79 19.79 0 0 1-3.07-8.67A2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72 12.84 12.84 0 0 0 .7 2.81 2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45 12.84 12.84 0 0 0 2.81.7A2 2 0 0 1 22 16.92z'%3E%3C/path%3E%3C/svg%3E");
}

span.icon-rss
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 11a9 9 0 0 1 9 9'%3E%3C/path%3E%3Cpath d='M4 4a16 16 0 0 1 16 16'%3E%3C/path%3E%3Ccircle cx='5' cy='19' r='1'%3E%3C/circle%3E%3C/svg%3E");
}

span.icon-search
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'%3E%3C/line%3E%3C/svg%3E");
}

span.icon-settings
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='3'%3E%3C/circle%3E%3Cpath d='M19.4 15a1.65 1.65 0 0 0 .33 1.82l.06.06a2 2 0 0 1 0 2.83 2 2 0 0 1-2.83 0l-.06-.06a1.65 1.65 0 0 0-1.82-.33 1.65 1.65 0 0 0-1 1.51V21a2 2 0 0 1-2 2 2 2 0 0 1-2-2v-.09A1.65 1.65 0 0 0 9 19.4a1.65 1.65 0 0 0-1.82.33l-.06.06a2 2 0 0 1-2.83 0 2 2 0 0 1 0-2.83l.06-.06a1.65 1.65 0 0 0 .33-1.82 1.65 1.65 0 0 0-1.51-1H3a2 2 0 0 1-2-2 2 2 0 0 1 2-2h.09A1.65 1.65 0 0 0 4.6 9a1.65 1.65 0 0 0-.33-1.82l-.06-.06a2 2 0 0 1 0-2.83 2 2 0 0 1 2.83 0l.06.06a1.65 1.65 0 0 0 1.82.33H9a1.65 1.65 0 0 0 1-1.51V3a2 2 0 0 1 2-2 2 2 0 0 1 2 2v.09a1.65 1.65 0 0 0 1 1.51 1.65 1.65 0 0 0 1.82-.33l.06-.06a2 2 0 0 1 2.83 0 2 2 0 0 1 0 2.83l-.06.06a1.65 1.65 0 0 0-.33 1.82V9a1.65 1.65 0 0 0 1.51 1H21a2 2 0 0 1 2 2 2 2 0 0 1-2 2h-.09a1.65 1.65 0 0 0-1.51 1z'%3E%3C/path%3E%3C/svg%3E");
}

span.icon-share
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='18' cy='5' r='3'%3E%3C/circle%3E%3Ccircle cx='6' cy='12' r='3'%3E%3C/circle%3E%3Ccircle cx='18' cy='19' r='3'%3E%3C/circle%3E%3Cline x1='8.59' y1='13.51' x2='15.42' y2='17.49'%3E%3C/line%3E%3Cline x1='15.41' y1='6.51' x2='8.59' y2='10.49'%3E%3C/line%3E%3C/svg%3E");
}

span.icon-cart
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='21' r='1'%3E%3C/circle%3E%3Ccircle cx='20' cy='21' r='1'%3E%3C/circle%3E%3Cpath d='M1 1h4l2.68 13.39a2 2 0 0 0 2 1.61h9.72a2 2 0 0 0 2-1.61L23 6H6'%3E%3C/path%3E%3C/svg%3E");
}

span.icon-upload
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 15v4a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2v-4'%3E%3C/path%3E%3Cpolyline points='17 8 12 3 7 8'%3E%3C/polyline%3E%3Cline x1='12' y1='3' x2='12' y2='15'%3E%3C/line%3E%3C/svg%3E");
}

span.icon-user
{
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 21v-2a4 4 0 0 0-4-4H8a4 4 0 0 0-4 4v2'%3E%3C/path%3E%3Ccircle cx='12' cy='7' r='4'%3E%3C/circle%3E%3C/svg%3E");
}

:root
{
  --generic-border-color: rgba(0,0,0,0.3);
  --generic-box-shadow: 0 .25rem .25rem 0 rgba(0,0,0,0.125),0 .125rem .125rem -.125rem rgba(0,0,0,0.25);
}

.hidden
{
  display: none !important;
}

.visually-hidden
{
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  margin: -1px !important;
  border: 0 !important;
  padding: 0 !important;
  clip: rect(0 0 0 0) !important;
  -webkit-clip-path: inset(100%) !important;
  clip-path: inset(100%) !important;
  overflow: hidden !important;
}

.bordered
{
  border: .0625rem solid var(--generic-border-color) !important;
}

.rounded
{
  border-radius: var(--universal-border-radius) !important;
}

.circular
{
  border-radius: 50% !important;
}

.shadowed
{
  box-shadow: var(--generic-box-shadow) !important;
}

.responsive-margin
{
  margin: calc(var(--universal-margin) / 4) !important;
}

@media screen and (min-width: 768px)
{
  .responsive-margin
  {
    margin: calc(var(--universal-margin) / 2) !important;
  }
}

@media screen and (min-width: 1280px)
{
  .responsive-margin
  {
    margin: var(--universal-margin) !important;
  }
}

.responsive-padding
{
  padding: calc(var(--universal-padding) / 4) !important;
}

@media screen and (min-width: 768px)
{
  .responsive-padding
  {
    padding: calc(var(--universal-padding) / 2) !important;
  }
}

@media screen and (min-width: 1280px)
{
  .responsive-padding
  {
    padding: var(--universal-padding) !important;
  }
}

@media screen and (max-width: 767px)
{
  .hidden-sm
  {
    display: none !important;
  }
}

@media screen and (min-width: 768px) and (max-width: 1279px)
{
  .hidden-md
  {
    display: none !important;
  }
}

@media screen and (min-width: 1280px)
{
  .hidden-lg
  {
    display: none !important;
  }
}

@media screen and (max-width: 767px)
{
  .visually-hidden-sm
  {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    margin: -1px !important;
    border: 0 !important;
    padding: 0 !important;
    clip: rect(0 0 0 0) !important;
    -webkit-clip-path: inset(100%) !important;
    clip-path: inset(100%) !important;
    overflow: hidden !important;
  }
}

@media screen and (min-width: 768px) and (max-width: 1279px)
{
  .visually-hidden-md
  {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    margin: -1px !important;
    border: 0 !important;
    padding: 0 !important;
    clip: rect(0 0 0 0) !important;
    -webkit-clip-path: inset(100%) !important;
    clip-path: inset(100%) !important;
    overflow: hidden !important;
  }
}

@media screen and (min-width: 1280px)
{
  .visually-hidden-lg
  {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    margin: -1px !important;
    border: 0 !important;
    padding: 0 !important;
    clip: rect(0 0 0 0) !important;
    -webkit-clip-path: inset(100%) !important;
    clip-path: inset(100%) !important;
    overflow: hidden !important;
  }
}


/* ---------- NAVIGATION ---------- */

.menu {
	margin: 0;
	padding-left: 0;
}
.menu li {
	display: inline-block;
	font-size: 1.2rem;
	list-style-type: none;
	margin-left: 1.5rem;
}
.menu li:first-child {
	margin-left: 0;
}
.menu li.active a {
	color: #444;
}
.menu.vertical li {
	display: block;
	margin-left: 0;
}
.menu.expanded li {
	margin-left: 0;
	transition-duration: .2s;
}
.menu.expanded li:hover {
	border-radius: .3rem;
	background-color: #ddd;
	transition-duration: .2s;
}
.menu.expanded li a {
	border-radius: .3rem;
	display: block;
	height: 3.5rem;
	line-height: 3.5rem;
	padding-left: .7rem;
	padding-right: .7rem;
}
.menu.expanded li a:hover {
	text-decoration: none;
}
.menu.breadcrumb li + li:before,
.menu.expanded.breadcrumb > li + li a:before {
	content: "/";
}
.menu.breadcrumb li + li:before,
.menu.expanded.breadcrumb > li + li:before,
.menu.expanded.breadcrumb > li + li a:before {
	margin-right: .7rem;
}
.menu.expanded.breadcrumb > li + li:before {
	content: none;
}
.menu.expanded li.active a,
.menu.expanded li.active:hover {
	background-color: #258fd6;
	color: #fff;
}
.responsive-menu label {
	background-color: #444;
	color: #fff;
	cursor: pointer;
	text-align: center;
}
#nav,/* fix old android browser (always open) */
.responsive-menu label,.responsive-menu input[type=checkbox] { 
	display: none;
}
.responsive-menu label {
	height: 3.5rem;
	line-height: 3.5rem;
	padding-left: .7rem;
	padding-right: .7rem;
}
#nav:checked+ul#responsive-menu,/* fix old android browser */
.responsive-menu input[type=checkbox]:checked+ul { 
	display: block;
}

@media (max-width: 767px) {
	.responsive-menu { /* fix old android browser : good position*/
		left: 0;
		right: 0;
	}
	.responsive-menu ul {
		display: none;
	}
	.responsive-menu label,
	.responsive-menu ul li {
		display: block;
		margin-left: 0;
	}
	.responsive-menu ul li:hover {
		background-color: #ddd;
	}
	.responsive-menu ul li a {
		display: block;
		height: 3.5rem;
		line-height: 3.5rem;
		padding-left: .7rem;
		padding-right: .7rem;
	}
	.responsive-menu ul li a:hover {
		text-decoration: none;
	}
	.responsive-menu .menu.breadcrumb li + li:before,
	.responsive-menu .menu.expanded.breadcrumb > li + li a:before {
		content: none;
	}
	.responsive-menu ul li.active a,
	.responsive-menu ul li.active:hover {
		background-color: #258fd6;
		color: #fff;
	}
}

/* Pagination */

.pagination {
	margin: 0;
	padding: 0;
	width: 100%;
}
.pagination ul,
.pagination ul ul {
	display: inline-block;
	margin: 0;
	padding: 0;
}
.pagination li,
.pagination li li {
	display: inline-block;
	font-size: 1.5rem;
	list-style-type: none;
	margin: 10px;
	cursor: pointer;
}
.pagination li.active a {
	color: #ff0000;
}
.pagination li.disabled a {
	color: #999;
}
.pagination li.disabled a:hover {
	text-decoration: none;
}
