@font-face {
  font-family: 'pamnew06regular';
  src: url("/static/css/pam_6-webfont.woff2") format("woff2"), url("/static/css/pam_6-webfont.woff") format("woff");
  font-weight: normal;
  font-style: normal; }

body {
  font-smooth: always;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-family: 'pamnew06regular', sans-serif;
  font-size: 17px;
  line-height: 1.45em;
  /*font-weight: 400;*/
  margin: 0;
  /*font-family: 'Nunito', sans-serif;*/
  color: #5f5454; }

h1, h2, h3, h4, h5, h6 {
  /*font-family: 'Playfair Display', serif;*/
  /*font-style: italic;*/ }

h1 {
  padding: 0;
  margin: 0 0 4px 0;
  font-weight: 300;
  font-size: 17px;
  text-transform: uppercase;
  /*border-bottom: 1px solid #d0d0d0;*/
  padding-bottom: 0.5em;
  display: inline-block;
  /*float: left;*/ }

h4 {
  text-transform: uppercase;
  font-size: 11px;
  font-weight: 400; }

nav ul {
  margin-top: 0;
  padding-left: 0;
  list-style-type: none;
  font-weight: 400; }
  nav ul li {
    height: 28px;
    overflow-y: hidden;
    border-bottom: solid 2px transparent; }
    nav ul li.selected a {
      color: black; }
      nav ul li.selected a:hover {
        background-color: black;
        color: white; }

main a {
  color: black;
  text-decoration: none; }

nav ul a {
  color: grey;
  text-decoration: none;
  padding: 8px 10px 0 10px;
  display: inline-block; }
  nav ul a #home-txt {
    color: transparent; }
  nav ul a:hover #home-txt {
    -webkit-transition: color 2s;
    transition: color 2s;
    color: white; }
  .home nav ul a {
    color: black; }
  nav ul a:hover {
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
    background-color: black;
    color: white; }

#name_n_nav {
  grid-column: 1 / span 1;
  grid-row: 1; }

#name {
  font-weight: 800;
  margin-top: 0; }
  #name a {
    text-decoration: none;
    color: black; }

#contact {
  width: calc(50% - 30px);
  background: aqua;
  position: absolute;
  right: 0;
  top: 0;
  height: calc(100vh - 40px);
  padding: 20px;
  text-align: center;
  font-size: 30px;
  color: #12557f;
  line-height: 1.3em;
  display: none;
  opacity: 0;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  z-index: 10; }
  @media (max-width: 500px) {
    #contact {
      width: calc(100% - 40px); } }
  #contact #close-contact {
    display: inline-block;
    padding: 50px 50px 0px 50px; }
    #contact #close-contact svg {
      fill: white;
      width: 50px; }
  #contact p {
    margin: 0; }
    #contact p a {
      -webkit-text-decoration-skip: ink;
      text-decoration-skip: ink;
      color: #12557f; }
    #contact p#contact-name {
      margin-bottom: 30px; }
  #contact span {
    display: none; }

.show-contact {
  -webkit-transition: all 1s;
  transition: all 1s;
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  opacity: 1 !important; }

@-webkit-keyframes fade-in {
  0% {
    -webkit-transform: translateY(-100px);
    transform: translateY(-100px);
    opacity: 0; }
  40% {
    -webkit-transform: translateY(0);
    transform: translateY(0); }
  100% {
    opacity: 1; } }

@keyframes fade-in {
  0% {
    -webkit-transform: translateY(-100px);
    transform: translateY(-100px);
    opacity: 0; }
  40% {
    -webkit-transform: translateY(0);
    transform: translateY(0); }
  100% {
    opacity: 1; } }

.home section {
  grid-column: 4 / span 6;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-animation: fade-in ease-in-out 2s forwards;
  animation: fade-in ease-in-out 2s forwards; }
  @media (min-width: 701px) {
    .home section {
      height: calc(100vh - 40px); } }
  @media (max-width: 700px) {
    .home section {
      grid-column: 1 / span 12;
      grid-row: 2 / 3;
      padding: 0 10px 2em 10px; } }
  .home section h2 {
    font-size: 48px !important;
    line-height: 1em !important;
    font-weight: 300;
    color: black !important;
    margin: 0;
    -webkit-transition: opacity 1s ease-in-out;
    transition: opacity 1s ease-in-out; }
  .home section h3 {
    font-weight: 300 !important;
    color: aqua !important; }

.home #colophon-wrapper {
  width: 100%;
  grid-row: 2 / span 1;
  grid-column: 1 / 12;
  color: lightgrey; }
  @media (max-width: 700px) {
    .home #colophon-wrapper {
      grid-row: 3 / 4; } }
  .home #colophon-wrapper #colophon {
    padding-left: 10px;
    margin-top: -40px; }
    .home #colophon-wrapper #colophon span {
      color: black; }

.work-index main {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: calc((100vh - 80px) / 3);
  grid-gap: 20px;
  padding: 0 20px;
  margin: 20px auto;
  max-width: 1600px; }
  @media screen and (min-height: 1200px) {
    .work-index main {
      grid-auto-rows: 360px; } }

