*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:#080a0c;color:#f3f5f5;font-family:Inter,Arial,sans-serif;line-height:1.55}a{color:inherit}.header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:24px;width:min(1180px,94%);margin:18px auto;padding:14px 18px;background:rgba(8,10,12,.86);border:1px solid #20262b;border-radius:18px;backdrop-filter:blur(14px)}.logo img{height:48px;display:block}.nav{display:flex;gap:24px;align-items:center}.nav a{text-decoration:none;color:#b9c0c5;font-size:14px}.nav a:hover{color:#a8ff00}.btn{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:999px;background:#a8ff00;color:#071006;text-decoration:none;font-weight:800;padding:13px 22px;cursor:pointer}.btn.small{padding:10px 16px}.link{color:#a8ff00;text-decoration:none;font-weight:800}.socialbar{position:fixed;right:18px;top:50%;transform:translateY(-50%);z-index:19;display:flex;flex-direction:column;gap:10px}.socialbar a{writing-mode:vertical-rl;transform:rotate(180deg);text-decoration:none;text-transform:uppercase;letter-spacing:.12em;font-size:11px;font-weight:900;color:#071006;background:#a8ff00;padding:14px 9px;border-radius:999px}main{width:min(1180px,94%);margin:0 auto}.hero{min-height:650px;display:grid;grid-template-columns:1.1fr .7fr;gap:60px;align-items:center;padding:80px 0;border-bottom:1px solid #20262b}.eyebrow{color:#a8ff00;text-transform:uppercase;letter-spacing:.16em;font-size:12px;font-weight:900;margin:0 0 14px}.hero h1{font-size:clamp(40px,6vw,76px);line-height:.98;letter-spacing:-.05em;margin:0}.lead{max-width:650px;color:#b9c0c5;font-size:19px}.actions{display:flex;gap:18px;align-items:center;margin-top:32px}.hero-logo{display:grid;place-items:center;border:1px solid #20262b;border-radius:28px;min-height:360px;background:linear-gradient(180deg,#101417,#090b0d)}.hero-logo img{width:min(360px,82%);filter:drop-shadow(0 0 20px rgba(168,255,0,.2))}.section{padding:72px 0;border-bottom:1px solid #20262b}.section-head{display:grid;grid-template-columns:280px 1fr;gap:40px;align-items:start;margin-bottom:30px}.section h2{font-size:clamp(28px,4vw,46px);line-height:1.05;letter-spacing:-.03em;margin:0}.cards,.gallery,.news,.admin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.cards article,.news article,.admin form{border:1px solid #20262b;background:#0d1114;border-radius:18px;padding:26px}.cards h3,.news h3,.admin h3{margin:0 0 10px}.cards p,.news p,.note{color:#aeb6bb;margin:0}.printer-list{display:grid;gap:12px}.printer-list div{display:flex;justify-content:space-between;gap:18px;align-items:center;padding:18px 20px;border:1px solid #20262b;border-radius:14px;background:#0d1114}.ok{color:#a8ff00;font-weight:900}.wait{color:#ffbd66;font-weight:900}.gallery figure{margin:0;border:1px solid #20262b;border-radius:18px;overflow:hidden;background:#0d1114}.gallery img{width:100%;height:240px;object-fit:cover;display:block}.gallery figcaption{padding:14px 18px;color:#c8ced2;font-weight:800}.news{grid-template-columns:repeat(2,1fr)}time{display:inline-block;color:#a8ff00;font-size:12px;text-transform:uppercase;font-weight:900;margin-bottom:12px}.admin-grid{grid-template-columns:1fr 1fr}.admin input,.admin textarea,.contact-form input,.contact-form select,.contact-form textarea{width:100%;margin:0 0 12px;padding:14px 15px;border-radius:12px;border:1px solid #242b30;background:#0b0f12;color:#fff;font:inherit}.contact-form{max-width:760px;margin-left:320px;display:grid;gap:12px}.footer{width:min(1180px,94%);margin:50px auto;padding:30px 0;display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px;color:#aeb6bb}.footer img{height:48px}.footer details{border:1px solid #20262b;border-radius:16px;padding:18px}.footer summary{color:#a8ff00;font-weight:900;cursor:pointer}@media(max-width:900px){.header{position:static;flex-wrap:wrap}.nav{width:100%;justify-content:center;flex-wrap:wrap}.socialbar{display:none}.hero,.section-head{grid-template-columns:1fr}.cards,.gallery,.news,.admin-grid,.footer{grid-template-columns:1fr}.contact-form{margin-left:0}.hero{padding-top:40px}.actions{flex-wrap:wrap}}
/* Modern Hero Update */
body{background:radial-gradient(circle at 18% 8%,rgba(168,255,0,.13),transparent 26%),radial-gradient(circle at 88% 12%,rgba(255,255,255,.07),transparent 22%),#07090b}
.header{box-shadow:0 16px 50px rgba(0,0,0,.32)}
.hero{min-height:560px;padding:54px 0 70px;position:relative}
.hero:before{content:"";position:absolute;inset:34px 0 auto 0;height:1px;background:linear-gradient(90deg,transparent,rgba(168,255,0,.45),transparent)}
.hero h1{max-width:760px;font-size:clamp(32px,4.6vw,58px)!important;line-height:1.04!important;letter-spacing:-.045em!important}
.lead{max-width:590px!important;font-size:16px!important;line-height:1.65!important;color:#b7c0c5!important}
.hero-points{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.hero-points span{border:1px solid #242b30;background:rgba(255,255,255,.035);color:#d9dedf;border-radius:999px;padding:8px 12px;font-size:12px;font-weight:800}
.actions{margin-top:26px!important;gap:14px!important}
.actions .btn{padding:11px 18px!important;font-size:13px!important}
.actions .link{font-size:13px!important}
.hero-logo{min-height:300px!important;border-radius:32px!important;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.015)),radial-gradient(circle at 50% 48%,rgba(168,255,0,.12),transparent 58%);overflow:hidden;position:relative}
.hero-logo:before{content:"";position:absolute;width:210px;height:210px;border-radius:50%;border:1px solid rgba(168,255,0,.22);animation:orbitPulse 5s ease-in-out infinite}
.hero-logo:after{content:"";position:absolute;inset:-40%;background:conic-gradient(from 0deg,transparent,rgba(168,255,0,.18),transparent 28%);animation:spinGlow 8s linear infinite;opacity:.55}
.hero-logo img{position:relative;z-index:2;width:min(290px,76%)!important;animation:logoFloat 4.2s ease-in-out infinite;filter:drop-shadow(0 0 14px rgba(168,255,0,.26)) drop-shadow(0 18px 30px rgba(0,0,0,.52))!important}
@keyframes logoFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-12px) scale(1.025)}}
@keyframes spinGlow{to{transform:rotate(360deg)}}
@keyframes orbitPulse{0%,100%{transform:scale(.92);opacity:.42}50%{transform:scale(1.16);opacity:.78}}
@media(max-width:900px){.hero{min-height:auto;padding:36px 0 54px}.hero-logo{min-height:240px}}

/* Single-section view: shows only the selected menu area */
.single-view main{min-height:calc(100vh - 170px)}
.view-section{display:none!important}
.view-section.active{display:grid!important;animation:sectionFade .28s ease both}
.section.view-section.active{display:block!important}
.nav a.is-active{color:#a8ff00}
.logo.is-active img{filter:drop-shadow(0 0 12px rgba(168,255,0,.45))}
.single-view .section,.single-view .hero{border-bottom:0}
.single-view .footer{margin-top:20px}
@keyframes sectionFade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:900px){
  .view-section.active{display:block!important}
  .hero.view-section.active{display:grid!important}
}

/* Kompakter Footer */
.footer{
  grid-template-columns: 220px 1fr 1fr !important;
  gap:12px !important;
  align-items:start;
}
.footer details{
  padding:10px 14px !important;
  border-radius:10px !important;
}
.footer summary{
  font-size:13px !important;
}
.footer details p{
  font-size:12px !important;
  line-height:1.45 !important;
  margin:8px 0 0 0 !important;
}
.footer img{
  height:38px !important;
}
.footer{
  padding:14px 0 !important;
}

