/* ----------- Color Variables --------- */

/*  
    light-neutral_color: '#f8f4f2'
    medium-neutral_color: '#cab485'
    dark-neutral_color: '#0d0a07'
    light-featured_color: '#a8a86a'
    dark-featured_color: '#ff6c14'
    accent_color: '#ca2801'

                                     */

/* Looking for the color variables? They have been moved to the inline-styles file in the _includes folder, and pull variables from the site-settings folder in the _data folder.  */

/* ----------- CSS RESET --------- */

* {
    padding: 0;
    margin: 0;
    box-sizing: border-box;
}
  

html {
  scroll-behavior: smooth;
}

img { max-width: 100%; height: auto; }  /* Otherwise CloudCannon might try to save aspect ratios, which can warp/ squish images when you upload i.e. a square & it makes it a portrait */ 

/* Override default gridlex padding */ 
[class*=col] { padding: 0; }
[class*=grid] { margin: 0; }

section { position: relative; }


/* ---------------- Google Fonts ----------------------------*/
/* lato-100 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Lato';
  font-style: normal;
  font-weight: 100;
  src: url('../fonts/lato-v24-latin-100.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* lato-100italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Lato';
  font-style: italic;
  font-weight: 100;
  src: url('../fonts/lato-v24-latin-100italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* lato-300 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Lato';
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/lato-v24-latin-300.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* lato-300italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Lato';
  font-style: italic;
  font-weight: 300;
  src: url('../fonts/lato-v24-latin-300italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* lato-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Lato';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/lato-v24-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* lato-italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Lato';
  font-style: italic;
  font-weight: 400;
  src: url('../fonts/lato-v24-latin-italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* lato-700 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Lato';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/lato-v24-latin-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* lato-700italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Lato';
  font-style: italic;
  font-weight: 700;
  src: url('../fonts/lato-v24-latin-700italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* lato-900 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Lato';
  font-style: normal;
  font-weight: 900;
  src: url('../fonts/lato-v24-latin-900.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* lato-900italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Lato';
  font-style: italic;
  font-weight: 900;
  src: url('../fonts/lato-v24-latin-900italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}


/* birthstone-bounce-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Birthstone Bounce';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/birthstone-bounce-v11-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* birthstone-bounce-500 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Birthstone Bounce';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/birthstone-bounce-v11-latin-500.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}


/* playfair-display-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/playfair-display-v36-latin-regular.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* playfair-display-italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 400;
  src: url('../fonts/playfair-display-v36-latin-italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* playfair-display-500 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/playfair-display-v36-latin-500.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* playfair-display-500italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 500;
  src: url('../fonts/playfair-display-v36-latin-500italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* playfair-display-600 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 600;
  src: url('../fonts/playfair-display-v36-latin-600.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* playfair-display-600italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 600;
  src: url('../fonts/playfair-display-v36-latin-600italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* playfair-display-700 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/playfair-display-v36-latin-700.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* playfair-display-700italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 700;
  src: url('../fonts/playfair-display-v36-latin-700italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* playfair-display-800 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 800;
  src: url('../fonts/playfair-display-v36-latin-800.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* playfair-display-800italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 800;
  src: url('../fonts/playfair-display-v36-latin-800italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* playfair-display-900 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 900;
  src: url('../fonts/playfair-display-v36-latin-900.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* playfair-display-900italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 900;
  src: url('../fonts/playfair-display-v36-latin-900italic.woff2') format('woff2'); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}




/* ---------- Negative Space Utility Classes  ------------------ */ 

.capped-width-wide        { max-width: 1600px; margin: auto; }
.capped-width-medium-wide { max-width: 1400px; margin: auto; }
.capped-width             { max-width: 1200px; margin: auto; }
.capped-width-narrow      { max-width: 1000px; margin: auto; }
.capped-width-v-narrow    { max-width: 800px;  margin: auto; }


.tall-100 { min-height: 100vh; }
.tall-90  { min-height: 90vh; }
.tall-80  { min-height: 80vh; }
.tall-70  { min-height: 70vh; }
.tall-60  { min-height: 60vh; }
.tall-50  { min-height: 50vh; }
.tall-20  { min-height: 20vh; }


/* Padding Utility Classes */ 
.padded-sm { padding: 2.5%; }
.padded    { padding: 5%;   }
.padded-lg { padding: 10%;  }

