:root {
	--he-hsl-background: 0 0% 100%;
	--he-hsl-foreground: 0 0% 3.9%;
	--he-hsl-card: 0 0% 100%;
	--he-hsl-card-foreground: 0 0% 3.9%;
	--he-hsl-popover: 0 0% 100%;
	--he-hsl-popover-foreground: 0 0% 3.9%;
	--he-hsl-primary: 0 0% 9%;
	--he-hsl-primary-foreground: 0 0% 98%;
	--he-hsl-secondary: 0 0% 96.1%;
	--he-hsl-secondary-foreground: 0 0% 9%;
	--he-hsl-muted: 0 0% 96.1%;
	--he-hsl-muted-foreground: 0 0% 45.1%;
	--he-hsl-accent: 0 0% 96.1%;
	--he-hsl-accent-foreground: 0 0% 9%;
	--he-hsl-border: 0 0% 89.8%;
	--he-hsl-input: 0 0% 89.8%;
	--he-hsl-ring: 0 0% 3.9%;

	--he-color-background: #ffffff;
	--he-color-foreground: #0a0a0a;
	--he-color-primary: #171717;
	--he-color-primary-foreground: #ffffff;
	--he-color-heading: #111827;
	--he-color-text-dark: #374151;
	--he-color-text-secondary: #4b5563;
	--he-color-text-muted: #6b7280;
	--he-color-placeholder: #9ca3af;
	--he-color-border: #e5e5e5;
	--he-color-border-light: #e5e7eb;
	--he-color-surface-gray: #f9fafb;
	--he-color-surface-soft: #f3f4f6;
	--he-color-surface-amber: #fffbeb;
	--he-color-surface-amber-soft: #fef3c7;
	--he-color-amber: #b45309;
	--he-color-amber-mid: #d97706;
	--he-color-amber-dark: #92400e;
	--he-color-gold: #fbbf24;
	--he-color-header-backdrop: rgba(255, 255, 255, 0.95);
	--he-color-footer-chip: #1f2937;
	--he-color-scrollbar-track: #f1f1f1;
	--he-color-scrollbar-thumb: #c4b5a0;
	--he-color-scrollbar-thumb-hover: #6b4e37;

	--he-font-heading: "Cormorant Garamond", serif;
	--he-font-body: Montserrat, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;

	--he-space-2: 2px;
	--he-space-4: 4px;
	--he-space-6: 6px;
	--he-space-8: 8px;
	--he-space-10: 10px;
	--he-space-12: 12px;
	--he-space-16: 16px;
	--he-space-20: 20px;
	--he-space-24: 24px;
	--he-space-28: 28px;
	--he-space-32: 32px;
	--he-space-40: 40px;
	--he-space-48: 48px;
	--he-space-64: 64px;
	--he-space-80: 80px;
	--he-space-96: 96px;

	--he-radius-base: 0.5rem;

	--he-type-logo-wordmark-size: 24px;
	--he-type-logo-wordmark-line-height: 32px;
	--he-type-logo-tagline-size: 12px;
	--he-type-logo-tagline-line-height: 16px;
	--he-type-logo-tagline-letter-spacing: 1.2px;
	--he-type-nav-size: 14px;
	--he-type-nav-line-height: 20px;
	--he-type-nav-letter-spacing: 0.7px;
	--he-type-display-size: 72px;
	--he-type-display-line-height: 72px;
	--he-type-display-mobile-size: 48px;
	--he-type-display-mobile-line-height: 60px;
	--he-type-page-title-size: 60px;
	--he-type-page-title-line-height: 60px;
	--he-type-section-title-size: 48px;
	--he-type-section-title-line-height: 48px;
	--he-type-section-title-mobile-size: 36px;
	--he-type-section-title-mobile-line-height: 40px;
	--he-type-card-title-size: 20px;
	--he-type-card-title-line-height: 28px;
	--he-type-footer-heading-size: 18px;
	--he-type-footer-heading-line-height: 28px;
	--he-type-footer-heading-letter-spacing: 0.9px;
	--he-type-body-large-size: 20px;
	--he-type-body-large-line-height: 28px;
	--he-type-body-size: 18px;
	--he-type-body-line-height: 28px;
	--he-type-body-small-size: 14px;
	--he-type-body-small-line-height: 20px;
	--he-type-testimonial-quote-size: 16px;
	--he-type-testimonial-quote-line-height: 26px;
	--he-type-testimonial-author-size: 16px;
	--he-type-testimonial-author-line-height: 24px;
	--he-type-button-size: 14px;
	--he-type-button-line-height: 20px;
	--he-type-label-size: 14px;
	--he-type-label-line-height: 14px;
	--he-type-caption-size: 12px;
	--he-type-caption-line-height: 16px;
	--he-type-caption-letter-spacing: 1.2px;
}

*,
*::before,
*::after {
	border: 0 solid var(--he-color-border-light);
	box-sizing: border-box;
}

html {
	-webkit-text-size-adjust: 100%;
	font-feature-settings: normal;
	font-variation-settings: normal;
	line-height: 1.5;
	scroll-behavior: smooth;
	tab-size: 4;
	-webkit-tap-highlight-color: transparent;
}

body {
	margin: 0;
	min-height: 100vh;
	background-color: var(--he-color-background);
	color: var(--he-color-foreground);
	font-family: var(--he-font-body);
	font-size: var(--he-type-body-size);
	font-weight: 400;
	line-height: var(--he-type-body-line-height);
}

