@font-face {
    font-display: block;
    font-family: "bootstrap-icons";
    src: url("/vendor/bootstrap-icons/font/bootstrap-icons.woff2")
            format("woff2"),
        url("/vendor/bootstrap-icons/font/bootstrap-icons.woff") format("woff");
}

@font-face { font-family: 'Andada Pro'; font-style: normal; font-weight: 400; font-display: swap; src: url('/fonts/andada-pro/andada-pro-v23-latin_latin-ext-regular.woff2') format('woff2'); }
@font-face { font-family: 'Andada Pro'; font-style: italic; font-weight: 400; font-display: swap; src: url('/fonts/andada-pro/andada-pro-v23-latin_latin-ext-italic.woff2') format('woff2'); }
@font-face { font-family: 'Andada Pro'; font-style: normal; font-weight: 500; font-display: swap; src: url('/fonts/andada-pro/andada-pro-v23-latin_latin-ext-500.woff2') format('woff2'); }
@font-face { font-family: 'Andada Pro'; font-style: italic; font-weight: 500; font-display: swap; src: url('/fonts/andada-pro/andada-pro-v23-latin_latin-ext-500italic.woff2') format('woff2'); }
@font-face { font-family: 'Andada Pro'; font-style: normal; font-weight: 600; font-display: swap; src: url('/fonts/andada-pro/andada-pro-v23-latin_latin-ext-600.woff2') format('woff2'); }
@font-face { font-family: 'Andada Pro'; font-style: italic; font-weight: 600; font-display: swap; src: url('/fonts/andada-pro/andada-pro-v23-latin_latin-ext-600italic.woff2') format('woff2'); }
@font-face { font-family: 'Andada Pro'; font-style: normal; font-weight: 700; font-display: swap; src: url('/fonts/andada-pro/andada-pro-v23-latin_latin-ext-700.woff2') format('woff2'); }
@font-face { font-family: 'Andada Pro'; font-style: italic; font-weight: 700; font-display: swap; src: url('/fonts/andada-pro/andada-pro-v23-latin_latin-ext-700italic.woff2') format('woff2'); }
@font-face { font-family: 'Andada Pro'; font-style: normal; font-weight: 800; font-display: swap; src: url('/fonts/andada-pro/andada-pro-v23-latin_latin-ext-800.woff2') format('woff2'); }
@font-face { font-family: 'Andada Pro'; font-style: italic; font-weight: 800; font-display: swap; src: url('/fonts/andada-pro/andada-pro-v23-latin_latin-ext-800italic.woff2') format('woff2'); }

