:root {
    --primary-font: 'Roobert';
    --secondary-font: 'RoobertSemiMono';
}

html { height: 100%; }

body {
	width: 100%;
	height: 100%;
	background: var(--neutral-25);
	color: var(--neutral-900);
	font-size: 16px;
	font-family: var(--primary-font), sans-serif;
	font-weight: 400;
}

* { margin: 0; padding: 0; outline: 0; }

a { color: var(--brand-100); text-decoration: none; }
a img { border: 0; }

strong { font-weight: 600; }
input, textarea, button { font-family: var(--primary-font), sans-serif; font-size: 16px; }
button { cursor: pointer; }

.button { transition: background 0.2s ease-in-out, border-color 0.2s ease-in-out, color 0.2s ease-in-out; align-self: flex-start; flex-shrink: 0; display: flex; flex-wrap: nowrap; justify-content: center; align-items: center; box-sizing: border-box; min-height: 48px; padding: 14px 19px; background: var(--brand-100); border: 1px solid var(--brand-100); color: var(--neutral-25); font-weight: 600; line-height: 18px; text-align: center; }
.button:hover { background: var(--neutral-900); border-color: var(--neutral-900); }

.button.icon { width: 48px; padding: 0; }
.button.large { min-height: 60px; padding: 20px 22px; }
.button.small { min-height: 36px; font-size: 15px; }
.button.small.icon { width: 36px; padding: 0; }

.button.white { background: var(--neutral-25); border-color: var(--neutral-25); color: var(--neutral-900); }
.button.white:hover { background: var(--neutral-50); border-color: var(--neutral-50); }

.button.grey { background: var(--neutral-75); border-color: var(--neutral-75); color: var(--neutral-500); }
.button.grey:hover { background: var(--neutral-100); border-color: var(--neutral-100); color: var(--neutral-900); }

.button.black { background: var(--neutral-900); border-color: var(--neutral-900); }
.button.black:hover { background: var(--neutral-700); border-color: var(--neutral-700); }

.button.outline { background: transparent; border-color: var(--neutral-100); color: var(--neutral-500); }
.button.outline:hover { border-color: var(--neutral-200); color: var(--neutral-900); }

.button.outline-red { background: transparent; border-color: var(--red-500); color: var(--red-500); }
.button.outline-red:hover { border-color: var(--red-600); color: var(--red-600); }

.button .icon { flex-shrink: 0; display: flex; margin-left: 10px; }
.button .icon.before { margin-left: 0; margin-right: 10px; }

.button.link { min-height: 0; padding: 0; background: transparent; border: 0; color: var(--neutral-500); }
.button.link:hover { background: transparent; color: var(--neutral-900); }
.button.link.small { font-weight: 400; }
.button.link.grey { color: var(--neutral-400); }
.button.link.grey:hover { color: var(--neutral-900); }
.button.link.grey-dark { color: var(--neutral-500); }
.button.link.grey-dark:hover { color: var(--neutral-300); }

.input { box-sizing: border-box; width: 100%; height: 48px; padding: 0 16px; background: var(--neutral-25); border: 1px solid var(--neutral-100); color: var(--neutral-900); }
.input:hover { border-bottom-color: var(--neutral-300); }
.input:focus { border-bottom-color: var(--brand-100); }
.input.small { height: 38px; font-size: 14px; }
.input.small-text { font-size: 14px; }
.input[type="tel"] { font-family: var(--secondary-font); }
.input[type="tel"]::placeholder { font-family: var(--primary-font); }
.input[type="number"] { font-family: var(--secondary-font); appearance: textfield; }
.input[type="number"]::placeholder { font-family: var(--primary-font); }

.input.dark { background: var(--neutral-900); border-color: var(--neutral-700); color: var(--neutral-25); }
.input.dark:hover { border-bottom-color: var(--neutral-500); }
.input.dark:focus { border-bottom-color: var(--brand-100); }

.textarea { box-sizing: border-box; width: 100%; height: 130px; padding: 12px 16px; background: var(--neutral-25); border: 1px solid var(--neutral-100); color: var(--neutral-900); line-height: 26px; resize: none; }
.textarea:hover { border-bottom-color: var(--neutral-300); }
.textarea:focus { border-bottom-color: var(--brand-100); }

.textarea.yellow { background: var(--amber-50); border-color: var(--amber-100); }

.select { width: 100%; height: 48px; }

:placeholder { color: var(--neutral-400); opacity: 1; }

.input-icon-container { display: flex; position: relative; width: 100%; }
.input-icon-container .icon { transition: color 0.2s ease-in-out; display: flex; justify-content: center; align-items: center; position: absolute; z-index: 10; top: 0; right: 0; width: 46px; height: 100%; background: transparent; border: 0; color: var(--neutral-400); cursor: text; }
.input-icon-container button.icon { cursor: pointer; }
.input-icon-container button.icon:hover { color: var(--neutral-900); }
.input-icon-container button.icon.grey-dark:hover { color: var(--neutral-300); }
.input-icon-container .icon.before { right: auto; left: 0; }
.input-icon-container .icon.grey { color: var(--neutral-200); }
.input-icon-container .icon.grey-dark { color: var(--neutral-500); }
.input-icon-container .icon.green { color: var(--lime-500); }
.input-icon-container .input { padding-right: 46px; }
.input-icon-container:has(.icon.before) .input { padding-left: 46px; }

.mono { font-family: var(--secondary-font); }
.numerical { font-variant-numeric: slashed-zero; }