@charset "UTF-8";
/*
Theme Name: Africa Multiple — DRE
Theme URI: https://github.com/AM-Digital-Research-Environment/DRE-theme
Author: Frédérick Madore
Author URI: https://www.frederickmadore.com/
Description: Digital Research Environment theme for the Africa Multiple Cluster of Excellence (University of Bayreuth). Scholarly Modernism on an OKLCH design-token foundation, with light and dark modes. Based on the Lively theme by the Omeka Team.
Version: 2.0.3
Omeka Version Constraint: ^4.2.0
Requires PHP: 8.1
License: GNU General Public License v3 or later
License URI: LICENSE
Text Domain: dre-theme
*/
/*--------------------------------------------------------------
# Variables and mixins
--------------------------------------------------------------*/
:root {
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;
  --space-40: 10rem;
  --space-xs: 0.25rem;
  --space-sm: 0.5rem;
  --space-md: 1rem;
  --space-lg: 1.5rem;
  --space-xl: 2rem;
  --space-2xl: 3rem;
  --space-3xl: 4rem;
  --radius-sm: 0.375rem;
  --radius-md: 0.5rem;
  --radius-lg: 0.75rem;
  --radius-xl: 1rem;
  --radius-2xl: 1.5rem;
  --radius-full: 9999px;
  --accent-line-sm: 2px;
  --accent-line-md: 3px;
  --lift-xs: -0.125rem;
  --lift-sm: -0.25rem;
  --size-control-sm: 2.25rem;
  --size-control-md: 2.5rem;
  --size-control-lg: 2.75rem;
  --size-control-xl: 3rem;
  --measure-narrow: 44rem;
  --measure-base: 52.5rem;
  --measure-wide: 72.5rem;
  --tracking-tighter: -0.04em;
  --tracking-tight: -0.02em;
  --tracking-normal: 0;
  --tracking-wide: 0.04em;
  --tracking-widest: 0.12em;
  --ring-focus: 0 0 0 3px var(--focus-ring);
  --ring-focus-sm: 0 0 0 2px color-mix(in oklab, var(--primary) 22%, transparent);
  --glow-sm: 0 2px 6px -1px color-mix(in oklab, var(--primary) 24%, transparent);
  --glow-md: 0 4px 12px -2px color-mix(in oklab, var(--primary) 30%, transparent);
  --shadow-color: color-mix(in oklab, oklch(24% 0.03 60) 14%, transparent);
  --shadow-color-strong: color-mix(in oklab, oklch(24% 0.03 60) 20%, transparent);
  --shadow-color-subtle: color-mix(in oklab, oklch(28% 0.03 60) 7%, transparent);
  --shadow-xs: 0 1px 2px 0 var(--shadow-color-subtle);
  --shadow-sm: 0 1px 3px 0 var(--shadow-color), 0 1px 2px -1px var(--shadow-color-subtle);
  --shadow-md: 0 4px 6px -1px var(--shadow-color), 0 2px 4px -2px var(--shadow-color-subtle);
  --shadow-lg: 0 10px 15px -3px var(--shadow-color), 0 4px 6px -4px var(--shadow-color-subtle);
  --shadow-xl: 0 20px 25px -5px var(--shadow-color), 0 10px 10px -5px var(--shadow-color-subtle);
  --panel-bg: var(--surface);
  --panel-border-color: var(--border);
  --panel-border: 1px solid var(--border);
  --panel-radius: var(--radius-lg);
  --panel-shadow: var(--shadow-sm);
  --ease-out-quart: cubic-bezier(0.25, 1, 0.5, 1);
  --ease-expo-out: cubic-bezier(0.16, 1, 0.3, 1);
  --transition-fast: 150ms var(--ease-out-quart);
  --transition-base: 200ms var(--ease-out-quart);
  --transition-slow: 320ms var(--ease-out-quart);
  --z-banner: 10;
  --z-dropdown: 100;
  --z-sticky: 200;
  --z-header: 250;
  --z-drawer: 280;
  --z-modal: 300;
  --z-tooltip: 500;
  --line-height-normal: 1.6;
  --line-height-relaxed: 1.75;
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme=light]) {
    --shadow-color: color-mix(in oklab, black 22%, transparent);
    --shadow-color-strong: color-mix(in oklab, black 30%, transparent);
    --shadow-color-subtle: color-mix(in oklab, black 14%, transparent);
    --shadow-xs: 0 1px 3px 0 var(--shadow-color-subtle), 0 1px 2px -1px color-mix(in oklab, black 12%, transparent);
    --shadow-sm: 0 2px 6px -1px var(--shadow-color), 0 2px 4px -2px var(--shadow-color-subtle);
    --shadow-md: 0 6px 16px -4px var(--shadow-color-strong), 0 4px 8px -4px var(--shadow-color-strong);
    --shadow-lg: 0 12px 28px -8px color-mix(in oklab, black 40%, transparent), 0 8px 16px -8px color-mix(in oklab, black 24%, transparent);
    --shadow-xl: 0 20px 40px -12px color-mix(in oklab, black 50%, transparent), 0 12px 24px -8px var(--shadow-color-strong);
    --panel-bg: var(--surface-raised);
    --panel-border-color: var(--border);
    --panel-border: 1px solid var(--border);
  }
}
body[data-theme=dark] {
  --shadow-color: color-mix(in oklab, black 22%, transparent);
  --shadow-color-strong: color-mix(in oklab, black 30%, transparent);
  --shadow-color-subtle: color-mix(in oklab, black 14%, transparent);
  --shadow-xs: 0 1px 3px 0 var(--shadow-color-subtle), 0 1px 2px -1px color-mix(in oklab, black 12%, transparent);
  --shadow-sm: 0 2px 6px -1px var(--shadow-color), 0 2px 4px -2px var(--shadow-color-subtle);
  --shadow-md: 0 6px 16px -4px var(--shadow-color-strong), 0 4px 8px -4px var(--shadow-color-strong);
  --shadow-lg: 0 12px 28px -8px color-mix(in oklab, black 40%, transparent), 0 8px 16px -8px color-mix(in oklab, black 24%, transparent);
  --shadow-xl: 0 20px 40px -12px color-mix(in oklab, black 50%, transparent), 0 12px 24px -8px var(--shadow-color-strong);
  --panel-bg: var(--surface-raised);
  --panel-border-color: var(--border);
  --panel-border: 1px solid var(--border);
}

body[data-theme=light] {
  --shadow-color: color-mix(in oklab, oklch(24% 0.03 60) 14%, transparent);
  --shadow-color-strong: color-mix(in oklab, oklch(24% 0.03 60) 20%, transparent);
  --shadow-color-subtle: color-mix(in oklab, oklch(28% 0.03 60) 7%, transparent);
  --shadow-xs: 0 1px 2px 0 var(--shadow-color-subtle);
  --shadow-sm: 0 1px 3px 0 var(--shadow-color), 0 1px 2px -1px var(--shadow-color-subtle);
  --shadow-md: 0 4px 6px -1px var(--shadow-color), 0 2px 4px -2px var(--shadow-color-subtle);
  --shadow-lg: 0 10px 15px -3px var(--shadow-color), 0 4px 6px -4px var(--shadow-color-subtle);
  --shadow-xl: 0 20px 25px -5px var(--shadow-color), 0 10px 10px -5px var(--shadow-color-subtle);
  --panel-bg: var(--surface);
  --panel-border-color: var(--border);
  --panel-border: 1px solid var(--border);
}

:root {
  --primary-base: #009260;
  color-scheme: light;
  --primary: color-mix(in oklab, var(--primary-base), black 12%);
  --primary-hover: color-mix(in oklab, var(--primary-base), black 22%);
  --primary-active: color-mix(in oklab, var(--primary-base), black 32%);
  --primary-muted: color-mix(in oklab, var(--primary-base) 12%, var(--surface));
  --primary-text: color-mix(in oklab, var(--primary-base), black 24%);
  --primary-contrast: oklch(99% 0.004 95);
  --primary-dark: var(--primary-hover);
  --accent-base: #d57912;
  --accent: color-mix(in oklab, var(--accent-base), black 4%);
  --accent-hover: color-mix(in oklab, var(--accent-base), black 16%);
  --accent-muted: color-mix(in oklab, var(--accent-base) 14%, var(--surface));
  --accent-text: color-mix(in oklab, var(--accent-base), black 22%);
  --secondary: var(--primary);
  --complementary: oklch(74% 0.13 78);
  --ink-strong: oklch(24% 0.020 66);
  --ink: oklch(33% 0.017 62);
  --ink-light: oklch(46% 0.015 60);
  --ink-subtle: oklch(55% 0.012 58);
  --muted: oklch(60% 0.010 58);
  --ink-on-pastel: oklch(28% 0.030 66);
  --white: #fff;
  --black: #000;
  --surface: oklch(99.2% 0.004 95);
  --surface-raised: oklch(98.0% 0.006 92);
  --surface-sunken: oklch(95.6% 0.008 88);
  --surface-overlay: color-mix(in oklab, var(--surface) 92%, transparent);
  --background: oklch(97.4% 0.007 90);
  --border-light: oklch(93% 0.007 85);
  --border: oklch(88% 0.009 80);
  --border-strong: oklch(79% 0.011 72);
  --link: var(--primary-text);
  --link-hover: var(--primary-active);
  --focus-color: var(--primary);
  --focus-ring: color-mix(in oklab, var(--primary) 32%, transparent);
  --selection-bg: color-mix(in oklab, var(--primary) 16%, transparent);
  --success: oklch(56% 0.13 158);
  --success-bg: oklch(95% 0.04 158);
  --warning: oklch(64% 0.16 70);
  --warning-bg: oklch(96% 0.06 78);
  --error: oklch(55% 0.20 25);
  --error-bg: oklch(96% 0.04 25);
  --info: oklch(56% 0.13 235);
  --info-bg: oklch(96% 0.03 235);
  --blockquote-bg: color-mix(in oklab, var(--surface-raised) 88%, var(--primary) 12%);
  --blockquote-border: color-mix(in oklab, var(--primary) 60%, var(--border) 40%);
  --blockquote-quote: color-mix(in oklab, var(--primary) 80%, var(--ink) 20%);
  --footer-surface: oklch(22% 0.022 165);
  --footer-surface-alt: oklch(17% 0.020 165);
  --footer-divider: oklch(34% 0.018 165);
  --footer-text: oklch(94% 0.006 90);
  --footer-text-muted: oklch(74% 0.010 90);
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme=light]) {
    color-scheme: dark;
    --primary: color-mix(in oklab, var(--primary-base), white 18%);
    --primary-hover: color-mix(in oklab, var(--primary-base), white 30%);
    --primary-active: color-mix(in oklab, var(--primary-base), white 42%);
    --primary-muted: color-mix(in oklab, var(--primary-base) 24%, var(--surface));
    --primary-text: color-mix(in oklab, var(--primary-base), white 34%);
    --primary-contrast: oklch(16% 0.022 165);
    --primary-dark: var(--primary-hover);
    --accent-base: #d57912;
    --accent: color-mix(in oklab, var(--accent-base), white 12%);
    --accent-hover: color-mix(in oklab, var(--accent-base), white 24%);
    --accent-muted: color-mix(in oklab, var(--accent-base) 22%, var(--surface));
    --accent-text: color-mix(in oklab, var(--accent-base), white 28%);
    --secondary: var(--primary);
    --complementary: oklch(78% 0.13 80);
    --ink-strong: oklch(97% 0.006 95);
    --ink: oklch(91% 0.008 92);
    --ink-light: oklch(75% 0.010 88);
    --ink-subtle: oklch(66% 0.011 80);
    --muted: oklch(60% 0.011 78);
    --ink-on-pastel: oklch(92% 0.010 95);
    --surface: oklch(19% 0.013 165);
    --surface-raised: oklch(22% 0.014 165);
    --surface-sunken: oklch(15% 0.012 165);
    --surface-overlay: color-mix(in oklab, var(--surface) 92%, transparent);
    --background: oklch(16% 0.013 165);
    --border-light: oklch(26% 0.013 165);
    --border: oklch(32% 0.014 165);
    --border-strong: oklch(43% 0.015 165);
    --link: var(--primary-text);
    --link-hover: var(--primary-active);
    --focus-color: var(--primary);
    --focus-ring: color-mix(in oklab, var(--primary) 38%, transparent);
    --selection-bg: color-mix(in oklab, var(--primary) 26%, transparent);
    --success: oklch(72% 0.14 158);
    --success-bg: color-mix(in oklab, oklch(52% 0.13 158) 24%, transparent);
    --warning: oklch(78% 0.15 78);
    --warning-bg: color-mix(in oklab, oklch(58% 0.15 78) 24%, transparent);
    --error: oklch(70% 0.19 25);
    --error-bg: color-mix(in oklab, oklch(52% 0.18 25) 24%, transparent);
    --info: oklch(72% 0.13 235);
    --info-bg: color-mix(in oklab, oklch(52% 0.13 235) 24%, transparent);
    --blockquote-bg: color-mix(in oklab, var(--surface-raised) 76%, var(--primary) 24%);
    --blockquote-border: color-mix(in oklab, var(--primary) 64%, var(--ink) 36%);
    --blockquote-quote: color-mix(in oklab, var(--primary) 78%, white 22%);
    --footer-surface: oklch(24% 0.024 165);
    --footer-surface-alt: oklch(20% 0.022 165);
    --footer-divider: oklch(40% 0.020 165);
    --footer-text: var(--ink);
    --footer-text-muted: var(--ink-light);
  }
}
body[data-theme=dark] {
  color-scheme: dark;
  --primary: color-mix(in oklab, var(--primary-base), white 18%);
  --primary-hover: color-mix(in oklab, var(--primary-base), white 30%);
  --primary-active: color-mix(in oklab, var(--primary-base), white 42%);
  --primary-muted: color-mix(in oklab, var(--primary-base) 24%, var(--surface));
  --primary-text: color-mix(in oklab, var(--primary-base), white 34%);
  --primary-contrast: oklch(16% 0.022 165);
  --primary-dark: var(--primary-hover);
  --accent-base: #d57912;
  --accent: color-mix(in oklab, var(--accent-base), white 12%);
  --accent-hover: color-mix(in oklab, var(--accent-base), white 24%);
  --accent-muted: color-mix(in oklab, var(--accent-base) 22%, var(--surface));
  --accent-text: color-mix(in oklab, var(--accent-base), white 28%);
  --secondary: var(--primary);
  --complementary: oklch(78% 0.13 80);
  --ink-strong: oklch(97% 0.006 95);
  --ink: oklch(91% 0.008 92);
  --ink-light: oklch(75% 0.010 88);
  --ink-subtle: oklch(66% 0.011 80);
  --muted: oklch(60% 0.011 78);
  --ink-on-pastel: oklch(92% 0.010 95);
  --surface: oklch(19% 0.013 165);
  --surface-raised: oklch(22% 0.014 165);
  --surface-sunken: oklch(15% 0.012 165);
  --surface-overlay: color-mix(in oklab, var(--surface) 92%, transparent);
  --background: oklch(16% 0.013 165);
  --border-light: oklch(26% 0.013 165);
  --border: oklch(32% 0.014 165);
  --border-strong: oklch(43% 0.015 165);
  --link: var(--primary-text);
  --link-hover: var(--primary-active);
  --focus-color: var(--primary);
  --focus-ring: color-mix(in oklab, var(--primary) 38%, transparent);
  --selection-bg: color-mix(in oklab, var(--primary) 26%, transparent);
  --success: oklch(72% 0.14 158);
  --success-bg: color-mix(in oklab, oklch(52% 0.13 158) 24%, transparent);
  --warning: oklch(78% 0.15 78);
  --warning-bg: color-mix(in oklab, oklch(58% 0.15 78) 24%, transparent);
  --error: oklch(70% 0.19 25);
  --error-bg: color-mix(in oklab, oklch(52% 0.18 25) 24%, transparent);
  --info: oklch(72% 0.13 235);
  --info-bg: color-mix(in oklab, oklch(52% 0.13 235) 24%, transparent);
  --blockquote-bg: color-mix(in oklab, var(--surface-raised) 76%, var(--primary) 24%);
  --blockquote-border: color-mix(in oklab, var(--primary) 64%, var(--ink) 36%);
  --blockquote-quote: color-mix(in oklab, var(--primary) 78%, white 22%);
  --footer-surface: oklch(24% 0.024 165);
  --footer-surface-alt: oklch(20% 0.022 165);
  --footer-divider: oklch(40% 0.020 165);
  --footer-text: var(--ink);
  --footer-text-muted: var(--ink-light);
}

