:root {
  --color-bg: radial-gradient(circle at 20% 0%, #1a2433 0%, #0f1218 45%);
  --color-accent: #ccff00;
  --color-text: #fff;
  --color-text-muted: #a8adb8;
  --color-text-subtle: #6f7b8c;
  --color-test-background:
    radial-gradient(
      circle at top left,
      rgba(204, 255, 0, 0.08),
      transparent 28%
    ),
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.04),
      rgba(255, 255, 255, 0.015)
    ),
    rgba(10, 14, 22, 0.76);
  --ff-gunplay: "Gunplay", sans-serif;
  --ff-roboto: "Roboto", Courier, monospace;
  --ff-roboto-condensed: "RobotoCondensed", Courier, monospace;
  --ff-syne: "Syne", Courier, monospace;
  --ff-klarheit-rg: "KlarheitRegular", Courier, monospace;
  --ff-klarheit-mrg: "KlarheitMonoRegular", Courier, monospace;
  --ff-klarheit-mbd: "KlarheitMonoBold", Courier, monospace;
  --ff-klarheit-ps: "KlarheitPoster", Courier, monospace;
  --card-color-border: 1px solid rgba(255, 255, 255, 0.12);
  --card-color-bg: rgba(255, 255, 255, 0.03);
  --navitem-dropdown-hover: rgba(56, 234, 178, 0.18);
}

i.text-primary,
.fa-duotone.text-primary,
.fa-light.text-primary,
.fa-regular.text-primary,
.fa-brands.text-primary {
  color: var(--color-accent) !important;
}

.text-muted,
.lead {
  color: var(--color-text-muted) !important;
}

.btn,
.btn-primary,
.btn-outline-primary,
.btn-outline-light,
.btn-outline-secondary {
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.9) !important;
  background: var(--color-bg) !important;
  color: var(--color-text) !important;
  font-weight: 700;
  letter-spacing: 0.01em;
  box-shadow: none !important;
  transition: background 180ms cubic-bezier(0.22, 1, 0.36, 1), border-color 180ms cubic-bezier(0.22, 1, 0.36, 1), color 180ms cubic-bezier(0.22, 1, 0.36, 1), transform 180ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.btn:hover,
.btn:focus-visible,
.btn-primary:hover,
.btn-primary:focus-visible,
.btn-outline-primary:hover,
.btn-outline-primary:focus-visible,
.btn-outline-secondary:hover,
.btn-outline-secondary:focus-visible,
.btn-outline-light:hover,
.btn-outline-light:focus-visible {
  background: var(--color-bg) !important;
  border-color: var(--color-accent) !important;
  color: var(--color-accent) !important;
  transform: none;
  box-shadow: none !important;
}

.btn:focus-visible,
.btn-primary:focus-visible,
.btn-outline-primary:focus-visible,
.btn-outline-secondary:focus-visible,
.btn-outline-light:focus-visible {
  outline: none;
  box-shadow: 0 0 0 0.2rem rgba(255, 255, 255, 0.2) !important;
}