/* Minimaler Footer mit Impressum/Datenschutz Modal */
.footer-minimal{
  width:min(1180px,94%)!important;
  margin:28px auto 34px!important;
  padding:14px 0!important;
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:18px!important;
  color:#8f989e!important;
  border-top:1px solid #20262b!important;
  grid-template-columns:none!important;
}
.footer-left{display:flex;align-items:center;gap:12px}
.footer-left img{height:32px!important}
.footer-left span{font-size:13px}
.footer-left a{color:#a8ff00;text-decoration:none}
.footer-links{display:flex;gap:10px;flex-wrap:wrap}
.footer-links button{
  border:1px solid #20262b;
  background:#0d1114;
  color:#c9d0d4;
  border-radius:999px;
  padding:9px 13px;
  font:inherit;
  font-size:12px;
  font-weight:800;
  cursor:pointer;
}
.footer-links button:hover{color:#071006;background:#a8ff00;border-color:#a8ff00}
.modal{position:fixed;inset:0;z-index:80;display:none}
.modal.open{display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(8px)}
.modal-card{
  position:absolute;
  right:24px;
  top:24px;
  bottom:24px;
  width:min(520px,calc(100% - 48px));
  overflow:auto;
  border:1px solid rgba(168,255,0,.18);
  border-radius:24px;
  background:#0b0f12;
  color:#e9eef2;
  padding:34px;
  box-shadow:0 30px 100px rgba(0,0,0,.55);
  animation:modalSlide .22s ease both;
}
.modal-card h2{margin:0 0 20px;font-size:30px}
.modal-card p{color:#b9c0c5;font-size:14px;line-height:1.6}
.modal-card a{color:#a8ff00}
.modal-close{
  position:absolute;
  top:16px;
  right:16px;
  width:36px;
  height:36px;
  border:1px solid #20262b;
  border-radius:50%;
  background:#11161a;
  color:#fff;
  font-size:22px;
  cursor:pointer;
}
@keyframes modalSlide{from{opacity:0;transform:translateX(22px)}to{opacity:1;transform:translateX(0)}}
@media(max-width:700px){
  .footer-minimal{align-items:flex-start!important;flex-direction:column!important}
  .modal-card{left:16px;right:16px;top:16px;bottom:16px;width:auto;padding:26px}
}


/* Premium Navigation Upgrade */
.header{
  position:sticky!important;
  top:14px!important;
  z-index:100!important;
  background:rgba(10,12,15,.92)!important;
  border:1px solid rgba(168,255,0,.28)!important;
  box-shadow:
    0 20px 60px rgba(0,0,0,.45),
    0 0 30px rgba(168,255,0,.08)!important;
  animation:navReveal .8s ease;
}

.header:before{
  content:"";
  position:absolute;
  left:20px;
  right:20px;
  top:0;
  height:2px;
  background:linear-gradient(90deg,
    transparent,
    rgba(168,255,0,.9),
    transparent);
  animation:navGlow 4s linear infinite;
}

.nav a{
  position:relative;
  font-weight:700!important;
  transition:all .25s ease!important;
}

.nav a:hover{
  color:#a8ff00!important;
  transform:translateY(-2px);
}

.nav a:after{
  content:"";
  position:absolute;
  left:0;
  bottom:-8px;
  width:0;
  height:2px;
  background:#a8ff00;
  transition:.3s;
  box-shadow:0 0 12px rgba(168,255,0,.8);
}

.nav a:hover:after,
.nav a.is-active:after{
  width:100%;
}

.nav a.is-active{
  color:#a8ff00!important;
}

.btn.small{
  box-shadow:0 0 24px rgba(168,255,0,.25);
  transition:.25s;
}

.btn.small:hover{
  transform:translateY(-2px);
  box-shadow:0 0 30px rgba(168,255,0,.4);
}

@keyframes navReveal{
  from{opacity:0;transform:translateY(-15px)}
  to{opacity:1;transform:translateY(0)}
}

@keyframes navGlow{
  0%{opacity:.3}
  50%{opacity:1}
  100%{opacity:.3}
}

/* Professionelles Kontaktformular */
.contact-layout{
  display:grid;
  grid-template-columns:320px 1fr;
  gap:42px;
  align-items:start;
}
.contact-copy{
  border:1px solid #20262b;
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.018));
  border-radius:22px;
  padding:26px;
}
.contact-copy h3{margin:0 0 12px;font-size:22px}
.contact-copy p{color:#b9c0c5;margin:0 0 14px}
.mail-note a{color:#a8ff00;text-decoration:none;font-weight:900}
.contact-form.enhanced{
  margin-left:0!important;
  max-width:none!important;
  border:1px solid rgba(168,255,0,.18);
  background:#0d1114;
  border-radius:24px;
  padding:26px;
  box-shadow:0 24px 70px rgba(0,0,0,.28);
}
.contact-form .form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.contact-form.enhanced input,
.contact-form.enhanced select,
.contact-form.enhanced textarea{
  margin:0!important;
  border-color:#263037!important;
  background:#090d10!important;
}
.contact-form.enhanced input:focus,
.contact-form.enhanced select:focus,
.contact-form.enhanced textarea:focus{
  outline:none;
  border-color:#a8ff00!important;
  box-shadow:0 0 0 3px rgba(168,255,0,.12);
}
.contact-form.enhanced small{
  color:#8f989e;
  font-size:12px;
}
@media(max-width:900px){
  .contact-layout{grid-template-columns:1fr}
  .contact-form .form-row{grid-template-columns:1fr}
}

/* Animierte Social-Media-Leiste */
.socialbar{
  position:fixed;
  right:18px;
  top:50%;
  transform:translateY(-50%);
  z-index:999;
}

.socialbar a{
  position:relative;
  overflow:hidden;
  animation:socialFloat 3.5s ease-in-out infinite;
  transition:all .3s ease;
}

.socialbar a:nth-child(2){
  animation-delay:.4s;
}

.socialbar a:nth-child(3){
  animation-delay:.8s;
}

.socialbar a:hover{
  transform:rotate(180deg) translateX(-6px) scale(1.08);
  box-shadow:
    0 0 25px rgba(168,255,0,.45),
    0 0 50px rgba(168,255,0,.25);
}

.socialbar a::before{
  content:"";
  position:absolute;
  inset:-40%;
  background:linear-gradient(
    120deg,
    transparent,
    rgba(255,255,255,.4),
    transparent
  );
  transform:translateX(-150%);
  animation:shine 4s linear infinite;
}

@keyframes socialFloat{
  0%,100%{
    transform:rotate(180deg) translateY(0);
  }
  50%{
    transform:rotate(180deg) translateY(-8px);
  }
}

@keyframes shine{
  0%{transform:translateX(-150%)}
  100%{transform:translateX(250%)}
}

/* Dropdown für 3D Studio */
.dropdown{position:relative;display:inline-block}
.dropdown-menu{
display:none;
position:absolute;
top:100%;
left:0;
min-width:180px;
padding:10px;
background:#0d1114;
border:1px solid #20262b;
border-radius:14px;
box-shadow:0 20px 40px rgba(0,0,0,.4);
}
.dropdown:hover .dropdown-menu{display:block}
.dropdown-menu a{
display:block;
padding:10px;
text-decoration:none;
white-space:nowrap;
}

.news article p b,.news article p strong{color:#fff}
.news article p i{color:#dce3e6}
.gallery figcaption small{display:block;color:#9aa3a9;font-weight:400;margin-top:6px;line-height:1.4}
.busy{color:#7dd3ff;font-weight:900}
.printer-list small{display:block;color:#9aa3a9;margin-top:8px;line-height:1.45}


/* Production Center Upgrade */
.studio-dashboard{
display:grid;
grid-template-columns:repeat(4,1fr);
gap:18px;
margin:0 0 30px;
}
.metric{
background:linear-gradient(180deg,#101417,#0c1013);
border:1px solid rgba(168,255,0,.15);
border-radius:20px;
padding:24px;
text-align:center;
}
.metric span{
display:block;
font-size:12px;
text-transform:uppercase;
letter-spacing:.12em;
color:#9aa3a9;
margin-bottom:10px;
}
.metric strong{
font-size:32px;
color:#a8ff00;
}

.printer-cards{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
gap:20px;
}

.printer-card{
background:linear-gradient(180deg,#101417,#0b0f12);
border:1px solid rgba(168,255,0,.12);
border-radius:24px;
padding:22px;
transition:.3s;
}
.printer-card:hover{
transform:translateY(-4px);
border-color:rgba(168,255,0,.35);
box-shadow:0 20px 50px rgba(0,0,0,.35);
}
.printer-head{
display:flex;
justify-content:space-between;
align-items:center;
gap:12px;
margin-bottom:12px;
}
.printer-head h3{
margin:0;
font-size:20px;
}
.printer-card p{
color:#b8c1c6;
line-height:1.6;
min-height:72px;
}
.printer-meta{
display:flex;
gap:10px;
flex-wrap:wrap;
margin:14px 0;
}
.printer-meta span{
background:#141a1e;
border:1px solid #232a2f;
padding:8px 12px;
border-radius:999px;
font-size:12px;
}
.progress{
height:8px;
background:#161c20;
border-radius:999px;
overflow:hidden;
margin-top:16px;
}
.bar{
height:100%;
background:linear-gradient(90deg,#75c800,#a8ff00);
border-radius:999px;
}
.ok,.busy,.wait,.offline{
padding:8px 12px;
border-radius:999px;
font-size:12px;
font-weight:900;
}
.ok{background:rgba(90,255,90,.12)}
.busy{background:rgba(90,180,255,.12)}
.wait{background:rgba(255,190,90,.12)}
.offline{background:rgba(255,90,90,.12)}

@media(max-width:900px){
.studio-dashboard{grid-template-columns:1fr 1fr}
}

/* Ultra Modern KS3D Printer Status */
.production-console{
  position:relative;
  padding:18px;
  border:1px solid rgba(168,255,0,.16);
  border-radius:28px;
  background:
    linear-gradient(135deg,rgba(168,255,0,.08),transparent 38%),
    rgba(255,255,255,.025);
  overflow:hidden;
}
.production-console:before{
  content:"";
  position:absolute;
  inset:-1px;
  background:linear-gradient(90deg,transparent,rgba(168,255,0,.35),transparent);
  transform:translateX(-100%);
  animation:consoleScan 5s linear infinite;
}
.production-console .metric{
  position:relative;
  z-index:1;
  text-align:left;
}
.metric small{
  display:block;
  color:#8f989e;
  margin-top:6px;
  font-size:12px;
}
.metric strong{
  font-size:clamp(22px,2.4vw,32px)!important;
  line-height:1.05;
}
.printer-cards{
  grid-template-columns:repeat(auto-fit,minmax(330px,1fr))!important;
}
.pro-card{
  position:relative;
  overflow:hidden;
  min-height:315px;
  border:1px solid rgba(168,255,0,.16)!important;
  background:
    radial-gradient(circle at 86% 10%,rgba(168,255,0,.16),transparent 28%),
    linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.018))!important;
}
.pro-card:before{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:26px 26px;
  mask-image:linear-gradient(to bottom,black,transparent 80%);
  pointer-events:none;
}
.pro-card:after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:2px;
  background:linear-gradient(90deg,transparent,#a8ff00,transparent);
  opacity:.65;
}
.pro-card:hover{
  transform:translateY(-7px) scale(1.01)!important;
  box-shadow:
    0 26px 70px rgba(0,0,0,.42),
    0 0 38px rgba(168,255,0,.13)!important;
}
.card-orb{
  position:absolute;
  right:-42px;
  top:-42px;
  width:135px;
  height:135px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(168,255,0,.22),transparent 65%);
  animation:orbPulse 4s ease-in-out infinite;
}
.unit-type{
  display:inline-block;
  color:#a8ff00;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:10px;
  font-weight:1000;
  margin-bottom:8px;
}
.status-pill{
  position:relative;
  white-space:nowrap;
}
.status-pill:before{
  content:"";
  display:inline-block;
  width:8px;
  height:8px;
  border-radius:50%;
  margin-right:7px;
  background:currentColor;
  box-shadow:0 0 14px currentColor;
  animation:statusBlink 1.8s ease-in-out infinite;
}
.printer-card p{
  position:relative;
  z-index:1;
  min-height:84px!important;
}
.printer-meta{
  position:relative;
  z-index:1;
}
.load-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  color:#aeb6bb;
  margin-top:18px;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.load-row strong{
  color:#a8ff00;
}
.progress{
  height:10px!important;
  background:#070a0c!important;
  border:1px solid rgba(255,255,255,.06);
  box-shadow:inset 0 0 10px rgba(0,0,0,.4);
}
.bar{
  position:relative;
  overflow:hidden;
  background:linear-gradient(90deg,#4f8f00,#a8ff00,#e4ff8a)!important;
}
.bar:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.55),transparent);
  animation:barShine 2.4s linear infinite;
}
.printer-footer{
  display:flex;
  justify-content:space-between;
  gap:14px;
  margin-top:16px;
  padding-top:14px;
  border-top:1px solid rgba(255,255,255,.08);
  color:#9aa3a9;
  font-size:12px;
}
.signal{
  color:#a8ff00;
  font-weight:900;
}
@keyframes consoleScan{
  to{transform:translateX(100%)}
}
@keyframes orbPulse{
  0%,100%{transform:scale(.9);opacity:.6}
  50%{transform:scale(1.18);opacity:1}
}
@keyframes statusBlink{
  0%,100%{opacity:.55}
  50%{opacity:1}
}
@keyframes barShine{
  from{transform:translateX(-100%)}
  to{transform:translateX(100%)}
}
@media(max-width:700px){
  .production-console{grid-template-columns:1fr!important}
  .printer-cards{grid-template-columns:1fr!important}
}


/* Status-spezifische Animationen für das Production Center */
.pro-card{transform-style:preserve-3d}
.pro-card .status-pill{overflow:hidden}
.pro-card .status-pill:after{content:"";position:absolute;inset:0;border-radius:999px;opacity:.35;pointer-events:none}

/* ONLINE */
.status-pill.ok,.ok.status-pill{
  color:#a8ff00!important;
  background:rgba(168,255,0,.12)!important;
  box-shadow:0 0 22px rgba(168,255,0,.18);
  animation:statusReady 2.8s ease-in-out infinite;
}

/* DRUCKT */
.status-pill.busy,.busy.status-pill{
  color:#7dd3ff!important;
  background:rgba(125,211,255,.13)!important;
  box-shadow:0 0 24px rgba(125,211,255,.22);
  animation:printingPulse 1.35s ease-in-out infinite;
}
.pro-card:has(.busy.status-pill),.pro-card:has(.status-pill.busy){border-color:rgba(125,211,255,.28)!important}
.pro-card:has(.busy.status-pill):before,.pro-card:has(.status-pill.busy):before{
  animation:printLayerScan 2.2s linear infinite;
  background-image:linear-gradient(rgba(125,211,255,.07) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
}

/* WARTUNG */
.status-pill.wait,.wait.status-pill{
  color:#ffbd66!important;
  background:rgba(255,189,102,.14)!important;
  box-shadow:0 0 24px rgba(255,189,102,.22);
  animation:maintenancePulse 1.9s ease-in-out infinite;
}
.status-pill.wait:after,.wait.status-pill:after{
  content:"⚙";position:static;display:inline-block;margin-left:7px;opacity:1;animation:gearRotate 2.2s linear infinite;
}
.pro-card:has(.wait.status-pill),.pro-card:has(.status-pill.wait){border-color:rgba(255,189,102,.32)!important}
.pro-card:has(.wait.status-pill):after,.pro-card:has(.status-pill.wait):after{
  background:linear-gradient(90deg,transparent,#ffbd66,transparent)!important;
  animation:maintenanceBorder 1.8s ease-in-out infinite;
}

/* OFFLINE */
.status-pill.offline,.offline.status-pill{
  color:#7b858b!important;
  background:rgba(160,170,175,.09)!important;
  box-shadow:none!important;
  animation:offlineBlink 2.4s ease-in-out infinite;
}
.pro-card:has(.offline.status-pill),.pro-card:has(.status-pill.offline){
  filter:saturate(.55) brightness(.78);
  border-color:rgba(150,160,165,.14)!important;
}
.pro-card:has(.offline.status-pill) .bar,.pro-card:has(.status-pill.offline) .bar{
  background:linear-gradient(90deg,#343b40,#68727a)!important;
}

/* Fortschrittsbalken je Status */
.pro-card:has(.busy.status-pill) .bar,.pro-card:has(.status-pill.busy) .bar{
  background:linear-gradient(90deg,#0ea5e9,#7dd3ff,#e0f7ff)!important;
  animation:printingBar 1.1s linear infinite;
}
.pro-card:has(.wait.status-pill) .bar,.pro-card:has(.status-pill.wait) .bar{
  background:linear-gradient(90deg,#ad6800,#ffbd66,#ffe0a8)!important;
  animation:maintenanceBar 1.8s ease-in-out infinite;
}
.pro-card:has(.ok.status-pill) .bar,.pro-card:has(.status-pill.ok) .bar{animation:readyBar 3s ease-in-out infinite}

/* Druckt: bewegte Schichten */
.pro-card:has(.busy.status-pill) .card-orb,.pro-card:has(.status-pill.busy) .card-orb{
  background:repeating-linear-gradient(0deg,rgba(125,211,255,0) 0px,rgba(125,211,255,0) 8px,rgba(125,211,255,.22) 9px,rgba(125,211,255,.22) 10px),radial-gradient(circle,rgba(125,211,255,.22),transparent 65%);
  animation:layerBuild 1.4s linear infinite;
}

/* Wartung: Werkzeugbewegung */
.pro-card:has(.wait.status-pill) .card-orb,.pro-card:has(.status-pill.wait) .card-orb{
  background:radial-gradient(circle,rgba(255,189,102,.22),transparent 65%);
  animation:maintenanceOrb 2.2s ease-in-out infinite;
}

/* Offline: gedimmt */
.pro-card:has(.offline.status-pill) .card-orb,.pro-card:has(.status-pill.offline) .card-orb{
  background:radial-gradient(circle,rgba(150,160,165,.12),transparent 65%);
  animation:offlineOrb 2.8s ease-in-out infinite;
}

@keyframes statusReady{0%,100%{box-shadow:0 0 16px rgba(168,255,0,.14)}50%{box-shadow:0 0 34px rgba(168,255,0,.34)}}
@keyframes printingPulse{0%,100%{box-shadow:0 0 14px rgba(125,211,255,.16);transform:scale(1)}50%{box-shadow:0 0 34px rgba(125,211,255,.42);transform:scale(1.04)}}
@keyframes maintenancePulse{0%,100%{box-shadow:0 0 12px rgba(255,189,102,.15)}50%{box-shadow:0 0 32px rgba(255,189,102,.38)}}
@keyframes offlineBlink{0%,100%{opacity:.45}45%{opacity:1}55%{opacity:.35}}
@keyframes gearRotate{to{transform:rotate(360deg)}}
@keyframes printLayerScan{0%{background-position:0 0,0 0}100%{background-position:0 52px,26px 0}}
@keyframes printingBar{0%{filter:brightness(1);background-position:0 0}50%{filter:brightness(1.35)}100%{filter:brightness(1);background-position:80px 0}}
@keyframes maintenanceBar{0%,100%{filter:brightness(.8)}50%{filter:brightness(1.35)}}
@keyframes readyBar{0%,100%{filter:brightness(1)}50%{filter:brightness(1.18)}}
@keyframes layerBuild{0%{background-position:0 0,0 0;transform:scale(.95)}100%{background-position:0 -40px,0 0;transform:scale(1.08)}}
@keyframes maintenanceOrb{0%,100%{transform:rotate(0deg) scale(.9)}50%{transform:rotate(12deg) scale(1.18)}}
@keyframes offlineOrb{0%,100%{opacity:.22;transform:scale(.9)}50%{opacity:.5;transform:scale(1.05)}}
@keyframes maintenanceBorder{0%,100%{opacity:.35}50%{opacity:1}}
.status-pill.ok:before{animation:statusBlink 2.2s ease-in-out infinite}
.status-pill.busy:before{animation:statusBlink .85s ease-in-out infinite}
.status-pill.wait:before{animation:statusBlink 1.3s ease-in-out infinite}
.status-pill.offline:before{animation:offlineBlink 2.4s ease-in-out infinite}


/* ==========================================================
   Einheitliches Responsive Layout für Desktop, Laptop, Tablet, Mobile
   ========================================================== */

:root{
  --page-width:1180px;
  --side-space:clamp(16px,3vw,40px);
  --section-space:clamp(42px,7vw,82px);
  --radius-xl:clamp(18px,2vw,28px);
}

html,body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
}

body{
  font-size:clamp(15px,1vw,17px);
}

img,video,canvas,svg{
  max-width:100%;
  height:auto;
}

.header,
main,
.footer-minimal,
.footer,
.admin-shell{
  width:min(var(--page-width),calc(100% - var(--side-space) * 2))!important;
}

/* Header sauber skalieren */
.header{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:clamp(12px,2vw,24px)!important;
  padding:clamp(10px,1.5vw,16px) clamp(12px,2vw,20px)!important;
  border-radius:var(--radius-xl)!important;
}

.logo img,
.header .logo img{
  height:clamp(38px,4vw,52px)!important;
}

.nav{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:clamp(10px,1.8vw,24px)!important;
  flex-wrap:wrap!important;
}

.nav a,
.dropdown > a{
  font-size:clamp(12px,1vw,14px)!important;
  white-space:nowrap;
}

/* Drop-down auch auf kleinen Geräten stabil */
.dropdown{
  position:relative;
}

.dropdown-menu{
  z-index:200!important;
}

/* Hero einheitlich */
.hero{
  min-height:auto!important;
  grid-template-columns:minmax(0,1.1fr) minmax(280px,.7fr)!important;
  gap:clamp(28px,5vw,70px)!important;
  padding:clamp(42px,7vw,80px) 0!important;
}

.hero h1{
  font-size:clamp(32px,5vw,58px)!important;
  max-width:780px!important;
}

.lead,
.hero p{
  font-size:clamp(15px,1.4vw,17px)!important;
  max-width:650px!important;
}

.hero-logo{
  min-height:clamp(230px,32vw,360px)!important;
}

.hero-logo img{
  width:min(300px,74%)!important;
}

/* Section Layout */
.section{
  padding:var(--section-space) 0!important;
}

.section-head{
  display:grid!important;
  grid-template-columns:minmax(180px,280px) minmax(0,1fr)!important;
  gap:clamp(20px,4vw,46px)!important;
  margin-bottom:clamp(24px,4vw,40px)!important;
}

.section h2,
.section-head h2{
  font-size:clamp(28px,4vw,46px)!important;
  line-height:1.08!important;
}

/* Karten / Raster */
.cards,
.gallery,
.news,
.admin-grid,
.printer-cards,
.studio-dashboard,
.production-console{
  gap:clamp(14px,2vw,22px)!important;
}

.cards{
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
}

.news{
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
}

.gallery{
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
}

.printer-cards{
  grid-template-columns:repeat(auto-fit,minmax(min(100%,310px),1fr))!important;
}

.studio-dashboard,
.production-console{
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
}

.metric,
.printer-card,
.cards article,
.news article,
.gallery figure,
.contact-copy,
.contact-form.enhanced{
  border-radius:clamp(16px,2vw,24px)!important;
}

/* Kontaktformular */
.contact-layout{
  display:grid!important;
  grid-template-columns:minmax(260px,330px) minmax(0,1fr)!important;
  gap:clamp(22px,4vw,42px)!important;
}

.contact-form .form-row{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
}

/* Galerie */
.gallery img{
  height:clamp(190px,22vw,260px)!important;
  object-fit:cover!important;
}

/* Social Bar */
.socialbar{
  right:clamp(8px,1.6vw,18px)!important;
}

.socialbar a{
  font-size:clamp(9px,.8vw,11px)!important;
  padding:clamp(10px,1.2vw,14px) 8px!important;
}

/* Footer */
.footer-minimal{
  flex-wrap:wrap!important;
}

.footer-left{
  min-width:min(100%,320px);
}

.footer-links{
  margin-left:auto;
}

/* Laptop */
@media (max-width:1200px){
  :root{--page-width:1040px}
  .studio-dashboard,
  .production-console{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
}

/* Tablet */
@media (max-width:900px){
  :root{--side-space:18px}
  .header{
    position:sticky!important;
    top:10px!important;
    flex-wrap:wrap!important;
  }
  .nav{
    order:3;
    width:100%;
    justify-content:flex-start!important;
    overflow-x:auto;
    padding:6px 2px 2px;
    scrollbar-width:none;
  }
  .nav::-webkit-scrollbar{display:none}
  .btn.small{
    margin-left:auto;
  }
  .hero{
    grid-template-columns:1fr!important;
    text-align:left!important;
    padding-top:36px!important;
  }
  .hero-logo{
    order:-1;
    min-height:220px!important;
  }
  .hero-logo img{
    width:min(240px,70%)!important;
  }
  .section-head{
    grid-template-columns:1fr!important;
  }
  .cards,
  .gallery,
  .news,
  .admin-grid,
  .contact-layout{
    grid-template-columns:1fr!important;
  }
  .contact-form .form-row{
    grid-template-columns:1fr!important;
  }
  .socialbar{
    display:none!important;
  }
  .footer-minimal{
    align-items:flex-start!important;
    flex-direction:column!important;
  }
  .footer-links{
    margin-left:0;
  }
}

/* Mobile */
@media (max-width:640px){
  :root{--side-space:14px;--section-space:38px}
  .header{
    margin:10px auto!important;
    border-radius:18px!important;
  }
  .logo img,
  .header .logo img{
    height:36px!important;
  }
  .nav{
    gap:8px!important;
  }
  .nav a,
  .dropdown > a{
    font-size:12px!important;
    padding:9px 10px!important;
  }
  .dropdown-menu{
    position:absolute!important;
    min-width:170px!important;
  }
  .hero h1{
    font-size:clamp(30px,9vw,40px)!important;
  }
  .lead{
    font-size:15px!important;
  }
  .actions{
    flex-direction:column!important;
    align-items:stretch!important;
  }
  .actions .btn,
  .actions .link{
    width:100%;
    justify-content:center;
    text-align:center;
  }
  .hero-points{
    gap:8px!important;
  }
  .hero-points span{
    font-size:11px!important;
    padding:7px 10px!important;
  }
  .studio-dashboard,
  .production-console{
    grid-template-columns:1fr!important;
    padding:12px!important;
  }
  .metric{
    padding:18px!important;
  }
  .printer-card{
    min-height:auto!important;
    padding:18px!important;
  }
  .printer-head{
    flex-direction:column!important;
    align-items:flex-start!important;
  }
  .printer-meta{
    gap:8px!important;
  }
  .printer-meta span{
    font-size:11px!important;
  }
  .gallery img{
    height:210px!important;
  }
  .modal-card{
    inset:14px!important;
    width:auto!important;
    padding:24px!important;
  }
}

/* Sehr kleine Displays */
@media (max-width:420px){
  .header{
    padding:10px!important;
  }
  .btn,
  .btn.small{
    width:100%;
  }
  .header .btn.small{
    width:auto;
  }
  .footer-links{
    width:100%;
  }
  .footer-links button{
    flex:1;
  }
}


/* Korrektur: Druckerstatus Schriften & Ausrichtung */
#druckerpark .section-head{
  align-items:start!important;
}

#druckerpark .printer-cards{
  align-items:stretch!important;
}

#druckerpark .printer-card,
#printerStatusList .printer-card{
  display:flex!important;
  flex-direction:column!important;
  justify-content:space-between!important;
  gap:14px!important;
  text-align:left!important;
}

#druckerpark .printer-head,
#printerStatusList .printer-head{
  display:flex!important;
  align-items:flex-start!important;
  justify-content:space-between!important;
  gap:16px!important;
  margin-bottom:4px!important;
}

#druckerpark .printer-head > div,
#printerStatusList .printer-head > div{
  min-width:0!important;
  flex:1!important;
}

#druckerpark .unit-type,
#printerStatusList .unit-type{
  display:block!important;
  line-height:1.25!important;
  margin-bottom:7px!important;
  white-space:normal!important;
}

#druckerpark .printer-head h3,
#printerStatusList .printer-head h3{
  font-size:clamp(18px,1.6vw,22px)!important;
  line-height:1.18!important;
  margin:0!important;
  letter-spacing:-.02em!important;
  word-break:normal!important;
  overflow-wrap:anywhere!important;
}

#druckerpark .status-pill,
#printerStatusList .status-pill{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  flex:0 0 auto!important;
  line-height:1!important;
  min-width:max-content!important;
  margin-top:2px!important;
  font-size:12px!important;
  padding:8px 11px!important;
}

#druckerpark .printer-card p,
#printerStatusList .printer-card p{
  min-height:0!important;
  margin:0!important;
  color:#b8c1c6!important;
  font-size:14px!important;
  line-height:1.55!important;
  overflow-wrap:break-word!important;
}

#druckerpark .printer-meta,
#printerStatusList .printer-meta{
  display:flex!important;
  flex-wrap:wrap!important;
  gap:8px!important;
  margin:4px 0 0!important;
}

#druckerpark .printer-meta span,
#printerStatusList .printer-meta span{
  display:inline-flex!important;
  align-items:center!important;
  line-height:1.1!important;
  white-space:normal!important;
}

#druckerpark .load-row,
#printerStatusList .load-row{
  margin-top:auto!important;
  padding-top:8px!important;
}

