@charset "utf-8";
@import url("font-awesome.css");

:root {
  /* Basic page palette: this is the main color block for custom adjustments. */
  --page-bg: #eef4fb;
  --page-ink: #182433;
  --muted-ink: #5a6d82;
  --page-gradient-start: #f4f8fd;
  --page-gradient-mid: #dde8f6;
  --page-gradient-end: #bed1e8;
  --panel-bg: rgba(247, 250, 255, 0.88);
  --panel-border: rgba(29, 95, 167, 0.14);
  --accent: #1d5fa7;
  --accent-dark: #123d6b;
  --accent-soft: #d9e7f7;
  --hero-deep: #10263b;
  --hero-mid: #1d4f83;
  --hero-warm: #5f97d1;
  --shadow-soft: 0 18px 50px rgba(20, 36, 60, 0.12);
  --shadow-card: 0 22px 60px rgba(20, 36, 60, 0.14);

  /* Theme surfaces: adjust these if you want to fine-tune the template look. */
  --hero-overlay-start: rgba(10, 24, 40, 0.9);
  --hero-overlay-end: rgba(24, 68, 112, 0.74);
  --header-orb-top: rgba(160, 205, 255, 0.11);
  --header-orb-bottom: rgba(84, 150, 225, 0.2);
  --utility-text: rgba(245, 250, 255, 0.94);
  --utility-link: #f5faff;
  --utility-link-hover: #ffffff;
  --utility-muted: rgba(220, 233, 247, 0.78);
  --brand-badge-bg: rgba(29, 95, 167, 0.08);
  --boxed-search-border: rgba(29, 95, 167, 0.16);
  --boxed-search-bg: rgba(247, 250, 255, 0.82);
  --search-border: rgba(255, 255, 255, 0.18);
  --search-bg: rgba(255, 255, 255, 0.12);
  --search-text: #f5faff;
  --search-placeholder: rgba(220, 233, 247, 0.78);
  --visual-header-bg: rgba(11, 25, 40, 0.96);
  --visual-utility-bg: rgba(14, 31, 50, 0.32);
  --floating-surface: rgba(14, 31, 50, 0.42);
  --floating-surface-strong: rgba(14, 31, 50, 0.62);
  --floating-border: rgba(255, 255, 255, 0.14);
  --floating-text: #f5faff;
  --hero-text: #f5faff;
  --hero-text-strong: #ffffff;
  --hero-text-soft: rgba(234, 243, 252, 0.9);
  --hero-text-muted: rgba(220, 233, 247, 0.78);
  --hero-note-surface: rgba(255, 255, 255, 0.12);
  --hero-note-label-bg: rgba(255, 255, 255, 0.16);
  --hero-note-text: #f5faff;
  --stat-card-surface: rgba(255, 255, 255, 0.08);
  --stat-card-text: #f5faff;
  --nav-bg: rgba(247, 250, 255, 0.92);
  --nav-toggle-bg: rgba(29, 95, 167, 0.08);
  --nav-active-bg: rgba(29, 95, 167, 0.14);
  --nav-active-ring: rgba(29, 95, 167, 0.12);
  --nav-dropdown-bg: rgba(247, 250, 255, 0.98);
  --nav-dropdown-border: rgba(29, 95, 167, 0.14);
  --nav-dropdown-shadow: 0 20px 36px rgba(20, 36, 60, 0.14);
  --nav-mega-item-bg: rgba(29, 95, 167, 0.04);
  --nav-tree-border: rgba(29, 95, 167, 0.12);
  --nav-tree-border-soft: rgba(29, 95, 167, 0.08);
  --nav-side-toggle-bg: rgba(29, 95, 167, 0.08);
  --nav-side-toggle-hover: rgba(29, 95, 167, 0.12);
  --content-surface-top: rgba(255, 255, 255, 0.42);
  --content-surface-bottom: rgba(247, 250, 255, 0.16);
  --teaser-surface-start: rgba(231, 241, 252, 0.98);
  --teaser-surface-end: rgba(205, 224, 244, 0.92);
  --cta-text: #f5faff;
  --cta-text-hover: #ffffff;
  --cta-shadow: 0 14px 28px rgba(29, 95, 167, 0.22);
  --after-note-bg: rgba(247, 250, 255, 0.72);
  --eyebrow-text: rgba(220, 233, 247, 0.78);
  --figcaption-text: rgba(234, 243, 252, 0.88);
  --floating-shadow: 0 14px 28px rgba(10, 12, 14, 0.28);
  --flag-shadow: 0 6px 12px rgba(0, 0, 0, 0.14);
  --mobile-toggle-border: rgba(255, 255, 255, 0.48);
  --mobile-toggle-icon: rgba(245, 250, 255, 0.92);
  --mobile-nav-border: rgba(29, 95, 167, 0.12);
  --mobile-nav-bg: rgba(247, 250, 255, 0.98);
  --mobile-nav-shadow: 0 20px 44px rgba(20, 36, 60, 0.2);
  --mobile-nav-zebra-odd: rgba(29, 95, 167, 0.12);
  --mobile-nav-zebra-even: rgba(255, 255, 255, 0.92);
  --mobile-nav-active-bg: rgba(29, 95, 167, 0.16);
  --radius-xl: 5px;
  --radius-lg: 15px;
  --radius-md: 14px;
  --content-width: 1260px;
  --hero-height: 420px;
}

/* Quick presets for the color_theme setting in index.php. */
.theme-warm {
  --page-bg: #f4efe8;
  --page-ink: #1f1e1a;
  --muted-ink: #675f56;
  --page-gradient-start: #f8f4ee;
  --page-gradient-mid: #ede1d5;
  --page-gradient-end: #d8c2ad;
  --panel-bg: rgba(255, 250, 245, 0.88);
  --panel-border: rgba(92, 69, 46, 0.16);
  --accent: #a44c34;
  --accent-dark: #6d2f23;
  --accent-soft: #f1dccf;
  --hero-deep: #23343b;
  --hero-mid: #3f5962;
  --hero-warm: #bf7b47;
  --shadow-soft: 0 18px 50px rgba(25, 21, 17, 0.12);
  --shadow-card: 0 22px 60px rgba(33, 24, 18, 0.14);
  --hero-overlay-start: rgba(20, 28, 31, 0.88);
  --hero-overlay-end: rgba(42, 62, 68, 0.72);
  --header-orb-top: rgba(255, 255, 255, 0.08);
  --header-orb-bottom: rgba(234, 190, 158, 0.16);
  --utility-text: rgba(255, 247, 239, 0.92);
  --utility-link: #fff7ef;
  --utility-link-hover: #fffdf9;
  --utility-muted: rgba(255, 241, 230, 0.74);
  --brand-badge-bg: rgba(109, 47, 35, 0.08);
  --boxed-search-border: rgba(92, 69, 46, 0.16);
  --boxed-search-bg: rgba(255, 250, 245, 0.82);
  --visual-header-bg: rgba(16, 21, 25, 0.96);
  --visual-utility-bg: rgba(18, 24, 28, 0.32);
  --floating-surface: rgba(18, 24, 28, 0.42);
  --floating-surface-strong: rgba(18, 24, 28, 0.62);
  --floating-text: #fff4ea;
  --hero-text: #fff8f1;
  --hero-text-strong: #fffdf9;
  --hero-text-soft: rgba(255, 244, 234, 0.9);
  --hero-text-muted: rgba(255, 241, 230, 0.78);
  --hero-note-surface: rgba(255, 248, 241, 0.12);
  --hero-note-label-bg: rgba(255, 248, 241, 0.18);
  --hero-note-text: #fff4ea;
  --stat-card-surface: rgba(255, 248, 241, 0.08);
  --stat-card-text: #fff4ea;
  --nav-bg: rgba(255, 250, 245, 0.92);
  --nav-toggle-bg: rgba(109, 47, 35, 0.08);
  --nav-active-bg: rgba(164, 76, 52, 0.14);
  --nav-active-ring: rgba(109, 47, 35, 0.12);
  --nav-dropdown-bg: rgba(255, 250, 245, 0.98);
  --nav-dropdown-border: rgba(109, 47, 35, 0.14);
  --nav-dropdown-shadow: 0 20px 36px rgba(33, 24, 18, 0.14);
  --nav-mega-item-bg: rgba(109, 47, 35, 0.04);
  --nav-tree-border: rgba(109, 47, 35, 0.12);
  --nav-tree-border-soft: rgba(109, 47, 35, 0.08);
  --nav-side-toggle-bg: rgba(109, 47, 35, 0.08);
  --nav-side-toggle-hover: rgba(109, 47, 35, 0.12);
  --content-surface-top: rgba(255, 255, 255, 0.42);
  --content-surface-bottom: rgba(255, 248, 241, 0.16);
  --teaser-surface-start: rgba(251, 238, 228, 0.98);
  --teaser-surface-end: rgba(236, 215, 199, 0.92);
  --cta-text: #fff7f0;
  --cta-shadow: 0 14px 28px rgba(109, 47, 35, 0.22);
  --after-note-bg: rgba(255, 250, 245, 0.72);
  --eyebrow-text: rgba(255, 235, 221, 0.78);
  --figcaption-text: rgba(255, 244, 234, 0.88);
  --mobile-nav-border: rgba(92, 69, 46, 0.12);
  --mobile-nav-shadow: 0 20px 44px rgba(33, 24, 18, 0.2);
  --mobile-nav-zebra-odd: rgba(109, 47, 35, 0.12);
  --mobile-nav-active-bg: rgba(164, 76, 52, 0.16);
}

