html main {
	font-size: 16px;
}

h1, h2 {
	font-size: 2.8em;
	line-height: 1;
	/*font-family: 'Freight Display','FreightDispLight',serif;*/
	font-family: var(--font-sans);
	font-weight: 300;
	letter-spacing: -0.5px;
}
h2 {
	color: #7F7F7F;
	margin-bottom: 4rem;
	letter-spacing: -0.5px;
	font-family: var(--font-sans);
	font-size: 2em;
	-webkit-font-smoothing: antialiased;
}
h2 span {
	display: block;
}
main p {
	font-size: 19px;
	color: #777;
}
main p.small {
	font-size: 15px;
}

.btn {
	padding: 1rem 2.5rem;
	text-transform: uppercase;
	letter-spacing: var(--type--caps-tracking);
}
.btn--primary, .btn--primary:hover {
	background: #000;
	color: #fff;
}
.btn--secondary, .btn--secondary:hover {
	background: #959697;
	color: #fff;
}
.btn--white, .btn--white:hover {
	background: #fff;
	color: #000;
}

img {
	display: block;
	width: 100%;
	max-width: 100%;
	height: auto;
}

/* -------------------- */

.flex {
	display: flex;
}
.flex-wrap {
	flex-wrap: wrap;
}
.flex-nowrap {
	flex-wrap: nowrap;
}
.align-center {
	align-content: center;
}
.items-center {
	align-items: center;
}

.pr1 { padding-right: 1rem; }
.pr2 { padding-right: 2rem; }
.pr3 { padding-right: 4rem; }
.pr4 { padding-right: 8rem; }
.pl1 { padding-left: 1rem; }
.pl2 { padding-left: 2rem; }
.pl3 { padding-left: 4rem; }
.pl4 { padding-left: 8rem; }

.mt1 { margin-top: 1rem; }
.mt2 { margin-top: 2rem; }
.mt3 { margin-top: 4rem; }
.mt4 { margin-top: 8rem; }
.mb1 { margin-bottom: 1rem; }
.mb2 { margin-bottom: 2rem; }
.mb3 { margin-bottom: 4rem; }
.mb4 { margin-bottom: 8rem; }

.inset { padding: 1rem; }
.inset1 { padding: 1rem; }
.inset2 { padding: 2rem; }
.inset3 { padding: 4rem; }
.inset4 { padding: 8rem; }

.w-auto { width: auto }
.w-40 { width: 40% }
.w-60 { width: 60% }
.w-100 { width: 100% }

@media(min-width: 56.25em) {

	.flex-wrap-ns {
		flex-wrap: wrap;
	}
	.flex-nowrap-ns {
		flex-wrap: nowrap;
	}

	.pr1-ns { padding-right: 1rem; }
	.pr2-ns { padding-right: 2rem; }
	.pr3-ns { padding-right: 4rem; }
	.pr4-ns { padding-right: 8rem; }

	.pl1-ns { padding-left: 1rem; }
	.pl2-ns { padding-left: 2rem; }
	.pl3-ns { padding-left: 4rem; }
	.pl4-ns { padding-left: 8rem; }

	.mt1-ns { margin-top: 1rem; }
	.mt2-ns { margin-top: 2rem; }
	.mt3-ns { margin-top: 4rem; }
	.mt4-ns { margin-top: 8rem; }
	.mb1-ns { margin-bottom: 1rem; }
	.mb2-ns { margin-bottom: 2rem; }
	.mb3-ns { margin-bottom: 4rem; }
	.mb4-ns { margin-bottom: 8rem; }

	.inset-ns { padding: 1rem; }
	.inset1-ns { padding: 1rem; }
	.inset2-ns{ padding: 2rem; }
	.inset3-ns { padding: 4rem; }
	.inset4-ns { padding: 8rem; }

	.w-auto-ns { width: auto }
	.w-40-ns { width: 40% }
	.w-60-ns { width: 60% }
	.w-100-ns { width: 100% }
}

/* -------------------- */

.hero {
	/*min-height: 600px;*/
	/*min-height: 80vh;*/
	background: #858C9E;
	position: relative;
}

.hero__img {
	color: #fff;
}