#druckerpark .printer-footer,
#printerStatusList .printer-footer{
  align-items:center!important;
  line-height:1.25!important;
}

@media(max-width:640px){
  #druckerpark .printer-head,
  #printerStatusList .printer-head{
    flex-direction:row!important;
    align-items:flex-start!important;
  }

  #druckerpark .status-pill,
  #printerStatusList .status-pill{
    font-size:11px!important;
    padding:7px 9px!important;
  }

  #druckerpark .printer-head h3,
  #printerStatusList .printer-head h3{
    font-size:18px!important;
  }
}


/* FIX: Druckerstatus Dashboard oben sauber ausrichten */
#druckerpark .studio-dashboard,
#druckerpark .production-console{
  display:grid!important;
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
  align-items:stretch!important;
}

#druckerpark .metric{
  display:flex!important;
  flex-direction:column!important;
  justify-content:center!important;
  align-items:center!important;
  text-align:center!important;
  min-height:150px!important;
  padding:22px 18px!important;
}

#druckerpark .metric span{
  display:block!important;
  width:100%!important;
  margin:0 0 14px 0!important;
  font-size:12px!important;
  line-height:1.2!important;
  text-align:center!important;
}

#druckerpark .metric strong{
  display:block!important;
  width:100%!important;
  margin:0!important;
  font-size:clamp(26px,3vw,38px)!important;
  line-height:1.05!important;
  text-align:center!important;
  white-space:normal!important;
  word-break:normal!important;
}