.theme-forest {
  --page-bg: #eef5f0;
  --page-ink: #1d2b24;
  --muted-ink: #5d7066;
  --page-gradient-start: #f2f8f3;
  --page-gradient-mid: #dcebdd;
  --page-gradient-end: #bdd7c2;
  --panel-bg: rgba(246, 251, 247, 0.9);
  --panel-border: rgba(54, 110, 76, 0.14);
  --accent: #2f7a55;
  --accent-dark: #1f563b;
  --accent-soft: #d8eadf;
  --hero-deep: #152b1f;
  --hero-mid: #2d5f43;
  --hero-warm: #76a87f;
  --shadow-soft: 0 18px 50px rgba(24, 40, 30, 0.12);
  --shadow-card: 0 22px 60px rgba(24, 40, 30, 0.14);
  --brand-badge-bg: rgba(54, 110, 76, 0.08);
  --boxed-search-border: rgba(54, 110, 76, 0.16);
  --boxed-search-bg: rgba(246, 251, 247, 0.82);
  --nav-bg: rgba(246, 251, 247, 0.92);
  --nav-toggle-bg: rgba(54, 110, 76, 0.08);
  --nav-active-bg: rgba(54, 110, 76, 0.14);
  --nav-active-ring: rgba(54, 110, 76, 0.12);
  --nav-dropdown-bg: rgba(246, 251, 247, 0.98);
  --nav-dropdown-border: rgba(54, 110, 76, 0.14);
  --nav-dropdown-shadow: 0 20px 36px rgba(24, 40, 30, 0.14);
  --nav-mega-item-bg: rgba(54, 110, 76, 0.04);
  --nav-tree-border: rgba(54, 110, 76, 0.12);
  --nav-tree-border-soft: rgba(54, 110, 76, 0.08);
  --nav-side-toggle-bg: rgba(54, 110, 76, 0.08);
  --nav-side-toggle-hover: rgba(54, 110, 76, 0.12);
  --content-surface-top: rgba(255, 255, 255, 0.42);
  --content-surface-bottom: rgba(236, 246, 238, 0.16);
  --teaser-surface-start: rgba(232, 244, 236, 0.98);
  --teaser-surface-end: rgba(205, 227, 212, 0.92);
  --cta-shadow: 0 14px 28px rgba(54, 110, 76, 0.22);
  --after-note-bg: rgba(246, 251, 247, 0.72);
  --mobile-nav-border: rgba(54, 110, 76, 0.12);
  --mobile-nav-bg: rgba(246, 251, 247, 0.98);
  --mobile-nav-shadow: 0 20px 44px rgba(24, 40, 30, 0.2);
  --mobile-nav-zebra-odd: rgba(54, 110, 76, 0.12);
  --mobile-nav-active-bg: rgba(54, 110, 76, 0.16);
}

.theme-neutral {
  --page-bg: #f3f5f7;
  --page-ink: #23292f;
  --muted-ink: #66717c;
  --page-gradient-start: #f8fafb;
  --page-gradient-mid: #e5ebf0;
  --page-gradient-end: #ccd7e1;
  --panel-bg: rgba(250, 252, 253, 0.9);
  --panel-border: rgba(74, 98, 122, 0.14);
  --accent: #466b90;
  --accent-dark: #304a66;
  --accent-soft: #dde7f0;
  --hero-deep: #1c2730;
  --hero-mid: #3d5569;
  --hero-warm: #7f9bb4;
  --shadow-soft: 0 18px 50px rgba(28, 39, 48, 0.12);
  --shadow-card: 0 22px 60px rgba(28, 39, 48, 0.14);
  --brand-badge-bg: rgba(74, 98, 122, 0.08);
  --boxed-search-border: rgba(74, 98, 122, 0.16);
  --boxed-search-bg: rgba(250, 252, 253, 0.82);
  --nav-bg: rgba(250, 252, 253, 0.92);
  --nav-toggle-bg: rgba(74, 98, 122, 0.08);
  --nav-active-bg: rgba(74, 98, 122, 0.14);
  --nav-active-ring: rgba(74, 98, 122, 0.12);
  --nav-dropdown-bg: rgba(250, 252, 253, 0.98);
  --nav-dropdown-border: rgba(74, 98, 122, 0.14);
  --nav-dropdown-shadow: 0 20px 36px rgba(28, 39, 48, 0.14);
  --nav-mega-item-bg: rgba(74, 98, 122, 0.04);
  --nav-tree-border: rgba(74, 98, 122, 0.12);
  --nav-tree-border-soft: rgba(74, 98, 122, 0.08);
  --nav-side-toggle-bg: rgba(74, 98, 122, 0.08);
  --nav-side-toggle-hover: rgba(74, 98, 122, 0.12);
  --content-surface-top: rgba(255, 255, 255, 0.42);
  --content-surface-bottom: rgba(240, 245, 249, 0.16);
  --teaser-surface-start: rgba(236, 242, 247, 0.98);
  --teaser-surface-end: rgba(214, 225, 235, 0.92);
  --cta-shadow: 0 14px 28px rgba(74, 98, 122, 0.22);
  --after-note-bg: rgba(250, 252, 253, 0.72);
  --mobile-nav-border: rgba(74, 98, 122, 0.12);
  --mobile-nav-bg: rgba(250, 252, 253, 0.98);
  --mobile-nav-shadow: 0 20px 44px rgba(28, 39, 48, 0.2);
  --mobile-nav-zebra-odd: rgba(74, 98, 122, 0.12);
  --mobile-nav-active-bg: rgba(74, 98, 122, 0.16);
}

.theme-my-theme {
  /* Custom theme: change these values if you want your own palette. */
  --page-bg: #eef4fb;
  --page-ink: #182433;
  --muted-ink: #5a6d82;
  --page-gradient-start: #f4f8fd;
  --page-gradient-mid: #dde8f6;
  --page-gradient-end: #bed1e8;
  --panel-bg: rgba(247, 250, 255, 0.88);
  --panel-border: rgba(29, 95, 167, 0.14);
  --accent: #1d5fa7;
  --accent-dark: #123d6b;
  --accent-soft: #d9e7f7;
  --hero-deep: #10263b;
  --hero-mid: #1d4f83;
  --hero-warm: #5f97d1;
  --shadow-soft: 0 18px 50px rgba(20, 36, 60, 0.12);
  --shadow-card: 0 22px 60px rgba(20, 36, 60, 0.14);
  --hero-overlay-start: rgba(10, 24, 40, 0.9);
  --hero-overlay-end: rgba(24, 68, 112, 0.74);
  --header-orb-top: rgba(160, 205, 255, 0.11);
  --header-orb-bottom: rgba(84, 150, 225, 0.2);
  --utility-text: rgba(245, 250, 255, 0.94);
  --utility-link: #f5faff;
  --utility-link-hover: #ffffff;
  --utility-muted: rgba(220, 233, 247, 0.78);
  --brand-badge-bg: rgba(29, 95, 167, 0.08);
  --boxed-search-border: rgba(29, 95, 167, 0.16);
  --boxed-search-bg: rgba(247, 250, 255, 0.82);
  --search-border: rgba(255, 255, 255, 0.18);
  --search-bg: rgba(255, 255, 255, 0.12);
  --search-text: #f5faff;
  --search-placeholder: rgba(220, 233, 247, 0.78);
  --visual-header-bg: rgba(11, 25, 40, 0.96);
  --visual-utility-bg: rgba(14, 31, 50, 0.32);
  --floating-surface: rgba(14, 31, 50, 0.42);
  --floating-surface-strong: rgba(14, 31, 50, 0.62);
  --floating-border: rgba(255, 255, 255, 0.14);
  --floating-text: #f5faff;
  --hero-text: #f5faff;
  --hero-text-strong: #ffffff;
  --hero-text-soft: rgba(234, 243, 252, 0.9);
  --hero-text-muted: rgba(220, 233, 247, 0.78);
  --hero-note-surface: rgba(255, 255, 255, 0.12);
  --hero-note-label-bg: rgba(255, 255, 255, 0.16);
  --hero-note-text: #f5faff;
  --stat-card-surface: rgba(255, 255, 255, 0.08);
  --stat-card-text: #f5faff;
  --nav-bg: rgba(247, 250, 255, 0.92);
  --nav-toggle-bg: rgba(29, 95, 167, 0.08);
  --nav-active-bg: rgba(29, 95, 167, 0.14);
  --nav-active-ring: rgba(29, 95, 167, 0.12);
  --nav-dropdown-bg: rgba(247, 250, 255, 0.98);
  --nav-dropdown-border: rgba(29, 95, 167, 0.14);
  --nav-dropdown-shadow: 0 20px 36px rgba(20, 36, 60, 0.14);
  --nav-mega-item-bg: rgba(29, 95, 167, 0.04);
  --nav-tree-border: rgba(29, 95, 167, 0.12);
  --nav-tree-border-soft: rgba(29, 95, 167, 0.08);
  --nav-side-toggle-bg: rgba(29, 95, 167, 0.08);
  --nav-side-toggle-hover: rgba(29, 95, 167, 0.12);
  --content-surface-top: rgba(255, 255, 255, 0.42);
  --content-surface-bottom: rgba(247, 250, 255, 0.16);
  --teaser-surface-start: rgba(231, 241, 252, 0.98);
  --teaser-surface-end: rgba(205, 224, 244, 0.92);
  --cta-text: #f5faff;
  --cta-text-hover: #ffffff;
  --cta-shadow: 0 14px 28px rgba(29, 95, 167, 0.22);
  --after-note-bg: rgba(247, 250, 255, 0.72);
  --eyebrow-text: rgba(220, 233, 247, 0.78);
  --figcaption-text: rgba(234, 243, 252, 0.88);
  --floating-shadow: 0 14px 28px rgba(10, 12, 14, 0.28);
  --flag-shadow: 0 6px 12px rgba(0, 0, 0, 0.14);
  --mobile-toggle-border: rgba(255, 255, 255, 0.48);
  --mobile-toggle-icon: rgba(245, 250, 255, 0.92);
  --mobile-nav-border: rgba(29, 95, 167, 0.12);
  --mobile-nav-bg: rgba(247, 250, 255, 0.98);
  --mobile-nav-shadow: 0 20px 44px rgba(20, 36, 60, 0.2);
  --mobile-nav-zebra-odd: rgba(29, 95, 167, 0.12);
  --mobile-nav-zebra-even: rgba(255, 255, 255, 0.92);
  --mobile-nav-active-bg: rgba(29, 95, 167, 0.16);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  color: var(--page-ink);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 100%;
  scroll-behavior: smooth;
}

