@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;600;700;800;900&family=Inter:wght@300;400;500;600&display=swap');

/* ======================================================
   LAUSITZWERFT – GLOBALES DESKTOP-CSS
   Komplett bereinigte Version
====================================================== */

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

.lw-site {
  --g: #111827;
  --s: #4B5563;
  --c: #E5E7EB;
  --a: #9CA3AF;
  --w: #FFFFFF;
  --fh: "Barlow Condensed", Arial, sans-serif;
  --fb: "Inter", Arial, sans-serif;
  background: var(--w);
  color: var(--g);
  font-family: var(--fb);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

.lw-site a { color: inherit; }

/* Header */
.lw-site .lw-global-nav {
  position: sticky;
  top: 0;
  z-index: 200;
  min-height: 68px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px 28px;
  flex-wrap: wrap;
  padding: 12px 56px;
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--c);
}

.lw-site .lw-logo {
  display: flex !important;
  align-items: center;
  gap: 14px;
  text-decoration: none;
  flex: 0 0 auto;
}

.lw-site .lw-logo-svg,
.lw-site .lw-logo svg {
  display: block;
  width: 90px;
  height: auto;
  flex-shrink: 0;
}

.lw-site .lw-logo-wordmark {
  display: inline-block;
  font-family: var(--fh);
  font-size: 17px;
  font-weight: 800;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--g);
  line-height: 1.2;
  white-space: nowrap;
}

.lw-site .jimdo-nav {
  flex: 1 1 auto;
  min-width: 420px;
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 24px;
  flex-wrap: wrap;
}

.lw-site .jimdo-nav ul,
.lw-site .jimdo-nav ul.mainNav1,
.lw-site .jimdo-nav ul.mainNav2,
.lw-site .jimdo-nav ul.mainNav3 {
  display: flex !important;
  align-items: center;
  justify-content: center;
  gap: 24px;
  row-gap: 10px;
  flex-wrap: wrap;
  list-style: none;
  margin: 0;
  padding: 0;
}

.lw-site .jimdo-nav li {
  list-style: none;
  margin: 0;
  padding: 0;
}

.lw-site .jimdo-nav a,
.lw-site .jimdo-nav a:link,
.lw-site .jimdo-nav a:visited,
.lw-site .jimdo-nav a span {
  font-family: var(--fh);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--s);
  text-decoration: none;
  transition: color .2s;
}

.lw-site .jimdo-nav a:hover,
.lw-site .jimdo-nav a.current,
.lw-site .jimdo-nav a.current span,
.lw-site .jimdo-nav a.parent,
.lw-site .jimdo-nav a.parent span {
  color: var(--g);
  text-decoration: none;
}

.lw-site .lw-nav-cta { flex: 0 0 auto; white-space: nowrap; }
.lw-site .lw-mobile-menu-button,
.lw-site .lw-mobile-home-link { display: none !important; }
.lw-site .lw-menu-toggle,
.lw-site .lw-menu-button,
.lw-site #lw-mobile-menu-toggle { display: none !important; visibility: hidden !important; opacity: 0 !important; width: 0 !important; height: 0 !important; overflow: hidden !important; pointer-events: none !important; }

/* Buttons */
.lw-site .btn {
  font-family: var(--fh);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  text-decoration: none;
  border: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1.2;
}
.lw-site .btn-dark { background: var(--g); color: var(--w); padding: 12px 26px; transition: background .2s; }
.lw-site .btn-dark:hover { background: var(--s); }
.lw-site .btn-outline { background: transparent; color: var(--g); border: 1.5px solid var(--g); padding: 11px 26px; transition: background .2s, color .2s; }
.lw-site .btn-outline:hover { background: var(--g); color: var(--w); }
.lw-site .btn-outline-light { color: var(--w); border-color: var(--w); }
.lw-site .btn-outline-light:hover { background: var(--w); color: var(--g); }
.lw-site .btn-ghost { font-family: var(--fh); font-size: 12px; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: var(--s); text-decoration: none; display: inline-flex; align-items: center; gap: 8px; transition: color .2s; }
.lw-site .btn-ghost:hover { color: var(--g); }