.breadcrumb-item a {
  color: var(--color-text-muted) !important;
  text-decoration: none;
  font-weight: 500;
  transition: color 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.breadcrumb-item a:hover {
  color: var(--color-accent) !important;
}

.breadcrumb-item.active {
  color: var(--color-accent) !important;
}

.breadcrumb-item + .breadcrumb-item::before {
  color: var(--color-text-subtle) !important;
  content: "/" !important;
}

.table-light {
  --bs-table-color: var(--color-text) !important;
}

.text-upper-accent {
  color: var(--color-accent);
  text-transform: uppercase;
}

.first-letter-accent {
  display: inline-block;
  color: var(--color-text);
}
.first-letter-accent::first-letter {
  color: var(--color-accent);
}
.first-letter-accent:hover, .first-letter-accent:focus-visible {
  color: var(--color-accent);
}
.first-letter-accent:hover::first-letter, .first-letter-accent:focus-visible::first-letter {
  color: var(--color-text);
}

.nav-link.first-letter-accent-reverse {
  color: var(--color-accent) !important;
}
.nav-link.first-letter-accent-reverse::first-letter {
  color: var(--color-text) !important;
}
.nav-link.first-letter-accent-reverse:hover, .nav-link.first-letter-accent-reverse:focus-visible {
  color: var(--color-text) !important;
}
.nav-link.first-letter-accent-reverse:hover::first-letter, .nav-link.first-letter-accent-reverse:focus-visible::first-letter {
  color: var(--color-accent) !important;
}

@font-face {
  font-family: "Gunplay";
  src: url("/assets/font/gunplay-rg.otf") format("opentype");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "RobotoCondensed";
  src: url("/assets/font/RobotoCondensed.ttf") format("truetype");
  font-weight: 100 200 300 400 500 600 700 800 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Roboto";
  src: url("/assets/font/Roboto.ttf") format("truetype");
  font-weight: 100 200 300 400 500 600 700 800 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Syne";
  src: url("/assets/font/Syne.ttf") format("truetype");
  font-weight: 100 200 300 400 500 600 700 800 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "BigMarker";
  src: url("/assets/font/marker/bigMarker.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "KlarheitRegular";
  src: url("/assets/font/ESKlarheitKurrent/KlarheitRegular.otf") format("opentype");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "KlarheitMonoRegular";
  src: url("/assets/font/ESKlarheitKurrent/KlarheitMonoRegular.otf") format("opentype");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "KlarheitMonoBold";
  src: url("/assets/font/ESKlarheitKurrent/KlarheitMonoBold.otf") format("opentype");
  font-weight: bold;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "KlarheitPoster";
  src: url("/assets/font/ESKlarheitKurrent/KlarheitPoster.otf") format("opentype");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "FatMarker";
  src: url("/assets/font/marker/fatMarker.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "GoodMarker";
  src: url("/assets/font/marker/goodMarker.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "SPMarker";
  src: url("/assets/font/marker/spMarker.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "XMarker";
  src: url("/assets/font/marker/xMarker.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
html {
  scroll-behavior: smooth;
  overflow-y: scroll;
  overscroll-behavior-y: contain;
}

body {
  font-family: var(--ff-syne);
  color: var(--color-text);
  background: var(--color-bg);
  background-attachment: fixed;
  overflow-x: hidden;
  font-size: 1.2rem;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--ff-syne);
  color: var(--color-text);
  letter-spacing: -0.01em;
}

h1 {
  color: var(--color-text);
}
h1::first-letter {
  color: var(--color-accent);
}
h1:hover, h1:focus-visible {
  color: var(--color-accent);
}
h1:hover::first-letter, h1:focus-visible::first-letter {
  color: var(--color-text);
}

p,
li,
label,
small {
  color: var(--color-text-muted) !important;
}

a {
  color: var(--color-text);
}

.container {
  max-width: 1550px;
}

.page-content {
  padding-top: clamp(8rem, 10vw, 12.5rem);
  padding-bottom: clamp(4rem, 6vw, 6.5rem);
}
.page-content h1 {
  font-size: clamp(38px, 8vw, 64px);
}

@media (prefers-reduced-motion: reduce) {
  * {
    animation: none !important;
    transition-duration: 0.01ms !important;
    transition-delay: 0ms !important;
    scroll-behavior: auto !important;
  }
}
:where(.btn-accent-pill,
.hero-cta--primary,
.shopware-demo-callout__link,
.btn-primary,
.cookie-consent__btn--primary,
.contact-submit-btn) {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  border: 1px solid var(--color-accent) !important;
  backdrop-filter: blur(1rem);
  -webkit-backdrop-filter: blur(1rem);
  transition: 0.5s;
}

:where(.btn-accent-pill,
.hero-cta--primary,
.shopware-demo-callout__link,
.btn-primary,
.cookie-consent__btn--primary,
.contact-submit-btn)::before,
:where(.btn-accent-pill,
.hero-cta--primary,
.shopware-demo-callout__link,
.btn-primary,
.cookie-consent__btn--primary,
.contact-submit-btn)::after {
  content: "";
  position: absolute;
  left: -50%;
  top: -120%;
  width: 200rem;
  height: 200rem;
  pointer-events: none;
  z-index: 0;
  opacity: 0.35;
  transition: opacity 0.5s, filter 0.5s;
}

:where(.btn-accent-pill,
.hero-cta--primary,
.shopware-demo-callout__link,
.btn-primary,
.cookie-consent__btn--primary,
.contact-submit-btn)::before {
  background: linear-gradient(160deg, rgba(199, 255, 0, 0.2), rgba(199, 255, 0, 0.09) 34%, rgba(12, 18, 30, 0.42) 72%, rgba(12, 18, 30, 0.58) 100%), radial-gradient(rgba(255, 255, 255, 0.95) 1px, transparent 1%);
  background-size: 100% 100%, 50px 50px;
  animation: animStar 60s linear infinite;
  opacity: 0.5;
}

:where(.btn-accent-pill,
.hero-cta--primary,
.shopware-demo-callout__link,
.btn-primary,
.cookie-consent__btn--primary,
.contact-submit-btn)::after {
  background: radial-gradient(rgba(255, 255, 255, 0.92) 1px, transparent 1%);
  background-size: 50px 50px;
  animation: animStarRotate 90s linear infinite;
  opacity: 0.22;
}

:where(.btn-accent-pill,
.hero-cta--primary,
.shopware-demo-callout__link,
.btn-primary,
.cookie-consent__btn--primary,
.contact-submit-btn) > * {
  position: relative;
  z-index: 1;
}

:where(.btn-accent-pill,
.hero-cta--primary,
.shopware-demo-callout__link,
.btn-primary,
.cookie-consent__btn--primary,
.contact-submit-btn):hover::before,
:where(.btn-accent-pill,
.hero-cta--primary,
.shopware-demo-callout__link,
.btn-primary,
.cookie-consent__btn--primary,
.contact-submit-btn):focus-visible::before {
  opacity: 0.18;
  filter: brightness(1.04);
}

:where(.hero-cta--primary,
.shopware-demo-callout__link,
.btn-primary,
.cookie-consent__btn--primary,
.contact-submit-btn):hover::after,
:where(.hero-cta--primary,
.shopware-demo-callout__link,
.btn-primary,
.cookie-consent__btn--primary,
.contact-submit-btn):focus-visible::after {
  opacity: 0.88;
  filter: brightness(1.22);
}

:where(.hero-cta--primary,
.shopware-demo-callout__link,
.btn-primary,
.cookie-consent__btn--primary,
.contact-submit-btn):hover,
:where(.hero-cta--primary,
.shopware-demo-callout__link,
.btn-primary,
.cookie-consent__btn--primary,
.contact-submit-btn):focus-visible {
  border-color: color-mix(in srgb, var(--color-accent) 86%, #fff 14%) !important;
  box-shadow: inset 0 0 0 9999px rgba(33, 33, 33, 0.26);
}

@keyframes animStar {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(-135rem);
  }
}
@keyframes animStarRotate {
  from {
    transform: rotate(360deg);
  }
  to {
    transform: rotate(0deg);
  }
}
@media (prefers-reduced-motion: reduce) {
  :where(.hero-cta--primary,
  .shopware-demo-callout__link,
  .btn-primary,
  .cookie-consent__btn--primary,
  .contact-submit-btn)::before,
  :where(.hero-cta--primary,
  .shopware-demo-callout__link,
  .btn-primary,
  .cookie-consent__btn--primary,
  .contact-submit-btn)::after {
    animation: none !important;
    transition: none !important;
  }
}
.checkbox-wrapper-25 input[type=checkbox] {
  background-image: -webkit-linear-gradient(hsla(0, 0%, 0%, 0.1), hsla(0, 0%, 100%, 0.1)), -webkit-linear-gradient(left, #f66 50%, #6cf 50%);
  background-size: 100% 100%, 200% 100%;
  background-position: 0 0, 15px 0;
  border-radius: 25px;
  box-shadow: inset 0 1px 4px hsla(0, 0%, 0%, 0.5), inset 0 0 10px hsla(0, 0%, 0%, 0.5), 0 0 0 1px hsla(0, 0%, 0%, 0.1), 0 -1px 2px 2px hsla(0, 0%, 0%, 0.25), 0 2px 2px 2px hsla(0, 0%, 100%, 0.75);
  cursor: pointer;
  height: 25px;
  padding-right: 25px;
  width: 75px;
  -webkit-appearance: none;
  -webkit-transition: 0.25s;
}

.checkbox-wrapper-25 input[type=checkbox]:after {
  background-color: #eee;
  background-image: -webkit-linear-gradient(hsla(0, 0%, 100%, 0.1), hsla(0, 0%, 0%, 0.1));
  border-radius: 25px;
  box-shadow: inset 0 1px 1px 1px hsl(0, 0%, 100%), inset 0 -1px 1px 1px hsla(0, 0%, 0%, 0.25), 0 1px 3px 1px hsla(0, 0%, 0%, 0.5), 0 0 2px hsla(0, 0%, 0%, 0.25);
  content: "";
  display: block;
  height: 25px;
  width: 50px;
}

.checkbox-wrapper-25 input[type=checkbox]:checked {
  background-position: 0 0, 35px 0;
  padding-left: 25px;
  padding-right: 0;
}

.site-layout {
  transition: background 700ms cubic-bezier(0.22, 1, 0.36, 1);
}

.site-layout .card::before,
.site-layout .card::after {
  content: "";
  position: absolute;
  pointer-events: none;
  width: 68px;
  height: 68px;
}

.site-layout .card::before {
  top: 0.7rem;
  left: 0.7rem;
  border-top: 1px solid var(--color-accent);
  border-left: 1px solid var(--color-accent);
  opacity: 0.7;
}

.site-layout .card::after {
  right: 0.7rem;
  bottom: 0.7rem;
  border-right: 1px solid var(--color-accent);
  border-bottom: 1px solid var(--color-accent);
  opacity: 0.5;
}

.site-layout .card .text-primary,
.site-layout .card i[class^=fa],
.site-layout .card i[class*=" fa-"] {
  color: var(--color-accent) !important;
}

body.accessibility-widget-open {
  overflow: hidden;
}

.floating-action--accessibility {
  position: relative;
  z-index: 2;
  width: 84px;
  height: 84px;
  margin-top: 0.8rem;
  border-width: 2px;
  border-color: var(--color-accent);
  background: rgba(15, 18, 24, 0.96);
  box-shadow: 0 18px 34px rgba(4, 8, 18, 0.28), 0 0 0 1px rgba(var(--color-bg), 0.08);
}
.floating-action--accessibility i {
  color: var(--color-accent);
  font-size: 1.55rem;
}

.accessibility-orbit {
  position: relative;
  display: flex;
  justify-content: flex-end;
  margin-bottom: 0.9rem;
}

.accessibility-orbit__actions {
  position: absolute;
  right: 14px;
  bottom: 12px;
  display: grid;
  gap: 0.7rem;
  opacity: 0;
  pointer-events: none;
  transform: translateX(-12px) scale(0.96);
  transition: opacity 180ms ease, transform 180ms ease;
}

.accessibility-orbit.is-open .accessibility-orbit__actions {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-90px) scale(1);
}

.accessibility-orbit__action {
  position: relative;
  width: 78px;
  height: 78px;
  border-color: rgba(255, 255, 255, 0.18);
  background: rgba(15, 18, 24, 0.94);
  box-shadow: 0 14px 28px rgba(4, 8, 18, 0.26);
}

.accessibility-orbit__action i {
  color: rgba(255, 255, 255, 0.86);
  font-size: 1.45rem;
}

.accessibility-orbit__action.is-open,
.accessibility-orbit__action:hover,
.accessibility-orbit__action:focus-visible {
  border-color: var(--color-accent);
}

.accessibility-orbit__action.is-open i,
.accessibility-orbit__action:hover i,
.accessibility-orbit__action:focus-visible i {
  color: var(--color-accent);
}

.accessibility-orbit__action--reset i {
  color: #f6f8fb;
}

.accessibility-orbit__badge {
  position: absolute;
  right: -4px;
  bottom: -4px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: 2px solid rgba(255, 255, 255, 0.9);
  border-radius: 999px;
  background: rgba(15, 18, 24, 0.98);
  color: var(--color-text);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
}

.accessibility-orbit__submenu {
  position: absolute;
  right: 286px;
  top: 50%;
  display: flex;
  flex-wrap: nowrap;
  justify-content: flex-start;
  align-items: center;
  gap: 0.7rem;
  width: max-content;
  max-width: none;
  opacity: 0;
  pointer-events: none;
  transform: translate3d(0, calc(-50% + 6px), 0);
  transition: opacity 180ms ease, transform 180ms ease;
}

.accessibility-orbit__submenu.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translate3d(0, -50%, 0);
}

.accessibility-orbit__option {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 72px;
  min-height: 72px;
  padding: 0.9rem 1rem;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 999px;
  background: rgba(15, 18, 24, 0.97);
  color: rgba(255, 255, 255, 0.9);
  font-weight: 700;
  box-shadow: 0 16px 32px rgba(4, 8, 18, 0.18);
  transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease, color 180ms ease;
}

.accessibility-orbit__option:hover,
.accessibility-orbit__option:focus-visible {
  border-color: var(--color-accent);
  color: var(--color-text) !important;
  transform: translateY(-2px);
}

.accessibility-orbit__option.is-active {
  border-color: #3b82f6;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.2), 0 16px 32px rgba(4, 8, 18, 0.18);
}

.accessibility-orbit__option i {
  font-size: 1.35rem;
}

.accessibility-orbit__option span {
  line-height: 1;
}

.accessibility-orbit__option--reset {
  min-width: 72px;
}

.accessibility-orbit__swatch {
  position: relative;
  width: 74px;
  min-width: 74px;
  height: 74px;
  padding: 0;
  overflow: hidden;
}

.accessibility-orbit__swatch::before {
  content: "";
  position: absolute;
  inset: 3px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.18);
}

.accessibility-orbit__swatch--mode-1 {
  background: linear-gradient(135deg, #000 50%, #fff 50%);
}

.accessibility-orbit__swatch--mode-2 {
  background: linear-gradient(135deg, #fff 50%, #000 50%);
}

.accessibility-orbit__swatch--mode-3 {
  background: linear-gradient(135deg, #2658b6 50%, #fff300 50%);
}

.accessibility-orbit__swatch--mode-4 {
  background: linear-gradient(135deg, #c50000 50%, #2dff00 50%);
}

.accessibility-mask {
  position: fixed;
  left: 0;
  width: 100%;
  z-index: 1500;
  background: rgba(7, 10, 18, 0.68);
  pointer-events: none;
  opacity: 0;
  transition: opacity 180ms ease;
}

.accessibility-mask--top {
  top: 0;
  height: max(var(--a11y-mask-y, 50vh) - 80px, 0px);
  border-bottom: 2px solid rgba(var(--color-bg), 0.9);
}

.accessibility-mask--bottom {
  top: calc(var(--a11y-mask-y, 50vh) + 80px);
  bottom: 0;
  border-top: 2px solid rgba(var(--color-bg), 0.9);
}

body.a11y-reading-mask .accessibility-mask {
  opacity: 1;
}

html.a11y-font-large {
  font-size: 112.5%;
}

html.a11y-font-xlarge {
  font-size: 125%;
}

body.a11y-night-mode,
body.a11y-night-mode .site-layout {
  background: #f5f5f7 !important;
  color: #0f172a !important;
}

body.a11y-night-mode .site-layout::before,
body.a11y-night-mode .freelance-compare::before,
body.a11y-night-mode .freelance-compare::after {
  display: none !important;
}

body.a11y-night-mode .navbar,
body.a11y-night-mode .footer,
body.a11y-night-mode .conversion-topbar,
body.a11y-night-mode .contact-section,
body.a11y-night-mode #contact,
body.a11y-night-mode .layout-card,
body.a11y-night-mode .card,
body.a11y-night-mode .dropdown-menu,
body.a11y-night-mode .freelance-compare,
body.a11y-night-mode .freelance-compare__card,
body.a11y-night-mode .blog-card,
body.a11y-night-mode .blog-detail,
body.a11y-night-mode .project-detail,
body.a11y-night-mode .project-detail-image,
body.a11y-night-mode .project-preview-card {
  background: #ffffff !important;
  color: #0f172a !important;
  border-color: rgba(15, 23, 42, 0.12) !important;
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.08) !important;
}

body.a11y-night-mode .navbar::before,
body.a11y-night-mode .footer::before {
  display: none !important;
}

body.a11y-night-mode .navbar-brand,
body.a11y-night-mode .navbar-brand span,
body.a11y-night-mode .navbar-toggler,
body.a11y-night-mode .nav-link,
body.a11y-night-mode .dropdown-item,
body.a11y-night-mode .footer a,
body.a11y-night-mode h1,
body.a11y-night-mode h2,
body.a11y-night-mode h3,
body.a11y-night-mode h4,
body.a11y-night-mode h5,
body.a11y-night-mode h6,
body.a11y-night-mode p,
body.a11y-night-mode li,
body.a11y-night-mode span,
body.a11y-night-mode strong,
body.a11y-night-mode small,
body.a11y-night-mode .content-page,
body.a11y-night-mode .blog-filter-count,
body.a11y-night-mode .contact-aside-link,
body.a11y-night-mode .contact-aside-icon,
body.a11y-night-mode .conversion-topbar__item,
body.a11y-night-mode .footer .text-muted,
body.a11y-night-mode .footer p,
body.a11y-night-mode .footer .col-md-4.text-center p {
  color: #0f172a !important;
}

body.a11y-night-mode .brand-logo,
body.a11y-night-mode .navbar-toggler-icon {
  filter: brightness(0) saturate(100%) !important;
}

body.a11y-night-mode .contact-form .form-control {
  background: #ffffff !important;
  color: #0f172a !important;
  border-color: rgba(15, 23, 42, 0.18) !important;
}

body.a11y-night-mode .contact-form .form-control::placeholder {
  color: rgba(15, 23, 42, 0.48) !important;
}

body.a11y-night-mode .contact-submit-btn,
body.a11y-night-mode .footer-legal-link,
body.a11y-night-mode .blog-filter-chip,
body.a11y-night-mode .blog-card-cta,
body.a11y-night-mode .nav-link.nav-cta {
  color: #0f172a !important;
  border-color: rgba(15, 23, 42, 0.18) !important;
}

body.a11y-contrast-1 {
  --a11y-contrast-bg: #000000;
  --a11y-contrast-surface: #000000;
  --a11y-contrast-text: #ffffff;
  --a11y-contrast-accent: #ffffff;
  --a11y-contrast-outline: rgba(255, 255, 255, 0.95);
}

body.a11y-contrast-2 {
  --a11y-contrast-bg: #ffffff;
  --a11y-contrast-surface: #ffffff;
  --a11y-contrast-text: #000000;
  --a11y-contrast-accent: #000000;
  --a11y-contrast-outline: rgba(0, 0, 0, 0.92);
}

body.a11y-contrast-3 {
  --a11y-contrast-bg: #2452aa;
  --a11y-contrast-surface: #2452aa;
  --a11y-contrast-text: #fff300;
  --a11y-contrast-accent: #fff300;
  --a11y-contrast-outline: rgba(255, 243, 0, 0.92);
}

body.a11y-contrast-4 {
  --a11y-contrast-bg: #a80000;
  --a11y-contrast-surface: #a80000;
  --a11y-contrast-text: #39ff14;
  --a11y-contrast-accent: #39ff14;
  --a11y-contrast-outline: rgba(57, 255, 20, 0.95);
}

body.a11y-contrast-1,
body.a11y-contrast-2,
body.a11y-contrast-3,
body.a11y-contrast-4 {
  background: var(--a11y-contrast-bg) !important;
  color: var(--a11y-contrast-text) !important;
}

body.a11y-contrast-1 .site-layout,
body.a11y-contrast-2 .site-layout,
body.a11y-contrast-3 .site-layout,
body.a11y-contrast-4 .site-layout,
body.a11y-contrast-1 .navbar,
body.a11y-contrast-2 .navbar,
body.a11y-contrast-3 .navbar,
body.a11y-contrast-4 .navbar,
body.a11y-contrast-1 .footer,
body.a11y-contrast-2 .footer,
body.a11y-contrast-3 .footer,
body.a11y-contrast-4 .footer,
body.a11y-contrast-1 .conversion-topbar,
body.a11y-contrast-2 .conversion-topbar,
body.a11y-contrast-3 .conversion-topbar,
body.a11y-contrast-4 .conversion-topbar,
body.a11y-contrast-1 .contact-section,
body.a11y-contrast-2 .contact-section,
body.a11y-contrast-3 .contact-section,
body.a11y-contrast-4 .contact-section,
body.a11y-contrast-1 #contact,
body.a11y-contrast-2 #contact,
body.a11y-contrast-3 #contact,
body.a11y-contrast-4 #contact,
body.a11y-contrast-1 .card,
body.a11y-contrast-2 .card,
body.a11y-contrast-3 .card,
body.a11y-contrast-4 .card,
body.a11y-contrast-1 .layout-card,
body.a11y-contrast-2 .layout-card,
body.a11y-contrast-3 .layout-card,
body.a11y-contrast-4 .layout-card,
body.a11y-contrast-1 .dropdown-menu,
body.a11y-contrast-2 .dropdown-menu,
body.a11y-contrast-3 .dropdown-menu,
body.a11y-contrast-4 .dropdown-menu,
body.a11y-contrast-1 .freelance-compare,
body.a11y-contrast-2 .freelance-compare,
body.a11y-contrast-3 .freelance-compare,
body.a11y-contrast-4 .freelance-compare,
body.a11y-contrast-1 .freelance-compare__card,
body.a11y-contrast-2 .freelance-compare__card,
body.a11y-contrast-3 .freelance-compare__card,
body.a11y-contrast-4 .freelance-compare__card {
  background: var(--a11y-contrast-surface) !important;
  color: var(--a11y-contrast-text) !important;
  border: 1px dashed var(--a11y-contrast-outline) !important;
  box-shadow: none !important;
}

body.a11y-contrast-1 .site-layout::before,
body.a11y-contrast-2 .site-layout::before,
body.a11y-contrast-3 .site-layout::before,
body.a11y-contrast-4 .site-layout::before,
body.a11y-contrast-1 .freelance-compare::before,
body.a11y-contrast-2 .freelance-compare::before,
body.a11y-contrast-3 .freelance-compare::before,
body.a11y-contrast-4 .freelance-compare::before,
body.a11y-contrast-1 .freelance-compare::after,
body.a11y-contrast-2 .freelance-compare::after,
body.a11y-contrast-3 .freelance-compare::after,
body.a11y-contrast-4 .freelance-compare::after {
  display: none !important;
}

body.a11y-contrast-1 a,
body.a11y-contrast-2 a,
body.a11y-contrast-3 a,
body.a11y-contrast-4 a,
body.a11y-contrast-1 p,
body.a11y-contrast-2 p,
body.a11y-contrast-3 p,
body.a11y-contrast-4 p,
body.a11y-contrast-1 li,
body.a11y-contrast-2 li,
body.a11y-contrast-3 li,
body.a11y-contrast-4 li,
body.a11y-contrast-1 span,
body.a11y-contrast-2 span,
body.a11y-contrast-3 span,
body.a11y-contrast-4 span,
body.a11y-contrast-1 strong,
body.a11y-contrast-2 strong,
body.a11y-contrast-3 strong,
body.a11y-contrast-4 strong,
body.a11y-contrast-1 small,
body.a11y-contrast-2 small,
body.a11y-contrast-3 small,
body.a11y-contrast-4 small,
body.a11y-contrast-1 h1,
body.a11y-contrast-2 h1,
body.a11y-contrast-3 h1,
body.a11y-contrast-4 h1,
body.a11y-contrast-1 h2,
body.a11y-contrast-2 h2,
body.a11y-contrast-3 h2,
body.a11y-contrast-4 h2,
body.a11y-contrast-1 h3,
body.a11y-contrast-2 h3,
body.a11y-contrast-3 h3,
body.a11y-contrast-4 h3,
body.a11y-contrast-1 h4,
body.a11y-contrast-2 h4,
body.a11y-contrast-3 h4,
body.a11y-contrast-4 h4,
body.a11y-contrast-1 h5,
body.a11y-contrast-2 h5,
body.a11y-contrast-3 h5,
body.a11y-contrast-4 h5,
body.a11y-contrast-1 h6,
body.a11y-contrast-2 h6,
body.a11y-contrast-3 h6,
body.a11y-contrast-4 h6,
body.a11y-contrast-1 .navbar-brand,
body.a11y-contrast-2 .navbar-brand,
body.a11y-contrast-3 .navbar-brand,
body.a11y-contrast-4 .navbar-brand,
body.a11y-contrast-1 .navbar-toggler,
body.a11y-contrast-2 .navbar-toggler,
body.a11y-contrast-3 .navbar-toggler,
body.a11y-contrast-4 .navbar-toggler,
body.a11y-contrast-1 .nav-link,
body.a11y-contrast-2 .nav-link,
body.a11y-contrast-3 .nav-link,
body.a11y-contrast-4 .nav-link,
body.a11y-contrast-1 .dropdown-item,
body.a11y-contrast-2 .dropdown-item,
body.a11y-contrast-3 .dropdown-item,
body.a11y-contrast-4 .dropdown-item,
body.a11y-contrast-1 .footer a,
body.a11y-contrast-2 .footer a,
body.a11y-contrast-3 .footer a,
body.a11y-contrast-4 .footer a,
body.a11y-contrast-1 .conversion-topbar__item,
body.a11y-contrast-2 .conversion-topbar__item,
body.a11y-contrast-3 .conversion-topbar__item,
body.a11y-contrast-4 .conversion-topbar__item {
  color: var(--a11y-contrast-text) !important;
}

body.a11y-contrast-1 .brand-logo,
body.a11y-contrast-2 .brand-logo,
body.a11y-contrast-3 .brand-logo,
body.a11y-contrast-4 .brand-logo,
body.a11y-contrast-1 .navbar-toggler-icon,
body.a11y-contrast-2 .navbar-toggler-icon,
body.a11y-contrast-3 .navbar-toggler-icon,
body.a11y-contrast-4 .navbar-toggler-icon {
  filter: grayscale(1) contrast(200%) brightness(1.15) !important;
}

body.a11y-contrast-1 .nav-link,
body.a11y-contrast-2 .nav-link,
body.a11y-contrast-3 .nav-link,
body.a11y-contrast-4 .nav-link,
body.a11y-contrast-1 .dropdown-item,
body.a11y-contrast-2 .dropdown-item,
body.a11y-contrast-3 .dropdown-item,
body.a11y-contrast-4 .dropdown-item,
body.a11y-contrast-1 .footer-legal-link,
body.a11y-contrast-2 .footer-legal-link,
body.a11y-contrast-3 .footer-legal-link,
body.a11y-contrast-4 .footer-legal-link,
body.a11y-contrast-1 .blog-filter-chip,
body.a11y-contrast-2 .blog-filter-chip,
body.a11y-contrast-3 .blog-filter-chip,
body.a11y-contrast-4 .blog-filter-chip,
body.a11y-contrast-1 .contact-submit-btn,
body.a11y-contrast-2 .contact-submit-btn,
body.a11y-contrast-3 .contact-submit-btn,
body.a11y-contrast-4 .contact-submit-btn,
body.a11y-contrast-1 .accessibility-orbit__action,
body.a11y-contrast-2 .accessibility-orbit__action,
body.a11y-contrast-3 .accessibility-orbit__action,
body.a11y-contrast-4 .accessibility-orbit__action,
body.a11y-contrast-1 .accessibility-orbit__option,
body.a11y-contrast-2 .accessibility-orbit__option,
body.a11y-contrast-3 .accessibility-orbit__option,
body.a11y-contrast-4 .accessibility-orbit__option,
body.a11y-contrast-1 .floating-action--accessibility,
body.a11y-contrast-2 .floating-action--accessibility,
body.a11y-contrast-3 .floating-action--accessibility,
body.a11y-contrast-4 .floating-action--accessibility,
body.a11y-contrast-1 .floating-action--top,
body.a11y-contrast-2 .floating-action--top,
body.a11y-contrast-3 .floating-action--top,
body.a11y-contrast-4 .floating-action--top {
  background: transparent !important;
  color: var(--a11y-contrast-text) !important;
  border-color: var(--a11y-contrast-outline) !important;
  outline: 1px dashed var(--a11y-contrast-outline);
  outline-offset: -2px;
  box-shadow: none !important;
}

body.a11y-contrast-1 .contact-form .form-control,
body.a11y-contrast-2 .contact-form .form-control,
body.a11y-contrast-3 .contact-form .form-control,
body.a11y-contrast-4 .contact-form .form-control {
  background: transparent !important;
  color: var(--a11y-contrast-text) !important;
  border: 1px dashed var(--a11y-contrast-outline) !important;
}

body.a11y-contrast-1 .contact-form .form-control::placeholder,
body.a11y-contrast-2 .contact-form .form-control::placeholder,
body.a11y-contrast-3 .contact-form .form-control::placeholder,
body.a11y-contrast-4 .contact-form .form-control::placeholder {
  color: var(--a11y-contrast-text) !important;
  opacity: 0.7;
}

body.a11y-contrast-1 i,
body.a11y-contrast-2 i,
body.a11y-contrast-3 i,
body.a11y-contrast-4 i,
body.a11y-contrast-1 .first-letter-accent,
body.a11y-contrast-2 .first-letter-accent,
body.a11y-contrast-3 .first-letter-accent,
body.a11y-contrast-4 .first-letter-accent {
  color: var(--a11y-contrast-accent) !important;
}

body.a11y-hide-images img,
body.a11y-hide-images picture,
body.a11y-hide-images video,
body.a11y-hide-images canvas,
body.a11y-hide-images .blog-card-media,
body.a11y-hide-images .blog-detail-media,
body.a11y-hide-images .project-detail-image,
body.a11y-hide-images .project-detail-image-link,
body.a11y-hide-images .reference-project-image,
body.a11y-hide-images .hero-image-shell,
body.a11y-hide-images .hero-media,
body.a11y-hide-images .hero-visual,
body.a11y-hide-images .hero-artwork,
body.a11y-hide-images .project-preview-media,
body.a11y-hide-images .blog-media {
  opacity: 0 !important;
  visibility: hidden !important;
  background-image: none !important;
}

body.a11y-hide-images .blog-card-media,
body.a11y-hide-images .blog-detail-media,
body.a11y-hide-images .project-detail-image,
body.a11y-hide-images .project-detail-image-link,
body.a11y-hide-images .reference-project-image,
body.a11y-hide-images .hero-image-shell,
body.a11y-hide-images .hero-media,
body.a11y-hide-images .hero-visual,
body.a11y-hide-images .hero-artwork,
body.a11y-hide-images .project-preview-media,
body.a11y-hide-images .blog-media {
  display: none !important;
}

body.a11y-hide-images [style*=background-image] {
  background-image: none !important;
}

@media (max-width: 767.98px) {
  .floating-action--accessibility {
    width: 72px;
    height: 72px;
  }
  .accessibility-orbit.is-open .accessibility-orbit__actions {
    transform: translateX(-78px) scale(1);
  }
  .accessibility-orbit__action {
    width: 64px;
    height: 64px;
  }
  .accessibility-orbit__submenu {
    right: 196px;
    top: 50%;
    gap: 0.55rem;
  }
  .accessibility-orbit__option,
  .accessibility-orbit__swatch {
    min-width: 58px;
    min-height: 58px;
    width: 58px;
    height: 58px;
    padding: 0.75rem;
  }
}
#contact {
  text-align: left;
  padding: clamp(4rem, 8vw, 7rem) 0;
  background-color: var(--color-bg) !important;
}

.contact-section {
  background-color: var(--color-bg) !important;
  padding-bottom: clamp(5rem, 8vw, 7rem);
  height: auto !important;
  z-index: 1200;
}

.site-layout #contact.layout-section,
.site-layout #contact.layout-contact {
  min-height: auto;
  padding: clamp(1rem, 2vw, 3rem) 0;
}

.contact-shell {
  padding: clamp(1.5rem, 2.4vw, 2rem);
}

.contact-shell__intro {
  display: grid;
  gap: 1.2rem;
}

.contact-aside {
  max-width: 560px;
  padding: 0.25rem 0.2rem 0;
}

.contact-form-panel {
  padding: clamp(1.2rem, 2vw, 1.55rem);
}

.contact-aside-link {
  font-size: clamp(1.08rem, 1vw + 0.85rem, 1.22rem);
  line-height: 1.3;
  transition: color 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.contact-aside-link:hover,
.contact-aside-link:focus-visible {
  color: var(--color-accent);
}

.contact-aside-link:hover .contact-aside-icon,
.contact-aside-link:focus-visible .contact-aside-icon {
  color: var(--color-accent);
}

.contact-aside-icon {
  font-size: clamp(1.12rem, 1vw + 0.9rem, 1.35rem);
  width: clamp(1.12rem, 1vw + 0.9rem, 1.35rem);
  text-align: center;
}

.contact-aside-malt {
  width: clamp(18px, 1.2vw, 20px);
  height: clamp(18px, 1.2vw, 20px);
  object-fit: contain;
  transition: opacity 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.contact-aside-link--malt::after {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: clamp(18px, 1.2vw, 20px);
  height: clamp(18px, 1.2vw, 20px);
  transform: translateY(-50%);
  background: var(--color-accent);
  -webkit-mask: url("/assets/ico/malt.svg") center/contain no-repeat;
  mask: url("/assets/ico/malt.svg") center/contain no-repeat;
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.contact-aside-link--malt:hover::after,
.contact-aside-link--malt:focus-visible::after {
  opacity: 1;
}

.contact-aside-link--malt:hover .contact-aside-malt,
.contact-aside-link--malt:focus-visible .contact-aside-malt {
  opacity: 0;
}

.contact-aside-divider {
  border-top: 1px solid rgba(255, 255, 255, 0.18);
}

.contact-aside-qr {
  width: clamp(96px, 9vw, 112px);
  height: clamp(96px, 9vw, 112px);
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.25);
  transition: transform 180ms cubic-bezier(0.22, 1, 0.36, 1), border-color 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.qr-scan-overlay {
  inset: 0;
  opacity: 0;
  pointer-events: none;
  background: transparent;
  transition: opacity 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.qr-scan-line {
  left: -54px;
  right: -54px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(0, 255, 136, 0), rgb(0, 255, 136), rgba(0, 255, 136, 0));
  box-shadow: 0 0 14px rgb(0, 255, 136), 0 0 28px rgba(0, 255, 136, 0.95), 0 0 46px rgba(0, 255, 136, 0.72), 0 0 72px rgba(0, 255, 136, 0.4);
  animation: qr-scan-updown 0.9s ease-in-out infinite alternate;
}

.qr-scan-line--one {
  animation-delay: 0s;
}

.qr-scan-line--two {
  animation-delay: 0.22s;
  opacity: 0.8;
}

.qr-scan-line--three {
  animation-delay: 0.44s;
  opacity: 0.62;
}

@keyframes qr-scan-updown {
  0% {
    top: 12%;
  }
  100% {
    top: 88%;
  }
}
.contact-aside-qr:hover .qr-scan-overlay,
.contact-aside-qr:focus-visible .qr-scan-overlay {
  opacity: 1;
}

.contact-aside-qr-note {
  margin-top: clamp(0.5rem, 1vw, 0.68rem);
  color: var(--color-accent);
  line-height: 1.25;
}

.site-layout #contact .layout-card::before {
  display: none;
}

.btn-accent-pill,
.contact-submit-btn {
  position: relative;
  font-family: inherit;
  font-size: clamp(1rem, 0.9rem + 0.25vw, 1.1rem);
  font-weight: 700;
  border: 1px solid rgba(255, 255, 255, 0.2) !important;
  border-radius: 999px !important;
  background: linear-gradient(140deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01)), rgba(13, 20, 34, 0.82) !important;
  color: var(--color-accent) !important;
  padding: 0.72em 1.1em 0.72em 0.95em !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-width: clamp(12rem, 20vw, 15rem);
  overflow: hidden;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(7, 12, 20, 0.22), inset 0 0 0 1px rgba(255, 255, 255, 0.03);
  transition: transform 0.2s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.2s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.2s cubic-bezier(0.22, 1, 0.36, 1);
}

.btn-accent-pill__icon-wrap,
.contact-submit-btn__icon-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5em;
  height: 1.5em;
  flex: 0 0 auto;
}

.btn-accent-pill__icon-wrap::before,
.contact-submit-btn__icon-wrap::before {
  content: "";
  position: absolute;
  inset: -0.15em;
  pointer-events: none;
  background-image: radial-gradient(circle, color-mix(in srgb, var(--color-accent) 86%, #ffffff 14%) 1px, transparent 1px);
  background-size: 9px 9px;
  opacity: 0;
  transform: scale(0.9);
  transition: opacity 0.28s ease, transform 0.28s ease;
}

.btn-accent-pill__icon-fly,
.contact-submit-btn__icon-fly {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-accent);
  transform-origin: center center;
  transform: rotate(-90deg);
  transition: transform 0.34s ease-in-out;
}

.btn-accent-pill__icon-fly::before,
.contact-submit-btn__icon-fly::before {
  content: "";
  position: absolute;
  left: -1.15em;
  right: 0.15em;
  top: 50%;
  height: 2px;
  transform: translateY(-50%) scaleX(0);
  transform-origin: left center;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--color-accent) 75%, #8dfff5 25%), transparent);
  opacity: 0;
  transition: opacity 0.24s ease, transform 0.24s ease;
}

.btn-accent-pill__icon,
.contact-submit-btn__icon {
  font-size: 1.08em;
  line-height: 1;
}

.btn-accent-pill__label,
.contact-submit-btn__label {
  display: inline-block;
  margin-left: 0.05em;
  white-space: nowrap;
  transition: transform 0.34s ease-in-out, opacity 0.34s ease-in-out;
}

.btn-accent-pill:hover .btn-accent-pill__icon-fly,
.btn-accent-pill:focus-visible .btn-accent-pill__icon-fly,
.contact-submit-btn:hover .contact-submit-btn__icon-fly,
.contact-submit-btn:focus-visible .contact-submit-btn__icon-fly {
  transform: translateX(0.38em) rotate(0deg) scale(1.08);
}

.btn-accent-pill:hover .btn-accent-pill__icon-fly::before,
.btn-accent-pill:focus-visible .btn-accent-pill__icon-fly::before,
.contact-submit-btn:hover .contact-submit-btn__icon-fly::before,
.contact-submit-btn:focus-visible .contact-submit-btn__icon-fly::before {
  opacity: 0.85;
  transform: translateY(-50%) scaleX(1);
  animation: contact-submit-trail 0.58s ease-in-out infinite alternate;
}

.btn-accent-pill:hover .btn-accent-pill__icon-wrap::before,
.btn-accent-pill:focus-visible .btn-accent-pill__icon-wrap::before,
.contact-submit-btn:hover .contact-submit-btn__icon-wrap::before,
.contact-submit-btn:focus-visible .contact-submit-btn__icon-wrap::before {
  opacity: 0.42;
  transform: scale(1);
  animation: contact-submit-sparkle 0.9s linear infinite;
}

.btn-accent-pill:hover .btn-accent-pill__icon,
.btn-accent-pill:focus-visible .btn-accent-pill__icon,
.contact-submit-btn:hover .contact-submit-btn__icon,
.contact-submit-btn:focus-visible .contact-submit-btn__icon {
  animation: contact-submit-fly 0.6s ease-in-out infinite alternate;
}

.btn-accent-pill:hover .btn-accent-pill__label,
.btn-accent-pill:focus-visible .btn-accent-pill__label,
.contact-submit-btn:hover .contact-submit-btn__label,
.contact-submit-btn:focus-visible .contact-submit-btn__label {
  transform: translateX(0.14em);
  opacity: 1;
}

.btn-accent-pill:hover,
.btn-accent-pill:focus-visible,
.contact-submit-btn:hover,
.contact-submit-btn:focus-visible {
  border-color: rgba(var(--color-bg), 0.46) !important;
  box-shadow: 0 10px 24px rgba(7, 12, 20, 0.22), inset 0 0 0 1px rgba(255, 255, 255, 0.03);
}

.btn-accent-pill:active,
.contact-submit-btn:active {
  transform: scale(0.95);
}

.btn-accent-pill:active .btn-accent-pill__icon-fly,
.btn-accent-pill.is-submitting .btn-accent-pill__icon-fly,
.contact-submit-btn:active .contact-submit-btn__icon-fly,
.contact-submit-btn.is-submitting .contact-submit-btn__icon-fly {
  transform: translateX(3.2em) rotate(0deg) scale(1.08);
}

.btn-accent-pill:active .btn-accent-pill__label,
.btn-accent-pill.is-submitting .btn-accent-pill__label,
.contact-submit-btn:active .contact-submit-btn__label,
.contact-submit-btn.is-submitting .contact-submit-btn__label {
  transform: translateX(220%);
  opacity: 0;
}

.btn-accent-pill:disabled,
.contact-submit-btn:disabled {
  opacity: 0.78;
  cursor: not-allowed;
}

@keyframes contact-submit-fly {
  from {
    transform: translateY(0.08em);
  }
  to {
    transform: translateY(-0.08em);
  }
}
@keyframes contact-submit-trail {
  from {
    opacity: 0.55;
    transform: translateY(-50%) scaleX(0.82);
  }
  to {
    opacity: 0.95;
    transform: translateY(-50%) scaleX(1.15);
  }
}
@keyframes contact-submit-sparkle {
  from {
    background-position: 0 0;
  }
  to {
    background-position: 9px -12px;
  }
}
.contact-form .form-control {
  border-radius: 4px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: #222837 !important;
  color: var(--color-text) !important;
  padding: clamp(0.76rem, 1vw + 0.4rem, 0.9rem) clamp(0.82rem, 1vw + 0.5rem, 1rem);
  box-shadow: none;
  transition: border-color 180ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 180ms cubic-bezier(0.22, 1, 0.36, 1), background 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.contact-form .form-control::placeholder {
  color: rgba(255, 255, 255, 0.5);
}

.contact-form .form-control:focus {
  border-color: var(--color-accent);
  background: #252c3d !important;
  box-shadow: 0 0 0 1px rgba(var(--color-bg), 0.55), 0 0 0 0.2rem rgba(var(--color-bg), 0.14);
}

.site-layout #contact.layout-section .container {
  max-width: 1540px;
}

/* Status modal */
.status-modal {
  z-index: 11000;
  background: rgba(13, 18, 27, 0.25);
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 280ms cubic-bezier(0.22, 1, 0.36, 1);
}

.status-modal.active {
  opacity: 1;
  visibility: visible;
}

.status-modal__glass {
  width: min(520px, 100% - 28px);
  border-radius: 22px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 24px 54px rgba(15, 23, 42, 0.18);
  padding: clamp(0.9rem, 1vw, 1rem) clamp(1rem, 1.4vw, 1.2rem);
  gap: clamp(0.65rem, 1vw, 0.75rem);
  transform: translateY(14px);
  transition: transform 280ms cubic-bezier(0.22, 1, 0.36, 1);
}

.status-modal.active .status-modal__glass {
  transform: translateY(0);
}

.status-modal__icon {
  width: clamp(2rem, 2vw + 1.2rem, 2.35rem);
  height: clamp(2rem, 2vw + 1.2rem, 2.35rem);
  font-size: clamp(1rem, 1vw + 0.7rem, 1.18rem);
}

.status-modal__text {
  margin: 0;
  color: var(--color-text);
}

.status-modal--success .status-modal__icon {
  background: rgba(20, 155, 82, 0.18);
  color: #197d4a;
  border: 1px solid rgba(20, 155, 82, 0.4);
}

@media (max-width: 991.98px) {
  .site-layout #contact.layout-section {
    padding: 34px 0 30px;
    min-height: auto;
  }
  .contact-form .form-control,
  .contact-form .form-control-lg {
    font-size: 1rem;
    padding: 0.82rem 0.9rem;
  }
  .contact-form textarea.form-control {
    min-height: 150px;
  }
  .contact-form .mb-3 {
    margin-bottom: 0.85rem !important;
  }
  .site-layout #contact.layout-section .container {
    padding-left: 12px;
    padding-right: 12px;
  }
  .contact-aside {
    max-width: none;
  }
}
@media (max-width: 767.98px) {
  .site-layout #contact.layout-section {
    padding: 24px 0 22px;
  }
  .contact-form .form-control,
  .contact-form .form-control-lg {
    font-size: 0.96rem;
    padding: 0.76rem 0.82rem;
  }
  .contact-form textarea.form-control {
    min-height: 132px;
  }
  .site-layout #contact.layout-section .container {
    padding-left: 10px;
    padding-right: 10px;
  }
  .contact-aside {
    padding-top: 0.25rem;
  }
  .contact-aside-qr {
    width: 96px;
    height: 96px;
  }
  .contact-submit-btn {
    min-height: 46px;
    padding: 0.72rem 0.95rem;
    width: 100%;
  }
  .contact-aside-link {
    font-size: 1.08rem;
  }
}
@media (max-width: 575.98px) {
  .contact-form .text-end {
    text-align: left !important;
  }
}
.conversion-topbar {
  --conversion-topbar-height: 40px;
  height: var(--conversion-topbar-height);
  z-index: 1085;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  background: var(--color-bg);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.conversion-topbar__inner {
  max-width: 1380px;
  padding: 0 1.2rem;
}

.conversion-topbar__rotator {
  min-height: 1.45rem;
}

.conversion-topbar__item {
  gap: 0.45rem;
  color: rgba(255, 255, 255, 0.9);
  transform: translate(-50%, -50%);
  will-change: transform, opacity;
  transition: color 180ms ease;
}

.conversion-topbar__item.is-active {
  animation: conversion-topbar-slide 2500ms linear both;
}

.conversion-topbar__item:hover,
.conversion-topbar__item:focus-visible {
  color: var(--color-accent);
}

.conversion-topbar__item i {
  color: var(--color-accent);
}

.conversion-topbar__item .fa-phone-flip {
  transform: scaleX(-1);
}

@keyframes conversion-topbar-slide {
  0% {
    opacity: 0;
    transform: translate(calc(-50% + 68px), -50%);
  }
  16% {
    opacity: 1;
    transform: translate(-50%, -50%);
  }
  68% {
    opacity: 1;
    transform: translate(-50%, -50%);
  }
  100% {
    opacity: 0;
    transform: translate(calc(-50% - 68px), -50%);
  }
}
@media (max-width: 991.98px) {
  .conversion-topbar {
    --conversion-topbar-height: 36px;
  }
}
@media (max-width: 767.98px) {
  .conversion-topbar {
    --conversion-topbar-height: 34px;
  }
  .conversion-topbar__inner {
    padding: 0 0.72rem;
  }
  .conversion-topbar__item {
    max-width: 94%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}
.cookie-consent {
  z-index: 2000;
  pointer-events: none;
}

.cookie-consent.is-open {
  pointer-events: auto;
}

.cookie-consent__panel {
  width: min(1280px, 100% - 2rem);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 12px;
  background: rgba(25, 27, 36, 0.98);
  color: var(--color-text);
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.45);
  grid-template-columns: minmax(0, 1fr) minmax(220px, 260px);
  gap: 1.2rem;
}

.cookie-consent__content {
  min-width: 0;
}

.cookie-consent__title {
  margin: 0 0 0.45rem;
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--color-text);
}

.cookie-consent__text {
  margin: 0;
  color: var(--color-text-muted);
  line-height: 1.5;
}

.cookie-consent__categories {
  margin-top: 1rem;
  gap: 0.75rem 1.25rem;
}

.cookie-consent__category {
  gap: 0.6rem;
  font-weight: 700;
  color: var(--color-text);
}

.cookie-consent__switch {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 58px;
  height: 32px;
}

.cookie-consent__switch input {
  position: absolute;
  width: 0;
  height: 0;
  opacity: 0;
}

.cookie-consent__slider {
  position: absolute;
  inset: 0;
  display: block;
  cursor: pointer;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 999px;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.28);
  transition: background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.cookie-consent__slider::before {
  content: "";
  position: absolute;
  width: 24px;
  height: 24px;
  left: 3px;
  top: 3px;
  border-radius: 50%;
  background: #f8fafc;
  box-shadow: 0 1px 6px rgba(0, 0, 0, 0.28);
  transition: transform 0.2s ease, background 0.2s ease;
}

.cookie-consent__switch input:checked + .cookie-consent__slider {
  background: rgba(var(--color-bg), 0.22);
  border-color: var(--color-accent);
  box-shadow: inset 0 0 0 1px rgba(var(--color-bg), 0.16), 0 0 14px rgba(var(--color-bg), 0.12);
}

.cookie-consent__switch input:checked + .cookie-consent__slider::before {
  transform: translateX(26px);
  background: var(--color-accent);
}

.cookie-consent__switch input:disabled + .cookie-consent__slider {
  background: rgba(var(--color-bg), 0.18);
  border-color: var(--color-accent);
  cursor: not-allowed;
  opacity: 1;
}

.cookie-consent__switch input:focus-visible + .cookie-consent__slider {
  box-shadow: 0 0 0 2px rgba(56, 234, 178, 0.34);
}

.cookie-consent__actions {
  align-content: start;
}

.cookie-consent__btn {
  min-height: 48px;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.9);
  background: var(--color-bg);
  color: var(--color-text);
  font-weight: 700;
  padding: 0.65rem 0.8rem;
  transition: background 0.2s ease, color 0.2s ease;
}

