
* {
  --color_dark_1: rgba(0, 0, 0, 0.8);
  --color_mint: #99c7c0;
  --color_vanilla: #95a1cf;
  --color_raspberry: #db97af;
  --color_mango: #fcdab1;
  --color_blueberry: #8879ab;
  --color_pear: #99c7a6;
  --color_peach: #ff9b99;

  --gap: 2rem;
  --base_font_size: 16px;

  --grid_areas: 
    "header"  
    "text_content"
    "contact";
  --grid_areas_reverse:
    "header"  
    "text_content"
    "contact";
  --grid_columns: 1fr;
  --grid_columns_reverse: 1fr;
}


@media(min-width: 481px) {

}
@media(min-width: 769px) {
  * {
    --content_width: 60rem;
    --grid_areas:
      "header  text_content"
      "contact text_content";
    --grid_areas_reverse:
      "text_content header"
      "text_content contact";
    --grid_columns: 1fr 2fr;
    --grid_columns_reverse: 2fr 1fr;
    --base_font_size: 18px;
  }
}

@media(min-width: 1025px) {
  * {
    --base_font_size: 20px;
  }
}

*, strong.default {
  font-family: sans-serif; /*Georgia, 'Times New Roman', Times, serif; */
  color: var(--color_dark_1)
}
html {
  font-size: var(--base_font_size);
}

body {
  font-family: "Noto Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  line-height: 1.4;
}

h1, .h1, h2, .h2, strong {
  font-family: "DM Serif Display", serif;
  font-weight: 400;
  font-style: normal;
  background-color: var(--color_dark_1);
  color: transparent;
  text-shadow: 2px 2px 3px rgba(255,255,255,0.1);
  background-clip: text;
}

strong {
  font-size: 1.1em;
}

p > strong {
  line-height: .8;
}

.obnoxious {
  font-size: 4rem;
}

h1, .h1 { 
  font-size: 1.8rem;
  margin-top: 0;
  margin-bottom: .8em;
}

h2, .h2 { 
  font-size: 1.25rem;
  margin-top: 1.4em;
  margin-bottom: .6em;
}
h3, .h3 { 
  font-size: 1rem;
  margin-top: 2em;
  margin-bottom: 1em;
}
p {
  margin-top: 0;
  line-height: 1.5;
}
p:last-child {
  margin-bottom: 0;
}
ul {
  line-height: 1.4;
}
li {
  margin-bottom: .5em;
}

.absolute {position: absolute;}
.relative {position: relative;}
.flex {display: flex;}
.flex-column {flex-direction: column;}
.center {justify-content: center; align-items: center;}
.text_center {text-align: center;}
.full_pager {
  box-sizing: border-box;
  min-height: 100vh;
  /*scroll-snap-align: start;*/
}
.ahead {
  position: relative;
  z-index: 2;
}

body {
  margin:0;
  padding:0;
}

html, body {
  scroll-behavior: smooth;
  /*scroll-snap-type: y proximity;*/
}

.contact > * {
  display: block;
}

header img {
  width: 20rem;
  margin-bottom: 4rem;
}

footer {position: relative;}

footer.pastel .contact {
  position: absolute;
  bottom: var(--gap);
  left: var(--gap);
  text-align: left;
}

footer .contact .location {
  max-width: 15em;
}

.footer p.h1 {
  max-width: 16em;
}

@media (max-width: 768px) {
  footer p.h1 {
    align-self: flex-start;
  }
}

.contact p.location {
  font-size: .8rem;
  margin-top: 1em;
}

.pastel {
  background-image:url('/grain.png');
  padding: calc(var(--gap) * 2) var(--gap);
}

.pastel .container {
  display: grid;
  width: var(--content_width);
  grid-template-areas: var(--grid_areas);
  grid-template-columns: var(--grid_columns);
  gap: var(--gap);
}

.pastel.header_right .container {
  grid-template-areas: var(--grid_areas_reverse);
  grid-template-columns: var(--grid_columns_reverse);
}

.pastel h1 {
  margin-top:-.25rem;
  margin-bottom: 0;
  grid-area: header;
}

.pastel .text_content {
  grid-area: text_content;
}

.pastel .text_content p:first-of-type {
  margin-top: 0;
}

.pastel .contact {
  grid-area: contact;
}

@media (min-width: 769px) {
  .pastel h1, .pastel .contact {
    text-align: right;
  }

  .pastel .contact {
    align-self: flex-end;
  }
  
  .pastel.header_right h1, .pastel.header_right .contact {
    text-align: left;
    order: 2;
  }
  .pastel .container .text_content {
    border-left: 1px solid var(--color_dark_1);
    padding-left: var(--gap);
  }
  
  .pastel.header_right .container .text_content {
    padding-left: 0;
    padding-right: var(--gap);
    border-left: 0;
    border-right: 1px solid var(--color_dark_1);
  }
}

@media (max-width: 768px) {
  section.pastel.center {
    align-items: flex-start;
  }
}


.mint       { background-color: var(--color_mint);      }
.vanilla    { background-color: var(--color_vanilla);   }
.raspberry  { background-color: var(--color_raspberry); }
.mango      { background-color: var(--color_mango);     }
.blueberry  { background-color: var(--color_blueberry); }
.pear       { background-color: var(--color_pear);      }
.peach      { background-color: var(--color_peach);     }
