@font-face {
  font-family: 'Pontano Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/pontanosans/v8/qFdD35GdgYR8EzR6oBLDHa3qwg.ttf) format('truetype');
}
@font-face {
  font-family: 'Zen Maru Gothic';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/zenmarugothic/v4/o-0SIpIxzW5b-RxT-6A8jWAtCp-k7Q.ttf) format('truetype');
}
@font-face {
  font-family: 'Zen Maru Gothic';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(https://fonts.gstatic.com/s/zenmarugothic/v4/o-0XIpIxzW5b-RxT-6A8jWAtCp-cGWtCPA.ttf) format('truetype');
}
* {
  color: #1F8A26;
  box-sizing: border-box;
  font-family: 'Pontano Sans', 'sans serif';
}
body {
  margin: 0;
  font-size: 14pt;
  height: 100%;
}
h1,
h2,
h3 {
  font-family: 'Zen Maru Gothic', 'sans serif';
  color: #095256;
}
h1 {
  font-size: 18pt;
}
h2 {
  font-size: 14pt;
}
a {
  text-decoration: none;
  color: #004E05;
}
a:hover {
  text-decoration: none;
  color: #61C067;
}
.login {
  width: 300px;
  margin-top: 250px;
  margin-left: auto;
  margin-right: auto;
}
.alert {
  color: #F00;
}
.notice {
  color: #00A100;
}
.closed {
  height: 0;
}
#top-navi {
  z-index: 1000;
  width: 100%;
  display: flex;
  flex-direction: column;
}
#top-navi div#menu-button {
  font-size: 17pt;
  text-align: center;
  padding: 5px;
  font-family: 'Pontano Sans', 'arial', 'sans serif';
  font-weight: bold;
  background-color: #fff;
  cursor: pointer;
}
#top-navi ul {
  transition: height 0.5s ease-in-out;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}
#top-navi ul li {
  list-style: none;
  overflow: hidden;
}
#top-navi ul li a {
  text-decoration: none;
  font-size: 17pt;
  display: block;
  text-align: center;
  padding: 5px;
  font-family: 'Pontano Sans', 'arial', 'sans serif';
  font-weight: bold;
  z-index: 100;
  background-color: #fff;
}
#wrapper {
  min-height: 100%;
  display: grid;
  grid-template-rows: auto 1fr auto;
}
.full-width {
  width: 100%;
}
#banner {
  background-image: url("/img/header_image2_small.jpg");
  height: 300px;
  background-size: cover;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-areas: "title" "textl" "textr";
}
#banner > div {
  padding: 10px;
  text-align: center;
  color: #f0e8db;
  font-family: 'Zen Maru Gothic', "sans serif";
  font-weight: 500;
  font-size: 16pt;
}
#banner > div > p {
  padding: 10px;
  text-align: center;
  color: #f0e8db;
  font-family: 'Zen Maru Gothic', "sans serif";
  font-weight: 500;
  font-size: 12pt;
}
#banner #hookline {
  grid-area: title;
}
#banner #dateline {
  grid-area: textl;
}
#banner #locationline {
  grid-area: textr;
}
.tiles {
  margin: 10px;
}
.tiles > div {
  display: flex;
  flex-direction: column;
}
.tiles > div > img {
  display: none;
}
img.profpic {
  display: block;
  width: 250px;
  height: 250px;
}
.tileimage {
  display: none;
}
td {
  padding-left: 2em;
  padding-bottom: 1.6em;
}
label {
  display: block;
}
form#emailform div {
  padding: 10px;
}
div.fields {
  display: grid;
}
input {
  border: 1px solid #BCE372;
  border-radius: 4px;
  padding: 8px;
}
input[type=button] {
  background-color: #BCE372;
  color: #00393C;
  transition: all 0.2s ease-in;
}
input[type=button]:hover {
  color: #009aa2;
  cursor: pointer;
}
textarea {
  border: 1px solid #BCE372;
  border-radius: 4px;
  padding: 8px;
  min-height: 120px;
}
select {
  border: 1px solid #BCE372;
  border-radius: 4px;
  padding: 8px;
  background-color: #BCE372;
  color: #00393C;
}
@media only screen and (min-width: 900px) {
  article {
    margin: 50px 120px 120px;
  }
  #site-header {
    z-index: 1200;
    position: fixed;
  }
  #top-navi {
    z-index: 1000;
    width: 100%;
    display: flex;
    position: relative;
    bottom: -3pt;
    align-items: flex-end;
  }
  #top-navi div#menu-button {
    display: none;
  }
  #top-navi ul {
    margin: 0;
    padding: 0;
    z-index: 1000;
    margin-left: auto;
    margin-right: auto;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
  }
  #top-navi ul li {
    list-style: none;
    z-index: 100;
    overflow: hidden;
  }
  #top-navi ul li a {
    text-decoration: none;
    font-size: 17pt;
    display: block;
    text-align: center;
    padding: 5px;
    font-family: 'Pontano Sans', 'arial', 'sans serif';
    font-weight: bold;
    z-index: 100;
    transition: border-bottom 0.2s ease-in;
    border-bottom: 3pt solid #61C067;
    background-color: #fff;
  }
  #top-navi ul li a:link,
  #top-navi ul li a:visited {
    color: #095256;
  }
  #top-navi ul li a:hover,
  #top-navi ul li a:active {
    border-bottom-color: #095256;
  }
  #top-navi ul li#current a {
    border-bottom-color: #095256;
  }
  #top-navi.scrolled ul li a {
    font-size: 95%;
    transition: all 0.3s ease-out;
  }
  #top-navi #logo {
    height: 90px;
    display: inline;
    transition: height 0.3s ease-out;
  }
  #banner {
    background-image: url("/img/header_image2.jpg");
    height: 1080px;
    padding-top: 150px;
    position: relative;
    z-index: 10;
    grid-template-columns: 1fr 4fr 4fr 1fr;
    grid-template-areas: ". title title ." ". textl textr .";
  }
  #banner > div {
    color: #f0e8db;
    text-shadow: 2px 2px 5px #000;
    padding: 10px;
    text-align: center;
  }
  #banner > div > p {
    color: #f0e8db;
    text-shadow: 2px 2px 5px #000;
    padding: 10px;
    text-align: center;
    font-size: 40pt;
  }
  #banner #hookline {
    grid-area: title;
    font-size: 60pt;
  }
  #banner #dateline {
    grid-area: textl;
    font-size: 40pt;
  }
  #banner #locationline {
    grid-area: textr;
    font-size: 40pt;
  }
  .tiles {
    margin-bottom: 80px;
  }
  .tiles > div {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-around;
  }
  .tiles > div > img {
    display: initial;
    margin-top: 70px;
    width: 30%;
    height: fit-content;
  }
  .tiles > div > div {
    padding-left: 10px;
    width: 60%;
  }
  .tiles > div > div.profile {
    width: 30%;
    flex-direction: column;
    align-items: center;
  }
  div.fields {
    grid-template-columns: 50% 50%;
    grid-auto-rows: minmax(80px, auto);
  }
}
#footer {
  flex-shrink: 0;
  color: #61C067;
  background-color: #095256;
  padding: 20px;
}
#footer p,
#footer a {
  font-family: 'Zen Maru Gothic', 'sans serif';
  font-weight: 500;
  color: #61C067;
  background-color: #095256;
}
#footer a:hover {
  text-decoration: underline;
}
#site-header {
  background-color: #fff;
  border-bottom: 3pt solid #61C067;
  display: flex;
  width: 100%;
}
#logo {
  height: 90px;
  display: none;
}
