:root {
	/* COLORS */
	--primary: #838EA0;
	--gray: #E5E5E5;
	--gray-dark: #979797;
	--gray-darker: #545454;
	--gray-light: #CED5E0;
	--black: #000000;
	--white: #ffffff;
	
	/* TRANSITIONS */
	--transition: all 0.5s ease-in-out;
	
	/* SPACERS */
	--size-xs: 10px;
	--size-s: 20px;
	--size-m: 40px;
	--size-l: 50px;
	--size-xl: 80px;
}

* {
	-webkit-font-smoothing: antialiased;
	position: relative;
	box-sizing: border-box;
}

html.overflow {
	overflow: hidden;
}

body {
	font-family: 'Sora', sans-serif;
	font-size: 17px;
	font-weight: 300;
	margin: 0;
	padding-top: 100px;
	overflow-x: hidden;
}

/* IMAGES */
picture {
	display: block;
}
img {
	display: block;
	width: 100%;
    height: 100%;
    object-fit: cover;
    user-drag: none;
    -webkit-user-drag: none;
}
img.fit {
	object-fit: contain;
}
img.default {
	width: auto;
	height: auto;
}
img[data-src] {
	opacity: 0;
	transition: var(--transition);
}
img[data-src][src] {
	opacity: 1;
}

/* DISPLAY & ALIGNMENT */
.flex {
	display: flex;
}
.grid {
	display: grid;
}
.none {
	display: none;
}

.fd-c {
	flex-direction: column;
}
.fd-r {
	flex-direction: row;
}
.fw-w {
	flex-wrap: wrap;
}

.jc-fs {
	justify-content: flex-start;
}
.jc-fe {
	justify-content: flex-end;
}
.jc-c {
	justify-content: center;
}
.jc-sb {
	justify-content: space-between;
}
.jc-sa {
	justify-content: space-around;
}

.ai-fs {
	align-items: flex-start !important;
}
.ai-fe {
	align-items: flex-end;
}
.ai-c {
	align-items: center;
}

.as-fs {
	align-self: flex-start;
}
.as-fe {
	align-self: flex-end;
}
.as-c {
	align-self: center;
}

/* COLORS AND BACKGROUNDS */
.primary {
	color: var(--primary);	
}
.white {
	color: var(--white);
}
.black {
	color: var(--black) !important;
}
.gray-dark {
	color: var(--gray-dark);	
}
.gray-light {
	color: var(--gray-light);	
}

.bg--primary {
	background-color: var(--primary);
}
.bg--white {
	background-color: var(--white);
}
.bg--black {
	background-color: var(--black);
}
.bg--beige {
	background-color: var(--beige);
}
.bg--beige-500 {
	background-color: var(--beige-500);
}
.bg--beige-600 {
	background-color: var(--beige-600);
}
.bg--beige-700 {
	background-color: var(--beige-700);
}
.bg--beige-900 {
	background-color: var(--beige-900);
}
.bg--gray {
	background-color: var(--gray);
}

/* WIDTHS */
.w-100 {
	width: 100%;
}
.w-90 {
	width: 90%;
}
.w-83 {
	width: 83.33333%;
}
.w-80 {
	width: 80%;
}
.w-75 {
	width: 75%;
}
.w-70 {
	width: 70%;
}
.w-66 {
	width: 66.66666%;
}
.w-60 {
	width: 60%;
}
.w-50 {
	width: 50%;
}
.w-40 {
	width: 40%;
}
.w-33 {
	width: 33.33333%;
}
.w-30 {
	width: 30%;
}
.w-25 {
	width: 25%;
}
.w-20 {
	width: 20%;
}
.w-16 {
	width: 16.66666%;
}
.w-10 {
	width: 10%;
}
.w-auto {
	width: auto;
}
.w-min {
	width: min-content;
}

/* HEIGHTS */
.h-100 {
	height: 100%;
}

/* PADDINGS & MARGINS */
.p-0 {
	padding: 0 !important;
}
.pl-0 {
	padding-left: 0 !important;
}
.pr-0 {
	padding-right: 0 !important;
}
.pt-0 {
	padding-top: 0 !important;
}
.pb-0 {
	padding-bottom: 0 !important;
}
[padding="s"] {
	padding: var(--size-s);
}
[padding="m"] {
	padding: var(--size-m);
}
[padding="l"] {
	padding: var(--size-l);
}

