html{box-sizing:border-box}
*,*:before,*:after{box-sizing:inherit}

/* Extract from normalize.css by Nicolas Gallagher and Jonathan Neal git.io/normalize */
html{-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}
article,aside,details,figcaption,figure,footer,header,main,menu,nav,section{display:block}summary{display:list-item}
audio,canvas,progress,video{display:inline-block}progress{vertical-align:baseline}
audio:not([controls]){display:none;height:0}[hidden],template{display:none}
a{background-color:transparent}a:active,a:hover{outline-width:0}
abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}
b,strong{font-weight:bolder}dfn{font-style:italic}mark{background:#ff0;color:#000}
small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}
sub{bottom:-0.25em}sup{top:-0.5em}figure{margin:1em 40px}img{border-style:none}
code,kbd,pre,samp{font-family:monospace,monospace;font-size:1em}hr{box-sizing:content-box;height:0;overflow:visible}
button,input,select,textarea,optgroup{font:inherit;margin:0}optgroup{font-weight:bold}
button,input{overflow:visible}button,select{text-transform:none}
button,[type=button],[type=reset],[type=submit]{-webkit-appearance:button}
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:-moz-focusring,[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring{outline:1px dotted ButtonText}
fieldset{border:1px solid #c0c0c0;margin:0 2px;padding:.35em .625em .75em}
legend{color:inherit;display:table;max-width:100%;padding:0;white-space:normal}textarea{overflow:auto}
[type=checkbox],[type=radio]{padding:0}
[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-decoration{-webkit-appearance:none}
::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}
/* End extract */

/* Common elements */

body {
  font-family: 'Fredoka', sans-serif;
  font-size: 1.15rem;
  line-height: 1.5;
  color: #444;
}

h1 {
  font-size: 2.1rem;
}

a {
  color: #33bb55;
}

a:hover {
  text-decoration: none;
}

img {
  max-width: 100%;
}

hr {
  border: 1px solid #33bb55;
}

table {
  display: block;
	margin: 1rem 0;
	border-spacing: 0;
	border-collapse: collapse;
  text-align: left;
  overflow-x: auto;
}

table tbody tr:nth-of-type(2n+1) {
	background: #4444440a;
}

table td, table th {
  padding: .6rem .4rem;
	border-bottom: .05rem solid #e7e9ed;
  vertical-align: top;
}

/* Main structural elements */

nav#tlMenu {
  position: fixed;
  top: 0;
  z-index: 40;
  width: 300px;
  height: 100%;
  padding: 8px 16px;
  background-image: linear-gradient(#33bb55, #33dd77);
  font-size: 1.25rem;
  color: white;
  overflow-y: auto;
  transition: left .5s;
}

#tlLogo {
  margin: 80px 0;
  padding: 8px 16px;
}

nav#tlToc {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 30;
  width: 200px;
  height: 100%;
  padding: 8px 16px;
  background-color: #ccffdd;
  color: black;
  overflow-y: auto;
  transition: right .5s;
}

nav#tlTocButton {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 2;
  padding: 8px 16px;
  color: black;
}

header {
  display: flex;
  position: fixed;
  top: 0;
  width: 100%;
  padding: 8px 16px;
  background-color: rgba(0,187,51,.8); /* IE/Edge quirk: #00bb33cc */
  font-size: 1.25rem;
  color: white;
  z-index: 5;
}

#tlHeaderLink {
  display: contents;
  /* padding: 8px 16px 0 16px; */
}

img#tlHeaderLogo {
  max-width: initial;
}

div#tlDimMenu,
div#tlDimToc {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 20;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,.5); /* IE/Edge quirk: #00000080 */
  cursor: pointer;
}

.tlMain {
  margin-left: 340px;
  margin-right: 40px;
  min-width: 320px;
  padding: 8px 16px;
  overflow-wrap: break-word;
  transition: margin .5s;
}

.tlMainWToc {
  margin-right: 240px;
}

#tlMainTitle {
  margin-top: 80px;
  font-size: 3.1rem;
  font-weight: 700;
  color: #33bb55;
}

#tlMainSubtitle {
  font-size: 2.1rem;
  font-weight: 700;
  color: #33bb55;
}

#tlMainTitleHr {
  margin: 20px 0;
  width: 74px;
  border: 5px solid #33bb55;
  border-radius: 4px;
  text-align: left; /* IE/Edge quirk */
}