.cookie-consent__btn:hover,
.cookie-consent__btn:focus-visible {
  background: var(--color-bg);
  border-color: var(--color-accent);
  color: var(--color-accent);
}

.cookie-consent__btn--primary {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: #101722;
}

.cookie-consent__btn--primary:hover,
.cookie-consent__btn--primary:focus-visible {
  background: var(--color-bg);
  border-color: var(--color-accent);
  color: var(--color-accent);
}

@media (max-width: 991.98px) {
  .cookie-consent {
    padding: 0.75rem;
  }
  .cookie-consent__panel {
    width: calc(100% - 1.5rem);
    grid-template-columns: 1fr;
    gap: 0.9rem;
  }
  .cookie-consent__actions {
    grid-template-columns: 1fr;
  }
  .cookie-consent__categories {
    gap: 0.65rem 1rem;
  }
}
.footer {
  flex-shrink: 0;
  visibility: visible !important;
  color: rgba(255, 255, 255, 0.88) !important;
  z-index: 10;
  border: none !important;
  border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
  background: var(--color-bg) !important;
  box-shadow: none;
  padding: 1rem 2rem !important;
}

.footer a {
  background: transparent !important;
  color: var(--color-text) !important;
  border: none !important;
  box-shadow: none !important;
  text-decoration: none;
  transition: color 180ms cubic-bezier(0.22, 1, 0.36, 1), background 180ms cubic-bezier(0.22, 1, 0.36, 1), opacity 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.footer-legal-link {
  appearance: none;
  border: none;
  background: transparent;
  color: inherit;
  font: inherit;
  cursor: pointer;
  transition: background 180ms cubic-bezier(0.22, 1, 0.36, 1), color 180ms cubic-bezier(0.22, 1, 0.36, 1), transform 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.footer a:hover,
.footer a.active {
  background: transparent !important;
  border: none !important;
  opacity: 0.82;
}

.footer .text-muted,
.footer p,
.footer .col-md-4.text-center p {
  color: rgba(255, 255, 255, 0.88) !important;
}

.footer .container {
  padding-left: clamp(12px, 3vw, 30px);
  padding-right: clamp(12px, 3vw, 30px);
}

.partner-logo svg {
  opacity: 0.75;
  transition: opacity 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.partner-logo:hover svg {
  opacity: 1;
}

.partner-logo .hubyte-text {
  fill: #ffffff !important;
}

.partner-logo .hubyte-box {
  fill: rgb(27, 103, 190) !important;
}

@media (max-width: 991.98px) {
  .footer .col-md-4.text-center p {
    white-space: normal;
  }
}
@media (max-width: 575.98px) {
  .footer {
    min-height: 72px;
  }
}
.footer .footer-legal-link:hover,
.footer .footer-legal-link:focus-visible {
  opacity: 1;
  color: var(--color-accent) !important;
  background: transparent !important;
  transform: translateY(0);
}

.footer .footer-legal-link[href$="imprint.php"],
.footer .footer-legal-link[href$="privacy-policy.php"] {
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.floating-actions {
  position: fixed;
  right: 20px;
  bottom: 100px;
  z-index: 1100;
}
@media (max-width: 767.98px) {
  .floating-actions {
    bottom: 24px;
    right: 14px;
  }
}

.floating-action {
  border: 1px solid rgba(255, 255, 255, 0.22);
  background: var(--color-bg);
  border-radius: 999px;
  min-width: 50px;
  min-height: 50px;
  cursor: pointer;
  transition: opacity 180ms cubic-bezier(0.22, 1, 0.36, 1), transform 180ms cubic-bezier(0.22, 1, 0.36, 1), border-color 180ms cubic-bezier(0.22, 1, 0.36, 1), color 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.floating-action--top {
  width: 64px;
  height: 122px;
  min-width: 64px;
  min-height: 122px;
  padding: 0;
  border: 0;
  background: transparent;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(10px);
  filter: blur(2px);
  transition: opacity 320ms cubic-bezier(0.22, 1, 0.36, 1), transform 320ms cubic-bezier(0.22, 1, 0.36, 1), filter 320ms cubic-bezier(0.22, 1, 0.36, 1), visibility 0ms linear 320ms;
}

.floating-action--top.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
  filter: blur(0);
  transition: opacity 220ms cubic-bezier(0.22, 1, 0.36, 1), transform 220ms cubic-bezier(0.22, 1, 0.36, 1), filter 220ms cubic-bezier(0.22, 1, 0.36, 1), visibility 0ms linear 0ms;
}

.floating-action:hover,
.floating-action:focus-visible {
  color: var(--color-accent) !important;
  border-color: var(--color-accent);
  transform: translateY(-2px);
}

.cosmic-scroll-top {
  position: relative;
  transform-style: preserve-3d;
  perspective: 500px;
}

.cosmic-scroll-top__slider {
  position: absolute;
  inset: 0;
  border-radius: 35px;
  overflow: hidden;
  background: linear-gradient(180deg, #1a1a2e, #16213e);
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.45), inset 0 0 15px rgba(255, 255, 255, 0.04);
  transition: 0.5s;
  transform-style: preserve-3d;
}

.cosmic-scroll-top__cosmos {
  position: absolute;
  inset: 0;
  background: radial-gradient(1px 1px at 14% 10%, #fff 100%, transparent), radial-gradient(1px 1px at 24% 24%, #fff 100%, transparent), radial-gradient(2px 2px at 36% 34%, #fff 100%, transparent), radial-gradient(1px 1px at 60% 24%, #fff 100%, transparent), radial-gradient(2px 2px at 70% 45%, #fff 100%, transparent), radial-gradient(1px 1px at 78% 66%, #fff 100%, transparent), radial-gradient(1px 1px at 48% 80%, #fff 100%, transparent);
  background-size: 200% 200%;
  opacity: 0.12;
  transition: 0.5s;
}

.cosmic-scroll-top__orb {
  position: absolute;
  left: 4px;
  bottom: 4px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(145deg, color-mix(in srgb, var(--color-accent) 38%, #1a2334 62%), color-mix(in srgb, var(--color-accent) 28%, #0f1623 72%));
  z-index: 2;
  transition: 0.6s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  transform-style: preserve-3d;
}

.cosmic-scroll-top__inner-orb {
  position: absolute;
  inset: 5px;
  border-radius: 50%;
  background: linear-gradient(145deg, #2a3448, #161f30);
  overflow: hidden;
}

.cosmic-scroll-top__inner-orb::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-conic-gradient(from 0deg, transparent 0deg, rgba(0, 0, 0, 0.1) 10deg, transparent 20deg);
  animation: cosmicPatternRotate 10s linear infinite;
}

.cosmic-scroll-top__inner-orb i {
  position: absolute;
  inset: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: color-mix(in srgb, var(--color-accent) 95%, #ecfff7 5%);
  font-size: 1.1rem;
  z-index: 1;
}

.cosmic-scroll-top__ring {
  position: absolute;
  inset: -3px;
  border: 2px solid rgba(255, 255, 255, 0.12);
  border-radius: 50%;
  transition: 0.5s;
}

.cosmic-scroll-top__energy-line {
  position: absolute;
  top: 0;
  width: 2px;
  height: 100%;
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--color-accent) 72%, #60fff0 28%), transparent);
  transform-origin: top;
  opacity: 0;
}

.cosmic-scroll-top__energy-line:nth-of-type(2) {
  left: 26%;
  transform: rotate(0deg);
}

.cosmic-scroll-top__energy-line:nth-of-type(3) {
  left: 50%;
  transform: rotate(0deg);
}

.cosmic-scroll-top__energy-line:nth-of-type(4) {
  left: 74%;
  transform: rotate(0deg);
}

.cosmic-scroll-top__particles {
  position: absolute;
  inset: 0;
}

.cosmic-scroll-top__particle {
  position: absolute;
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: color-mix(in srgb, var(--color-accent) 78%, #82fff4 22%);
  opacity: 0;
}

.cosmic-scroll-top__particle:nth-child(1) {
  left: 20%;
  top: 34%;
  animation-delay: 0s;
}

.cosmic-scroll-top__particle:nth-child(2) {
  left: 40%;
  top: 42%;
  animation-delay: 0.2s;
}

.cosmic-scroll-top__particle:nth-child(3) {
  left: 58%;
  top: 36%;
  animation-delay: 0.4s;
}

.cosmic-scroll-top__particle:nth-child(4) {
  left: 72%;
  top: 50%;
  animation-delay: 0.6s;
}

.cosmic-scroll-top__particle:nth-child(5) {
  left: 34%;
  top: 62%;
  animation-delay: 0.8s;
}

.cosmic-scroll-top__particle:nth-child(6) {
  left: 64%;
  top: 68%;
  animation-delay: 1s;
}

.floating-action--top.is-visible:hover .cosmic-scroll-top__slider,
.floating-action--top.is-visible:focus-visible .cosmic-scroll-top__slider {
  transform: rotateX(7deg) rotateY(7deg);
}

.floating-action--top.is-visible:hover .cosmic-scroll-top__orb,
.floating-action--top.is-visible:focus-visible .cosmic-scroll-top__orb {
  filter: brightness(1.15);
  box-shadow: 0 0 20px color-mix(in srgb, var(--color-accent) 72%, #80fff4 28%), 0 0 40px color-mix(in srgb, var(--color-accent) 45%, #80fff4 55%);
}

.floating-action--top.is-launching .cosmic-scroll-top__orb {
  animation: cosmicOrbLaunch 460ms cubic-bezier(0.68, -0.55, 0.265, 1.55) forwards;
}

.floating-action--top.is-visible:hover .cosmic-scroll-top__ring,
.floating-action--top.is-visible:focus-visible .cosmic-scroll-top__ring {
  border-color: color-mix(in srgb, var(--color-accent) 64%, #80fff4 36%);
  animation: cosmicRingPulse 2s infinite;
}

.floating-action--top.is-visible:hover .cosmic-scroll-top__energy-line,
.floating-action--top.is-visible:focus-visible .cosmic-scroll-top__energy-line {
  opacity: 1;
  animation: cosmicEnergyFlow 2s linear infinite;
}

.floating-action--top.is-visible:hover .cosmic-scroll-top__particle,
.floating-action--top.is-visible:focus-visible .cosmic-scroll-top__particle {
  animation: cosmicParticleBurst 1s ease-out infinite;
}

.floating-action--top.is-visible:hover .cosmic-scroll-top__cosmos,
.floating-action--top.is-visible:focus-visible .cosmic-scroll-top__cosmos {
  opacity: 0.24;
  animation: cosmicPan 20s linear infinite;
}

@keyframes cosmicRingPulse {
  0%, 100% {
    transform: scale(1);
    opacity: 0.3;
  }
  50% {
    transform: scale(1.1);
    opacity: 0.62;
  }
}
@keyframes cosmicPatternRotate {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
@keyframes cosmicEnergyFlow {
  0% {
    transform: scaleX(0) translateX(0);
    opacity: 0;
  }
  50% {
    transform: scaleX(1) translateX(50%);
    opacity: 1;
  }
  100% {
    transform: scaleX(0) translateX(100%);
    opacity: 0;
  }
}
@keyframes cosmicParticleBurst {
  0% {
    transform: translate(0, 0) scale(1);
    opacity: 1;
  }
  100% {
    transform: translate(12px, -18px) scale(0);
    opacity: 0;
  }
}
@keyframes cosmicPan {
  0% {
    background-position: 0% 0%;
  }
  100% {
    background-position: 200% 200%;
  }
}
@keyframes cosmicOrbLaunch {
  0% {
    transform: translateY(0) rotate(0deg);
  }
  42% {
    transform: translateY(0) rotate(360deg);
  }
  100% {
    transform: translateY(-58px) rotate(360deg);
  }
}
@media (prefers-reduced-motion: reduce) {
  .cosmic-scroll-top__inner-orb::before {
    animation: none;
  }
  .floating-action--top.is-visible:hover .cosmic-scroll-top__orb,
  .floating-action--top.is-visible:focus-visible .cosmic-scroll-top__orb {
    transform: translateY(-38px);
  }
  .floating-action--top.is-launching .cosmic-scroll-top__orb {
    animation: none;
    transform: translateY(-38px);
  }
  .floating-action--top.is-visible:hover .cosmic-scroll-top__energy-line,
  .floating-action--top.is-visible:focus-visible .cosmic-scroll-top__energy-line,
  .floating-action--top.is-visible:hover .cosmic-scroll-top__particle,
  .floating-action--top.is-visible:focus-visible .cosmic-scroll-top__particle,
  .floating-action--top.is-visible:hover .cosmic-scroll-top__cosmos,
  .floating-action--top.is-visible:focus-visible .cosmic-scroll-top__cosmos {
    animation: none;
  }
}
.matrix-text {
  display: inline-block;
}

.matrix-char {
  color: inherit;
  display: inline-block;
  min-width: 0.62ch;
}

.matrix-char--final {
  color: inherit;
}

.matrix-char--rand {
  color: var(--color-accent);
  text-shadow: 0 0 12px var(--color-accent);
}

.navbar-brand.matrix--active .brand-logo {
  transform: translateY(-1px);
  filter: drop-shadow(0 0 10px rgba(56, 234, 178, 0.42));
}

.navbar-brand.matrix--active .matrix-text {
  font-family: inherit;
}

@keyframes brand-logo-glow {
  0%, 100% {
    filter: drop-shadow(0 0 0 rgba(var(--color-bg), 0));
    transform: translateY(0);
  }
  50% {
    filter: drop-shadow(0 0 12px rgba(var(--color-bg), 0.75));
    transform: translateY(-1px);
  }
}
.navbar {
  position: fixed !important;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  width: min(1380px, 100% - 60px);
  z-index: 1030;
  padding: 0.75rem 1.2rem !important;
  border-radius: 22px !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  background: var(--color-bg) !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.25);
  transition: transform 280ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 280ms cubic-bezier(0.22, 1, 0.36, 1), background 280ms cubic-bezier(0.22, 1, 0.36, 1), border-color 280ms cubic-bezier(0.22, 1, 0.36, 1);
}

.navbar-nav {
  font-size: 1.5rem;
}

.navbar::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 22px;
  pointer-events: none;
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.navbar.scrolled {
  transform: translateX(-50%) translateY(-2px);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.35);
  background: rgba(25, 27, 36, 0.95) !important;
  border-color: rgba(255, 255, 255, 0.1) !important;
}

.has-conversion-topbar .navbar {
  top: calc(var(--conversion-topbar-height, 40px) - 1px) !important;
}

.navbar .container {
  padding: 0 clamp(12px, 3vw, 30px);
}

.navbar-brand {
  color: var(--color-text) !important;
  font-size: 1.42rem;
  transition: color 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.brand-logo {
  height: 39px;
  width: auto;
  filter: none;
  transition: filter 180ms cubic-bezier(0.22, 1, 0.36, 1), transform 180ms cubic-bezier(0.22, 1, 0.36, 1), opacity 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.navbar-brand span {
  font-family: var(--ff-gunplay);
  letter-spacing: 0.7px;
}

.navbar-nav {
  gap: 0.42rem;
}

.navitem-bg {
  background-color: var(--navitem-dropdown-hover) !important;
}

.multi-word-accent .word-accent {
  display: inline-block;
}
.multi-word-accent .word-accent__initial {
  color: var(--color-accent);
  transition: color 180ms cubic-bezier(0.22, 1, 0.36, 1);
}
.multi-word-accent:hover .word-accent__initial, .multi-word-accent:focus-visible .word-accent__initial, .multi-word-accent.active .word-accent__initial {
  color: var(--color-text);
}

.multi-word-accent--reverse {
  color: var(--color-accent) !important;
}
.multi-word-accent--reverse .word-accent__initial {
  color: var(--color-text);
}
.multi-word-accent--reverse:hover, .multi-word-accent--reverse:focus-visible {
  color: var(--color-text) !important;
}
.multi-word-accent--reverse:hover .word-accent__initial, .multi-word-accent--reverse:focus-visible .word-accent__initial {
  color: var(--color-accent);
}

.nav-item-with-menu .dropdown-toggle::after {
  display: none;
}

.dropdown-toggle-icon {
  position: relative;
  display: inline-grid;
  place-items: center;
  width: 1.1em;
  height: 1.1em;
  font-size: 1rem;
  line-height: 1;
}
.dropdown-toggle-icon i {
  grid-area: 1/1;
  transition: opacity 180ms cubic-bezier(0.22, 1, 0.36, 1), transform 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.dropdown-toggle-icon__closed {
  opacity: 1;
  transform: scale(1) rotate(0deg);
}

.dropdown-toggle-icon__open {
  opacity: 0;
  transform: scale(0.84) rotate(-10deg);
}

.dropdown-toggle-split[aria-expanded=true] .dropdown-toggle-icon__closed {
  opacity: 0;
  transform: scale(0.84) rotate(10deg);
}

.dropdown-toggle-split[aria-expanded=true] .dropdown-toggle-icon__open {
  opacity: 1;
  transform: scale(1) rotate(0deg);
}

.navbar .dropdown-menu {
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(25, 27, 36, 0.98);
  min-width: 240px;
  padding: 0.45rem;
  font-size: clamp(0.9rem, 1vw + 0.2rem, 1.2rem);
}

@keyframes navbar-dropdown-reveal {
  0% {
    opacity: 0;
    transform: translateY(14px) scale(0.975);
    filter: blur(4px);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
  }
}
.navbar .dropdown-item {
  color: var(--color-text-muted);
  border-radius: 8px;
  padding: 0.45rem 0.65rem !important;
}

.navbar .dropdown-item.multi-word-accent {
  color: rgba(255, 255, 255, 0.9);
}

.navbar .dropdown-item:hover,
.navbar .dropdown-item:focus-visible {
  background: var(--navitem-dropdown-hover) !important;
  color: var(--bs-white);
}

.navbar .dropdown-item.multi-word-accent:hover,
.navbar .dropdown-item.multi-word-accent:focus-visible {
  color: var(--color-accent);
}

.navbar .dropdown-item.multi-word-accent:hover .word-accent__initial,
.navbar .dropdown-item.multi-word-accent:focus-visible .word-accent__initial {
  color: var(--color-text);
}

@media (min-width: 992px) {
  .navbar .nav-item-with-menu {
    position: relative;
  }
  .navbar .nav-item-with-menu > .nav-link {
    position: relative;
    z-index: 3;
    border-radius: 999px;
    transition: color 180ms cubic-bezier(0.22, 1, 0.36, 1), background 220ms cubic-bezier(0.22, 1, 0.36, 1), border-color 220ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 220ms cubic-bezier(0.22, 1, 0.36, 1);
  }
  .navbar .nav-item-with-menu > .dropdown-menu {
    display: block;
    top: calc(100% - 10px);
    margin-top: 0;
    padding: 0.72rem 0.55rem 0.62rem;
    min-width: min(280px, 42vw);
    border: 1px solid rgba(var(--color-bg), 0.22);
    border-top: 0;
    border-radius: 0 14px 14px 14px;
    background: linear-gradient(180deg, rgba(204, 255, 0, 0.08) 0%, rgba(204, 255, 0, 0) 44%), rgba(8, 12, 20, 0.9);
    box-shadow: 0 22px 44px rgba(0, 0, 0, 0.35);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(10px);
    transform-origin: top center;
    transition: opacity 220ms cubic-bezier(0.22, 1, 0.36, 1), transform 220ms cubic-bezier(0.22, 1, 0.36, 1), visibility 220ms cubic-bezier(0.22, 1, 0.36, 1);
  }
  .navbar .nav-item-with-menu > .dropdown-menu::after {
    content: "";
    position: absolute;
    top: -1px;
    left: 1px;
    right: 1px;
    height: 3px;
    background: rgba(8, 12, 20, 0.94);
    pointer-events: none;
  }
  .navbar .nav-item-with-menu > .dropdown-menu::before {
    content: "";
    position: absolute;
    top: 0.18rem;
    left: 1rem;
    width: 1px;
    height: calc(100% - 0.42rem);
    background: linear-gradient(180deg, rgba(var(--color-bg), 0.45), rgba(255, 255, 255, 0.08));
    opacity: 0.65;
  }
  .navbar .dropdown-item {
    position: relative;
    padding: 0.42rem 0 0.42rem 1.35rem !important;
    border-radius: 0;
    background: transparent;
    color: var(--color-text-muted);
    letter-spacing: 0.03em;
    transition: color 180ms cubic-bezier(0.22, 1, 0.36, 1), transform 180ms cubic-bezier(0.22, 1, 0.36, 1);
  }
  .navbar .dropdown-item::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0.55rem;
    width: 0.42rem;
    height: 1px;
    background: rgba(255, 255, 255, 0.28);
    transform: translateY(-50%);
    transition: width 180ms cubic-bezier(0.22, 1, 0.36, 1), background 180ms cubic-bezier(0.22, 1, 0.36, 1);
  }
  .navbar .nav-item-with-menu:hover > .dropdown-menu,
  .navbar .nav-item-with-menu:focus-within > .dropdown-menu,
  .navbar .nav-item-with-menu:has(> .dropdown-menu.show) > .dropdown-menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
    animation: navbar-dropdown-reveal 280ms cubic-bezier(0.22, 1, 0.36, 1) both;
  }
  .navbar .nav-item-with-menu:hover > .nav-link,
  .navbar .nav-item-with-menu:focus-within > .nav-link,
  .navbar .nav-item-with-menu:has(> .dropdown-menu.show) > .nav-link {
    position: relative;
    background: linear-gradient(180deg, rgba(204, 255, 0, 0.12) 0%, rgba(204, 255, 0, 0.02) 100%), rgba(8, 12, 20, 0.9) !important;
    border: 1px solid rgba(var(--color-bg), 0.22) !important;
    border-bottom-color: transparent !important;
    border-radius: 16px 16px 0 0;
    margin-bottom: -2px;
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
  }
  .navbar .nav-item-with-menu:hover > .nav-link::after,
  .navbar .nav-item-with-menu:focus-within > .nav-link::after,
  .navbar .nav-item-with-menu:has(> .dropdown-menu.show) > .nav-link::after {
    content: "";
    position: absolute;
    left: 1px;
    right: 1px;
    bottom: -3px;
    height: 4px;
    background: rgba(8, 12, 20, 0.9);
    pointer-events: none;
  }
  .navbar .nav-item-with-menu:hover > .nav-link,
  .navbar .nav-item-with-menu:focus-within > .nav-link,
  .navbar .nav-item-with-menu:has(> .dropdown-menu.show) > .nav-link {
    color: var(--color-accent) !important;
  }
  .navbar .nav-item-with-menu:hover > .nav-link::first-letter,
  .navbar .nav-item-with-menu:focus-within > .nav-link::first-letter,
  .navbar .nav-item-with-menu:has(> .dropdown-menu.show) > .nav-link::first-letter {
    color: var(--color-text);
  }
  .navbar .dropdown-item:hover,
  .navbar .dropdown-item:focus-visible {
    background: transparent;
    color: var(--color-accent);
    transform: translateX(4px);
  }
  .navbar .dropdown-item:hover::before,
  .navbar .dropdown-item:focus-visible::before {
    width: 0.7rem;
    background: var(--color-accent);
  }
  .site-layout .dropdown-menu {
    border: none;
    background: transparent;
    box-shadow: none;
  }
  .site-layout .dropdown-item {
    color: var(--color-text);
  }
  .site-layout .dropdown-item:hover,
  .site-layout .dropdown-item:focus-visible {
    background: transparent;
    color: var(--color-accent);
  }
}
@media (min-width: 992px) and (max-width: 1199px) {
  .site-layout .nav-link {
    font-size: 0.96rem;
  }
}
.nav-link {
  color: var(--color-text-muted) !important;
  border-radius: 0;
  padding: 0.48rem 1rem !important;
  letter-spacing: 0.04em;
  transition: color 180ms cubic-bezier(0.22, 1, 0.36, 1), opacity 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.nav-link:hover,
.nav-link:focus-visible {
  color: var(--color-accent) !important;
  background: transparent !important;
  box-shadow: none !important;
  transform: none;
}

.nav-link.active {
  color: var(--color-accent) !important;
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
}

.navbar-toggler {
  border: none;
  border-radius: 0;
  padding: 0.35rem 0.5rem;
  background: transparent !important;
  box-shadow: none !important;
}

.navbar-toggler:focus {
  box-shadow: none !important;
}

.navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255,255,255,1%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2.3' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}

@media (max-width: 991.98px) {
  .navbar {
    width: calc(100% - 24px);
    top: 12px;
  }
  .navbar-brand {
    margin-right: 0 !important;
    min-width: 0;
    max-width: calc(100% - 52px);
  }
  .navbar-brand span {
    font-size: clamp(0.82rem, 3.8vw, 1.08rem);
    letter-spacing: 0.2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: clip;
  }
  .brand-logo {
    height: 29px;
  }
  .navbar-toggler {
    margin-left: 0 !important;
    z-index: 1051;
  }
  .navbar-collapse {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100vw;
    height: 100dvh;
    max-height: 100dvh;
    z-index: 2000;
    padding: 104px 20px 40px;
    background: var(--color-bg);
    overflow-y: auto;
    opacity: 0;
    pointer-events: none;
    transition: opacity 180ms cubic-bezier(0.22, 1, 0.36, 1);
  }
  .navbar-mobile-close {
    top: 18px;
    right: 16px;
    width: 36px;
    height: 36px;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: 10px;
    background: var(--card-color-bg);
    color: rgba(255, 255, 255, 0.88);
    font-size: 1.4rem;
    line-height: 1;
    cursor: pointer;
    transition: color 180ms cubic-bezier(0.22, 1, 0.36, 1), border-color 180ms cubic-bezier(0.22, 1, 0.36, 1), background 180ms cubic-bezier(0.22, 1, 0.36, 1);
  }
  .navbar-mobile-close:hover,
  .navbar-mobile-close:focus-visible {
    color: var(--color-accent);
    border-color: rgba(56, 234, 178, 0.58);
    background: rgba(56, 234, 178, 0.08);
    outline: none;
  }
  .navbar-collapse.show {
    opacity: 1;
    pointer-events: auto;
  }
  .navbar-nav {
    width: 100%;
    gap: 0.55rem;
  }
  .nav-item-with-menu {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    column-gap: 0.25rem;
    width: 100%;
  }
  .nav-item-with-menu > .nav-link:not(.dropdown-toggle-split) {
    min-width: 0;
    margin: 0;
  }
  .nav-item-with-menu .dropdown-toggle-split {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    margin: 0;
    align-self: stretch;
    padding: 1rem 0.9rem !important;
    min-width: 3rem;
  }
  .nav-item-with-menu .dropdown-menu {
    grid-column: 1/-1;
    position: static !important;
    transform: none !important;
    margin-top: 0.15rem;
    width: 100%;
    min-width: 0;
    border: none;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    padding: 0.25rem 0 0.35rem;
  }
  .nav-link {
    margin: 0.12rem 0;
    padding: 1rem 0.9rem !important;
    font-size: clamp(1.45rem, 2vw + 1rem, 2rem);
  }
  .navbar-collapse .nav-link:hover,
  .navbar-collapse .nav-link:focus-visible,
  .navbar-collapse .nav-link.active,
  .navbar-collapse .dropdown-item:hover,
  .navbar-collapse .dropdown-item:focus-visible {
    color: var(--color-accent) !important;
    background: transparent !important;
    box-shadow: none !important;
  }
  .navbar-collapse .nav-item-with-menu:has(.dropdown-toggle-split[aria-expanded=true]) > .nav-link,
  .navbar-collapse .nav-item-with-menu > .nav-link:hover,
  .navbar-collapse .nav-item-with-menu > .nav-link:focus-visible {
    color: var(--color-accent) !important;
  }
  .navbar-collapse .nav-item-with-menu:has(.dropdown-toggle-split[aria-expanded=true]) > .nav-link::first-letter,
  .navbar-collapse .nav-item-with-menu > .nav-link:hover::first-letter,
  .navbar-collapse .nav-item-with-menu > .nav-link:focus-visible::first-letter {
    color: var(--color-text);
  }
  .navbar-collapse .dropdown-item.multi-word-accent {
    position: relative;
    padding: 0.58rem 0 0.58rem 1.35rem !important;
    border-radius: 0;
    background: transparent;
    letter-spacing: 0.03em;
    font-size: clamp(1.2rem, 1.2vw + 0.95rem, 1.55rem);
  }
  .navbar-collapse .dropdown-menu {
    padding: 0.15rem 0 0.35rem;
  }
  .navbar-collapse .dropdown-menu::before {
    content: "";
    position: absolute;
    top: 1.05rem;
    left: 0.95rem;
    width: 1px;
    height: calc(100% - 2rem);
    background: linear-gradient(180deg, rgba(var(--color-bg), 0.45), rgba(255, 255, 255, 0.08));
    opacity: 0.65;
  }
  .navbar-collapse .dropdown-item::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0.55rem;
    width: 0.42rem;
    height: 1px;
    background: rgba(255, 255, 255, 0.28);
    transform: translateY(-50%);
    transition: width 180ms cubic-bezier(0.22, 1, 0.36, 1), background 180ms cubic-bezier(0.22, 1, 0.36, 1);
  }
  .navbar-collapse .dropdown-item.multi-word-accent:hover,
  .navbar-collapse .dropdown-item.multi-word-accent:focus-visible {
    color: var(--color-accent) !important;
    background: transparent !important;
  }
  .navbar-collapse .dropdown-item.multi-word-accent:hover .word-accent__initial,
  .navbar-collapse .dropdown-item.multi-word-accent:focus-visible .word-accent__initial {
    color: var(--color-text);
  }
  .navbar-collapse .dropdown-item:hover::before,
  .navbar-collapse .dropdown-item:focus-visible::before {
    width: 0.7rem;
    background: var(--color-accent);
  }
}
@media (max-width: 575.98px) {
  .navbar {
    padding: 0.62rem 0.85rem !important;
  }
}
@media (max-width: 767.98px) {
  .has-conversion-topbar .navbar {
    top: calc(var(--conversion-topbar-height, 34px) - 1px) !important;
  }
}
.site-layout .navbar {
  width: 100%;
  max-width: none;
  left: 0;
  right: 0;
  transform: none;
  top: 0;
  border: none !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
  border-radius: 0 !important;
  box-shadow: none;
  background: var(--color-bg) !important;
  padding: 0.9rem 0 !important;
}

.site-layout .navbar::before {
  content: none;
}

.site-layout .navbar .container {
  max-width: 2560px;
  width: 100%;
  padding: 0 clamp(12px, 3vw, 30px);
}

.site-layout .navbar-brand,
.site-layout .nav-link {
  color: var(--color-text) !important;
}

.site-layout .navbar-brand span {
  font-size: 2.15rem;
  letter-spacing: 0.2px;
}

.site-layout .brand-logo {
  height: 48px;
  filter: brightness(0) invert(1);
}

.site-layout .nav-link {
  background: transparent;
  border: none !important;
  font-size: clamp(0.98rem, 1.15vw, 1.4rem);
  font-weight: 700;
  box-shadow: none !important;
}

.site-layout .nav-link.multi-word-accent .word-accent,
.site-layout .dropdown-item.multi-word-accent .word-accent {
  display: inline-block;
}
.site-layout .nav-link.multi-word-accent .word-accent__initial,
.site-layout .dropdown-item.multi-word-accent .word-accent__initial {
  color: var(--color-accent);
}

.site-layout .nav-link:hover,
.site-layout .nav-link:focus-visible,
.site-layout .nav-link.active {
  color: var(--color-accent) !important;
  border: none !important;
  text-decoration: none;
}

.site-layout .nav-link.nav-cta {
  color: var(--color-accent) !important;
}
.site-layout .nav-link.nav-cta::first-letter {
  color: var(--color-text);
}

.site-layout .nav-link.nav-cta:hover,
.site-layout .nav-link.nav-cta:focus-visible {
  color: var(--color-text) !important;
}

.site-layout .nav-link.nav-cta:hover::first-letter,
.site-layout .nav-link.nav-cta:focus-visible::first-letter {
  color: var(--color-accent);
}

.site-layout .nav-link.nav-cta.active {
  color: var(--color-accent) !important;
}
.site-layout .nav-link.nav-cta.active::first-letter {
  color: var(--color-text);
}

.site-layout .nav-link.nav-cta::after {
  content: "";
}

.site-layout .dropdown-toggle-split {
  border-radius: 999px;
  padding: 0.48rem 0.32rem !important;
  margin-left: -0.22rem;
}

.site-layout .dropdown-menu {
  border: 1px solid rgba(var(--color-bg), 0.22);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(204, 255, 0, 0.08) 0%, rgba(204, 255, 0, 0) 44%), rgba(8, 12, 20, 0.9);
  box-shadow: 0 22px 44px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.navbar .dropdown-menu.show {
  animation: navbar-dropdown-reveal 280ms cubic-bezier(0.22, 1, 0.36, 1) both;
  transform-origin: top center;
}

@media (max-width: 991.98px) {
  .navbar .dropdown-menu,
  .site-layout .dropdown-menu,
  .navbar .dropdown-menu.show {
    border: none;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    animation: none;
    transform: none;
  }
}
.site-layout .dropdown-item {
  color: rgba(255, 255, 255, 0.9);
}

.site-layout .dropdown-item:hover,
.site-layout .dropdown-item:focus-visible {
  background: transparent;
  color: var(--color-accent);
}

.site-layout .nav-item-with-menu:hover > .nav-link,
.site-layout .nav-item-with-menu:focus-within > .nav-link,
.site-layout .nav-item-with-menu:has(.dropdown-toggle-split[aria-expanded=true]) > .nav-link {
  color: var(--color-accent) !important;
}

.site-layout .nav-item-with-menu:hover > .nav-link .word-accent__initial,
.site-layout .nav-item-with-menu:focus-within > .nav-link .word-accent__initial,
.site-layout .nav-item-with-menu:has(.dropdown-toggle-split[aria-expanded=true]) > .nav-link .word-accent__initial {
  color: var(--color-text);
}

.site-layout .dropdown-item.multi-word-accent:hover,
.site-layout .dropdown-item.multi-word-accent:focus-visible {
  background: transparent;
  color: var(--color-accent);
}

.site-layout .dropdown-item.multi-word-accent:hover .word-accent__initial,
.site-layout .dropdown-item.multi-word-accent:focus-visible .word-accent__initial {
  color: var(--color-text);
}

@media (max-width: 991.98px) {
  .site-layout .navbar {
    left: 0;
    right: 0;
    width: 100%;
    top: calc(var(--conversion-topbar-height, 36px) - 1px);
    padding: 0.75rem 0 !important;
  }
  .site-layout .navbar-collapse {
    border-top: none;
    top: var(--conversion-topbar-height, 36px);
    height: calc(100dvh - var(--conversion-topbar-height, 36px));
    max-height: calc(100dvh - var(--conversion-topbar-height, 36px));
    padding-top: 86px;
  }
  .site-layout .navbar .container {
    padding-left: 10px;
    padding-right: 10px;
  }
  .site-layout .navbar-brand span {
    font-size: 1.22rem;
  }
  .site-layout .nav-link {
    font-size: clamp(1.45rem, 2vw + 1rem, 2rem);
  }
  .site-layout .nav-link.nav-cta {
    width: fit-content;
    margin-top: 0.4rem;
  }
  .site-layout .navbar-collapse .nav-link.nav-cta:hover,
  .site-layout .navbar-collapse .nav-link.nav-cta:focus-visible {
    color: var(--color-text) !important;
  }
  .site-layout .navbar-collapse .nav-link.nav-cta:hover::first-letter,
  .site-layout .navbar-collapse .nav-link.nav-cta:focus-visible::first-letter {
    color: var(--color-accent);
  }
  .site-layout .navbar-collapse .nav-link.nav-cta.active {
    color: var(--color-accent) !important;
  }
  .site-layout .navbar-collapse .nav-link.nav-cta.active::first-letter {
    color: var(--color-text);
  }
  .site-layout .brand-logo {
    height: 34px;
  }
  .site-layout .nav-item-with-menu .dropdown-toggle-split {
    color: var(--color-text) !important;
  }
  .site-layout .nav-item-with-menu .dropdown-toggle-split:hover,
  .site-layout .nav-item-with-menu .dropdown-toggle-split:focus-visible {
    color: var(--color-accent) !important;
  }
}
@media (max-width: 767.98px) {
  .site-layout .navbar-brand {
    max-width: calc(100% - 64px);
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
  }
  .site-layout .navbar-brand span {
    white-space: nowrap;
    font-size: 1.2rem;
    letter-spacing: 0.2px;
  }
}
.page-blog .blog-filter-btn {
  appearance: none;
  -webkit-appearance: none;
  border: 1px solid rgba(255, 255, 255, 0.22) !important;
  background: rgba(255, 255, 255, 0.03) !important;
  color: rgba(255, 255, 255, 0.9) !important;
  border-radius: 999px;
  padding: 0.34rem 0.86rem;
  cursor: pointer;
  transition: border-color 180ms cubic-bezier(0.22, 1, 0.36, 1), color 180ms cubic-bezier(0.22, 1, 0.36, 1), background 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.page-blog .blog-filter-btn:hover,
.page-blog .blog-filter-btn:focus-visible,
.page-blog .blog-filter-btn.is-active {
  border-color: var(--color-accent) !important;
  color: var(--color-accent) !important;
  background: rgba(56, 234, 178, 0.08) !important;
}

.page-blog .blog-filter-bar {
  align-items: center;
}

.page-blog .blog-filter-count {
  color: var(--color-text-subtle);
  white-space: nowrap;
}

.page-blog [data-stagger-reveal].is-reveal-ready {
  opacity: 0;
  transform: translateY(26px) scale(0.98);
  filter: blur(4px);
  transition: opacity 560ms cubic-bezier(0.22, 1, 0.36, 1), transform 560ms cubic-bezier(0.22, 1, 0.36, 1), filter 560ms cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: calc(var(--stagger-order, 0) * 70ms);
}

.page-blog [data-stagger-reveal].is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  filter: blur(0);
}

.page-blog .blog-card {
  border: var(--shel-color-border) !important;
  border-radius: 18px;
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.025)) !important;
  box-shadow: 0 20px 42px rgba(0, 0, 0, 0.18);
}

.page-blog .blog-card-media,
.page-blog .blog-detail-media {
  position: relative;
  overflow: hidden;
  border-radius: 16px;
  border: var(--shel-color-border);
  background: radial-gradient(circle at 18% 18%, rgba(var(--color-bg), 0.22), transparent 30%), radial-gradient(circle at 82% 22%, rgba(59, 130, 246, 0.24), transparent 32%), radial-gradient(circle at 86% 78%, rgba(56, 234, 178, 0.12), transparent 42%), radial-gradient(circle at 14% 84%, rgba(56, 189, 248, 0.1), transparent 38%), linear-gradient(145deg, rgba(13, 18, 32, 0.96), rgba(18, 28, 46, 0.92));
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06), inset 0 -28px 64px rgba(56, 234, 178, 0.06);
}

.page-blog .blog-card-media {
  min-height: clamp(180px, 25vw, 220px);
  margin: 0.9rem 0.9rem 0;
}

.page-blog .blog-detail-media {
  min-height: 280px;
  margin-bottom: 1.75rem;
}

.page-blog .blog-card-media::before,
.page-blog .blog-detail-media::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(rgba(255, 255, 255, 0.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.05) 1px, transparent 1px);
  background-size: 28px 28px;
  opacity: 0.24;
  z-index: 1;
  pointer-events: none;
}

.page-blog .blog-card-media--with-image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(165deg, rgba(7, 12, 24, 0.24) 0%, rgba(7, 12, 24, 0.45) 56%, rgba(7, 12, 24, 0.7) 100%);
  z-index: 1;
  pointer-events: none;
}

.page-blog .blog-card-media:not(.blog-card-media--with-image)::after,
.page-blog .blog-detail-media:not(.blog-card-media--with-image)::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(125deg, rgba(56, 234, 178, 0.16), transparent 22%) top left/100% 100% no-repeat, linear-gradient(-55deg, rgba(56, 189, 248, 0.12), transparent 28%) bottom right/100% 100% no-repeat;
  box-shadow: inset 0 0 0 1px rgba(162, 189, 255, 0.14);
  z-index: 1;
  pointer-events: none;
}

.page-blog .blog-card-media__image,
.page-blog .blog-detail-media__image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
  filter: saturate(1.03) contrast(1.04);
}

.page-blog .blog-card-media__inner,
.page-blog .blog-detail-media__inner {
  position: relative;
  z-index: 2;
  min-height: inherit;
  padding: 1.2rem;
}

.page-blog .blog-card-media__eyebrow,
.page-blog .blog-detail-media__eyebrow {
  color: rgba(255, 255, 255, 0.7);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.page-blog .blog-card-media__title,
.page-blog .blog-detail-media__title {
  color: #f8fbff;
  max-width: 14ch;
  line-height: 0.95;
}

.page-blog .blog-card-media__icon,
.page-blog .blog-detail-media__icon {
  color: var(--color-accent);
  text-shadow: 0 0 18px rgba(var(--color-bg), 0.4);
}

.page-blog .blog-card-media__icon {
  font-size: 1.9rem;
}

.page-blog .blog-detail-media__icon {
  font-size: 2.4rem;
}

.page-blog .blog-card .card-body {
  padding: 1.15rem 1.2rem 1.2rem !important;
}

.page-blog pre {
  background: #1f2432 !important;
  color: #e8eef8 !important;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 10px !important;
  overflow-x: auto;
}

.page-blog pre code {
  color: #e8eef8 !important;
  background: transparent !important;
}

.page-blog code {
  color: #f597d8;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 4px;
  padding: 0.08rem 0.32rem;
}

.page-blog .card a,
.page-blog .card .text-primary {
  color: var(--color-accent) !important;
}

.page-blog .badge {
  border: 1px solid rgba(255, 255, 255, 0.28) !important;
  background: transparent !important;
  color: rgba(255, 255, 255, 0.92) !important;
}

.page-blog .text-muted {
  color: var(--color-text-subtle) !important;
}

@media (max-width: 767.98px) {
  .page-blog .blog-detail-media {
    min-height: 220px;
  }
}
:root {
  --lab-bg: #0f1218;
  --lab-panel: #161b24;
  --lab-border: rgba(255, 255, 255, 0.12);
  --lab-text: #f0f4fb;
  --lab-muted: #9ba7be;
  --c-light: #6dd3ff;
  --c-solid: #ffd86b;
  --c-duo: #a2ff8a;
}

.icon-lab-page {
  background: radial-gradient(circle at 20% 0%, #1a2433 0%, var(--lab-bg) 45%);
  color: var(--lab-text);
}

.icon-lab {
  max-width: 1200px;
}

.icon-lab__eyebrow {
  color: #8de6cc;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 0.25rem;
}

.icon-lab h1 {
  font-size: clamp(1.7rem, 3.2vw, 2.7rem);
  margin-bottom: 0.75rem;
}

.icon-lab p {
  color: var(--lab-muted);
  max-width: 820px;
}

.icon-lab code {
  background: rgba(255, 255, 255, 0.08);
  border-radius: 6px;
  padding: 0.1rem 0.4rem;
}

.icon-lab__section h2 {
  font-size: 1.25rem;
  margin-bottom: 1rem;
}

.icon-grid {
  gap: 0.8rem;
  grid-template-columns: repeat(auto-fit, minmax(min(186px, 100%), 1fr));
}

.icon-card {
  border: 1px solid var(--lab-border);
  border-radius: 14px;
  background: linear-gradient(160deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.02));
  padding: 0.9rem;
}

.icon-card h3 {
  margin: 0 0 0.7rem;
  color: #dce4f2;
}

.palette-grid {
  gap: 1rem;
  grid-template-columns: repeat(auto-fit, minmax(min(320px, 100%), 1fr));
}

.palette-card {
  border: 1px solid var(--lab-border);
  border-radius: 16px;
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.025));
  padding: 1rem;
  gap: 1rem;
}

.palette-card__head h3 {
  color: #eef4ff;
}

.palette-card__head p {
  color: var(--lab-muted);
  max-width: none;
}

.palette-card__icon {
  font-size: 1.4rem;
  color: #8de6cc;
  opacity: 0.9;
}

.palette-swatches {
  gap: 0.65rem;
  grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
}

.palette-swatch {
  min-height: 88px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: var(--swatch);
  color: var(--swatch-text);
  padding: 0.8rem;
  display: grid;
  align-content: space-between;
  gap: 0.5rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.palette-swatch span {
  font-size: 0.76rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  opacity: 0.86;
}

.palette-swatch strong {
  display: block;
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.25;
}

.icon-weights {
  gap: 0.45rem;
}

.chip {
  border: 1px solid var(--lab-border);
  border-radius: 10px;
  padding: 0.45rem 0.6rem;
  color: #dce4f2;
}

.chip i {
  font-size: 1.15rem;
}

.chip-light i {
  color: var(--c-light);
}

.chip-solid i {
  color: var(--c-solid);
}

.chip-duo i {
  color: var(--c-duo);
}

.brand-grid {
  gap: 0.8rem;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.brand-card {
  border: 1px solid var(--lab-border);
  border-radius: 14px;
  background: var(--lab-panel);
  padding: 0.9rem;
  gap: 0.55rem;
  justify-items: center;
}

.brand-card i {
  font-size: 1.8rem;
  color: #7bb3ff;
}

.brand-card:nth-child(2) i {
  color: #54e38f;
}

.brand-card:nth-child(3) i {
  color: #7ac6ff;
}

.brand-card:nth-child(4) i {
  color: #b7d1ff;
}

.brand-card:nth-child(5) i {
  color: #e5e9f2;
}

.brand-card:nth-child(6) i {
  color: #86f9d6;
}

.brand-card:nth-child(7) i {
  color: #ff93d6;
}

.brand-card:nth-child(8) i {
  color: #84c6ff;
}

.brand-card:nth-child(9) i {
  color: #ffcf66;
}

.brand-card:nth-child(10) i {
  color: #ffe082;
}

.brand-card span {
  color: var(--lab-muted);
}

.legal-page-content {
  max-width: 980px;
}

.legal-page-title {
  margin: 0 0 1.25rem;
  font-size: clamp(2rem, 4.5vw, 3rem);
  line-height: 0.95;
}

.legal-page-content h2 {
  margin: 1.55rem 0 0.7rem;
  font-size: clamp(1.24rem, 2vw, 1.52rem);
}

.legal-page-content p,
.legal-page-content li,
.legal-page-content strong {
  color: var(--color-text-muted) !important;
}

.legal-page-content a {
  color: var(--color-accent);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.legal-page-content p,
.legal-page-content li,
.legal-page-content a {
  overflow-wrap: anywhere;
  word-break: break-word;
}

.content-page .legal-shell {
  min-height: auto;
  padding: 118px 0 72px;
  scroll-snap-align: none;
  scroll-snap-stop: normal;
}

.content-page hr {
  border-color: rgba(255, 255, 255, 0.08);
  opacity: 1;
}

.content-page .page-content ul a {
  transition: color 180ms cubic-bezier(0.22, 1, 0.36, 1);
}

.content-page .page-content ul a:hover,
.content-page .page-content ul a:focus-visible {
  color: var(--color-accent);
}

.content-page .page-content .card mark {
  color: inherit;
  background: rgba(56, 234, 178, 0.2);
}

.content-page .page-content .card .text-primary,
.content-page .page-content .card i[class^=fa],
.content-page .page-content .card i[class*=" fa-"] {
  color: var(--color-accent) !important;
}

.content-page .page-content .table {
  color: inherit;
  border-color: rgba(255, 255, 255, 0.14);
}

.content-page .page-content .table > :not(caption) > * > * {
  background: rgba(23, 29, 42, 0.85) !important;
  color: inherit !important;
  border-color: rgba(255, 255, 255, 0.14);
}

.content-page .page-content .table-light > :not(caption) > * > * {
  background: rgba(56, 234, 178, 0.12) !important;
  color: inherit !important;
}

@media (max-width: 991.98px) {
  .content-page .legal-shell {
    padding: 104px 0 56px;
  }
}
@media (max-width: 767.98px) {
  .content-page .legal-page-title {
    font-size: clamp(1.8rem, 8vw, 2.4rem);
    line-height: 1.05;
  }
  .content-page .legal-page-content h2 {
    line-height: 1.3;
  }
}
.page-project .project-detail-image {
  margin-top: clamp(1.25rem, 2.5vw, 2rem);
}

.page-project .project-detail-image-link {
  display: block;
  width: 100%;
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: var(--card-color-bg);
  box-shadow: 0 24px 48px rgba(0, 0, 0, 0.3);
}

.page-project .project-detail-image-link::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(8, 12, 20, 0.22);
  transition: background 0.25s ease;
  z-index: 1;
}

.page-project .project-detail-image img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  border: 0;
  border-radius: 18px;
  box-shadow: none;
  transition: transform 0.28s ease;
}

.page-project .project-detail-image-caption {
  color: rgba(255, 255, 255, 0.9);
  font-size: clamp(1.45rem, 3.1vw, 2.25rem);
  letter-spacing: 0.01em;
  text-shadow: 0 2px 14px rgba(0, 0, 0, 0.48);
  transition: opacity 0.25s ease;
}

.page-project .project-detail-image-link:hover::before,
.page-project .project-detail-image-link:focus-visible::before {
  background: rgba(8, 12, 20, 0.42);
}

.page-project .project-detail-image-link:hover img,
.page-project .project-detail-image-link:focus-visible img {
  transform: scale(1.02);
}

.page-project .project-detail-image-link:hover .project-detail-image-caption,
.page-project .project-detail-image-link:focus-visible .project-detail-image-caption {
  opacity: 1;
}

.page-project .project-detail-image-link:focus-visible {
  outline: 2px solid rgba(56, 234, 178, 0.85);
  outline-offset: 4px;
}

.page-shopware-update .project-detail-image {
  max-height: 380px;
  object-position: top center;
  border: 1px solid rgba(255, 255, 255, 0.16);
}

.site-layout.content-page.page-shopware .page-content hr.my-5 {
  margin-top: 2.3rem !important;
  margin-bottom: 2.1rem !important;
}

.site-layout.content-page.page-shopware .page-content h2.h4.fw-bold.mb-3 {
  margin-bottom: 0.95rem !important;
}

.page-shopware-update .card h6,
.page-shopware-update .card p,
.page-shopware-update .card a {
  overflow-wrap: anywhere;
}

.site-layout.content-page.page-shopware .page-content a.card.text-decoration-none {
  height: auto !important;
  min-height: 0 !important;
  padding: 0.95rem 1rem !important;
}

.site-layout.content-page.page-shopware .page-content a.card.text-decoration-none p.small {
  margin-top: 0.2rem !important;
  margin-bottom: 0 !important;
  line-height: 1.35;
}

.site-layout.content-page.page-shopware .page-content .row.g-3.mb-5 {
  margin-bottom: 2rem !important;
}

.freelance-compare {
  max-width: 1180px;
  margin: 0 auto 2.75rem;
  padding: clamp(1.4rem, 0.8rem + 2vw, 3.1rem);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 1.9rem;
  background: radial-gradient(circle at top left, rgba(var(--color-bg), 0.08), transparent 30%), linear-gradient(180deg, rgba(255, 255, 255, 0.035), rgba(255, 255, 255, 0.015)), rgba(15, 18, 24, 0.92);
  box-shadow: 0 28px 80px rgba(3, 11, 29, 0.34);
}

.freelance-compare__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.9rem;
  color: rgba(255, 255, 255, 0.42);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.freelance-compare__eyebrow::before {
  content: "";
  width: 2.5rem;
  height: 1px;
  background: rgba(255, 255, 255, 0.16);
}

.freelance-compare__title {
  margin-bottom: 0.95rem;
  color: var(--color-text);
  font-size: clamp(2rem, 1.2rem + 2vw, 3rem);
  line-height: 1.06;
}

.freelance-compare__intro {
  max-width: 52rem;
  margin-bottom: clamp(1.8rem, 1.15rem + 1.2vw, 2.5rem);
  color: rgba(255, 255, 255, 0.58);
  font-size: clamp(1.25rem, 1rem + 1vw, 1.95rem);
  line-height: 1.35;
}

.freelance-compare__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1rem, 0.7rem + 1vw, 1.5rem);
  position: relative;
}

.freelance-compare__loader-wrap {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 80px;
  height: 40px;
  transform: translate(-50%, -50%);
  pointer-events: none;
  z-index: 4;
}

.freelance-compare__loader {
  position: relative;
  width: 100%;
  height: 100%;
}

.freelance-compare__loader .lightsaber {
  position: absolute;
  width: 4px;
  height: 12px;
  background-color: #666;
  border-radius: 1px;
  bottom: 0;
}

.freelance-compare__loader .lightsaber.ls-left {
  left: 0;
  animation: fightright 2s ease-in-out infinite 1s reverse;
}

.freelance-compare__loader .lightsaber.ls-right {
  right: 0;
  animation: fightright 2s ease-in-out infinite 1s;
}

.freelance-compare__loader .lightsaber::before {
  position: absolute;
  content: "";
  display: block;
  width: 2px;
  height: 25px;
  max-height: 1px;
  left: 1px;
  top: 1px;
  background-color: #fff;
  border-radius: 1px;
  transform: rotateZ(180deg);
  transform-origin: center top;
}

.freelance-compare__loader .lightsaber::after {
  position: absolute;
  content: "";
  display: block;
  width: 2px;
  height: 2px;
  left: 1px;
  top: 4px;
  background-color: #fff;
  border-radius: 50%;
}

.freelance-compare__loader .ls-particles {
  position: absolute;
  left: 42px;
  top: 10px;
  width: 1px;
  height: 5px;
  background-color: rgba(51, 51, 51, 0);
  transform: rotateZ(0deg);
}

.freelance-compare__loader .lightsaber.ls-green::before {
  animation: showlightgreen 2s ease-in-out infinite 1s;
}

.freelance-compare__loader .lightsaber.ls-red::before {
  animation: showlightred 2s ease-in-out infinite 1s;
}

.freelance-compare__loader .ls-particles.ls-part-1 {
  animation: particles1 2s ease-out infinite 1s;
}

.freelance-compare__loader .ls-particles.ls-part-2 {
  animation: particles2 2s ease-out infinite 1s;
}

.freelance-compare__loader .ls-particles.ls-part-3 {
  animation: particles3 2s ease-out infinite 1s;
}

.freelance-compare__loader .ls-particles.ls-part-4 {
  animation: particles4 2s ease-out infinite 1s;
}

.freelance-compare__loader .ls-particles.ls-part-5 {
  animation: particles5 2s ease-out infinite 1s;
}

.freelance-compare__card {
  position: relative;
  overflow: hidden;
  min-height: 100%;
  padding: clamp(1.6rem, 1.1rem + 1.4vw, 2.2rem);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 1.8rem;
  background: var(--card-color-bg);
  box-shadow: 0 18px 42px rgba(15, 22, 38, 0.16);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.freelance-compare__card::after {
  content: "";
  position: absolute;
  inset: auto 1.25rem 0.9rem auto;
  width: 6rem;
  height: 6rem;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(199, 255, 0, 0.16), rgba(199, 255, 0, 0));
  pointer-events: none;
}

.freelance-compare__card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 50px rgba(15, 22, 38, 0.12);
}