#druckerpark .metric small{
  display:block!important;
  width:100%!important;
  margin:10px 0 0 0!important;
  font-size:12px!important;
  line-height:1.25!important;
  text-align:center!important;
  color:#9aa3a9!important;
}

#druckerpark .metric strong + small{
  margin-top:10px!important;
}

/* Speziell lange Texte wie PLA · PETG · TPU sauber umbrechen */
#druckerpark .metric:nth-child(4) strong{
  font-size:clamp(22px,2.2vw,32px)!important;
  line-height:1.15!important;
}

/* Druckerkarten: Kapazität und Live Status nicht zusammenkleben */
#printerStatusList .load-row{
  display:flex!important;
  justify-content:space-between!important;
  align-items:center!important;
  gap:12px!important;
  font-size:12px!important;
  line-height:1.25!important;
}

#printerStatusList .load-row span,
#printerStatusList .load-row strong{
  display:block!important;
}

#printerStatusList .progress{
  margin:10px 0 0!important;
}

#printerStatusList .printer-footer{
  display:flex!important;
  justify-content:space-between!important;
  gap:10px!important;
  flex-wrap:wrap!important;
  margin-top:12px!important;
}

/* Laptop / Tablet */
@media(max-width:1200px){
  #druckerpark .studio-dashboard,
  #druckerpark .production-console{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
  }
}

/* Mobile */
@media(max-width:640px){
  #druckerpark .studio-dashboard,
  #druckerpark .production-console{
    grid-template-columns:1fr!important;
  }

  #druckerpark .metric{
    min-height:120px!important;
  }

  #druckerpark .metric strong{
    font-size:30px!important;
  }
}

#printerStatusList .load-row{display:none!important;}


/* Sticky Header + Mobile Klappmenü */
.header{
  position:fixed!important;
  top:14px!important;
  left:50%!important;
  transform:translateX(-50%)!important;
  z-index:1000!important;
  margin:0!important;
  backdrop-filter:blur(18px)!important;
  -webkit-backdrop-filter:blur(18px)!important;
}

body{
  padding-top:96px!important;
}

.mobile-menu-toggle{
  display:none;
  width:44px;
  height:44px;
  border:1px solid rgba(168,255,0,.28);
  border-radius:14px;
  background:rgba(13,17,20,.92);
  cursor:pointer;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
  padding:0;
}

.mobile-menu-toggle span{
  display:block;
  width:22px;
  height:2px;
  border-radius:999px;
  background:#a8ff00;
  transition:.25s ease;
  box-shadow:0 0 10px rgba(168,255,0,.35);
}

.mobile-menu-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.mobile-menu-toggle.open span:nth-child(2){opacity:0}
.mobile-menu-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(min-width:901px){
  .nav{display:flex!important}
}

@media(max-width:900px){
  body{padding-top:86px!important}

  .header{
    top:10px!important;
    display:grid!important;
    grid-template-columns:auto 1fr auto!important;
    align-items:center!important;
    gap:12px!important;
  }

  .mobile-menu-toggle{
    display:flex!important;
    grid-column:3;
  }

  .header .btn.small{display:none!important}

  .nav{
    grid-column:1 / -1!important;
    width:100%!important;
    display:none!important;
    flex-direction:column!important;
    align-items:stretch!important;
    justify-content:flex-start!important;
    gap:8px!important;
    overflow:visible!important;
    padding:14px 0 2px!important;
    animation:mobileMenuDrop .22s ease both;
  }

  .nav.open{display:flex!important}

  .nav a,
  .dropdown > a{
    width:100%!important;
    display:flex!important;
    justify-content:space-between!important;
    align-items:center!important;
    padding:13px 14px!important;
    border-radius:14px!important;
    background:rgba(255,255,255,.035)!important;
    border:1px solid rgba(255,255,255,.06)!important;
  }

  .dropdown{width:100%!important}

  .dropdown-menu{
    position:static!important;
    display:none!important;
    width:100%!important;
    min-width:0!important;
    margin-top:8px!important;
    padding:8px!important;
    background:rgba(0,0,0,.22)!important;
    border-radius:14px!important;
  }

  .dropdown:hover .dropdown-menu,
  .dropdown:focus-within .dropdown-menu{
    display:block!important;
  }

  .dropdown-menu a{
    margin-bottom:6px!important;
    background:rgba(168,255,0,.06)!important;
  }
}

@media(max-width:520px){
  body{padding-top:78px!important}

  .header{
    width:calc(100% - 20px)!important;
    border-radius:16px!important;
    padding:10px!important;
  }

  .mobile-menu-toggle{
    width:40px;
    height:40px;
  }
}

@keyframes mobileMenuDrop{
  from{opacity:0;transform:translateY(-8px)}
  to{opacity:1;transform:translateY(0)}
}