article {
  margin: 2em 0;
}

footer {
  margin-top: 80px;
  z-index: 4;
  width: 100%;
  background-color: #ccffdd;
  font-size: 1rem;
}

div#tlCopyright {
  text-align: center;
}

/* Special screen/print cases */

@media screen and (max-width: 992px) {
  nav#tlMenu {
    left: -300px;
  }
  nav#tlToc {
    right: -200px;
  }
  main,
  #tlCopyright {
    margin: 0 !important;
  }
  nav#tlTocButton {
    display: none;
  }
}

@media screen and (min-width: 993px) and (max-width: 1216px) {
  nav#tlMenu {
    left: 0 !important;
  }
  nav#tlToc {
    right: -200px;
  }
  header,
  div#tlDimMenu,
  .tlMenuCloseButton {
    display: none !important;
  }
  main,
  div#tlCopyright {
    margin-left: 340px;
    margin-right: 0 !important;
  }
}

@media screen and (min-width: 1217px) {
  nav#tlMenu {
    left: 0 !important;
  }
  nav#tlToc {
    right: 0 !important;
  }
  header,
  div#tlDimMenu,
  div#tlDimToc,
  nav#tlTocButton,
  .tlMenuCloseButton,
  .tlTocCloseButton {
    display: none !important;
  }
}

@media print {
  table {
    overflow-x: visible; /* Hides scrollbar in Chrome */
  }
  header,
  nav#tlMenu,
  nav#tlTocButton,
  nav#tlToc,
  #footerSitemap,
  .tlNavMenuButton {
    display: none !important;
  }
  .tlMain,
  .tlMainWToc {
    margin: 0;
  }
}

/* Main individual elements */

.tlMenuButton,
.tlNavMenuButton {
  display: block;
  padding: 8px 16px;
  font-size: 1.25rem;
  color: inherit;
  text-decoration: none;
  border-radius: 6px;
  cursor: pointer;
  transition: .3s;
  -webkit-tap-highlight-color: transparent; /* Prevents default selection background on Android Chrome */
}

.tlMenuButton:hover {
  background-color: white;
  color: #444;
}

/* Turn off hover & active effect on touch devices */
@media (hover: none) {
  .tlNoHover:hover {
    background-color: transparent;
    color: inherit;
  }
}

.tlSubMenuButton {
  margin-left: 1em;
}

.tlSubMenuButton,
.tlSmallMenuButton,
.tlNavMenuButton {
  font-size: 1.15rem;
}

.tlMenuCloseButton,
.tlTocCloseButton {
  position: absolute;
}

.tlTocCloseButton {
  right: 16px;
}

.tlTocCloseButtonBackground {
  background-color: rgba(204,255,221,.8); /* IE/Edge quirk: #ccffddcc */
}

.tlTocTitle {
  margin: 80px 0;
  border-bottom: 1px solid black;
}

.tlSectionAnchor {
  position: absolute;
  margin-left: -32px;
  font-weight: normal;
  font-size: 90%;
  text-decoration: none;
}

/* Customized per-content elements */

.tlFloatContainer {
  overflow: auto;
}

.tlFloater {
  float: left;
  margin: 0 1em;
}

.tlNavMenuButton {
  padding-left: 40px;
  background-color: #eee;
}

.tlNavMenuButton:before {
  position: absolute;
  margin-left: -24px;
  font-family: "fontello";
  content: "\f04a";
}

.tlNavMenuButton:hover {
  background-color: #ccc;
  color: black;
}

.tlNavMenuButton.active {
  background-color: darkgrey;
  color: #eee;
}

.tlAccordion {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.2s ease-out;
}

.tlNotices {
  margin: 1.5rem 0;
  padding: 1px .8rem 1px 30px;
  border-radius: 6px;
}

.tlNotices.blue {
  border-left: 10px solid #5bc0ee;
	background: #f4f8fc;
	color: #28a1e5;
}

.tlNotices.green {
  border-left: 10px solid #5bc85b;
	background: #f1f9f1;
	color: #3dab3d;
}

.tlNotices.yellow {
  border-left: 10px solid #ffc562;
  background: #fcf8f2;
  color: #efaa33;
}

.tlNotices.red {
  border-left: 10px solid #e9534f;
  background: #fdf7f7;
  color: #d52b27;
}