.freelance-compare__card--freelancer {
  border-color: rgba(199, 255, 0, 0.6);
  background: linear-gradient(160deg, rgba(199, 255, 0, 0.1), rgba(255, 255, 255, 0.03) 42%), rgba(255, 255, 255, 0.035);
}

.freelance-compare__card-title {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  margin-bottom: 1.45rem;
  color: var(--color-text);
  font-size: clamp(1.55rem, 1.15rem + 0.65vw, 2rem);
  font-weight: 700;
}

.freelance-compare__card-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3.75rem;
  height: 3.75rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: var(--color-text);
  font-size: 1.35rem;
}

.freelance-compare__card--freelancer .freelance-compare__card-icon {
  background: rgba(199, 255, 0, 0.16);
  color: var(--color-accent);
}

.freelance-compare__list {
  display: grid;
  gap: 1rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.freelance-compare__item {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.8rem;
  align-items: start;
  color: rgba(255, 255, 255, 0.72);
  font-size: clamp(1.2rem, 1rem + 0.45vw, 1.65rem);
  font-weight: 500;
  line-height: 1.45;
}

.freelance-compare__bullet {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  margin-top: 0.1rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: var(--color-text);
  font-size: 0.95rem;
}

.freelance-compare__card--freelancer .freelance-compare__bullet {
  background: rgba(199, 255, 0, 0.18);
  color: var(--color-accent);
}

@media (max-width: 991.98px) {
  .freelance-compare__grid {
    grid-template-columns: 1fr;
  }
  .freelance-compare__loader-wrap {
    display: none;
  }
}
@media (max-width: 575.98px) {
  .freelance-compare {
    border-radius: 1.3rem;
  }
  .freelance-compare__card {
    padding: 1.2rem;
    border-radius: 1.35rem;
  }
}
@media (prefers-reduced-motion: reduce) {
  .freelance-compare__loader-wrap {
    display: none;
  }
}
@keyframes showlightgreen {
  0% {
    max-height: 0;
    box-shadow: 0 0 0 0 #87c054;
  }
  5% {
    box-shadow: 0 0 4px 2px #87c054;
  }
  10%, 80% {
    max-height: 22px;
  }
  85% {
    box-shadow: 0 0 4px 2px #87c054;
  }
  100% {
    max-height: 0;
    box-shadow: 0 0 0 0 #87c054;
  }
}
@keyframes showlightred {
  0% {
    max-height: 0;
    box-shadow: 0 0 0 0 #f06363;
  }
  20% {
    box-shadow: 0 0 4px 2px #f06363;
  }
  25%, 80% {
    max-height: 22px;
  }
  85% {
    box-shadow: 0 0 4px 2px #f06363;
  }
  100% {
    max-height: 0;
    box-shadow: 0 0 0 0 #f06363;
  }
}
@keyframes fightright {
  0% {
    transform: rotateZ(0deg);
    right: 0;
    bottom: 0;
  }
  30% {
    transform: rotateZ(0deg);
    bottom: 0;
  }
  45% {
    transform: rotateZ(-45deg);
    right: 0;
    bottom: 2px;
  }
  50% {
    transform: rotateZ(-65deg);
    right: 0;
  }
  68% {
    transform: rotateZ(-410deg);
    right: 27px;
    bottom: 13px;
  }
  95% {
    transform: rotateZ(-410deg);
    right: 0;
    bottom: 0;
  }
  100% {
    transform: rotateZ(-360deg);
    right: 0;
    bottom: 0;
  }
}
@keyframes particles1 {
  0%, 63% {
    background-color: rgba(51, 51, 51, 0);
    transform: rotateZ(35deg) translateY(0px);
  }
  64% {
    background-color: rgb(51, 51, 51);
    transform: rotateZ(35deg) translateY(0px);
  }
  100% {
    background-color: rgba(51, 51, 51, 0);
    transform: rotateZ(35deg) translateY(-30px);
  }
}
@keyframes particles2 {
  0%, 63% {
    background-color: rgba(51, 51, 51, 0);
    transform: rotateZ(-65deg) translateY(0px);
  }
  64% {
    background-color: rgb(51, 51, 51);
    transform: rotateZ(-65deg) translateY(0px);
  }
  95%, 100% {
    background-color: rgba(51, 51, 51, 0);
    transform: rotateZ(-65deg) translateY(-40px);
  }
}
@keyframes particles3 {
  0%, 63% {
    background-color: rgba(51, 51, 51, 0);
    transform: rotateZ(-75deg) translateY(0px);
  }
  64% {
    background-color: rgb(51, 51, 51);
    transform: rotateZ(-75deg) translateY(0px);
  }
  97%, 100% {
    background-color: rgba(51, 51, 51, 0);
    transform: rotateZ(-75deg) translateY(-35px);
  }
}
@keyframes particles4 {
  0%, 63% {
    background-color: rgba(51, 51, 51, 0);
    transform: rotateZ(-25deg) translateY(0px);
  }
  64% {
    background-color: rgb(51, 51, 51);
    transform: rotateZ(-25deg) translateY(0px);
  }
  97%, 100% {
    background-color: rgba(51, 51, 51, 0);
    transform: rotateZ(-25deg) translateY(-30px);
  }
}
@keyframes particles5 {
  0%, 63% {
    background-color: rgba(51, 51, 51, 0);
    transform: rotateZ(65deg) translateY(0px);
  }
  64% {
    background-color: rgb(51, 51, 51);
    transform: rotateZ(65deg) translateY(0px);
  }
  97%, 100% {
    background-color: rgba(51, 51, 51, 0);
    transform: rotateZ(65deg) translateY(-35px);
  }
}
.hero-media {
  position: relative;
  display: inline-block;
  isolation: isolate;
}

.hero-media > img {
  position: relative;
  z-index: 3;
}

.hero-media::before {
  content: "";
  position: absolute;
  top: clamp(0.25rem, 2vw, 1.5rem);
  right: 3vw;
  width: clamp(110px, 16vw, 220px);
  aspect-ratio: 1;
  background: url("/assets/img/home/shopwarePlanet.png") center/cover no-repeat;
  filter: saturate(1.02);
  opacity: 1;
  transform: translate3d(0, 0, 0);
  z-index: 1;
}

.hero-planet-starfield {
  position: absolute;
  top: clamp(-1rem, 0.6vw, 0.4rem);
  right: clamp(-2.6rem, -0.8vw, -0.6rem);
  width: clamp(220px, 28vw, 390px);
  aspect-ratio: 1;
  opacity: 0.9;
  border-radius: 50%;
  overflow: hidden;
  mask-image: radial-gradient(circle at 46% 50%, rgba(0, 0, 0, 0.99) 0%, rgba(0, 0, 0, 0.96) 56%, rgba(0, 0, 0, 0.78) 74%, rgba(0, 0, 0, 0) 100%);
  -webkit-mask-image: radial-gradient(circle at 46% 50%, rgba(0, 0, 0, 0.99) 0%, rgba(0, 0, 0, 0.96) 56%, rgba(0, 0, 0, 0.78) 74%, rgba(0, 0, 0, 0) 100%);
  z-index: 0;
}

.hero-planet-starfield .starfield__layer {
  inset: -14%;
  background-size: 64px 64px;
  filter: none;
  opacity: 0.62;
}

.hero-planet-starfield .starfield__layer--mid {
  background-size: 116px 116px;
  opacity: 0.5;
}

.hero-planet-starfield .starfield__layer--near {
  background-size: 168px 168px;
  opacity: 0.38;
}

.hero-planet-starfield .starfield__spark {
  opacity: 0.34;
}

.hero-planet-hermann {
  position: absolute;
  top: clamp(0.1rem, 0.25vw, 0.45rem);
  right: clamp(4.8rem, 6.8vw, 9rem);
  width: clamp(16px, 2.4vw, 34px);
  aspect-ratio: 0.42;
  background: url("/assets/img/home/hermannsdenkmal.png") center/contain no-repeat;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.4));
  opacity: 0.92;
  z-index: 4;
  pointer-events: none;
}