.padded-05 { padding: 0.5rem; }
.padded-1  { padding: 1rem; }
.padded-1-05  { padding: 1.5rem; }
.padded-2  { padding: 2rem; }

.padded-t  { padding-top: 5%; }
.padded-b  { padding-bottom: 5%; }
.padded-l  { padding-left: 5%; }
.padded-r  { padding-right: 5%; }

.padded-tb  { padding-top: 5%; padding-bottom: 5%; }
.padded-lr  { padding-left: 5%; padding-right: 5%; }

.padded-t-1 { padding-top: 1rem; }
.padded-b-1 { padding-bottom: 1rem; }
.padded-l-1 { padding-left: 1rem; }
.padded-r-1 { padding-right: 1rem; }

.padded-t-2 { padding-top: 2rem; }
.padded-b-2 { padding-bottom: 2rem; }
.padded-l-2 { padding-left: 2rem; }
.padded-r-2 { padding-right: 2rem; }

.padded-t-0 { padding-top: 0; }
.padded-b-0 { padding-bottom: 0; }
.padded-l-0 { padding-left: 0; }
.padded-r-0 { padding-right: 0; }

/* Margin Utility Classes */ 


.margin   { margin: 1rem; }
.margin-t { margin-top: 5%; }
.margin-b { margin-bottom: 5%; }
.margin-l { margin-left: 5%; }
.margin-r { margin-right: 5%; }

.margin-t-05 { margin-top: 0.5rem; }
.margin-b-05 { margin-bottom: 0.5rem; }
.margin-l-05 { margin-left: 0.5rem; }
.margin-r-05 { margin-right: 0.5rem; }

.margin-t-1 { margin-top: 1rem; }
.margin-b-1 { margin-bottom: 1rem; }
.margin-l-1 { margin-left: 1rem; }
.margin-r-1 { margin-right: 1rem; }

.margin-t-2 { margin-top: 2rem; }
.margin-b-2 { margin-bottom: 2rem; } 
.margin-l-2 { margin-left: 2rem; }
.margin-r-2 { margin-right: 2rem; }

.margin-t-0 { margin-top: 0; }
.margin-b-0 { margin-bottom: 0; }
.margin-l-0 { margin-left: 0; }
.margin-r-0 { margin-right: 0; }

.margin-tb { margin-top: 5%; margin-bottom: 5%; }
.margin-lr { margin-left: 5%; margin-right: 5%; }


/* ------------------ Typography Styles ----------------------- */

.left         { text-align: left; }
.right        { text-align: right; }
.center       { text-align: center; }
.justify      { text-align: justify;}
.uppercase    { text-transform: uppercase; }

.handwritten  { 
  font-family: 'Birthstone Bounce', cursive;
  font-size: 2.5rem;
  font-weight: 400;
}

.vertical-plus-90 { transform: rotate(90deg); }
.upside-down { transform: rotate(180deg); }
.vertical-minus-90 { transform: rotate(-90deg); }

body {
  font-family: 'Lato', sans-serif;  /* Add your font here */ 
  color: var(--dark-neutral);
}

h2, h3, h4, h5, h6 {
  line-height: 1.1;
  margin-bottom: 1.2rem;
}

h1 { font-size: 4rem; }
h2 { font-size: 2rem; }
h3 { font-size: 1.8rem; }
h4 { font-size: 1.6rem; }
h5 { font-size: 1.4rem; }
h6 { font-size: 1.2rem; }


p, li {
  line-height: 1.4; 
  margin-bottom: 1rem;
  font-family: 'Lato', sans-serif;
  font-weight: 400;
  font-size: 1rem;
}

h2:last-child, 
h3:last-child, 
h4:last-child, 
h5:last-child, 
h6:last-child, 
p:last-child {
	margin-bottom: 0;
}


ul, ol {
  list-style-position: outside;
  margin-left: 1.2rem;
}

li {
  padding-left: 0.5rem;
}


/* Unique Typography Styles  */
.emphasis             { font-size: 1.2rem; }
.dark-text            { color: var(--dark-neutral);}
.medium-text          { color: var(--medium-neutral);}
.light-text           { color: var(--light-neutral);}
.light-featured-text  { color: var(--light-featured);}
.accent-text          { color: var(--accent);}
.subtle               { opacity: 0.8;     }
.subtitle             { font-size: 0.8rem; }  /* you might also wanna make that italic */
.italic               { font-style: italic; }
.space { 
  word-spacing: 1em; 
  white-space: nowrap;
  overflow:hidden;
}

