/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */

/* Document
   ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */

html {
	line-height: 1.15; /* 1 */
	-webkit-text-size-adjust: 100%; /* 2 */
	box-sizing: border-box;
	scroll-behavior: smooth;
}
* {
	box-sizing: border-box;
}

/* Sections
	 ========================================================================== */

/**
   * Remove the margin in all browsers.
   */

body {
	margin: 0;
	font-size: 1rem;
	--primary-serif: "Josefin Slab", Utopia, serif;
	--primary-sans-serif: "Urbabist", Helvetica, sans-serif;
	--site-padding-left: 1rem;
	--site-padding-top: 5rem;
	--site-padding-bottom: 1rem;
	font-family: var(--primary-sans-serif);
	background-color: #fff;
	position: relative;
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
}
@media screen and (min-width: 40rem) {
	body {
		--site-padding-left: 3.5rem;
	}
}
@media screen and (min-width: 60rem) {
	body {
		--site-padding-left: 8rem;
	}
}
/**
   * Render the `main` element consistently in IE.
   */

main,
#place-overlay {
	display: block;
	padding-top: var(--site-padding-top);
	padding-left: var(--site-padding-left);
}
section {
	padding: 2rem 0;
}

div {
	display: block;
}
/**
   * Correct the font size and margin on `h1` elements within `section` and
   * `article` contexts in Chrome, Firefox, and Safari.
   */

h1 {
	font-size: 2em;
	font-weight: 300;
	margin: 0;
	padding-bottom: 0.3rem;
}
@media screen and (min-width: 40rem) {
	h1 {
		font-size: 3em;
	}
}
h2 {
	font-weight: 300;
	font-size: 1.4em;
	font-family: "Quicksand", sans-serif;
	margin: 0;
	padding-top: 14rem;
	padding-bottom: 2rem;
	text-align: right;
}
@media screen and (min-width: 40rem) {
	h2 {
		padding-bottom: 8rem;
	}
}

ul {
	list-style-type: none;
	padding: 0;
}
p {
	font-family: var(--primary-sans-serif);
	margin: 0;
	font-weight: 300;
	max-width: 29em;
}
/* Grouping content
	 ========================================================================== */

/**
   * 1. Add the correct box sizing in Firefox.
   * 2. Show the overflow in Edge and IE.
   */

hr {
	box-sizing: content-box; /* 1 */
	height: 0; /* 1 */
	overflow: visible; /* 2 */
}

/**
   * 1. Correct the inheritance and scaling of font size in all browsers.
   * 2. Correct the odd `em` font sizing in all browsers.
   */

pre {
	font-family: monospace, monospace; /* 1 */
	font-size: 1em; /* 2 */
}

/* Text-level semantics
	 ========================================================================== */

/**
   * Remove the gray background on active links in IE 10.
   */

a,
a:active,
a:visited {
	background-color: transparent;
	color: #818181;
	font-weight: 300;
	transition: color 1s ease-out;
}
a:hover {
	color: #000;
	transition: color 0.33s ease-in;
}

/**
   * 1. Remove the bottom border in Chrome 57-
   * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
   */

abbr[title] {
	border-bottom: none; /* 1 */
	text-decoration: underline; /* 2 */
	text-decoration: underline dotted; /* 2 */
}

/**
   * Add the correct font weight in Chrome, Edge, and Safari.
   */

b,
strong {
	font-weight: bolder;
}

/**
   * 1. Correct the inheritance and scaling of font size in all browsers.
   * 2. Correct the odd `em` font sizing in all browsers.
   */

code,
kbd,
samp {
	font-family: monospace, monospace; /* 1 */
	font-size: 1em; /* 2 */
}

/**
   * Add the correct font size in all browsers.
   */

small {
	font-size: 80%;
}

/**
   * Prevent `sub` and `sup` elements from affecting the line height in
   * all browsers.
   */

sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

/* Embedded content
	 ========================================================================== */

/**
   * Remove the border on images inside links in IE 10.
   */

img {
	border-style: none;
}

/* Forms
	 ========================================================================== */

/**
   * 1. Change the font styles in all browsers.
   * 2. Remove the margin in Firefox and Safari.
   */

button,
input,
optgroup,
select,
textarea {
	font-family: inherit; /* 1 */
	font-size: 100%; /* 1 */
	line-height: 1.15; /* 1 */
	margin: 0; /* 2 */
}

