@charset "utf-8";
/* CSS Document */

/* OPTIONAL: Nur verwenden, wenn du wirklich eine Datei "dependencies.css" lädst.
   Sonst diese Zeile löschen. */
/* @import url("dependencies.css"); */

html {
  scroll-behavior: smooth !important;
}

/* ===== ALLGEMEIN ===== */

body.wrapper-fluid .site-grid {
    grid-gap: 0;
}

#g-page-surround {
  position: relative;
  background:
    radial-gradient(circle at 15% 20%, rgba(0,153,204,.16), transparent 24%),
    radial-gradient(circle at 82% 18%, rgba(0,204,153,.14), transparent 20%),
    radial-gradient(circle at 50% 115%, rgba(0,153,204,.24), transparent 38%),
    linear-gradient(180deg, #02111d 0%, #04506c 52%, #00b39f 100%) !important;
  overflow: hidden;
}

#g-navigation {
  text-align: center;
  background: transparent;
}

#g-navigation .g-main-nav .g-toplevel > li.active > .g-menu-item-container > .g-menu-item-content {
  box-shadow: 0 2px 0 rgb(0 153 204);
}

#g-navigation .g-main-nav .g-toplevel > li > .g-menu-item-container {
    color: #fff;
  font-weight: 400;
  }

.row {
  padding-right: 0 !important;
  padding-left: 0 !important;
  --bs-gutter-x: 0 !important;
}

#g-mainbar {
  padding: 0;
	margin: 20px auto;
  padding: 20px;
  border: 2px solid #e0e0e0;
  border-radius: 2em;
  box-shadow: 0 10px 10px rgba(0, 0, 0, 0.5);
}

#g-container-main {
  margin-top: -82px;
}

@media (max-width: 1200px) {
	#g-container-main {
  margin-top: -163px;
	}}

.drop-shadow-png img {
  filter: drop-shadow(20px 20px 20px gray);
}

/* ===== LOGO ===== */
.g-logo img,
.g-logo svg {
  display: inline-block;
}

/* ===== BLOG OVERFLOW ===== */
.blog-item,
.blog-item .item-image {
  overflow: visible !important;
}

/* ===== UTILS ===== */
.text-align-center {
  text-align: center;
}

/* ===== OFFCANVAS MENU ===== */
.g-offcanvas-toggle {
  color: #fff;
  padding: 1em;
  border-radius: 50%;
  border: solid 0.2em #fff;

  display: flex;
  justify-content: center;
  align-items: center;

  font-size: 1.5em;
  background: linear-gradient(135deg, #0099cc, #00cc99);

  position: fixed;
  opacity: 0.85;
}

.g-offcanvas-open #g-offcanvas {
  align-content: center;
}

#g-mobilemenu-container i {
  float: none;
}

#g-offcanvas #g-mobilemenu-container ul > li.g-menu-item-link-parent > .g-menu-item-container > .g-menu-parent-indicator {
  border: 1px solid #0099cc;
  background: #ffffff;
}

#g-offcanvas #g-mobilemenu-container ul > li:not(.g-menu-item-type-particle):not(.g-menu-item-type-module).active {
  background: linear-gradient(135deg, rgba(0, 153, 204, 1) 0%, rgba(0, 204, 153, 1) 100%);
  border-radius: 5em 0 0 5em;
}

#g-offcanvas #g-mobilemenu-container ul i.fa {
  display: inline-flex;
  justify-content: center;
  align-items: center;

  width: 40px;
  height: 40px;

  border-radius: 50%;
  border: 3px solid transparent;

  background: linear-gradient(135deg, #0099cc, #00cc99) padding-box, #fff border-box;
  color: #fff;

  margin-right: 15px;
}

/* WENN AKTIV / HOVER */
#g-offcanvas #g-mobilemenu-container ul > li:not(.g-menu-item-type-particle):not(.g-menu-item-type-module).active > .g-menu-item-container,
#g-offcanvas #g-mobilemenu-container ul > li:not(.g-menu-item-type-particle):not(.g-menu-item-type-module):hover > .g-menu-item-container {
  color: #ffffff;
  font-weight: 700;
}