/* FAQ im 3D Studio */
.faq-section .faq-list{
  display:grid;
  gap:14px;
  max-width:920px;
  margin-left:auto;
}
.faq-item{
  border:1px solid rgba(168,255,0,.16);
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.018));
  border-radius:18px;
  overflow:hidden;
}
.faq-item summary{
  cursor:pointer;
  padding:20px 22px;
  font-weight:900;
  color:#f3f5f5;
  list-style:none;
  display:flex;
  justify-content:space-between;
  gap:18px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:after{
  content:"+";
  color:#a8ff00;
  font-size:22px;
  line-height:1;
}
.faq-item[open] summary:after{content:"–"}
.faq-item div{
  padding:0 22px 22px;
  color:#b9c0c5;
  line-height:1.65;
}
.faq-item div b,.faq-item div strong{color:#fff}
.faq-item div a{color:#a8ff00}
@media(max-width:900px){
  .faq-section .faq-list{margin-left:0}
}


/* Menü oben rechts ausrichten */
.header{justify-content:flex-end!important}
.header .logo{margin-right:auto!important}
.nav{margin-left:auto!important;justify-content:flex-end!important}
.header .btn.small{margin-left:18px!important}

/* Professionelle Galerie */
.gallery-intro{max-width:760px;margin:0 0 28px auto;color:#b9c0c5;line-height:1.65}
.gallery-pro{display:grid!important;grid-template-columns:repeat(auto-fit,minmax(min(100%,280px),1fr))!important;gap:18px!important}
.gallery-card{position:relative;min-height:280px;border-radius:24px!important;overflow:hidden;cursor:pointer;background:#0d1114;border:1px solid rgba(168,255,0,.14)!important;box-shadow:0 20px 60px rgba(0,0,0,.28);transition:.32s ease}
.gallery-card:hover{transform:translateY(-6px) scale(1.01);border-color:rgba(168,255,0,.38)!important;box-shadow:0 28px 80px rgba(0,0,0,.4),0 0 35px rgba(168,255,0,.12)}
.gallery-card img{height:100%!important;min-height:280px;width:100%;object-fit:cover;filter:saturate(.95) contrast(1.08) brightness(.82);transition:.35s ease}
.gallery-card:hover img{transform:scale(1.06);filter:saturate(1.05) contrast(1.12) brightness(.92)}
.gallery-card figcaption{position:absolute;left:0;right:0;bottom:0;padding:70px 22px 22px!important;background:linear-gradient(transparent,rgba(0,0,0,.86));color:#fff!important}
.gallery-card figcaption strong{display:block;color:#fff;font-size:18px}
.gallery-card figcaption small{color:#c7ced2!important;font-size:13px;line-height:1.45}
.gallery-lightbox{position:fixed;inset:0;z-index:2000;display:none;align-items:center;justify-content:center;padding:28px;background:rgba(0,0,0,.82);backdrop-filter:blur(12px)}
.gallery-lightbox.open{display:flex}
.gallery-lightbox img{max-width:min(980px,88vw);max-height:78vh;object-fit:contain;border-radius:22px;border:1px solid rgba(168,255,0,.2);box-shadow:0 30px 100px rgba(0,0,0,.6)}
.gallery-lightbox div{position:absolute;left:50%;bottom:28px;transform:translateX(-50%);width:min(760px,90%);padding:18px 22px;border-radius:18px;background:rgba(10,14,16,.86);border:1px solid rgba(255,255,255,.08);text-align:center}
.gallery-lightbox h3{margin:0 0 6px}
.gallery-lightbox p{margin:0;color:#b9c0c5}
.gallery-lightbox-close{position:absolute;top:22px;right:22px;width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.16);background:#0d1114;color:#fff;font-size:28px;cursor:pointer}

/* FAQ */
.faq-section .faq-list{display:grid;gap:14px;max-width:920px;margin-left:auto}
.faq-item{border:1px solid rgba(168,255,0,.16);background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.018));border-radius:18px;overflow:hidden}
.faq-item summary{cursor:pointer;padding:20px 22px;font-weight:900;color:#f3f5f5;list-style:none;display:flex;justify-content:space-between;gap:18px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:after{content:"+";color:#a8ff00;font-size:22px;line-height:1}
.faq-item[open] summary:after{content:"–"}
.faq-item div{padding:0 22px 22px;color:#b9c0c5;line-height:1.65}
.faq-item div strong,.faq-item div b{color:#fff}

@media(max-width:900px){
  .header{justify-content:space-between!important}
  .nav{margin-left:0!important;justify-content:flex-start!important}
  .gallery-intro,.faq-section .faq-list{margin-left:0}
}


/* FIX: Menü konsequent rechts oben */
.header{
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:18px!important;
}
.header .logo{
  margin-right:auto!important;
  flex:0 0 auto!important;
}
.mobile-menu-toggle{
  order:3!important;
}
.nav{
  margin-left:auto!important;
  justify-content:flex-end!important;
  align-items:center!important;
}
.header .btn.small{
  margin-left:10px!important;
  flex:0 0 auto!important;
}

/* FAQ professionell */
.faq-section .section-head{
  margin-bottom:18px!important;
}
.faq-intro{
  max-width:760px;
  margin:0 0 28px auto;
  color:#b9c0c5;
  line-height:1.7;
  font-size:16px;
}
.faq-section .faq-list{
  display:grid!important;
  gap:14px!important;
  max-width:920px!important;
  margin-left:auto!important;
}
.faq-item{
  position:relative;
  border:1px solid rgba(168,255,0,.18)!important;
  background:
    radial-gradient(circle at 96% 0%,rgba(168,255,0,.08),transparent 28%),
    linear-gradient(180deg,rgba(255,255,255,.052),rgba(255,255,255,.018))!important;
  border-radius:20px!important;
  overflow:hidden!important;
  box-shadow:0 18px 50px rgba(0,0,0,.22);
  transition:.25s ease;
}
.faq-item:hover{
  transform:translateY(-2px);
  border-color:rgba(168,255,0,.34)!important;
}
.faq-item summary{
  cursor:pointer!important;
  padding:22px 24px!important;
  font-weight:900!important;
  color:#f3f5f5!important;
  list-style:none!important;
  display:flex!important;
  justify-content:space-between!important;
  align-items:center!important;
  gap:18px!important;
  font-size:clamp(16px,1.4vw,19px)!important;
  line-height:1.35!important;
}
.faq-item summary::-webkit-details-marker{display:none!important}
.faq-item summary:after{
  content:"+";
  display:grid;
  place-items:center;
  flex:0 0 34px;
  width:34px;
  height:34px;
  border-radius:50%;
  color:#071006;
  background:#a8ff00;
  font-size:22px;
  line-height:1;
  box-shadow:0 0 22px rgba(168,255,0,.25);
}
.faq-item[open] summary:after{content:"–"}
.faq-item div{
  padding:0 24px 24px!important;
  color:#b9c0c5!important;
  line-height:1.7!important;
  font-size:15px!important;
}
.faq-item div strong,.faq-item div b{
  color:#fff!important;
}
.faq-item div span[style]{
  font-weight:700;
}

/* Mobile Menü bleibt aufklappbar und sauber */
@media(max-width:900px){
  .header{
    justify-content:space-between!important;
    display:grid!important;
    grid-template-columns:auto 1fr auto!important;
  }
  .header .logo{
    margin-right:0!important;
  }
  .nav{
    margin-left:0!important;
    justify-content:flex-start!important;
  }
  .faq-intro,
  .faq-section .faq-list{
    margin-left:0!important;
  }
}


/* ===== KS3D Professional Cleanup & Legal Footer ===== */
:root{
  --ks-bg:#07090b;
  --ks-surface:#0d1114;
  --ks-border:#20262b;
  --ks-text:#f3f5f5;
  --ks-muted:#aeb7bd;
  --ks-green:#a8ff00;
  --ks-shadow:0 24px 70px rgba(0,0,0,.34);
}
body{background:radial-gradient(circle at 18% 8%,rgba(168,255,0,.12),transparent 26%),radial-gradient(circle at 88% 12%,rgba(255,255,255,.06),transparent 22%),var(--ks-bg)!important;color:var(--ks-text)!important}
.section{scroll-margin-top:120px}
.header{border-color:rgba(168,255,0,.22)!important;background:rgba(8,11,13,.9)!important;box-shadow:0 20px 70px rgba(0,0,0,.45),0 0 34px rgba(168,255,0,.08)!important}
.nav a,.dropdown>a{font-weight:800!important}.nav a:hover,.nav a.is-active,.dropdown:hover>a{color:var(--ks-green)!important}
.btn{background:linear-gradient(135deg,#a8ff00,#75c800)!important;color:#071006!important;box-shadow:0 0 26px rgba(168,255,0,.22)}
.cards article,.news article,.printer-card,.gallery-card,.faq-item,.contact-form.enhanced,.contact-copy{background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.018))!important;border:1px solid rgba(255,255,255,.08)!important;box-shadow:var(--ks-shadow)}
.site-footer{width:min(1180px,calc(100% - 32px));margin:50px auto 34px;border-top:1px solid var(--ks-border);padding-top:28px;color:var(--ks-muted)}
.footer-main{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:28px;align-items:start}
.footer-brand img{height:42px;margin-bottom:14px}.footer-brand p{max-width:420px;margin:0 0 8px}.footer-brand a,.footer-group a{color:var(--ks-green);text-decoration:none}
.footer-group{display:grid;gap:9px}.footer-group h3{margin:0 0 8px;color:var(--ks-text);font-size:14px;text-transform:uppercase;letter-spacing:.12em}
.footer-group button{justify-self:start;border:1px solid var(--ks-border);background:var(--ks-surface);color:var(--ks-text);border-radius:999px;padding:10px 14px;cursor:pointer;font:inherit;font-weight:800}
.footer-group button:hover{background:var(--ks-green);border-color:var(--ks-green);color:#071006}
.footer-bottom{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;border-top:1px solid var(--ks-border);margin-top:26px;padding-top:16px;font-size:13px}
.modal{position:fixed;inset:0;z-index:3000;display:none}.modal.open{display:block}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(10px)}
.modal-card{position:absolute;right:24px;top:24px;bottom:24px;width:min(680px,calc(100% - 48px));overflow:auto;border:1px solid rgba(168,255,0,.18);border-radius:26px;background:#0b0f12;color:var(--ks-text);padding:34px;box-shadow:0 30px 100px rgba(0,0,0,.58)}
.legal-card h2{margin:0 0 24px;font-size:34px}.legal-card h3{margin:24px 0 8px;color:#fff;font-size:16px}.legal-card p,.legal-card li{color:#b9c0c5;line-height:1.65}.legal-card a{color:var(--ks-green)}
.modal-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border:1px solid var(--ks-border);border-radius:50%;background:#11161a;color:#fff;font-size:24px;cursor:pointer}
.faq-intro{color:var(--ks-muted)}.faq-item[open]{border-color:rgba(168,255,0,.35)!important}
@media(max-width:900px){.footer-main{grid-template-columns:1fr}.modal-card{left:16px;right:16px;top:16px;bottom:16px;width:auto;padding:26px}.footer-bottom{flex-direction:column}}

.footer-minimal{
 max-width:1180px;
 margin:20px auto 30px;
 padding-top:12px;
 border-top:1px solid rgba(255,255,255,.08);
 text-align:center;
}
.footer-links{
 display:flex;
 justify-content:center;
 gap:12px;
}
.footer-links button{
 background:transparent;
 border:1px solid rgba(255,255,255,.12);
 color:#b9c0c5;
 padding:8px 14px;
 border-radius:999px;
 cursor:pointer;
}
.footer-links button:hover{
 color:#fff;
 border-color:#a8ff00;
}
.legal-modal{
 display:none;
 position:fixed;
 inset:0;
 background:rgba(0,0,0,.75);
 z-index:3000;
}
.legal-modal.open{display:grid;place-items:center}
.legal-box{
 width:min(700px,92vw);
 max-height:80vh;
 overflow:auto;
 background:#0d1114;
 border-radius:20px;
 padding:24px;
 color:#fff;
}
.legal-box button{
 float:right;
}


/* ==========================================================
   KS3D Modern Studio Design
   Clean · Premium · Dark · Studio UI
   ========================================================== */

:root{
  --bg:#050607;
  --surface:rgba(13,17,20,.72);
  --surface-solid:#0d1114;
  --surface-soft:#12181d;
  --line:rgba(255,255,255,.08);
  --line-strong:rgba(168,255,0,.22);
  --text:#f4f7f7;
  --muted:#a9b2b8;
  --green:#a8ff00;
  --green-soft:rgba(168,255,0,.12);
  --radius:28px;
  --shadow:0 30px 90px rgba(0,0,0,.42);
}

*{
  box-sizing:border-box;
}

body{
  background:
    radial-gradient(circle at 15% 8%,rgba(168,255,0,.14),transparent 25%),
    radial-gradient(circle at 82% 12%,rgba(255,255,255,.08),transparent 22%),
    linear-gradient(180deg,#07090b,#040506 70%)!important;
  color:var(--text)!important;
  font-family:Inter,Arial,Helvetica,sans-serif!important;
  letter-spacing:-.01em;
}

/* Subtiler Studio-Grid Hintergrund */
body:before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.024) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.024) 1px,transparent 1px);
  background-size:42px 42px;
  mask-image:linear-gradient(to bottom,black,transparent 78%);
}

/* Premium Header */
.header{
  width:min(1180px,calc(100% - 32px))!important;
  top:16px!important;
  border-radius:24px!important;
  border:1px solid var(--line-strong)!important;
  background:rgba(8,10,12,.78)!important;
  backdrop-filter:blur(22px)!important;
  -webkit-backdrop-filter:blur(22px)!important;
  box-shadow:
    0 22px 70px rgba(0,0,0,.48),
    inset 0 1px 0 rgba(255,255,255,.08),
    0 0 34px rgba(168,255,0,.09)!important;
}

.header:after{
  content:"";
  position:absolute;
  left:24px;
  right:24px;
  bottom:-1px;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--green),transparent);
  opacity:.65;
}

.logo img{
  filter:drop-shadow(0 0 12px rgba(168,255,0,.22));
}

.nav{
  gap:8px!important;
}

.nav a,
.dropdown > a{
  padding:11px 14px!important;
  border-radius:999px!important;
  color:#cbd2d6!important;
  text-decoration:none!important;
  transition:.22s ease!important;
}

.nav a:hover,
.nav a.is-active,
.dropdown:hover > a{
  color:#071006!important;
  background:var(--green)!important;
  transform:translateY(-1px);
}

.dropdown-menu{
  border-radius:18px!important;
  background:rgba(8,10,12,.96)!important;
  border:1px solid var(--line-strong)!important;
  padding:10px!important;
  box-shadow:0 22px 70px rgba(0,0,0,.52)!important;
}

.dropdown-menu a{
  border-radius:12px!important;
}

/* Hero: Studio Landing Look */
.hero{
  min-height:calc(100vh - 130px)!important;
  align-items:center!important;
  border-bottom:0!important;
  position:relative;
}

.hero:after{
  content:"";
  position:absolute;
  inset:38px 0 auto 0;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(168,255,0,.45),transparent);
}

.eyebrow{
  color:var(--green)!important;
  letter-spacing:.18em!important;
}

.hero h1{
  max-width:820px!important;
  font-size:clamp(40px,6vw,82px)!important;
  line-height:.96!important;
  letter-spacing:-.065em!important;
}

.lead{
  max-width:650px!important;
  color:var(--muted)!important;
  font-size:clamp(16px,1.3vw,19px)!important;
  line-height:1.72!important;
}

.hero-points span,
.studio-stats span{
  background:rgba(255,255,255,.04)!important;
  border:1px solid var(--line)!important;
  color:#dce2e4!important;
  backdrop-filter:blur(14px);
}

.studio-stats{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:26px;
}

.studio-stats span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border-radius:999px;
  padding:10px 14px;
  font-size:13px;
  color:#dce2e4;
}

.studio-stats strong{
  color:var(--green);
}

.hero-logo{
  border-radius:34px!important;
  border:1px solid var(--line)!important;
  background:
    linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.015)),
    radial-gradient(circle at 50% 44%,rgba(168,255,0,.18),transparent 58%)!important;
  box-shadow:
    var(--shadow),
    inset 0 1px 0 rgba(255,255,255,.08)!important;
}

/* Sections als moderne Studio-Flächen */
.section{
  padding:clamp(56px,7vw,92px) 0!important;
  border-bottom:1px solid rgba(255,255,255,.06)!important;
}

.section-head{
  align-items:start!important;
}

.section h2,
.section-head h2{
  letter-spacing:-.045em!important;
}

.cards article,
.news article,
.contact-copy,
.contact-form.enhanced,
.printer-card,
.gallery-card,
.faq-item,
.metric{
  border-radius:var(--radius)!important;
  background:
    linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.018))!important;
  border:1px solid var(--line)!important;
  box-shadow:var(--shadow)!important;
  backdrop-filter:blur(16px);
}

.cards article:hover,
.news article:hover,
.faq-item:hover,
.gallery-card:hover,
.printer-card:hover{
  border-color:var(--line-strong)!important;
  transform:translateY(-4px);
}

/* Production Center optisch ruhiger */
.production-console{
  border-radius:30px!important;
  border:1px solid var(--line-strong)!important;
  background:
    radial-gradient(circle at 20% 0%,rgba(168,255,0,.10),transparent 34%),
    rgba(255,255,255,.025)!important;
}

.metric{
  text-align:center!important;
}

.metric strong{
  color:var(--green)!important;
}

/* Galerie modern */
.gallery-card{
  min-height:320px!important;
}

.gallery-card img{
  min-height:320px!important;
}

.gallery-card figcaption{
  backdrop-filter:blur(8px);
}

/* FAQ klarer */
.faq-intro{
  margin-left:auto!important;
  color:var(--muted)!important;
}

.faq-item summary{
  font-size:clamp(16px,1.3vw,19px)!important;
}

.faq-item[open]{
  border-color:var(--line-strong)!important;
}

/* Kontakt modern */
.contact-layout{
  align-items:stretch!important;
}

.contact-copy,
.contact-form.enhanced{
  height:100%;
}

.contact-form.enhanced input,
.contact-form.enhanced select,
.contact-form.enhanced textarea{
  border-radius:16px!important;
  border:1px solid rgba(255,255,255,.10)!important;
  background:rgba(5,7,8,.72)!important;
}

.contact-form.enhanced input:focus,
.contact-form.enhanced select:focus,
.contact-form.enhanced textarea:focus{
  border-color:var(--green)!important;
  box-shadow:0 0 0 3px rgba(168,255,0,.12)!important;
}

/* Kompakter Footer wie vorher, aber sauber */
.footer-minimal{
  width:min(1180px,calc(100% - 32px))!important;
  margin:34px auto 34px!important;
  padding-top:18px!important;
  border-top:1px solid rgba(255,255,255,.08)!important;
}

.footer-links button{
  background:rgba(255,255,255,.035)!important;
  border:1px solid rgba(255,255,255,.10)!important;
  color:#cbd2d6!important;
  border-radius:999px!important;
  font-weight:800!important;
}

.footer-links button:hover{
  color:#071006!important;
  background:var(--green)!important;
  border-color:var(--green)!important;
}

/* Mobile Studio */
@media(max-width:900px){
  .hero{
    min-height:auto!important;
  }

  .header{
    top:10px!important;
    border-radius:20px!important;
  }

  .nav a,
  .dropdown > a{
    border-radius:14px!important;
    background:rgba(255,255,255,.035)!important;
    color:#e8eeee!important;
  }

  .nav a:hover,
  .nav a.is-active,
  .dropdown:hover > a{
    background:rgba(168,255,0,.16)!important;
    color:var(--green)!important;
  }

  .hero-logo{
    min-height:230px!important;
  }

  .studio-stats{
    display:grid;
    grid-template-columns:1fr;
  }

  .gallery-card,
  .gallery-card img{
    min-height:260px!important;
  }
}

@media(max-width:520px){
  .hero h1{
    font-size:clamp(34px,10vw,46px)!important;
  }

  .section{
    padding:44px 0!important;
  }
}

/* Final legal modal + CTA fix */
.footer-minimal{
  width:min(1180px,calc(100% - 32px))!important;
  margin:34px auto!important;
  padding-top:18px!important;
  border-top:1px solid rgba(255,255,255,.08)!important;
  text-align:center!important;
}
.footer-links{
  display:flex!important;
  justify-content:center!important;
  gap:12px!important;
  flex-wrap:wrap!important;
}
.footer-links button{
  background:rgba(255,255,255,.035)!important;
  border:1px solid rgba(255,255,255,.12)!important;
  color:#cbd2d6!important;
  padding:9px 15px!important;
  border-radius:999px!important;
  font-weight:800!important;
  cursor:pointer!important;
}
.footer-links button:hover{
  background:#a8ff00!important;
  border-color:#a8ff00!important;
  color:#071006!important;
}
.legal-modal{
  display:none;
  position:fixed;
  inset:0;
  z-index:4000;
  background:rgba(0,0,0,.78);
  backdrop-filter:blur(10px);
  padding:24px;
}
.legal-modal.open{
  display:grid;
  place-items:center;
}
.legal-box{
  width:min(760px,94vw);
  max-height:84vh;
  overflow:auto;
  background:#0d1114;
  border:1px solid rgba(168,255,0,.2);
  border-radius:24px;
  padding:30px;
  color:#f3f5f5;
  box-shadow:0 30px 100px rgba(0,0,0,.6);
}
.legal-box h2{margin-top:0;font-size:32px}
.legal-box h3{margin-top:24px;color:#fff}
.legal-box p,.legal-box li{color:#b9c0c5;line-height:1.65}
.legal-box a{color:#a8ff00}
.legal-close{
  float:right;
  width:40px;
  height:40px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.12);
  background:#11161a;
  color:#fff;
  font-size:24px;
  cursor:pointer;
}
.actions a[data-section]{
  cursor:pointer;
}

/* Einheitliche Bereichsanzeige: keine separaten Seiten, nur aktiver Bereich sichtbar */
.view-section{display:none!important}
.view-section.active{display:block!important;animation:ks3dSectionFade .24s ease both}
.hero.view-section.active{display:grid!important}
.nav a.is-active,
.dropdown > a.is-active{color:#a8ff00!important}
@keyframes ks3dSectionFade{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}
body{min-height:100vh}
main{min-height:calc(100vh - 180px)}

/* Hero bleibt sichtbar, Inhalte öffnen darunter */
.hero-persistent{
  display:grid!important;
}

.view-section{
  display:none!important;
}

.view-section.active{
  display:block!important;
  animation:ks3dContentReveal .28s ease both;
}

main::after{
  content:"";
  display:block;
  height:1px;
}

.view-section.active{
  position:relative;
}

.view-section.active:before{
  content:"";
  display:block;
  height:1px;
  width:100%;
  margin-bottom:0;
  background:linear-gradient(90deg,transparent,rgba(168,255,0,.25),transparent);
}

@keyframes ks3dContentReveal{
  from{opacity:0;transform:translateY(14px)}
  to{opacity:1;transform:translateY(0)}
}

.nav a.is-active,
.dropdown a.is-active{
  color:#a8ff00!important;
}

/* Unter-Hero-Bereich optisch wie ein Studio-Panel */
.view-section.active{
  margin-top:clamp(18px,3vw,34px)!important;
  padding-top:clamp(42px,6vw,72px)!important;
}

/* Hero Buttons wirken als Inhalts-Tabs */
.actions a[data-section]{
  cursor:pointer;
}


/* Galerie als Vorschau-Grid */
.gallery-pro{
  display:grid!important;
  grid-template-columns:repeat(auto-fill,minmax(180px,1fr))!important;
  gap:16px!important;
}

.gallery-card{
  min-height:auto!important;
  height:180px!important;
  border-radius:18px!important;
  overflow:hidden!important;
  cursor:pointer!important;
}

.gallery-card img{
  width:100%!important;
  height:180px!important;
  min-height:180px!important;
  object-fit:cover!important;
}

.gallery-card figcaption{
  padding:12px!important;
  background:linear-gradient(transparent,rgba(0,0,0,.9))!important;
}

.gallery-card figcaption small{
  display:none!important;
}

/* Lightbox bleibt groß */
.gallery-lightbox img{
  max-width:min(1200px,92vw)!important;
  max-height:85vh!important;
}

@media(max-width:768px){
  .gallery-pro{
    grid-template-columns:repeat(2,1fr)!important;
  }
  .gallery-card,
  .gallery-card img{
    height:140px!important;
    min-height:140px!important;
  }
}

/* KS3D Compact Modern UI Update */
:root{--compact-green:#a8ff00;--compact-bg:#060708;--compact-panel:rgba(12,15,18,.78);--compact-line:rgba(255,255,255,.08);--compact-muted:#aeb7bd}
body{font-size:15px!important}
main{width:min(1080px,calc(100% - 28px))!important}
.header{width:min(1080px,calc(100% - 24px))!important;min-height:58px!important;padding:8px 12px!important;border-radius:18px!important;gap:10px!important;background:rgba(7,9,11,.88)!important;border:1px solid rgba(168,255,0,.24)!important;box-shadow:0 14px 44px rgba(0,0,0,.42),0 0 22px rgba(168,255,0,.08)!important}
.header:after{display:none!important}
.logo img,.header .logo img{height:38px!important}
.nav{gap:5px!important}
.nav a,.dropdown>a{color:#ecf2f2!important;background:transparent!important;padding:8px 11px!important;border-radius:12px!important;font-size:12px!important;line-height:1.1!important;font-weight:850!important;text-decoration:none!important;text-shadow:none!important}
.nav a:hover,.nav a.is-active,.dropdown:hover>a,.dropdown>a:hover{color:#071006!important;background:var(--compact-green)!important;box-shadow:0 0 18px rgba(168,255,0,.22)!important}
.nav a:after,.dropdown>a:after{display:none!important}
.dropdown-menu{top:calc(100% + 8px)!important;min-width:170px!important;padding:8px!important;border-radius:14px!important;background:rgba(7,9,11,.98)!important;border:1px solid rgba(168,255,0,.22)!important}
.dropdown-menu a{color:#eaf0f0!important;background:transparent!important;padding:10px 11px!important;border-radius:10px!important}
.dropdown-menu a:hover,.dropdown-menu a.is-active{color:#071006!important;background:var(--compact-green)!important}
.header .btn.small,.btn.small{min-height:36px!important;padding:8px 13px!important;font-size:12px!important;border-radius:12px!important}
.hero{min-height:520px!important;padding:38px 0 44px!important;gap:34px!important}
.hero h1{font-size:clamp(34px,4.6vw,62px)!important;line-height:.98!important;max-width:700px!important}
.lead,.hero p{font-size:15px!important;line-height:1.6!important;max-width:590px!important}
.hero-points,.studio-stats{gap:8px!important;margin-top:16px!important}
.hero-points span,.studio-stats span{padding:7px 10px!important;font-size:11px!important;border-radius:999px!important}
.actions{margin-top:20px!important;gap:10px!important}
.actions .btn{min-height:40px!important;padding:10px 16px!important;font-size:12px!important}
.actions .link{min-height:40px!important;display:inline-flex!important;align-items:center!important;padding:0 12px!important;border:1px solid rgba(255,255,255,.1)!important;border-radius:999px!important;text-decoration:none!important}
.actions .link:hover{color:#071006!important;background:var(--compact-green)!important;border-color:var(--compact-green)!important}
.hero-logo{min-height:240px!important;border-radius:24px!important}
.hero-logo img{width:min(230px,70%)!important}
.section{padding:clamp(34px,5vw,58px) 0!important}
.view-section.active{margin-top:12px!important;padding-top:34px!important}
.section-head{gap:18px!important;margin-bottom:20px!important}
.section h2,.section-head h2{font-size:clamp(26px,3vw,38px)!important}
.cards,.news,.gallery-pro,.printer-cards,.studio-dashboard,.production-console{gap:12px!important}
.cards article,.news article,.printer-card,.faq-item,.contact-copy,.contact-form.enhanced,.metric{border-radius:18px!important;padding:18px!important;box-shadow:0 14px 38px rgba(0,0,0,.28)!important}
.production-console{padding:12px!important;border-radius:20px!important}
.metric{min-height:110px!important}
.metric span{font-size:10px!important;margin-bottom:8px!important}
.metric strong{font-size:clamp(20px,2vw,28px)!important}
.printer-card{min-height:auto!important}
.printer-head h3{font-size:17px!important}
.printer-card p{font-size:13px!important;line-height:1.45!important}
.printer-meta span{font-size:10px!important;padding:6px 9px!important}
.printer-footer{font-size:11px!important;margin-top:10px!important}
.gallery-pro{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))!important}
.gallery-card{height:150px!important;min-height:150px!important;border-radius:16px!important}
.gallery-card img{height:150px!important;min-height:150px!important}
.gallery-card figcaption{padding:38px 10px 10px!important}
.gallery-card figcaption strong{font-size:13px!important}
.faq-intro{font-size:14px!important;margin-bottom:18px!important}
.faq-item summary{padding:15px 16px!important;font-size:15px!important}
.faq-item summary:after{width:28px!important;height:28px!important;font-size:18px!important}
.faq-item div{padding:0 16px 16px!important;font-size:13px!important}
.contact-layout{gap:20px!important}
.contact-copy h3{font-size:18px!important}
.contact-copy p{font-size:13px!important}
.contact-form.enhanced{padding:18px!important}
.contact-form.enhanced input,.contact-form.enhanced select,.contact-form.enhanced textarea{padding:11px 12px!important;border-radius:12px!important;font-size:13px!important}
.footer-minimal{margin:20px auto 24px!important;padding-top:12px!important}
.footer-links button{padding:7px 12px!important;font-size:12px!important}
@media(max-width:900px){body{padding-top:74px!important}.header{width:calc(100% - 18px)!important;top:8px!important;border-radius:16px!important;padding:8px!important}.mobile-menu-toggle{width:38px!important;height:38px!important;border-radius:12px!important}.nav{padding-top:10px!important;gap:6px!important}.nav a,.dropdown>a{padding:11px 12px!important;color:#f4f8f8!important;background:rgba(255,255,255,.045)!important}.nav a:hover,.nav a.is-active,.dropdown:hover>a{color:#071006!important;background:var(--compact-green)!important}.hero{padding:26px 0 34px!important}.hero-logo{min-height:185px!important}.hero-logo img{width:min(190px,65%)!important}.studio-stats{grid-template-columns:1fr!important}.gallery-pro{grid-template-columns:repeat(2,1fr)!important}.gallery-card,.gallery-card img{height:125px!important;min-height:125px!important}}
@media(max-width:520px){main{width:calc(100% - 22px)!important}.hero h1{font-size:32px!important}.lead{font-size:14px!important}.section h2,.section-head h2{font-size:26px!important}}


/* KS3D Social Media Bar - Links & Sticky */
.social-sidebar,
.social-floating,
.social-links{
    position:fixed !important;
    left:18px !important;
    right:auto !important;
    top:50% !important;
    transform:translateY(-50%) !important;
    z-index:2500 !important;
    display:flex !important;
    flex-direction:column !important;
    gap:12px !important;
}

.social-sidebar a,
.social-floating a,
.social-links a{
    width:52px !important;
    height:52px !important;
    border-radius:16px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    background:rgba(13,17,20,.88) !important;
    border:1px solid rgba(168,255,0,.18) !important;
    backdrop-filter:blur(12px);
    box-shadow:0 10px 30px rgba(0,0,0,.35);
    transition:.25s ease;
}

.social-sidebar a:hover,
.social-floating a:hover,
.social-links a:hover{
    transform:translateX(6px) scale(1.08);
    background:#a8ff00 !important;
}

.social-sidebar a img,
.social-floating a img,
.social-links a img{
    width:24px !important;
    height:24px !important;
}

@media(max-width:768px){
    .social-sidebar,
    .social-floating,
    .social-links{
        left:10px !important;
        gap:8px !important;
    }

    .social-sidebar a,
    .social-floating a,
    .social-links a{
        width:44px !important;
        height:44px !important;
        border-radius:12px !important;
    }
}


/* Brand-Hover & Tooltips für linke Social-Leiste */
.social-sidebar a,
.social-floating a,
.social-links a{
  position:relative!important;
  overflow:visible!important;
  color:#fff!important;
}

.social-sidebar a::after,
.social-floating a::after,
.social-links a::after{
  content:attr(data-label);
  position:absolute;
  left:62px;
  top:50%;
  transform:translateY(-50%) translateX(-8px);
  opacity:0;
  pointer-events:none;
  white-space:nowrap;
  background:rgba(7,9,11,.94);
  color:#f3f5f5;
  border:1px solid rgba(168,255,0,.24);
  border-radius:999px;
  padding:9px 13px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.02em;
  box-shadow:0 16px 40px rgba(0,0,0,.35);
  transition:.25s ease;
}

.social-sidebar a:hover::after,
.social-floating a:hover::after,
.social-links a:hover::after{
  opacity:1;
  transform:translateY(-50%) translateX(0);
}

/* Instagram */
.social-sidebar a[href*="instagram"]:hover,
.social-floating a[href*="instagram"]:hover,
.social-links a[href*="instagram"]:hover{
  background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045)!important;
  border-color:rgba(255,255,255,.35)!important;
  box-shadow:0 0 26px rgba(253,29,29,.36),0 16px 42px rgba(0,0,0,.42)!important;
}

/* TikTok */
.social-sidebar a[href*="tiktok"]:hover,
.social-floating a[href*="tiktok"]:hover,
.social-links a[href*="tiktok"]:hover{
  background:linear-gradient(135deg,#00f2ea,#111,#ff0050)!important;
  border-color:rgba(255,255,255,.35)!important;
  box-shadow:0 0 24px rgba(0,242,234,.32),0 0 34px rgba(255,0,80,.24),0 16px 42px rgba(0,0,0,.42)!important;
}

/* MakerWorld / KS3D */
.social-sidebar a[href*="makerworld"]:hover,
.social-floating a[href*="makerworld"]:hover,
.social-links a[href*="makerworld"]:hover{
  background:linear-gradient(135deg,#a8ff00,#75c800)!important;
  border-color:#a8ff00!important;
  box-shadow:0 0 28px rgba(168,255,0,.42),0 16px 42px rgba(0,0,0,.42)!important;
}

/* Text-Links in der Social-Bar schön lesbar, falls keine Icons genutzt werden */
.social-sidebar a,
.social-floating a,
.social-links a{
  font-size:0!important;
  text-decoration:none!important;
}

.social-sidebar a[aria-label]::before,
.social-floating a[aria-label]::before,
.social-links a[aria-label]::before{
  content:attr(aria-label);
  font-size:11px;
  font-weight:1000;
  color:#a8ff00;
  letter-spacing:.06em;
}

.social-sidebar a:hover::before,
.social-floating a:hover::before,
.social-links a:hover::before{
  color:#071006;
}

/* Kürzere Kürzel */
.social-sidebar a[href*="instagram"]::before,
.social-floating a[href*="instagram"]::before,
.social-links a[href*="instagram"]::before{content:"IG"!important}

.social-sidebar a[href*="tiktok"]::before,
.social-floating a[href*="tiktok"]::before,
.social-links a[href*="tiktok"]::before{content:"TT"!important}

.social-sidebar a[href*="makerworld"]::before,
.social-floating a[href*="makerworld"]::before,
.social-links a[href*="makerworld"]::before{content:"MW"!important}

@media(max-width:768px){
  .social-sidebar a::after,
  .social-floating a::after,
  .social-links a::after{
    display:none!important;
  }
}


/* Materialien Bereich */
.materials-intro{
  max-width:820px;
  margin:0 0 24px auto;
  color:#aeb7bd;
  line-height:1.65;
  font-size:14px;
}

.materials-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(100%,310px),1fr));
  gap:14px;
}

.material-card{
  border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.018));
  border-radius:18px;
  padding:18px;
  box-shadow:0 14px 38px rgba(0,0,0,.28);
  transition:.25s ease;
}

.material-card:hover{
  transform:translateY(-3px);
  border-color:rgba(168,255,0,.28);
  box-shadow:0 18px 48px rgba(0,0,0,.34),0 0 24px rgba(168,255,0,.08);
}

.material-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}

.material-top h3{
  margin:0;
  font-size:20px;
  letter-spacing:-.03em;
}

.material-top span{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:6px 9px;
  background:rgba(168,255,0,.12);
  color:#a8ff00;
  font-size:10px;
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.material-card p{
  color:#b9c0c5;
  font-size:13px;
  line-height:1.55;
  margin:0 0 12px;
}

.material-cols{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

.material-cols strong{
  color:#fff;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.material-cols ul{
  margin:8px 0 0;
  padding-left:18px;
  color:#aeb7bd;
  font-size:12px;
  line-height:1.5;
}

.material-cols li{
  margin-bottom:4px;
}

.usecase{
  margin-top:14px!important;
  padding-top:12px;
  border-top:1px solid rgba(255,255,255,.08);
  color:#e2e8ea!important;
}

@media(max-width:720px){
  .materials-intro{
    margin-left:0;
  }

  .material-cols{
    grid-template-columns:1fr;
  }

  .material-card{
    padding:16px;
  }
}


/* FINAL FIX: echte linke Social-Media-Leiste */
.ks3d-social{
  position:fixed!important;
  left:18px!important;
  right:auto!important;
  top:50%!important;
  transform:translateY(-50%)!important;
  z-index:3500!important;
  display:flex!important;
  flex-direction:column!important;
  gap:10px!important;
}

.ks3d-social a{
  position:relative!important;
  width:46px!important;
  height:46px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  border-radius:15px!important;
  background:rgba(13,17,20,.88)!important;
  border:1px solid rgba(168,255,0,.22)!important;
  color:#a8ff00!important;
  font-size:11px!important;
  font-weight:1000!important;
  letter-spacing:.05em!important;
  text-decoration:none!important;
  backdrop-filter:blur(14px)!important;
  -webkit-backdrop-filter:blur(14px)!important;
  box-shadow:0 12px 32px rgba(0,0,0,.38)!important;
  transition:transform .25s ease, background .25s ease, box-shadow .25s ease, color .25s ease!important;
}

.ks3d-social a::after{
  content:attr(data-label);
  position:absolute;
  left:58px;
  top:50%;
  transform:translateY(-50%) translateX(-8px);
  opacity:0;
  pointer-events:none;
  white-space:nowrap;
  background:rgba(7,9,11,.96);
  color:#f3f5f5;
  border:1px solid rgba(168,255,0,.24);
  border-radius:999px;
  padding:8px 12px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.02em;
  box-shadow:0 16px 42px rgba(0,0,0,.36);
  transition:.25s ease;
}

.ks3d-social a:hover{
  transform:translateX(7px) scale(1.08)!important;
}

.ks3d-social a:hover::after{
  opacity:1;
  transform:translateY(-50%) translateX(0);
}

.ks3d-social .social-instagram:hover{
  color:#fff!important;
  background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045)!important;
  border-color:rgba(255,255,255,.35)!important;
  box-shadow:0 0 26px rgba(253,29,29,.36),0 16px 42px rgba(0,0,0,.42)!important;
}

.ks3d-social .social-tiktok:hover{
  color:#fff!important;
  background:linear-gradient(135deg,#00f2ea,#111,#ff0050)!important;
  border-color:rgba(255,255,255,.35)!important;
  box-shadow:0 0 24px rgba(0,242,234,.32),0 0 34px rgba(255,0,80,.24),0 16px 42px rgba(0,0,0,.42)!important;
}

.ks3d-social .social-makerworld:hover{
  color:#071006!important;
  background:linear-gradient(135deg,#a8ff00,#75c800)!important;
  border-color:#a8ff00!important;
  box-shadow:0 0 28px rgba(168,255,0,.42),0 16px 42px rgba(0,0,0,.42)!important;
}

/* alte Socialbar zur Sicherheit deaktivieren */
.socialbar,
.social-sidebar,
.social-floating,
.social-links{
  display:none!important;
}

@media(max-width:768px){
  .ks3d-social{
    left:8px!important;
    gap:7px!important;
  }

  .ks3d-social a{
    width:38px!important;
    height:38px!important;
    border-radius:12px!important;
    font-size:10px!important;
  }

  .ks3d-social a::after{
    display:none!important;
  }
}


/* ===== Materialien im Stil des Druckerstatus ===== */

.materials-section .section-head{
  margin-bottom:28px!important;
}

.materials-intro{
  max-width:900px;
  padding:18px 22px;
  border-radius:20px;
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
  border:1px solid rgba(168,255,0,.14);
}

.materials-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(340px,1fr));
  gap:18px;
}

.material-card{
  position:relative;
  overflow:hidden;
  border-radius:24px!important;
  padding:22px!important;
  border:1px solid rgba(168,255,0,.14)!important;
  background:
    radial-gradient(circle at top right,rgba(168,255,0,.12),transparent 35%),
    linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.015))!important;
  box-shadow:0 20px 55px rgba(0,0,0,.32)!important;
}

.material-card::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:4px;
  height:100%;
  background:linear-gradient(180deg,#a8ff00,#75c800);
}

.material-card:hover{
  transform:translateY(-5px)!important;
  border-color:rgba(168,255,0,.35)!important;
  box-shadow:0 24px 65px rgba(0,0,0,.4),0 0 30px rgba(168,255,0,.12)!important;
}

.material-top{
  margin-bottom:18px;
}

.material-top h3{
  font-size:24px!important;
  margin:0;
}

.material-top span{
  font-size:11px!important;
  padding:7px 12px!important;
  background:rgba(168,255,0,.14)!important;
  border:1px solid rgba(168,255,0,.24);
}

.material-cols{
  gap:18px!important;
  margin-top:16px;
}

.material-cols > div{
  padding:14px;
  border-radius:16px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
}

.material-cols strong{
  display:block;
  margin-bottom:10px;
  color:#a8ff00!important;
}

.material-cols ul{
  margin:0;
}

.material-cols li{
  margin-bottom:7px;
}

.material-cols li::marker{
  color:#a8ff00;
}

.usecase{
  margin-top:18px!important;
  padding:14px 16px!important;
  border-radius:14px;
  border:1px solid rgba(168,255,0,.12);
  background:rgba(168,255,0,.06);
}

.usecase::before{
  content:"Einsatzgebiet";
  display:block;
  color:#a8ff00;
  font-size:11px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:6px;
}

/* Dashboard Kennzahlen wie Druckstatus */
.materials-section .materials-grid::before{
  content:"Materialübersicht";
  grid-column:1/-1;
  display:block;
  padding:14px 18px;
  border-radius:18px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(168,255,0,.12);
  color:#a8ff00;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}

@media(max-width:768px){
  .materials-grid{
    grid-template-columns:1fr;
  }
}


/* Material Icons + UV-Beständigkeit */
.material-title{
  display:flex;
  align-items:center;
  gap:12px;
}

.material-icon{
  width:46px;
  height:46px;
  display:grid;
  place-items:center;
  border-radius:16px;
  background:
    radial-gradient(circle at 30% 20%,rgba(168,255,0,.35),transparent 45%),
    linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.02));
  border:1px solid rgba(168,255,0,.28);
  color:#a8ff00;
  font-size:24px;
  font-weight:1000;
  box-shadow:0 0 24px rgba(168,255,0,.12);
  animation:materialIconPulse 3.2s ease-in-out infinite;
}

.material-card:hover .material-icon{
  transform:scale(1.08) rotate(-3deg);
  box-shadow:0 0 34px rgba(168,255,0,.26);
}

.material-stats{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  margin-top:16px;
}

.material-stats div{
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.035);
  border-radius:14px;
  padding:12px;
}

.material-stats small{
  display:block;
  color:#8f989e;
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.09em;
  margin-bottom:6px;
}

.material-stats strong{
  display:flex;
  align-items:center;
  gap:8px;
  color:#f3f5f5;
  font-size:14px;
}

.material-stats strong:before{
  content:"";
  width:9px;
  height:9px;
  border-radius:50%;
  background:#a8ff00;
  box-shadow:0 0 14px currentColor;
}

.material-stats .uv-high{color:#a8ff00}
.material-stats .uv-mid{color:#ffd166}
.material-stats .uv-low{color:#ff8f8f}

.material-stats .uv-high:before{background:#a8ff00}
.material-stats .uv-mid:before{background:#ffd166}
.material-stats .uv-low:before{background:#ff8f8f}

@keyframes materialIconPulse{
  0%,100%{filter:brightness(1);transform:translateY(0)}
  50%{filter:brightness(1.2);transform:translateY(-2px)}
}

@media(max-width:520px){
  .material-stats{
    grid-template-columns:1fr;
  }
  .material-icon{
    width:40px;
    height:40px;
    border-radius:13px;
    font-size:20px;
  }
}


/* FINAL: Materialien Header entfernen */
#materialien .section-head,
#materialien .materials-intro{
    display:none !important;
}

#materialien{
    padding-top:10px !important;
}

#materialien .materials-grid{
    margin-top:0 !important;
}



/* ==========================================================
   FINAL FIX 2026-06-16
   Hero kleiner + Materialien Überschrift/Text weg
   ========================================================== */

/* Hauptheadline auf Startseite wirklich kleiner */
#start h1,
.hero h1,
.hero-main-title{
  font-size:clamp(24px,2.8vw,40px) !important;
  line-height:1.08 !important;
  max-width:680px !important;
  letter-spacing:-0.025em !important;
}

/* Untertext ebenfalls kompakter */
#start .lead,
.hero .lead,
#start p.lead{
  font-size:14px !important;
  line-height:1.55 !important;
  max-width:540px !important;
  color:#b4bcc2 !important;
}

/* Hero insgesamt etwas kompakter */
#start.hero,
.hero.hero-persistent,
.hero{
  min-height:420px !important;
  padding-top:28px !important;
  padding-bottom:34px !important;
}

/* Materialien: Überschrift und Einleitung komplett ausblenden */
#materialien .section-head,
#materialien .materials-intro,
#materialien > .section-head,
#materialien > .materials-intro,
section#materialien .section-head,
section#materialien .materials-intro{
  display:none !important;
  visibility:hidden !important;
  height:0 !important;
  min-height:0 !important;
  max-height:0 !important;
  margin:0 !important;
  padding:0 !important;
  overflow:hidden !important;
}

/* Falls die Überschrift als einzelnes Element übrig bleibt */
#materialien h1:first-child,
#materialien h2:first-child,
#materialien .eyebrow:first-child{
  display:none !important;
}

/* Materialien-Bereich startet direkt mit Karten */
#materialien{
  padding-top:8px !important;
}

#materialien .materials-grid{
  margin-top:0 !important;
  padding-top:0 !important;
}