.subtle-heading { font-weight: 400; }


.fa-chevron-down      { padding-left: 0.5rem; }
.fa-chevron-up        { padding-left: 0.5rem; }

  

/* ------------ Backgrounds & Background Images  ----------------------- */

.bg-dark-neutral   { 
  background-color: var(--dark-neutral);
  color: var(--light-neutral);
}

.bg-medium-neutral { 
  background-color: var(--medium-neutral); 
  color: var(--light-neutral);
}

.bg-light-neutral  { 
  background-color: var(--light-neutral); 
  color: var(--dark-neutral);
}

.bg-light-featured { 
  background-color: var(--light-featured); 
  color: var(--dark-neutral);
}

.bg-accent { 
  background-color: var(--accent); 
  color: var(--light-neutral);
}


.bg-image {
    background-color: var(--medium-neutral); /* Set a fall-back color while images are loading */ 
    background-image: url('#');
    background-size: cover;
    background-position: center; 
    background-repeat: no-repeat;
}


/* Aspect Ratios with percentage unit are only effective if the element (the <div>) is inside a parent container or column, it can't be applied to the column itself. */

a.bg-image { display: block;}

.landscape-small { padding-bottom: 55%; }
.landscape     { padding-bottom: 66%;  }
.portrait-tall { padding-bottom: 175%; }
.portrait      { padding-bottom: 125%; }
.square        { padding-bottom: 100%; }
.round         { border-radius: 50%;   }


.flex-flip-alternate:nth-child(even) {
  flex-direction: row-reverse;
}

.main-banner {
  background-color: var(--medium-neutral);
  color: var(--light-neutral);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  min-height: 90vh;
  padding: 5%;
}

.main-banner h1 {
  font-family: 'Playfair Display', serif;
  font-weight: 500;
  font-size: 4rem;
}

.main-banner h2 {
  font-family: 'Playfair Display', serif;
  font-weight: 500;
  font-size: 3rem;
}

.banner {
  background-color: var(--medium-neutral);
  color: var(--light-neutral);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  min-height: 50vh;
  padding: 5%;
  font-size: 3rem;
  font-family: 'Playfair Display', serif;
}

.banner h2 { 
  font-size: 3rem; 
  font-weight: 500;
}


/* ------------- Overlays --------------- */
/* Full overlay */
.bg-overlay {
  position: relative;
}

.bg-overlay::before {
  content: ""; 
  position: absolute;
  top: 0;
  left: 0;
	bottom: 0;
	right: 0;
  background-color: rgba(0,0,0,0.4);
}

.bg-overlay > * {
  position: relative;
}

/* Half overlay */
.bg-overlay-half {
  position: relative;
}

.bg-overlay-half::before {
  content: ""; 
  position: absolute;
  top: 1rem;
  left: 1rem;
	bottom: 1rem;
	right: 1rem;
  width: 45%;
  background-color: rgba(0,0,0,0.5);
}

.bg-overlay-half > * {
  position: relative;
} 

/* Add a second class to change the color or style  */

.bg-overlay-gradient::after { 
  background-image: linear-gradient(0deg, rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0));
} 

.bg-overlay-featured::after { 
  background-color: var(--dark-neutral);
  opacity: 0.5;
} 



/* Background Position */
.bg-pos-t { background-position: top; }
.bg-pos-b { background-position: bottom; }
.bg-pos-l { background-position: left; }
.bg-pos-r { background-position: right; }


/* ------------ Buttons & Links ------------ */
a {
    color: inherit;
    text-decoration: none;
}

a:hover {
  color: var(--accent); 
}

p a {
    text-decoration: none;
    border-bottom: 1px solid;
}

p a:hover { 
  color: var(--accent); 
}

ul a {
  display: inline-block;
  text-decoration: none;
}


.button-neutral { 
    display: inline-block;
    text-decoration: none;
    line-height: 1;
    padding: 0.5rem 1.5rem;
    background-color: var(--light-neutral);
    color: var(--dark-neutral);
    border: 1px solid var(--dark-neutral);
    border-radius: 5px;
}

.button-neutral:hover {
    background-color: var(--dark-neutral);
    color: var(--light-neutral);
}

.button-accent { 
  display: inline-block;
  text-decoration: none;
  line-height: 1;
  padding: 0.5rem 1.5rem;
  background-color: var(--accent);
  color: var(--light-neutral);
  border: 1px solid var(--accent);
  border-radius: 5px;
}