body[data-theme=light] {
  color-scheme: light;
  --primary: color-mix(in oklab, var(--primary-base), black 12%);
  --primary-hover: color-mix(in oklab, var(--primary-base), black 22%);
  --primary-active: color-mix(in oklab, var(--primary-base), black 32%);
  --primary-muted: color-mix(in oklab, var(--primary-base) 12%, var(--surface));
  --primary-text: color-mix(in oklab, var(--primary-base), black 24%);
  --primary-contrast: oklch(99% 0.004 95);
  --primary-dark: var(--primary-hover);
  --accent-base: #d57912;
  --accent: color-mix(in oklab, var(--accent-base), black 4%);
  --accent-hover: color-mix(in oklab, var(--accent-base), black 16%);
  --accent-muted: color-mix(in oklab, var(--accent-base) 14%, var(--surface));
  --accent-text: color-mix(in oklab, var(--accent-base), black 22%);
  --secondary: var(--primary);
  --complementary: oklch(74% 0.13 78);
  --ink-strong: oklch(24% 0.020 66);
  --ink: oklch(33% 0.017 62);
  --ink-light: oklch(46% 0.015 60);
  --ink-subtle: oklch(55% 0.012 58);
  --muted: oklch(60% 0.010 58);
  --ink-on-pastel: oklch(28% 0.030 66);
  --white: #fff;
  --black: #000;
  --surface: oklch(99.2% 0.004 95);
  --surface-raised: oklch(98.0% 0.006 92);
  --surface-sunken: oklch(95.6% 0.008 88);
  --surface-overlay: color-mix(in oklab, var(--surface) 92%, transparent);
  --background: oklch(97.4% 0.007 90);
  --border-light: oklch(93% 0.007 85);
  --border: oklch(88% 0.009 80);
  --border-strong: oklch(79% 0.011 72);
  --link: var(--primary-text);
  --link-hover: var(--primary-active);
  --focus-color: var(--primary);
  --focus-ring: color-mix(in oklab, var(--primary) 32%, transparent);
  --selection-bg: color-mix(in oklab, var(--primary) 16%, transparent);
  --success: oklch(56% 0.13 158);
  --success-bg: oklch(95% 0.04 158);
  --warning: oklch(64% 0.16 70);
  --warning-bg: oklch(96% 0.06 78);
  --error: oklch(55% 0.20 25);
  --error-bg: oklch(96% 0.04 25);
  --info: oklch(56% 0.13 235);
  --info-bg: oklch(96% 0.03 235);
  --blockquote-bg: color-mix(in oklab, var(--surface-raised) 88%, var(--primary) 12%);
  --blockquote-border: color-mix(in oklab, var(--primary) 60%, var(--border) 40%);
  --blockquote-quote: color-mix(in oklab, var(--primary) 80%, var(--ink) 20%);
  --footer-surface: oklch(22% 0.022 165);
  --footer-surface-alt: oklch(17% 0.020 165);
  --footer-divider: oklch(34% 0.018 165);
  --footer-text: oklch(94% 0.006 90);
  --footer-text-muted: oklch(74% 0.010 90);
}

:root[data-theme=dark] {
  color-scheme: dark;
}

:root[data-theme=light] {
  color-scheme: light;
}

:root {
  --brand-green: #009260;
  --brand-braun: #d57912;
  --brand-gelb: #f59c08;
  --brand-dunkelblau: #00268a;
  --brand-hellblau: #44b8f2;
  --brand-gold: #cca352;
}

:root {
  --font-display: "Spectral", Georgia, "Times New Roman", serif;
  --font-body: "Hanken Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;
  --font-mono: ui-monospace, "SF Mono", "Cascadia Mono", "Roboto Mono", monaco, consolas, monospace;
  --text-xs: 0.8125rem;
  --text-sm: 0.9375rem;
  --text-base: 1.0625rem;
  --text-lg: 1.1875rem;
  --text-xl: 1.5rem;
  --text-2xl: 1.875rem;
  --text-3xl: clamp(2rem, 1.7rem + 1.5vw, 2.75rem);
  --text-4xl: clamp(2.5rem, 2.1rem + 2vw, 3.5rem);
}

/*--------------------------------------------------------------
# Generic
--------------------------------------------------------------*/
/* Normalize
--------------------------------------------- */
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
     ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15;
  -webkit-text-size-adjust: 100%;
}

/* Sections
     ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

/* Grouping content
     ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace;
  font-size: 1em;
}

/* Text-level semantics
     ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
     ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none;
}

/* Forms
     ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *		`fieldset` elements in all browsers.
 */
legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type=checkbox],
[type=radio] {
  box-sizing: border-box;
  padding: 0;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

/* Interactive
     ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* Misc
     ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none;
}

/* Box sizing
--------------------------------------------- */
/* Inherit box-sizing to more easily change it's value on a component level.
@link http://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/ */
*,
*::before,
*::after {
  box-sizing: inherit;
}

html {
  box-sizing: border-box;
}

/* Collapse
--------------------------------------------- */
.expand:after {
  content: "";
  display: inline-block;
  width: 0.75em;
  height: 0.75em;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='%23000'%3E%3Cpath%20d='M9%205l8%207-8%207z'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='%23000'%3E%3Cpath%20d='M9%205l8%207-8%207z'/%3E%3C/svg%3E") no-repeat center/contain;
  vertical-align: -0.05em;
}

.collapse:after {
  content: "";
  display: inline-block;
  width: 0.75em;
  height: 0.75em;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='%23000'%3E%3Cpath%20d='M5%209l7%208%207-8z'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='%23000'%3E%3Cpath%20d='M5%209l7%208%207-8z'/%3E%3C/svg%3E") no-repeat center/contain;
  vertical-align: -0.05em;
}

.collapsible {
  display: none;
}

.collapse + .collapsible {
  display: block;
  background-color: var(--surface-sunken);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  margin: 0 0 1rem;
  width: 100%;
}

/*--------------------------------------------------------------
# Base
--------------------------------------------------------------*/
/* Theme infrastructure (resets, focus, selection, motion)
--------------------------------------------- */
html {
  scroll-behavior: smooth;
  scroll-padding-top: 6rem;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
       text-size-adjust: 100%;
}

html:has(.main-header input:focus) {
  scroll-padding-top: 0;
}

body {
  min-height: 100vh;
  min-height: 100dvh;
  transition: background-color var(--transition-base), color var(--transition-base);
}

::-moz-selection {
  background: var(--selection-bg);
  color: var(--ink-strong);
}

::selection {
  background: var(--selection-bg);
  color: var(--ink-strong);
}

:focus-visible {
  outline: 2px solid var(--focus-color);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
/* Typography
--------------------------------------------- */
body,
button,
input,
select,
optgroup,
textarea {
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 1.0625rem;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: "kern", "liga", "calt";
}

h1,
h2,
h3,
h4 {
  color: var(--ink-strong);
  font-family: var(--font-display);
  letter-spacing: var(--tracking-tight);
  text-wrap: balance;
  margin-top: 0;
}

h5,
h6 {
  color: var(--ink-strong);
  font-family: var(--font-body);
  margin-top: 0;
}

h1 {
  clear: both;
  font-size: 2.25rem;
  font-weight: 800;
  line-height: 1.2;
  margin-bottom: 1.875rem;
}
@media (min-width: 768px) {
  h1 {
    font-size: clamp(2.5rem, 2.1rem + 2vw, 3.5rem);
    margin-bottom: 3.125rem;
  }
}

h2 {
  font-size: 1.875rem;
  font-weight: 800;
  line-height: 1.2;
  margin-bottom: 1.875rem;
}
@media (min-width: 768px) {
  h2 {
    font-size: clamp(2rem, 1.7rem + 1.5vw, 2.75rem);
  }
}

h3 {
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 1.875rem;
}
@media (min-width: 768px) {
  h3 {
    font-size: 1.875rem;
  }
}

h4 {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 1.75rem;
}
@media (min-width: 768px) {
  h4 {
    font-size: 1.5rem;
  }
}

h5 {
  font-size: 1.125rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 1.4rem;
}
@media (min-width: 768px) {
  h5 {
    font-size: 1.25rem;
  }
}

h6 {
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 1rem;
}
@media (min-width: 768px) {
  h6 {
    font-size: 1.0625rem;
  }
}

p {
  margin-bottom: 1.5rem;
  margin-top: 0;
}

dfn,
cite,
em,
i {
  font-style: italic;
}

blockquote {
  background-color: var(--blockquote-bg);
  border: 1px solid var(--blockquote-border);
  border-radius: var(--radius-lg);
  color: var(--ink);
  font-family: var(--font-display);
  font-size: 1.0625rem;
  font-style: italic;
  line-height: 1.5;
  padding: var(--space-6) var(--space-6) var(--space-6) var(--space-12);
  position: relative;
  margin: 1.5rem 0;
}
@media (min-width: 768px) {
  blockquote {
    margin: 1.5rem 2.5rem;
  }
}
blockquote::before {
  content: "“";
  color: var(--blockquote-quote);
  opacity: 0.55;
  font-family: var(--font-display);
  font-size: 4.5rem;
  font-style: normal;
  left: var(--space-4);
  position: absolute;
  top: var(--space-3);
  line-height: 1;
}
blockquote > *:last-child {
  margin-bottom: 0;
}
blockquote a[rel=footnote] {
  font-style: initial;
}

address {
  margin: 0 0 1.5em;
}

pre {
  background: var(--surface-sunken);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  font-family: var(--font-mono);
  line-height: 1.6;
  color: var(--ink);
  margin-bottom: 1.6em;
  max-width: 100%;
  overflow: auto;
  padding: 1.6em;
}

code,
kbd,
tt,
var {
  font-family: var(--font-mono);
}

abbr,
acronym {
  border-bottom: 1px dotted var(--border);
  cursor: help;
}

mark,
ins {
  background: var(--border-light);
  text-decoration: none;
}

big {
  font-size: 125%;
}

/* Elements
--------------------------------------------- */
body {
  background: var(--background);
}

hr {
  background-color: var(--border);
  border: 0;
  height: 1px;
  margin-bottom: 1.5em;
}

.o-icon-chevron-down::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m6%209%206%206%206-6'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m6%209%206%206%206-6'/%3E%3C/svg%3E") no-repeat center/contain;
  vertical-align: -0.1em;
}

.o-icon-prev::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m15%2018-6-6%206-6'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m15%2018-6-6%206-6'/%3E%3C/svg%3E") no-repeat center/contain;
}

.o-icon-next::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m9%2018%206-6-6-6'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m9%2018%206-6-6-6'/%3E%3C/svg%3E") no-repeat center/contain;
}

.o-icon-grid::before,
.o-icon-list::before,
.o-icon-search::before,
.o-icon-add::before,
.o-icon-delete::before,
.o-icon-private::before,
.o-icon-annotation::before {
  vertical-align: -0.125em;
}

.o-icon-grid::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Crect%20width='7'%20height='7'%20x='3'%20y='3'%20rx='1'/%3E%3Crect%20width='7'%20height='7'%20x='14'%20y='3'%20rx='1'/%3E%3Crect%20width='7'%20height='7'%20x='14'%20y='14'%20rx='1'/%3E%3Crect%20width='7'%20height='7'%20x='3'%20y='14'%20rx='1'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Crect%20width='7'%20height='7'%20x='3'%20y='3'%20rx='1'/%3E%3Crect%20width='7'%20height='7'%20x='14'%20y='3'%20rx='1'/%3E%3Crect%20width='7'%20height='7'%20x='14'%20y='14'%20rx='1'/%3E%3Crect%20width='7'%20height='7'%20x='3'%20y='14'%20rx='1'/%3E%3C/svg%3E") no-repeat center/contain;
}

.o-icon-list::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M3%2012h.01'/%3E%3Cpath%20d='M3%206h.01'/%3E%3Cpath%20d='M3%2018h.01'/%3E%3Cpath%20d='M8%2012h13'/%3E%3Cpath%20d='M8%206h13'/%3E%3Cpath%20d='M8%2018h13'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M3%2012h.01'/%3E%3Cpath%20d='M3%206h.01'/%3E%3Cpath%20d='M3%2018h.01'/%3E%3Cpath%20d='M8%2012h13'/%3E%3Cpath%20d='M8%206h13'/%3E%3Cpath%20d='M8%2018h13'/%3E%3C/svg%3E") no-repeat center/contain;
}

.o-icon-search::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Ccircle%20cx='11'%20cy='11'%20r='8'/%3E%3Cpath%20d='m21%2021-4.3-4.3'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Ccircle%20cx='11'%20cy='11'%20r='8'/%3E%3Cpath%20d='m21%2021-4.3-4.3'/%3E%3C/svg%3E") no-repeat center/contain;
}

.o-icon-add::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M5%2012h14'/%3E%3Cpath%20d='M12%205v14'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M5%2012h14'/%3E%3Cpath%20d='M12%205v14'/%3E%3C/svg%3E") no-repeat center/contain;
}

.o-icon-delete::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M18%206%206%2018'/%3E%3Cpath%20d='m6%206%2012%2012'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M18%206%206%2018'/%3E%3Cpath%20d='m6%206%2012%2012'/%3E%3C/svg%3E") no-repeat center/contain;
}

.o-icon-private::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Crect%20width='18'%20height='11'%20x='3'%20y='11'%20rx='2'%20ry='2'/%3E%3Cpath%20d='M7%2011V7a5%205%200%200%201%2010%200v4'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Crect%20width='18'%20height='11'%20x='3'%20y='11'%20rx='2'%20ry='2'/%3E%3Cpath%20d='M7%2011V7a5%205%200%200%201%2010%200v4'/%3E%3C/svg%3E") no-repeat center/contain;
}

.o-icon-annotation::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2015a2%202%200%200%201-2%202H7l-4%204V5a2%202%200%200%201%202-2h14a2%202%200%200%201%202%202z'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M21%2015a2%202%200%200%201-2%202H7l-4%204V5a2%202%200%200%201%202-2h14a2%202%200%200%201%202%202z'/%3E%3C/svg%3E") no-repeat center/contain;
}

.language {
  display: inline-flex;
  align-items: center;
  background-color: var(--surface-sunken);
  border-radius: 20px;
  color: var(--ink-strong);
  font-family: var(--font-body);
  font-size: 0.8125rem;
  font-weight: 600;
  line-height: 1;
  padding: 5px 10px 5px 5px;
  vertical-align: top;
  height: 22px;
  flex-shrink: 0;
}
.language::before {
  content: "";
  display: block;
  background-color: var(--primary);
  width: 14px;
  height: 14px;
  border-radius: 50%;
  margin-right: 5px;
}

ul,
ol {
  margin: 0;
  padding-left: 2rem;
}

ul {
  margin-bottom: 1.5rem;
}
ul li {
  margin-bottom: 0.5rem;
}
ul li::marker {
  color: var(--primary);
}

ol {
  list-style: decimal;
  margin-bottom: 1.5rem;
}
ol li {
  margin-bottom: 0.5rem;
}
ol li::marker {
  color: var(--primary);
  font-weight: 600;
  margin-right: 15px;
}

li > ul,
li > ol {
  margin-bottom: 0;
  margin-left: 1.5em;
}

dt {
  color: var(--ink-strong);
  font-size: 1rem;
  font-weight: 600;
}
@media (min-width: 768px) {
  dt {
    font-size: 1.0625rem;
  }
}

dd {
  margin: 0 1rem 1rem 0;
}
dd::after {
  content: "";
  clear: both;
  display: table;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
  max-width: 100%;
}

img:not(.leaflet-marker-icon) {
  height: auto;
  max-width: 100%;
}
#main-content img:not(.leaflet-marker-icon) {
  border-radius: 20px 0;
}

figure {
  margin: 1em 0;
}

.decoration {
  display: inline-block;
  font-size: 0;
  position: relative;
  padding: 10px 0 0 10px;
}
.decoration::after {
  content: "";
  width: calc(100% - 10px);
  height: calc(100% - 10px);
  border-radius: 20px 0;
  position: absolute;
  left: 0;
  top: 0;
  border: 1px dashed var(--complementary);
  z-index: 2;
  pointer-events: none;
}
.decoration--thumbnail img {
  border-radius: 10px 0;
}