@font-face { font-family: 'DM Sans'; font-style: normal; font-weight: 100; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-100.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: italic; font-weight: 100; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-100italic.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: normal; font-weight: 200; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-200.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: italic; font-weight: 200; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-200italic.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: normal; font-weight: 300; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-300.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: italic; font-weight: 300; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-300italic.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: normal; font-weight: 400; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-regular.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: italic; font-weight: 400; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-italic.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: normal; font-weight: 500; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-500.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: italic; font-weight: 500; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-500italic.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: normal; font-weight: 600; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-600.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: italic; font-weight: 600; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-600italic.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: normal; font-weight: 700; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-700.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: italic; font-weight: 700; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-700italic.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: normal; font-weight: 800; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-800.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: italic; font-weight: 800; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-800italic.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: normal; font-weight: 900; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-900.woff2') format('woff2'); }
@font-face { font-family: 'DM Sans'; font-style: italic; font-weight: 900; font-display: swap; src: url('/fonts/dm-sans/dm-sans-v16-latin_latin-ext-900italic.woff2') format('woff2'); }

@font-face { font-family: 'Playwrite DE Grund'; font-style: normal; font-weight: 100; font-display: swap; src: url('/fonts/playwrite/playwrite-de-grund-v10-latin-100.woff2') format('woff2'); }
@font-face { font-family: 'Playwrite DE Grund'; font-style: normal; font-weight: 200; font-display: swap; src: url('/fonts/playwrite/playwrite-de-grund-v10-latin-200.woff2') format('woff2'); }
@font-face { font-family: 'Playwrite DE Grund'; font-style: normal; font-weight: 300; font-display: swap; src: url('/fonts/playwrite/playwrite-de-grund-v10-latin-300.woff2') format('woff2'); }
@font-face { font-family: 'Playwrite DE Grund'; font-style: normal; font-weight: 400; font-display: swap; src: url('/fonts/playwrite/playwrite-de-grund-v10-latin-regular.woff2') format('woff2'); }

:root {
    --darkest: #0d1b2aff;
    --darker: #1b263bff;
    --dark: #415a77ff;
    --text: rgb(87, 90, 95);
    --light: #778da9ff;
    --lighter: #e0e1ddff;
    --primary: #619700ff;
    --primary-light: #71ac08ff;
    --primary-dark: #578702ff;
    --border: #dfe2e5ff;
    --body-font-size: 15px;
    --shadow: #61970033;
    --default-serif-font: "Andada Pro", serif;
    --default-sans-serif-font: "DM Sans", sans-serif;
    --brand-font: "Playwrite DE Grund", sans-serif;
    --bs-primary: var(--primary);
    --bs-btn-hover-bg: var(--primary-light);
    --bs-link-color: var(--primary);
    --bs-btn-hover-color: var(--primary);
    --bs-dropdown-link-active-bg: #71ac08ff;
    --bs-btn-hover-bg: transparent;
    --bs-link-hover-color: var(--primary-dark);
    --bs-btn-active-color: var(--primary-dark);
}
html {
    scrollbar-gutter: stable;
}
body {
    font-family: "DM Sans", sans-serif;
    color: var(--text);
    font-size: var(--body-font-size);
    background-color: #fdfdfd;
    padding: 0;
    margin: 0;
    overflow-y: auto;
}
.container {
    padding: 12pt 0;
    max-width: 1080px;
}

.text-primary {
    color: var(--primary) !important;
}

/****************** HEADINGS *******************/
h1,
h2,
h3,
h4,
h5 {
    font-family: var(--default-serif-font);
    font-weight: bold;
    color: var(--primary);
}
h1 {
    font-size: 1.5rem;
}
h2 {
    font-size: 1.25rem;
}
h3 {
    font-size: 1.125rem;
}
h4 {
    font-size: 1rem;
}
h5 {
    font-size: 0.875rem;
}

/****************** CARDS *******************/

.card {
    margin: 0;
    padding: 12pt 0;
    background-color: white;
    border: 1px solid var(--border);
    box-shadow: 0px 1px 4px -1px var(--shadow);
    border-radius: 12pt;
    display: flex;
    flex-direction: column;
    gap: 12pt;
}
.card-header,
.card-footer {
    padding: 0 12pt;
    background-color: transparent;
    border: none;
    line-height: 1;
}
.card-header {
    font-weight: bold;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
}
.card-header h3 {
    margin: 0;
    font-weight: 300;
    font-size: 1.5rem;
    font-family: "DM Sans", sans-serif;
    text-transform: none;
    color: #535b57;
}
.card-body {
    padding: 0 12pt;
    color: var(--text);
}

svg.feather {
    width: 1rem;
    height: 1rem;
    margin-top: -4px;
}

/****************** FORMS *******************/

textarea.form-control,
input[type="text"].form-control,
input[type="email"].form-control,
input[type="password"].form-control,
select.form-select {
    font-size: var(--body-font-size);
    color: var(--text);
    border: 1px solid oklch(0.922 0 0);
    outline: 2px solid transparent;
    box-shadow: 0 1px 1px rgba(0, 0, 0, 0.1);
    transition: outline 0.3s ease-in-out;
}
.form-control:focus,
.form-select:focus,
input[type="text"]:focus,
textarea:focus,
select:focus {
    outline: 2px solid var(--primary);
    border-color: transparent;
    box-shadow: none;
}
textarea.form-control::placeholder,
input[type="text"]::placeholder,
input[type="email"]::placeholder,
input[type="password"]::placeholder {
    color: var(--light);
}
p {
    color: var(--text);
    font-size: var(--body-font-size);
    font-weight: 400;
    margin-bottom: 0;
}
a {
    color: var(--primary);
    text-decoration: none;
}
.btn {
    font-size: var(--body-font-size);
}
.btn.btn-primary {
    background-color: var(--primary);
    border-color: var(--primary);
}
.btn.btn-primary:hover {
    background-color: var(--primary-light);
    border-color: var(--primary-light);
}
.btn.btn-primary:active {
    background-color: var(--primary-dark);
    border-color: var(--primary-dark);
    color: white;
}
.btn.btn-light {
    border: 1px solid var(--border);
    color: var(--darker);
}

/****************** RESULTS *******************/

.result.card {
    border: none;
    border-radius: 0;
    box-shadow: none;
}

.result.card h3 {
    text-transform: uppercase;
    font-size: 1.2rem;
    font-weight: 600;
    max-width: calc(100% - 4rem);
}

.result.card .rating {
    text-align: right;
    margin-top: 4pt;
}

/****************** SPLIT PANES *******************/

.default-theme.splitpanes--vertical > .splitpanes__splitter {
    width: 12px !important;
    border: none !important;
}

.splitpanes.default-theme .splitpanes__pane {
    background-color: white !important;
}

.btn:hover {
    color: none;
}
.dropdown-item:active {
    background-color: var(--primary-light);
}
