@import url("https://fonts.googleapis.com/css2?family=Palette+Mosaic&display=swap");
/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

.post .post-title, .site-title, blockquote::before, h2, h1 {
  font-family: "Palette Mosaic", "Helvetica", "Arial", sans-serif;
  font-weight: 400;
  font-style: normal;
  text-transform: uppercase;
  line-height: 1.4;
}

body {
  font-family: "Helvetica Neue", "Helvetica", "Arial", sans-serif;
}

video, .image-gallery.fancy li img, .project-featured-image, .project-thumbnail, figure img {
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 8px;
  box-shadow: 4px 4px 8px rgba(0, 0, 0, 0.05);
}

body {
  background: #FFFFFF;
  color: #000000;
  margin: 0;
  padding: 0;
  font-size: 18px;
  line-height: 1.8;
}

h1,
h2,
h3,
h4 {
  margin-bottom: 1rem;
}

h1 {
  font-size: 4rem;
}

h2 {
  font-size: 2.5rem;
}

h3 {
  font-weight: bold;
  font-size: 1.125rem;
  margin-bottom: 0;
}

p {
  margin-bottom: 1rem;
}

th {
  text-align: left;
}

td, th {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}

th {
  border-bottom: 3px solid rgba(12.6, 12.5, 12.55, 0.1);
}

td {
  border-top: 1px solid rgba(12.6, 12.5, 12.55, 0.1);
}

.event-schedule ul, .post ol,
.page main ol, .post ul,
.page main ul {
  margin-left: 1rem;
  margin-bottom: 1rem;
}
.event-schedule ul li, .post ol li,
.page main ol li, .post ul li,
.page main ul li {
  margin-bottom: 0;
  margin-left: 1rem;
}

.post .post-supertitle, .note, figcaption {
  font-size: 0.875rem;
  line-height: 1.25rem;
}

a {
  color: #3863e3;
  text-decoration: underline;
  transition: color 300ms ease;
}

a:hover,
a:focus {
  color: rgb(28, 49.5, 113.5);
}

a:active {
  color: #000;
  opacity: 1;
}

em {
  font-weight: normal;
  font-style: italic;
}

strong {
  font-weight: bold;
}

blockquote {
  margin-left: 2rem;
}
blockquote::before {
  content: open-quote;
  color: #895689;
}

figure {
  margin-bottom: 2rem;
}
figcaption {
  margin-top: 0.5rem;
}

img {
  width: 100%;
  height: auto;
}

/* Branding
------------------------------------------------- */
.site-title {
  color: #215b34;
  font-size: 1.5rem;
  text-decoration: none;
}

/* Footer
------------------------------------------------- */
.site-footer {
  font-size: 0.75rem;
}

/* Home
------------------------------------------------- */
.home > section {
  margin-bottom: 4rem;
}

/* Social Icons
------------------------------------------------- */
.social-icon {
  display: inline-block;
  width: 34px;
  height: 34px;
  text-indent: 100%; /* hide text: http://www.zeldman.com/2012/03/01/replacing-the-9999px-hack-new-image-replacement/ */
  white-space: nowrap;
  overflow: hidden;
  margin-right: 1rem;
  background-image: url("../images/icons-social-sprite.svg");
  background-repeat: no-repeat;
  background-size: 34px auto;
}

.social-icon-twitter {
  background-position: 0px 0px;
}

.social-icon-facebook {
  background-position: 0px -44px;
}

.social-icon-linkedin {
  background-position: 0px -88px;
}

.social-icon-mastodon {
  background-position: 0px -132px;
}

/* Thoughts
------------------------------------------------- */
.posts-widget .post-title,
.posts-widget .post-meta {
  color: rgba(12.6, 12.5, 12.55, 0.4);
  margin-bottom: 0;
}

/* Posts & Pages
------------------------------------------------- */
.post ul,
.page main ul {
  list-style: disc;
}
.post ol,
.page main ol {
  list-style: decimal;
}
.post table th,
.page main table th {
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.875em;
}

/* Posts & Pages
------------------------------------------------- */
.event-schedule ul {
  list-style: disc;
}

/* Posts
------------------------------------------------- */
.post .post-content {
  margin-top: 1rem;
}
.post .post-title {
  font-size: 2rem;
  line-height: 2rem;
  margin-bottom: 0;
}
.post .post-supertitle {
  text-transform: uppercase;
  margin-bottom: 0.5rem;
}
.post .post-meta {
  color: rgba(12.6, 12.5, 12.55, 0.4);
}

.posts .post {
  margin-bottom: 4rem;
}
.posts .post .post-meta {
  margin-bottom: 1rem;
}
.posts .post .post-title {
  margin-bottom: 1rem;
}

.back-to-posts {
  margin-top: 4rem;
}

/* Portfolio
------------------------------------------------- */
.project-card {
  position: relative;
}
.project-card a {
  border-bottom: none;
}
.project-card.card-locked a::before {
  content: url("/images/icon-lock-reverse.svg");
  width: 14px;
  height: 20px;
  position: absolute;
  padding: 4px 8px;
  background: #0A745D;
  top: 8px;
  right: 8px;
  border-radius: 4px;
  z-index: 10;
  transition: all ease-in-out 200ms;
  box-shadow: 1px 1px 2px rgba(0, 0, 0, 0.05);
}
@media (prefers-reduced-motion: no-preference) {
  .project-card a:hover::before {
    transform: translate(-6px, -6px);
    box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.05);
  }
  .project-card a:hover img {
    transform: translate(-4px, -4px);
    box-shadow: 8px 8px 12px rgba(0, 0, 0, 0.1);
  }
}