.hero__text {
	color: #fff;
	width: 75%;
	max-width: 450px;
	position: absolute;
	left: 4rem;
	top: 3rem;
	bottom: 15%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

.hero h1 {
	color: rgba(0,0,0,.75);
}
.hero p {
	color: rgba(0,0,0,.75);
	max-width: 270px;
}

.hero h3 {
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: var(--type--caps-tracking);
	flex: 1 auto;
}
.hero h3 span {
	display: block;
	opacity: 0.6;
}
.hero .btn {
	margin-top: 3rem;
	width: auto;
	align-self: flex-start;
}

.experience p {
	margin-bottom: 1.5rem;
	max-width: 72ch;
}

.experience p a {
	color: black;
	text-decoration: underline;
	margin-bottom: 0.5rem;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	font-size: 12px;
	display: inline-block;
}

.map {
	max-width: 430px;
	display: none;
}

.map a {
	cursor: move;
  cursor: -webkit-grab;
  cursor: grab;
}

.garment-styles {
	display: block;
}

.garment-styles figure {
	width: 60%;
	padding: 0 1rem;
}
.flickity-slider {
	margin-left: 0;
}
.flickity-prev-next-button {
	background: rgba(255,255,255,.2);
	display: flex;
	align-items: center;
	justify-content: center;
}
.flickity-prev-next-button:hover {
	background: rgba(255,255,255,1);
}
.flickity-prev-next-button .flickity-button-icon {
	width: 16px;
	height: 16px;
	display: block;
	position: relative;
	left: unset;
	top: unset;
}

.flickity-page-dots {
	width: auto;
	bottom: 16px;
	right: 16px;
}

.flickity-page-dots .dot {
	border: 1px solid #fff;
	background: rgba(0,0,0,.2);
	opacity: 1;
}
.flickity-page-dots .dot.is-selected {
	background: rgba(255,255,255,1);
}

.garments p span {
	color: #aaa;
}

main .guarantee {
	background: #F0F1F2;
	background: #A7A7A7;
	padding-bottom: 12em;
}
main .guarantee h2 {
	color: #fff;
}
main .guarantee p {
	color: #fff;
	max-width: 74ch;
}

.guarantee a:not(.btn) {
	color: #333;
	text-transform: uppercase;
	letter-spacing: var(--type--caps-tracking);
	padding: 3px 0;
	font-size: 13px;
	margin-left: 1rem;
	border-bottom: 1px solid #999;
}
.guarantee a:not(.btn):hover {
	text-decoration: none;
	color: #000;
}

.final-cta {
	text-align: center;
	justify-content: center;
}
.final-cta a {
	white-space: nowrap;
}
.final-cta .btn {
	margin-bottom: 1.5rem;
}
.final-cta span {
	display: block;
	width: 100%;
}

.shirt-stack div {
	position: relative;
	margin: 2rem auto 0;
	width: 100%;
	height: 100%;
}

.shirt-stack img {
	opacity: 0;
	top: 0;
	left: 0;
	width: 90%;
	max-width: 500px;
	height: auto;
	position: absolute;
	transition: .4s ease;
}
.shirt-stack img.is-active {
	opacity: 1;
}

@media(max-width: 36em) {
	.locations {
		display: flex;
		justify-content: space-between;
	}
	.locations p:first-child {
		margin-right: 2rem;
	}
}

@media(min-width: 36em) {
	h1 {
		font-size: 3.2em;
	}
	.hero__text {
		bottom: 30%;
		max-width: 480px;
	}
	.shirt-stack div {
		position: relative;
		margin: -2rem auto 0;
		width: 100%;
		height: 1px;
		padding-top: 125%;
	}
}

@media(min-width: 56.25em) {

	h1 {
		font-size: 3.2em;
	}
	.hero h1 {
		color: rgba(255,255,255,1);
	}
	h2 {
		font-size: 3.2em;
	}
	.hero p {
		color: rgba(255,255,255,.85);
		margin: 1rem 0 1rem 0;
		line-height: 1.4;
		font-size: 1.5em;
		max-width: 400px;
	}
	.hero h3 {
		font-size: 16px;
	}

	.hero__text {
		width: 75%;
		max-width: 550px;
		left: 8rem;
		top: 8rem;
		bottom: 30%;
	}

	.map {
		display: block;
	}

	.garment-styles figure {
		width: 29.5%;
		padding: 0 2rem;
	}
	.garment-styles .flickity-slider {
		margin-left: 4%;
	}
	.final-cta {
		justify-content: flex-start;
		text-align: left;
	}
	.final-cta span {
		display: inline-flex;
		width: auto;
	}

}