.resource .description {
  white-space: -moz-pre-wrap; /* Mozilla */
  white-space: -hp-pre-wrap; /* HP printers */
  white-space: -o-pre-wrap; /* Opera 7 */
  white-space: -pre-wrap; /* Opera 4-6 */
  white-space: pre-wrap; /* CSS 2.1 */
  white-space: pre-line; /* CSS 3 (and 2.1 as well, actually) */
  word-wrap: break-word; /* IE */
  word-break: break-word;
}
.resource .description.fadeout {
  position: relative;
  max-height: 6.2rem;
  overflow: hidden;
}
.resource .description.fadeout::after {
  content: "";
  background: linear-gradient(to right, transparent, var(--surface) 60%);
  height: 1.7rem;
  left: 50%;
  position: absolute;
  right: 0;
  top: 4.5rem;
}
.resource .description.ellipsis {
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.resource-tags {
  display: flex;
  flex-shrink: 0;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 15px;
}
.resource-tags .resource-tag {
  display: flex;
  align-items: center;
  color: var(--ink-strong);
  background-color: var(--surface-sunken);
  border-radius: 20px;
  font-size: 0.8125rem;
  font-weight: 600;
  padding: 5px 10px;
}
.resource-tags .resource-tag .resource-tag-color {
  display: block;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  margin-right: 5px;
}

table {
  margin: 0 0 1.5em;
  width: 100%;
}
table td {
  word-break: break-word;
  overflow-wrap: anywhere;
  white-space: normal;
}

.title,
.block-pageTitle {
  display: inline-block;
  margin-bottom: 1.875rem !important;
  padding-bottom: 0.5rem;
  position: relative;
}
.title::after,
.block-pageTitle::after {
  content: "";
  display: block;
  width: 2.75rem;
  height: var(--accent-line-md);
  margin-top: 0.6rem;
  background-color: var(--primary);
  border-radius: var(--radius-full);
}
.title .title,
.block-pageTitle .title {
  margin-bottom: 0 !important;
  padding-bottom: 0;
}
.title .title::after,
.block-pageTitle .title::after {
  content: none;
}
.slick-slide .title::after,
.slick-slide .block-pageTitle::after {
  content: none;
}
.title.has-background,
.block-pageTitle.has-background {
  padding-right: 10px;
}

.caption {
  font-style: italic;
  font-size: 0.9375rem;
}

.tooltip {
  display: inline-block;
  color: var(--secondary);
  font-size: 1.2rem;
  line-height: 1;
  margin-left: 5px;
  position: relative;
}
.tooltip.is-visible .tooltip-text {
  visibility: visible;
}
.tooltip .tooltip-button {
  border-radius: 50%;
  width: 20px;
  height: 20px;
  line-height: 1;
  padding: 0;
  background-color: var(--secondary);
  font-weight: 500;
}
.tooltip .tooltip-button:hover, .tooltip .tooltip-button:focus {
  background-color: var(--secondary);
}
.tooltip .tooltip-text {
  background-color: var(--secondary);
  border-radius: 6px;
  bottom: 130%;
  color: var(--surface);
  font-size: 0.8125rem;
  left: 50%;
  margin-left: -106px;
  padding: 12px;
  position: absolute;
  text-align: center;
  visibility: hidden;
  width: 212px;
  z-index: 1;
}
.tooltip .tooltip-text::after {
  content: "";
  border-color: var(--secondary) transparent transparent transparent;
  border-style: solid;
  border-width: 5px;
  left: 50%;
  margin-left: -5px;
  position: absolute;
  top: 100%;
}

/* Links
--------------------------------------------- */
a {
  color: var(--link);
  text-decoration-thickness: 1px;
  text-underline-offset: 0.15em;
  transition: color var(--transition-fast), text-decoration-color var(--transition-fast);
  word-wrap: break-word;
}
a:visited {
  color: var(--link);
}
a:hover, a:active {
  color: var(--link-hover);
}
a:focus-visible {
  outline: 2px solid var(--focus-color);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* Forms
--------------------------------------------- */
button,
.button,
input[type=button],
input[type=reset],
input[type=submit] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  border-radius: var(--radius-md);
  cursor: pointer;
  padding: 0.7rem 1.4rem;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.9375rem;
  line-height: 1.2;
  letter-spacing: 0.005em;
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base), color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-fast);
  background-color: var(--primary);
  border: 1px solid transparent;
  color: var(--primary-contrast);
  box-shadow: var(--shadow-xs);
}
button:hover:not(.disabled):not(:disabled),
.button:hover:not(.disabled):not(:disabled),
input[type=button]:hover:not(.disabled):not(:disabled),
input[type=reset]:hover:not(.disabled):not(:disabled),
input[type=submit]:hover:not(.disabled):not(:disabled) {
  background-color: var(--primary-hover);
  color: var(--primary-contrast);
  box-shadow: var(--glow-sm);
  transform: translateY(var(--lift-xs));
}
button:active:not(.disabled):not(:disabled),
.button:active:not(.disabled):not(:disabled),
input[type=button]:active:not(.disabled):not(:disabled),
input[type=reset]:active:not(.disabled):not(:disabled),
input[type=submit]:active:not(.disabled):not(:disabled) {
  background-color: var(--primary-active);
  box-shadow: var(--shadow-xs);
  transform: none;
}
button:focus-visible,
.button:focus-visible,
input[type=button]:focus-visible,
input[type=reset]:focus-visible,
input[type=submit]:focus-visible {
  outline: 2px solid var(--focus-color);
  outline-offset: 2px;
}
button:disabled, button[disabled], button.disabled,
.button:disabled,
.button[disabled],
.button.disabled,
input[type=button]:disabled,
input[type=button][disabled],
input[type=button].disabled,
input[type=reset]:disabled,
input[type=reset][disabled],
input[type=reset].disabled,
input[type=submit]:disabled,
input[type=submit][disabled],
input[type=submit].disabled {
  background-color: var(--muted);
  color: var(--surface);
  cursor: default;
  box-shadow: none;
  transform: none;
}
button:visited,
.button:visited,
input[type=button]:visited,
input[type=reset]:visited,
input[type=submit]:visited {
  color: var(--primary-contrast);
}
button.btn--secondary,
.button.btn--secondary,
input[type=button].btn--secondary,
input[type=reset].btn--secondary,
input[type=submit].btn--secondary {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  border-radius: var(--radius-md);
  cursor: pointer;
  padding: 0.7rem 1.4rem;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.9375rem;
  line-height: 1.2;
  letter-spacing: 0.005em;
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base), color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-fast);
  background-color: transparent;
  border: 1px solid var(--border-strong);
  color: var(--primary-text);
}
button.btn--secondary:hover:not(.disabled):not(:disabled),
.button.btn--secondary:hover:not(.disabled):not(:disabled),
input[type=button].btn--secondary:hover:not(.disabled):not(:disabled),
input[type=reset].btn--secondary:hover:not(.disabled):not(:disabled),
input[type=submit].btn--secondary:hover:not(.disabled):not(:disabled) {
  background-color: var(--primary-muted);
  border-color: var(--primary);
  color: var(--primary-text);
}
button.btn--secondary:active:not(.disabled):not(:disabled),
.button.btn--secondary:active:not(.disabled):not(:disabled),
input[type=button].btn--secondary:active:not(.disabled):not(:disabled),
input[type=reset].btn--secondary:active:not(.disabled):not(:disabled),
input[type=submit].btn--secondary:active:not(.disabled):not(:disabled) {
  background-color: color-mix(in oklab, var(--primary-muted), var(--primary) 10%);
}
button.btn--secondary:focus-visible,
.button.btn--secondary:focus-visible,
input[type=button].btn--secondary:focus-visible,
input[type=reset].btn--secondary:focus-visible,
input[type=submit].btn--secondary:focus-visible {
  outline: 2px solid var(--focus-color);
  outline-offset: 2px;
}
button.btn--secondary:disabled, button.btn--secondary[disabled], button.btn--secondary.disabled,
.button.btn--secondary:disabled,
.button.btn--secondary[disabled],
.button.btn--secondary.disabled,
input[type=button].btn--secondary:disabled,
input[type=button].btn--secondary[disabled],
input[type=button].btn--secondary.disabled,
input[type=reset].btn--secondary:disabled,
input[type=reset].btn--secondary[disabled],
input[type=reset].btn--secondary.disabled,
input[type=submit].btn--secondary:disabled,
input[type=submit].btn--secondary[disabled],
input[type=submit].btn--secondary.disabled {
  border-color: var(--border);
  color: var(--muted);
  cursor: default;
}
button.btn--secondary:visited,
.button.btn--secondary:visited,
input[type=button].btn--secondary:visited,
input[type=reset].btn--secondary:visited,
input[type=submit].btn--secondary:visited {
  color: var(--primary-text);
}
button.link-style,
.button.link-style,
input[type=button].link-style,
input[type=reset].link-style,
input[type=submit].link-style {
  background-color: transparent !important;
  color: var(--link);
  padding-left: 0;
  padding-right: 0;
  text-transform: none;
  text-decoration: underline;
}
button.icon-btn,
.button.icon-btn,
input[type=button].icon-btn,
input[type=reset].icon-btn,
input[type=submit].icon-btn {
  padding: 0;
  background-color: transparent !important;
  color: var(--primary);
  font-size: 1.7rem;
  line-height: 1;
}
button.icon-btn:hover, button.icon-btn:active, button.icon-btn:focus,
.button.icon-btn:hover,
.button.icon-btn:active,
.button.icon-btn:focus,
input[type=button].icon-btn:hover,
input[type=button].icon-btn:active,
input[type=button].icon-btn:focus,
input[type=reset].icon-btn:hover,
input[type=reset].icon-btn:active,
input[type=reset].icon-btn:focus,
input[type=submit].icon-btn:hover,
input[type=submit].icon-btn:active,
input[type=submit].icon-btn:focus {
  color: var(--secondary);
}
button.icon-btn:disabled, button.icon-btn[disabled] button.icon-btn.disabled,
.button.icon-btn:disabled,
button.icon-btn[disabled] .button.icon-btn.disabled,
input[type=button].icon-btn:disabled,
button.icon-btn[disabled] input[type=button].icon-btn.disabled,
input[type=reset].icon-btn:disabled,
button.icon-btn[disabled] input[type=reset].icon-btn.disabled,
input[type=submit].icon-btn:disabled,
button.icon-btn[disabled] input[type=submit].icon-btn.disabled,
.button.icon-btn[disabled] button.icon-btn.disabled,
.button.icon-btn[disabled] .button.icon-btn.disabled,
.button.icon-btn[disabled] input[type=button].icon-btn.disabled,
.button.icon-btn[disabled] input[type=reset].icon-btn.disabled,
.button.icon-btn[disabled] input[type=submit].icon-btn.disabled,
input[type=button].icon-btn[disabled] button.icon-btn.disabled,
input[type=button].icon-btn[disabled] .button.icon-btn.disabled,
input[type=button].icon-btn[disabled] input[type=button].icon-btn.disabled,
input[type=button].icon-btn[disabled] input[type=reset].icon-btn.disabled,
input[type=button].icon-btn[disabled] input[type=submit].icon-btn.disabled,
input[type=reset].icon-btn[disabled] button.icon-btn.disabled,
input[type=reset].icon-btn[disabled] .button.icon-btn.disabled,
input[type=reset].icon-btn[disabled] input[type=button].icon-btn.disabled,
input[type=reset].icon-btn[disabled] input[type=reset].icon-btn.disabled,
input[type=reset].icon-btn[disabled] input[type=submit].icon-btn.disabled,
input[type=submit].icon-btn[disabled] button.icon-btn.disabled,
input[type=submit].icon-btn[disabled] .button.icon-btn.disabled,
input[type=submit].icon-btn[disabled] input[type=button].icon-btn.disabled,
input[type=submit].icon-btn[disabled] input[type=reset].icon-btn.disabled,
input[type=submit].icon-btn[disabled] input[type=submit].icon-btn.disabled {
  color: var(--muted);
}

button.add-value,
button.remove-value {
  background-color: var(--surface);
  border: 1px solid var(--border);
  border-radius: 50%;
  cursor: pointer;
  color: var(--primary);
  width: 35px;
  height: 35px;
  padding: 5px 9px;
  text-transform: uppercase;
  -webkit-appearance: none;
  -moz-appearance: none;
  flex-shrink: 0;
}
button.add-value:hover, button.add-value:focus,
button.remove-value:hover,
button.remove-value:focus {
  background-color: var(--primary) !important;
  color: var(--surface);
}

.button {
  cursor: pointer;
}

input[type=text],
input[type=email],
input[type=url],
input[type=password],
input[type=search],
input[type=number],
input[type=tel],
input[type=range],
input[type=date],
input[type=month],
input[type=week],
input[type=time],
input[type=datetime],
input[type=datetime-local],
input[type=color],
textarea,
select {
  display: block;
  background-color: var(--surface);
  border: 1px solid var(--border-strong);
  margin-bottom: 8px;
  padding: 0.6rem 0.9rem;
  border-radius: var(--radius-md);
  line-height: 1.4;
  color: var(--ink);
  text-overflow: ellipsis;
  width: 100%;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
input[type=text]:focus,
input[type=email]:focus,
input[type=url]:focus,
input[type=password]:focus,
input[type=search]:focus,
input[type=number]:focus,
input[type=tel]:focus,
input[type=range]:focus,
input[type=date]:focus,
input[type=month]:focus,
input[type=week]:focus,
input[type=time]:focus,
input[type=datetime]:focus,
input[type=datetime-local]:focus,
input[type=color]:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: var(--ring-focus);
}
input[type=text]::-moz-placeholder, input[type=email]::-moz-placeholder, input[type=url]::-moz-placeholder, input[type=password]::-moz-placeholder, input[type=search]::-moz-placeholder, input[type=number]::-moz-placeholder, input[type=tel]::-moz-placeholder, input[type=range]::-moz-placeholder, input[type=date]::-moz-placeholder, input[type=month]::-moz-placeholder, input[type=week]::-moz-placeholder, input[type=time]::-moz-placeholder, input[type=datetime]::-moz-placeholder, input[type=datetime-local]::-moz-placeholder, input[type=color]::-moz-placeholder, textarea::-moz-placeholder, select::-moz-placeholder {
  color: var(--ink-subtle);
}
input[type=text]::placeholder,
input[type=email]::placeholder,
input[type=url]::placeholder,
input[type=password]::placeholder,
input[type=search]::placeholder,
input[type=number]::placeholder,
input[type=tel]::placeholder,
input[type=range]::placeholder,
input[type=date]::placeholder,
input[type=month]::placeholder,
input[type=week]::placeholder,
input[type=time]::placeholder,
input[type=datetime]::placeholder,
input[type=datetime-local]::placeholder,
input[type=color]::placeholder,
textarea::placeholder,
select::placeholder {
  color: var(--ink-subtle);
}

input[type=checkbox]:not(input[name=numeric-toggle-time-checkbox]) {
  border: 2px solid var(--border-strong);
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  background-color: var(--surface);
  margin: 0;
  font: inherit;
  color: var(--surface);
  width: 1.2rem;
  height: 1.2rem;
  border-radius: 0.15em;
  transform: translateY(0.2em);
  display: grid;
  place-content: center;
  flex-shrink: 0;
}
input[type=checkbox]:not(input[name=numeric-toggle-time-checkbox]):checked {
  border: 2px solid var(--primary);
  background-color: var(--primary);
}
input[type=checkbox]:not(input[name=numeric-toggle-time-checkbox]):checked::before {
  content: "";
  display: inline-block;
  width: 0.85rem;
  height: 0.85rem;
  background-color: var(--surface);
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='3'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M20%206%209%2017l-5-5'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='3'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='M20%206%209%2017l-5-5'/%3E%3C/svg%3E") no-repeat center/contain;
}

input[type=radio] {
  border: 2px solid var(--border-strong);
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  background-color: var(--surface);
  margin: 0;
  font: inherit;
  color: var(--primary);
  width: 1.15rem;
  height: 1.15rem;
  border-radius: 50%;
  transform: translateY(0.2em);
  display: grid;
  place-content: center;
  flex-shrink: 0;
}
input[type=radio]::before {
  content: "";
  width: 0.65em;
  height: 0.65em;
  border-radius: 50%;
  transform: scale(0);
  box-shadow: inset 1em 1em var(--primary);
  border: 2px solid var(--primary);
}
input[type=radio]:checked {
  border: 2px solid var(--primary);
}
input[type=radio]:checked::before {
  transform: scale(1);
}

select {
  position: relative;
  -moz-appearance: none; /* Firefox */
  -webkit-appearance: none; /* Safari and Chrome */
  appearance: none;
  background-color: var(--surface);
  background-image: url("../img/arrow-down-blue.svg");
  background-position: calc(100% - 15px) center;
  background-size: 18px;
  background-repeat: no-repeat;
  height: 44px;
  padding-right: 45px;
}

label,
.label,
legend {
  color: var(--ink-strong);
  display: inline-block;
}

label.sub-label {
  display: flex;
  flex-direction: column;
  font-size: 0.9375rem;
}
label.sub-label input,
label.sub-label select {
  margin-top: 0 !important;
}

.field,
fieldset {
  border: 1px dashed var(--border);
  border-radius: 20px 0;
  padding: 20px 25px;
  margin-bottom: 25px;
}

fieldset {
  border: none;
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}
fieldset legend {
  float: left;
  width: 100%;
}
fieldset .field {
  flex: 1 1 100px;
  box-shadow: none;
  margin-bottom: 0;
  margin-right: 15px;
  max-width: 100%;
  min-width: 100px;
  padding: 0;
}
fieldset .field:last-of-type {
  margin-right: 0;
}
fieldset .field .field-meta label {
  font-size: 0.9375rem;
}

/* Layouts
--------------------------------------------------------------*/
html, body {
  width: 100%;
}

html {
  scroll-padding-top: 6rem;
}

.container {
  width: 100%;
  max-width: 1440px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 15px;
  position: relative;
}
@media (min-width: 768px) {
  .container {
    padding: 0 30px;
  }
}

#content {
  padding-top: 2rem;
  padding-bottom: 3rem;
}
@media (min-width: 1024px) {
  #content {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
}
@media (min-width: 1024px) {
  body.items.search #content {
    max-width: 1160px;
    padding: 3rem 10rem 4rem 4rem;
  }
}
@media (min-width: 1200px) {
  body.items.search #content {
    max-width: 1160px;
    padding: 3rem 10rem 4rem;
  }
}