/* WENN AKTIV */
#g-offcanvas #g-mobilemenu-container ul > li.g-menu-item-link-parent.active > .g-menu-item-container > .g-menu-parent-indicator {
  border: none;
  background: none;
}

/* ===== GLOBAL FONT / HEADINGS ===== */
h1, h2, h3, h4, h5, h6 {
  color: #333;
  margin-top: 0.5em;
  line-height: 1.2;
}

h1 { font-size: 2.5em; font-weight: 700; }
h2 { font-size: 2em;   font-weight: 700; }
h3 { font-size: 1.75em;font-weight: 700; }
h4 { font-size: 1.5em; font-weight: 700; }
h5 { font-size: 1.25em;font-weight: 700; }
h6 { font-size: 1em;   font-weight: 700; }

@media (max-width: 1200px) {
  h1 { font-size: 2.25em; }
  h2 { font-size: 1.85em; }
  h3 { font-size: 1.6em; }
  h4 { font-size: 1.35em; }
  h5 { font-size: 1.1em; }
  h6 { font-size: 0.95em; }
}
@media (max-width: 992px) {
  h1 { font-size: 2em; }
  h2 { font-size: 1.75em; }
  h3 { font-size: 1.5em; }
  h4 { font-size: 1.25em; }
  h5 { font-size: 1em; }
  h6 { font-size: 0.9em; }
}
@media (max-width: 768px) {
  h1 { font-size: 1.75em; }
  h2 { font-size: 1.6em; }
  h3 { font-size: 1.4em; }
  h4 { font-size: 1.2em; }
  h5 { font-size: 1em; }
  h6 { font-size: 0.85em; }
}
@media (max-width: 576px) {
  h1 { font-size: 1.5em; }
  h2 { font-size: 1.4em; }
  h3 { font-size: 1.25em; }
  h4 { font-size: 1.1em; }
  h5 { font-size: 0.95em; }
  h6 { font-size: 0.8em; }
}

/* ===== BLOG ===== */
.blog_div_1 {
  box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
  margin-top: 50px;
  border-radius: 15px;
}
.blog_div_image {
  font-size: 120pt;
  text-align: center;
}
.blog_div_text {
  padding: 50px;
}