.hero-media::after {
  content: "";
  position: absolute;
  top: clamp(0.25rem, 2vw, 1.5rem);
  right: 3vw;
  width: clamp(110px, 16vw, 220px);
  aspect-ratio: 1;
  border-radius: 50%;
  background: linear-gradient(138deg, rgba(15, 18, 24, 0) 0%, rgba(15, 18, 24, 0) 54%, rgba(15, 18, 24, 0.22) 66%, rgba(15, 18, 24, 0.54) 78%, rgba(15, 18, 24, 0.86) 90%, rgba(15, 18, 24, 0.98) 100%);
  box-shadow: inset -18px -14px 26px rgba(15, 18, 24, 0.32), inset -42px -34px 54px rgba(15, 18, 24, 0.62), inset -72px -58px 92px rgba(15, 18, 24, 0.9);
  transform: translate3d(0, 0, 0);
  z-index: 2;
}

.hero-speech {
  position: absolute;
  top: 40%;
  left: 61%;
  max-width: 385px;
  padding: 0.9rem 1.2rem;
  background: rgba(8, 12, 20, 0.75);
  border: 1px solid rgba(130, 210, 255, 0.45);
  border-radius: 20px;
  color: #dff6ff;
  font-size: 1.05rem;
  letter-spacing: 0.02em;
  box-shadow: 0 12px 24px rgba(5, 10, 20, 0.4);
  backdrop-filter: blur(6px);
  z-index: 5;
}