.regions-container {
  display: flex;
  flex-direction: column;
  gap: 50px;
  margin-bottom: 3rem;
  padding-bottom: 50px;
  border-bottom: 1px solid var(--secondary);
}
@media (min-width: 768px) {
  .regions-container {
    flex-direction: row;
  }
}
.regions-container .main-region {
  order: -1;
  width: 100%;
}
@media (min-width: 768px) {
  .regions-container .main-region {
    order: initial;
  }
}
.regions-container .sidebar-region {
  flex-shrink: 0;
  position: relative;
  width: 100%;
}
@media (min-width: 768px) {
  .regions-container .sidebar-region {
    width: 30%;
  }
}
.regions-container .sidebar-region--left::after {
  right: -30px;
}
.regions-container .sidebar-region--right::after {
  left: -30px;
}
.regions-container--all {
  flex-direction: column !important;
}
@media (min-width: 1200px) {
  .regions-container--all {
    flex-direction: row !important;
  }
}
.regions-container--all .main-region {
  order: -1 !important;
}
@media (min-width: 1200px) {
  .regions-container--all .main-region {
    order: initial !important;
  }
}
.regions-container--all .sidebar-region {
  width: 100% !important;
}
@media (min-width: 1200px) {
  .regions-container--all .sidebar-region {
    width: 20% !important;
  }
}

/*--------------------------------------------------------------
# Components
--------------------------------------------------------------*/
/* Header
--------------------------------------------- */
.main-header {
  background-color: var(--surface);
  position: sticky;
  width: 100%;
  top: 0;
  left: 0;
  z-index: var(--z-header);
  border-top: 3px solid var(--primary);
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
  transition: top 0.3s var(--ease-out-quart), background-color var(--transition-base), border-color var(--transition-base);
}
.main-header__top-bar {
  background-color: var(--surface-sunken);
  border-bottom: 1px solid var(--border-light);
  display: none;
}
@media (min-width: 1200px) {
  .main-header__top-bar {
    display: block;
  }
}
.main-header__top-bar .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--space-2);
  padding-bottom: var(--space-2);
  color: var(--ink-light);
  font-size: 0.8125rem;
}
.main-header__top-bar .container a {
  color: var(--ink-light);
  text-decoration: none;
}
.main-header__top-bar .container a:hover {
  color: var(--primary-text);
}
.main-header__top-bar .container .top-bar__info {
  display: flex;
  gap: var(--space-8);
  margin-right: var(--space-3);
}
.main-header__top-bar .container .top-bar__info .contact_info {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.main-header hr {
  background-color: var(--border);
  border: 0;
  height: 1px;
  margin-bottom: 0;
}
.main-header__main-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  position: relative;
  padding-top: var(--space-3);
  padding-bottom: var(--space-3);
}
.main-header__site-title {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  margin-bottom: 0;
  max-width: 60%;
  order: 0;
}
@media (min-width: 1024px) {
  .main-header__site-title {
    max-width: 40%;
    order: initial;
  }
}
.main-header__site-title a {
  display: inline-flex;
  align-items: center;
  font-family: var(--font-display);
  font-size: 1.25rem;
  font-weight: 600;
  line-height: 1.2;
  color: var(--ink-strong);
  text-decoration: none;
}
.main-header__utilities {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  min-width: 0;
  order: 2;
}
@media (min-width: 1200px) {
  .main-header__utilities {
    margin-left: auto;
    order: initial;
  }
}

.site-logo {
  display: block;
  width: auto;
  height: auto;
  max-height: 46px;
}
@media (min-width: 1024px) {
  .site-logo {
    max-height: 54px;
  }
}

.site-logo--dark {
  display: none;
}

body[data-theme=dark] .site-logo--light {
  display: none;
}
body[data-theme=dark] .site-logo--dark {
  display: block;
}

@media (prefers-color-scheme: dark) {
  body:not([data-theme=light]) .site-logo--light {
    display: none;
  }
  body:not([data-theme=light]) .site-logo--dark {
    display: block;
  }
}
.theme-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: var(--size-control-md);
  height: var(--size-control-md);
  padding: 0;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  background-color: transparent;
  color: var(--ink-light);
  cursor: pointer;
  transition: color var(--transition-fast), background-color var(--transition-fast), border-color var(--transition-fast);
}
.theme-toggle:hover:not(.disabled):not(:disabled) {
  background-color: var(--surface-sunken);
  border-color: var(--border-strong);
  color: var(--primary-text);
  box-shadow: none;
  transform: none;
}
.theme-toggle:focus-visible {
  outline: 2px solid var(--focus-color);
  outline-offset: 2px;
}
.theme-toggle svg {
  width: 18px;
  height: 18px;
  display: block;
}
.theme-toggle__icon {
  display: inline-flex;
  line-height: 0;
}
.theme-toggle__icon--moon {
  display: none;
}

body[data-theme=dark] .theme-toggle .theme-toggle__icon--sun {
  display: none;
}
body[data-theme=dark] .theme-toggle .theme-toggle__icon--moon {
  display: inline-flex;
}

@media (prefers-color-scheme: dark) {
  body:not([data-theme=light]) .theme-toggle .theme-toggle__icon--sun {
    display: none;
  }
  body:not([data-theme=light]) .theme-toggle .theme-toggle__icon--moon {
    display: inline-flex;
  }
}
.main-search-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: var(--size-control-md);
  height: var(--size-control-md);
  padding: 0;
  font-size: 1.125rem;
  line-height: 1;
  margin-left: auto;
  margin-right: 0;
}
@media (min-width: 1200px) {
  .main-search-button {
    margin-left: 0;
    order: initial;
  }
}
.main-search-button:hover:not(.disabled):not(:disabled) {
  transform: none;
}

.main-header-search {
  display: none;
  flex-direction: column;
  align-items: flex-end;
  position: absolute;
  top: 100%;
  right: 0;
  background-color: var(--surface);
  border-top: 1px solid var(--secondary);
  border-radius: 0 0 30px 30px;
  box-shadow: 0px 2px 5px 2px rgba(0, 0, 0, 0.11);
  padding: 20px;
  width: calc(100% - 30px);
  margin: 0 15px;
  z-index: 24;
}
@media (min-width: 768px) {
  .main-header-search {
    width: calc(100% - 60px);
    margin: 0 30px;
  }
}
@media (min-width: 1200px) {
  .main-header-search {
    width: 450px;
  }
}
.main-header-search.visible {
  display: flex;
}
.main-header-search form {
  display: flex;
  width: 100%;
  margin-bottom: 15px;
}
.main-header-search input {
  padding-right: 46px;
  margin-bottom: 0;
  margin-right: -46px;
  width: 100%;
}
.main-header-search button {
  color: var(--surface);
  padding: 10px 15px;
  border-radius: 0 22px 22px 0;
}

.main-header__utilities .main-header__search-bar {
  width: clamp(11rem, 20vw, 16rem);
  min-width: 9rem;
  flex-shrink: 1;
}
@media (min-width: 1200px) {
  .main-header__utilities .main-header__search-bar {
    margin-left: auto;
  }
}

.main-header__search-bar.d-xl-none {
  margin-left: auto;
}
.main-header__search-bar.d-xl-none,
.main-header__search-bar.d-xl-none .dre-search-bar--collapsible {
  position: static;
}

.main-header__search-bar.d-xl-none .dre-search-bar--collapsible.dre-search-bar--expanded .dre-search-bar__input-wrap {
  inset-inline: var(--space-3);
  width: auto;
  top: 100%;
  transform: translateY(var(--space-2));
}

.main-header__search-bar.d-xl-none .dre-search-bar--collapsible.dre-search-bar--expanded .dre-search-bar__suggest {
  inset-inline: var(--space-3);
  width: auto;
  top: 100%;
  transform: translateY(calc(var(--space-2) + var(--size-control-md, 2.5rem) + var(--space-2)));
}

/* Navigation
--------------------------------------------- */
.main-navigation {
  order: 3;
}
@media (min-width: 1200px) {
  .main-navigation {
    margin-left: auto;
    margin-right: 20px;
    order: initial;
  }
}
.main-navigation__container {
  display: none;
}
@media screen and (min-width: 1200px) {
  .main-navigation__container {
    display: block;
  }
}
.main-navigation__toggle {
  display: block;
  width: 35px;
  height: 28px;
  position: relative;
  margin: 0;
  flex-shrink: 0;
  transform: rotate(0deg);
  transition: 0.5s ease-in-out;
  background-color: transparent;
  padding: 0;
  border-radius: 0;
}
@media (min-width: 1200px) {
  .main-navigation__toggle {
    display: none;
  }
}
.main-navigation__toggle:hover:not(.disabled):not(:disabled) {
  background-color: transparent;
  transform: none;
  box-shadow: none;
}
.main-navigation__toggle span {
  display: block;
  position: absolute;
  height: 4px;
  width: 100%;
  background: var(--primary);
  border-radius: 9px;
  opacity: 1;
  left: 0;
  transform: rotate(0deg);
  transition: 0.25s ease-in-out;
}
.main-navigation__toggle span:nth-child(2) {
  top: 0px;
  transform-origin: left center;
}
.main-navigation__toggle span:nth-child(3) {
  top: 11px;
  transform-origin: left center;
}
.main-navigation__toggle span:nth-child(4) {
  top: 22px;
  transform-origin: left center;
}
.main-navigation__toggle.open span:nth-child(2) {
  transform: rotate(45deg);
  top: -1px;
  left: 5px;
}
.main-navigation__toggle.open span:nth-child(3) {
  width: 0%;
  opacity: 0;
}
.main-navigation__toggle.open span:nth-child(4) {
  transform: rotate(-45deg);
  top: 24px;
  left: 5px;
}
.main-navigation .navigation {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 0.15rem;
  margin: 0;
  padding-left: 0;
}
.main-header--inline .main-navigation .navigation {
  margin-right: -10px;
}
.main-navigation .navigation li {
  margin-bottom: 0;
}
.main-navigation .navigation li::before {
  content: none !important;
}
.main-navigation .navigation > li {
  display: flex;
  align-items: center;
  cursor: pointer;
}
.main-navigation .navigation > li.active > a {
  color: var(--primary-text);
  font-weight: 600;
  background-color: color-mix(in oklab, var(--primary) 14%, transparent);
  border-color: color-mix(in oklab, var(--primary) 32%, transparent);
}
.main-navigation .navigation > li:hover > a, .main-navigation .navigation > li:focus-within > a {
  color: var(--primary-text);
  background-color: color-mix(in oklab, var(--primary) 12%, transparent);
}
.main-navigation .navigation > li > a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35em;
  position: relative;
  color: var(--ink-strong);
  text-decoration: none;
  margin: 0;
  padding: var(--space-2) clamp(0.55rem, 0.3rem + 0.6vw, 0.95rem);
  border: 1px solid transparent;
  border-radius: var(--radius-full);
  text-align: center;
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.2;
  transition: background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}
.main-navigation .navigation > li > a:focus-visible {
  outline: 2px solid var(--focus-color);
  outline-offset: 2px;
}
.main-navigation .navigation > li.menu-item-has-children > a {
  padding-right: 1.85rem;
}
.main-navigation .navigation > li.menu-item-has-children > a::after {
  content: "";
  position: absolute;
  right: 0.85rem;
  top: 50%;
  width: 0.42rem;
  height: 0.42rem;
  border-right: 2px solid var(--primary);
  border-bottom: 2px solid var(--primary);
  transform: translateY(-65%) rotate(45deg);
  transition: transform var(--transition-fast);
}
.main-navigation .navigation > li.menu-item-has-children > a::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  height: 1.4rem;
}
.main-navigation .navigation > li.menu-item-has-children.open > a::after {
  transform: translateY(-25%) rotate(225deg);
}
.main-navigation .navigation > li.menu-item-has-children .submenu-btn {
  align-self: stretch;
  width: 1.85rem;
  margin-left: -1.85rem;
  position: relative;
  z-index: 1;
  padding: 0;
  background-color: transparent;
  border: none;
  border-radius: var(--radius-full);
  box-shadow: none;
  color: inherit;
  cursor: pointer;
}
.main-navigation .navigation > li.menu-item-has-children .submenu-btn:hover:not(.disabled):not(:disabled), .main-navigation .navigation > li.menu-item-has-children .submenu-btn:active:not(.disabled):not(:disabled) {
  background-color: transparent;
  box-shadow: none;
  transform: none;
}
.main-navigation .navigation > li.menu-item-has-children .submenu-btn:focus-visible {
  outline: 2px solid var(--focus-color);
  outline-offset: 2px;
}
.main-navigation .navigation > li > ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: clamp(var(--space-6), 2.2vw, var(--space-12));
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  width: 100%;
  margin: 0 auto;
  padding: clamp(var(--space-5), 2.5vw, var(--space-8)) clamp(var(--space-6), 3vw, var(--space-10));
  list-style: none;
  background-color: var(--surface);
  border-top: var(--accent-line-md) solid var(--primary);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  box-shadow: var(--shadow-lg);
  z-index: var(--z-dropdown);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-0.4rem);
  pointer-events: none;
  transition: opacity var(--transition-fast), transform var(--transition-fast), visibility 0s linear var(--transition-fast);
}
.main-navigation .navigation > li > ul::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 100%;
  height: 1.4rem;
}
.main-navigation .navigation > li > ul > li {
  max-width: 260px;
  position: relative;
}
.main-navigation .navigation > li > ul > li:not(:last-child)::after {
  content: "";
  height: 100%;
  width: 1px;
  position: absolute;
  background-color: var(--border);
  top: 0;
  bottom: 0;
  right: -1.35rem;
}
.main-navigation .navigation > li > ul > li > a {
  font-weight: 700;
  color: var(--ink-strong);
}
.main-navigation .navigation > li > ul > li > a:has(+ ul)::after {
  content: "";
  display: inline-block;
  width: 0.6rem;
  height: 0.6rem;
  background-color: var(--accent);
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m9%2018%206-6-6-6'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m9%2018%206-6-6-6'/%3E%3C/svg%3E") no-repeat center/contain;
  margin-left: 5px;
  vertical-align: 0.02em;
}
.main-navigation .navigation > li > ul > li > ul {
  margin-top: 0.8rem;
  margin-left: 0;
  padding-left: 0;
  list-style: none;
}
.main-navigation .navigation > li > ul > li > ul li {
  margin-bottom: 5px;
}
.main-navigation .navigation > li > ul > li > ul li ul {
  margin-left: 0;
  padding-left: 25px;
}
.main-navigation .navigation > li > ul a {
  color: var(--ink);
  text-transform: none;
  text-decoration: none;
  font-size: 0.94rem;
  border-radius: var(--radius-sm);
  transition: color var(--transition-fast);
}
.main-navigation .navigation > li > ul a:hover {
  color: var(--primary-text);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}
.main-navigation .navigation > li.menu-item-has-children.open > ul, .main-navigation .navigation > li.menu-item-has-children:hover > ul {
  opacity: 1;
  visibility: visible;
  transform: none;
  pointer-events: auto;
  transition: opacity var(--transition-fast), transform var(--transition-fast);
}
.main-navigation .navigation a {
  display: block;
}

