/*
Theme Name: UPH Version 2.19.6 Menu Clean
Theme URI: https://uniphone-hannover.de
Author: UniPhone Hannover
Description: Header und Home exakt gleiche Größe wie Screenshot, nicht vergrößert, nicht verschwommen, Footer gleiche Breite.
Version: 2.23.0
Text Domain: uniphone-full-exakt
*/
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:#f7f4ff;font-family:Arial,Helvetica,sans-serif;color:#111}
a{text-decoration:none;color:inherit}

.site-width{
  width:100%;
  max-width:1536px;
  margin:0 auto;
}

.full-home{
  position:relative;
  background:#f7f4ff;
  overflow:hidden;
}

.full-home img{
  width:100%;
  max-width:1536px;
  height:auto;
  display:block;
  margin:0 auto;
  image-rendering:auto;
}

.hotspot{
  position:absolute;
  display:block;
  z-index:5;
}

/* Klickbereiche passend zum Screenshot */
.hot-home{left:5.6%;top:19.5%;width:5.2%;height:7.8%}
.hot-services-menu{left:13.2%;top:23.6%;width:14.5%;height:4.5%}
.hot-about{left:30.2%;top:23.7%;width:7.4%;height:4.5%}
.hot-news{left:39.5%;top:23.7%;width:7.5%;height:4.5%}
.hot-shop{left:49.2%;top:23.7%;width:5%;height:4.5%}
.hot-contact-menu{left:55.8%;top:23.7%;width:6.2%;height:4.5%}
.hot-phone{left:32.8%;top:8.4%;width:13.2%;height:7%}
.hot-mail{left:63.8%;top:8.2%;width:16.2%;height:7%}
.hot-services-btn{left:5.5%;top:81.8%;width:16.4%;height:6.2%}
.hot-contact-btn{left:23.2%;top:81.8%;width:17.3%;height:6.2%}
.hot-facebook{left:79.6%;top:23.4%;width:2.8%;height:4.5%}
.hot-youtube{left:86.8%;top:23.4%;width:2.8%;height:4.5%}

.section{
  width:100%;
  max-width:1536px;
  margin:0 auto;
  padding:70px 5.5%;
  background:#fff;
}