.work-item {
  grid-column-start: 7;
  grid-column-end: span 3;
  grid-row-end: span 1;
  padding: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  color: white;
  background-color: #eee;
  -webkit-transition: background-image 3.5s;
  transition: background-image 3.5s; }
  .work-item h4 {
    color: white;
    font-size: 16px;
    margin: 0; }
  .work-item:hover {
    -webkit-transition: background 3.5s;
    transition: background 3.5s;
    background-image: none !important; }

.work-page header {
  background: white;
  background: linear-gradient(45deg, #eeeeee 0%, white 100%);
  padding: 20px; }
  .work-page header section {
    padding-top: 0 !important; }
  .work-page header article {
    padding: 40px 0 40px 0;
    grid-column: 7 / span 5; }
    .work-page header article h1 {
      color: black;
      font-size: 20px;
      padding-bottom: 0;
      text-transform: none; }

.work-page .section-wrapper {
  padding: 0 20px; }

.grid_basics, .work-page section, blockquote, .video-wrapper {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-gap: 10px 20px;
  margin-left: auto;
  margin-right: auto;
  max-width: 1600px;
  padding: 60px 0; }

.work-page section h5 {
  grid-column: 7 / 9;
  grid-row: 1; }

.work-page section img {
  width: 100%;
  height: auto; }
  .work-page section img.light-grey-border {
    border: solid 1px #eee; }
  .work-page section img.grey-border {
    border: solid 1px #dbdbdb; }
  .work-page section img.white-border {
    border: solid 1px #fff; }

.work-page section .gre_1 {
  grid-row-end: span 1; }

.work-page section .gre_2 {
  grid-row-end: span 2; }

.work-page section .gce_1 {
  grid-column-end: span 1; }

.work-page section .gce_2 {
  grid-column-end: span 2; }

.work-page section .gce_3 {
  grid-column-end: span 3; }

.work-page section .gce_4 {
  grid-column-end: span 4; }

.work-page section .gce_5 {
  grid-column-end: span 5; }

.work-page section .gce_6 {
  grid-column-end: span 6; }

.work-page section .gce_7 {
  grid-column-end: span 7; }

.work-page section .gce_8 {
  grid-column-end: span 8; }

.work-page section .gce_9 {
  grid-column-end: span 9; }

.work-page section .gce_10 {
  grid-column-end: span 10; }

.work-page section .gce_11 {
  grid-column-end: span 11; }

.work-page section .gce_12 {
  grid-column-end: span 12; }

blockquote {
  margin-top: 0;
  margin-bottom: 0; }
  blockquote .quote_image_wrapper img {
    margin-top: 17px; }
  blockquote .quote_wrapper {
    color: black;
    grid-column: 7/span 5; }

#hero img {
  width: 100%; }

/*article	{
	margin-top: 1em;
}
*/
#made-at a {
  color: black;
  text-decoration: none; }
  #made-at a:hover {
    text-decoration: underline; }

.full-width-image {
  width: 100%;
  grid-column: 4/span 3; }

.half-width-image {
  grid-column: 2 / span 2;
  width: 100%; }

.first_column {
  grid-column: 1 / span 5; }

.second_column {
  grid-column: 7 / span 5; }

.caption {
  font-size: 15px;
  line-height: 1.4rem; }

.tag {
  display: inline-block;
  background-color: #eee;
  padding: 10px 10px 0px 10px;
  color: #999999;
  text-decoration: none;
  margin-right: 2px; }
  .tag:hover {
    color: #eee;
    background-color: #222526; }

#tags_n_next {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-gap: 10px 20px;
  margin-left: auto;
  margin-right: auto;
  padding: 0;
  max-width: 1600px; }

@-webkit-keyframes fade-in2 {
  0% {
    -webkit-transform: translateX(-100px);
    transform: translateX(-100px);
    opacity: 0; }
  40% {
    -webkit-transform: translateX(0);
    transform: translateX(0); }
  100% {
    opacity: 1; } }

@keyframes fade-in2 {
  0% {
    -webkit-transform: translateX(-100px);
    transform: translateX(-100px);
    opacity: 0; }
  40% {
    -webkit-transform: translateX(0);
    transform: translateX(0); }
  100% {
    opacity: 1; } }

.video-wrapper .half_1st_col {
  grid-column: 1/span 6; }

.video-wrapper .half_2nd_col {
  grid-column: 7/span 6; }

.video-wrapper .full_width {
  grid-column: 1/span 12; }

#next-project, #previous-project {
  grid-column: 7 / span 6;
  display: block;
  text-decoration: none;
  margin: 2em 0;
  padding: 50px 0;
  font-size: 17px;
  background-color: transparent;
  background-size: 200% 100%;
  background-image: -webkit-gradient(linear, right top, left top, from(transparent), color-stop(30%, rgba(0, 0, 0, 0.02)), color-stop(50%, transparent));
  background-image: linear-gradient(to left, transparent 0%, rgba(0, 0, 0, 0.02) 30%, transparent 50%);
  color: black;
  -webkit-transition: background-position 0.5s;
  transition: background-position 0.5s; }
  #next-project:hover, #previous-project:hover {
    background-position: -100% 0; }
    #next-project:hover #next-intro, #next-project:hover #previous-intro, #previous-project:hover #next-intro, #previous-project:hover #previous-intro {
      -webkit-animation: fade-in2 ease-in-out 0.75s forwards;
      animation: fade-in2 ease-in-out 0.75s forwards; }