.hero-speech::after {
  content: "";
  position: absolute;
  top: 28%;
  left: -8px;
  width: 18px;
  height: 18px;
  background: rgba(8, 12, 20, 0.75);
  border-left: 1px solid rgba(130, 210, 255, 0.45);
  border-top: 1px solid rgba(130, 210, 255, 0.45);
  transform: rotate(-45deg);
}

.hero-speech__label {
  display: block;
  font-size: 0.75rem;
  text-transform: uppercase;
  color: rgba(180, 255, 255, 0.7);
  margin-bottom: 0.15rem;
}

.hero-speech__text {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  font-family: var(--ff-syne);
  font-size: 1.1rem;
  color: #b6ffcf;
  min-height: 1.4em;
  text-decoration: none;
  transition: color 160ms ease;
}

.hero-speech__text[href]:hover,
.hero-speech__text[href]:focus-visible {
  color: var(--color-accent);
}

.hero-speech__text[href]:hover .hero-speech__text-label,
.hero-speech__text[href]:focus-visible .hero-speech__text-label,
.hero-speech__text[href]:hover .hero-speech__text-icon,
.hero-speech__text[href]:focus-visible .hero-speech__text-icon,
.hero-speech__text[href]:hover .hero-speech__text-icon i,
.hero-speech__text[href]:focus-visible .hero-speech__text-icon i {
  color: var(--color-accent);
}

.hero-speech__text-icon {
  display: inline-flex;
  align-items: center;
  line-height: 1;
}

.hero-speech__text-icon[hidden] {
  display: none;
}

@media (max-width: 991.98px) {
  .hero-speech {
    max-width: 260px;
    font-size: 1rem;
  }
}
@media (max-width: 767.98px) {
  .hero-media::before {
    top: -0.5rem;
    right: -1rem;
    width: clamp(90px, 28vw, 150px);
    opacity: 0.34;
  }
  .hero-planet-starfield {
    top: -0.9rem;
    right: -2.8rem;
    width: clamp(175px, 50vw, 260px);
  }
  .hero-planet-hermann {
    top: -0.1rem;
    right: clamp(3.2rem, 15vw, 4.4rem);
    width: clamp(12px, 3vw, 22px);
  }
  .hero-media::after {
    top: -0.5rem;
    right: -1rem;
    width: clamp(90px, 28vw, 150px);
  }
  .hero-speech {
    position: static;
    margin: 0.75rem auto 0;
    max-width: 260px;
  }
  .hero-speech::after {
    display: none;
  }
}
.floating-chatbot {
  position: fixed;
  right: clamp(0.9rem, 2vw, 1.6rem);
  bottom: clamp(0.9rem, 3vw, 4.5rem);
  width: clamp(136px, 15vw, 230px);
  aspect-ratio: 1.08;
  z-index: 24;
  isolation: isolate;
  display: block;
  text-decoration: none;
  pointer-events: none;
}