.menu-drawer {
  display: block !important;
  position: fixed;
  height: calc(100% - 74px);
  width: 100%;
  transform: translateX(-100%);
  z-index: 23;
  top: 74px;
  left: 0;
  background-color: var(--surface);
  overflow-x: hidden;
  transition: all 0.3s ease-out;
  visibility: hidden;
}
@media screen and (min-width: 1200px) {
  .menu-drawer {
    transform: translateX(-100%) !important;
  }
}
.menu-drawer > .wrap {
  margin-left: auto;
  margin-right: auto;
  max-width: 1300px;
  display: block;
  padding: 0;
  text-align: right;
}
.menu-drawer.toggled {
  transform: translateX(0);
  visibility: visible;
}
.menu-drawer .navigation-controls {
  border-bottom: 1px solid var(--muted);
  background-color: var(--secondary);
  color: var(--surface);
  font-size: 1.1rem;
  text-align: left;
}
.menu-drawer .navigation-controls a {
  display: block;
  padding-top: 1rem;
  padding-bottom: 1rem;
  padding-left: 4rem;
  color: inherit !important;
  text-decoration: none;
}
.menu-drawer .navigation-controls a::before {
  width: 26px;
  height: 26px;
  position: absolute;
  left: 1.5rem;
  content: "";
  background-image: url(../img/chevron-right-thin.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  transition: all 0.1s ease-in;
  transform: rotate(180deg);
}
.menu-drawer .menu-container {
  max-width: none;
  width: 100%;
  transition: all 0.25s ease-in-out;
}
.menu-drawer .menu-container ul {
  list-style: none;
  margin-left: 0;
  padding-left: 0;
}
.menu-drawer .menu-container li {
  position: static;
  padding-left: 15px;
  padding-right: 15px;
}
.menu-drawer .menu-container li.active > a {
  color: var(--primary);
  font-weight: bold;
}
.menu-drawer .menu-container li::before {
  content: none !important;
}
.menu-drawer .menu-container a {
  display: block;
  border-bottom: 1px solid var(--surface-sunken);
  color: var(--ink);
  padding: 1rem;
  text-align: left;
  text-decoration: none;
}
.menu-drawer .menu-container a:hover {
  text-decoration: none;
}
.menu-drawer .menu-container .navigation {
  margin-bottom: 1rem;
  display: block;
}
.menu-drawer .menu-container .navigation ul {
  display: none;
  position: static;
  width: 100%;
  box-shadow: none;
  border: 0;
}
.menu-drawer .menu-container .navigation ul ul {
  background-color: transparent;
}
.menu-drawer .menu-container .navigation ul li {
  position: static;
}
.menu-drawer .menu-container .navigation ul li::before {
  content: none !important;
}
.menu-drawer .menu-container .navigation .expanded > ul {
  display: block;
  position: absolute;
  top: 0;
  left: 100%;
}
.menu-drawer .menu-item-has-children > a {
  display: flex;
  align-items: center;
  gap: 20px;
  justify-content: space-between;
  position: relative;
}
.menu-drawer .menu-item-has-children > a::after {
  content: "";
  display: inline-block;
  width: 0.8rem;
  height: 0.8rem;
  background-color: var(--primary);
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m9%2018%206-6-6-6'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m9%2018%206-6-6-6'/%3E%3C/svg%3E") no-repeat center/contain;
  margin-left: 5px;
  flex-shrink: 0;
}
.menu-drawer .menu-item-has-children li:not(.menu-header) {
  padding-left: 2rem;
}
.menu-drawer .menu-header {
  border-bottom: 1px solid var(--border-strong);
}
.menu-drawer .menu-header a {
  border-bottom: none;
  color: var(--primary);
  font-weight: bold;
}

body.menu-drawer-toggled {
  overflow-y: hidden;
}

/* Accordion
--------------------------------------------- */
.accordion__container {
  background-color: var(--surface);
  border: 1px dashed var(--border);
  border-radius: 20px 0;
  margin-bottom: 1rem;
}
.accordion__heading {
  margin-bottom: 0;
}
.accordion__trigger {
  background: none;
  color: var(--ink-strong);
  font-size: 1.125rem;
  outline: none;
  padding: 30px 60px 30px 30px;
  position: relative;
  text-align: left;
  text-transform: none;
  transition: 0.4s;
  width: 100%;
  border-radius: 20px 0;
}
.accordion__trigger:hover, .accordion__trigger:active, .accordion__trigger:focus {
  background-color: var(--surface-sunken) !important;
  color: var(--ink-strong) !important;
  outline: 1px dashed Highlight;
}
.accordion__title {
  display: flex;
  align-items: center;
}
.accordion__title::before {
  content: "";
  display: block;
  background-color: var(--primary);
  border-radius: 50%;
  width: 12px;
  height: 12px;
  margin-right: 12px;
  flex-shrink: 0;
}
.accordion__icon {
  display: flex;
  align-items: center;
  color: var(--primary);
  border: 1px solid var(--primary);
  border-radius: 50%;
  height: 34px;
  justify-content: center;
  pointer-events: none;
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%) rotate(0);
  transition: transform 0.3s;
  width: 34px;
}
.accordion__trigger.expanded .accordion__icon {
  transform: translateY(-50%) rotate(-180deg);
}
.accordion__panel {
  max-height: 0;
  overflow: hidden;
  padding: 0 30px;
  transition: max-height 0.4s ease-out;
}

/* Advanced Search
--------------------------------------------- */
#advanced-search {
  max-width: 840px;
  margin-left: auto;
  margin-right: auto;
  margin-top: 25px;
  overflow: auto;
}
#advanced-search::after {
  content: "";
  clear: both;
  display: table;
}
#advanced-search input,
#advanced-search select {
  margin-bottom: 8px !important;
}
#advanced-search .field-meta {
  margin: 0.25rem 0;
}
#advanced-search button[type=submit] {
  float: right;
}
#advanced-search .advanced-search-content {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 25px;
  margin-bottom: 25px;
}
@media (min-width: 1024px) {
  #advanced-search .advanced-search-content {
    position: relative;
    z-index: 1;
  }
}
#advanced-search .advanced-search-content > div {
  flex-basis: 100%;
}
.items.search #advanced-search {
  overflow: initial;
}
.items.search #advanced-search::after {
  content: none;
}
@media (min-width: 1024px) {
  .items.search #advanced-search .advanced-search-content {
    margin-bottom: -105px;
  }
}
#advanced-search fieldset {
  margin-bottom: 0;
}
#advanced-search fieldset .field-meta {
  margin: 0;
}
#advanced-search .field {
  margin-bottom: 0;
}
#advanced-search .field.multi-value .field-meta {
  margin-bottom: 1rem;
}
#advanced-search .field.multi-value .value {
  align-items: center;
  flex-wrap: wrap !important;
  gap: 15px;
}
#advanced-search .field.multi-value .value:first-child .logical-operator:first-child {
  display: none;
}
#advanced-search .field.multi-value .value:only-child .sub-field:last-of-type,
#advanced-search .field.multi-value .value:only-child .sub-label:last-of-type {
  margin-right: 0;
}
#advanced-search .field.multi-value .sub-field,
#advanced-search .field.multi-value .sub-label {
  flex: 1 0 100%;
}
@media (min-width: 768px) {
  #advanced-search .field.multi-value .sub-field,
  #advanced-search .field.multi-value .sub-label {
    flex: 1 1 100px;
    margin-right: 0;
    max-width: 100%;
    min-width: 100px;
  }
}
#advanced-search .field.multi-value .sub-field:last-of-type,
#advanced-search .field.multi-value .sub-label:last-of-type {
  flex: 1 1 100px;
  max-width: 100%;
  min-width: 100px;
}
#advanced-search .field.multi-value .sub-field.logical-operator,
#advanced-search .field.multi-value .sub-label.logical-operator {
  flex-basis: 100%;
}
#advanced-search .field.multi-value button.remove-value {
  margin: 6px 0 0;
}
@media (min-width: 768px) {
  #advanced-search .field.multi-value#item-sets .value .sub-label:first-child {
    max-width: 110px;
  }
}
#advanced-search .field:not(.multi-value) .inputs {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
}
#advanced-search .field:not(.multi-value) .inputs > * {
  flex: 1 0 100%;
}
@media (min-width: 768px) {
  #advanced-search .field:not(.multi-value) .inputs > * {
    flex: 1 1 100px;
    margin-right: 15px;
    max-width: 100%;
    min-width: 100px;
  }
}
@media (min-width: 768px) {
  #advanced-search .field:not(.multi-value) .inputs > *:last-child {
    margin-right: 0;
  }
}
#advanced-search .field:not(.multi-value) .inputs select[name*=sort] {
  width: 100%;
}
@media (min-width: 768px) {
  #advanced-search .field:not(.multi-value) .inputs .numeric-timestamp {
    flex: 1 1 350px !important;
  }
}
#advanced-search .field:not(.multi-value) .inputs .numeric-timestamp > .numeric-datetime-inputs {
  flex-wrap: wrap;
}
#advanced-search .field:not(.multi-value) .inputs .numeric-timestamp > .numeric-datetime-inputs input:not([type=checkbox]) {
  width: 8em;
}
@media (min-width: 768px) {
  #advanced-search .field:not(.multi-value) .inputs .numeric-duration {
    flex: 1 1 330px !important;
  }
}
#advanced-search .field .numeric-datetime-inputs div {
  margin-top: 0 !important;
}
#advanced-search .field .numeric-date-inputs > * {
  flex-grow: 0;
}
#advanced-search .field .numeric-date-inputs,
#advanced-search .field .numeric-time-inputs {
  gap: 4px;
}
#advanced-search .field .numeric-toggle-time {
  align-self: center;
  background-color: var(--surface);
  color: var(--primary);
  cursor: pointer;
  height: 35px;
  margin: 0.5rem 0 0 0.3rem;
  padding: 5px 9px;
}
#advanced-search .field .numeric-toggle-time:hover, #advanced-search .field .numeric-toggle-time:focus-within {
  background-color: var(--primary);
  color: var(--surface);
}
#advanced-search .field .numeric-toggle-time input[type=checkbox] {
  margin: 0 !important;
}
#advanced-search .field .numeric-toggle-time input[type=checkbox]:focus {
  outline: none;
}
@media (min-width: 768px) {
  #advanced-search .half {
    flex-basis: calc(50% - 12.5px) !important;
  }
}
#advanced-search #property-queries .input-group {
  gap: initial;
  position: relative;
}
#advanced-search #property-queries .input-group > * {
  margin-right: 15px;
}
#advanced-search #property-queries .input-group > *:last-child {
  margin-right: 0;
}
#advanced-search #property-queries .input-group .joiner {
  flex: 0 0 100px;
  width: 100px !important;
}
#advanced-search #property-queries .input-group .flex-break {
  flex-basis: 100%;
  height: 0;
}
#advanced-search #property-queries .input-group .sub-field {
  margin-top: 20px;
}
#advanced-search #property-queries .input-group .sub-label {
  opacity: 0;
  position: absolute;
  top: 0;
}
#advanced-search #page-actions {
  display: flex;
  background-color: var(--secondary);
  bottom: 0;
  gap: 20px;
  justify-content: center;
  margin-left: calc((100vw - 100%) / -2);
  padding: 25px;
  position: sticky;
  width: 100vw;
}
@media (min-width: 1024px) {
  #advanced-search #page-actions {
    align-items: flex-end;
    background-color: transparent;
    bottom: 15px;
    flex-direction: column;
    gap: 15px;
    justify-content: initial;
    margin-left: 0;
    margin-right: -140px;
    padding: 0;
    width: auto;
  }
}
#advanced-search #page-actions > * {
  margin-bottom: 0 !important;
  padding: 10px;
  text-align: center;
  width: 120px;
}
#advanced-search #mapping-geographic-location .inputs label {
  font-size: 0.9375rem;
}

.search-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 2rem;
}
.search-filters .filter {
  display: flex;
  background-color: var(--secondary);
  border-radius: 3px;
  color: var(--surface);
  gap: 0;
  padding: 2px 10px;
}
.search-filters .filter-label::after {
  content: ":";
}
.search-filters .filter-value {
  margin: 0;
  padding: 0 10px;
}
.search-filters .filter-value:not(:last-child) {
  border-right: 1px solid color-mix(in oklab, var(--primary-contrast) 45%, transparent);
}

/* Annotation
--------------------------------------------- */
.annotation-btn {
  display: inline-block;
  padding: 0 5px;
  position: relative;
}
.annotation-btn:hover .annotation-tooltip {
  height: auto;
  opacity: 1;
  padding: 18px;
}
.annotation-btn .has-annotation {
  color: var(--link);
}
.annotation-btn .annotation-tooltip {
  height: 0;
  opacity: 0;
  overflow: hidden;
  position: absolute;
  left: 0;
  bottom: 10px;
  transition: opacity 0.3s ease-out;
  z-index: 10;
}
@media (min-width: 1024px) {
  .annotation-btn .annotation-tooltip {
    bottom: 5px;
  }
}
.annotation-btn .annotation-tooltip__wrapper {
  background-color: var(--surface);
  border: 1px dashed var(--border);
  border-radius: 10px 10px 10px 0;
  font-size: 0.8125rem;
  width: 230px;
  height: auto;
  padding: 15px 15px 30px;
}
@media (min-width: 1024px) {
  .annotation-btn .annotation-tooltip__wrapper {
    padding: 15px;
  }
}
.annotation-btn .annotation-tooltip__wrapper.below-button {
  border-radius: 0 10px 10px 10px;
}
.annotation-btn .annotation-tooltip__heading {
  font-size: 0.9375rem;
}
.annotation-btn .annotation-tooltip .property:not(:last-child) {
  margin-bottom: 1rem;
}
.annotation-btn .annotation-tooltip dt {
  float: left;
  font-size: 0.8125rem;
  margin-bottom: 0.5rem;
  padding-right: 10px;
  width: 70px !important;
}
.annotation-btn .annotation-tooltip dd {
  font-size: 0.8125rem;
  margin: 0;
  margin-left: 70px !important;
}
.annotation-btn .annotation-tooltip dd.resource.media img {
  display: block;
  max-width: 80px;
  border-radius: 10px 0 !important;
}

/* Banner
--------------------------------------------- */
.site-banner {
  position: relative;
  isolation: isolate;
  overflow: clip;
  background-color: var(--surface);
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--space-8);
}

.site-banner__art {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background-image: linear-gradient(108deg, color-mix(in oklab, var(--brand-green) 58%, var(--surface)) 0%, color-mix(in oklab, var(--brand-gold) 70%, var(--surface)) 52%, color-mix(in oklab, var(--brand-braun) 60%, var(--surface)) 100%);
}
.site-banner__art::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: linear-gradient(90deg, color-mix(in oklab, var(--surface) 80%, transparent) 0%, transparent 62%);
}

.site-banner__inner {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
}

.site-banner__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.site-banner__content > * {
  margin: 0;
}

.site-banner__eyebrow {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--primary-text);
}

.site-banner__title {
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--ink-strong);
  letter-spacing: var(--tracking-tight);
  line-height: 1.08;
  text-wrap: balance;
}

.site-banner__tagline {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  line-height: 1.5;
  color: var(--ink-light);
  max-width: var(--measure-narrow);
  text-wrap: pretty;
}

.site-banner__cta {
  align-self: flex-start;
  margin-top: var(--space-2);
}

.site-banner--home .site-banner__inner {
  min-height: clamp(20rem, 40vh, 28.75rem);
  padding-block: var(--space-12);
}
.site-banner--home .site-banner__content {
  gap: var(--space-5);
  max-width: min(46rem, 100%);
}
.site-banner--home .site-banner__title {
  font-size: var(--text-4xl);
}

.site-banner--page {
  margin-bottom: var(--space-6);
}
.site-banner--page .site-banner__inner {
  min-height: clamp(5.5rem, 14vh, 8rem);
  padding-block: var(--space-5);
}
.site-banner--page .site-banner__title {
  font-size: var(--text-2xl);
  line-height: 1.15;
  max-width: min(42rem, 72%);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

body[data-theme=dark] .site-banner__art {
  background-image: linear-gradient(108deg, color-mix(in oklab, var(--brand-green) 32%, var(--surface)) 0%, color-mix(in oklab, var(--brand-gold) 28%, var(--surface)) 52%, color-mix(in oklab, var(--brand-braun) 32%, var(--surface)) 100%);
}

@media (prefers-color-scheme: dark) {
  body:not([data-theme=light]) .site-banner__art {
    background-image: linear-gradient(108deg, color-mix(in oklab, var(--brand-green) 32%, var(--surface)) 0%, color-mix(in oklab, var(--brand-gold) 28%, var(--surface)) 52%, color-mix(in oklab, var(--brand-braun) 32%, var(--surface)) 100%);
  }
}
@media (max-width: 767px) {
  .site-banner--home .site-banner__inner {
    min-height: clamp(7rem, 24vh, 11rem);
    padding-block: var(--space-8);
  }
  .site-banner--home .site-banner__title {
    font-size: var(--text-3xl);
  }
  .site-banner--page .site-banner__title {
    max-width: 86%;
  }
}
/* Breadcrumbs
--------------------------------------------- */
.breadcrumbs {
  display: inline-block;
  background-color: var(--surface-sunken);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-full);
  color: var(--ink-light);
  font-size: 0.9375rem;
  padding: var(--space-2) var(--space-4);
  width: auto;
  margin-bottom: var(--space-4);
}

/* Linked Resources
--------------------------------------------- */
.resources-linked {
  display: block;
}
.resources-linked__head {
  list-style: none;
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  cursor: pointer;
  border-bottom: 1px solid var(--border);
}
.resources-linked__head::-webkit-details-marker {
  display: none;
}
.resources-linked__head:hover .resources-linked__heading {
  color: var(--primary-text);
}
.resources-linked__head:focus-visible {
  outline: 2px solid var(--focus-color);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}