#materialien .materials-grid::before{
  margin-top:0 !important;
}

/* Mobile */
@media(max-width:768px){
  #start h1,
  .hero h1,
  .hero-main-title{
    font-size:28px !important;
  }

  #start .lead,
  .hero .lead{
    font-size:13.5px !important;
  }

  #start.hero,
  .hero{
    min-height:360px !important;
  }
}


/* Unser Studio im Material-/Production-Look */
.studio-section{
  padding-top:8px!important;
}

.studio-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(min(100%,330px),1fr));
  gap:16px;
}

.studio-card{
  position:relative;
  overflow:hidden;
  border-radius:24px;
  border:1px solid rgba(168,255,0,.16);
  background:
    radial-gradient(circle at top right,rgba(168,255,0,.12),transparent 35%),
    linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.018));
  box-shadow:0 20px 55px rgba(0,0,0,.32);
  transition:.25s ease;
}

.studio-card::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:4px;
  height:100%;
  background:linear-gradient(180deg,#a8ff00,#75c800);
  z-index:2;
}

.studio-card:hover{
  transform:translateY(-5px);
  border-color:rgba(168,255,0,.35);
  box-shadow:0 24px 65px rgba(0,0,0,.4),0 0 30px rgba(168,255,0,.12);
}

.studio-image{
  height:190px;
  overflow:hidden;
  border-bottom:1px solid rgba(255,255,255,.08);
}