body.allcssRes {
  margin: 0;
  color: var(--page-ink);
  background:
    radial-gradient(circle at top left, rgba(255, 255, 255, 0.78), transparent 34%),
    linear-gradient(135deg, var(--page-gradient-start) 0%, var(--page-gradient-mid) 48%, var(--page-gradient-end) 100%);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.utility-bar img,
.hero-panel img,
.primary-nav img,
.side-nav img,
.site-footer img,
.template-hint img,
.hero-edit-link img {
  max-width: 100%;
  height: auto;
}

.layout-boxed #allcssRes-wrapper.site-shell,
#allcssRes-wrapper.site-shell.layout-boxed {
  width: min(calc(100% - 32px), var(--content-width));
  margin: 24px auto 0;
  padding-bottom: 24px;
}

.layout-full-hero #allcssRes-wrapper.site-shell,
#allcssRes-wrapper.site-shell.layout-full-hero {
  width: min(calc(100% - 32px), var(--content-width));
  margin: 0 auto;
  padding-bottom: 24px;
}

.layout-full-hero #allcssRes-wrapper.site-shell.is-start-page,
#allcssRes-wrapper.site-shell.layout-full-hero.is-start-page {
  padding-bottom: 0;
}

.layout-full-site #allcssRes-wrapper.site-shell,
#allcssRes-wrapper.site-shell.layout-full-site {
  width: 100%;
  margin: 0;
  padding: 0 0 24px;
}

#allcssRes-wrapper.site-shell {
  flex: 1 0 auto;
  display: flex;
  flex-direction: column;
}

.layout-full-hero .site-header {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  border-radius: 0;
  border-left: 0;
  border-right: 0;
}

.layout-full-site .primary-nav,
.layout-full-site .full-width-band,
.layout-full-site .page-grid,
.layout-full-site .site-footer,
.layout-full-site .powered_by {
  width: auto;
  max-width: none;
  margin-left: 16px;
  margin-right: 16px;
}

.layout-full-site .site-header {
  border-radius: 0;
  border-left: 0;
  border-right: 0;
}

.layout-full-hero .hero-panel,
.layout-full-site .hero-panel {
  border-radius: 0;
}

.layout-full-hero .hero-panel--custom img,
.layout-full-hero .hero-panel--custom figure img,
.layout-full-hero .hero-panel--custom .hero-media img,
.layout-full-site .hero-panel--custom img,
.layout-full-site .hero-panel--custom figure img,
.layout-full-site .hero-panel--custom .hero-media img {
  border-radius: 0;
}

.site-header {
  position: relative;
  z-index: 120;
  overflow: hidden;
  border: 0;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-soft);
  background:
    linear-gradient(140deg, var(--hero-overlay-start), var(--hero-overlay-end)),
    linear-gradient(135deg, var(--hero-deep) 0%, var(--hero-mid) 56%, var(--hero-warm) 100%);
}

.layout-boxed .site-header {
  background: transparent;
  border: 0;
  box-shadow: none;
}

.layout-boxed.visual-hero-image .site-header,
.layout-boxed #allcssRes-wrapper.site-shell.visual-hero-image .site-header {
  background: transparent;
}

.layout-boxed .utility-bar,
.layout-boxed.visual-hero-image .utility-bar,
.layout-boxed.visual-header-image .utility-bar,
.layout-boxed #allcssRes-wrapper.site-shell.visual-hero-image .utility-bar,
.layout-boxed #allcssRes-wrapper.site-shell.visual-header-image .utility-bar {
  background: transparent;
  border-bottom: 0;
  backdrop-filter: none;
  color: var(--page-ink);
}

.layout-boxed .utility-brand,
.layout-boxed .utility-brand:hover {
  color: var(--page-ink);
}

.layout-boxed .utility-brand__logo {
  background: var(--brand-badge-bg);
  color: var(--accent-dark);
}

.layout-boxed .utility-brand__text span {
  color: var(--muted-ink);
}

.layout-boxed .site-search {
  border-color: var(--boxed-search-border);
  background: var(--boxed-search-bg);
  backdrop-filter: none;
}

.layout-boxed .site-search__button,
.layout-boxed .site-search__input,
.layout-boxed .site-search__input::placeholder {
  color: var(--page-ink);
}

.layout-boxed .site-header::before,
.layout-boxed .site-header::after {
  display: none;
}

.visual-hero-image .site-header {
  background: var(--visual-header-bg);
}

.visual-header-image .site-header {
  background:
    linear-gradient(140deg, rgba(20, 28, 31, 0.24), rgba(42, 62, 68, 0.16)),
    var(--header-image) center/cover no-repeat;
}

.layout-boxed.visual-header-image .site-header,
.layout-boxed #allcssRes-wrapper.site-shell.visual-header-image .site-header {
  background:
    linear-gradient(140deg, rgba(20, 28, 31, 0.24), rgba(42, 62, 68, 0.16)),
    var(--header-image) center/cover no-repeat;
}

.visual-hero-image .hero-panel:not(.hero-panel--custom) {
  background:
    linear-gradient(140deg, rgba(20, 28, 31, 0.54), rgba(42, 62, 68, 0.38)),
    var(--hero-image) center/cover no-repeat;
}

.visual-hero-image .utility-bar,
.visual-header-image .utility-bar {
  background: var(--visual-utility-bg);
  backdrop-filter: blur(8px);
}

.visual-hero-image .utility-bar {
  margin-bottom: 18px;
}

.visual-hero-image .site-header::before,
.visual-hero-image .site-header::after {
  display: none;
}

.site-header::before,
.site-header::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
}

.site-header::before {
  top: -120px;
  right: -60px;
  width: 320px;
  height: 320px;
  background: var(--header-orb-top);
}

.site-header::after {
  bottom: -120px;
  left: -80px;
  width: 260px;
  height: 260px;
  background: var(--header-orb-bottom);
}

.utility-bar,
.hero-panel,
.primary-nav,
.feature-strip,
.page-grid,
.site-footer {
  position: relative;
  z-index: 1;
}

.utility-bar {
  display: flex;
  justify-content: flex-start;
  gap: 18px;
  margin-top: -1px;
  padding: 12px 28px;
  color: var(--utility-text);
  align-items: center;
}

.is-start-page .site-header {
  overflow: visible;
}

.is-start-page .utility-bar {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
  position: relative;
  z-index: 120;
}

.utility-bar__left,
.utility-bar__right {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: nowrap;
}

.is-start-page .utility-bar__left {
  justify-self: start;
}

.is-start-page .utility-bar__right {
  justify-self: end;
}

.language-switch {
  margin-left: auto;
}

.utility-bar a,
.language-switch a,
.language-switch img {
  vertical-align: middle;
  text-decoration: none;
}

.utility-brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: var(--utility-link);
}

.utility-brand:hover {
  color: var(--utility-link-hover);
}

.utility-brand__logo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 14px;
  background: var(--hero-note-surface);
  font: 700 0.95rem/1 "Trebuchet MS", Arial, sans-serif;
  letter-spacing: 0.08em;
}

.utility-brand__logo--image {
  width: auto;
  min-width: 40px;
  padding: 4px;
}

/* Adjust the logo size here when you use images/site-logo.svg or another supported site-logo file. */
.utility-brand__logo--image img {
  display: block;
  width: auto;
  height: 100%;
  max-width: min(180px, 28vw);
  object-fit: contain;
}

.utility-brand__text {
  display: grid;
  gap: 2px;
  font: 0.9rem/1.2 "Trebuchet MS", Arial, sans-serif;
}

/* Adjust the website title next to the logo here. */
.utility-brand__text strong {
  font-size: 0.98rem;
  line-height: 1.2;
}