/* ===== NACH OBEN BUTTON ===== */
.g-totop i {
  color: #fff;
  width: 50px;
  height: 50px;
  padding: 0.5em;

  border-radius: 50%;
  border: solid 2px #fff;

  display: flex;
  justify-content: center;
  align-items: center;

  text-align: center;
  font-size: 1.5em;

  background: linear-gradient(135deg, #0099cc, #00cc99);
  position: fixed;
  bottom: 20px;
  right: 20px;
  opacity: 0.5;
}

@media (max-width: 768px) {
  .g-totop i {
    width: 35px;
    height: 35px;
    font-size: 1em;
  }
}

/* ===== GRADIENT ANIMATION ===== */
.bg-gradient-animation {
  background: linear-gradient(-45deg, #0099cc, #00cc99, #0099cc, #00cc99);
  background-size: 400% 100%;
  animation: gradient 5s ease infinite;
}
@keyframes gradient {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* ===== WAVES ===== */
.waves {
  position: relative;
  width: 100%;
  height: 15vh;
  margin-bottom: -7px;
  min-height: 100px;
  max-height: 150px;
}

.parallax > use {
  animation: move-forever 25s cubic-bezier(.55, .5, .45, .5) infinite;
}
.parallax > use:nth-child(1) { animation-delay: -2s; animation-duration: 7s; }
.parallax > use:nth-child(2) { animation-delay: -3s; animation-duration: 10s; }
.parallax > use:nth-child(3) { animation-delay: -4s; animation-duration: 13s; }
.parallax > use:nth-child(4) { animation-delay: -5s; animation-duration: 20s; }

@keyframes move-forever {
  0%   { transform: translate3d(-90px, 0, 0); }
  100% { transform: translate3d(85px, 0, 0); }
}

/* ===== ASTRONAUT FLOAT ===== */
.astronaut-float {
  animation: float 1.5s ease alternate infinite;
  filter: drop-shadow(0px 15px 15px rgba(0, 0, 0, 0.35));
}
@keyframes float {
  0%   { transform: translateY(0); }
  100% { transform: translateY(-18px); }
}

/* ===== PULSE / CARDS ===== */
.pulse_div_container {
  justify-content: center;
  align-items: center;
  text-align: center;
}
.pulse_div_container a {
  text-decoration: none;
  transition: all 0.25s;
  color: black;
}

.hover_shadow:hover {
  padding: 35px 20px 20px 20px;
  border-radius: 25px;
  box-shadow: 0 0 20px rgba(33, 33, 33, 0.2);
  transition-duration: 0.5s;
}

.div_round_aufmerksam {
  color: #fff;
  width: 50px;
  height: 50px;
  padding: 50px;
  border-radius: 50%;
  border: solid 5px #fff;

  justify-content: center;
  align-items: center;
  text-align: center;
  display: flex;

  background: linear-gradient(135deg, #0099cc, #00cc99);
  animation: gradient 5s ease infinite;

  clear: both;
  margin: auto;
  font-size: 3em;
}

.div_oval_startseite_aufmerksam {
  color: #fff;
  width: 150px;
  height: 150px;
  padding: 100px;
  border-radius: 50%;
  border: solid 5px #fff;

  justify-content: center;
  align-items: center;
  text-align: center;
  display: flex;

  background: linear-gradient(135deg, #0099cc, #00cc99);
  animation: gradient 5s ease infinite;

  clear: both;
  margin: auto;
  font-size: 5em;
}

.pulse {
  animation: pulse-animation 1.5s infinite;
}
@keyframes pulse-animation {
  0%   { box-shadow: 0 0 0 0px rgba(0, 153, 204, 0.5); }
  100% { box-shadow: 0 0 0 20px rgba(0, 153, 204, 0); }
}

.div_button_aufmerksam {
  color: #fff;
  padding: 20px 10px;
  border-radius: 25px;
  border: solid 5px #fff;

  align-items: center;
  display: flex;
  text-align: left;

  background: linear-gradient(135deg, #0099cc, #00cc99);
  animation: gradient 5s ease infinite;

  clear: both;
  margin: auto;
  font-size: 1em;
}

/* ===== BUTTONS ===== */
.btn-white-frame {
  text-align: center;
  margin: 35px auto;
  display: flex;
  justify-content: center;
  align-items: center;

  padding: 20px 50px;
  min-width: 150px;
  min-height: 50px;

  font-size: 1.2em;
  letter-spacing: 0.1em;

  border-radius: 100px;
  cursor: pointer;
  font-weight: 700;
  position: relative;

  border: 5px solid #fff;
  background: transparent;
  color: #fff;

  overflow: hidden;
  transition: transform 0.1s ease-out, box-shadow 0.1s ease-out;
  text-decoration: none;
}

.btn-white-frame:hover {
  transform: scale(1.05);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.35);
  color: #fff;
}

.btn-white-frame i {
  font-size: 1em;
  padding: 0 10px;
  transition: transform 0.1s linear;
}

.btn-white-frame:hover i {
  transform: translateX(10px);
}

.btn-white-frame a {
  color: #fff !important;
  text-decoration: none !important;
}

@media only screen and (max-width: 768px) {
  .btn-white-frame { width: 100%; }
}

.btn-blue-frame {
  text-align: center;
  margin: 35px auto;
  display: flex;
  justify-content: center;
  align-items: center;

  padding: 20px 50px;
  min-width: 150px;
  min-height: 50px;

  font-size: 1.2em;
  letter-spacing: 0.1em;

  border-radius: 100px;
  cursor: pointer;
  font-weight: 700;
  position: relative;

  border: 5px solid transparent;
  background: linear-gradient(135deg, #0099cc, #00cc99) padding-box, #fff border-box;
  color: #fff;

  overflow: hidden;
  transition: transform 0.3s ease-out, box-shadow 0.3s ease-out;
}

.btn-blue-frame:hover { transform: scale(1.05); }

.btn-blue-frame i {
  font-size: 1em;
  padding: 0 10px;
  transition: transform 0.1s linear;
}

.btn-blue-frame:hover i { transform: translateX(10px); }

.btn-blue-frame a {
  color: #fff !important;
  text-decoration: none;
}

@media only screen and (max-width: 768px) {
  .btn-blue-frame { width: 100%; }
}

/* ===== GLOW BOX ===== */
.div_glow_box_circle_icon {
  color: #fff;
  width: 70px;
  height: 70px;
  padding: 35px;

  border-radius: 50%;
  border: solid 5px #fff;

  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 2.5em;

  background: linear-gradient(135deg, #0099cc, #00cc99);
  position: absolute;
  bottom: -35px;
  left: 50%;

  transform: translateX(-50%);
  transition: transform 0.3s ease-out;
}

.div_glow_box_circle_icon:hover {
  transform: translateX(-50%) scale(1.1);
}

.div_glow_box_circle_icon a {
  color: #fff !important;
  text-decoration: none;
}

.div_glow_box {
  outline: none;
  background: #fff;
  z-index: 0;

  padding: 25px 25px 50px 25px;
  position: relative;

  border-radius: 25px;
  box-shadow: 0 0 0 20px rgba(0, 0, 0, 0.025);
  margin: 20px;
}

.div_glow_box:before {
  content: '';
  background: linear-gradient(135deg, #ccc, #0099cc, #00cc99, #ccc, #0099cc, #00cc99, #ccc, #0099cc, #00cc99, #ccc);
  position: absolute;
  top: 10px;
  left: -2px;

  width: calc(100% + 4px);
  height: calc(100% + 4px);

  transform: scale(0.9);
  background-size: 400%;
  z-index: -1;

  filter: blur(20px);
  animation: glowing 20s linear infinite;

  opacity: 1;
  transition: opacity 0.3s ease-in-out;
  border-radius: 25px;
}

.div_glow_box:after {
  z-index: -1;
  content: '';
  position: absolute;

  width: 100%;
  height: 100%;

  background: #fff;
  left: 0;
  top: 0;
  border-radius: 25px;
}

@keyframes glowing {
  0%   { background-position: 0 0; }
  50%  { background-position: 400% 0; }
  100% { background-position: 0 0; }
}

/* ===== SVG GLOW BOTTOM ===== */
.svg_glow_logo {
  position: relative;
  z-index: 0;
}
.svg_glow_logo:before {
  content: '';
  position: absolute;
  top: 120%;
  left: 50%;

  width: 80%;
  height: 10%;

  transform: translate(-50%, -50%);
  background: linear-gradient(135deg, #ccc, #0099cc, #00cc99, #ccc, #0099cc, #00cc99, #ccc, #0099cc, #00cc99, #ccc);
  background-size: 400%;

  z-index: -1;
  filter: blur(3px);
  animation: glowing 20s linear infinite;
  border-radius: 50%;
}

/* ===== CONTACT ICONS ===== */
.contact-icons {
  display: flex;
  justify-content: center;
  gap: 15px;
  margin: 20px 0;
}
.contact-icon {
  display: inline-flex;
  justify-content: center;
  align-items: center;

  padding: 15px;
  width: 50px;
  height: 50px;
  font-size: 1.5em;

  border-radius: 50%;
  cursor: pointer;

  border: 5px solid transparent;
  background: linear-gradient(135deg, #0099cc, #00cc99) padding-box, #fff border-box;
  color: #fff;

  transition: transform 0.3s ease-out, box-shadow 0.3s ease-out;
}
.contact-icon:hover { transform: scale(1.1); }
.contact-icon a {
  color: #fff !important;
  text-decoration: none;
}

/* ===== PRICE TABLE ===== */
.pricing-table {
  margin: 20px auto;
  padding: 20px;
  border: 2px solid #e0e0e0;
  border-radius: 2em;
  background-color: #f9f9f9;
  box-shadow: 0 10px 10px rgba(0, 0, 0, 0.1);
}

.pricing-table__header {
  font-size: 2em;
  margin-bottom: 15px;
  color: #333;
}

.pricing-table img {
  width: 100%;
  height: auto;
  border-radius: 1em;
  margin-bottom: 15px;
}

.pricing-table__price {
  font-size: 2em;
  margin: 15px 0;
  font-weight: bold;
}

.pricing-table__price span {
  font-size: 0.5em;
}

.pricing-table__list {
  list-style: none;
  padding: 0;
  margin: 20px 0;
  text-align: left;
}

.pricing-table__list li {
  margin-bottom: 10px;
  font-size: 0.9em;
  color: #666;

  padding-left: 20px;
  position: relative;

  border-bottom: 1px solid #e0e0e0;
  padding-bottom: 10px;
}

.pricing-table__list li:before {
  content: "\2713";
  color: #0099cc;
  font-weight: bold;
  position: absolute;
  left: 0;
}

.pricing-table__list li:last-child {
  border-bottom: none;
}


/* HEADER MENUE NAVIGATION */
/* =========================================================
   FIX: Graue Fläche + fehlerhaftes Dropdown (Quix Dropbar)
   -> Dropbar transparent machen + Layering korrigieren
========================================================= */

/* Header immer über allem */
.aufmerksam-nav .qx-navbar{
  position: relative;
  z-index: 9998;
}

/* Dropbar/Dropnav-Container: keine graue Fläche, kein Shadow */
.aufmerksam-nav .qx-dropbar,
.aufmerksam-nav .qx-dropbar-top,
.aufmerksam-nav .qx-dropnav-dropbar,
.aufmerksam-nav .qx-navbar-dropbar{
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}

/* Wichtig: Dropbar darf keine "Block-Fläche" aufziehen */
.aufmerksam-nav .qx-dropbar-top{
  height: auto !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Dropdown-Panel muss über Dropbar liegen */
.aufmerksam-nav .qx-navbar-dropdown{
  z-index: 9999 !important;
}

/* Falls Quix eine Overlay-Fläche innerhalb der Dropbar nutzt */
.aufmerksam-nav .qx-dropbar *[class*="overlay"],
.aufmerksam-nav .qx-dropbar .qx-background-overlay{
  background: transparent !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Optional: Wenn immer noch eine Fläche "klickt" / blockiert */
.aufmerksam-nav .qx-dropbar,
.aufmerksam-nav .qx-dropbar-top{
  pointer-events: none;
}
.aufmerksam-nav .qx-navbar-dropdown,
.aufmerksam-nav .qx-navbar-dropdown *{
  pointer-events: auto;
}
/* =========================================================
   PATCH: kompakter Header + korrekt positioniertes Dropdown
   + futuristisch-clean (aufmerksam Stil)
========================================================= */

/* 1) Header kompakter */
.aufmerksam-nav .qx-navbar-nav > li > a{
  padding: 10px 12px !important;
  font-size: 14px !important;
  border-radius: 11px !important;
  font-weight: 650;
}

/* Underline näher an Text (futuristischer, nicht so tief) */
.aufmerksam-nav .qx-navbar-nav > li > a::after{
  bottom: 6px !important;
  left: 12px !important;
  right: 12px !important;
  opacity: .85 !important;
}

/* 2) Dropdown direkt unter der Navbar ausrichten */
.aufmerksam-nav .qx-navbar{
  position: relative !important;
}

/* Wichtig: Quix setzt inline top/left – wir überschreiben das sauber */
.aufmerksam-nav .qx-navbar-dropdown{
  margin-top: 8px !important;
  top: calc(100% + 8px) !important; /* direkt unter der Navbar */
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: min(1100px, calc(100vw - 32px)) !important;

  /* Futuristisch-clean Panel */
  border-radius: 18px !important;
  border: 1px solid rgba(0,0,0,.08) !important;
  background: rgba(255,255,255,.92) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 22px 55px rgba(0,0,0,.14) !important;
  overflow: hidden;
}

/* Energy Line oben im Panel (2156, aber clean) */
.aufmerksam-nav .qx-navbar-dropdown::before{
  content:"";
  position:absolute;
  left:0; right:0; top:0;
  height: 2px;
  background: linear-gradient(135deg, #0099cc 0%, #00cc99 100%);
  opacity: .95;
}

/* 3) Mega-Menü Grid: kompakt & hochwertig */
.aufmerksam-nav .qx-navbar-dropdown .qx-navbar-dropdown-nav{
  display: grid !important;
  grid-template-columns: repeat(3, minmax(200px, 1fr) !important;
  gap: 6px 14px !important;
  padding: 16px !important;          /* weniger Luft */
  margin: 0 !important;
}

/* Dropdown Links: als „soft cards“ (futuristisch, aber nicht übertrieben) */
.aufmerksam-nav .qx-navbar-dropdown .qx-navbar-dropdown-nav > li > a{
  padding: 11px 12px !important;
}

/* =========================================================
   OFFCANVAS (QUIX) – aufmerksam Futuristic Clean
   Target: #qx-joomla-menu-truyx-offcanvas
========================================================= */

:root{
  --aufm-acc:#2d5c88;
  --aufm-g1:#0099cc;
  --aufm-g2:#00cc99;
  --aufm-grad: linear-gradient(135deg, var(--aufm-g1), var(--aufm-g2));
  --aufm-txt:#0b0f14;
  --aufm-line: rgba(0,0,0,.10);
  --aufm-shadow: 0 18px 45px rgba(0,0,0,.16);
}

/* ---------- Hamburger Button (Trigger) ---------- */
/* sitzt in deiner .aufmerksam-nav, daher dort stylen */
.aufmerksam-nav .hamburger-menu .qx-button.qx-button-link{
  width: 48px;
  height: 48px;
  border-radius: 999px;

  background: var(--aufm-grad);
  border: 2px solid rgba(255,255,255,.95);

  display: inline-flex;
  align-items: center;
  justify-content: center;

  box-shadow: 0 12px 24px rgba(0,0,0,.18);
  opacity: .92;
  transition: transform .15s ease, opacity .15s ease, box-shadow .15s ease;
}

.aufmerksam-nav .hamburger-menu .qx-button.qx-button-link:hover{
  transform: translateY(-1px);
  opacity: 1;
  box-shadow: 0 16px 30px rgba(0,0,0,.20);
}

/* SVG Lines im Button */
.aufmerksam-nav .hamburger-menu .qx-button.qx-button-link svg rect{
  fill: #fff !important;
  opacity: .95;
}

/* ---------- Offcanvas Panel ---------- */
#qx-joomla-menu-truyx-offcanvas.qx-offcanvas .qx-offcanvas-bar{
  background: rgba(255,255,255,.96) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  border-left: 1px solid rgba(0,0,0,.08) !important;
  box-shadow: var(--aufm-shadow) !important;

  padding: 16px 14px !important;
  position: relative;
}

/* Energy line oben */
#qx-joomla-menu-truyx-offcanvas.qx-offcanvas .qx-offcanvas-bar::before{
  content:"";
  position:absolute;
  left:0; right:0; top:0;
  height: 2px;
  background: var(--aufm-grad);
  opacity: .95;
}

/* Close Button */
#qx-joomla-menu-truyx-offcanvas.qx-offcanvas .qx-offcanvas-close{
  width: 42px;
  height: 42px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;

  background: rgba(0,0,0,.03);
  border: 1px solid rgba(0,0,0,.08);
  transition: background .15s ease, transform .15s ease;
}
#qx-joomla-menu-truyx-offcanvas.qx-offcanvas .qx-offcanvas-close:hover{
  background: rgba(45,92,136,.08);
  transform: translateY(-1px);
}
#qx-joomla-menu-truyx-offcanvas.qx-offcanvas .qx-offcanvas-close svg line{
  stroke: #000 !important;
  opacity: .75;
}

/* ---------- Menu List Spacing (kompakt) ---------- */
#qx-joomla-menu-truyx-offcanvas.qx-offcanvas .qx-offcanvas-bar .qx-nav{
  margin-top: 12px !important;
  gap: 8px;
}

/* Main links (Pill) */
#qx-joomla-menu-truyx-offcanvas.qx-offcanvas .qx-offcanvas-bar .qx-nav > li > a{
  position: relative !important;
  display:flex !important;
  align-items:center !important;

  padding: 12px 12px !important;       /* kompakter */
  border-radius: 999px !important;

  color: var(--aufm-txt) !important;
  font-weight: 750 !important;
  letter-spacing: .1px;

  border: 1px solid rgba(0,0,0,.08) !important;
  background: rgba(255,255,255,.92) !important;

  transition: transform .14s ease, box-shadow .14s ease, background .14s ease, border-color .14s ease, color .14s ease;
}

/* Energy Dot (statt Icons – lightweight, futuristisch) */
#qx-joomla-menu-truyx-offcanvas.qx-offcanvas .qx-offcanvas-bar .qx-nav > li > a::before{
  content:"";
  width: 10px;
  height: 10px;
  border-radius: 999px;
  margin-right: 10px;
  background: var(--aufm-grad);
  opacity: .95;
}

/* Hover */
#qx-joomla-menu-truyx-offcanvas.qx-offcanvas .qx-offcanvas-bar .qx-nav > li > a:hover{
  transform: translateY(-1px);
  border-color: rgba(45,92,136,.18) !important;
  box-shadow: 0 10px 18px rgba(45,92,136,.10) !important;
  background: rgba(45,92,136,.06) !important;
}

/* Active (qx-active) – Gradient Pill links offen */
#qx-joomla-menu-truyx-offcanvas.qx-offcanvas .qx-offcanvas-bar .qx-nav > li.qx-active > a{
  background: var(--aufm-grad) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 999px 0 0 999px !important;
  box-shadow: 0 16px 28px rgba(0,153,204,.18) !important;
}
#qx-joomla-menu-truyx-offcanvas.qx-offcanvas .qx-offcanvas-bar .qx-nav > li.qx-active > a::before{
  background: rgba(255,255,255,.95);
  opacity: 1;
}

/* ---------- Submenu ---------- */
#qx-joomla-menu-truyx-offcanvas.qx-offcanvas .qx-offcanvas-bar .qx-nav-sub{
  margin: 8px 0 6px 16px !important;
  padding-left: 10px !important;
  border-left: 1px solid rgba(0,0,0,.10) !important;
}

#qx-joomla-menu-truyx-offcanvas.qx-offcanvas .qx-offcanvas-bar .qx-nav-sub > li > a{
  display:flex !important;
  align-items:center !important;

  padding: 10px 10px !important;      /* kompakt */
  border-radius: 14px !important;

  font-weight: 650 !important;
  color: rgba(11,15,20,.85) !important;

  background: rgba(0,0,0,.02) !important;
  border: 1px solid rgba(0,0,0,.06) !important;

  transition: background .14s ease, transform .14s ease, border-color .14s ease;
}

#qx-joomla-menu-truyx-offcanvas.qx-offcanvas .qx-offcanvas-bar .qx-nav-sub > li > a::before{
  content:"";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  margin-right: 10px;
  background: rgba(45,92,136,.55);
}