.m-0 {
	margin: 0 !important;
}
.ml-a {
	margin-left: auto !important;
}
.mr-a {
	margin-right: auto !important;
}
.mt-a {
	margin-top: auto !important;
}
.mb-a {
	margin-bottom: auto !important;
}

/* CONTAINER */
.container {
	width: 100%;
	max-width: 1600px;
	margin: 0 auto;
	padding: 0 80px;
}

/* ANCHORS */
a {
	color: var(--black);
	text-decoration: none;
}
a:hover {
	color: var(--primary);
}

/* TYPOGRAPHY */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
	margin: 0;
	line-height: 100%;
}
h1, h2, h3, h4, h5,
.h1, .h2, .h3, .h4, .h5 {
	font-family: 'ClashDisplay-Medium';
	font-weight: 300;
}
h1, .h1 {
	font-family: 'ClashDisplay-Regular';
	font-size: 120px;
}
h2, .h2 {
	font-size: 54px;
	line-height: 130%;
}
h3, .h3 {
	font-size: 48px;
	line-height: 120%;
}
h4, .h4 {
	font-size: 26px;
	line-height: 130%;
}
h5, .h5 {
	font-family: 'ClashDisplay-Regular';
	font-size: 20px;
	line-height: 140%;
	text-transform: uppercase;
}
h6, .h6 {
	font-family: 'Sora', sans-serif;
	font-weight: 500;
	font-size: 18px;
}

p {
	margin: 0;
	margin-bottom: 20px;
	font-weight: 300;
	line-height: 180%;
	color: #838EA0;
}
p:last-of-type {
	margin-bottom: 0;
}

p + ul,
p + ol {
	margin-top: 20px;
}

p a {
	font-weight: 500;
}

strong, .strong, b, .b {
	font-family: 'ClashDisplay-Semibold';
}

small, .small {
	font-size: 13px;
	line-height: 130%;
}

.ws-nw {
	white-space: nowrap;
}

.ta-c {
	text-align: center;
}
.ta-r {
	text-align: right;
}

/* SPACERS */
hr {
	border: 0;
	margin: 0;
}
hr.xl {
	height: var(--size-xl);
}
hr.l {
	height: var(--size-l);
}
hr.m {
	height: var(--size-m);
}
hr.s {
	height: var(--size-s);
}
hr.xs {
	height: var(--size-xs);
}

hr.vertical {
	height: 0;
}
hr.vertical.xl {
	min-width: var(--size-xl);
}
hr.vertical.l {
	min-width: var(--size-l);
}
hr.vertical.m {
	min-width: var(--size-m);
}
hr.vertical.s {
	min-width: var(--size-s);
}
hr.vertical.xs {
	min-width: var(--size-xs);
}

/* LISTS */
ul, ol {
	margin: 0;
}

/* COLUMNS */
.grid {
	display: grid;
}
.grid[column-count="4"] {
    grid-template-columns: repeat(4, 1fr);
}
.grid[column-count="3"] {
    grid-template-columns: repeat(3, 1fr);
}
.grid[column-count="2"] {
    grid-template-columns: repeat(2, 1fr);
}

.grid[column-gap="l"] {
    column-gap: var(--size-l);
    row-gap: var(--size-l);
}
.grid[column-gap="m"] {
    column-gap: var(--size-m);
    row-gap: var(--size-m);
}
.grid[column-gap="s"] {
    column-gap: var(--size-s);
    row-gap: var(--size-s);
}

.grid[row-gap="xl"] {
    row-gap: var(--size-xl) !important;
}
.grid[row-gap="l"] {
    row-gap: var(--size-l) !important;
}
.grid[row-gap="m"] {
    row-gap: var(--size-m) !important;
}
.grid[row-gap="s"] {
    row-gap: var(--size-s) !important;
}

/* OPACITY */
[opacity="0.8"] {
	opacity: 0.8;
}
[opacity="0.7"] {
	opacity: 0.7;
}

/* ZINDEX */
.zi-1 {
	z-index: 1;
}
.zi-2 {
	z-index: 2;
}

/* */
[overflow] {
	overflow: hidden;
}

[uppercase] {
	text-transform: uppercase;
}
[lowercase] {
	text-transform: lowercase;
}