.floating-chatbot--left {
  left: clamp(0.8rem, 1vw, 1rem);
  right: auto;
}

.floating-chatbot--linked {
  pointer-events: auto;
}

@media (max-width: 767.98px) {
  .floating-chatbot--hide-mobile {
    display: none;
  }
}
.floating-chatbot__robot,
.floating-chatbot__planet,
.floating-chatbot__planet-fade,
.floating-chatbot__hermann,
.floating-chatbot__planet-starfield,
.floating-chatbot__starfield {
  position: absolute;
}

.floating-chatbot__robot {
  right: 0;
  bottom: 0;
  width: 76%;
  aspect-ratio: 0.88;
  background: url("/assets/img/psd/devserverCyberRobot.png") center bottom/contain no-repeat;
  mask-image: linear-gradient(to bottom, rgb(0, 0, 0) 70%, rgba(0, 0, 0, 0) 100%);
  -webkit-mask-image: linear-gradient(to bottom, rgb(0, 0, 0) 70%, rgba(0, 0, 0, 0) 100%);
  z-index: 3;
}

.floating-chatbot--left .floating-chatbot__robot {
  right: auto;
  left: 0;
  transform: scaleX(-1);
}

.floating-chatbot__planet {
  top: 12%;
  left: 2%;
  width: 46%;
  aspect-ratio: 1;
  background: url("/assets/img/home/shopwarePlanet.png") center/cover no-repeat;
  z-index: 1;
}

.floating-chatbot--left .floating-chatbot__planet {
  left: auto;
  right: 2%;
}

.floating-chatbot__starfield {
  inset: -24%;
  opacity: 1;
  border-radius: 48% 52% 44% 56%/42% 52% 48% 58%;
  overflow: hidden;
  pointer-events: none;
  mix-blend-mode: screen;
  mask-image: radial-gradient(ellipse at 48% 56%, rgba(0, 0, 0, 0.99) 0%, rgba(0, 0, 0, 0.99) 58%, rgba(0, 0, 0, 0.92) 76%, rgba(0, 0, 0, 0.64) 90%, rgba(0, 0, 0, 0) 100%);
  -webkit-mask-image: radial-gradient(ellipse at 48% 56%, rgba(0, 0, 0, 0.99) 0%, rgba(0, 0, 0, 0.99) 58%, rgba(0, 0, 0, 0.92) 76%, rgba(0, 0, 0, 0.64) 90%, rgba(0, 0, 0, 0) 100%);
  z-index: 0;
}

.floating-chatbot__starfield .starfield__layer {
  inset: -26%;
  background-size: 56px 56px;
  opacity: 0.8;
}

.floating-chatbot__starfield .starfield__layer--mid {
  background-size: 96px 96px;
  opacity: 0.62;
}

.floating-chatbot__starfield .starfield__layer--near {
  background-size: 148px 148px;
  opacity: 0.48;
}

.floating-chatbot__starfield .starfield__spark {
  opacity: 0.52;
}

.floating-chatbot__planet-fade {
  top: 12%;
  left: 2%;
  width: 40%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: linear-gradient(138deg, rgba(15, 18, 24, 0) 0%, rgba(15, 18, 24, 0) 54%, rgba(15, 18, 24, 0.2) 66%, rgba(15, 18, 24, 0.5) 78%, rgba(15, 18, 24, 0.84) 90%, rgba(15, 18, 24, 0.96) 100%);
  box-shadow: inset -10px -8px 14px rgba(15, 18, 24, 0.24), inset -18px -14px 28px rgba(15, 18, 24, 0.46);
  z-index: 2;
}

.floating-chatbot--left .floating-chatbot__planet-fade {
  left: auto;
  right: 7%;
}

.floating-chatbot__hermann {
  top: 2%;
  left: 22%;
  width: 7%;
  aspect-ratio: 0.42;
  background: url("/assets/img/home/hermannsdenkmal.png") center/contain no-repeat;
  z-index: 4;
}

.floating-chatbot--left .floating-chatbot__hermann {
  left: auto;
  right: 22%;
}

.floating-chatbot__bubble {
  position: absolute;
  bottom: 80%;
  right: 26%;
  width: clamp(220px, 20vw, 280px);
  min-width: 220px;
  max-width: 280px;
  padding: 0.55rem 0.8rem;
  border-radius: 16px;
  background: rgba(8, 12, 20, 0.78);
  border: 1px solid rgba(130, 210, 255, 0.38);
  color: #dff6ff;
  font-size: clamp(0.7rem, 0.74vw, 0.92rem);
  line-height: 1.25;
  box-shadow: 0 10px 24px rgba(5, 10, 20, 0.3);
  backdrop-filter: blur(6px);
  z-index: 5;
  display: flex;
  flex-direction: column;
  gap: 0.14rem;
  white-space: nowrap;
}

.floating-chatbot__bubble::after {
  content: "";
  position: absolute;
  left: 0.95rem;
  bottom: -0.34rem;
  width: 0.72rem;
  height: 0.72rem;
  background: rgba(8, 12, 20, 0.78);
  border-right: 1px solid rgba(130, 210, 255, 0.32);
  border-bottom: 1px solid rgba(130, 210, 255, 0.32);
  transform: rotate(45deg);
}

.floating-chatbot--left .floating-chatbot__bubble {
  right: auto;
  left: 10%;
}

.floating-chatbot--left .floating-chatbot__bubble::after {
  left: auto;
  right: 3.5rem;
}

.floating-chatbot__bubble-label {
  display: block;
  font-size: 0.58rem;
  text-transform: uppercase;
  color: rgba(180, 255, 255, 0.68);
}

.floating-chatbot__bubble-text {
  display: block;
  min-height: 2.2em;
  font-family: var(--ff-syne);
  color: #b6ffcf;
  white-space: nowrap;
}

.floating-chatbot--signal-intro {
  opacity: 0;
  transform: translate3d(0, 10px, 0) scale(0.965);
}

.floating-chatbot--signal-intro.is-signal-running {
  animation: floating-chatbot-signal-intro 2.2s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.floating-chatbot--signal-intro.is-signal-running::before {
  content: "";
  position: absolute;
  inset: -6%;
  border-radius: 50%;
  background: linear-gradient(180deg, rgba(190, 245, 255, 0) 0%, rgba(190, 245, 255, 0.22) 46%, rgba(190, 245, 255, 0) 100%), repeating-linear-gradient(180deg, rgba(160, 255, 248, 0.1) 0 2px, rgba(10, 16, 24, 0) 2px 6px);
  mix-blend-mode: screen;
  opacity: 0;
  z-index: 6;
  pointer-events: none;
  animation: floating-chatbot-signal-overlay 2.2s linear forwards;
}

@keyframes floating-chatbot-signal-intro {
  0% {
    opacity: 0;
    transform: translate3d(0, 12px, 0) scale(0.94);
    filter: blur(12px) saturate(1.8);
  }
  14% {
    opacity: 0.96;
    transform: translate3d(0, 0, 0) scale(1.02);
    filter: blur(0) saturate(1.2);
  }
  24% {
    opacity: 0.22;
    transform: translate3d(-1px, 1px, 0) scale(0.99);
    filter: blur(1.5px) hue-rotate(8deg);
  }
  36% {
    opacity: 0;
    transform: translate3d(2px, -2px, 0) scale(0.97);
    filter: blur(7px);
  }
  58% {
    opacity: 0;
    transform: translate3d(0, 8px, 0) scale(0.95);
    filter: blur(8px);
  }
  76% {
    opacity: 0.98;
    transform: translate3d(0, 0, 0) scale(1.015);
    filter: blur(0) saturate(1.26);
  }
  100% {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
    filter: none;
  }
}
@keyframes floating-chatbot-signal-overlay {
  0%, 8%, 52%, 100% {
    opacity: 0;
  }
  12%, 18%, 72% {
    opacity: 0.78;
  }
  32%, 60% {
    opacity: 0.18;
  }
}
@media (max-width: 767.98px) {
  .floating-chatbot {
    width: clamp(92px, 24vw, 132px);
    bottom: 1rem;
  }
  .floating-chatbot__bubble {
    width: 220px;
    min-width: 220px;
    max-width: 220px;
    display: none;
  }
}
.layout-section {
  min-height: clamp(480px, 82vh, 920px);
}
.layout-section h1,
.layout-section h2 {
  font-size: clamp(48px, 8vw, 64px);
  font-weight: 600;
}

#hero {
  top: 150px;
  overflow: hidden;
}
#hero h1 {
  font-family: var(--ff-syne) !important;
  font-size: clamp(56px, 16vw, 120px);
  text-transform: none;
  line-height: 0.9;
}
@media (max-width: 767.98px) {
  #hero .row > [class*=col-6] {
    flex: 0 0 100%;
    max-width: 100%;
  }
  #hero h1 {
    font-size: clamp(42px, 12.5vw, 62px);
  }
}

#hero h1 {
  color: var(--color-text);
}
#hero h1::first-letter {
  color: inherit;
}
#hero h1:hover, #hero h1:focus-visible {
  color: var(--color-text);
}
#hero h1:hover::first-letter, #hero h1:focus-visible::first-letter {
  color: inherit;
}

#hero img.img-fluid.rounded {
  mask-image: linear-gradient(to bottom, rgb(0, 0, 0) 68%, rgba(0, 0, 0, 0) 100%);
  mask-size: 100% 100%;
  mask-repeat: no-repeat;
  -webkit-mask-image: linear-gradient(to bottom, rgb(0, 0, 0) 68%, rgba(0, 0, 0, 0) 100%);
  -webkit-mask-size: 100% 100%;
  -webkit-mask-repeat: no-repeat;
}

.hero-cta-group {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem;
  margin-top: clamp(1.2rem, 2vw, 1.8rem);
  margin-bottom: clamp(1.2rem, 2vw, 1.8rem);
  justify-content: center;
}

.hero-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.85rem 1.8rem;
  border-radius: 999px;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-decoration: none;
  transition: transform 160ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 160ms cubic-bezier(0.22, 1, 0.36, 1), background 160ms cubic-bezier(0.22, 1, 0.36, 1), color 160ms cubic-bezier(0.22, 1, 0.36, 1), border-color 160ms cubic-bezier(0.22, 1, 0.36, 1);
}

.hero-cta--primary {
  color: var(--color-text);
  border: 1px solid var(--color-accent);
  transition: transform 160ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 160ms cubic-bezier(0.22, 1, 0.36, 1);
  box-shadow: 0 16px 28px rgba(18, 24, 32, 0.25), 0 0 0 1px rgba(var(--color-bg), 0.35);
}

.hero-cta--primary:hover,
.hero-cta--primary:focus-visible {
  color: var(--color-text);
  transform: translateY(-3px);
  box-shadow: 0 22px 38px rgba(18, 24, 32, 0.42), 0 0 0 2px rgba(var(--color-bg), 0.52), 0 0 22px rgba(var(--color-bg), 0.28);
}

.hero-cta--secondary {
  background: transparent;
  color: var(--color-text);
  border: 1px solid rgba(255, 255, 255, 0.2);
  box-shadow: 0 12px 22px rgba(10, 15, 24, 0.18);
}

.hero-cta--secondary:hover,
.hero-cta--secondary:focus-visible {
  color: var(--color-accent);
  border-color: rgba(var(--color-bg), 0.5);
  transform: translateY(-2px);
  box-shadow: 0 16px 26px rgba(10, 15, 24, 0.28);
}

.section-shell {
  position: relative;
  width: 100%;
  margin: 0 auto;
  padding: clamp(1.5rem, 2vw, 2rem);
  border: var(--card-color-border);
  border-radius: 2rem;
  background: var(--color-bg);
  box-shadow: 0 28px 70px rgba(2, 8, 18, 0.28);
  overflow: hidden;
}

.section-kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  margin-bottom: 1rem;
  color: rgba(255, 255, 255, 0.58);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.section-kicker::before {
  content: "";
  width: 2.4rem;
  height: 1px;
  background: rgba(255, 255, 255, 0.22);
}

.section-lead {
  max-width: 34rem;
  margin: 0;
  color: rgba(255, 255, 255, 0.7);
  font-size: clamp(1.08rem, 1rem + 0.5vw, 1.35rem);
  line-height: 1.55;
}

.layout-section--shopware {
  min-height: auto;
  padding-top: clamp(9rem, 8vw, 18rem);
  padding-bottom: clamp(1rem, 2vw, 3rem);
}

.shopware-section-shell {
  padding: clamp(1.6rem, 2.4vw, 2.4rem);
}

.shopware-section-copy {
  display: grid;
  align-content: space-between;
  gap: 1.25rem;
  min-height: 100%;
}

.shopware-topic-grid {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  height: clamp(420px, 58vh, 620px);
  padding: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  overflow: hidden;
}

.shopware-topic-card {
  position: relative;
  display: flex;
  flex: 1 1 0;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.4rem;
  overflow: hidden;
  padding: 1rem 1.05rem;
  border-radius: 1.6rem;
  border: var(--card-color-border);
  background: var(--card-color-bg);
  color: var(--color-text);
  text-decoration: none;
  transition: flex 500ms cubic-bezier(0.22, 1, 0.36, 1), border-color 220ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

.shopware-topic-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(var(--color-bg), 0.08);
  opacity: 0;
  pointer-events: none;
  transition: opacity 500ms cubic-bezier(0.22, 1, 0.36, 1);
}

.shopware-topic-card--1,
.shopware-topic-card--2,
.shopware-topic-card--3 {
  flex: 1 1 0;
}

.shopware-topic-card:hover,
.shopware-topic-card:focus-visible {
  flex: 4 1 0;
  align-items: flex-start;
  justify-content: flex-start;
  padding: 1.1rem 1.1rem;
  color: var(--color-text);
  border-color: rgba(204, 255, 0, 0.48);
  box-shadow: 0 20px 44px rgba(4, 10, 22, 0.26);
}

.shopware-topic-card:hover::before,
.shopware-topic-card:focus-visible::before {
  opacity: 1;
}

.shopware-topic-card__line {
  width: 0;
  height: 1px;
  background: rgba(204, 255, 0, 0.8);
  opacity: 0;
  transition: width 320ms cubic-bezier(0.22, 1, 0.36, 1), opacity 200ms cubic-bezier(0.22, 1, 0.36, 1);
}

.shopware-topic-card__eyebrow {
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  color: rgba(255, 255, 255, 0.58);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  transition: opacity 200ms cubic-bezier(0.22, 1, 0.36, 1), max-height 260ms cubic-bezier(0.22, 1, 0.36, 1);
}

.shopware-topic-card__head {
  display: flex;
  justify-content: center;
  width: 100%;
  gap: 0.85rem;
  align-items: center;
  position: relative;
  z-index: 1;
}

.shopware-topic-card__title {
  margin: 0;
  min-width: 0;
  font-size: clamp(1.1rem, 1rem + 0.32vw, 1.35rem);
  line-height: 1.05;
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-align: center;
  transform: rotate(0deg);
  transform-origin: center;
  color: var(--color-text);
  transition: transform 500ms cubic-bezier(0.22, 1, 0.36, 1);
}

.shopware-topic-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.85rem;
  height: 1.85rem;
  border-radius: 999px;
  background: rgba(var(--color-bg), 0.14);
  font-size: 0.95rem;
  opacity: 0;
  transition: opacity 220ms cubic-bezier(0.22, 1, 0.36, 1);
  position: relative;
  z-index: 1;
}

.shopware-topic-card__text {
  margin: 0;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  color: rgba(255, 255, 255, 0.68);
  line-height: 1.55;
  position: relative;
  z-index: 1;
  transition: opacity 220ms cubic-bezier(0.22, 1, 0.36, 1), max-height 280ms cubic-bezier(0.22, 1, 0.36, 1);
}

.shopware-topic-card__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: var(--color-accent);
  font-weight: 700;
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  position: relative;
  z-index: 1;
  transition: opacity 220ms cubic-bezier(0.22, 1, 0.36, 1), max-height 280ms cubic-bezier(0.22, 1, 0.36, 1);
}

.shopware-topic-card:hover .shopware-topic-card__title,
.shopware-topic-card:focus-visible .shopware-topic-card__title {
  transform: rotate(0deg);
  text-align: left;
}

.shopware-topic-card:hover .shopware-topic-card__line,
.shopware-topic-card:focus-visible .shopware-topic-card__line {
  width: 4.2rem;
  opacity: 1;
}

.shopware-topic-card:hover .shopware-topic-card__eyebrow,
.shopware-topic-card:focus-visible .shopware-topic-card__eyebrow,
.shopware-topic-card:hover .shopware-topic-card__text,
.shopware-topic-card:focus-visible .shopware-topic-card__text,
.shopware-topic-card:hover .shopware-topic-card__cta,
.shopware-topic-card:focus-visible .shopware-topic-card__cta {
  opacity: 1;
  max-height: 14rem;
}

.shopware-topic-card:hover .shopware-topic-card__icon,
.shopware-topic-card:focus-visible .shopware-topic-card__icon {
  opacity: 1;
}

@media (max-width: 991.98px) {
  .shopware-topic-grid {
    height: auto;
    gap: 0.9rem;
  }
  .shopware-topic-card,
  .shopware-topic-card:hover,
  .shopware-topic-card:focus-visible {
    min-height: 120px;
    align-items: flex-start;
    justify-content: flex-start;
    padding: 1.15rem;
    border-radius: 1.1rem;
    flex: 1 1 auto;
  }
  .shopware-topic-card__line {
    width: 4.2rem;
    opacity: 1;
  }
  .shopware-topic-card__eyebrow,
  .shopware-topic-card__text,
  .shopware-topic-card__cta,
  .shopware-topic-card__icon {
    opacity: 1;
    max-height: 20rem;
  }
  .shopware-topic-card__head {
    justify-content: space-between;
    align-items: flex-start;
  }
  .shopware-topic-card__title {
    min-width: 0;
    white-space: normal;
    text-align: left;
    transform: rotate(0deg);
    letter-spacing: 0.02em;
  }
}
@media (prefers-reduced-motion: reduce) {
  .shopware-topic-card,
  .shopware-topic-card__title,
  .shopware-topic-card__line,
  .shopware-topic-card__eyebrow,
  .shopware-topic-card__text,
  .shopware-topic-card__cta,
  .shopware-topic-card__icon {
    transition: none !important;
  }
}
.shopware-demo-callout {
  display: grid;
  gap: 0.8rem;
  padding: 1.25rem 1.3rem;
  border-radius: 1.5rem;
  border: var(--card-color-border);
  background: var(--card-color-bg);
}

.shopware-demo-callout__eyebrow {
  color: rgba(255, 255, 255, 0.58);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.shopware-demo-callout__title {
  font-size: clamp(1.35rem, 1.1rem + 0.6vw, 1.8rem);
  line-height: 1.05;
}

.shopware-demo-callout__text {
  margin: 0;
  color: rgba(255, 255, 255, 0.68);
  line-height: 1.55;
}

.shopware-demo-callout__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-width: 11rem;
  padding: 0.8rem 1.15rem;
  border-radius: 999px;
  color: var(--color-text);
  font-weight: 700;
  text-decoration: none;
  transition: opacity 160ms cubic-bezier(0.22, 1, 0.36, 1), transform 160ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 160ms cubic-bezier(0.22, 1, 0.36, 1);
}

.shopware-demo-callout__link:hover,
.shopware-demo-callout__link:focus-visible {
  color: var(--color-text);
  transform: translateY(-2px);
  box-shadow: 0 16px 30px rgba(12, 16, 24, 0.34), 0 0 0 1px rgba(var(--color-bg), 0.46), 0 0 20px rgba(var(--color-bg), 0.24);
}

.layout-section--about,
.layout-section--projects,
.layout-section--blog {
  min-height: auto;
  padding: clamp(1rem, 2vw, 3rem) 0;
}

.home-section-copy {
  display: grid;
  gap: 1rem;
  align-content: start;
  min-height: 100%;
}