.studio-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:saturate(.95) contrast(1.08) brightness(.8);
  transition:.3s ease;
}

.studio-card:hover .studio-image img{
  transform:scale(1.06);
  filter:saturate(1.05) contrast(1.12) brightness(.92);
}

.studio-content{
  padding:18px;
}

.studio-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:12px;
}

.studio-top h3{
  margin:0;
  font-size:22px;
  letter-spacing:-.03em;
}

.studio-top span{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:7px 12px;
  background:rgba(168,255,0,.14);
  border:1px solid rgba(168,255,0,.24);
  color:#a8ff00;
  font-size:10px;
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.studio-content p{
  color:#b9c0c5;
  font-size:13px;
  line-height:1.55;
  margin:0 0 14px;
}

.studio-points{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.studio-points span{
  display:inline-flex;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  color:#e2e8ea;
  font-size:11px;
  font-weight:800;
}

@media(max-width:720px){
  .studio-image{
    height:160px;
  }
}


/* Preiskalkulator */
.calculator-section{
  padding-top:8px!important;
}

.calculator-shell{
  display:grid;
  grid-template-columns:minmax(260px,.75fr) minmax(0,1.25fr);
  gap:18px;
  align-items:start;
}

.calculator-info,
.calculator-card{
  border:1px solid rgba(168,255,0,.16);
  border-radius:24px;
  background:
    radial-gradient(circle at top right,rgba(168,255,0,.12),transparent 35%),
    linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.018));
  box-shadow:0 20px 55px rgba(0,0,0,.32);
}