/* Adjust the smaller line below the website title here. */
.utility-brand__text span {
  color: var(--utility-muted);
  font-size: 0.82rem;
}

.site-search {
  display: flex;
  align-items: center;
  width: min(320px, 34vw);
  min-width: 220px;
  border: 1px solid var(--search-border);
  border-radius: var(--radius-xl);
  background: var(--search-bg);
  backdrop-filter: blur(10px);
}

.is-start-page .site-search {
  position: relative;
  justify-content: flex-end;
  width: 46px;
  min-width: 46px;
  min-height: 44px;
  border: 0;
  background: transparent;
  backdrop-filter: none;
  overflow: visible;
  box-sizing: border-box;
}

.is-start-page .site-search__input {
  order: 1;
}

.is-start-page .site-search__button {
  order: 2;
}

.is-start-page .site-search__toggle {
  order: 3;
  flex: 0 0 auto;
  position: relative;
  z-index: 4;
}

.site-search__button {
  border: 0;
  background: transparent;
  color: var(--search-text);
  padding: 0 0 0 16px;
  cursor: pointer;
  font-size: 1rem;
}

.site-search__toggle {
  border: 0;
  background: transparent;
  color: var(--search-text);
  padding: 0;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  border-radius: 999px;
}

.site-search__toggle:hover,
.site-search__toggle:focus-visible {
  background: rgba(255, 255, 255, 0.12);
  outline: none;
}

.site-search__submit-label {
  display: none;
}

.site-search__icon {
  display: block;
  width: 22px;
  height: 22px;
}

.site-search__input {
  width: 100%;
  min-width: 0;
  border: 0;
  background: transparent;
  color: var(--search-text);
  padding: 12px 16px 12px 10px;
  font: inherit;
}

.is-start-page .site-search__button {
  display: none;
}

.is-start-page .site-search__input {
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 0;
  min-width: 0;
  height: 44px;
  padding: 10px 52px 10px 12px;
  border-radius: var(--radius-xl);
  background: rgba(18, 42, 68, 0.98);
  box-shadow: inset 0 0 0 1px transparent;
  opacity: 0;
  pointer-events: none;
  z-index: 3;
  transition: width 180ms ease, opacity 140ms ease, box-shadow 180ms ease;
}

.is-start-page .site-search.is-open {
  box-shadow: none;
  border-radius: 0;
  background: transparent;
  backdrop-filter: none;
}

.is-start-page .site-search.is-open .site-search__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 8px 0 0;
  color: var(--search-text);
}

.is-start-page .site-search.is-open .site-search__input {
  width: min(320px, 28vw);
  box-shadow: inset 0 0 0 1px var(--search-border);
  opacity: 1;
  pointer-events: auto;
}

.site-search__input::placeholder {
  color: var(--search-placeholder);
}

.hero-panel {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(260px, 0.8fr);
  gap: 22px;
  align-items: start;
  padding: 30px 24px 26px;
  height: var(--hero-height);
}

.hero-panel--single {
  grid-template-columns: minmax(0, 1fr);
}

.hero-panel--overlay {
  position: relative;
  display: flex;
  align-items: flex-end;
  padding: 42px 24px 70px;
}

.hero-panel__overlay-content {
  position: relative;
  z-index: 1;
  width: min(760px, 100%);
  color: var(--hero-text);
}

.hero-panel__overlay-content > :first-child {
  margin-top: 0;
}

.hero-panel__overlay-content > :last-child {
  margin-bottom: 0;
}

.hero-panel__overlay-content h1,
.hero-panel__overlay-content h2,
.hero-panel__overlay-content h3,
.hero-panel__overlay-content h4,
.hero-panel__overlay-content h5,
.hero-panel__overlay-content h6 {
  color: var(--hero-text-strong);
}

.hero-panel__overlay-content p,
.hero-panel__overlay-content li,
.hero-panel__overlay-content label,
.hero-panel__overlay-content figcaption,
.hero-panel__overlay-content small {
  color: var(--hero-text-soft);
}

.hero-panel__overlay-content a:not(.button-link):not(.btn) {
  color: var(--hero-text);
  text-decoration: none;
}

.hero-panel__overlay-content a:not(.button-link):not(.btn):visited {
  color: var(--hero-text);
}

.hero-panel--custom {
  display: block;
  height: var(--hero-height);
  padding: 0;
  overflow: hidden;
}

.hero-panel--custom > *:not(.hero-edit-link):not(.hero-size-note--inside) {
  height: 100%;
}

.hero-panel--custom > :first-child {
  margin-top: 0;
}

.hero-panel--custom > :last-child {
  margin-bottom: 0;
}

.hero-panel--custom p,
.hero-panel--custom .wb_element,
.hero-panel--custom .content-wrap,
.hero-panel--custom .hero-media {
  height: 100%;
  margin: 0;
}

.hero-panel__content {
  max-width: 760px;
  align-self: start;
  padding-top: 34px;
}

.hero-panel__aside {
  align-self: start;
  padding-top: 18px;
}

.hero-edit-link {
  position: fixed;
  top: 12px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1200;
  isolation: isolate;
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  padding: 8px 40px 8px 12px;
  border-radius: 18px;
  background: var(--floating-surface);
  backdrop-filter: blur(8px);
}

.hero-edit-link.is-hidden {
  display: none;
}

.hero-edit-link a {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 8px;
  border-radius: 10px;
  background: transparent;
  color: var(--floating-text) !important;
  font: 700 0.8rem/1 "Trebuchet MS", Arial, sans-serif;
}

.hero-edit-link a:hover {
  background: var(--hero-note-label-bg);
}

.hero-edit-link__close {
  position: absolute;
  top: 8px;
  right: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: var(--floating-surface);
  color: var(--floating-text);
  cursor: pointer;
}

.hero-edit-link__close:hover {
  background: var(--floating-surface-strong);
}

.hero-edit-link__close span {
  position: relative;
  display: block;
  width: 12px;
  height: 12px;
}

.hero-edit-link__close span::before,
.hero-edit-link__close span::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 12px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
}

.hero-edit-link__close span::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.hero-edit-link__close span::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.hero-edit-link .template-hint__close,
.hero-edit-link .template-hint__drag {
  top: 8px;
}

.hero-panel--custom img,
.hero-panel--custom figure img,
.hero-panel--custom .hero-media img {
  display: block;
  width: 100%;
  height: 100%;
  max-height: 100%;
  min-height: 0;
  object-fit: cover;
  object-position: 50% 50%;
  border-radius: 20px;
  box-shadow: none;
}

.hero-panel--custom figure {
  margin: 0;
  height: 100%;
}

.hero-panel--custom figcaption {
  margin-top: 10px;
  color: var(--figcaption-text);
}

.eyebrow,
.panel__label,
.hero-note__label {
  display: inline-block;
  margin: 0 0 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font: 700 0.74rem/1.2 "Trebuchet MS", Arial, sans-serif;
}

.eyebrow {
  color: var(--eyebrow-text);
}

.site-title {
  display: inline-block;
  margin-bottom: 12px;
  color: var(--hero-text-strong);
  font-size: clamp(1.15rem, 1rem + 0.7vw, 1.5rem);
  font-weight: 700;
}

.page-title {
  margin: 0;
  color: var(--hero-text);
  font-size: clamp(1.95rem, 5.1vw, 3.55rem);
  line-height: 0.94;
  letter-spacing: -0.03em;
}

.page-context {
  max-width: 44rem;
  margin: 12px 0 0;
  color: var(--hero-text-muted);
  font: 1.05rem/1.7 "Trebuchet MS", Arial, sans-serif;
}

.hero-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 18px;
}

.hero-actions__note {
  max-width: 26rem;
  color: var(--hero-text-muted);
  font: 0.95rem/1.6 "Trebuchet MS", Arial, sans-serif;
}

.hero-note {
  padding: 18px;
  border: 1px solid var(--floating-border);
  border-radius: var(--radius-lg);
  background: var(--hero-note-surface);
  color: var(--hero-note-text);
  backdrop-filter: blur(10px);
}

.hero-note strong {
  display: block;
  margin-bottom: 8px;
  font-size: 1.05rem;
}

.hero-note p {
  margin: 0;
  font: 0.92rem/1.55 "Trebuchet MS", Arial, sans-serif;
}

.header-block {
  margin: 0 28px 28px;
  padding: 22px 24px;
  border-radius: 18px;
  background: var(--hero-note-surface);
  color: var(--hero-note-text);
  backdrop-filter: blur(8px);
}

.header-block > :first-child {
  margin-top: 0;
}

.header-block > :last-child {
  margin-bottom: 0;
}

.hero-size-note {
  padding: 12px 18px;
  border-radius: 14px;
  background: var(--hero-note-label-bg);
  color: var(--hero-text-soft);
  font: 0.92rem/1.55 "Trebuchet MS", Arial, sans-serif;
}

.hero-size-note--inside {
  position: absolute;
  left: 28px;
  right: 28px;
  bottom: 18px;
  z-index: 2;
  margin: 0;
  background: var(--floating-surface);
  border: 1px solid var(--floating-border);
  backdrop-filter: blur(8px);
}