#qx-joomla-menu-truyx-offcanvas.qx-offcanvas .qx-offcanvas-bar .qx-nav-sub > li > a:hover{
  background: rgba(45,92,136,.06) !important;
  border-color: rgba(45,92,136,.16) !important;
  transform: translateY(-1px);
}

/* Focus */
#qx-joomla-menu-truyx-offcanvas.qx-offcanvas a:focus-visible,
#qx-joomla-menu-truyx-offcanvas.qx-offcanvas button:focus-visible{
  outline: 3px solid rgba(45,92,136,.35);
  outline-offset: 2px;
  border-radius: 12px;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  #qx-joomla-menu-truyx-offcanvas.qx-offcanvas *{
    transition: none !important;
    animation: none !important;
  }
}

/* =========================================================
   STICKY ICON LEADS (MOBILE)
========================================================= */
:root{
  --lead-g1:#0099cc;
  --lead-g2:#00cc99;
  --lead-grad: linear-gradient(135deg, var(--lead-g1), var(--lead-g2));

  --lead-bg: rgba(255,255,255,.20);
  --lead-border: rgba(0,0,0,.08);
  --lead-shadow: 0 10px 30px rgba(0,0,0,.10);
  --lead-radius: 18px;

  --btn-size: 56px;         /* circle size for phone/mail */
  --btn-size-primary: 66px; /* circle size for WhatsApp */

  --btn-bg: rgba(255,255,255,.92);
  --btn-border: rgba(0,0,0,.10);
  --btn-shadow: 0 10px 22px rgba(0,0,0,.10);

  --focus: rgba(0,153,204,.38);

  /* Pulse tuning (only for primary button) */
  --pulse-color: rgba(0,204,153,.45);
  --pulse-size: 20px;
}