.calculator-info{
  padding:22px;
}

.calculator-info h2{
  margin:0 0 12px;
  font-size:clamp(26px,3vw,38px);
  letter-spacing:-.04em;
}

.calculator-info p{
  color:#b9c0c5;
  line-height:1.6;
  font-size:14px;
}

.calc-hints{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:16px;
}

.calc-hints span{
  display:inline-flex;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(168,255,0,.08);
  border:1px solid rgba(168,255,0,.18);
  color:#e2e8ea;
  font-size:11px;
  font-weight:800;
}

.calculator-card{
  padding:22px;
}

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

.calc-grid label{
  display:grid;
  gap:6px;
  color:#fff;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.06em;
}

.calc-grid input,
.calc-grid select{
  width:100%;
  color:#fff;
  background:#050708;
  border:1px solid rgba(168,255,0,.18);
  border-radius:13px;
  padding:12px;
  font:inherit;
  text-transform:none;
  letter-spacing:0;
}

.calc-result{
  margin-top:18px;
  padding:18px;
  border-radius:18px;
  background:rgba(168,255,0,.08);
  border:1px solid rgba(168,255,0,.22);
  text-align:center;
}

.calc-result span,
.calc-result small{
  display:block;
  color:#aeb7bd;
  font-size:12px;
}

.calc-result strong{
  display:block;
  margin:6px 0;
  color:#a8ff00;
  font-size:clamp(32px,5vw,54px);
  line-height:1;
  letter-spacing:-.05em;
}

.calc-actions{
  display:flex;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
  margin-top:16px;
}

@media(max-width:850px){
  .calculator-shell,
  .calc-grid{
    grid-template-columns:1fr;
  }
}


/* Einfacher Preiskalkulator im KS3D Studio Design */
.calculator-section{
  padding-top:8px!important;
}

.simple-calc-card{
  max-width:820px;
  margin:0 auto;
  border:1px solid rgba(168,255,0,.18);
  border-radius:24px;
  background:
    radial-gradient(circle at top right,rgba(168,255,0,.13),transparent 34%),
    linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.018));
  box-shadow:0 20px 55px rgba(0,0,0,.32);
  padding:22px;
  position:relative;
  overflow:hidden;
}

.simple-calc-card:before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  width:4px;
  height:100%;
  background:linear-gradient(180deg,#a8ff00,#75c800);
}

.simple-calc-head{
  text-align:center;
  margin-bottom:20px;
}

.simple-calc-head span{
  display:inline-flex;
  margin-bottom:8px;
  padding:7px 11px;
  border-radius:999px;
  background:rgba(168,255,0,.12);
  border:1px solid rgba(168,255,0,.22);
  color:#a8ff00;
  font-size:10px;
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.09em;
}

.simple-calc-head h2{
  margin:0;
  font-size:clamp(24px,3vw,36px);
  letter-spacing:-.04em;
}

.simple-calc-head p{
  max-width:560px;
  margin:10px auto 0;
  color:#aeb7bd;
  font-size:13px;
  line-height:1.55;
}

.simple-calc-grid{
  display:grid;
  grid-template-columns:1.3fr 1.1fr .6fr;
  gap:12px;
}

.simple-calc-grid label{
  display:grid;
  gap:6px;
  color:#fff;
  font-size:12px;
  font-weight:900;
}

.simple-calc-grid select,
.simple-calc-grid input{
  width:100%;
  color:#fff;
  background:#050708;
  border:1px solid rgba(168,255,0,.18);
  border-radius:13px;
  padding:12px;
  font:inherit;
}

.simple-calc-result{
  margin:16px 0;
  padding:18px;
  border-radius:18px;
  background:rgba(168,255,0,.08);
  border:1px solid rgba(168,255,0,.22);
  text-align:center;
}

.simple-calc-result small{
  display:block;
  color:#aeb7bd;
  font-size:12px;
}

.simple-calc-result strong{
  display:block;
  color:#a8ff00;
  font-size:clamp(32px,5vw,52px);
  line-height:1;
  letter-spacing:-.05em;
  margin-top:6px;
}

.simple-calc-actions{
  display:flex;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
}

@media(max-width:800px){
  .simple-calc-grid{
    grid-template-columns:1fr;
  }
}