.home-section-copy--with-link {
  min-height: clamp(240px, 28vw, 340px);
}

.home-section-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  align-self: flex-start;
  margin-top: auto;
  min-width: 11rem;
  padding: 0.82rem 1.18rem;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: linear-gradient(140deg, rgba(255, 255, 255, 0.04), rgba(255, 255, 255, 0.01)), rgba(13, 20, 34, 0.82);
  color: var(--color-text);
  text-decoration: none;
  font-weight: 700;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(7, 12, 20, 0.22), inset 0 0 0 1px rgba(255, 255, 255, 0.03);
  transition: transform 0.2s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.2s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.2s cubic-bezier(0.22, 1, 0.36, 1);
}

.home-section-link__label {
  position: relative;
  z-index: 1;
  display: inline-block;
  margin-left: 0.05em;
  white-space: nowrap;
  transition: transform 0.34s ease-in-out, opacity 0.34s ease-in-out;
}

.home-section-link:hover,
.home-section-link:focus-visible {
  color: var(--color-text);
  border-color: rgba(var(--color-bg), 0.46);
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(7, 12, 20, 0.22), inset 0 0 0 1px rgba(255, 255, 255, 0.03);
}

.home-section-link:hover .home-section-link__label,
.home-section-link:focus-visible .home-section-link__label {
  transform: translateX(0.14em);
  opacity: 1;
}

.home-section-link--inline {
  margin-left: 0;
}

.home-mini-grid {
  display: grid;
  gap: 1rem;
}

.home-mini-card {
  display: grid;
  gap: 0.75rem;
  min-height: 100%;
  padding: 1.2rem 1.25rem;
  border-radius: 1.3rem;
  border: var(--card-color-border);
  background: var(--card-color-bg);
  color: var(--color-text);
  text-decoration: none;
}

.home-mini-card:hover,
.home-mini-card:focus-visible {
  color: var(--color-text);
  border-color: rgba(204, 255, 0, 0.42);
}

.home-mini-card__eyebrow {
  color: rgba(255, 255, 255, 0.52);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.home-mini-card__title {
  margin: 0;
  font-size: clamp(1.25rem, 1.05rem + 0.55vw, 1.65rem);
}

.home-mini-card__text {
  margin: 0;
  color: rgba(255, 255, 255, 0.68);
  line-height: 1.52;
}

.home-mini-card__cta {
  margin-top: auto;
  justify-self: end;
  color: var(--color-accent);
  font-weight: 700;
  font-size: 0.92rem;
}

.project-logo-orbit {
  position: relative;
  isolation: isolate;
}

.project-logo-orbit__mask {
  position: relative;
  overflow: hidden;
  padding: 0.35rem;
  border-radius: 999px;
  background: transparent;
  box-shadow: none;
  mask-image: linear-gradient(90deg, rgba(0, 0, 0, 0) 0, rgba(0, 0, 0, 0.98) 8%, rgba(0, 0, 0, 0.98) 92%, rgba(0, 0, 0, 0) 100%);
  -webkit-mask-image: linear-gradient(90deg, rgba(0, 0, 0, 0) 0, rgba(0, 0, 0, 0.98) 8%, rgba(0, 0, 0, 0.98) 92%, rgba(0, 0, 0, 0) 100%);
}

.project-logo-orbit__track {
  display: flex;
  gap: 0.7rem;
  width: max-content;
  align-items: stretch;
}

.project-logo-pill {
  flex: 0 0 auto;
  width: clamp(220px, 25vw, 320px);
}

.project-logo-pill__link {
  position: relative;
  isolation: isolate;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 0.42rem;
  min-height: clamp(108px, 10vw, 132px);
  padding: 0.9rem 1rem 0.78rem;
  border-radius: 999px;
  background: transparent;
  color: var(--color-text);
  text-decoration: none;
  overflow: hidden;
  transition: transform 220ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

.project-logo-pill__glow {
  display: none;
}

.project-logo-pill__logo-wrap {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 52px;
}

.project-logo-pill__logo {
  position: relative;
  z-index: 1;
  max-width: min(210px, 92%);
  max-height: 52px;
  width: auto;
  height: auto;
  object-fit: contain;
  opacity: 0.92;
  filter: brightness(0) invert(1) grayscale(1) drop-shadow(0 5px 15px rgba(0, 0, 0, 0.3));
  transition: opacity 220ms cubic-bezier(0.22, 1, 0.36, 1), filter 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

.project-logo-pill__logo--hover-state {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  opacity: 0;
  filter: none;
  pointer-events: none;
}

.project-logo-pill__name {
  display: none;
}

.project-logo-pill__link:hover,
.project-logo-pill__link:focus-visible {
  color: var(--color-text);
  transform: translateY(-2px);
  box-shadow: none;
}

.project-logo-pill__link:hover .project-logo-pill__logo,
.project-logo-pill__link:focus-visible .project-logo-pill__logo {
  opacity: 1;
  filter: none;
}

.project-logo-pill__link:hover .project-logo-pill__logo--keep-light,
.project-logo-pill__link:focus-visible .project-logo-pill__logo--keep-light {
  filter: brightness(0) invert(1) grayscale(1) drop-shadow(0 5px 15px rgba(0, 0, 0, 0.3));
}

.project-logo-pill__link--dual-hover:hover .project-logo-pill__logo--base,
.project-logo-pill__link--dual-hover:focus-visible .project-logo-pill__logo--base {
  opacity: 0;
}

.project-logo-pill__link--dual-hover:hover .project-logo-pill__logo--hover-state,
.project-logo-pill__link--dual-hover:focus-visible .project-logo-pill__logo--hover-state {
  opacity: 1;
}

@keyframes project-orbit-marquee {
  0% {
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(-50%, 0, 0);
  }
}
@media (prefers-reduced-motion: no-preference) {
  .project-logo-orbit__track {
    animation: project-orbit-marquee 32s linear infinite;
    will-change: transform;
  }
  .project-logo-orbit__mask:hover .project-logo-orbit__track,
  .project-logo-orbit__mask:focus-within .project-logo-orbit__track {
    animation-play-state: paused;
  }
}
@media (prefers-reduced-motion: reduce) {
  .project-logo-orbit__track {
    animation: none !important;
  }
}
.project-logo-cluster {
  position: relative;
  isolation: isolate;
  min-height: clamp(290px, 34vw, 420px);
}

.project-logo-cluster__links {
  position: absolute;
  inset: 0.5rem 0.75rem;
  z-index: 0;
  pointer-events: none;
}

.project-logo-cluster__link {
  position: absolute;
  height: 1px;
  background: linear-gradient(90deg, rgba(56, 234, 178, 0.06) 0%, rgba(56, 234, 178, 0.36) 50%, rgba(56, 234, 178, 0.06) 100%);
  box-shadow: 0 0 18px rgba(56, 234, 178, 0.16);
  transform-origin: left center;
}

.project-logo-cluster__link--one {
  top: 24%;
  left: 29%;
  width: 42%;
  transform: rotate(-9deg);
}

.project-logo-cluster__link--two {
  top: 50%;
  left: 34%;
  width: 37%;
  transform: rotate(4deg);
}

.project-logo-cluster__link--three {
  top: 72%;
  left: 26%;
  width: 46%;
  transform: rotate(13deg);
}

.project-logo-cluster__nodes {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.26fr 1fr;
  grid-template-areas: "hero satA" "hero satB" "hero satC";
  gap: 0.75rem;
  min-height: inherit;
}

.project-logo-node {
  min-height: 100%;
}

.project-logo-node--hero {
  grid-area: hero;
}

.project-logo-node--satellite-a {
  grid-area: satA;
}

.project-logo-node--satellite-b {
  grid-area: satB;
}

.project-logo-node--satellite-c {
  grid-area: satC;
}

.project-logo-node--fallback {
  grid-column: 1/-1;
}

.project-logo-node__link {
  position: relative;
  isolation: isolate;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 0.5rem;
  min-height: 100%;
  padding: 0.95rem 1rem;
  border-radius: 1.16rem;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: radial-gradient(circle at 18% 12%, rgba(56, 234, 178, 0.12), transparent 36%), linear-gradient(150deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.015));
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04), 0 16px 34px rgba(4, 10, 24, 0.34);
  color: var(--color-text);
  text-decoration: none;
  overflow: hidden;
  transition: border-color 220ms cubic-bezier(0.22, 1, 0.36, 1), transform 220ms cubic-bezier(0.22, 1, 0.36, 1), background 220ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

.project-logo-node--hero .project-logo-node__link {
  padding: 1.2rem 1.2rem 1.05rem;
}

.project-logo-node__halo {
  position: absolute;
  z-index: 0;
  inset: auto auto -62% -34%;
  width: 78%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(204, 255, 0, 0.22), transparent 72%);
  opacity: 0.24;
  transition: opacity 220ms cubic-bezier(0.22, 1, 0.36, 1), transform 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

.project-logo-node--satellite-a .project-logo-node__halo {
  inset: -56% -24% auto auto;
  width: 72%;
}

.project-logo-node--satellite-b .project-logo-node__halo {
  inset: auto -18% -64% auto;
  width: 66%;
}

.project-logo-node--satellite-c .project-logo-node__halo {
  inset: -52% auto auto -22%;
  width: 74%;
}

.project-logo-node__logo-wrap {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 58px;
}

.project-logo-node--hero .project-logo-node__logo-wrap {
  min-height: 72px;
}

.project-logo-node__logo {
  max-width: min(215px, 92%);
  max-height: 58px;
  width: auto;
  height: auto;
  object-fit: contain;
  opacity: 0.92;
  filter: brightness(0) invert(1) grayscale(1) drop-shadow(0 5px 16px rgba(0, 0, 0, 0.3));
  transition: opacity 220ms cubic-bezier(0.22, 1, 0.36, 1), filter 220ms cubic-bezier(0.22, 1, 0.36, 1);
}

.project-logo-node--hero .project-logo-node__logo {
  max-height: 66px;
}

.project-logo-node__name {
  position: relative;
  z-index: 1;
  margin: 0;
  font-size: 0.72rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.47);
  text-align: center;
}

.project-logo-node__link:hover,
.project-logo-node__link:focus-visible {
  color: var(--color-text);
  border-color: rgba(204, 255, 0, 0.4);
  transform: translateY(-2px);
  box-shadow: inset 0 0 0 1px rgba(204, 255, 0, 0.14), 0 18px 42px rgba(5, 12, 28, 0.5);
}

.project-logo-node__link:hover .project-logo-node__logo,
.project-logo-node__link:focus-visible .project-logo-node__logo {
  opacity: 1;
  filter: brightness(0) saturate(100%) invert(86%) sepia(78%) saturate(2333%) hue-rotate(19deg) brightness(109%) contrast(102%) drop-shadow(0 8px 20px rgba(10, 15, 28, 0.46));
}

.project-logo-node__link:hover .project-logo-node__halo,
.project-logo-node__link:focus-visible .project-logo-node__halo {
  opacity: 0.44;
  transform: scale(1.07);
}

@keyframes project-node-float-a {
  0% {
    transform: translate3d(0, 0, 0);
  }
  50% {
    transform: translate3d(0, -4px, 0);
  }
  100% {
    transform: translate3d(0, 0, 0);
  }
}
@keyframes project-node-float-b {
  0% {
    transform: translate3d(0, 0, 0);
  }
  50% {
    transform: translate3d(0, 3px, 0);
  }
  100% {
    transform: translate3d(0, 0, 0);
  }
}
@keyframes project-halo-pulse {
  0% {
    opacity: 0.2;
  }
  50% {
    opacity: 0.3;
  }
  100% {
    opacity: 0.2;
  }
}
@media (prefers-reduced-motion: no-preference) {
  .project-logo-node--hero {
    animation: project-node-float-a 13s ease-in-out infinite;
  }
  .project-logo-node--satellite-a,
  .project-logo-node--satellite-c {
    animation: project-node-float-b 11s ease-in-out infinite;
  }
  .project-logo-node--satellite-b {
    animation: project-node-float-a 12s ease-in-out infinite;
  }
  .project-logo-node__halo {
    animation: project-halo-pulse 9s ease-in-out infinite;
  }
}
@media (prefers-reduced-motion: reduce) {
  .project-logo-node,
  .project-logo-node__halo {
    animation: none !important;
  }
}
.home-blog-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1rem;
}

.blog-home-title {
  display: block !important;
  margin-top: 0.7rem;
}

.home-blog-native-cards {
  margin-top: 0.35rem;
}

.home-blog-card__link {
  display: grid;
  gap: 0.65rem;
  height: 100%;
  padding: 1.1rem 1.15rem;
  border-radius: 1.2rem;
  border: var(--card-color-border);
  background: var(--card-color-bg);
  color: var(--color-text);
  text-decoration: none;
}

.home-blog-card__link:hover,
.home-blog-card__link:focus-visible {
  color: var(--color-text);
  border-color: rgba(204, 255, 0, 0.42);
}

.home-blog-card__date {
  color: rgba(255, 255, 255, 0.52);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.home-blog-card__title {
  margin: 0;
  font-size: clamp(1.08rem, 1rem + 0.36vw, 1.32rem);
  line-height: 1.35;
}

.home-blog-card__text {
  margin: 0;
  color: rgba(255, 255, 255, 0.66);
  line-height: 1.5;
}

.home-blog-card__cta {
  margin-top: auto;
  color: var(--color-accent);
  font-weight: 700;
  font-size: 0.92rem;
}

@media (min-width: 992px) {
  .project-logo-cluster {
    min-height: clamp(290px, 34vw, 420px);
  }
}
@media (max-width: 991.98px) {
  .project-logo-orbit__mask {
    border-radius: 1.4rem;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .project-logo-orbit__mask::-webkit-scrollbar {
    display: none;
  }
  .project-logo-orbit__track {
    width: auto;
    animation: none !important;
  }
  .project-logo-pill {
    width: min(76vw, 300px);
    scroll-snap-align: start;
  }
  .project-logo-cluster__links {
    display: none;
  }
  .project-logo-cluster__nodes {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-areas: "hero satA" "satB satC";
    min-height: 0;
  }
  .project-logo-node--hero .project-logo-node__logo-wrap {
    min-height: 64px;
  }
  .home-blog-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 575.98px) {
  .hero-cta-group {
    width: 100%;
  }
  .hero-cta {
    width: 100%;
    justify-content: center;
  }
  .section-shell {
    padding: 1.2rem;
    border-radius: 1.5rem;
  }
  .shopware-topic-card--1,
  .shopware-topic-card--2,
  .shopware-topic-card--3 {
    grid-column: span 12;
  }
  .home-section-link,
  .home-section-link--inline {
    width: 100%;
    margin-left: 0;
  }
  .home-blog-grid {
    grid-template-columns: 1fr;
  }
  .project-logo-cluster__nodes {
    grid-template-columns: 1fr;
    grid-template-areas: "hero" "satA" "satB" "satC";
  }
  .project-logo-pill {
    width: min(88vw, 320px);
  }
}
body.is-starfield-active {
  position: relative;
  isolation: isolate;
  overflow-x: clip;
}

#hero {
  position: relative;
  overflow: hidden;
}

#hero > .container,
#hero > .container-fluid {
  position: relative;
  z-index: 1;
}

.site-starfield,
.hero-starfield {
  pointer-events: none;
  mix-blend-mode: screen;
}

.site-starfield {
  position: fixed;
  inset: 0;
  z-index: -1;
}

.hero-starfield {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.starfield__layer {
  position: absolute;
  inset: -20%;
  background-repeat: repeat;
  background-image: radial-gradient(2px 2px at 10% 20%, rgba(255, 255, 255, 0.95) 0, rgba(255, 255, 255, 0) 55%), radial-gradient(2px 2px at 30% 80%, rgba(180, 220, 255, 0.9) 0, rgba(255, 255, 255, 0) 55%), radial-gradient(1.5px 1.5px at 55% 35%, rgba(255, 255, 255, 0.9) 0, rgba(255, 255, 255, 0) 55%), radial-gradient(2px 2px at 75% 55%, rgba(170, 255, 255, 0.85) 0, rgba(255, 255, 255, 0) 55%), radial-gradient(2px 2px at 85% 15%, rgba(255, 255, 255, 0.95) 0, rgba(255, 255, 255, 0) 55%), radial-gradient(1.5px 1.5px at 15% 60%, rgba(255, 255, 255, 0.85) 0, rgba(255, 255, 255, 0) 55%), radial-gradient(1.5px 1.5px at 40% 10%, rgba(200, 255, 255, 0.85) 0, rgba(255, 255, 255, 0) 55%), radial-gradient(2px 2px at 65% 90%, rgba(255, 255, 255, 0.9) 0, rgba(255, 255, 255, 0) 55%), radial-gradient(2px 2px at 22% 42%, rgba(190, 240, 255, 0.9) 0, rgba(255, 255, 255, 0) 55%), radial-gradient(2px 2px at 88% 68%, rgba(255, 255, 255, 0.95) 0, rgba(255, 255, 255, 0) 55%);
  background-size: 120px 120px;
  animation: hero-starfield-flicker 9s ease-in-out infinite;
  filter: drop-shadow(0 0 6px rgba(140, 220, 255, 0.35));
}

.starfield__layer--mid {
  background-size: 320px 320px;
  animation-duration: 12s;
  opacity: 0.8;
}

.starfield__layer--near {
  background-size: 420px 420px;
  animation-duration: 15s;
  opacity: 0.9;
}

.starfield--low .starfield__layer {
  background-size: 190px 190px;
  opacity: 0.38;
}

.starfield--low .starfield__layer--mid {
  background-size: 420px 420px;
  opacity: 0.28;
}

.starfield--low .starfield__layer--near {
  background-size: 560px 560px;
  opacity: 0.22;
}

.starfield__spark {
  position: absolute;
  width: 3px;
  height: 3px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.85);
  box-shadow: 0 0 8px rgba(160, 220, 255, 0.7);
  opacity: 0.18;
  transform: translate(-50%, -50%);
  animation: hero-starfield-spark 5.2s ease-in-out infinite;
}

.starfield__spark--1 {
  left: 12%;
  top: 16%;
}

.starfield__spark--2 {
  left: 28%;
  top: 72%;
  animation-delay: 0.8s;
}

.starfield__spark--3 {
  left: 44%;
  top: 24%;
  animation-delay: 1.6s;
}

.starfield__spark--4 {
  left: 63%;
  top: 58%;
  animation-delay: 2.4s;
}

.starfield__spark--5 {
  left: 81%;
  top: 22%;
  animation-delay: 3.2s;
}

.starfield__spark--6 {
  left: 90%;
  top: 76%;
  animation-delay: 4s;
}

.starfield__spark--7 {
  left: 8%;
  top: 48%;
  animation-delay: 1.1s;
  animation-duration: 6.3s;
}

.starfield__spark--8 {
  left: 21%;
  top: 31%;
  animation-delay: 2.2s;
  animation-duration: 4.9s;
}

.starfield__spark--9 {
  left: 37%;
  top: 64%;
  animation-delay: 3.7s;
  animation-duration: 6.8s;
}

.starfield__spark--10 {
  left: 57%;
  top: 14%;
  animation-delay: 0.6s;
  animation-duration: 5.7s;
}

.starfield__spark--11 {
  left: 73%;
  top: 82%;
  animation-delay: 4.5s;
  animation-duration: 7.1s;
}

.starfield__spark--12 {
  left: 95%;
  top: 38%;
  animation-delay: 2.9s;
  animation-duration: 5.4s;
}

.starfield--low .starfield__spark:nth-of-type(n + 8) {
  display: none;
}

@keyframes hero-starfield-flicker {
  0%, 100% {
    opacity: 0.45;
  }
  45% {
    opacity: 0.75;
  }
  70% {
    opacity: 0.55;
  }
}
@keyframes hero-starfield-spark {
  0%, 100% {
    opacity: 0.1;
    transform: translate(-50%, -50%) scale(0.7);
  }
  40% {
    opacity: 0.85;
    transform: translate(-50%, -50%) scale(1.25);
  }
  55% {
    opacity: 0.2;
    transform: translate(-50%, -50%) scale(0.9);
  }
}

/*# sourceMappingURL=all.css.map */