.resources-linked__headwrap {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: var(--space-2) var(--space-3);
}
.resources-linked__heading {
  margin: 0;
  transition: color var(--transition-fast);
}
.resources-linked__summary {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--ink-light);
}
.resources-linked__summary b {
  color: var(--ink);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.resources-linked__chevron {
  flex-shrink: 0;
  margin-left: auto;
  width: 0.6rem;
  height: 0.6rem;
  border-right: 2px solid var(--ink-light);
  border-bottom: 2px solid var(--ink-light);
  transform: translateY(-2px) rotate(45deg);
  transition: transform var(--transition-base), border-color var(--transition-fast);
}
.resources-linked__head:hover .resources-linked__chevron {
  border-color: var(--primary);
}
.resources-linked[open] .resources-linked__chevron {
  transform: translateY(1px) rotate(225deg);
}
.resources-linked__panel {
  padding-top: var(--space-5);
}
.resources-linked__types {
  display: inline-flex;
  gap: var(--space-1);
  margin-bottom: var(--space-4);
  padding: var(--space-1);
  background-color: var(--surface-sunken);
  border-radius: var(--radius-full);
}
.resources-linked__controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-3) var(--space-4);
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--border);
}
.resources-linked__search {
  position: relative;
  flex: 0 1 18rem;
  min-width: 0;
  display: flex;
  align-items: center;
}
.resources-linked__search .lr-search__icon {
  position: absolute;
  left: 0.8rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1rem;
  height: 1rem;
  color: var(--ink-subtle);
  pointer-events: none;
}
.resources-linked__search .lr-search__input {
  width: 100%;
  height: auto;
  margin: 0;
  padding: 0.4rem 0.9rem 0.4rem 2.3rem;
  font-size: var(--text-sm);
  line-height: 1.2;
  color: var(--ink);
  background-color: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-full);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.resources-linked__search .lr-search__input::-moz-placeholder {
  color: var(--ink-subtle);
}
.resources-linked__search .lr-search__input::placeholder {
  color: var(--ink-subtle);
}
.resources-linked__search .lr-search__input:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: var(--ring-focus);
}
.resources-linked__facets {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin: 0;
  padding: 0;
}
.resources-linked__sort {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  flex-shrink: 0;
  margin-left: auto;
}
.resources-linked__sort-label {
  color: var(--ink-light);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  white-space: nowrap;
}
.resources-linked__sort select {
  width: auto;
  min-width: 9.5rem;
  height: auto;
  margin-bottom: 0;
  padding: 0.4rem 2rem 0.4rem 0.9rem;
  font-size: var(--text-sm);
  line-height: 1.2;
  border-color: var(--border);
  border-radius: var(--radius-full);
  background-position: calc(100% - 0.7rem) center;
  background-size: 14px;
}

.lr-type {
  padding: 0.35rem 0.95rem;
  border-radius: var(--radius-full);
  color: var(--ink-light);
  font-size: var(--text-sm);
  font-weight: 500;
  text-decoration: none;
  transition: color var(--transition-fast), background-color var(--transition-fast);
}
.lr-type:hover {
  color: var(--ink);
}
.lr-type[aria-current=true] {
  background-color: var(--surface);
  color: var(--ink-strong);
  box-shadow: var(--shadow-xs);
}
.lr-type:focus-visible {
  outline: none;
  box-shadow: var(--ring-focus);
}

.lr-facet {
  display: inline-flex;
  align-items: baseline;
  gap: 0.5rem;
  padding: 0.4rem 0.85rem;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 500;
  line-height: 1.2;
  color: var(--ink);
  background-color: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: background-color var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast);
}
.lr-facet:hover {
  background-color: var(--surface-raised);
  border-color: var(--border-strong);
}
.lr-facet:focus-visible {
  outline: none;
  box-shadow: var(--ring-focus);
}
.lr-facet__count {
  color: var(--ink-subtle);
  font-size: var(--text-xs);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.lr-facet.is-active {
  background-color: var(--primary);
  border-color: var(--primary);
  color: var(--primary-contrast);
}
.lr-facet.is-active .lr-facet__count {
  color: var(--primary-contrast);
  opacity: 0.78;
}

.connections {
  list-style: none;
  margin: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 19rem), 1fr));
  gap: var(--space-8) var(--space-4);
  max-height: clamp(28rem, 62vh, 44rem);
  overflow-y: auto;
  overscroll-behavior: contain;
  padding: var(--space-2) var(--space-1);
  scrollbar-width: thin;
  scrollbar-color: var(--border-strong) transparent;
}
.connections::-webkit-scrollbar {
  width: 0.875rem;
}
.connections::-webkit-scrollbar-track {
  background: transparent;
}
.connections::-webkit-scrollbar-thumb {
  background-color: var(--border-strong);
  background-clip: padding-box;
  border: 0.3rem solid transparent;
  border-radius: var(--radius-full);
}
.connections::-webkit-scrollbar-thumb:hover {
  background-color: var(--ink-light);
}

.connection {
  margin: 0;
}
.connection::before {
  content: none !important;
}
.connection[hidden] {
  display: none;
}

.connection__card {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  height: 100%;
  padding: var(--space-3);
  background-color: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  text-decoration: none;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast), background-color var(--transition-fast);
}
.connection__card:hover {
  border-color: var(--border-strong);
  background-color: var(--surface-raised);
  box-shadow: var(--shadow-md);
}
.connection__card:focus-visible {
  outline: none;
  border-color: var(--primary);
  box-shadow: var(--ring-focus);
}

.connection__thumb {
  flex-shrink: 0;
  display: block;
  width: 3rem;
  height: 3rem;
  overflow: hidden;
  border-radius: var(--radius-md);
  background-color: var(--surface-sunken);
  box-shadow: inset 0 0 0 1px var(--border-light);
}
.connection__thumb img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.connection__body {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

.connection__title {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 600;
  line-height: 1.35;
  color: var(--ink-strong);
  transition: color var(--transition-fast);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.connection__card:hover .connection__title {
  color: var(--primary-text);
}

.connection__meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.3rem 0.45rem;
  min-width: 0;
}

.connection__type {
  flex-shrink: 0;
  padding: 0.1rem 0.5rem;
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--ink);
  background-color: var(--surface-sunken);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-full);
}

.connection__rel {
  color: var(--ink-light);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: var(--tracking-wide);
  line-height: 1.3;
  text-transform: uppercase;
}

.connections__empty {
  margin: 0;
  padding: var(--space-8) var(--space-6);
  text-align: center;
  color: var(--ink-light);
  font-size: var(--text-sm);
  background-color: var(--surface-sunken);
  border-radius: var(--radius-lg);
}

.resources-linked .linked-footer {
  margin-top: var(--space-6);
}

@media (max-width: 600px) {
  .resources-linked__search {
    flex-basis: 100%;
    max-width: none;
  }
  .resources-linked__search .lr-search__input {
    font-size: 1rem;
    padding-block: 0.6rem;
  }
  .resources-linked__sort {
    width: 100%;
    margin-left: 0;
  }
  .resources-linked__sort select {
    flex: 1 1 auto;
  }
}
/* Local Contexts
--------------------------------------------- */
#local-contexts-content {
  width: 100%;
  max-width: 1440px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 15px;
  position: relative;
}
@media (min-width: 768px) {
  #local-contexts-content {
    padding: 0 30px;
  }
}
#local-contexts-content {
  margin-bottom: 40px;
  padding-bottom: 2rem !important;
  padding-top: 2rem !important;
}
#local-contexts-content .local-contexts-notice {
  padding: 1rem;
}
#local-contexts-content .notice-name {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 10px;
}

/* Mapping
--------------------------------------------- */
.mapping-map .leaflet-popup-content {
  margin: 13px;
}
.mapping-map .mapping-marker-popup-heading {
  font-size: 1.1rem;
  margin-bottom: 0.8rem;
}
.mapping-map .mapping-marker-popup-content {
  display: flex;
  gap: 13px;
}
.mapping-map .mapping-marker-popup-content img {
  max-width: 100px;
  max-height: 100px;
}

/* Metadata
--------------------------------------------- */
.metadata {
  width: 100%;
}
@media (min-width: 768px) {
  .metadata {
    width: auto;
  }
}
.metadata > div:not(:last-child),
.metadata .media-render:not(:last-child) {
  margin-bottom: 2rem;
}
.metadata .media-render > * {
  max-width: 100%;
}
.metadata .media-embed {
  margin-bottom: 1rem;
}
.metadata dl {
  margin-top: 0;
  margin-bottom: 2rem;
}
.metadata dl:last-child {
  margin-bottom: 0;
}
.metadata dl > .property {
  margin-bottom: 1.25rem;
}
.metadata dl > .property::after {
  content: "";
  display: table;
  clear: both;
}
.metadata dl > .property dt {
  line-height: 1.2;
  margin-bottom: 0.5rem;
  padding-right: 15px;
  word-wrap: break-word;
}
@media (min-width: 768px) {
  .metadata dl > .property dt:not(.sidebar-region .metadata dl > .property dt) {
    margin-bottom: 0;
    float: left;
    width: 170px;
  }
}
.metadata dl > .property dt .field-term {
  font-size: 0.9375rem;
  font-weight: 500;
}
.metadata dl > .property dd {
  margin: 0 0 1rem;
  word-break: break-word;
  overflow-wrap: anywhere;
  white-space: normal;
  align-items: flex-start;
}
@media (min-width: 768px) {
  .metadata dl > .property dd:not(.sidebar-region .metadata dl > .property dd) {
    margin-left: 170px;
  }
}
.metadata dl > .property dd:last-child {
  margin-bottom: 0;
}
.metadata dl > .property .language {
  margin-right: 5px;
}
.metadata .value.resource .resource-link {
  display: inline-flex;
  align-items: center;
}
.metadata .value.resource img {
  flex-shrink: 0;
  height: 60px;
  width: auto;
  max-width: 100%;
  margin-right: 1rem;
  -o-object-fit: contain;
     object-fit: contain;
}
.metadata .media-list dd {
  margin-bottom: 1rem !important;
}
.metadata .media-list dd:last-child {
  margin-bottom: 0 !important;
}
.metadata .media-list .resource-link {
  display: flex;
  align-items: center;
}
.metadata .media-list .resource-link img {
  flex-shrink: 0;
  height: 100px;
  -o-object-fit: cover;
     object-fit: cover;
  width: 100px;
}
.metadata .media-list .resource-link .resource-name {
  padding: 1rem;
}

/* Blocks
--------------------------------------------- */
/* Assets
--------------------------------------------- */
.assets,
.block-asset {
  margin-bottom: 3rem;
}
.assets.inline .assets,
.block-asset.inline .assets {
  display: flex;
  flex-direction: column;
  gap: 40px;
}
@media (min-width: 768px) {
  .assets.inline .assets,
  .block-asset.inline .assets {
    flex-direction: row;
  }
}

/* Browse Preview
--------------------------------------------- */
.preview-block {
  margin: 1rem 0 4rem !important;
  overflow: visible !important;
}
.preview-block .browse-all {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  border-radius: var(--radius-md);
  cursor: pointer;
  padding: 0.7rem 1.4rem;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.9375rem;
  line-height: 1.2;
  letter-spacing: 0.005em;
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base), color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-fast);
  background-color: transparent;
  border: 1px solid var(--border-strong);
  color: var(--primary-text);
}
.preview-block .browse-all:hover:not(.disabled):not(:disabled) {
  background-color: var(--primary-muted);
  border-color: var(--primary);
  color: var(--primary-text);
}
.preview-block .browse-all:active:not(.disabled):not(:disabled) {
  background-color: color-mix(in oklab, var(--primary-muted), var(--primary) 10%);
}
.preview-block .browse-all:focus-visible {
  outline: 2px solid var(--focus-color);
  outline-offset: 2px;
}
.preview-block .browse-all:disabled, .preview-block .browse-all[disabled], .preview-block .browse-all.disabled {
  border-color: var(--border);
  color: var(--muted);
  cursor: default;
}
.preview-block .browse-all:visited {
  color: var(--primary-text);
}
.preview-block .browse-all {
  float: right;
}

/* Carousel
--------------------------------------------- */
.carousel-block {
  padding-left: 45px;
  padding-right: 45px;
}
.carousel-block .slick-arrow {
  border: 1px solid var(--border);
  border-radius: 50%;
  height: 40px;
  width: 40px;
}
.carousel-block .slick-arrow:hover .slick-prev-icon::before,
.carousel-block .slick-arrow:hover .slick-next-icon::before {
  background-color: var(--surface);
}
.carousel-block .slick-arrow.slick-next {
  padding-left: 3px;
  right: -45px;
}
.carousel-block .slick-arrow.slick-prev {
  padding-right: 3px;
  left: -45px;
}
.carousel-block .slick-arrow .slick-prev-icon::before,
.carousel-block .slick-arrow .slick-next-icon::before {
  content: "";
  display: inline-block;
  width: 22px;
  height: 22px;
  background-color: var(--primary);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
  transition: background-color 0.3s ease;
}
.carousel-block .slick-arrow .slick-prev-icon::before {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m15%2018-6-6%206-6'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m15%2018-6-6%206-6'/%3E%3C/svg%3E");
}
.carousel-block .slick-arrow .slick-next-icon::before {
  -webkit-mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m9%2018%206-6-6-6'/%3E%3C/svg%3E");
  mask-image: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m9%2018%206-6-6-6'/%3E%3C/svg%3E");
}
.carousel-block .slick-dots button:hover {
  background-color: transparent;
}

/* Collecting
--------------------------------------------- */
.collecting-block-form {
  max-width: 840px;
  margin-left: auto;
  margin-right: auto;
  margin-top: 25px;
}
.collecting-block-form form {
  margin-bottom: 25px;
}
.collecting-block-form form::after {
  content: "";
  clear: both;
  display: table;
}
.collecting-block-form form .field {
  box-shadow: none;
}
.collecting-block-form form input[type=submit] {
  float: right;
}

/* Item With metadata
--------------------------------------------- */
.item-with-metadata {
  overflow: initial !important;
  margin-bottom: 3rem !important;
}
.item-with-metadata__container {
  border: 1px dashed var(--border);
  border-radius: 20px 0;
  margin-bottom: 1.5rem;
}
.item-with-metadata__header {
  padding: 30px;
  position: relative;
  width: 100%;
}
.item-with-metadata__header .language {
  margin-left: 10px;
}
.item-with-metadata__heading {
  display: flex;
  gap: 10px;
  margin-bottom: 0;
}
.item-with-metadata__heading::before {
  display: block;
  align-self: stretch;
  content: "";
  background-color: var(--primary);
  width: 8px;
  border-radius: 5px 0 0 5px;
  flex-shrink: 0;
}
.item-with-metadata__content {
  display: flex;
  align-items: center;
  border-top: none;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 40px;
  padding: 20px;
}
@media (min-width: 768px) {
  .item-with-metadata__content {
    align-items: flex-start;
    flex-direction: row;
    flex-wrap: nowrap;
    padding: 30px;
  }
}
.item-with-metadata__thumbnail {
  flex-shrink: 0;
  height: auto;
  max-width: 100%;
}
.item-with-metadata__thumbnail img {
  outline-offset: -10px;
}
@media (min-width: 768px) {
  .item-with-metadata__thumbnail {
    max-width: 150px;
  }
}
@media (min-width: 1024px) {
  .item-with-metadata__thumbnail {
    max-width: 250px;
  }
}
@media (min-width: 1200px) {
  .item-with-metadata__thumbnail {
    max-width: 370px;
  }
  .item-with-metadata__thumbnail img {
    outline-offset: -20px;
  }
}

/* Item Showcase
--------------------------------------------- */
.item-showcase {
  border-top: none !important;
  border-bottom: none !important;
  gap: 25px;
  text-align: left !important;
  margin-bottom: 3rem !important;
}
.item-showcase__content {
  padding: 15px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;
}
.item-showcase__media {
  display: block;
}
.item-showcase .resource.item {
  width: 100% !important;
  max-width: 325px;
  border: 1px dashed var(--border);
  border-radius: 20px 0;
  padding: 0 !important;
  display: flex;
  flex-direction: column;
}
.item-showcase .resource.item h3 {
  color: var(--ink-strong);
  font-family: var(--font-body);
  font-weight: 600;
  margin: 0 0 1rem !important;
  padding: 0 10px;
}
.item-showcase .resource.item .caption {
  padding: 0 10px 15px;
}
.item-showcase .resource.item img {
  max-height: none !important;
  height: 150px;
  width: 100% !important;
  -o-object-fit: cover;
     object-fit: cover;
  margin: 10px 0 0 10px;
}