.project-thumbnail {
  transition: all ease-in-out 200ms;
  z-index: 5;
}

.post.project .post-title {
  margin-bottom: 2rem;
}
.post.project section h2 {
  color: #895689;
}
.post.project section {
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}
.post.project .project-summary ol, .post.project .project-summary ul {
  font-size: 1.5rem;
  line-height: 2rem;
}
.post.project .project-summary ol li, .post.project .project-summary ul li {
  margin-bottom: 1rem;
}

.image-gallery {
  margin: 0;
  padding: 0;
}
.image-gallery li {
  list-style: none;
  margin: 0;
  padding: 0;
}

.image-gallery.fancy li:nth-child(1) {
  transform: rotate(randomNum(-2, 2)deg);
}
.image-gallery.fancy li:nth-child(2) {
  transform: rotate(randomNum(-2, 2)deg);
}
.image-gallery.fancy li:nth-child(3) {
  transform: rotate(randomNum(-2, 2)deg);
}
.image-gallery.fancy li:nth-child(4) {
  transform: rotate(randomNum(-2, 2)deg);
}
.image-gallery.fancy li:nth-child(5) {
  transform: rotate(randomNum(-2, 2)deg);
}
.image-gallery.fancy li:nth-child(6) {
  transform: rotate(randomNum(-2, 2)deg);
}
.image-gallery.fancy li:nth-child(7) {
  transform: rotate(randomNum(-2, 2)deg);
}
.image-gallery.fancy li:nth-child(8) {
  transform: rotate(randomNum(-2, 2)deg);
}
.image-gallery.fancy li:nth-child(9) {
  transform: rotate(randomNum(-2, 2)deg);
}
video {
  width: 100%;
  height: auto;
}

/* Forms
------------------------------------------------- */
/* style the placeholder text on the form */
::-webkit-input-placeholder {
  color: rgba(252, 250, 251, 0.67);
}

:-moz-placeholder { /* Firefox 18- */
  color: rgba(252, 250, 251, 0.67);
}

::-moz-placeholder { /* Firefox 19+ */
  color: rgba(252, 250, 251, 0.67);
}

:-ms-input-placeholder {
  color: rgba(252, 250, 251, 0.67);
}

input[type=text],
input[type=email] {
  border: 0;
  background: rgba(252, 250, 251, 0.25);
  font-family: "Sanchez", "Helvetica", "Arial", "sans-serif";
  font-size: 1rem;
  padding: 0.5rem 2%;
  width: 96%;
  color: #FCFAFB;
}

/* custom checkbox: http://webdesign.tutsplus.com/tutorials/quick-tip-easy-css3-checkboxes-and-radio-buttons--webdesign-8953 */
input[type=checkbox] {
  display: none;
}

input[type=checkbox] + label {
  cursor: pointer;
}

input[type=checkbox] + label span {
  display: inline-block;
  width: 20px;
  height: 18px;
  margin: -2px 4px 0 0;
  vertical-align: middle;
  background: url("../images/ui-checkbox-sprite.svg") 0 0 no-repeat;
  cursor: pointer;
}

input[type=checkbox]:checked + label span {
  background-position: 0 -22px;
}

input[type=submit] {
  border: 1px solid #FCFAFB;
  font-family: "Sanchez", "Helvetica", "Arial", "sans-serif";
  font-weight: bold;
  font-size: 1.5rem;
  padding: 0.5rem 1rem;
  color: #FCFAFB;
  background: transparent;
  transition: all 0.2s ease;
}

input[type=submit]:hover,
input[type=submit]:focus {
  background: rgba(252, 250, 251, 0.25);
}

input[type=submit]:active {
  background: #FCFAFB;
  color: #000;
}

/* Utilities
------------------------------------------------- */
.visuallyhidden {
  position: absolute; /* visually hidden: http://snook.ca/archives/html_and_css/hiding-content-for-accessibility */
  overflow: hidden;
  clip: rect(0 0 0 0);
  height: 1px;
  width: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
}

body {
  padding-bottom: 4rem;
}

.site-header {
  padding: 1rem 1rem 4rem 1rem;
}

.site-logo {
  max-width: 15rem;
  height: auto;
}

.site-footer {
  padding: 4rem 1rem 0 1rem;
  text-align: right;
}

.home section,
.page main {
  max-width: 50rem;
  margin-right: auto;
  margin-left: auto;
  padding: 1rem;
}

/* Wider than a phone
------------------------------------------------- */
@media screen and (min-width: 40rem) {
  .image-gallery {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: 0.5rem;
  }
}
/* Taller and wider than a phone
------------------------------------------------- */
/* Taller than a small laptop
------------------------------------------------- */
/* Wider than a medium laptop
------------------------------------------------- */

/*# sourceMappingURL=screen.css.map */