.button-accent:hover {
  background-color: var(--light-neutral);
  color: var(--accent);
}

.subtle-button {
  text-decoration: none;
  border-bottom: 1px solid;
}

.relative {
  position: relative;
}

.top-button {
  background-color: var(--accent);
  color: var(--light-neutral);
  font-size: 1.5rem;
  position: fixed;
  padding: 0.5rem;
  bottom: 0;
  right: 0;
}

.top-button:hover {
  color: var(--light-neutral);
  border: 2px solid var(--accent);
}


/* Slider */
.slider-item {
  padding: 0.5rem;
  display: inline-block;
}



/* ------------ Header & Hamburger Menu -------------- */
header {
    padding: 1rem 5%;
}

header a:hover {
  color: var(--light-neutral);
}

nav a {
    padding: 0.5rem 0.25rem;
    margin: 0 0.5rem;
    display: inline-block;
    text-decoration: none;
    text-transform: capitalize;
}

nav a:hover {
  color: var(--light-neutral);
}

header nav a {
  border-bottom: 1px solid var(--accent);
}

header nav a:hover {
  border-bottom: 1px solid var(--light-neutral);
}


.logo {
  text-decoration: none;
  font-size: 2.5rem;
  font-family: 'Playfair Display', serif;
} 


/* Dropdown styles */

.dropdown { 
  position: relative; 
  display: inline-block;
  /* border: 1px solid orange; */
}

.dropdown-title {
  padding: 0.25rem 0.5rem;
  display: inline-block;
}

.dropdown-content {
  position: absolute;
  top: 100%;
  left: -1rem;
  padding: 0.5rem;
  display:none; 
  background-color: white;
  z-index: 2;
  text-align: left;
  min-width: 10rem;
  border: 1px solid mediumvioletred;
}

.dropdown:hover .dropdown-content{ 
  display: block;
}

.dropdown-content a {
  display: block;
  padding: 0.2rem;
}

.hamburger-button {
    cursor: pointer;
    padding: 0.5rem;
    display: inline-block;
    font-weight: 200;
    font-size: 2.5rem;
    line-height: 1.5;
    position: fixed;
    right: 5%;
    top: 0rem;
    z-index: 4;
  }
  
  /* Styles when the hamburger button is active  */
  .hamburger-button::before {
    content: "☰";
 }
 
  .hamburger-button.active::before {
   content: "✕";
   color: var(--light-neutral);
 }
  
  
  .mobile-menu {
    display: none; 
    background-color: var(--accent);
    color: var(--light-neutral);
    padding: 25%;
    position: fixed; 
    z-index:3;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    text-align: center;
  }
  
  .mobile-menu a {
    text-decoration: none; 
    font-size: 1.5rem;
    color: inherit; 
    padding: 5%;
    display: block;
    font-weight: normal;
  }

  .mobile-menu a:hover {
    text-decoration: underline; 
  }


/* ----------- Footer Styles ------------------------ */
footer a {
  display: block;
}


/* ------------ Contact Forms  ----------------------- */
input,
textarea {
    width: 100%;
    display: block;
    margin-bottom: 0.3rem;
    padding: 0.5rem;
    font-family: inherit;
    font-size: 0.9rem;
    border: none;
    border: 2px solid var(--medium-neutral);
}

input:focus, 
textarea:focus {
    outline: none;
    border: 2px solid var(--accent); 
}

form .button {
  border: 2px solid var(--accent);
  padding: 0.5rem 2rem;
  border-radius: 5px;
  background-color: var(--accent);
  color: var(--light-neutral);
  font-family: 'Lato', sans-serif;
  font-size: 1rem;
}

form .button:focus {
  background-color: var(--light-neutral);
  color: var(--accent);
}

form .button:hover {
  background-color: var(--light-neutral);
  color: var(--accent);
}


/* Miscelaneous elements  */

hr.short {
  border: 1px solid var(--dark-neutral);
  width: 2rem;
  margin: 1rem 0;
}

hr.short.center {
  margin:auto;
  margin: 1rem auto;
}

hr.medium {
  border: 1px solid var(--dark-neutral);
  width: 100%;
  margin: 1rem auto;
}


/* ------------ Page Name  ----------------------- */



/* -------------  Cookie Banner ---------------------------*/

