
html,
body {
	margin: 0;
	padding: 0;
}

body {
	padding: 2rem;
	font-family: sans-serif;
	line-height: 1.2;
	color: #333;
}

.nojs .nojs-hide {
	display: none;
}

.page {
	max-width: 600px;
	margin: 0 auto;
}

.filter {
	margin-bottom: 2rem;
}

.filter__input {
	font-size: 2rem;
	display: block;
	border: solid 2px #888;
	padding: .5rem;
	box-sizing: border-box;
	width: 100%;
}

.filter__input:focus {
	outline: none;
	border-color: #69f;
}

.phrases {
	list-style: none;
	margin: 0;
	padding: 0;
}

.phrases > li {
	margin-bottom: 1.5rem;
}

.phrase {
	margin: 0;
}

.phrase__direction {
	color: #666;
}

.phrase__content {
	margin: 0 0 .5rem 0;
	font-size: 2rem;
}

.phrase__quote::before {
	content: "“";
	color: #666;
}

.phrase__quote::after {
	content: "”";
	color: #666;
}

.phrase__meta {
	color: #888;
	font-size: 1.2rem;
}

.phrase__citation {
	color: #333;
}

.phrase__citation-description,
.phrase__tags {
	font-size: 1rem;
}

.hidden {
	display: none;
}