/* Media Embed
--------------------------------------------- */
.media-embed.media-display-thumbnail {
  margin-bottom: 3rem;
}
.media-embed.media-display-thumbnail .item.resource {
  width: 100%;
  max-width: 325px;
}
.media-embed.media-display-thumbnail .item.resource h3 {
  color: var(--ink-strong);
  font-family: var(--font-body);
  font-weight: 600;
  margin: 1rem;
}
.media-embed.media-display-thumbnail .item.resource .caption {
  margin: 1rem;
}
.media-embed.media-display-thumbnail .item.resource img {
  max-height: none;
  height: 150px;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.media-embed.media-display-thumbnail .item.resource .decoration {
  width: 100%;
}
.media-embed.layout-horizontal {
  align-items: start !important;
}
.media-embed .decoration {
  width: 100%;
}
.media-embed .decoration .iiif_presentation {
  padding: 0 19px 19px 0;
}

.file {
  border-top: none !important;
  border-bottom: none !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}
.file .resource.item h3 {
  color: var(--ink-strong);
  font-weight: 600;
  padding: 0 10px;
  font-size: 1.25rem;
}
@media (max-width: 768px) {
  .file.left, .file.right {
    float: none !important;
    clear: none !important;
    max-width: none;
    margin: 0 !important;
  }
}
.file.left .item.resource img, .file.right .item.resource img {
  margin-bottom: 0;
}
.file.left .item.resource:first-of-type, .file.right .item.resource:first-of-type {
  padding-top: 0.6rem !important;
}
.file.left .item.resource {
  margin: 0 0.5rem 1rem 0 !important;
}
.file.right .item.resource {
  margin: 0 0 1rem 0.5rem !important;
}
.file.center {
  margin-bottom: 1.5rem !important;
}

/* Table of contents
--------------------------------------------- */
.toc-block > ul {
  border-left: none !important;
}
.toc-block > ul > li {
  margin-bottom: 2rem !important;
}
.toc-block > ul > li:before {
  content: "";
  display: inline-block;
  width: 0.75rem;
  height: 0.75rem;
  background-color: var(--primary);
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m9%2018%206-6-6-6'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m9%2018%206-6-6-6'/%3E%3C/svg%3E") no-repeat center/contain;
  margin-right: 15px;
  vertical-align: 0.02em;
}
.toc-block > ul > li > a {
  font-weight: 600 !important;
  font-size: 1.125rem;
  margin-bottom: 0.5rem;
  display: inline-block;
}
.toc-block > ul ul > li {
  margin-bottom: 0.3rem;
}
.toc-block > ul ul > li:before {
  content: "";
  display: inline-block;
  width: 0.4rem;
  height: 0.4rem;
  background-color: var(--primary);
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='%23000'%3E%3Ccircle%20cx='12'%20cy='12'%20r='10'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='%23000'%3E%3Ccircle%20cx='12'%20cy='12'%20r='10'/%3E%3C/svg%3E") no-repeat center/contain;
  margin-right: 15px;
  vertical-align: 0.25em;
}

/* List of sites
--------------------------------------------- */
.list-of-sites {
  margin-bottom: 3rem;
}
.list-of-sites .site {
  margin-bottom: 1.5rem !important;
}
.list-of-sites .site .site-thumbnail-image {
  margin-right: 1.5rem !important;
}

/* Timeline
--------------------------------------------- */
.tl-timeline .tl-slidenav-next:focus,
.tl-timeline .tl-slidenav-previous:focus {
  outline: none;
}
.tl-timeline .tl-timemarker .tl-timemarker-content-container .tl-timemarker-content .tl-timemarker-text h2.tl-headline,
.tl-timeline .tl-timemarker .tl-timemarker-content-container .tl-timemarker-content .tl-timemarker-text h2.tl-headline p {
  color: #6c6357;
}
.tl-timeline .tl-attribution a {
  color: #8c8377 !important;
}

/* Pagination
--------------------------------------------- */
.pagination {
  display: flex;
  align-items: center;
  border-bottom: 1px solid var(--border);
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
  gap: 1.5rem;
  justify-content: center;
  margin: 30px 0;
  padding: 30px 0;
  width: 100%;
}
.pagination .pager-wrapper {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  gap: 1rem;
}
@media (min-width: 600px) {
  .pagination .pager-wrapper {
    gap: 1.5rem;
  }
}
.pagination input[type=text] {
  display: inline-block;
  margin: 0 0 0 0.5rem !important;
  padding: 12px 10px;
  text-align: center;
  width: auto;
  border-radius: 15px;
}
@media (min-width: 600px) {
  .pagination input[type=text] {
    padding: 12px 30px;
    border-radius: 22px;
  }
}
.pagination input[type=submit] {
  padding: 12px 15px;
}
@media (min-width: 600px) {
  .pagination input[type=submit] {
    padding: 12px 30px;
  }
}
.pagination .row-count {
  color: var(--ink-light);
  font-size: 0.9375rem;
  margin-right: 1rem;
}
.pagination .pager label,
.pagination .pager .page-count {
  color: var(--ink-light);
  margin-right: 0.5rem;
}
.pagination .button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  border-radius: var(--radius-md);
  cursor: pointer;
  padding: 0.7rem 1.4rem;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.9375rem;
  line-height: 1.2;
  letter-spacing: 0.005em;
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base), color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-fast);
  background-color: transparent;
  border: 1px solid var(--border-strong);
  color: var(--primary-text);
}
.pagination .button:hover:not(.disabled):not(:disabled) {
  background-color: var(--primary-muted);
  border-color: var(--primary);
  color: var(--primary-text);
}
.pagination .button:active:not(.disabled):not(:disabled) {
  background-color: color-mix(in oklab, var(--primary-muted), var(--primary) 10%);
}
.pagination .button:focus-visible {
  outline: 2px solid var(--focus-color);
  outline-offset: 2px;
}
.pagination .button:disabled, .pagination .button[disabled], .pagination .button.disabled {
  border-color: var(--border);
  color: var(--muted);
  cursor: default;
}
.pagination .button:visited {
  color: var(--primary-text);
}
.pagination .button {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  font-size: 1.4rem;
  height: 40px;
  justify-content: center;
  padding: 0;
  position: relative;
  width: 40px;
}
.pagination .button:hover:not(.disabled)::before, .pagination .button:active:not(.disabled)::before {
  color: var(--secondary);
}
.pagination .button.disabled {
  border-color: var(--muted);
  color: var(--muted);
  cursor: default;
}

.site-page-pagination {
  display: flex;
  border-top: 1px solid var(--border);
  gap: 1rem;
  justify-content: center;
  margin: 30px 0;
  padding: 30px 0;
}
.site-page-pagination a {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  border-radius: var(--radius-md);
  cursor: pointer;
  padding: 0.7rem 1.4rem;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.9375rem;
  line-height: 1.2;
  letter-spacing: 0.005em;
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base), color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-fast);
  background-color: transparent;
  border: 1px solid var(--border-strong);
  color: var(--primary-text);
}
.site-page-pagination a:hover:not(.disabled):not(:disabled) {
  background-color: var(--primary-muted);
  border-color: var(--primary);
  color: var(--primary-text);
}
.site-page-pagination a:active:not(.disabled):not(:disabled) {
  background-color: color-mix(in oklab, var(--primary-muted), var(--primary) 10%);
}
.site-page-pagination a:focus-visible {
  outline: 2px solid var(--focus-color);
  outline-offset: 2px;
}
.site-page-pagination a:disabled, .site-page-pagination a[disabled], .site-page-pagination a.disabled {
  border-color: var(--border);
  color: var(--muted);
  cursor: default;
}
.site-page-pagination a:visited {
  color: var(--primary-text);
}
.site-page-pagination a {
  font-size: 0.8125rem;
  padding: 10px 14px;
}

/* Facets
--------------------------------------------- */
.faceted-browse-page #container,
.block-facetedBrowsePreview #container {
  flex-wrap: wrap;
}
@media (min-width: 1200px) {
  .faceted-browse-page #container,
  .block-facetedBrowsePreview #container {
    flex-wrap: nowrap;
    gap: 3rem;
  }
}
.faceted-browse-page #section-sidebar,
.block-facetedBrowsePreview #section-sidebar {
  width: 100%;
}
@media (min-width: 1200px) {
  .faceted-browse-page #section-sidebar,
  .block-facetedBrowsePreview #section-sidebar {
    width: 25%;
    z-index: auto !important;
  }
}
.faceted-browse-page #section-sidebar.open,
.block-facetedBrowsePreview #section-sidebar.open {
  z-index: 1050 !important;
}
.faceted-browse-page #section-sidebar-modal-toggle,
.block-facetedBrowsePreview #section-sidebar-modal-toggle {
  margin-bottom: 25px;
}
.faceted-browse-page #section-sidebar .field, .faceted-browse-page #section-sidebar fieldset,
.block-facetedBrowsePreview #section-sidebar .field,
.block-facetedBrowsePreview #section-sidebar fieldset {
  box-shadow: none;
  background-color: var(--surface-sunken);
}
.faceted-browse-page #section-sidebar button.close-button,
.block-facetedBrowsePreview #section-sidebar button.close-button {
  background-color: var(--primary);
}
.faceted-browse-page #section-content,
.block-facetedBrowsePreview #section-content {
  padding-left: 0;
  width: 100%;
}
@media (min-width: 1200px) {
  .faceted-browse-page #section-content,
  .block-facetedBrowsePreview #section-content {
    width: 75%;
  }
}
.faceted-browse-page #section-content .browse-controls,
.block-facetedBrowsePreview #section-content .browse-controls {
  border-bottom: none;
  margin-bottom: 0;
}
.faceted-browse-page #section-content .browse-controls .pagination,
.block-facetedBrowsePreview #section-content .browse-controls .pagination {
  margin-top: 0;
}
.faceted-browse-page .faceted-results img,
.block-facetedBrowsePreview .faceted-results img {
  border-radius: 10px 0;
  margin-right: 1rem;
  max-height: 3rem;
  max-width: 3rem;
}
.faceted-browse-page .faceted-results a,
.block-facetedBrowsePreview .faceted-results a {
  display: list-item;
  width: auto;
}
.faceted-browse-page #facets,
.block-facetedBrowsePreview #facets {
  margin-bottom: 1rem;
  overflow: hidden;
}
@media (min-width: 1200px) {
  .faceted-browse-page #facets,
  .block-facetedBrowsePreview #facets {
    height: auto;
    margin-bottom: 0;
    overflow: initial;
  }
}
.faceted-browse-page #facets.show-all,
.block-facetedBrowsePreview #facets.show-all {
  height: auto;
  overflow: initial;
}
.faceted-browse-page #facets legend,
.block-facetedBrowsePreview #facets legend {
  font-size: 1.25rem;
}
@media (min-width: 1200px) {
  .faceted-browse-page #show-more-facets,
  .block-facetedBrowsePreview #show-more-facets {
    display: none;
  }
}
.faceted-browse-page .select-list,
.block-facetedBrowsePreview .select-list {
  display: flex;
  flex-wrap: wrap;
  margin-left: 0 !important;
  width: 100%;
}
@media (min-width: 1200px) {
  .faceted-browse-page .select-list,
  .block-facetedBrowsePreview .select-list {
    display: block;
    margin-left: 1rem !important;
  }
}
.faceted-browse-page .select-list-item,
.block-facetedBrowsePreview .select-list-item {
  margin-left: 1rem;
}
@media (min-width: 1200px) {
  .faceted-browse-page .select-list-item,
  .block-facetedBrowsePreview .select-list-item {
    margin-left: 0;
  }
}
.faceted-browse-page .select-list-item::before,
.block-facetedBrowsePreview .select-list-item::before {
  content: none !important;
}
.faceted-browse-page .select-list-expand, .faceted-browse-page .select-list-collapse,
.block-facetedBrowsePreview .select-list-expand,
.block-facetedBrowsePreview .select-list-collapse {
  margin-left: 1rem;
}
.faceted-browse-page #categories,
.block-facetedBrowsePreview #categories {
  margin-top: 0;
}
.faceted-browse-page #categories li,
.block-facetedBrowsePreview #categories li {
  border-bottom: none;
}
.faceted-browse-page #categories li::before,
.block-facetedBrowsePreview #categories li::before {
  content: none !important;
}
.faceted-browse-page #categories-return,
.block-facetedBrowsePreview #categories-return {
  display: inline-block;
  margin-bottom: 33px;
}
.faceted-browse-page #categories-return::before,
.block-facetedBrowsePreview #categories-return::before {
  content: "";
  display: inline-block;
  width: 0.8rem;
  height: 0.8rem;
  background-color: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m15%2018-6-6%206-6'/%3E%3C/svg%3E") no-repeat center/contain;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%20fill='none'%20stroke='%23000'%20stroke-width='2.5'%20stroke-linecap='round'%20stroke-linejoin='round'%3E%3Cpath%20d='m15%2018-6-6%206-6'/%3E%3C/svg%3E") no-repeat center/contain;
  margin-right: 5px;
  vertical-align: -0.08em;
}
.faceted-browse-page .facets-container,
.block-facetedBrowsePreview .facets-container {
  align-items: flex-start;
  flex-direction: column;
}
.faceted-browse-page .categories-container,
.faceted-browse-page .facets-container,
.block-facetedBrowsePreview .categories-container,
.block-facetedBrowsePreview .facets-container {
  margin-bottom: 0;
  padding: 1rem 1.2rem 0;
}
.faceted-browse-page .categories-container legend,
.faceted-browse-page .facets-container legend,
.block-facetedBrowsePreview .categories-container legend,
.block-facetedBrowsePreview .facets-container legend {
  color: var(--ink-strong);
  font-weight: 400;
  line-height: 1.2;
}
.faceted-browse-page .categories-container legend,
.block-facetedBrowsePreview .categories-container legend {
  font-size: 1.5rem;
  margin-bottom: 1.1rem;
}
.faceted-browse-page .facets-container legend,
.block-facetedBrowsePreview .facets-container legend {
  font-size: 1.25rem;
  margin-bottom: 1rem;
}
.faceted-browse-page label input,
.block-facetedBrowsePreview label input {
  margin: 0 0.6rem 0 0 !important;
}
.faceted-browse-page .resource-name,
.block-facetedBrowsePreview .resource-name {
  font-weight: 500;
}
.faceted-browse-page .resource-list,
.block-facetedBrowsePreview .resource-list {
  padding-top: 5px;
}
.faceted-browse-page .resource-list .resource,
.block-facetedBrowsePreview .resource-list .resource {
  padding: 0 !important;
}
.faceted-browse-page .resource-list .resource-link,
.block-facetedBrowsePreview .resource-list .resource-link {
  width: 100%;
}
.faceted-browse-page .faceted-browse-table-wrapper,
.block-facetedBrowsePreview .faceted-browse-table-wrapper {
  overflow-x: auto;
  padding: 0 5px;
}
.faceted-browse-page table,
.block-facetedBrowsePreview table {
  border-collapse: collapse;
  border-spacing: 0 15px;
}
.faceted-browse-page table thead,
.block-facetedBrowsePreview table thead {
  background-color: var(--secondary);
  color: var(--surface);
}
.faceted-browse-page table thead th,
.block-facetedBrowsePreview table thead th {
  padding: 0.75rem;
  font-weight: 500;
  text-align: left;
}
.faceted-browse-page table tbody tr,
.block-facetedBrowsePreview table tbody tr {
  border-bottom: 1px dashed var(--border);
}
.faceted-browse-page table tbody tr:last-child,
.block-facetedBrowsePreview table tbody tr:last-child {
  border-bottom: none;
}
.faceted-browse-page table tbody tr td,
.block-facetedBrowsePreview table tbody tr td {
  padding: 0.75rem;
}
.faceted-browse-page table tbody tr td .resource-link,
.block-facetedBrowsePreview table tbody tr td .resource-link {
  display: flex;
  align-items: center;
}

/* Hierarchy
--------------------------------------------- */
.hierarchy-module .hierarchy-sidebar-content {
  padding-bottom: 50px;
}
@media (max-width: 768px) {
  .hierarchy-module .hierarchy-main-content {
    border-left: none;
    padding-left: 0;
  }
}
.hierarchy-module .hierarchy-itemset-metadata {
  padding: 15px;
  width: 100%;
}
.hierarchy-module .hierarchy-itemset-metadata .resource-link {
  display: flex;
  align-items: center;
  font-size: 1.2rem;
  width: 100%;
}
.hierarchy-module .hierarchy-itemset-metadata img {
  height: 100px;
  margin-left: auto;
  -o-object-fit: cover;
     object-fit: cover;
  order: 1;
  width: 100px;
}

/* Resources
--------------------------------------------- */
.browse-controls {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 1.5rem;
  justify-content: space-between;
  margin-bottom: 20px;
  padding-bottom: 20px;
}
.browse-controls input[type=text],
.browse-controls select {
  padding: 8px 15px;
  margin-bottom: 0;
}
.browse-controls select {
  min-width: 100px;
  padding-right: 45px;
  width: auto;
}
.browse-controls .layout-toggle {
  display: flex;
  gap: 20px;
}
.browse-controls .layout-toggle button {
  background: none;
  padding: 0;
  color: var(--primary);
  text-decoration: underline;
}
.browse-controls .layout-toggle button:hover, .browse-controls .layout-toggle button:active, .browse-controls .layout-toggle button:focus {
  outline: none;
}
.browse-controls .layout-toggle button:disabled, .browse-controls .layout-toggle button[disabled] .browse-controls .layout-toggle button.disabled {
  color: var(--muted);
  text-decoration: none;
}
.browse-controls .layout-toggle .layout-toggle-separator {
  border-left: 1px solid;
}
.browse-controls .sorting {
  display: flex;
  flex-wrap: nowrap;
  gap: 15px;
  margin-left: auto;
  max-width: 100%;
}
.browse-controls .sorting button {
  padding: 10px 30px;
}
.browse-controls .advanced-search-container {
  display: flex;
  justify-content: flex-end;
  width: 100%;
}
.browse-controls .advanced-search-container a {
  font-size: 0.9375rem;
}
.browse-controls .permalink {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  border-radius: var(--radius-md);
  cursor: pointer;
  padding: 0.7rem 1.4rem;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.9375rem;
  line-height: 1.2;
  letter-spacing: 0.005em;
  text-decoration: none;
  transition: background-color var(--transition-base), border-color var(--transition-base), color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-fast);
  background-color: transparent;
  border: 1px solid var(--border-strong);
  color: var(--primary-text);
}
.browse-controls .permalink:hover:not(.disabled):not(:disabled) {
  background-color: var(--primary-muted);
  border-color: var(--primary);
  color: var(--primary-text);
}
.browse-controls .permalink:active:not(.disabled):not(:disabled) {
  background-color: color-mix(in oklab, var(--primary-muted), var(--primary) 10%);
}
.browse-controls .permalink:focus-visible {
  outline: 2px solid var(--focus-color);
  outline-offset: 2px;
}
.browse-controls .permalink:disabled, .browse-controls .permalink[disabled], .browse-controls .permalink.disabled {
  border-color: var(--border);
  color: var(--muted);
  cursor: default;
}
.browse-controls .permalink:visited {
  color: var(--primary-text);
}
.browse-controls .permalink {
  padding: 10px 20px;
}