.section.alt{background:#f7f4ff}
.section h2{font-size:38px;text-transform:uppercase;text-align:center;margin:0 0 14px}
.section p{font-size:17px;line-height:1.7;text-align:center;max-width:760px;margin:0 auto 35px;color:#555}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:#fff;border:1px solid #eee8ff;border-radius:12px;padding:30px;box-shadow:0 14px 32px rgba(45,12,128,.10)}
.card h3{margin:0 0 12px;font-size:21px}
.card p{text-align:left;margin:0;color:#555;font-size:16px}

.footer{
  width:100%;
  max-width:1536px;
  margin:0 auto;
  background:linear-gradient(135deg,#5d27df 0%,#4212aa 55%,#26006c 100%);
  color:#fff;
  padding:42px 5.5% 28px;
}
.footer-box{
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  box-shadow:0 18px 38px rgba(0,0,0,.22);
  min-height:360px;
  padding:42px 38px;
  display:grid;
  grid-template-columns:1.25fr .55fr .65fr .85fr;
  gap:48px;
}
.footer h3{font-size:18px;text-transform:uppercase;margin:0 0 22px;color:#fff}
.footer p,.footer li,.footer a{font-size:16px;line-height:1.65;color:#eee9ff}
.footer ul{list-style:none;margin:0;padding:0;display:grid;gap:11px}
.social{display:flex;gap:10px;margin-top:18px}
.social a{width:31px;height:31px;border-radius:4px;background:#fff;color:#5d27df;display:grid;place-items:center;font-weight:900}
.payments{display:flex;justify-content:center;gap:10px;margin-top:26px;flex-wrap:wrap}
.payments span{background:#fff;color:#5d27df;border-radius:4px;padding:8px 12px;font-weight:900;font-size:14px}

.entry-content{max-width:1100px;margin:55px auto;padding:0 24px;line-height:1.7}

@media(max-width:900px){
  .cards,.footer-box{grid-template-columns:1fr}
  .footer-box{min-height:auto}
  .section h2{font-size:30px}
  .footer{padding:30px 18px}
  .section{padding:55px 18px}
}


/* FINAL EXTRA FEATURES */
.whatsapp-float{
  position:fixed;
  right:22px;
  bottom:22px;
  width:62px;
  height:62px;
  border-radius:50%;
  background:#25D366;
  color:#fff;
  display:grid;
  place-items:center;
  font-size:30px;
  font-weight:900;
  box-shadow:0 12px 30px rgba(0,0,0,.25);
  z-index:9999;
}

.contact-box{
  max-width:900px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}

.contact-card{
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:14px;
  box-shadow:0 14px 32px rgba(45,12,128,.10);
  padding:30px;
}

.contact-card p{
  text-align:left;
  margin:0 0 12px;
}

.contact-form input,
.contact-form textarea{
  width:100%;
  padding:15px;
  border:1px solid #ddd;
  border-radius:6px;
  margin-bottom:13px;
  font:inherit;
}

.contact-form textarea{
  min-height:130px;
}

.contact-form button{
  background:linear-gradient(135deg,var(--uph-main,#5d27df),var(--uph-dark,#26006c));
  color:#fff;
  border:0;
  padding:15px 24px;
  font-weight:900;
  text-transform:uppercase;
  border-radius:4px;
  cursor:pointer;
}

@media(max-width:900px){
  .contact-box{
    grid-template-columns:1fr;
  }
  .full-home img{
    width:100%;
    max-width:100%;
  }
}


/* LINKS UND WEITERE SEITEN */
.service-links{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:28px;
}

.service-link{
  display:block;
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:12px;
  padding:22px;
  box-shadow:0 12px 28px rgba(45,12,128,.10);
  font-weight:900;
  color:#4212aa;
}

.service-link span{
  display:block;
  color:#555;
  font-weight:400;
  margin-top:8px;
  line-height:1.6;
}

.shop-buttons{
  display:flex;
  gap:14px;
  justify-content:center;
  flex-wrap:wrap;
}

.shop-buttons a{
  background:linear-gradient(135deg,var(--uph-main,#5d27df),var(--uph-dark,#26006c));
  color:#fff;
  padding:15px 22px;
  border-radius:4px;
  font-weight:900;
  text-transform:uppercase;
}

.page-hero{
  max-width:1536px;
  margin:0 auto;
  padding:80px 5.5%;
  background:linear-gradient(135deg,#5d27df,#26006c);
  color:#fff;
  text-align:center;
}

.page-hero h1{
  margin:0 0 15px;
  font-size:44px;
  text-transform:uppercase;
}

.page-hero p{
  max-width:760px;
  margin:0 auto;
  color:#eee9ff;
  font-size:18px;
  line-height:1.7;
}

.price-table{
  width:100%;
  border-collapse:collapse;
  background:#fff;
  box-shadow:0 14px 32px rgba(45,12,128,.10);
  border-radius:12px;
  overflow:hidden;
}

.price-table th,
.price-table td{
  padding:16px;
  border-bottom:1px solid #eee8ff;
  text-align:left;
}

.price-table th{
  background:linear-gradient(135deg,var(--uph-main,#5d27df),var(--uph-dark,#26006c));
  color:#fff;
}

@media(max-width:900px){
  .service-links{
    grid-template-columns:1fr;
  }
}


/* SHOP SEITE ANGEPASST AN THEME */
.shop-hero{
  max-width:1536px;
  margin:0 auto;
  padding:76px 5.5%;
  background:linear-gradient(135deg,#5d27df 0%,#4212aa 55%,#26006c 100%);
  color:#fff;
  text-align:center;
  position:relative;
  overflow:hidden;
}

.shop-hero:before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(112deg,rgba(255,255,255,.14) 0 28%,rgba(255,255,255,.04) 28.4% 29%,transparent 29.4%),
    radial-gradient(circle at 92% 8%,rgba(255,255,255,.16),transparent 30%);
}

.shop-hero > *{
  position:relative;
  z-index:1;
}

.shop-hero h1{
  margin:0 0 14px;
  font-size:46px;
  line-height:1.1;
  text-transform:uppercase;
}

.shop-hero p{
  max-width:760px;
  margin:0 auto;
  color:#eee9ff;
  font-size:18px;
  line-height:1.7;
}

.shop-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:36px;
}

.shop-card{
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:16px;
  padding:30px;
  box-shadow:0 14px 34px rgba(45,12,128,.12);
  transition:.25s ease;
}

.shop-card:hover{
  transform:translateY(-5px);
  box-shadow:0 20px 45px rgba(45,12,128,.18);
}

.shop-icon{
  width:64px;
  height:64px;
  border-radius:16px;
  background:linear-gradient(135deg,#5d27df,#4212aa);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:32px;
  margin-bottom:20px;
  box-shadow:0 12px 25px rgba(93,39,223,.22);
}

.shop-card h3{
  margin:0 0 12px;
  font-size:22px;
  color:#111;
}

.shop-card p{
  text-align:left;
  margin:0 0 18px;
  color:#555;
  font-size:16px;
  line-height:1.7;
}

.shop-price{
  display:inline-block;
  background:#f1ecff;
  color:#4212aa;
  padding:8px 12px;
  border-radius:999px;
  font-weight:900;
  font-size:14px;
  margin-bottom:18px;
}

.shop-card a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,var(--uph-main,#5d27df),var(--uph-dark,#26006c));
  color:#fff;
  padding:13px 18px;
  border-radius:4px;
  font-weight:900;
  text-transform:uppercase;
  font-size:13px;
}

.shop-note{
  margin-top:38px;
  padding:26px;
  border-radius:16px;
  background:#f7f4ff;
  border:1px solid #eee8ff;
  text-align:center;
}

.shop-note p{
  margin:0;
  color:#555;
  font-size:17px;
}

@media(max-width:900px){
  .shop-grid{
    grid-template-columns:1fr;
  }
  .shop-hero h1{
    font-size:34px;
  }
}


/* WOOCOMMERCE SHOP INTEGRATION */
.woocommerce-wrap{
  max-width:1536px;
  margin:0 auto;
  padding:70px 5.5%;
  background:#fff;
}

.woocommerce ul.products{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}

.woocommerce ul.products li.product{
  width:auto !important;
  margin:0 !important;
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:16px;
  padding:24px !important;
  box-shadow:0 14px 34px rgba(45,12,128,.12);
  text-align:left;
}

.woocommerce ul.products li.product img{
  border-radius:12px;
  margin-bottom:18px;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title{
  color:#111;
  font-size:20px;
  font-weight:900;
}

.woocommerce ul.products li.product .price{
  color:#4212aa;
  font-weight:900;
  font-size:17px;
}

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit{
  background:#5d27df !important;
  color:#fff !important;
  border-radius:4px !important;
  padding:13px 18px !important;
  font-weight:900 !important;
  text-transform:uppercase;
}

.woocommerce div.product{
  max-width:1536px;
  margin:0 auto;
  padding:70px 5.5%;
}

.woocommerce div.product .product_title{
  color:#111;
  font-size:42px;
  font-weight:900;
}

.woocommerce div.product p.price,
.woocommerce div.product span.price{
  color:#4212aa;
  font-weight:900;
}

.woocommerce-cart .entry-content,
.woocommerce-checkout .entry-content,
.woocommerce-account .entry-content{
  max-width:1536px;
  margin:0 auto;
  padding:70px 5.5%;
}

.header-real-links{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:8;
}

.header-real-links a{
  position:absolute;
  display:block;
  pointer-events:auto;
}

@media(max-width:900px){
  .woocommerce ul.products{
    grid-template-columns:1fr;
  }
}


/* SHOP/KONTAKT HEADER GENAU WIE HOME LAYOUT */
.inner-exakt-header{
  position:relative;
  width:100%;
  max-width:1536px;
  margin:0 auto;
  background:#f7f4ff;
  overflow:hidden;
}

.inner-exakt-header img{
  width:100%;
  max-width:1536px;
  height:auto;
  display:block;
  margin:0 auto;
}

.inner-hot{
  position:absolute;
  display:block;
  z-index:10;
}

/* Klickbereiche im Header-Menü wie Home */
.inner-home{left:5.6%;top:67%;width:5.2%;height:24%}
.inner-services{left:13.2%;top:76%;width:14.5%;height:13%}
.inner-about{left:30.2%;top:76%;width:7.4%;height:13%}
.inner-news{left:39.5%;top:76%;width:7.5%;height:13%}
.inner-shop{left:49.2%;top:76%;width:5%;height:13%}
.inner-contact{left:55.8%;top:76%;width:6.2%;height:13%}
.inner-phone{left:32.8%;top:24%;width:13.2%;height:22%}
.inner-mail{left:63.8%;top:24%;width:16.2%;height:22%}
.inner-facebook{left:79.6%;top:75%;width:2.8%;height:13%}
.inner-youtube{left:86.8%;top:75%;width:2.8%;height:13%}

/* Unterseiten Hero direkt unter exakt Header, gleiche Breite */
.shop-hero,
.page-hero{
  max-width:1536px !important;
  margin:0 auto !important;
}


/* KONTAKT SEITE MIT KARTE UND NAVIGATION */
.contact-intro-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-bottom:34px;
}

.contact-info-tile{
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:16px;
  padding:26px;
  box-shadow:0 14px 34px rgba(45,12,128,.12);
}

.contact-info-icon{
  width:58px;
  height:58px;
  border-radius:15px;
  background:linear-gradient(135deg,#5d27df,#4212aa);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:28px;
  margin-bottom:18px;
}

.contact-info-tile h3{
  margin:0 0 10px;
  color:#111;
  font-size:21px;
}

.contact-info-tile p{
  text-align:left;
  margin:0;
  color:#555;
  line-height:1.7;
  font-size:16px;
}

.map-section{
  max-width:1536px;
  margin:0 auto;
  padding:70px 5.5%;
  background:#f7f4ff;
}

.map-wrap{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:28px;
  align-items:stretch;
}

.map-card,
.route-card{
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 16px 38px rgba(45,12,128,.13);
}

.map-card{
  position:relative;
  min-height:430px;
}

.map-card iframe{
  width:100%;
  height:100%;
  min-height:430px;
  border:0;
  display:block;
}

.map-logo-marker{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-110%);
  background:linear-gradient(135deg,var(--uph-main,#5d27df),var(--uph-dark,#26006c));
  color:#fff;
  padding:12px 16px;
  border-radius:14px;
  font-weight:900;
  box-shadow:0 12px 28px rgba(0,0,0,.25);
  pointer-events:none;
  text-align:center;
  line-height:1.1;
}

.map-logo-marker span{
  display:block;
  font-size:12px;
  font-weight:500;
  color:#e9ddff;
}

.route-card{
  padding:34px;
}

.route-card h2{
  text-align:left;
  margin:0 0 15px;
  color:#111;
  font-size:32px;
  text-transform:uppercase;
}

.route-card p{
  text-align:left;
  margin:0 0 18px;
  color:#555;
  line-height:1.7;
}

.route-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:22px;
}

.route-actions a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 20px;
  border-radius:5px;
  font-weight:900;
  text-transform:uppercase;
  font-size:13px;
}

.route-primary{
  background:linear-gradient(135deg,var(--uph-main,#5d27df),var(--uph-dark,#26006c));
  color:#fff;
}

.route-secondary{
  background:#f1ecff;
  color:#4212aa;
}

.route-list{
  display:grid;
  gap:12px;
  margin-top:20px;
}

.route-list div{
  background:#f7f4ff;
  border-radius:10px;
  padding:13px 15px;
  color:#333;
  font-size:16px;
}

@media(max-width:900px){
  .contact-intro-grid,
  .map-wrap{
    grid-template-columns:1fr;
  }
}


/* HEADER LINKS FINAL */
.inner-exakt-header,
.full-home{
  position:relative;
}

.hotspot,
.inner-hot{
  cursor:pointer;
}

.hotspot:hover,
.inner-hot:hover{
  outline:2px solid rgba(93,39,223,.0);
}

/* Kontakt Inhalte final */
.kontakt-service-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-top:34px;
}

.kontakt-service-card{
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:16px;
  padding:28px;
  box-shadow:0 14px 34px rgba(45,12,128,.12);
}

.kontakt-service-card .icon{
  width:58px;
  height:58px;
  border-radius:15px;
  background:linear-gradient(135deg,#5d27df,#4212aa);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:28px;
  margin-bottom:18px;
}

.kontakt-service-card h3{
  margin:0 0 10px;
  color:#111;
  font-size:21px;
}

.kontakt-service-card p{
  text-align:left;
  margin:0;
  color:#555;
  line-height:1.7;
}

.kontakt-cta{
  max-width:1536px;
  margin:0 auto;
  padding:55px 5.5%;
  background:linear-gradient(135deg,#5d27df,#26006c);
  color:#fff;
  text-align:center;
}

.kontakt-cta h2{
  color:#fff;
  margin:0 0 12px;
  text-transform:uppercase;
  font-size:36px;
}

.kontakt-cta p{
  color:#eee9ff;
  max-width:750px;
  margin:0 auto 24px;
  font-size:17px;
  line-height:1.7;
}

.kontakt-cta a{
  display:inline-flex;
  background:#fff;
  color:#5d27df;
  padding:15px 22px;
  border-radius:5px;
  font-weight:900;
  text-transform:uppercase;
  margin:6px;
}

@media(max-width:900px){
  .kontakt-service-grid{
    grid-template-columns:1fr;
  }
}


/* DROPDOWN MENÜS IM HEADER */
.home-dropdown,
.inner-dropdown{
  position:absolute;
  z-index:30;
}

.home-dropdown .drop-trigger,
.inner-dropdown .drop-trigger{
  display:block;
  width:100%;
  height:100%;
  cursor:pointer;
}

.dropdown-panel{
  position:absolute;
  top:100%;
  left:0;
  min-width:260px;
  background:#fff;
  border-radius:0 0 10px 10px;
  box-shadow:0 18px 40px rgba(30,10,90,.22);
  padding:12px 0;
  opacity:0;
  visibility:hidden;
  transform:translateY(10px);
  transition:.18s ease;
  border-top:4px solid #5d27df;
}

.home-dropdown:hover .dropdown-panel,
.inner-dropdown:hover .dropdown-panel{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}

.dropdown-panel a{
  display:block;
  padding:13px 18px;
  font-size:14px;
  font-weight:800;
  color:#111;
  background:#fff;
  white-space:nowrap;
}

.dropdown-panel a:hover{
  background:#f3edff;
  color:#5d27df;
}

/* Positionen Home-Screenshot */
.home-services-dropdown{left:13.2%;top:23.7%;width:14.5%;height:4.5%}
.home-shop-dropdown{left:49.2%;top:23.7%;width:5.2%;height:4.5%}

/* Positionen Unterseiten-Header */
.inner-services-dropdown{left:13.2%;top:76%;width:14.5%;height:13%}
.inner-shop-dropdown{left:49.2%;top:76%;width:5.2%;height:13%}

/* Kontaktseite Inhalt im Flattech-Stil */
.flat-contact-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:30px;
  align-items:stretch;
  margin-top:34px;
}

.flat-contact-card{
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:18px;
  box-shadow:0 16px 38px rgba(45,12,128,.13);
  padding:34px;
}

.flat-contact-card h2{
  text-align:left;
  color:#111;
  margin:0 0 16px;
  font-size:32px;
  text-transform:uppercase;
}

.flat-contact-card p{
  text-align:left;
  color:#555;
  font-size:16px;
  line-height:1.75;
  margin:0 0 16px;
}

.flat-contact-list{
  display:grid;
  gap:14px;
  margin-top:22px;
}

.flat-contact-list a,
.flat-contact-list div{
  display:flex;
  gap:14px;
  align-items:flex-start;
  background:#f7f4ff;
  color:#333;
  border-radius:12px;
  padding:15px 16px;
  font-size:16px;
  line-height:1.5;
}

.flat-contact-list strong{
  color:#4212aa;
}

.flat-contact-icon{
  width:38px;
  height:38px;
  min-width:38px;
  border-radius:10px;
  background:linear-gradient(135deg,#5d27df,#4212aa);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:20px;
}

.flat-hours{
  display:grid;
  gap:10px;
  margin-top:16px;
}

.flat-hours div{
  display:flex;
  justify-content:space-between;
  gap:20px;
  border-bottom:1px solid #eee8ff;
  padding:10px 0;
  color:#555;
}

.flat-hours strong{
  color:#111;
}

.flat-form input,
.flat-form textarea,
.flat-form select{
  width:100%;
  padding:15px;
  border:1px solid #ddd;
  border-radius:8px;
  margin-bottom:14px;
  font:inherit;
}

.flat-form textarea{
  min-height:140px;
}

.flat-form button{
  background:linear-gradient(135deg,var(--uph-main,#5d27df),var(--uph-dark,#26006c));
  color:#fff;
  border:0;
  border-radius:5px;
  padding:15px 24px;
  font-weight:900;
  text-transform:uppercase;
  cursor:pointer;
}

.flat-faq{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
  margin-top:34px;
}

.flat-faq-item{
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:16px;
  padding:26px;
  box-shadow:0 14px 34px rgba(45,12,128,.10);
}

.flat-faq-item h3{
  margin:0 0 10px;
  color:#4212aa;
  font-size:20px;
}

.flat-faq-item p{
  text-align:left;
  margin:0;
  color:#555;
  line-height:1.7;
}

@media(max-width:900px){
  .home-dropdown,
  .inner-dropdown{
    display:none;
  }

  .flat-contact-grid,
  .flat-faq{
    grid-template-columns:1fr;
  }
}


/* KOMPLETTE SITE-SEITEN */
.content-hero{
  max-width:1536px;
  margin:0 auto;
  padding:76px 5.5%;
  background:linear-gradient(135deg,#5d27df 0%,#4212aa 55%,#26006c 100%);
  color:#fff;
  text-align:center;
}
.content-hero h1{
  margin:0 0 14px;
  font-size:46px;
  text-transform:uppercase;
}
.content-hero p{
  max-width:760px;
  margin:0 auto;
  color:#eee9ff;
  font-size:18px;
  line-height:1.7;
}
.content-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.content-card{
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:16px;
  padding:30px;
  box-shadow:0 14px 34px rgba(45,12,128,.12);
}
.content-icon{
  width:64px;
  height:64px;
  border-radius:16px;
  background:linear-gradient(135deg,#5d27df,#4212aa);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:32px;
  margin-bottom:20px;
}
.content-card h3{
  margin:0 0 12px;
  font-size:22px;
  color:#111;
}
.content-card p,
.content-card li{
  color:#555;
  line-height:1.7;
  font-size:16px;
}
.content-card ul{
  margin:0;
  padding-left:18px;
}
.content-cta{
  margin-top:36px;
  text-align:center;
}
.content-cta a{
  display:inline-flex;
  background:linear-gradient(135deg,var(--uph-main,#5d27df),var(--uph-dark,#26006c));
  color:#fff;
  padding:15px 22px;
  border-radius:5px;
  font-weight:900;
  text-transform:uppercase;
  margin:6px;
}
.timeline{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  margin-top:34px;
}
.timeline-step{
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:16px;
  padding:26px;
  box-shadow:0 14px 34px rgba(45,12,128,.10);
}
.timeline-step strong{
  display:inline-grid;
  place-items:center;
  width:42px;
  height:42px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--uph-main,#5d27df),var(--uph-dark,#26006c));
  color:#fff;
  margin-bottom:14px;
}
.faq-list{
  display:grid;
  gap:16px;
  max-width:980px;
  margin:0 auto;
}
.faq-item{
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:14px;
  padding:24px;
  box-shadow:0 12px 30px rgba(45,12,128,.10);
}
.faq-item h3{
  margin:0 0 10px;
  color:#4212aa;
}
.faq-item p{
  margin:0;
  text-align:left;
}
@media(max-width:900px){
  .content-grid,
  .timeline{
    grid-template-columns:1fr;
  }
  .content-hero h1{
    font-size:34px;
  }
}


/* UPH VERSION 2.0 HOME HERO SLIDER */
.uph-v2-hero-slider{
  max-width:1536px;
  height:612px;
  margin:0 auto;
  position:relative;
  overflow:hidden;
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
}

/* This soft panel hides old text baked into the uploaded image, keeping image look */
.uph-v2-text-mask{
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:46%;
  background:
    linear-gradient(90deg,rgba(255,255,255,.98) 0%,rgba(255,255,255,.96) 68%,rgba(255,255,255,.35) 100%);
  z-index:1;
  pointer-events:none;
}

.uph-v2-text-mask:before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:280px;
  height:190px;
  background:rgba(93,39,223,.13);
  clip-path:polygon(0 0,100% 0,0 100%);
}

.uph-v2-hero-content{
  position:relative;
  z-index:2;
  width:min(1340px,calc(100% - 58px));
  height:100%;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:flex-start;
  padding-bottom:10px;
}

.uph-v2-kicker{
  color:#5d27df;
  font-size:18px;
  line-height:1.2;
  font-weight:900;
  text-transform:uppercase;
  margin-bottom:36px;
  letter-spacing:.2px;
}

.uph-v2-hero-content h1{
  margin:0 0 31px;
  font-size:72px;
  line-height:1.02;
  letter-spacing:-2px;
  text-transform:uppercase;
  font-weight:900;
}

.uph-v2-hero-content h1 span{
  display:block;
}

.uph-v2-title1{
  color:#050508;
}

.uph-v2-title2{
  color:#5d27df;
}

.uph-v2-desc{
  max-width:545px;
  margin:0 0 40px;
  color:#111;
  font-size:20px;
  line-height:1.75;
}

.uph-v2-buttons{
  display:flex;
  gap:20px;
  flex-wrap:wrap;
}

.uph-v2-btn{
  height:64px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0 31px;
  border-radius:4px;
  border:2px solid #5d27df;
  font-size:16px;
  font-weight:900;
  text-transform:uppercase;
  transition:.2s ease;
}

.uph-v2-btn.primary{
  background:linear-gradient(135deg,var(--uph-main,#5d27df),var(--uph-dark,#26006c));
  color:#fff;
}

.uph-v2-btn.secondary{
  background:#fff;
  color:#5d27df;
}

.uph-v2-btn:hover{
  transform:translateY(-2px);
}

.uph-v2-dots{
  position:absolute;
  left:50%;
  bottom:15px;
  transform:translateX(-50%);
  display:flex;
  gap:18px;
  z-index:3;
}

.uph-v2-dots button{
  width:22px;
  height:22px;
  border-radius:50%;
  border:0;
  background:#c9c9cf;
  cursor:pointer;
  padding:0;
}

.uph-v2-dots button.active{
  background:#5d27df;
}

@media(max-width:900px){
  .uph-v2-hero-slider{
    height:auto;
    min-height:660px;
    background-size:cover;
    background-position:center center;
  }
  .uph-v2-text-mask{
    width:100%;
    background:linear-gradient(180deg,rgba(255,255,255,.98) 0%,rgba(255,255,255,.93) 58%,rgba(255,255,255,.30) 100%);
  }
  .uph-v2-hero-content{
    width:calc(100% - 28px);
    padding:56px 0 260px;
    justify-content:flex-start;
  }
  .uph-v2-kicker{
    font-size:14px;
    margin-bottom:22px;
  }
  .uph-v2-hero-content h1{
    font-size:42px;
  }
  .uph-v2-desc{
    font-size:16px;
  }
  .uph-v2-btn{
    height:52px;
    font-size:13px;
  }
}

/* UPH VERSION 2.1 PRO */
#uph21-preloader{position:fixed;inset:0;background:#f7f4ff;z-index:999999;display:grid;place-items:center;transition:.35s ease}
#uph21-preloader div{width:82px;height:82px;border-radius:22px;background:linear-gradient(135deg,#5d27df,#26006c);color:#fff;display:grid;place-items:center;font-weight:900;font-size:24px;box-shadow:0 20px 60px rgba(45,12,128,.28)}
#uph21-preloader.hide{opacity:0;visibility:hidden}
.uph21-whatsapp{position:fixed;right:24px;bottom:24px;width:64px;height:64px;border-radius:50%;background:#25D366;color:#fff;display:grid;place-items:center;font-size:31px;font-weight:900;z-index:9999;box-shadow:0 16px 35px rgba(0,0,0,.25)}
.uph21-top{position:fixed;right:24px;bottom:100px;width:48px;height:48px;border-radius:50%;border:0;background:#5d27df;color:#fff;font-size:24px;font-weight:900;z-index:9998;cursor:pointer;opacity:0;visibility:hidden;transition:.2s}
.uph21-top.show{opacity:1;visibility:visible}
.uph21-cookie{position:fixed;left:24px;bottom:24px;background:#fff;border:1px solid #eee8ff;border-radius:14px;box-shadow:0 16px 40px rgba(0,0,0,.18);padding:18px;display:flex;gap:16px;align-items:center;z-index:9999;max-width:520px}
.uph21-cookie button{background:#5d27df;color:#fff;border:0;border-radius:5px;padding:10px 16px;font-weight:900}
.uph21-mobilebar{display:none}
.uph21-price{width:100%;border-collapse:collapse;background:#fff;border-radius:14px;overflow:hidden;box-shadow:0 14px 34px rgba(45,12,128,.12)}
.uph21-price th{background:#5d27df;color:#fff;text-align:left;padding:16px}.uph21-price td{padding:16px;border-bottom:1px solid #eee8ff;color:#333}.uph21-price a{color:#5d27df;font-weight:900}
.uph21-brands{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}.uph21-brands div{background:#fff;border:1px solid #eee8ff;border-radius:12px;padding:22px;text-align:center;font-weight:900;color:#4212aa;box-shadow:0 10px 25px rgba(45,12,128,.08)}
@media(max-width:900px){.uph21-brands{grid-template-columns:repeat(2,1fr)}.uph21-cookie{left:14px;right:14px;bottom:84px;max-width:none}.uph21-mobilebar{position:fixed;left:0;right:0;bottom:0;height:58px;background:#fff;border-top:1px solid #eee8ff;display:grid;grid-template-columns:repeat(3,1fr);z-index:9998;box-shadow:0 -8px 25px rgba(0,0,0,.12)}.uph21-mobilebar a{display:grid;place-items:center;color:#5d27df;font-weight:900;font-size:13px}.uph21-whatsapp{bottom:76px;width:54px;height:54px}}

/* UPH 2.12 FIXED ORIGINAL HEADER */
:root{--purple:#5d27df;--purple-dark:#2d087a;--purple-mid:#4515b3;--light:#f7f4ff;--text:#07070b}
.container{width:min(1340px,calc(100% - 58px));margin:0 auto}
.up-top{height:122px;background:linear-gradient(135deg,#6d35f0 0%,#4a16bc 45%,#290071 100%);color:#fff;position:relative;overflow:hidden}
.up-top:before{content:"";position:absolute;inset:0;background:linear-gradient(112deg,rgba(255,255,255,.16) 0 30%,rgba(255,255,255,.04) 30.2% 30.7%,transparent 31%),radial-gradient(circle at 96% -18%,rgba(255,255,255,.14),transparent 29%);pointer-events:none}
.up-top-inner{position:relative;height:122px;display:grid;grid-template-columns:1.28fr 2.2fr;align-items:center}
.up-brand{display:flex;align-items:center;gap:15px;color:#fff;text-decoration:none}
.up-brand svg{width:72px;height:72px;flex:0 0 auto}
.up-brand-title{font-size:30px;font-weight:900;letter-spacing:-1px;line-height:1}
.up-brand-title span{font-weight:400;color:#d5c9ff}
.up-brand-sub{font-size:13px;margin-top:7px;color:#fff}
.up-info{height:88px;display:grid;grid-template-columns:repeat(3,1fr);box-shadow:0 13px 26px rgba(0,0,0,.23)}
.up-info-box{padding:20px 22px;display:flex;gap:13px;align-items:center;background:linear-gradient(180deg,rgba(111,57,236,.55),rgba(44,10,125,.66));border-left:1px solid rgba(255,255,255,.14);border-right:1px solid rgba(0,0,0,.16);color:#fff;text-decoration:none}
.up-info-icon{font-size:20px;opacity:.7}.up-info-label{font-size:12px;margin-bottom:8px;opacity:.92}.up-info-main{font-size:16px;font-weight:900;white-space:nowrap}
.up-menu-wrap{position:relative;z-index:100;margin-top:-21px}
.up-nav{height:92px;background:#fff;border-radius:3px;box-shadow:0 16px 38px rgba(40,10,120,.17);display:flex;align-items:center;justify-content:space-between;padding:0 28px}
.up-nav-left{display:flex;align-items:center;gap:34px}.up-home{width:64px;height:64px;border-radius:3px;display:grid;place-items:center;background:#eee8ff;color:var(--purple);font-size:32px;font-weight:900;text-decoration:none}
.up-menu{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:38px;text-transform:uppercase;font-size:13px;font-weight:900}
.up-menu li{position:relative}.up-menu a{color:#111;display:block;text-decoration:none}.up-menu a:hover{color:var(--purple)}
.up-menu .has-sub>a:after{content:"⌄";font-size:12px;margin-left:7px}.up-sub{position:absolute;top:100%;left:0;min-width:235px;background:#fff;box-shadow:0 18px 35px rgba(0,0,0,.15);padding:12px 0;display:none;z-index:999}.up-sub a{padding:12px 18px;white-space:nowrap}.up-menu li:hover .up-sub{display:block}
.up-social{display:flex;gap:10px}.up-social a{width:32px;height:32px;border-radius:3px;background:var(--purple);color:#fff;display:grid;place-items:center;font-size:13px;font-weight:900;text-decoration:none}
@media(max-width:1000px){.up-top{height:auto}.up-top-inner{height:auto;grid-template-columns:1fr;gap:20px;padding:24px 0 64px}.up-info{height:auto;grid-template-columns:1fr}.up-menu-wrap{margin-top:-48px}.up-nav{height:auto;align-items:flex-start;flex-direction:column;gap:18px;padding:18px}.up-nav-left{flex-direction:column;align-items:flex-start;gap:18px}.up-menu{flex-wrap:wrap;gap:19px}}
@media(max-width:560px){.container{width:calc(100% - 28px)}.up-brand-title{font-size:25px}.up-info-main{font-size:14px}.up-menu{display:grid;grid-template-columns:1fr 1fr;width:100%;font-size:12px}}

/* UPH 2.12: slider below original header */
.uph-v2-hero-slider{margin-top:0!important}
.up-menu-wrap + main .uph-v2-hero-slider{margin-top:18px!important}


/* UPH VERSION 2.13 TOP MENU FIX */
/* This forces the top menu to appear the same on home, prices, shop, contact and all subpages. */
.uph-fixed-top-menu,
.uph-fixed-main-menu{
  width:100%;
  max-width:1536px;
  margin-left:auto;
  margin-right:auto;
}

.uph-fixed-main-menu{
  margin-bottom:18px;
}

.inner-exakt-header,
.full-home.site-width > img[alt*="Header"],
.full-home .inner-hot,
.full-home .hotspot.hot-services-menu,
.full-home .hotspot.hot-shop,
.full-home .hotspot.hot-contact-menu{
  display:none!important;
}

/* Prevent old image-header links/dropdown overlays from showing on pages */
.inner-dropdown,
.home-dropdown{
  display:none!important;
}

.uph-cart-link{
  font-size:14px!important;
}

.up-menu .current-menu-item > a,
.up-menu a[aria-current="page"]{
  color:#5d27df;
}

@media(max-width:1000px){
  .uph-fixed-main-menu{
    margin-bottom:0;
  }
}


/* UPH VERSION 2.14 EXACT TOP MENU - same visual header on every page */
.uph-v214-exact-header{
  position:relative;
  width:100%;
  max-width:1536px;
  margin:0 auto;
  background:#f7f4ff;
  z-index:5000;
  line-height:0;
}
.uph-v214-exact-header img{
  width:100%;
  height:auto;
  display:block;
  margin:0 auto;
}
.uph214-hot,
.uph214-dd{
  position:absolute;
  z-index:20;
  display:block;
}
.uph214-dd-trigger{
  display:block;
  width:100%;
  height:100%;
}
.uph214-dd-panel{
  position:absolute;
  top:100%;
  left:0;
  min-width:250px;
  background:#fff;
  border-top:4px solid #5d27df;
  box-shadow:0 18px 40px rgba(30,10,90,.22);
  border-radius:0 0 10px 10px;
  padding:12px 0;
  opacity:0;
  visibility:hidden;
  transform:translateY(10px);
  transition:.18s ease;
  line-height:1.35;
}
.uph214-dd:hover .uph214-dd-panel{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}
.uph214-dd-panel a{
  display:block;
  padding:13px 18px;
  color:#111;
  background:#fff;
  font-size:14px;
  font-weight:800;
  white-space:nowrap;
  text-decoration:none;
}
.uph214-dd-panel a:hover{
  background:#f3edff;
  color:#5d27df;
}

/* hotspot positions based on original 1536px header layout */

/* topbar rechts oben: klickbare Links, Design bleibt im Header-Bild */
.uph214-top-about{left:78.4%;top:3.5%;width:5.0%;height:7.5%}
.uph214-top-news{left:84.2%;top:3.5%;width:5.0%;height:7.5%}
.uph214-top-contact{left:90.2%;top:3.5%;width:5.0%;height:7.5%}
.uph214-phone{left:31.8%;top:25%;width:15%;height:24%}
.uph214-mail{left:62.5%;top:25%;width:18%;height:24%}
.uph214-home{left:5.4%;top:67%;width:5.7%;height:24%}
.uph214-services{left:13.0%;top:75%;width:15.4%;height:14%}
.uph214-about{left:30.2%;top:75%;width:7.6%;height:14%}
.uph214-news{left:39.3%;top:75%;width:7.8%;height:14%}
.uph214-shop{left:48.8%;top:75%;width:5.8%;height:14%}
.uph214-contact{left:55.4%;top:75%;width:7.1%;height:14%}
.uph214-facebook{left:78.7%;top:75%;width:2.7%;height:14%}
.uph214-youtube{left:85.5%;top:75%;width:2.9%;height:14%}
.uph214-emailicon{left:89.0%;top:75%;width:2.9%;height:14%}

/* Hide all older header systems so the exact header is the only one */
.up-top,
.up-menu-wrap,
.inner-exakt-header,
.full-home .hotspot,
.home-dropdown,
.inner-dropdown{
  display:none!important;
}

/* Content starts right under same header on every page */
.uph-v214-exact-header + main,
.uph-v214-exact-header + .shop-hero,
.uph-v214-exact-header + .content-hero,
.uph-v214-exact-header + .page-hero{
  margin-top:0!important;
}

/* Sticky option without changing form */
body.uph-sticky-header .uph-v214-exact-header,
.uph-v214-exact-header.sticky{
  position:sticky;
  top:0;
}

@media(max-width:900px){
  .uph-v214-exact-header{
    overflow:hidden;
  }
  .uph-v214-exact-header img{
    width:180%;
    max-width:none;
    transform:translateX(-7%);
  }
  .uph214-hot,
  .uph214-dd{
    display:none;
  }
}


/* UPH VERSION 2.15 ELEMENTOR BUILDER */
.uph-elementor-main{
  max-width:1536px;
  margin:0 auto;
  background:#fff;
}
.uph-elementor-fullwidth .entry-content,
.uph-elementor-fullwidth .uph-elementor-main{
  width:100%;
  max-width:1536px;
  padding:0;
}
.uph215-section{
  max-width:1536px;
  margin:0 auto;
  padding:78px 5.5%;
  background:#fff;
}
.uph215-section.alt{
  background:#f7f4ff;
}
.uph215-container{
  max-width:1340px;
  margin:0 auto;
}
.uph215-section h2{
  text-align:center;
  margin:0 0 14px;
  font-size:40px;
  text-transform:uppercase;
  color:#111;
}
.uph215-lead{
  text-align:center;
  max-width:760px;
  margin:0 auto 38px;
  color:#555;
  line-height:1.7;
  font-size:17px;
}
.uph215-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.uph215-card{
  display:block;
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:16px;
  padding:30px;
  box-shadow:0 14px 34px rgba(45,12,128,.12);
  color:#111;
  text-decoration:none;
  transition:.2s ease;
}
.uph215-card:hover{
  transform:translateY(-5px);
  box-shadow:0 20px 45px rgba(45,12,128,.18);
}
.uph215-icon{
  width:64px;
  height:64px;
  border-radius:16px;
  background:linear-gradient(135deg,#5d27df,#4212aa);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:32px;
  margin-bottom:18px;
}
.uph215-card h3{
  margin:0 0 12px;
  font-size:22px;
}
.uph215-card p{
  margin:0;
  color:#555;
  line-height:1.7;
}
.uph215-contact-box{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.uph215-contact-box > div{
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:16px;
  padding:30px;
  box-shadow:0 14px 34px rgba(45,12,128,.12);
}
.uph215-btn{
  display:inline-flex;
  background:#5d27df;
  color:#fff!important;
  padding:14px 20px;
  border-radius:5px;
  font-weight:900;
  text-transform:uppercase;
  text-decoration:none;
}
.uph215-map iframe{
  width:100%;
  min-height:430px;
  border:0;
  border-radius:18px;
  box-shadow:0 16px 38px rgba(45,12,128,.13);
}
.uph215-price{
  width:100%;
  border-collapse:collapse;
  background:#fff;
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 14px 34px rgba(45,12,128,.12);
}
.uph215-price th{
  background:linear-gradient(135deg,var(--uph-main,#5d27df),var(--uph-dark,#26006c));
  color:#fff;
  text-align:left;
  padding:16px;
}
.uph215-price td{
  padding:16px;
  border-bottom:1px solid #eee8ff;
  color:#333;
}
.uph215-price a{
  color:#5d27df;
  font-weight:900;
}
.uph215-brands{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:16px;
}
.uph215-brands div{
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:12px;
  padding:22px;
  text-align:center;
  font-weight:900;
  color:#4212aa;
  box-shadow:0 10px 25px rgba(45,12,128,.08);
}
@media(max-width:900px){
  .uph215-cards,
  .uph215-contact-box{
    grid-template-columns:1fr;
  }
  .uph215-brands{
    grid-template-columns:repeat(2,1fr);
  }
  .uph215-section h2{
    font-size:30px;
  }
}


/* UPH VERSION 2.16 DEMO IMPORT + MEGA MENU */
.uph216-mega-wrap{
  position:absolute;
  top:89%;
  z-index:80;
  opacity:0;
  visibility:hidden;
  transform:translateY(10px);
  transition:.18s ease;
  line-height:1.4;
}
.services-mega-wrap{left:13%;width:690px}
.shop-mega-wrap{left:48%;width:520px}

.uph214-services:hover ~ .services-mega-wrap,
.services-mega-wrap:hover{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}
.uph214-shop:hover ~ .shop-mega-wrap,
.shop-mega-wrap:hover{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}

.uph216-mega{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  background:#fff;
  border-top:4px solid #5d27df;
  border-radius:0 0 14px 14px;
  box-shadow:0 20px 45px rgba(30,10,90,.22);
  padding:26px;
}
.uph216-mega-shop{
  grid-template-columns:1fr 1fr;
}
.uph216-mega strong{
  display:block;
  color:#4212aa;
  font-size:16px;
  margin-bottom:12px;
  text-transform:uppercase;
}
.uph216-mega a{
  display:block;
  color:#222;
  text-decoration:none;
  padding:8px 0;
  font-size:15px;
  font-weight:700;
}
.uph216-mega a:hover{
  color:#5d27df;
}

@media(max-width:900px){
  .uph216-mega-wrap{
    display:none!important;
  }
}


/* UPH VERSION 2.17 WOOCOMMERCE PRO */
.uph217-shop-hero{
  max-width:1536px;
  margin:0 auto;
  padding:76px 5.5%;
  background:linear-gradient(135deg,#5d27df 0%,#4212aa 55%,#26006c 100%);
  color:#fff;
  text-align:center;
}
.uph217-shop-hero h1{margin:0 0 14px;font-size:46px;text-transform:uppercase;color:#fff}
.uph217-shop-hero p{max-width:760px;margin:0 auto;color:#eee9ff;font-size:18px;line-height:1.7}
.uph217-shop-wrap,
.uph217-single-product{
  max-width:1536px;
  margin:0 auto;
  padding:40px 5.5% 80px;
  background:#fff;
}
.uph217-cat-grid{
  max-width:1536px;
  margin:0 auto;
  padding:34px 5.5% 10px;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  background:#fff;
}
.uph217-cat-grid a{
  display:flex;
  align-items:center;
  gap:14px;
  background:#f7f4ff;
  border:1px solid #eee8ff;
  border-radius:14px;
  padding:20px;
  text-decoration:none;
  box-shadow:0 10px 25px rgba(45,12,128,.08);
}
.uph217-cat-grid span{width:48px;height:48px;border-radius:12px;background:#5d27df;color:#fff;display:grid;place-items:center;font-size:24px}
.uph217-cat-grid strong{color:#4212aa;font-size:17px}
.uph217-filters{
  max-width:1536px;
  margin:0 auto;
  padding:22px 5.5%;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  background:#fff;
}
.uph217-filters a{
  background:#fff;
  border:1px solid #eee8ff;
  color:#4212aa;
  border-radius:999px;
  padding:11px 16px;
  font-weight:900;
  text-decoration:none;
}
.woocommerce ul.products{
  display:grid!important;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.woocommerce ul.products li.product{
  width:auto!important;
  margin:0!important;
  position:relative;
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:18px;
  padding:22px!important;
  box-shadow:0 14px 34px rgba(45,12,128,.12);
  transition:.2s ease;
}
.woocommerce ul.products li.product:hover{transform:translateY(-5px);box-shadow:0 22px 50px rgba(45,12,128,.18)}
.woocommerce ul.products li.product img{border-radius:14px;margin-bottom:16px}
.woocommerce-loop-product__title{font-size:20px!important;color:#111;font-weight:900}
.woocommerce ul.products li.product .price{color:#4212aa!important;font-weight:900!important;font-size:18px!important}
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit{
  background:#5d27df!important;
  color:#fff!important;
  border-radius:5px!important;
  padding:13px 18px!important;
  font-weight:900!important;
  text-transform:uppercase;
}
.uph217-badge{
  position:absolute;
  left:18px;
  top:18px;
  background:linear-gradient(135deg,var(--uph-main,#5d27df),var(--uph-dark,#26006c));
  color:#fff;
  border-radius:999px;
  padding:7px 11px;
  font-size:12px;
  font-weight:900;
  z-index:2;
}
.uph217-quick,
.uph217-whatsapp-product,
.uph217-single-whatsapp{
  display:inline-flex;
  margin-top:10px;
  margin-right:8px;
  padding:12px 15px;
  border-radius:5px;
  font-weight:900;
  text-transform:uppercase;
  font-size:12px;
  text-decoration:none!important;
}
.uph217-quick{background:#f1ecff;color:#4212aa!important}
.uph217-whatsapp-product,
.uph217-single-whatsapp{background:#25D366;color:#fff!important}
.woocommerce div.product .product_title{font-size:42px;font-weight:900;color:#111}
.woocommerce div.product p.price,
.woocommerce div.product span.price{color:#4212aa;font-size:26px;font-weight:900}
@media(max-width:900px){
  .uph217-cat-grid{grid-template-columns:1fr 1fr;padding:24px 18px}
  .uph217-filters{padding:18px}
  .woocommerce ul.products{grid-template-columns:1fr!important}
  .uph217-shop-hero h1{font-size:34px}
}


/* UPH VERSION 2.18 MOBILE PRO */
.uph218-mobile-header,
.uph218-drawer,
.uph218-overlay,
.uph218-bottom-bar{
  display:none;
}

@media(max-width:900px){
  body{
    padding-bottom:74px;
  }

  .uph-v214-exact-header{
    display:none!important;
  }

  .uph218-mobile-header{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:14px;
    height:74px;
    padding:0 16px;
    background:linear-gradient(135deg,#5d27df,#26006c);
    color:#fff;
    position:sticky;
    top:0;
    z-index:99999;
    box-shadow:0 10px 28px rgba(0,0,0,.18);
  }

  .uph218-menu-btn{
    width:46px;
    height:46px;
    border:0;
    border-radius:10px;
    background:rgba(255,255,255,.14);
    display:grid;
    place-items:center;
    padding:10px;
  }

  .uph218-menu-btn span{
    display:block;
    width:24px;
    height:3px;
    background:#fff;
    margin:2px 0;
    border-radius:3px;
  }

  .uph218-mobile-logo{
    color:#fff;
    text-decoration:none;
    line-height:1.1;
    text-align:center;
  }

  .uph218-mobile-logo strong{
    display:block;
    font-size:22px;
    font-weight:900;
    letter-spacing:-.5px;
  }

  .uph218-mobile-logo small{
    display:block;
    color:#e8ddff;
    font-size:12px;
    margin-top:4px;
  }

  .uph218-mobile-call{
    width:46px;
    height:46px;
    border-radius:10px;
    background:#fff;
    color:#5d27df;
    display:grid;
    place-items:center;
    font-size:23px;
    font-weight:900;
    text-decoration:none;
  }

  .uph218-overlay{
    display:block;
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.55);
    z-index:99998;
    opacity:0;
    visibility:hidden;
    transition:.22s ease;
  }

  .uph218-drawer{
    display:block;
    position:fixed;
    top:0;
    left:0;
    bottom:0;
    width:min(88vw,360px);
    background:#fff;
    z-index:99999;
    transform:translateX(-105%);
    transition:.25s ease;
    box-shadow:18px 0 45px rgba(0,0,0,.22);
    overflow-y:auto;
  }

  body.uph218-open .uph218-overlay{
    opacity:1;
    visibility:visible;
  }

  body.uph218-open .uph218-drawer{
    transform:translateX(0);
  }

  .uph218-drawer-head{
    height:84px;
    background:linear-gradient(135deg,#5d27df,#26006c);
    color:#fff;
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:0 20px;
  }

  .uph218-drawer-head strong{
    font-size:24px;
    font-weight:900;
  }

  .uph218-close{
    width:42px;
    height:42px;
    border:0;
    border-radius:50%;
    background:rgba(255,255,255,.16);
    color:#fff;
    font-size:30px;
    line-height:1;
  }

  .uph218-drawer-nav{
    padding:16px;
    display:grid;
    gap:8px;
  }

  .uph218-drawer-nav a,
  .uph218-accordion{
    width:100%;
    display:flex;
    align-items:center;
    justify-content:space-between;
    text-align:left;
    padding:15px 14px;
    border:1px solid #eee8ff;
    border-radius:12px;
    background:#f7f4ff;
    color:#111;
    font-size:15px;
    font-weight:900;
    text-decoration:none;
  }

  .uph218-accordion span{
    color:#5d27df;
    font-size:20px;
  }

  .uph218-submenu{
    display:none;
    padding:4px 0 4px 14px;
    gap:6px;
  }

  .uph218-submenu.open{
    display:grid;
  }

  .uph218-submenu a{
    background:#fff;
    font-size:14px;
    font-weight:700;
    padding:12px 14px;
  }

  .uph218-drawer-contact{
    padding:16px;
    border-top:1px solid #eee8ff;
    display:grid;
    gap:10px;
  }

  .uph218-drawer-contact a{
    color:#4212aa;
    text-decoration:none;
    font-weight:900;
    background:#f7f4ff;
    padding:13px 14px;
    border-radius:10px;
  }

  .uph218-bottom-bar{
    position:fixed;
    left:0;
    right:0;
    bottom:0;
    height:68px;
    background:#fff;
    border-top:1px solid #eee8ff;
    box-shadow:0 -10px 28px rgba(0,0,0,.14);
    z-index:99997;
    display:grid;
    grid-template-columns:repeat(4,1fr);
  }

  .uph218-bottom-bar a{
    display:grid;
    place-items:center;
    color:#5d27df;
    text-decoration:none;
    font-size:20px;
    font-weight:900;
    padding:8px 4px 6px;
  }

  .uph218-bottom-bar span{
    display:block;
    font-size:11px;
    color:#111;
    margin-top:3px;
  }

  .uph-v2-hero-slider{
    height:auto!important;
    min-height:620px!important;
    background-position:center center!important;
  }

  .uph-v2-text-mask{
    width:100%!important;
    background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(255,255,255,.92),rgba(255,255,255,.28))!important;
  }

  .uph-v2-hero-content{
    width:calc(100% - 30px)!important;
    padding-top:48px!important;
  }

  .woocommerce ul.products{
    grid-template-columns:1fr!important;
  }

  .uph217-cat-grid,
  .uph215-cards,
  .uph215-contact-box{
    grid-template-columns:1fr!important;
  }

  .footer-box{
    grid-template-columns:1fr!important;
  }
}


/* UPH VERSION 2.19 MEGA MENU FIX */
/* Entfernt das zweite kleine Dropdown komplett */
.uph-hide-second-dropdown .uph214-dd-panel,
.uph-mega-only .uph214-dd-panel,
.uph214-disabled-panel,
.uph214-services .uph214-dd-panel,
.uph214-shop .uph214-dd-panel{
  display:none!important;
  opacity:0!important;
  visibility:hidden!important;
  pointer-events:none!important;
}

/* Nur das große Mega Menü bleibt sichtbar */
.uph216-mega-wrap{
  display:block!important;
}

/* Mega Menü sauber positionieren */
.uph-v214-exact-header .services-mega-wrap{
  left:13%!important;
  top:89%!important;
}
.uph-v214-exact-header .shop-mega-wrap{
  left:48%!important;
  top:89%!important;
}

/* Kein zweites weißes Fenster unten */
.uph214-dd:hover .uph214-dd-panel{
  display:none!important;
}

/* Admin-like pro polish */
.uph216-mega{
  border-top:5px solid #5d27df;
}
.uph216-mega a{
  border-radius:6px;
}
.uph216-mega a:hover{
  background:#f3edff;
  padding-left:12px;
}

/* Header stays same on all pages */
body:not(.home) .uph-v214-exact-header,
body.home .uph-v214-exact-header{
  display:block!important;
}


/* UPH VERSION 2.19.1 PAGE TITLE AREA */
.uph-page-title-area{
  max-width:1536px;
  min-height:240px;
  margin:0 auto;
  background:#f7f4ff;
  background-size:cover;
  background-position:center center;
  display:flex;
  align-items:center;
}
.uph-page-title-overlay{
  width:min(1340px,calc(100% - 58px));
  margin:0 auto;
  padding:55px 0;
}
.uph-page-title-overlay h1{
  font-size:46px;
  line-height:1.1;
  margin:0 0 10px;
  color:#111;
  text-transform:uppercase;
  font-weight:900;
}
.uph-page-title-overlay p{
  max-width:760px;
  font-size:18px;
  line-height:1.65;
  margin:0;
  color:#444;
}
@media(max-width:900px){
  .uph-page-title-overlay{
    width:calc(100% - 30px);
  }
  .uph-page-title-overlay h1{
    font-size:34px;
  }
}


/* UPH VERSION 2.19.2 PAGE TITLE FRONTEND */
.uph2192-page-title{
  max-width:1536px;
  min-height:240px;
  margin:0 auto;
  background:#f7f4ff;
  background-size:cover;
  background-position:center center;
  display:flex;
  align-items:center;
}
.uph2192-page-title-inner{
  width:min(1340px,calc(100% - 58px));
  margin:0 auto;
  padding:56px 0;
}
.uph2192-page-title-inner h1{
  margin:0 0 10px;
  color:#111;
  font-size:46px;
  line-height:1.1;
  font-weight:900;
  text-transform:uppercase;
}
.uph2192-page-title-inner p{
  max-width:760px;
  margin:0;
  color:#444;
  font-size:18px;
  line-height:1.65;
}
@media(max-width:900px){
  .uph2192-page-title-inner{width:calc(100% - 30px)}
  .uph2192-page-title-inner h1{font-size:34px}
}

/* UPH VERSION 2.19.5 MENU MANAGER */
.uph2195-nav{max-width:1536px;margin:0 auto;background:#fff;box-shadow:0 14px 34px rgba(45,12,128,.12);position:relative;z-index:2000}
.uph2195-nav.is-sticky{position:sticky;top:0}
.uph2195-nav-inner{width:min(1340px,calc(100% - 58px));min-height:74px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px}
.uph2195-menu{list-style:none;margin:0;padding:0;display:flex;align-items:center;gap:30px;font-size:13px;font-weight:900;text-transform:uppercase}
.uph2195-menu li{position:relative}.uph2195-menu a{color:#111;display:flex;align-items:center;gap:7px}.uph2195-menu a:hover,.uph2195-menu .uph-is-active>a,.uph2195-menu .current-menu-item>a{color:#5d27df}
.uph2195-menu .sub-menu{list-style:none;position:absolute;top:100%;left:0;min-width:245px;padding:12px 0;margin:0;background:#fff;border-top:4px solid #5d27df;box-shadow:0 18px 40px rgba(30,10,90,.22);border-radius:0 0 10px 10px;display:none}
.uph2195-menu li:hover>.sub-menu{display:block}.uph2195-menu .sub-menu a{padding:12px 18px;text-transform:none;white-space:nowrap}.uph-menu-badge{display:inline-flex;background:#5d27df;color:#fff;border-radius:999px;padding:3px 7px;font-size:10px;line-height:1}
.uph2195-actions{display:flex;align-items:center;gap:10px;flex:0 0 auto}.uph2195-phone{color:#4212aa;font-weight:900;white-space:nowrap}.uph2195-whatsapp{background:#25D366;color:#fff!important;padding:11px 15px;border-radius:5px;font-weight:900}.uph2195-cta{background:#5d27df;color:#fff!important;padding:12px 16px;border-radius:5px;font-weight:900;text-transform:uppercase}
.uph2195-mobile-shell,.uph2195-mobile-drawer,.uph2195-mobile-overlay{display:none}
@media(max-width:900px){
.uph2195-nav{display:none}.uph2195-mobile-shell{display:flex;align-items:center;justify-content:space-between;height:72px;padding:0 16px;background:linear-gradient(135deg,#5d27df,#26006c);color:#fff;position:sticky;top:0;z-index:99998;box-shadow:0 10px 28px rgba(0,0,0,.18)}
.uph2195-mobile-open{width:46px;height:46px;border:0;border-radius:10px;background:rgba(255,255,255,.14);display:grid;place-items:center;padding:10px}.uph2195-mobile-open span{display:block;width:24px;height:3px;background:#fff;margin:2px 0;border-radius:3px}.uph2195-mobile-brand{color:#fff;font-size:22px;font-weight:900}.uph2195-mobile-call{width:46px;height:46px;background:#fff;color:#5d27df;border-radius:10px;display:grid;place-items:center;font-size:22px;font-weight:900}
.uph2195-mobile-overlay{display:block;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:99998;opacity:0;visibility:hidden;transition:.2s}.uph2195-mobile-drawer{display:block;position:fixed;top:0;left:0;bottom:0;width:min(88vw,360px);background:#fff;z-index:99999;transform:translateX(-105%);transition:.25s ease;overflow:auto;box-shadow:18px 0 45px rgba(0,0,0,.22)}
body.uph2195-menu-open .uph2195-mobile-overlay{opacity:1;visibility:visible}body.uph2195-menu-open .uph2195-mobile-drawer{transform:translateX(0)}
.uph2195-drawer-head{height:84px;background:linear-gradient(135deg,#5d27df,#26006c);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 20px}.uph2195-mobile-close{width:42px;height:42px;border:0;border-radius:50%;background:rgba(255,255,255,.16);color:#fff;font-size:30px}
.uph2195-mobile-menu,.uph2195-drawer-nav ul{list-style:none;padding:16px;margin:0;display:grid;gap:8px}.uph2195-mobile-menu a{display:flex;align-items:center;gap:8px;justify-content:space-between;padding:14px;border:1px solid #eee8ff;border-radius:12px;background:#f7f4ff;color:#111;font-weight:900}.uph2195-mobile-menu .sub-menu{display:none;list-style:none;margin:6px 0 0 12px;padding:0;gap:6px}.uph2195-mobile-menu li.open>.sub-menu{display:grid}.uph2195-mobile-menu .sub-menu a{background:#fff;font-size:14px}.uph2195-drawer-actions{padding:16px;display:grid;gap:10px;border-top:1px solid #eee8ff}.uph2195-drawer-actions a{background:#f7f4ff;color:#4212aa;padding:13px 14px;border-radius:10px;font-weight:900}
}


/* UPH VERSION 2.19.6 MENU CLEAN */
/* Entfernt die zusätzliche weiße Menü-Leiste aus 2.19.5 */
.uph2195-nav,
.uph2195-mobile-shell,
.uph2195-mobile-overlay,
.uph2195-mobile-drawer{
  display:none!important;
  visibility:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
}

/* Original Header / RepairPress-Layout bleibt sichtbar */
.uph-v214-exact-header,
.uph-top,
.site-header,
.header,
#masthead{
  display:block;
}


/* UPH Vorteile-Boxen unter dem Menü */
.uph-feature-boxes{
  width:100%;
  max-width:1536px;
  margin:0 auto;
  padding:34px 5.5%;
  background:#fff;
}
.uph-feature-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.uph-feature-card{
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:12px;
  padding:26px;
  box-shadow:0 14px 32px rgba(45,12,128,.10);
  border-bottom:4px solid var(--uph-main,#5d27df);
}
.uph-feature-icon{
  width:46px;
  height:46px;
  border-radius:9px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(135deg,var(--uph-main,#5d27df),var(--uph-dark,#26006c));
  color:#fff;
  font-size:22px;
  margin-bottom:16px;
}
.uph-feature-card h3{
  margin:0 0 10px;
  font-size:19px;
  font-weight:900;
  color:#000;
}
.uph-feature-card p{
  margin:0;
  font-size:15px;
  line-height:1.6;
  color:#555;
}
@media(max-width:900px){
  .uph-feature-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:560px){
  .uph-feature-grid{grid-template-columns:1fr;}
}

/* UPH Kategorie-Slider über den Vorteile-Boxen */
.uph-category-slider-wrap{
  width:100%;
  max-width:1536px;
  margin:0 auto;
  padding:34px 5.5% 0;
  background:#fff;
}
.uph-category-slider{
  position:relative;
  min-height:360px;
}
.uph-category-slide{
  position:absolute;
  inset:0;
  opacity:0;
  visibility:hidden;
  transition:opacity .35s ease, visibility .35s ease;
}
.uph-category-slide.is-active{
  opacity:1;
  visibility:visible;
}
.uph-category-slide-card{
  min-height:170px;
  background:#fff;
  border:1px solid #eee8ff;
  border-radius:12px;
  padding:26px;
  box-shadow:0 14px 32px rgba(45,12,128,.10);
  border-bottom:4px solid var(--uph-main,#5d27df);
}
.uph-category-slide-link{
  display:block;
  color:inherit;
  text-decoration:none;
}
.uph-category-slide-card h3{
  margin:0 0 10px;
  font-size:19px;
  font-weight:900;
  color:#000;
}
.uph-category-slide-card p{
  margin:0;
  font-size:15px;
  line-height:1.6;
  color:#555;
}

.uph-category-slider-single .uph-category-slide,
.uph-category-slider-single .uph-category-slide.is-active{
  position:relative;
  opacity:1;
  visibility:visible;
}
.uph-category-slide-image-card{
  padding:0;
  overflow:hidden;
}
.uph-category-slide-image{
  display:block;
  width:100%;
  height:100%;
  min-height:170px;
  object-fit:cover;
}

/* UPH 2.20.8 Slider-Schrift: nutzt bestehendes Theme-Design */
.uph-category-slide-image-card{
  position:relative;
}
.uph-category-slide-content{
  position:absolute;
  left:26px;
  bottom:26px;
  max-width:520px;
  background:rgba(255,255,255,.92);
  border:1px solid #eee8ff;
  border-radius:12px;
  padding:18px 20px;
  box-shadow:0 14px 32px rgba(45,12,128,.10);
  font-family:inherit;
}
.uph-category-slide-content h3{
  margin:0 0 10px;
  font-size:19px;
  font-weight:900;
  color:#000;
  font-family:inherit;
}
.uph-category-slide-content p{
  margin:0;
  font-size:15px;
  line-height:1.6;
  color:#555;
  font-family:inherit;
}
.uph-category-slide-button{
  display:inline-block;
  margin-top:14px;
  padding:11px 18px;
  border-radius:9px;
  background:linear-gradient(135deg,var(--uph-main,#5d27df),var(--uph-dark,#26006c));
  color:#fff;
  font-size:14px;
  font-weight:800;
  font-family:inherit;
}
@media(max-width:700px){
  .uph-category-slide-content{
    left:16px;
    right:16px;
    bottom:16px;
    max-width:none;
  }
}


/* UPH 2.21.6: 5-Slider mit Admin-Text */
.uph-category-slider{min-height:360px;}
.uph-category-slide-card{min-height:360px;}
.uph-category-slide-image{min-height:360px;}
.uph-category-slide-content{left:30px;bottom:30px;max-width:560px;}
.uph-category-slide-content h3{font-weight:900;line-height:1.08;text-transform:uppercase;letter-spacing:.02em;}
.uph-category-slide-content p{line-height:1.55;}
@media(max-width:700px){
  .uph-category-slider,.uph-category-slide-card,.uph-category-slide-image{min-height:300px;}
  .uph-category-slide-content h3{font-size:30px!important;}
}


/* UPH 2.21.7: Slider Pfeile, manuell wechselbar, Text-Hintergrund besser passend */
.uph-category-slider{
  overflow:hidden;
}
.uph-category-slider-arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:5;
  width:44px;
  height:44px;
  border:0;
  border-radius:999px;
  background:linear-gradient(135deg,var(--uph-main,#5d27df),var(--uph-dark,#26006c));
  color:#fff;
  font-size:34px;
  line-height:40px;
  font-weight:700;
  cursor:pointer;
  box-shadow:0 12px 28px rgba(45,12,128,.22);
  opacity:.95;
}
.uph-category-slider-arrow:hover{
  opacity:1;
}
.uph-category-slider-prev{
  left:18px;
}
.uph-category-slider-next{
  right:18px;
}
.uph-category-slide-content{
  backdrop-filter:blur(5px);
  -webkit-backdrop-filter:blur(5px);
}
@media(max-width:700px){
  .uph-category-slider-arrow{
    width:38px;
    height:38px;
    font-size:28px;
    line-height:34px;
  }
  .uph-category-slider-prev{left:10px;}
  .uph-category-slider-next{right:10px;}
}


/* UPH 2.22.1: Slider 1 neues Hintergrundbild ohne eingebrannte Schrift, Admin-Text bleibt änderbar */
.uph-category-slider-wrap{
  padding-top:34px;
}
.uph-category-slider{
  min-height:430px;
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 14px 32px rgba(45,12,128,.10);
}
.uph-category-slide-card{
  min-height:430px;
  border:0;
  border-radius:14px;
  border-bottom:4px solid var(--uph-main,#5d27df);
  box-shadow:none;
  background:#111;
}
.uph-category-slide-image{
  min-height:430px;
}
.uph-category-slide-content{
  left:90px;
  top:50%;
  bottom:auto;
  transform:translateY(-50%);
  max-width:560px;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  padding:0;
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
  text-shadow:0 3px 16px rgba(0,0,0,.45);
}
.uph-category-slide-content h3{
  margin:0 0 24px;
  font-size:56px!important;
  line-height:.98;
  font-weight:900;
  color:#fff!important;
  letter-spacing:.015em;
}
.uph-category-slide-title-line{
  display:block;
  color:inherit;
}
.uph-category-slide-title-line:nth-child(2){
  color:var(--uph-main,#5d27df);
}
.uph-category-slide-content p{
  max-width:520px;
  color:#fff!important;
  font-size:22px!important;
  line-height:1.45;
  font-weight:500;
}
.uph-category-slide-content:after{
  content:"";
  display:block;
  width:92px;
  height:6px;
  border-radius:999px;
  background:var(--uph-main,#5d27df);
  margin-top:24px;
}
.uph-category-slider-arrow{
  width:54px;
  height:54px;
  z-index:8;
  font-size:46px;
  line-height:46px;
}
.uph-category-slider-prev{left:16px;}
.uph-category-slider-next{right:16px;}
.uph-category-slider-dots{
  position:absolute;
  left:50%;
  bottom:26px;
  transform:translateX(-50%);
  z-index:9;
  display:flex;
  gap:14px;
  align-items:center;
}
.uph-category-slider-dot{
  width:14px;
  height:14px;
  border:0;
  border-radius:999px;
  background:#fff;
  opacity:.92;
  cursor:pointer;
  padding:0;
  box-shadow:0 2px 8px rgba(0,0,0,.25);
}
.uph-category-slider-dot.is-active{
  background:var(--uph-main,#5d27df);
  opacity:1;
}
@media(max-width:900px){
  .uph-category-slider,.uph-category-slide-card,.uph-category-slide-image{min-height:360px;}
  .uph-category-slide-content{left:70px;right:70px;max-width:none;}
  .uph-category-slide-content h3{font-size:38px!important;}
  .uph-category-slide-content p{font-size:18px!important;}
}
@media(max-width:560px){
  .uph-category-slider,.uph-category-slide-card,.uph-category-slide-image{min-height:330px;}
  .uph-category-slide-content{left:58px;right:20px;}
  .uph-category-slide-content h3{font-size:28px!important;}
  .uph-category-slide-content p{font-size:15px!important;}
  .uph-category-slider-arrow{width:38px;height:38px;font-size:30px;line-height:30px;}
  .uph-category-slider-prev{left:10px;}
  .uph-category-slider-next{right:10px;}
  .uph-category-slider-dots{bottom:14px;gap:9px;}
  .uph-category-slider-dot{width:10px;height:10px;}
}


/* UPH 2.22.1: Sliderbilder alle mit sicherem Text-/Button-Bereich links */
.uph-category-slide-image{
  object-position:center center;
}
.uph-category-slide-content{
  z-index:7;
  left:105px;
  max-width:520px;
}
.uph-category-slide-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:210px;
  margin-top:24px;
  padding:17px 26px;
  border-radius:10px;
  font-size:20px;
  line-height:1;
  color:#fff!important;
  background:linear-gradient(135deg,var(--uph-main,#5d27df),var(--uph-dark,#26006c))!important;
  box-shadow:0 14px 30px rgba(45,12,128,.30);
}
.uph-category-slide-content:after{
  margin-top:18px;
}
@media(max-width:900px){
  .uph-category-slide-content{left:82px;max-width:460px;}
  .uph-category-slide-button{font-size:17px;min-width:180px;padding:14px 22px;}
}
@media(max-width:560px){
  .uph-category-slide-content{left:58px;right:18px;max-width:none;}
  .uph-category-slide-button{font-size:15px;min-width:150px;padding:12px 18px;margin-top:16px;}
}


/* UPH 2.22.2: Slider-Bild komplett sichtbar, Text/Button als echtes Admin-HTML */
.uph-category-slider{
  aspect-ratio:20/9;
  min-height:0!important;
  height:auto!important;
}
.uph-category-slide-card{
  height:100%!important;
  min-height:0!important;
}
.uph-category-slide-image{
  width:100%;
  height:100%!important;
  min-height:0!important;
  object-fit:contain!important;
  object-position:center center!important;
  background:#090414;
}
.uph-category-slide-content{
  pointer-events:auto;
  user-select:text;
  -webkit-user-select:text;
}
.uph-category-slide-button{
  position:relative;
  z-index:12;
  text-decoration:none!important;
}
@media(max-width:900px){
  .uph-category-slider{aspect-ratio:20/10;}
}
@media(max-width:560px){
  .uph-category-slider{aspect-ratio:20/13;}
}


/* UPH 2.22.3: Slider fertigstellen - Bild groß, Text/Button komplett sichtbar */
.uph-category-slider-wrap{
  width:100%!important;
  max-width:1536px!important;
  margin:0 auto!important;
  padding:34px 4.4% 0!important;
  background:#fff!important;
}
.uph-category-slider{
  position:relative!important;
  aspect-ratio:auto!important;
  height:560px!important;
  min-height:560px!important;
  max-height:none!important;
  border-radius:14px!important;
  overflow:hidden!important;
}
.uph-category-slide,
.uph-category-slide-card{
  position:absolute!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  min-height:560px!important;
}
.uph-category-slide-card{
  padding:0!important;
  border:0!important;
  border-radius:14px!important;
  border-bottom:4px solid var(--uph-main,#5d27df)!important;
  background:#090414!important;
  overflow:hidden!important;
}
.uph-category-slide-image{
  display:block!important;
  width:100%!important;
  height:100%!important;
  min-height:560px!important;
  object-fit:cover!important;
  object-position:center center!important;
}
.uph-category-slide-content{
  position:absolute!important;
  z-index:7!important;
  left:90px!important;
  top:50%!important;
  bottom:auto!important;
  transform:translateY(-50%)!important;
  max-width:560px!important;
  padding:0!important;
  margin:0!important;
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  color:#fff!important;
  text-shadow:0 3px 16px rgba(0,0,0,.55)!important;
  pointer-events:auto!important;
  user-select:text!important;
  -webkit-user-select:text!important;
}
.uph-category-slide-content h3{
  margin:0 0 22px!important;
  line-height:.98!important;
  font-weight:900!important;
  text-transform:uppercase!important;
  letter-spacing:.015em!important;
}
.uph-category-slide-title-line{display:block!important;}
.uph-category-slide-title-line:nth-child(2){color:var(--uph-main,#5d27df)!important;}
.uph-category-slide-content p{
  margin:0!important;
  max-width:530px!important;
  line-height:1.42!important;
  font-weight:500!important;
}
.uph-category-slide-content:after{
  content:""!important;
  display:block!important;
  width:90px!important;
  height:6px!important;
  border-radius:999px!important;
  background:var(--uph-main,#5d27df)!important;
  margin-top:20px!important;
}
.uph-category-slide-button{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-width:215px!important;
  margin-top:24px!important;
  padding:18px 28px!important;
  border-radius:10px!important;
  font-size:20px!important;
  font-weight:800!important;
  line-height:1!important;
  text-decoration:none!important;
  position:relative!important;
  z-index:12!important;
  box-shadow:0 14px 30px rgba(45,12,128,.34)!important;
}
.uph-category-slider-arrow{
  z-index:9!important;
  width:54px!important;
  height:54px!important;
  border-radius:999px!important;
  font-size:46px!important;
  line-height:46px!important;
}
.uph-category-slider-prev{left:16px!important;}
.uph-category-slider-next{right:16px!important;}
.uph-category-slider-dots{bottom:24px!important;z-index:9!important;}
@media(max-width:1024px){
  .uph-category-slider{height:520px!important;min-height:520px!important;}
  .uph-category-slide,.uph-category-slide-card,.uph-category-slide-image{min-height:520px!important;}
  .uph-category-slide-content{left:76px!important;max-width:510px!important;}
  .uph-category-slide-content h3{font-size:44px!important;}
  .uph-category-slide-content p{font-size:18px!important;}
}
@media(max-width:760px){
  .uph-category-slider{height:500px!important;min-height:500px!important;}
  .uph-category-slide,.uph-category-slide-card,.uph-category-slide-image{min-height:500px!important;}
  .uph-category-slide-content{left:58px!important;right:24px!important;max-width:none!important;}
  .uph-category-slide-content h3{font-size:34px!important;margin-bottom:18px!important;}
  .uph-category-slide-content p{font-size:16px!important;}
  .uph-category-slide-button{font-size:16px!important;min-width:170px!important;padding:14px 20px!important;margin-top:18px!important;}
  .uph-category-slider-arrow{width:40px!important;height:40px!important;font-size:32px!important;line-height:32px!important;}
  .uph-category-slider-prev{left:10px!important;}
  .uph-category-slider-next{right:10px!important;}
}


/* UPH 2.23.0: Slider Widget Builder */
.uph-widget-slider-wrap{width:100%;max-width:1200px;margin:24px auto 18px;padding:0 15px;box-sizing:border-box}
.uph-widget-slider{position:relative;overflow:hidden;border-radius:18px;background:#15112a;box-shadow:0 14px 40px rgba(18,12,45,.18)}
.uph-widget-slide{display:none;position:relative;min-height:520px;background:#15112a}
.uph-widget-slide.is-active{display:block}
.uph-widget-slide-img{display:block;width:100%;height:auto;max-height:none;object-fit:contain;background:#15112a}
.uph-widget-slide-text{position:absolute;left:7%;top:50%;transform:translateY(-50%);z-index:4;max-width:460px;padding:22px 24px;border-radius:18px;background:rgba(15,10,34,.38);backdrop-filter:blur(3px)}
.uph-widget-slide-text h2{margin:0 0 14px;font-size:clamp(32px,4vw,58px);line-height:1.02;font-weight:900;text-transform:uppercase;letter-spacing:.02em}
.uph-widget-slide-text h2 span{display:block}.uph-widget-slide-text p{margin:0 0 20px;font-size:clamp(16px,1.6vw,21px);line-height:1.55;font-weight:500}.uph-widget-slide-btn{display:inline-block;padding:13px 26px;border-radius:999px;text-decoration:none!important;font-weight:800;box-shadow:0 10px 24px rgba(93,39,223,.28)}
.uph-widget-prev,.uph-widget-next{position:absolute;top:50%;transform:translateY(-50%);z-index:8;width:48px;height:48px;border:0;border-radius:50%;background:rgba(93,39,223,.88);color:#fff;font-size:38px;line-height:42px;cursor:pointer;box-shadow:0 8px 22px rgba(0,0,0,.25)}
.uph-widget-prev{left:18px}.uph-widget-next{right:18px}.uph-widget-prev:hover,.uph-widget-next:hover{background:#4b18c9}.uph-widget-dots{position:absolute;left:0;right:0;bottom:22px;z-index:9;display:flex;align-items:center;justify-content:center;gap:10px}.uph-widget-dots button{width:12px;height:12px;border-radius:50%;border:2px solid #fff;background:rgba(255,255,255,.25);cursor:pointer;padding:0}.uph-widget-dots button.is-active{background:#5d27df;border-color:#5d27df}
@media(max-width:900px){.uph-widget-slide{min-height:420px}.uph-widget-slide-text{left:5%;right:5%;max-width:520px;top:auto;bottom:54px;transform:none;padding:18px}.uph-widget-slide-text h2{font-size:34px}.uph-widget-slide-text p{font-size:16px}.uph-widget-prev,.uph-widget-next{width:40px;height:40px;font-size:30px}.uph-widget-prev{left:10px}.uph-widget-next{right:10px}}
@media(max-width:600px){.uph-widget-slider-wrap{padding:0 10px}.uph-widget-slide{min-height:360px}.uph-widget-slide-text{position:relative;left:auto;right:auto;bottom:auto;top:auto;transform:none;max-width:none;margin:0;background:#15112a;border-radius:0}.uph-widget-slide-img{width:100%}}