/**
   * Show the overflow in IE.
   * 1. Show the overflow in Edge.
   */

button,
input {
	/* 1 */
	overflow: visible;
}

/**
   * Remove the inheritance of text transform in Edge, Firefox, and IE.
   * 1. Remove the inheritance of text transform in Firefox.
   */

button,
select {
	/* 1 */
	text-transform: none;
	color: #000;
}

/**
   * Correct the inability to style clickable types in iOS and Safari.
   */

button,
[type="button"],
[type="reset"],
[type="submit"] {
	-webkit-appearance: button;
}

/**
   * Remove the inner border and padding in Firefox.
   */

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

/**
   * Restore the focus styles unset by the previous rule.
   */

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
	outline: 1px dotted ButtonText;
}

/**
   * Correct the padding in Firefox.
   */

fieldset {
	padding: 0.35em 0.75em 0.625em;
}

/**
   * 1. Correct the text wrapping in Edge and IE.
   * 2. Correct the color inheritance from `fieldset` elements in IE.
   * 3. Remove the padding so developers are not caught out when they zero out
   *    `fieldset` elements in all browsers.
   */

legend {
	box-sizing: border-box; /* 1 */
	color: inherit; /* 2 */
	display: table; /* 1 */
	max-width: 100%; /* 1 */
	padding: 0; /* 3 */
	white-space: normal; /* 1 */
}

/**
   * Add the correct vertical alignment in Chrome, Firefox, and Opera.
   */

progress {
	vertical-align: baseline;
}

/**
   * Remove the default vertical scrollbar in IE 10+.
   */

textarea {
	overflow: auto;
}

/**
   * 1. Add the correct box sizing in IE 10.
   * 2. Remove the padding in IE 10.
   */

[type="checkbox"],
[type="radio"] {
	box-sizing: border-box; /* 1 */
	padding: 0; /* 2 */
}

/**
   * Correct the cursor style of increment and decrement buttons in Chrome.
   */

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
	height: auto;
}

/**
   * 1. Correct the odd appearance in Chrome and Safari.
   * 2. Correct the outline style in Safari.
   */

[type="search"] {
	-webkit-appearance: textfield; /* 1 */
	outline-offset: -2px; /* 2 */
}

/**
   * Remove the inner padding in Chrome and Safari on macOS.
   */

[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

/**
   * 1. Correct the inability to style clickable types in iOS and Safari.
   * 2. Change font properties to `inherit` in Safari.
   */

::-webkit-file-upload-button {
	-webkit-appearance: button; /* 1 */
	font: inherit; /* 2 */
}

/* Interactive
	 ========================================================================== */

/*
   * Add the correct display in Edge, IE 10+, and Firefox.
   */

details {
	display: block;
}

/*
   * Add the correct display in all browsers.
   */

summary {
	display: list-item;
}

/* Misc
	 ========================================================================== */

/**
   * Add the correct display in IE 10+.
   */

template {
	display: none;
}

/**
   * Add the correct display in IE 10.
   */

[hidden] {
	display: none;
}

/* CUSTOM CODE */

a {
	text-decoration: none;
}

body.lock-body {
	height: 100vh;
	width: 100vw;
	position: fixed;
	overflow: hidden;
}

.align-center {
	align-items: center;
}

button {
	padding-bottom: 0.05rem;
	outline: none;
	border: none;
	border-bottom: 0.05rem solid transparent;
	background-color: transparent;
	transition: border-bottom 0.5s;
}
button:hover {
	border-bottom: 0.05rem solid #000;
	cursor: pointer;
}
svg {
	width: 100%;
	height: auto;
	display: block;
}
/* ========================== */
/* BODY CONTAINER */
/* ========================== */
main {
	background-color: inherit;
	min-height: calc(100vh - 87.1953px - 0.25rem);
	min-height: calc(100svh - 87.1953px - 0.25rem);
	opacity: 0;
}
.initiated main {
	opacity: 1;
	transition: opacity 1.2s ease-in;
}

/* ========================== */
/* FILTER CONTAINER */
/* ========================== */
.filter-container {
	margin-bottom: 3rem;
	position: relative;
}
.description-view .filter-container .filter-container-inner-container {
	opacity: 0;
}

.filter-container .filter {
	display: inline;
	padding-left: 0;
	padding-right: 0;
	font-weight: 500;
}
.filter-container #filter-options {
	margin: 0.1rem 0 0;
	font-size: 0.7rem;
	transition: opacity 1s;
}
@media screen and (min-width: 45em) {
	.filter-container #filter-options {
		opacity: 0;
	}
}
.filter-container:hover #filter-options,
.filter-container.reveal-filter-list #filter-options {
	opacity: 1;
}
.filter-container #filter-options {
	width: 85%;
	max-width: 43rem;
}
.filter-container #filter-options li {
	display: inline-block;
	margin: 0.25rem;
	margin-left: 0;
	margin-right: 0.5rem;
}
.filter-container #filter-options li button {
	padding-left: 0;
	padding-right: 0;
}
/* ========================== */
/* PLACESS CONTAINER */
/* ========================== */
#places-container {
	padding: 0;
	width: 85%;
	max-width: 60rem;
	min-height: calc(100vh - 20rem);
	min-height: calc(100svh - 20rem);
	opacity: 0;
}
.description-view .places-loaded #places-container {
	opacity: 0;
	transition: none;
}
.places-loaded #places-container {
	opacity: 1;
	transition: opacity 0.5s ease-out;
}