.resource-grid {
  opacity: 0;
  list-style: none;
  padding-left: 0;
  position: relative;
}
.resource-grid .grid-sizer,
.resource-grid .resource {
  width: 100%;
}
@media (min-width: 768px) {
  .resource-grid .grid-sizer,
  .resource-grid .resource {
    width: 49%;
  }
}
.resource-grid .gutter-sizer {
  width: 2%;
}
.resource-grid .resource {
  display: flex;
  flex-direction: column;
  background-color: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  position: absolute;
  margin-bottom: 24px;
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}
.resource-grid .resource::before {
  content: none !important;
}
.resource-grid .resource:hover {
  border-color: var(--border-strong);
  box-shadow: var(--shadow-md);
  transform: translateY(var(--lift-xs));
}
@media (min-width: 768px) {
  .resource-grid .resource {
    flex-direction: row;
  }
}
.resource-grid .resource__thumbnail {
  line-height: 1;
  width: 100%;
  margin: 10px 0 0 10px;
}
@media (min-width: 768px) {
  .resource-grid .resource__thumbnail {
    width: 50%;
    flex-shrink: 0;
    margin: 10px 0 -15px 10px;
  }
}
.resource-grid .resource__thumbnail img {
  max-height: 324px;
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
}
.resource-grid .resource__content {
  padding: 15px;
}
.resource-grid .resource__meta {
  padding: 5px 10px;
}

.resource-list {
  height: auto !important;
  list-style: none;
  padding-left: 0;
}
.resource-list .resource {
  display: flex;
  background-color: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  position: relative !important;
  left: auto !important;
  top: auto !important;
  width: 100% !important;
  margin-bottom: 16px;
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}
.resource-list .resource::before {
  content: none !important;
}
.resource-list .resource:hover {
  border-color: var(--border-strong);
  box-shadow: var(--shadow-md);
  transform: translateY(var(--lift-xs));
}
.resource-list .resource__thumbnail {
  flex-shrink: 0;
  line-height: 1;
  margin: 15px 15px 15px auto;
  order: 1;
}
.resource-list .resource__thumbnail img {
  height: 100px;
  -o-object-fit: cover;
     object-fit: cover;
  width: 100px;
}
.resource-list .resource__content {
  padding: 15px;
}
.resource-list .resource__meta {
  padding: 5px 10px;
}

/* Search Results
--------------------------------------------- */
body.search .results {
  max-width: 1160px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 40px;
}
body.search .results .resource__content {
  display: flex;
  align-items: center;
}

/* URI Dereferencer
--------------------------------------------- */
.uri-dereferencer-toggle, .uri-dereferencer-fetch {
  margin-left: 0.5rem;
}
.uri-dereferencer-markup {
  border: 1px solid var(--border);
  padding: 0.5rem 0.8rem;
  margin-top: 0.5rem;
}
.uri-dereferencer-fetch + .uri-dereferencer-toggle + .uri-dereferencer-markup {
  display: none;
}

/* User Bar
--------------------------------------------- */
#user-bar {
  gap: 15px;
}
#user-bar a {
  display: block;
}
@media (min-width: 1024px) {
  #user-bar a {
    display: initial;
  }
}
#user-bar .site-links {
  width: 60%;
}
#user-bar .site-links a {
  display: inline-block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  width: 100%;
}
@media (min-width: 1024px) {
  #user-bar .site-links a {
    overflow: initial;
    white-space: initial;
    width: auto;
  }
}
#user-bar .site-links .admin::after {
  content: none !important;
}
@media (min-width: 1024px) {
  #user-bar .site-links .admin::after {
    content: ">" !important;
  }
}
#user-bar .site-links .admin:last-child::after {
  content: none !important;
}
#user-bar .user-links {
  width: 40%;
  text-align: right;
}
#user-bar .user-links .logout {
  margin-left: 0;
  margin-top: 15px;
  padding: 6px 10px;
  text-decoration: none;
}
@media (min-width: 1024px) {
  #user-bar .user-links .logout {
    margin-left: 12px;
    margin-top: 0;
    padding: 0 6px;
  }
}

/* Footer
--------------------------------------------- */
.main-footer {
  background-color: var(--footer-surface);
  clear: both;
  color: var(--footer-text);
  font-size: 0.9375rem;
}
.main-footer.has-contact-info {
  margin-top: 40px;
}
.main-footer a {
  color: var(--footer-text);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}
.main-footer a:hover {
  color: color-mix(in oklab, var(--footer-text), white 25%);
}
.main-footer ::-moz-selection {
  background-color: var(--primary);
  color: var(--primary-contrast);
}
.main-footer ::selection {
  background-color: var(--primary);
  color: var(--primary-contrast);
}
.main-footer .footer-contact-info {
  margin-top: -40px;
}
.main-footer .footer-contact-info__content {
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: var(--space-4);
  padding: var(--space-6) var(--space-4) var(--space-3);
  box-shadow: var(--shadow-lg);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  z-index: 5;
  position: relative;
  background-color: var(--surface);
}
@media (min-width: 1024px) {
  .main-footer .footer-contact-info__content {
    flex-direction: row;
    justify-content: space-around;
  }
}
.main-footer .footer-contact-info__content h6,
.main-footer .footer-contact-info__content a {
  color: var(--ink-strong);
  text-decoration: none;
}
.main-footer .footer-contact-info__content .contact_info {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--ink);
}
.main-footer__inner {
  padding-block: clamp(var(--space-12), 6vw, var(--space-20));
}
.main-footer__masthead {
  display: grid;
  gap: var(--space-12);
  align-items: start;
}
@media (min-width: 1024px) {
  .main-footer__masthead {
    grid-template-columns: minmax(0, 1.5fr) auto;
    gap: var(--space-16);
  }
}
.main-footer__identity {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-width: 0;
}
.main-footer__brand {
  margin: 0;
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: var(--tracking-tight);
  color: var(--footer-text);
}
.main-footer__brand::after {
  content: "";
  display: block;
  width: 2.5rem;
  height: 2px;
  margin-top: var(--space-3);
  background-color: var(--primary);
  border-radius: var(--radius-full);
}
.main-footer__tagline {
  max-width: 46ch;
  margin-top: var(--space-5);
  color: var(--footer-text-muted);
  line-height: var(--line-height-relaxed);
}
.main-footer__tagline p {
  margin: 0;
}
.main-footer__tagline p + p {
  margin-top: var(--space-2);
}
.main-footer__social {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin: var(--space-8) 0 0;
  padding: 0;
  list-style: none;
}
.main-footer__social li {
  margin: 0;
}
.main-footer__social li::before {
  content: none !important;
}
.main-footer__social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--size-control-lg);
  height: var(--size-control-lg);
  color: var(--footer-text);
  border: 1px solid var(--footer-divider);
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: color var(--transition-fast), border-color var(--transition-fast), background-color var(--transition-fast), transform var(--transition-fast);
}
.main-footer__social a:hover {
  color: var(--primary-contrast);
  background-color: var(--primary);
  border-color: var(--primary);
  transform: translateY(var(--lift-xs));
}
.main-footer__social a:focus-visible {
  outline: 2px solid var(--focus-color);
  outline-offset: 2px;
}
.main-footer__social a svg {
  width: 18px;
  height: 18px;
}
@media (min-width: 1024px) {
  .main-footer__institutions {
    justify-self: end;
  }
}
.main-footer__institution-grid {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-4);
  list-style: none;
  margin: 0;
  padding: 0;
}
@media (min-width: 1024px) {
  .main-footer__institution-grid {
    justify-content: flex-end;
  }
}
.main-footer__institution-grid li::before {
  content: none !important;
}
.main-footer__institution {
  margin: 0;
}
.main-footer__institution a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: var(--white);
  border: 1px solid var(--border-light);
  border-radius: var(--radius-md);
  padding: var(--space-4) var(--space-5);
  box-shadow: var(--shadow-xs);
  text-decoration: none;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}
.main-footer__institution a:hover {
  transform: translateY(var(--lift-xs));
  box-shadow: var(--shadow-md);
}
.main-footer__institution a:focus-visible {
  outline: 2px solid var(--focus-color);
  outline-offset: 2px;
}
.main-footer__institution img {
  display: block;
  width: auto;
  height: 34px;
  max-width: 220px;
  -o-object-fit: contain;
     object-fit: contain;
}
@media (min-width: 768px) {
  .main-footer__institution img {
    height: 40px;
  }
}
.main-footer__bottom {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  margin-top: clamp(var(--space-10), 4vw, var(--space-16));
  padding-top: var(--space-6);
  border-top: 1px solid var(--footer-divider);
  color: var(--footer-text-muted);
  font-size: var(--text-xs);
}
@media (min-width: 768px) {
  .main-footer__bottom {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}
.main-footer__bottom a {
  color: var(--footer-text-muted);
}
.main-footer__bottom a:hover {
  color: color-mix(in oklab, var(--footer-text-muted), white 30%);
}
.main-footer__copyright a {
  text-decoration: underline;
  text-underline-offset: 0.15em;
}
.main-footer__meta {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
@media (min-width: 768px) {
  .main-footer__meta {
    align-items: flex-end;
  }
}
.main-footer__credit {
  margin: 0;
}
.main-footer__credit a {
  text-decoration: underline;
  text-underline-offset: 0.15em;
}
.main-footer__links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4) var(--space-6);
  margin: 0;
  padding: 0;
  list-style: none;
}
.main-footer__links li {
  margin: 0;
}
.main-footer__links li::before {
  content: none !important;
}
.main-footer__links a {
  text-decoration: none;
}
.main-footer__links a:hover {
  text-decoration: underline;
}

/* Back to top
--------------------------------------------- */
.back-to-top {
  position: fixed;
  right: clamp(1rem, 3vw, 2rem);
  bottom: clamp(1rem, 3vw, 2rem);
  z-index: var(--z-sticky);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--size-control-lg);
  height: var(--size-control-lg);
  padding: 0;
  color: var(--primary-contrast);
  background-color: var(--primary);
  border: 1px solid color-mix(in oklab, var(--primary), black 18%);
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-lg);
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  transform: translateY(0.75rem);
  transition: opacity var(--transition-base), transform var(--transition-base), visibility 0s linear var(--transition-base), background-color var(--transition-fast);
}
.back-to-top.is-visible {
  opacity: 1;
  visibility: visible;
  transform: none;
  transition: opacity var(--transition-base), transform var(--transition-base), background-color var(--transition-fast);
}
.back-to-top:hover {
  background-color: var(--primary-hover);
  box-shadow: var(--shadow-xl);
}
.back-to-top:focus-visible {
  outline: 2px solid var(--focus-color);
  outline-offset: 2px;
}
.back-to-top svg {
  display: block;
  width: 20px;
  height: 20px;
}
@media (prefers-reduced-motion: reduce) {
  .back-to-top {
    transform: none;
    transition: opacity var(--transition-base), visibility 0s linear var(--transition-base), background-color var(--transition-fast);
  }
  .back-to-top.is-visible {
    transform: none;
  }
}

/*--------------------------------------------------------------
# Utilities
--------------------------------------------------------------*/
/* Accessibility
--------------------------------------------- */
#skipnav {
  position: fixed;
  top: 1.6;
  left: 50%;
  border: 1px solid var(--border-strong);
  transform: translateX(-50%);
  z-index: -5;
  padding: 1rem;
  background-color: var(--surface);
  opacity: 0;
}
#skipnav:focus {
  z-index: 1000;
  opacity: 1;
}

/* Text meant only for screen readers. `.sr-only` / `.sr-only-focusable` mirror
   the Bootstrap class names the markup uses (e.g. the header lockup's visually-
   hidden site title, menu-toggle labels). They were previously supplied by
   Omeka core's `iconfonts.css`; the theme no longer loads that file, so they
   must be defined here — otherwise every visually-hidden label renders as
   visible text. */
.screen-reader-text,
.sr-only,
.sr-only-focusable {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
}

/* Reveal on focus — the skip link and any `.sr-only-focusable` control. Plain
   `.sr-only` (non-interactive labels) stays hidden. */
.screen-reader-text:focus,
.sr-only-focusable:focus {
  background-color: var(--border);
  border-radius: 3px;
  box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
  clip: auto !important;
  clip-path: none;
  color: var(--ink-light);
  display: block;
  font-size: 0.875rem;
  font-weight: 700;
  height: auto;
  left: 5px;
  line-height: normal;
  padding: 15px 23px 14px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000;
}

/* Alignments
--------------------------------------------- */
.alignleft {
  /*rtl:ignore*/
  float: left;
  /*rtl:ignore*/
  margin-right: 1.5rem;
  margin-bottom: 1.5rem;
}

.alignright {
  /*rtl:ignore*/
  float: right;
  /*rtl:ignore*/
  margin-left: 1.5rem;
  margin-bottom: 1.5rem;
}

.aligncenter {
  clear: both;
  display: block;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1.5em;
}

.alignfull {
  margin: 0 0 1.5rem;
  max-width: 100%;
}

.alignwide {
  margin: 0 calc(25% - 25vw) 1.5rem;
  max-width: 100vw;
}

.alignnarrow {
  display: block;
  margin-left: auto;
  margin-right: auto;
  max-width: 1024px;
  width: 100%;
}

.textleft {
  text-align: left;
}

.textright {
  text-align: right;
}

.textcenter {
  text-align: center;
}

/* Clearfix
--------------------------------------------- */
.clearfix::after {
  content: "";
  clear: both;
  display: table;
}

/* Visibility
--------------------------------------------- */
.d-none {
  display: none !important;
}

.d-inline {
  display: inline !important;
}

.d-inline-block {
  display: inline-block !important;
}

.d-block {
  display: block !important;
}

.d-flex {
  display: flex !important;
}

.d-inline-flex {
  display: inline-flex !important;
}

.d-grid {
  display: grid !important;
}

@media (min-width: 600px) {
  .d-sm-none {
    display: none !important;
  }
  .d-sm-inline {
    display: inline !important;
  }
  .d-sm-inline-block {
    display: inline-block !important;
  }
  .d-sm-block {
    display: block !important;
  }
  .d-sm-flex {
    display: flex !important;
  }
  .d-sm-inline-flex {
    display: inline-flex !important;
  }
  .d-sm-grid {
    display: grid !important;
  }
}
@media (min-width: 768px) {
  .d-md-none {
    display: none !important;
  }
  .d-md-inline {
    display: inline !important;
  }
  .d-md-inline-block {
    display: inline-block !important;
  }
  .d-md-block {
    display: block !important;
  }
  .d-md-flex {
    display: flex !important;
  }
  .d-md-inline-flex {
    display: inline-flex !important;
  }
  .d-md-grid {
    display: grid !important;
  }
}
@media (min-width: 1024px) {
  .d-lg-none {
    display: none !important;
  }
  .d-lg-inline {
    display: inline !important;
  }
  .d-lg-inline-block {
    display: inline-block !important;
  }
  .d-lg-block {
    display: block !important;
  }
  .d-lg-flex {
    display: flex !important;
  }
  .d-lg-inline-flex {
    display: inline-flex !important;
  }
  .d-lg-grid {
    display: grid !important;
  }
}
@media (min-width: 1200px) {
  .d-xl-none {
    display: none !important;
  }
  .d-xl-inline {
    display: inline !important;
  }
  .d-xl-inline-block {
    display: inline-block !important;
  }
  .d-xl-block {
    display: block !important;
  }
  .d-xl-flex {
    display: flex !important;
  }
  .d-xl-inline-flex {
    display: inline-flex !important;
  }
  .d-xl-grid {
    display: grid !important;
  }
}
@media (min-width: 1460px) {
  .d-xxl-none {
    display: none !important;
  }
  .d-xxl-inline {
    display: inline !important;
  }
  .d-xxl-inline-block {
    display: inline-block !important;
  }
  .d-xxl-block {
    display: block !important;
  }
  .d-xxl-flex {
    display: flex !important;
  }
  .d-xxl-inline-flex {
    display: inline-flex !important;
  }
  .d-xxl-grid {
    display: grid !important;
  }
}