.header-size-note {
  position: absolute;
  left: 28px;
  right: 28px;
  top: 86px;
  z-index: 2;
  margin: 0;
  background: var(--floating-surface);
  border: 1px solid var(--floating-border);
  backdrop-filter: blur(8px);
}

.template-hint {
  position: relative;
}

.template-hint--floating {
  min-width: min(520px, calc(100% - 56px));
}

.template-hint.is-hidden {
  display: none;
}

.template-hint__close,
.template-hint__drag {
  position: absolute;
  top: 10px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: 0;
  border-radius: 999px;
  background: var(--floating-surface);
  color: var(--floating-text);
  cursor: pointer;
  padding: 0;
}

.template-hint__close {
  right: 10px;
}

.template-hint__drag {
  right: 44px;
  cursor: move;
  font: 700 0.82rem/1 "Trebuchet MS", Arial, sans-serif;
}

.template-hint__close span {
  position: relative;
  display: block;
  width: 12px;
  height: 12px;
}

.template-hint__close span::before,
.template-hint__close span::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 12px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  transform-origin: center;
}

.template-hint__close span::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.template-hint__close span::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.template-hint__close:hover,
.template-hint__drag:hover {
  background: var(--floating-surface-strong);
}

.hero-size-note.template-hint {
  padding-right: 84px;
}

.after-content-note.template-hint {
  padding-right: 62px;
}

.after-content-note .template-hint__close {
  top: 12px;
  right: 12px;
}

.template-hint--floating.is-dragging {
  cursor: move;
}

.hero-stat-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.hero-stat {
  padding: 14px;
  border: 1px solid var(--floating-border);
  border-radius: 18px;
  background: var(--stat-card-surface);
  color: var(--stat-card-text);
}

.hero-stat__value {
  display: block;
  margin-bottom: 4px;
  font-size: 1.7rem;
  line-height: 1;
  font-weight: 700;
}

.hero-stat__label {
  font: 0.82rem/1.4 "Trebuchet MS", Arial, sans-serif;
  color: var(--hero-text-muted);
}

.primary-nav {
  margin-top: 18px;
  padding: 12px 14px;
  border: 1px solid var(--panel-border);
  border-radius: calc(var(--radius-xl) - 4px);
  background: var(--nav-bg);
  box-shadow: var(--shadow-soft);
  position: relative;
  z-index: 80;
}

.is-start-page .utility-nav.primary-nav--header {
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
}

.is-start-page .utility-nav.primary-nav--header {
  width: 100%;
  max-width: 880px;
}

.is-start-page .utility-nav.primary-nav--header > ul {
  justify-content: center;
  align-items: center;
  gap: 4px;
}

.is-start-page .utility-nav.primary-nav--header a,
.is-start-page .utility-nav.primary-nav--header a:visited {
  color: var(--utility-link);
}

.is-start-page .utility-nav.primary-nav--header > ul > li {
  display: flex;
  align-items: center;
  position: relative;
}

.is-start-page .utility-nav.primary-nav--header > ul > li + li::before {
  content: "|";
  display: inline-block;
  margin: 0 2px 0 0;
  color: rgba(255, 255, 255, 0.72);
  font: 400 0.9rem/1 "Trebuchet MS", Arial, sans-serif;
}

.is-start-page .utility-nav.primary-nav--header > ul > li.menu-current.menu-first {
  display: none;
}

.is-start-page .utility-nav.primary-nav--header > ul > li.menu-current.menu-first + li::before {
  display: none;
}

.is-start-page .utility-nav.primary-nav--header a {
  padding: 8px 10px 6px;
  font-size: 0.9rem;
  line-height: 1.1;
  border-radius: 0;
  border-bottom: 2px solid transparent;
}

.is-start-page .utility-nav.primary-nav--header > ul > li.menu-current > a,
.is-start-page .utility-nav.primary-nav--header > ul > li.active > a,
.is-start-page .utility-nav.primary-nav--header a:hover {
  background: transparent;
  color: var(--utility-link-hover);
  box-shadow: none;
  border-bottom-color: #8fc5ff;
}

.is-start-page .utility-nav.primary-nav--header > ul > li.menu-current > a,
.is-start-page .utility-nav.primary-nav--header > ul > li.active > a {
  border-bottom-color: #8fc5ff;
}

.is-start-page .utility-nav.primary-nav--header .nav-toggle {
  color: var(--utility-link);
}

.is-start-page .utility-nav.primary-nav--header li:hover > .nav-toggle,
.is-start-page .utility-nav.primary-nav--header li.is-open > .nav-toggle {
  color: var(--utility-link-hover);
}

.is-start-page .utility-nav.primary-nav--header ul ul a,
.is-start-page .utility-nav.primary-nav--header ul ul a:visited {
  display: block;
  padding-left: 12px;
  color: var(--page-ink);
}

.is-start-page .utility-nav.primary-nav--header ul ul li.menu-current > a,
.is-start-page .utility-nav.primary-nav--header ul ul li.active > a,
.is-start-page .utility-nav.primary-nav--header ul ul a:hover {
  color: var(--accent-dark);
}

@media (max-width: 1480px) and (min-width: 981px) {
  .is-start-page .utility-bar {
    grid-template-columns: minmax(180px, 260px) minmax(0, 1fr) auto;
    column-gap: 12px;
  }

  .is-start-page .utility-nav.primary-nav--header {
    position: static;
    left: auto;
    transform: none;
    width: auto;
    max-width: 100%;
    min-width: 0;
    justify-self: center;
  }

  .is-start-page .utility-nav.primary-nav--header > ul {
    flex-wrap: nowrap;
    gap: 2px;
  }

  .is-start-page .utility-nav.primary-nav--header a {
    padding: 8px 8px 6px;
    font-size: 0.84rem;
  }

  .is-start-page .utility-nav.primary-nav--header > ul > li + li::before {
    margin-right: 0;
    font-size: 0.82rem;
  }

  .is-start-page .utility-brand {
    min-width: 0;
  }

  .is-start-page .utility-brand__text {
    gap: 1px;
  }

  .is-start-page .utility-brand__text strong {
    font-size: 0.92rem;
  }

  .is-start-page .utility-brand__text span {
    display: none;
    font-size: 0.78rem;
  }
}

.mobile-nav-toggle {
  display: none;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
  width: 52px;
  height: 48px;
  margin-left: auto;
  border: 0;
  border-radius: var(--radius-xl);
  background: var(--nav-toggle-bg);
  cursor: pointer;
}

.mobile-nav-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  border-radius: 999px;
  background: var(--accent-dark);
}