#cookie-notice {
  padding: 0.5rem 1rem;
  display: none;
  line-height: 2;
  text-align: center;
  position: fixed;
  bottom: 0;
  width: 100%;
  background: #222;
  color: rgba(255,255,255,0.8);
}

#cookie-notice a {
  display: inline-block;
  text-decoration: underline;
  cursor: pointer;
  margin-left: 0.5rem;
}

#cookie-notice .button-subtle {
opacity: 0.8;
}

#cookie-notice .button-subtle:hover {
  color: rgba(255,255,255);
}

#cookie-notice .button {
  background: #222;
  color: rgba(255,255,255,0.8);
  text-decoration: none;
  padding: 0.25rem 1rem;
  border: 1px solid rgba(255,255,255,0.8);
  opacity: 0.8;
}

#cookie-notice .button:hover {
  background: rgba(255,255,255,0.8);
  color: #222;
  border: 1px solid #222;
}

#close-cookie-banner {
padding: 1rem;
cursor: pointer;
font-size: 0.8rem;
opacity: 0.5
}

#close-cookie-banner:hover {
  color: rgba(255,255,255);
}




/* ------------ Responsive Styles ----------------------- */

/* General CSS Responsive Styles (Apply everywhere unless overriden) */ 

.show-xs, 
.show-sm,
.show-md {
	display: none; 
}

.inline { 
  display: inline-block;
  vertical-align: top;
}



/* ------- MD Media Query (64em / 1024px) --------------- */ 
/* - Styles added here will apply at devices smaller than 576px, or zoomed in equivalent */ 

@media(max-width:64em) {

	.show-md { display: block; }
	.hide-md { display: none;  }

  .bg-overlay-half::before {
    content: ""; 
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    width: 100%;
    background-color: rgba(0,0,0,0.5);
  }

  .subtle-heading-md {
    font-weight: 300;
    font-family: 'Playfair Display', serif;
  }


  h2 {font-size: 1.4rem;}
  h4 { font-size: 1.4rem; }

  .logo {
    font-size: 2rem;
  }

  .flex-flip-sm { flex-direction: row-reverse; }

  .padded-md { padding: 5%; }
  .padded-lr { padding: 0; }

}




/* ------- SM Media Query (48em / 768px) --------------- */ 
/* - Styles added here will apply at devices smaller than 768px, or zoomed in equivalent */ 


@media(max-width:48em) {

  .show-sm { display: block; }
	.hide-sm { display: none;  }

  .sm-text-center { text-align: center; }
  .sm-text-left   { text-align: left; }
  .sm-text-right  { text-align: right; }

  .sm-padded     { padding: 5%; }
  .sm-padded-1   { padding: 1rem; }
  .sm-padded-05  { padding: 0.5rem; }

  .sm-padded-t-0 { padding-top: 0; }
  .sm-padded-b-0 { padding-bottom: 0; }
  .sm-margin-t-0 { margin-top: 0; }
  .sm-margin-b-0 { margin-bottom: 0; }

  .sm-landscape     { padding-bottom: 66% ; }
  .sm-portrait-tall { padding-bottom: 175%; }
  .sm-portrait      { padding-bottom: 125%; }
  .sm-square        { padding-bottom: 100%; }

  .padded-1-05  { padding: 1rem; }

  .margin-t-1 { margin-top: 0rem; }

  .main-banner h2 {
    font-size: 2.5rem;
  }

  .banner h2 {
    font-size: 2.5rem;
  }

  h2 { font-size: 1.2rem; }
  h4 { font-size: 1.2rem; }

  .logo {
    font-size: 1.8rem;
  }

  .margin-l-05 { 
    margin-left: 0; 
    margin-top: 0.5rem;
  }
  .margin-r-05 { 
    margin-right: 0; 
    margin-bottom: 0.5rem;
  }

  .sm-left { text-align: left; }

}



/* ------- XS Media Query (36em / 576px) --------------- */ 
/* - Styles added here will apply at devices smaller than 576px, or zoomed in equivalent */ 

@media(max-width:36em) {

		.show-xs { display: block; }
		.hide-xs { display: none;  }

    .padded { padding: 7%; }
    .padded-md { padding: 7%; }
    .padded-xs { padding: 7% }

    .subtle-heading-xs {
      font-weight: 300;
      font-family: 'Playfair Display', serif; 
    }

    .main-banner h2 {
      font-size: 1.8rem;
    }

    .banner h2 {
      font-size: 1.8rem;
    }

}