/* Helper */
.lw-site .tag { display: inline-flex; align-items: center; gap: 10px; font-family: var(--fh); font-size: 11px; font-weight: 700; letter-spacing: 0.3em; text-transform: uppercase; color: var(--s); margin-bottom: 14px; }
.lw-site .tag::before { content: ""; width: 18px; height: 1px; background: var(--s); }
.lw-site .tag-light { color: var(--a); }
.lw-site .tag-light::before { background: var(--a); }
.lw-site h2 { font-family: var(--fh); font-weight: 900; text-transform: uppercase; line-height: 0.92; letter-spacing: -0.01em; color: var(--g); }
.lw-site h2.light { color: var(--w); }
.lw-site h2 .dim { color: var(--s); }
.lw-site .section { padding: 96px 56px; }
.lw-site .bg-w { background: var(--w); }
.lw-site .bg-c { background: var(--c); }
.lw-site .bg-g { background: var(--g); }

/* Hero / Slider */
.lw-site .hero { min-height: calc(100vh - 68px); padding: 80px 56px; display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; background: var(--w); position: relative; overflow: hidden; }
.lw-site .hero::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(var(--c) 1px, transparent 1px), linear-gradient(90deg, var(--c) 1px, transparent 1px); background-size: 48px 48px; opacity: 0.55; pointer-events: none; }
.lw-site .hero-text { position: relative; z-index: 1; }
.lw-site .hero h1 { font-family: var(--fh); font-size: clamp(54px, 6.5vw, 92px); font-weight: 900; line-height: 0.88; text-transform: uppercase; letter-spacing: -0.01em; color: var(--g); margin: 0 0 24px; }
.lw-site .hero h1 span { color: var(--s); }
.lw-site .hero-sub { font-size: 15px; line-height: 1.75; color: var(--s); max-width: 440px; margin: 0 0 40px; }
.lw-site .hero-actions { display: flex; gap: 16px; flex-wrap: wrap; align-items: center; }
.lw-site .hero-img, .lw-site .hero-slider { position: relative; z-index: 1; aspect-ratio: 4 / 3; background: var(--c); border: 1px solid var(--a); overflow: hidden; display: block; }
.lw-site .hero-img::before, .lw-site .hero-slider::before { content: ""; position: absolute; top: 16px; left: 16px; right: 16px; bottom: 16px; border: 1px dashed var(--a); opacity: 0.4; pointer-events: none; z-index: 4; }
.lw-site .hero-img::after, .lw-site .hero-slider::after { content: ""; position: absolute; inset: 6px; pointer-events: none; z-index: 5; background: linear-gradient(var(--s), var(--s)) top left / 14px 2px no-repeat, linear-gradient(var(--s), var(--s)) top left / 2px 14px no-repeat, linear-gradient(var(--s), var(--s)) top right / 14px 2px no-repeat, linear-gradient(var(--s), var(--s)) top right / 2px 14px no-repeat, linear-gradient(var(--s), var(--s)) bottom left / 14px 2px no-repeat, linear-gradient(var(--s), var(--s)) bottom left / 2px 14px no-repeat, linear-gradient(var(--s), var(--s)) bottom right / 14px 2px no-repeat, linear-gradient(var(--s), var(--s)) bottom right / 2px 14px no-repeat; }
.lw-site .hero-slides { position: absolute; inset: 0; width: 100%; height: 100%; overflow: hidden; }
.lw-site .hero-slide { position: absolute; inset: 0; width: 100%; height: 100%; max-width: none; max-height: none; object-fit: cover; opacity: 0; transform: scale(1.03); animation-name: heroSliderFade5; animation-duration: 30s; animation-iteration-count: infinite; animation-timing-function: linear; }
.lw-site .hero-slide:nth-child(1) { animation-delay: 0s; }
.lw-site .hero-slide:nth-child(2) { animation-delay: 6s; }
.lw-site .hero-slide:nth-child(3) { animation-delay: 12s; }
.lw-site .hero-slide:nth-child(4) { animation-delay: 18s; }
.lw-site .hero-slide:nth-child(5) { animation-delay: 24s; }
@keyframes heroSliderFade5 { 0% { opacity: 0; transform: scale(1.03); } 4% { opacity: 1; } 18% { opacity: 1; } 22% { opacity: 0; transform: scale(1.08); } 100% { opacity: 0; transform: scale(1.08); } }
.lw-site .hero-slider-caption { position: absolute; left: 22px; bottom: 22px; z-index: 6; background: rgba(17, 24, 39, 0.82); color: var(--w); padding: 10px 14px; font-family: var(--fh); font-size: 11px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; }