.primary-nav > ul,
.menu > ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.primary-nav > ul {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.primary-nav li {
  list-style: none;
  position: relative;
}

.primary-nav a {
  display: block;
  padding: 11px 14px;
  border-radius: 999px;
  color: var(--page-ink);
  text-decoration: none;
  font: 700 0.95rem/1.2 "Trebuchet MS", Arial, sans-serif;
  transition: background-color 160ms ease, color 160ms ease, box-shadow 160ms ease;
}

.primary-nav a:visited {
  color: var(--page-ink);
}

.primary-nav li.menu-current > a,
.primary-nav li.active > a,
.primary-nav a:hover {
  background: var(--nav-active-bg);
  color: var(--accent-dark);
  box-shadow: inset 0 0 0 1px var(--nav-active-ring);
}

.primary-nav ul ul {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  z-index: 20;
  display: block;
  min-width: 250px;
  padding: 8px;
  border: 1px solid var(--nav-dropdown-border);
  border-radius: 5px;
  background: var(--nav-dropdown-bg);
  box-shadow: var(--nav-dropdown-shadow);
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity 180ms ease, transform 180ms ease, visibility 180ms ease;
}

.primary-nav ul ul li {
  position: relative;
}

.primary-nav ul ul ul {
  top: -10px;
  left: calc(100% + 10px);
}

.primary-nav li.is-open > ul {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.primary-nav ul ul a {
  padding: 11px 12px;
  border-radius: 14px;
  font-weight: 600;
}

.primary-nav ul ul.nav-columns-2,
.primary-nav ul ul.nav-columns-3 {
  min-width: min(560px, calc(100vw - 48px));
  max-height: calc(100vh - 140px);
  overflow-x: hidden;
  overflow-y: auto;
  column-gap: 10px;
}

.primary-nav ul ul.nav-columns-2 {
  column-count: 2;
}

.primary-nav ul ul.nav-columns-3 {
  min-width: min(780px, calc(100vw - 48px));
  column-count: 3;
}

.primary-nav ul ul.nav-columns-2 > li,
.primary-nav ul ul.nav-columns-3 > li {
  break-inside: avoid;
  page-break-inside: avoid;
  margin-bottom: 6px;
}

.primary-nav ul ul.nav-mega {
  display: grid;
  left: 50%;
  right: auto;
  transform: translate(-50%, 8px);
  grid-template-columns: repeat(3, minmax(180px, 1fr));
  gap: 8px 10px;
  align-items: start;
  align-content: start;
  min-width: min(700px, calc(100vw - 40px));
  max-width: min(860px, calc(100vw - 40px));
  max-height: calc(100vh - 140px);
  overflow-x: hidden;
  overflow-y: auto;
}

.primary-nav ul ul.nav-mega > li {
  margin: 0;
  padding: 0;
  border-radius: 5px;
  background: var(--nav-mega-item-bg);
  align-self: start;
  break-inside: avoid;
  page-break-inside: avoid;
}

.primary-nav ul ul.nav-mega > li > a {
  margin-bottom: 0;
  padding: 8px 8px 6px;
  font-weight: 700;
}

.primary-nav ul ul.nav-mega li,
.primary-nav ul ul.nav-mega ul li {
  position: relative;
}

.primary-nav ul ul.nav-mega li.has-children {
  padding-right: 0;
}

.primary-nav ul ul.nav-mega li.has-children > a {
  padding-right: 34px;
}

.primary-nav ul ul.nav-mega .nav-toggle {
  top: 5px;
  right: 6px;
  width: 22px;
  height: 22px;
  margin-top: 0;
}

.primary-nav ul ul.nav-mega ul {
  position: static;
  top: auto;
  left: auto;
  display: none;
  min-width: 0;
  margin-top: 2px;
  padding: 0 0 0 10px;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  opacity: 1;
  visibility: visible;
  transform: none;
  transition: none;
}

.primary-nav ul ul.nav-mega li.is-open > ul {
  display: block;
}

.primary-nav ul ul.nav-mega ul a {
  padding: 6px 8px;
  border-radius: 5px;
  font-weight: 600;
}

.primary-nav ul ul.nav-mega ul ul {
  margin-top: 1px;
  padding-left: 10px;
}

.primary-nav li.has-children {
  padding-right: 34px;
}

.primary-nav li.has-children > a {
  padding-right: 8px;
}

.page-grid {
  display: grid;
  grid-template-columns: minmax(220px, 0.62fr) minmax(0, 1.55fr) minmax(260px, 0.72fr);
  gap: 24px;
  margin-top: 24px;
  align-items: start;
  position: relative;
  z-index: 1;
}

.page-grid--no-left {
  grid-template-columns: minmax(0, 1.42fr) minmax(240px, 0.58fr);
}

.page-grid--no-right {
  grid-template-columns: minmax(170px, 0.38fr) minmax(0, 1.46fr);
}

.page-grid--no-left.page-grid--no-right {
  grid-template-columns: minmax(0, 1fr);
}

.left-column,
.right-column {
  display: grid;
  gap: 18px;
  align-content: start;
  position: relative;
}

.panel--teaser {
  background:
    linear-gradient(135deg, var(--teaser-surface-start), var(--teaser-surface-end));
}

.panel--teaser h2 {
  margin: 0 0 12px;
  font-size: clamp(1.45rem, 2.2vw, 2rem);
  line-height: 1.05;
}

.panel--teaser > :first-child {
  margin-top: 0;
}

.panel--teaser > :last-child {
  margin-bottom: 0;
}

.panel--placeholder p {
  margin-bottom: 0;
}

.panel,
.content-card,
.site-footer {
  border: 1px solid var(--panel-border);
  border-radius: var(--radius-xl);
  background: var(--panel-bg);
  box-shadow: var(--shadow-card);
  backdrop-filter: blur(12px);
}

.panel {
  padding: 22px;
}

.panel__label,
.hero-note__label {
  color: var(--accent);
}

.hero-note__label {
  padding: 4px 10px;
  border-radius: 999px;
  background: var(--hero-note-label-bg);
  color: var(--hero-note-text);
}

.panel p,
.panel li,
.panel label,
.site-footer,
.powered_by {
  font: 1rem/1.7 "Trebuchet MS", Arial, sans-serif;
}

.menu ul ul {
  margin-top: 10px;
  padding-left: 14px;
  border-left: 1px solid var(--nav-tree-border);
  display: none;
  overflow: visible;
}

.menu ul ul ul {
  margin-top: 8px;
  padding-left: 12px;
  border-left-color: var(--nav-tree-border-soft);
}

.menu li + li {
  margin-top: 8px;
}

.menu li {
  position: relative;
}

.menu a {
  display: block;
  padding: 8px 0;
  color: var(--page-ink);
  text-decoration: none;
  font: 700 0.95rem/1.35 "Trebuchet MS", Arial, sans-serif;
}

.menu a:visited {
  color: var(--page-ink);
}

.menu li.menu-current > a,
.menu a:hover {
  color: var(--accent-dark);
}

.menu li.is-open > ul {
  display: block;
}

.nav-toggle {
  position: absolute;
  top: 50%;
  right: 0;
  width: 28px;
  height: 28px;
  margin-top: -14px;
  border: 0;
  border-radius: 999px;
  background: var(--nav-side-toggle-bg);
  color: var(--accent-dark);
  cursor: pointer;
}

.nav-toggle span {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0;
  height: 0;
  margin-left: -5px;
  margin-top: -3px;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 7px solid currentColor;
  transform-origin: 50% 45%;
  transition: transform 180ms ease;
}

li.is-open > .nav-toggle span {
  transform: rotate(180deg);
}

.primary-nav .nav-toggle {
  right: 6px;
  width: 26px;
  height: 26px;
  margin-top: -13px;
  background: var(--nav-side-toggle-bg);
  transition: background-color 160ms ease, color 160ms ease;
}

.primary-nav li.is-open > .nav-toggle,
.primary-nav li:hover > .nav-toggle {
  background: var(--nav-side-toggle-hover);
}

.side-nav .nav-toggle span {
  margin-top: -3px;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 7px solid currentColor;
  border-bottom: 0;
  transform: none;
}

.side-nav li.is-open > .nav-toggle span {
  margin-top: -6px;
  border-top: 0;
  border-bottom: 7px solid currentColor;
  transform: none;
}

.side-nav .nav-toggle {
  right: -4px;
  top: 8px;
  margin-top: 0;
}

.content-card {
  overflow: hidden;
}

.content-card__inner {
  padding: clamp(24px, 3vw, 42px);
  background:
    linear-gradient(180deg, var(--content-surface-top), var(--content-surface-bottom));
}

.content-card__inner > :first-child {
  margin-top: 0;
}

.content-card__inner > :last-child {
  margin-bottom: 0;
}

.content-stage img {
  max-width: 100%;
  height: auto;
}

.button-link,
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border: 0;
  border-radius: var(--radius-xl);
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);
  color: var(--cta-text) !important;
  font: 700 0.92rem/1 "Trebuchet MS", Arial, sans-serif;
  cursor: pointer;
  box-shadow: var(--cta-shadow);
}

.button-link:hover,
.btn:hover {
  color: var(--cta-text-hover) !important;
  transform: translateY(-1px);
}

.after-content-note {
  margin-top: 18px;
  padding: 18px 22px;
  border-left: 4px solid var(--accent);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  background: var(--after-note-bg);
  color: var(--muted-ink);
}

.after-content-note p {
  margin: 0;
}

.site-footer {
  margin-top: 24px;
  padding: 16px 22px;
}

.footer-nav {
  margin-bottom: 6px;
}