#next-intro, #previous-intro {
  display: inline-block;
  opacity: 0; }

#previous-project {
  grid-column: 1 / span 6; }
  #previous-project:hover {
    background-position: 100% 0; }

.resume main, .home main {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-gap: 20px;
  padding: 0 20px;
  margin: 20px auto;
  max-width: 1600px; }
  .resume main .job-block, .home main .job-block {
    margin-top: 2em; }
  .resume main h2, .home main h2 {
    color: #194d4d;
    font-size: 15px; }
  .resume main h4, .home main h4 {
    margin-bottom: 0;
    color: #899898;
    font-weight: 300; }
  .resume main .non-url-line h4, .home main .non-url-line h4 {
    margin-bottom: -10px; }
  .resume main h3, .home main h3 {
    margin-top: 0;
    color: #899898;
    line-height: 27px; }
    .resume main h3 .company, .home main h3 .company {
      display: inline-block;
      color: black;
      border-bottom: 2px aqua solid;
      height: 21px; }
    .resume main h3 a:hover, .home main h3 a:hover {
      color: aqua; }
  .resume main .non-url-line h3 .company, .home main .non-url-line h3 .company {
    border-top: 2px aqua solid;
    border-bottom: none;
    padding-top: 10px; }
  .resume main .rich-text a, .home main .rich-text a {
    display: inline-block;
    height: 6px;
    border-bottom: 2px solid aqua; }
  .resume main #full-time, .resume main #education, .resume main #key-skills, .home main #full-time, .home main #education, .home main #key-skills {
    grid-column-start: 6;
    grid-column-end: span 3; }
    @media (max-width: 1024px) {
      .resume main #full-time, .resume main #education, .resume main #key-skills, .home main #full-time, .home main #education, .home main #key-skills {
        padding-left: 10px;
        grid-column: 1 / span 5; } }
    @media (max-width: 500px) {
      .resume main #full-time, .resume main #education, .resume main #key-skills, .home main #full-time, .home main #education, .home main #key-skills {
        padding-left: 10px;
        padding-right: 10px;
        grid-column: 1 / span 12; } }
  .resume main #freelance-part-time, .resume main #technical-skills, .resume main #key-skills-col2, .home main #freelance-part-time, .home main #technical-skills, .home main #key-skills-col2 {
    grid-column-start: 10;
    grid-column-end: span 3; }
    @media (max-width: 1024px) {
      .resume main #freelance-part-time, .resume main #technical-skills, .resume main #key-skills-col2, .home main #freelance-part-time, .home main #technical-skills, .home main #key-skills-col2 {
        padding-left: 10px;
        grid-column: 7 / span 5; } }
    @media (max-width: 500px) {
      .resume main #freelance-part-time, .resume main #technical-skills, .resume main #key-skills-col2, .home main #freelance-part-time, .home main #technical-skills, .home main #key-skills-col2 {
        padding-left: 10px;
        padding-right: 10px;
        grid-column: 1 / span 12; } }

@media (max-width: 500px) {
  #key-skills-col2 {
    display: none; }
  .resume section {
    border-top: 2px solid #eeeeee; } }

#key-skills, #key-skills-col2 {
  color: black; }

#password-container {
  width: 50vw;
  height: 100vh;
  background-color: aqua;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center; }
  @media (max-width: 768px) {
    #password-container {
      padding: 0 40px;
      width: calc(100% - 80px); } }
  #password-container h1 {
    font-size: 30px;
    text-transform: none;
    color: #12557f; }
  #password-container #password_n_button {
    margin: calc(2em - 25px) 0 1em 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center; }
    @media (max-width: 500px) {
      #password-container #password_n_button {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column; } }
  #password-container #continue_btn {
    padding: 0.5em 1em 0 1em;
    background: transparent;
    border: 2px solid #12557f;
    font-family: inherit;
    font-size: 17px;
    color: #12557f;
    margin: 0 0 0 2em; }
    #password-container #continue_btn:hover {
      border-color: white; }
    @media (max-width: 500px) {
      #password-container #continue_btn {
        margin: 1em 0 0 0; } }
  #password-container .errorlist {
    color: #12557f;
    padding-left: 0;
    list-style-type: none;
    text-align: center; }
  #password-container input[type="password"], #password-container input:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 1000px red inset !important;
    -webkit-text-fill-color: white;
    color: pink !important;
    background-color: red !important;
    border: solid 2px red;
    font-family: inherit;
    font-size: 17px;
    padding: 0.5em 1em 0 1em; }
    @media (max-width: 500px) {
      #password-container input[type="password"], #password-container input:-webkit-autofill {
        text-align: center; } }
  #password-container p {
    color: #12557f;
    padding: 0 40px;
    text-align: center; }
  #password-container a {
    text-decoration: underline;
    color: #12557f; }
    #password-container a:hover {
      text-decoration: none; }