/* Ticker */
.lw-site .ticker { background: var(--g); overflow: hidden; white-space: nowrap; padding: 13px 0; }
.lw-site .ticker-inner { display: inline-block; animation: tick 32s linear infinite; }
.lw-site .ticker span { font-family: var(--fh); font-size: 12px; font-weight: 600; letter-spacing: 0.26em; text-transform: uppercase; color: var(--a); margin-right: 52px; }
.lw-site .ticker span::before { content: "— "; color: var(--s); }
@keyframes tick { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* Startseiten-Sektionen */
.lw-site .intro-grid, .lw-site .staerke-grid, .lw-site .ueber-grid, .lw-site .kontakt-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
.lw-site .intro-text h2, .lw-site .staerke-text h2, .lw-site .ref-header h2, .lw-site .ueber-text h2, .lw-site .kontakt-left h2 { margin: 0 0 24px; }
.lw-site .intro-text p, .lw-site .staerke-text p, .lw-site .ueber-text p, .lw-site .kontakt-left > p { font-size: 14px; color: var(--s); line-height: 1.85; margin: 0 0 16px; }
.lw-site .intro-aside { border-left: 2px solid var(--c); padding-left: 36px; }
.lw-site .aside-head { font-family: var(--fh); font-size: 13px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; color: var(--g); margin-bottom: 14px; }
.lw-site .intro-aside ul, .lw-site .ziel-list, .lw-site .staerke-list { list-style: none; display: flex; flex-direction: column; gap: 10px; margin: 0; padding: 0; }
.lw-site .intro-aside li, .lw-site .ziel-list li, .lw-site .staerke-list li { font-size: 13px; color: var(--s); padding-left: 16px; position: relative; line-height: 1.55; }
.lw-site .intro-aside li::before, .lw-site .staerke-list li::before { content: "—"; position: absolute; left: 0; color: var(--a); }
.lw-site .ziel-list li::before { content: "·"; position: absolute; left: 0; color: var(--g); font-weight: 900; }
.lw-site .ziel-grid, .lw-site .ref-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--a); }
.lw-site .ziel-card, .lw-site .ref-card { background: var(--w); padding: 44px 36px; display: flex; flex-direction: column; gap: 16px; }
.lw-site .ref-card { padding: 36px 28px; gap: 10px; }
.lw-site .ziel-num, .lw-site .ref-type { font-family: var(--fh); font-size: 10px; font-weight: 700; letter-spacing: 0.24em; text-transform: uppercase; color: var(--a); }
.lw-site .ziel-head, .lw-site .ref-title, .lw-site .p-title, .lw-site .contact-panel-head { font-family: var(--fh); font-weight: 800; text-transform: uppercase; color: var(--g); line-height: 1.08; }
.lw-site .ziel-head { font-size: 24px; }
.lw-site .ref-title { font-size: 20px; }
.lw-site .ref-meta { font-size: 12px; color: var(--s); font-weight: 500; }
.lw-site .ziel-text, .lw-site .ref-text, .lw-site .p-text { font-size: 13px; color: var(--s); line-height: 1.7; }
.lw-site .ref-header { display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; margin-bottom: 48px; }
.lw-site .ref-img { width: 100%; aspect-ratio: 16 / 7; background: var(--c); display: block; margin-bottom: 4px; position: relative; overflow: hidden; }
.lw-site .ref-img-label { display: block; width: 100%; height: 100%; line-height: 0; overflow: hidden; }
.lw-site .ref-img img, .lw-site .ref-img-label img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Prozess */
.lw-site .prozess-steps { display: flex; flex-direction: column; }
.lw-site .p-step { display: flex; align-items: flex-start; gap: 20px; padding: 20px 0; border-bottom: 1px solid var(--c); }
.lw-site .p-step:last-child { border-bottom: none; }
.lw-site .p-num { font-family: var(--fh); font-size: 32px; font-weight: 900; color: var(--c); line-height: 1; flex-shrink: 0; width: 44px; }
.lw-site .p-title { font-size: 17px; letter-spacing: 0.06em; margin-bottom: 4px; }