main {
	display: block;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	margin: 0;
	color: var(--he-color-heading);
	font-family: var(--he-font-heading);
	font-weight: 400;
}

p,
ul,
ol,
dl,
blockquote,
figure {
	margin: 0;
}

p,
li {
	font-size: var(--he-type-body-size);
	font-weight: 400;
	line-height: var(--he-type-body-line-height);
}

a {
	color: inherit;
	text-decoration: none;
}

button,
input,
optgroup,
select,
textarea {
	margin: 0;
	color: inherit;
	font-family: inherit;
	font-size: 100%;
	font-weight: inherit;
	letter-spacing: inherit;
	line-height: inherit;
}

button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
	-webkit-appearance: button;
	background-color: transparent;
	background-image: none;
	border: 0;
	cursor: pointer;
	transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}

button:disabled,
input:disabled,
select:disabled,
textarea:disabled {
	cursor: default;
}

label {
	font-size: var(--he-type-label-size);
	font-weight: 500;
	line-height: var(--he-type-label-line-height);
}

input,
select,
textarea {
	font-size: var(--he-type-body-small-size);
	font-weight: 400;
	line-height: var(--he-type-body-small-line-height);
}

input::placeholder,
textarea::placeholder {
	color: var(--he-color-placeholder);
	opacity: 1;
}

textarea {
	resize: vertical;
}

menu,
ol,
ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

img,
picture,
svg,
video,
canvas,
audio,
iframe {
	display: block;
	vertical-align: middle;
}

img,
video {
	max-width: 100%;
	height: auto;
	object-fit: cover;
	transition: transform 0.5s ease;
}

table {
	border-collapse: collapse;
	border-color: inherit;
	text-indent: 0;
}

small {
	font-size: var(--he-type-caption-size);
	line-height: var(--he-type-caption-line-height);
}

.he-type-logo-wordmark {
	font-family: var(--he-font-heading);
	font-size: var(--he-type-logo-wordmark-size);
	font-weight: 400;
	line-height: var(--he-type-logo-wordmark-line-height);
}

.he-type-logo-tagline {
	font-family: var(--he-font-body);
	font-size: var(--he-type-logo-tagline-size);
	font-weight: 400;
	line-height: var(--he-type-logo-tagline-line-height);
	letter-spacing: var(--he-type-logo-tagline-letter-spacing);
	text-transform: uppercase;
}

.he-type-display {
	font-family: var(--he-font-heading);
	font-size: var(--he-type-display-size);
	font-weight: 400;
	line-height: var(--he-type-display-line-height);
}

.he-type-page-title {
	font-family: var(--he-font-heading);
	font-size: var(--he-type-page-title-size);
	font-weight: 400;
	line-height: var(--he-type-page-title-line-height);
}

.he-type-section-title {
	font-family: var(--he-font-heading);
	font-size: var(--he-type-section-title-size);
	font-weight: 400;
	line-height: var(--he-type-section-title-line-height);
}

.he-type-card-title {
	font-family: var(--he-font-heading);
	font-size: var(--he-type-card-title-size);
	font-weight: 500;
	line-height: var(--he-type-card-title-line-height);
}

.he-type-footer-heading {
	font-family: var(--he-font-heading);
	font-size: var(--he-type-footer-heading-size);
	font-weight: 500;
	line-height: var(--he-type-footer-heading-line-height);
	letter-spacing: var(--he-type-footer-heading-letter-spacing);
	text-transform: uppercase;
}

.he-type-body-large {
	font-size: var(--he-type-body-large-size);
	font-weight: 400;
	line-height: var(--he-type-body-large-line-height);
}

.he-type-body-small,
.he-type-nav,
.he-type-button {
	font-size: var(--he-type-body-small-size);
	line-height: var(--he-type-body-small-line-height);
}

.he-type-nav {
	font-weight: 500;
	letter-spacing: var(--he-type-nav-letter-spacing);
	text-transform: uppercase;
}

.he-type-button {
	font-weight: 500;
}

.he-type-caption {
	font-size: var(--he-type-caption-size);
	font-weight: 400;
	line-height: var(--he-type-caption-line-height);
	letter-spacing: var(--he-type-caption-letter-spacing);
	text-transform: uppercase;
}

.he-type-testimonial-quote {
	font-size: var(--he-type-testimonial-quote-size);
	font-weight: 400;
	line-height: var(--he-type-testimonial-quote-line-height);
}

.he-type-testimonial-author {
	font-size: var(--he-type-testimonial-author-size);
	font-weight: 500;
	line-height: var(--he-type-testimonial-author-line-height);
}

.he-type-testimonial-location {
	font-size: var(--he-type-body-small-size);
	font-weight: 400;
	line-height: var(--he-type-body-small-line-height);
}

::-webkit-scrollbar {
	width: 10px;
}

::-webkit-scrollbar-track {
	background: var(--he-color-scrollbar-track);
}

::-webkit-scrollbar-thumb {
	background: var(--he-color-scrollbar-thumb);
	border-radius: 5px;
}

::-webkit-scrollbar-thumb:hover {
	background: var(--he-color-scrollbar-thumb-hover);
}

@media (max-width: 767px) {
	.he-type-display {
		font-size: var(--he-type-display-mobile-size);
		line-height: var(--he-type-display-mobile-line-height);
	}

	.he-type-section-title {
		font-size: var(--he-type-section-title-mobile-size);
		line-height: var(--he-type-section-title-mobile-line-height);
	}
}