#places-container #places-list[filter="filtered"] {
	column-count: 1;
}
@media screen and (min-width: 45em) {
	#places-container #places-list,
	#places-container #places-list[filter="filtered"][filter-style="two-columns"] {
		column-count: 2;
	}
}
@media screen and (min-width: 60em) {
	#places-container #places-list,
	#places-container #places-list[filter="filtered"][filter-style="three-columns"] {
		column-count: 3;
	}
}
#places-container #places-list li {
	margin-bottom: 0.25rem;
}

#places-container #places-list[filter="filtered"] li {
	opacity: 0;
	display: none;
}
#places-container #places-list[filter="filtered"] li.active {
	opacity: 1;
	display: block;
}
#places-container #places-list button {
	padding-left: 0;
}

#clear-filter {
	opacity: 0;
	padding-left: 0;
	padding-top: 2rem;
}
body:not(.description-view) .filtered #clear-filter {
	opacity: 1;
}
/* ========================== */
/* 	OVERLAY CONTAINER */
/* ========================== */
#place-overlay {
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	min-height: 100vh;
	min-height: 100svh;
	min-height: 100dvh;
	background-color: #fff;
	opacity: 0;
	transform: translateX(100vw);
	transition: transform 1s;
}
.reveal-overlay #place-overlay {
	opacity: 1;
	transform: translateX(0);
}
.remove-overlay #place-overlay {
	transform: translateY(100vh);
}
.reveal-overlay main {
	opacity: 0;
}
.remove-overlay main {
	opacity: 1;
	transition: opacity 0.75s 0.65s;
}

#place-overlay .overlay-inner-container {
	min-height: calc(100vh - var(--site-padding-top) - 3rem);
	min-height: calc(100svh - var(--site-padding-top) - 3rem);
	min-height: calc(100dvh - var(--site-padding-top) - 3rem);
	display: flex;
	flex-flow: column;
	align-items: flex-start;
	justify-content: space-between;
	padding-bottom: 1rem;
}

#place-overlay h2 {
	font-size: 2em;
	font-weight: 300;
	margin: 0;
	padding: 0;
	padding-bottom: 0.3rem;
	text-align: left;
}
@media screen and (min-width: 40em) {
	#place-overlay h2 {
		font-size: 3em;
	}
}
#place-overlay p {
	line-height: 1.15;
}
#place-overlay address {
	font-style: normal;
	font-weight: 300;
	font-size: 0.9em;
}
#place-overlay button {
	padding-left: 0;
}

/* ========================== */
/* 	PROJECT DESCRIPTION */
/* ========================== */
#description-button {
	font-size: 0.9rem;
}
#project-description {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	min-height: 100vh;
	min-height: 100svh;
	padding: 0;
	z-index: 200;
	opacity: 0;
	pointer-events: none;
}
.description-view #project-description {
	opacity: 1;
	pointer-events: all;
}

#project-description p {
	margin-bottom: 1rem;
	line-height: 1.65;
	font-size: 0.9em;
	max-width: 36rem;
}
/* ========================== */
/* FOOTER CONTAINER */
/* ========================== */
#colophon {
	padding-top: 2rem;
	padding-left: var(--site-padding-left);
	opacity: 0;
}

.initiated #colophon {
	opacity: 1;
	transition: opacity 1.2s ease-in;
}