/* Container */
.sticky-leads{
  position: fixed;
  left: 12px;
  right: 12px;
  bottom: 12px;
  z-index: 9999;

  display: none;
  justify-content: center;
  align-items: center;
  gap: 14px;
  padding: 10px 12px;

  background: var(--lead-bg);
  border: 1px solid var(--lead-border);
  border-radius: var(--lead-radius);
  box-shadow: var(--lead-shadow);

  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

/* Base circular button */
.sticky-leads .lead-btn{
  width: var(--btn-size);
  height: var(--btn-size);
  flex: 0 0 auto;

  display: grid;
  place-items: center;

  border-radius: 50%;
  text-decoration: none;

  color: #0b0f14;
  background: var(--btn-bg);
  border: 1px solid var(--btn-border);
  box-shadow: var(--btn-shadow);

  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease, background .14s ease;
  will-change: transform;
}

/* Icon sizing */
.sticky-leads .lead-btn i{
  font-size: 20px;
  line-height: 1;
}

/* Hover/active */
.sticky-leads .lead-btn:hover{
  transform: translateY(-1px);
  border-color: rgba(0,153,204,.25);
  box-shadow: 0 14px 26px rgba(0,153,204,.12);
}

.sticky-leads .lead-btn:active{
  transform: translateY(0);
  box-shadow: var(--btn-shadow);
}

/* Focus visible */
.sticky-leads .lead-btn:focus-visible{
  outline: 3px solid var(--focus);
  outline-offset: 3px;
}

/* Primary (WhatsApp) - larger + gradient */
.sticky-leads .lead-btn--primary{
  width: var(--btn-size-primary);
  height: var(--btn-size-primary);

  background: var(--lead-grad);
  color: #fff;
  border-color: rgba(255,255,255,.28);
  box-shadow: 0 16px 34px rgba(0,153,204,.18);

  /* emphasized presence without breaking layout */
  transform: translateY(-2px);
}

/* Primary hover keeps emphasis */
.sticky-leads .lead-btn--primary:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 38px rgba(0,204,153,.18);
}