.footer-nav ul {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 14px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.footer-nav li {
  list-style: none;
}

.footer-nav a {
  color: var(--page-ink);
  text-decoration: none;
  font: 700 0.92rem/1.2 "Trebuchet MS", Arial, sans-serif;
}

.footer-nav a:visited {
  color: var(--page-ink);
}

.content-stage a:not(.button-link):not(.btn):link,
.content-stage a:not(.button-link):not(.btn):visited,
.content-stage a:not(.button-link):not(.btn):hover,
.content-stage a:not(.button-link):not(.btn):focus,
.content-stage a:not(.button-link):not(.btn):active,
.left-column a:not(.button-link):not(.btn):link,
.left-column a:not(.button-link):not(.btn):visited,
.left-column a:not(.button-link):not(.btn):hover,
.left-column a:not(.button-link):not(.btn):focus,
.left-column a:not(.button-link):not(.btn):active,
.right-column a:not(.button-link):not(.btn):link,
.right-column a:not(.button-link):not(.btn):visited,
.right-column a:not(.button-link):not(.btn):hover,
.right-column a:not(.button-link):not(.btn):focus,
.right-column a:not(.button-link):not(.btn):active,
.site-footer a:not(.button-link):not(.btn):link,
.site-footer a:not(.button-link):not(.btn):visited,
.site-footer a:not(.button-link):not(.btn):hover,
.site-footer a:not(.button-link):not(.btn):focus,
.site-footer a:not(.button-link):not(.btn):active,
.powered_by a:not(.button-link):not(.btn):link,
.powered_by a:not(.button-link):not(.btn):visited,
.powered_by a:not(.button-link):not(.btn):hover,
.powered_by a:not(.button-link):not(.btn):focus,
.powered_by a:not(.button-link):not(.btn):active {
  color: var(--page-ink) !important;
  text-decoration: none !important;
}

.powered_by .button-link,
.powered_by .button-link:visited,
.powered_by .button-link:hover,
.powered_by .button-link:focus,
.powered_by .button-link:active {
  text-decoration: none !important;
}

.footer-nav a:hover,
.footer-nav li.menu-current > a,
.footer-nav li.active > a {
  color: var(--accent-dark);
}

.site-footer__content {
  margin-bottom: 14px;
}

.site-footer__meta {
  color: var(--muted-ink);
  line-height: 1.3;
}

.powered_by {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8px 14px;
  padding: 18px 0 34px;
  color: var(--muted-ink);
}

.powered_by__consent {
  border: 0;
  padding: 0;
  background: transparent;
  color: var(--accent-dark);
  font: 700 0.9rem/1.4 "Trebuchet MS", Arial, sans-serif;
  text-decoration: none;
  cursor: pointer;
}

.powered_by__consent:hover {
  color: var(--accent);
}

.language-switch .langmenu {
  display: flex !important;
  gap: 8px;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: nowrap;
  padding: 0 !important;
  margin: 0 !important;
  min-height: 0;
}

.language-switch .langmenu a,
.language-switch .langmenu .anchor {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  width: auto;
  padding: 2px;
}

.language-switch .langmenu span {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
}

.language-switch .langmenu img {
  border-radius: 0;
  box-shadow: var(--flag-shadow);
  width: 22px !important;
  height: auto !important;
  max-width: none;
}

.language-switch__toggle {
  display: none;
}

@media (max-width: 980px) {
  .hero-panel,
  .page-grid {
    grid-template-columns: 1fr;
  }

  .hero-panel {
    height: auto;
    min-height: var(--hero-height);
  }

  .hero-panel__content {
    max-width: none;
    padding-top: 20px;
    padding-bottom: 8px;
  }

  .hero-panel__aside {
    display: none;
  }

  .hero-size-note--inside {
    left: 16px;
    right: 16px;
    bottom: 14px;
  }

  .template-hint--floating {
    min-width: 0;
    width: auto;
    max-width: calc(100% - 32px);
  }

  .hero-panel--overlay {
    padding-bottom: 94px;
  }

  .hero-panel__overlay-content {
    width: 100%;
  }

  .mobile-nav-toggle {
    display: inline-flex;
    position: static;
    z-index: 5;
    margin-left: auto;
    background: transparent;
    box-shadow: none;
    border: 1px solid var(--mobile-toggle-border);
    width: 32px;
    height: 32px;
    gap: 2px;
    border-radius: 8px;
    flex: 0 0 auto;
  }

  .mobile-nav-toggle span {
    width: 16px;
    height: 2px;
    background: var(--mobile-toggle-icon);
  }

  .visual-hero-image .utility-bar,
  .visual-header-image .utility-bar {
    border-bottom: 0;
  }

  .primary-nav {
    position: fixed;
    top: 64px;
    right: 0;
    left: 0;
    z-index: 160;
    width: 100%;
    margin-top: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    pointer-events: none;
  }

  .is-start-page .utility-nav.primary-nav--header {
    position: absolute;
    top: calc(100% - 54px);
    right: 0;
    left: 0;
    width: auto;
    margin: 0;
    padding: 0;
    pointer-events: auto;
    transform: none;
    z-index: 180;
  }

  .is-start-page .utility-bar {
    grid-template-columns: minmax(0, 1fr) auto auto;
  }

  .primary-nav > ul {
    display: none;
    flex-direction: column;
    margin-top: 0;
    padding: 12px 18px 0;
    border-top: 1px solid var(--mobile-nav-border);
    border-bottom: 1px solid var(--mobile-nav-border);
    border-radius: 0;
    background: var(--mobile-nav-bg);
    box-shadow: var(--mobile-nav-shadow);
  }

  .is-start-page .utility-nav.primary-nav--header > ul {
    gap: 8px;
    padding: 8px 18px 12px;
    border-radius: 0;
    background: var(--mobile-nav-bg);
    box-shadow: var(--mobile-nav-shadow);
  }

  .is-start-page .utility-nav.primary-nav--header {
    grid-column: 1 / -1;
    order: 4;
    max-width: none;
  }

  .primary-nav.is-mobile-open > ul {
    display: flex;
  }

  .primary-nav.is-mobile-open {
    pointer-events: auto;
  }

  .is-start-page .utility-nav.primary-nav--header a,
  .is-start-page .utility-nav.primary-nav--header a:visited {
    color: var(--page-ink);
  }

  .is-start-page .utility-nav.primary-nav--header li {
    display: block;
  }

  .is-start-page .utility-nav.primary-nav--header li + li::before {
    display: none;
  }

  .is-start-page .utility-nav.primary-nav--header a,
  .is-start-page .utility-nav.primary-nav--header a:visited {
    display: block;
    width: 100%;
    padding: 11px 14px;
    border-radius: 10px;
    border-bottom: 0 !important;
    color: var(--page-ink) !important;
    text-decoration: none;
    font: 700 0.95rem/1.2 "Trebuchet MS", Arial, sans-serif;
    box-shadow: none;
  }

  .is-start-page .utility-nav.primary-nav--header > ul > li,
  .is-start-page .utility-nav.primary-nav--header > ul > li > a {
    width: 100%;
  }

  .is-start-page .utility-nav.primary-nav--header > ul > li:nth-child(odd) > a {
    background: var(--mobile-nav-zebra-odd);
  }

  .is-start-page .utility-nav.primary-nav--header > ul > li:nth-child(even) > a {
    background: var(--mobile-nav-zebra-even);
  }

  .is-start-page .utility-nav.primary-nav--header li.menu-current > a,
  .is-start-page .utility-nav.primary-nav--header li.active > a {
    background: var(--mobile-nav-active-bg) !important;
    color: var(--accent-dark) !important;
    border-bottom: 0 !important;
    border-radius: 10px;
    box-shadow: inset 4px 0 0 var(--accent-dark) !important;
  }

  .is-start-page .utility-nav.primary-nav--header a:hover {
    border-bottom: 0 !important;
  }

  .is-start-page .utility-bar__right {
    width: 100%;
    margin-top: 8px;
    order: 4;
  }

  .is-start-page .site-search {
    position: relative;
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    align-items: center;
    justify-content: stretch;
    width: 100%;
    min-width: 0;
    min-height: 46px;
    border: 1px solid var(--search-border);
    border-radius: var(--radius-xl);
    background: var(--search-bg);
    backdrop-filter: blur(10px);
  }

  .is-start-page .site-search__toggle {
    order: 0;
    justify-self: center;
    width: 42px;
    height: 42px;
    z-index: auto;
  }

  .is-start-page .site-search__button {
    display: none !important;
  }

  .is-start-page .site-search__input,
  .is-start-page .site-search.is-open .site-search__input {
    position: static;
    top: auto;
    right: auto;
    transform: none;
    width: 100%;
    min-width: 0;
    height: auto;
    padding: 12px 14px 12px 10px;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    opacity: 1;
    pointer-events: auto;
    z-index: auto;
  }

  .is-start-page .site-search.is-open {
    width: 100%;
    box-shadow: none;
  }

  .primary-nav > ul > li,
  .primary-nav > ul > li > a {
    width: 100%;
  }

  .primary-nav > ul > li:nth-child(odd) > a {
    background: var(--mobile-nav-zebra-odd);
  }

  .primary-nav > ul > li:nth-child(even) > a {
    background: var(--mobile-nav-zebra-even);
  }

  .primary-nav li.menu-current > a,
  .primary-nav li.active > a {
    background: var(--mobile-nav-active-bg);
    color: var(--accent-dark);
    box-shadow: inset 4px 0 0 var(--accent-dark);
  }

  .primary-nav li.has-children {
    padding-right: 0;
  }

  .primary-nav li.has-children > a {
    padding-right: 40px;
  }

  .primary-nav a {
    border-radius: 18px;
  }

  .primary-nav ul ul {
    display: none;
    position: static;
    top: auto;
    left: auto;
    min-width: 0;
    margin-top: 8px;
    padding: 6px 0 0 12px;
    border: 0;
    border-radius: 5px;
    background: transparent;
    box-shadow: none;
    opacity: 1;
    visibility: visible;
    transform: none;
    transition: none;
  }

  .primary-nav ul ul.nav-columns-2,
  .primary-nav ul ul.nav-columns-3,
  .primary-nav ul ul.nav-mega {
    min-width: 0;
    max-width: none;
    max-height: none;
    overflow: visible;
    display: none;
    column-count: 1;
  }

  .primary-nav ul ul.nav-mega > li {
    padding: 0;
    background: transparent;
  }

  .primary-nav ul ul.nav-mega ul {
    display: none;
    margin-top: 8px;
    padding: 6px 0 0 12px;
  }

  .primary-nav li.is-open > ul {
    display: block;
  }

  .content-stage {
    order: 1;
  }

  .left-column {
    order: 2;
  }

  .right-column {
    order: 3;
  }

  .left-column .panel--nav {
    display: none;
  }

  .hero-size-note,
  .header-block,
  .page-grid,
  .full-width-band,
  .site-footer {
    margin-top: 4px;
  }

  .footer-nav ul {
    flex-direction: column;
    gap: 8px;
  }

  .powered_by {
    justify-content: center;
  }

  .utility-bar {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin-top: -1px;
    padding: 12px 18px;
  }

  .utility-bar__left {
    width: auto;
    flex: 1 1 auto;
    justify-content: flex-start;
    order: 1;
  }

  .is-start-page .utility-bar {
    display: flex;
  }

  .is-start-page .utility-nav.primary-nav--header {
    right: 0;
    left: 0;
  }

.utility-brand {
  width: auto;
}

  /* Adjust the mobile logo size here. */
  .utility-brand__logo--image img {
    max-width: min(150px, 44vw);
  }

  .utility-bar__left,
  .utility-bar__right {
    flex-wrap: wrap;
    justify-content: flex-end;
  }

  .utility-bar__left {
    justify-content: flex-start;
  }

  .utility-bar__right {
    width: 100%;
    margin-top: 8px;
    gap: 10px;
    align-items: center;
    order: 4;
  }

  .language-switch {
    position: relative;
    order: 2;
    margin-left: 0;
  }

  .language-switch__toggle {
    display: inline-flex;
    align-items: center;
    justify-content: flex-start;
    gap: 5px;
    min-width: 36px;
    height: 32px;
    padding: 0 7px;
    border: 1px solid var(--mobile-toggle-border);
    border-radius: 9px;
    background: transparent;
    cursor: pointer;
  }

  .language-switch__toggle img {
    width: 18px !important;
    height: auto !important;
    box-shadow: none;
  }

  .language-switch__arrow {
    width: 0;
    height: 0;
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    border-top: 5px solid var(--mobile-toggle-icon);
  }

  .language-switch .langmenu {
    display: none !important;
    position: absolute;
    top: calc(100% + 8px);
    right: 0;
    width: 100%;
    flex-direction: column;
    gap: 6px;
    padding: 8px 0;
    border: 1px solid var(--mobile-toggle-border);
    border-radius: 9px;
    background: var(--floating-surface-strong);
    box-shadow: var(--floating-shadow);
    z-index: 70;
  }

  .language-switch.is-open .langmenu {
    display: flex !important;
  }

  .language-switch .langmenu a,
  .language-switch .langmenu .anchor,
  .language-switch .langmenu span {
    width: 100%;
    justify-content: center;
  }

  .language-switch .langmenu a {
    padding: 3px 9px;
  }

  .language-switch__toggle img {
    width: 18px !important;
  }

  .language-switch .langmenu img {
    width: 22px !important;
  }

  .language-switch .langmenu a.current {
    display: none;
  }

  .mobile-nav-toggle {
    order: 3;
  }

  .primary-nav .nav-toggle {
    top: 11px;
    right: 8px;
    margin-top: 0;
  }

  .mobile-nav-toggle {
    width: 48px;
    flex: 0 0 auto;
    margin-left: auto;
  }

  .utility-bar__right .site-search {
    flex: 1 1 220px;
  }

  .hero-stat-grid {
    grid-template-columns: 1fr 1fr;
  }

  .left-column .panel:first-child,
  .right-column .panel:first-child {
    margin-top: 0;
  }
}

@media (max-width: 640px) {
  #allcssRes-wrapper.site-shell {
    width: min(calc(100% - 18px), var(--content-width));
    margin-top: 10px;
  }

  .site-header,
  .primary-nav,
  .feature-strip__inner,
  .panel,
  .content-card,
  .site-footer {
    border-radius: 18px;
  }

  .utility-bar,
  .hero-panel,
  .header-block,
  .feature-strip__inner,
  .content-card__inner,
  .site-footer {
    padding-left: 18px;
    padding-right: 18px;
  }

  .is-start-page .utility-nav.primary-nav--header {
    right: 18px;
    left: 18px;
    margin-left: 0;
    margin-right: 0;
  }

  .page-title {
    font-size: clamp(2rem, 12vw, 3rem);
  }

  .account-block table.account,
  .account-block table.account tbody,
  .account-block table.account tr,
  .account-block table.account td {
    display: block;
    width: 100% !important;
  }

  .account-block table.account tr {
    margin-bottom: 12px;
  }

  .account-block .setting-name,
  .account-block .setting-right,
  .account-block .setting-top {
    padding: 0 0 6px;
    text-align: left;
  }

  .account-block input[type="text"],
  .account-block input[type="email"],
  .account-block input[type="password"],
  .account-block input[type="search"],
  .account-block input[type="tel"],
  .account-block input[type="url"],
  .account-block input[type="number"],
  .account-block select,
  .account-block textarea {
    width: 100% !important;
    max-width: 100%;
    box-sizing: border-box;
  }

  .account-block .captcha_table,
  .account-block .captcha-code {
    width: 100% !important;
  }

  .account-block .captcha-code {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
  }

  .account-block .image-captcha {
    max-width: 100%;
    height: auto;
  }

  .account-block .w3-bar {
    display: block;
  }

  .account-block .w3-bar-item {
    display: block;
    width: 100% !important;
    margin: 0 0 8px;
  }

  .account-block .login_form {
    display: grid;
    gap: 10px;
  }

  .account-block .login_form .w3-btn,
  .account-block .login_form button,
  .account-block .login_form input[type="submit"] {
    display: block;
    width: 100%;
  }

  .content-stage .syntaxhighlighter {
    max-width: 100% !important;
    overflow-x: auto !important;
    overflow-y: hidden;
    box-sizing: border-box;
  }

  .content-stage .syntaxhighlighter table {
    width: auto !important;
    max-width: none !important;
  }

  .content-stage .syntaxhighlighter .line,
  .content-stage .syntaxhighlighter code {
    white-space: pre-wrap !important;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  .login-box .login-table,
  .login-box .login-table fieldset,
  .login-box .login-table p,
  .login-box .login-table .input,
  .login-box .login-table input[type="text"],
  .login-box .login-table input[type="email"],
  .login-box .login-table input[type="password"],
  .login-box .login-table input[type="submit"] {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }

  .login-box .login-table p {
    margin: 0 0 10px;
  }

  .login-box .toggle-password {
    right: 10px;
  }

  .login-box .dbutton {
    display: block;
    width: 100%;
  }

  .login-box .login-advance {
    padding-left: 1rem;
  }

  .klaro .cookie-notice:not(.cookie-modal-notice) {
    left: 12px;
    right: 12px;
    width: auto;
    max-width: none;
    box-sizing: border-box;
  }

  .klaro .cookie-notice:not(.cookie-modal-notice) .cn-body,
  .klaro .cookie-notice:not(.cookie-modal-notice) .cn-buttons,
  .klaro .cookie-notice:not(.cookie-modal-notice) .cn-ok {
    width: 100%;
    box-sizing: border-box;
  }

  .klaro .cookie-notice:not(.cookie-modal-notice) .cn-buttons,
  .klaro .cookie-notice:not(.cookie-modal-notice) .cn-ok {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }

  .klaro .cookie-notice:not(.cookie-modal-notice) .cn-buttons .cm-btn,
  .klaro .cookie-notice:not(.cookie-modal-notice) .cn-ok .cm-btn {
    width: auto;
    max-width: 100%;
  }

  .site-search {
    min-width: 100%;
  }

  .hero-stat-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 460px) {
  #allcssRes-wrapper.site-shell {
    width: min(calc(100% - 10px), var(--content-width));
    margin-top: 6px;
  }

  .utility-bar,
  .hero-panel,
  .header-block,
  .feature-strip__inner,
  .content-card__inner,
  .site-footer,
  .panel {
    padding-left: 12px;
    padding-right: 12px;
  }

  .utility-bar {
    padding-top: 10px;
    padding-bottom: 10px;
    gap: 10px;
  }

  .is-start-page .utility-nav.primary-nav--header {
    right: 0;
    left: 0;
    margin-left: 0;
    margin-right: 0;
  }

  .utility-bar__right {
    margin-top: 6px;
    gap: 8px;
  }

  .hero-panel {
    min-height: 0;
    padding-top: 18px;
    padding-bottom: 18px;
  }

  .hero-panel__content {
    padding-top: 8px;
    padding-bottom: 0;
  }

  .page-title {
    font-size: clamp(1.65rem, 11vw, 2.5rem);
    line-height: 0.98;
  }

  .page-context {
    margin-top: 10px;
    font-size: 0.98rem;
    line-height: 1.6;
  }

  .hero-actions {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    margin-top: 14px;
  }

  .hero-actions__note {
    max-width: none;
    font-size: 0.92rem;
    line-height: 1.5;
  }

  .button-link,
  .btn {
    min-height: 40px;
    padding: 0 14px;
  }

  .content-card__inner {
    padding-top: 16px;
    padding-bottom: 16px;
  }

  .panel {
    padding-top: 16px;
    padding-bottom: 16px;
  }

  .site-search__button {
    padding-left: 12px;
  }

  .site-search__input {
    padding-right: 12px;
  }
}

/* Full-height stage mode: let the utility bar stay on top and stretch the hero to the viewport height. */
.hero-height-screen .site-header {
  min-height: 100svh;
  display: flex;
  flex-direction: column;
}

body.is-start-page {
  overflow: hidden;
}

@media (max-width: 980px) {
  body.is-start-page {
    overflow-x: hidden;
    overflow-y: auto;
  }

  .is-start-page .site-header::before,
  .is-start-page .site-header::after {
    display: none;
  }

  .hero-height-screen .site-header,
  .hero-height-screen.is-start-page .site-header {
    min-height: 0;
  }

  .hero-height-screen .hero-panel,
  .is-start-page .hero-panel {
    flex: 0 0 auto;
    min-height: 0;
    height: auto;
  }
}

.hero-height-screen.is-start-page .site-header {
  min-height: 100svh;
  height: auto;
}

.hero-height-screen .hero-panel {
  flex: 1 1 auto;
  min-height: 0;
  height: auto;
}


.hero-height-screen .hero-panel--custom > *:not(.hero-edit-link):not(.hero-size-note--inside) {
  min-height: 100%;
}