/* Kontakt */
.lw-site .contact-items { display: flex; flex-direction: column; gap: 18px; }
.lw-site .contact-item { display: flex; gap: 14px; align-items: flex-start; }
.lw-site .contact-icon { color: var(--a); flex-shrink: 0; margin-top: 2px; }
.lw-site .contact-label { font-family: var(--fh); font-size: 10px; font-weight: 700; letter-spacing: 0.24em; text-transform: uppercase; color: var(--s); margin-bottom: 3px; }
.lw-site .contact-value, .lw-site .contact-value a { font-size: 14px; color: var(--w); text-decoration: none; }
.lw-site .contact-panel { background: #1F2937; border: 1px solid #374151; padding: 34px; display: flex; flex-direction: column; gap: 22px; }
.lw-site .contact-panel-head { font-size: 16px; letter-spacing: 0.16em; color: var(--w); }
.lw-site .contact-panel p { color: var(--a); font-size: 14px; line-height: 1.8; margin: 0; }
.lw-site .contact-facts { display: grid; grid-template-columns: 1fr; gap: 1px; background: #374151; border: 1px solid #374151; }
.lw-site .contact-facts div { background: #111827; padding: 18px 18px 16px; }
.lw-site .contact-facts span { display: block; font-family: var(--fh); font-size: 11px; font-weight: 800; letter-spacing: 0.22em; color: var(--s); margin-bottom: 6px; }
.lw-site .contact-facts strong { display: block; font-family: var(--fh); font-size: 17px; font-weight: 800; text-transform: uppercase; color: var(--w); margin-bottom: 4px; }
.lw-site .contact-facts em { display: block; color: var(--a); font-size: 12px; line-height: 1.6; font-style: normal; }
.lw-site .contact-actions { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.lw-site .contact-mail { display: inline-flex; text-decoration: none; }

/* Unterseiten */
.lw-site .lw-main { min-height: 60vh; background: var(--w); }
.lw-site .lw-subpage-hero { padding: 96px 56px 72px; background: var(--w); border-bottom: 1px solid var(--c); }
.lw-site .lw-subpage-hero h1 { font-family: var(--fh); font-size: clamp(44px, 6vw, 82px); font-weight: 900; line-height: 0.9; text-transform: uppercase; letter-spacing: -0.01em; color: var(--g); margin: 0 0 22px; max-width: 920px; }
.lw-site .lw-subpage-hero p, .lw-site .lw-content-section p, .lw-site .lw-content-section li { font-size: 15px; line-height: 1.85; color: var(--s); }
.lw-site .lw-content-section { padding: 82px 56px; background: var(--w); }
.lw-site .lw-content-section h2 { font-size: clamp(32px, 4vw, 56px); margin-bottom: 22px; }
.lw-site .lw-spacer { height: 96px; background: var(--c); font-size: 0; line-height: 0; overflow: hidden; }

/* Footer */
.lw-site .lw-global-footer { background: var(--g); border-top: 1px solid #1F2937; padding: 28px 56px; display: flex; justify-content: space-between; align-items: center; gap: 24px; }
.lw-site .f-logo { display: flex; align-items: center; gap: 14px; }
.lw-site .f-wm { font-family: var(--fh); font-size: 13px; font-weight: 700; letter-spacing: 0.26em; text-transform: uppercase; color: var(--a); }
.lw-site .f-copy { font-size: 11px; color: var(--s); }
.lw-site .jimdo-footer, .lw-site .jimdo-footer ul { display: flex; align-items: center; justify-content: flex-end; gap: 22px; flex-wrap: wrap; list-style: none; margin: 0; padding: 0; }
.lw-site .jimdo-footer li { list-style: none; margin: 0; padding: 0; }
.lw-site .jimdo-footer a, .lw-site .jimdo-footer a:link, .lw-site .jimdo-footer a:visited, .lw-site .jimdo-footer a span { font-family: var(--fh); font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--s); text-decoration: none; transition: color .2s; }
.lw-site .jimdo-footer a:hover, .lw-site .jimdo-footer a.current, .lw-site .jimdo-footer a.current span { color: var(--w); text-decoration: none; }
.lw-site .jimdo-footer a[href*="widerruf"], .lw-site .jimdo-footer a[href*="withdraw"], .lw-site .jimdo-footer a[href*="withdrawal"], .lw-site .jimdo-footer a[href*="revocation"], html body a[href*="widerruf"], html body a[href*="Widerruf"], html body a[href*="withdraw"], html body a[href*="withdrawal"], html body a[href*="revocation"], html body a[href*="/j/shop/withdrawal"], html body a[href*="/shop/withdrawal"] { display: none !important; visibility: hidden !important; opacity: 0 !important; width: 0 !important; height: 0 !important; overflow: hidden !important; }
.lw-site .jimdo-footer a.lw-footer-login-link, .lw-site .jimdo-footer a[href*="login"], .lw-site .jimdo-footer a[href*="signin"] { opacity: 0.42 !important; font-size: 10px !important; letter-spacing: 0.08em !important; text-transform: none !important; }
.lw-site .jimdo-footer a.lw-footer-login-link:hover, .lw-site .jimdo-footer a[href*="login"]:hover, .lw-site .jimdo-footer a[href*="signin"]:hover { opacity: 0.8 !important; }
.lw-site .jimdo-sidebar-placeholder { display: none; }

/* Desktop responsive */
@media (max-width: 1280px) {
  .lw-site .lw-global-nav { padding-left: 36px; padding-right: 36px; justify-content: space-between; row-gap: 14px; }
  .lw-site .jimdo-nav { order: 3; flex: 1 0 100%; width: 100%; min-width: 0; justify-content: center; padding-top: 2px; }
  .lw-site .jimdo-nav ul, .lw-site .jimdo-nav ul.mainNav1, .lw-site .jimdo-nav ul.mainNav2, .lw-site .jimdo-nav ul.mainNav3 { gap: 18px 24px; }
}

@media (max-width: 900px) {
  .lw-site .hero, .lw-site .intro-grid, .lw-site .staerke-grid, .lw-site .ueber-grid, .lw-site .kontakt-grid { grid-template-columns: 1fr; }
  .lw-site .ziel-grid, .lw-site .ref-grid { grid-template-columns: 1fr; }
  .lw-site .section, .lw-site .hero, .lw-site .lw-subpage-hero, .lw-site .lw-content-section { padding-left: 24px; padding-right: 24px; }
  .lw-site .ref-header { flex-direction: column; align-items: flex-start; }
  .lw-site .lw-global-footer { flex-direction: column; text-align: center; justify-content: center; padding-left: 24px; padding-right: 24px; }
  .lw-site .jimdo-footer, .lw-site .jimdo-footer ul { justify-content: center; }
}