/* Pulse ONLY on WhatsApp button */
.sticky-leads .lead-btn--primary{
  animation: lead-pulse 1.8s infinite;
}

@keyframes lead-pulse{
  0%   { box-shadow: 0 0 0 0 var(--pulse-color), 0 16px 34px rgba(0,153,204,.18); }
  100% { box-shadow: 0 0 0 var(--pulse-size) rgba(0,204,153,0), 0 16px 34px rgba(0,153,204,.18); }
}

/* Mobile only */
@media (max-width: 768px){
  .sticky-leads{ display:flex; }
  body{ padding-bottom: 110px; } /* Platz: Kreisbuttons + Container */
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .sticky-leads .lead-btn--primary{
    animation: none;
  }
  .sticky-leads .lead-btn{
    transition: none;
  }
}

/* Backdrop-filter fallback */
@supports not ((backdrop-filter: blur(10px)) or (-webkit-backdrop-filter: blur(10px))){
  .sticky-leads{
    background: rgba(255,255,255,.85);
  }
}

/* =========================================================
   VISIBILITY STATES (Slide Up)
========================================================= */

/* Standardzustand: versteckt (aber nur auf Mobile aktiv, siehe Media Query unten) */
.sticky-leads{
  opacity: 0;
  transform: translateY(120%);
  pointer-events: none;
}

/* Sichtbar */
.sticky-leads.is-visible{
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

/* Transition nur wenn Motion erlaubt */
@media (prefers-reduced-motion: no-preference){
  .sticky-leads{
    transition: transform .22s ease, opacity .22s ease;
  }
}

