﻿.clean-page {
  background: #f4f6f8;
  color: #081a36;
}

.clean-page nav a.active {
  color: #49a532;
  border-bottom: 2px solid #49a532;
  padding-bottom: 8px;
}

.clean-hero {
  position: relative;
  min-height: 720px;
  overflow: hidden;
  background:
    radial-gradient(ellipse 54% 30% at 20% 15%, rgba(255,255,255,.96) 0%, rgba(255,255,255,.82) 48%, rgba(255,255,255,0) 74%),
    linear-gradient(90deg, rgba(255,255,255,.98) 0%, rgba(255,255,255,.9) 28%, rgba(255,255,255,.36) 42%, rgba(255,255,255,0) 54%),
    url('hero-flaechenreinigung.webp') center center / cover no-repeat;
}

.clean-hero .container {
  position: relative;
  min-height: 720px;
  padding-top: 46px;
}

.clean-hero h1 {
  max-width: 780px;
  margin: 0;
  color: #082b5b;
  font-size: clamp(52px, 5.8vw, 82px);
  line-height: 1.02;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.clean-hero h1 span {
  display: block;
  color: #49a532;
}

.clean-lead {
  max-width: 650px;
  margin: 20px 0 0;
  color: #081a36;
  font-size: 22px;
  line-height: 1.45;
  font-weight: 700;
}


.clean-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
  margin-top: 34px;
}

.clean-page .btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  min-height: 42px;
  padding: 11px 20px !important;
  border: 1px solid transparent;
  border-radius: 999px;
  font-size: 14px !important;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
  box-shadow: 0 8px 18px rgba(2,8,23,.12);
  transition: transform .18s ease, box-shadow .18s ease, background-color .18s ease, border-color .18s ease;
}

.clean-page .btn::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent 0%, rgba(255,255,255,.28) 45%, transparent 72%);
  transform: translateX(-120%);
  transition: transform .45s ease;
}

.clean-page .btn:hover,
.clean-page .btn:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 12px 24px rgba(2,8,23,.16);
}

.clean-page .btn:hover::before,
.clean-page .btn:focus-visible::before {
  transform: translateX(120%);
}

.clean-page .btn.green {
  background: #49a532;
}

.clean-page .btn.blue {
  background: #082b5b;
}

.clean-hero-card {
  position: absolute;
  right: 36px;
  top: 104px;
  width: 260px;
}

.clean-service {
  display: grid;
  grid-template-columns: 38px minmax(0,1fr);
  gap: 10px;
  align-items: center;
  padding: 13px 16px;
  border-radius: 8px;
  color: #fff;
  font-weight: 900;
  background: linear-gradient(135deg, #2f8f25, #49a532);
  box-shadow: 0 12px 26px rgba(2,8,23,.16);
}

.clean-service strong,
.clean-service span {
  display: block;
  text-transform: uppercase;
}

.clean-service strong {
  font-size: 14px;
  line-height: 1.15;
}

.clean-service span {
  margin-top: 3px;
  color: #d8f5c9;
  font-size: 12px;
  line-height: 1.25;
}

.clean-icon-large {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,.16);
  font-size: 22px;
}

.clean-page main section:not(.clean-hero) h2 {
  font-size: 20px !important;
  line-height: 1.2 !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0 !important;
}

.clean-page main section:not(.clean-hero) h3,
.clean-page main section:not(.clean-hero) .why-item strong,
.clean-page main section:not(.clean-hero) .choice-title,
.clean-page main section:not(.clean-hero) .upload-box strong {
  font-size: 15px !important;
  line-height: 1.2 !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0 !important;
}

.clean-page main section:not(.clean-hero) p,
.clean-page main section:not(.clean-hero) li,
.clean-page main section:not(.clean-hero) label,
.clean-page main section:not(.clean-hero) .package-price,
.clean-page main section:not(.clean-hero) .package-price span,
.clean-page main section:not(.clean-hero) .upload-box,
.clean-page main section:not(.clean-hero) .clean-contact-stack small {
  font-size: 14px !important;
  line-height: 1.4 !important;
}

.clean-page main section:not(.clean-hero) h2 + p,
.clean-page main section:not(.clean-hero) h2 + .why-lead {
  font-size: 16px !important;
  line-height: 1.45 !important;
  font-weight: 700 !important;
}

.clean-page main section:not(.clean-hero) .package-price strong {
  font-size: 24px !important;
  line-height: 1.1 !important;
}

.clean-video {
  background: #fff;
  padding: 28px 0;
  border-top: 1px solid #e5e7eb;
}

.clean-video-grid {
  display: grid;
  grid-template-columns: minmax(250px,.42fr) minmax(0,600px);
  gap: 72px;
  align-items: center;
  justify-content: center;
}

.clean-video-copy {
  padding-top: 0;
  text-align: center;
}

.clean-video-copy h2 {
  margin: 0 0 18px;
  color: #082b5b;
}

.clean-video-copy p {
  margin: 0;
  color: #334155;
  font-weight: 700;
}

.video-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 28px;
  padding: 11px 16px;
  border-radius: 7px;
  background: #082b5b;
  color: #fff;
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
}

.video-frame {
  position: relative;
  justify-self: end;
  width: 100%;
  max-width: 600px;
  overflow: hidden;
  border-radius: 10px;
  background: #061b42;
  box-shadow: 0 18px 38px rgba(2,8,23,.16);
  aspect-ratio: 16/9;
}

.video-frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.surface-strip {
  background: #fff;
  border-top: 1px solid #e5e7eb;
  border-bottom: 1px solid #e5e7eb;
  padding: 22px 0;
}

.surface-strip h2 {
  margin: 0 0 18px;
  color: #082b5b;
  text-align: center;
}

.surface-grid {
  display: grid;
  grid-template-columns: repeat(7,1fr);
  gap: 14px;
}

.surface-card {
  position: relative;
  overflow: hidden;
  min-height: 144px;
  border: 1px solid #dbe3ea;
  border-radius: 8px;
  background: #fff;
  color: #fff;
  text-align: center;
  box-shadow: 0 10px 24px rgba(2,8,23,.1);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.surface-card img {
  display: block;
  width: 100%;
  height: 144px;
  object-fit: cover;
  transition: transform .25s ease;
}

.surface-card span {
  position: absolute;
  left: 50%;
  bottom: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: max-content;
  max-width: calc(100% - 16px);
  min-height: 26px;
  padding: 4px 11px;
  border-radius: 6px;
  background: rgba(8,43,91,.88);
  font-size: 13px !important;
  line-height: 1.2 !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0 !important;
  transform: translateX(-50%);
}

.surface-card:hover,
.surface-card:focus-within {
  transform: translateY(-2px);
  border-color: #b8c7d6;
  box-shadow: 0 14px 28px rgba(2,8,23,.14);
}

.surface-card:hover img,
.surface-card:focus-within img {
  transform: scale(1.035);
}

.before-after {
  background: #f8fafc;
  padding: 28px 0;
}

.before-grid {
  display: grid;
  grid-template-columns: 240px minmax(0,680px);
  gap: 24px;
  align-items: start;
  justify-content: center;
}

.before-copy {
  position: sticky;
  top: 122px;
}

.before-copy h2 {
  margin: 0 0 12px;
  color: #082b5b;
}

.before-copy p {
  color: #334155;
}

.result-gallery {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 10px;
}

.result-card {
  position: relative;
  overflow: hidden;
  margin: 0;
  border: 1px solid #dbe3ea;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 8px 18px rgba(2,8,23,.08);
}

.result-card.featured {
  grid-column: span 2;
  grid-row: span 2;
}

.result-card img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 145px;
  aspect-ratio: 1/1;
  object-fit: cover;
}

.result-card::before {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 10px;
  z-index: 1;
  width: 54%;
  max-width: 280px;
  height: 38px;
  transform: translateX(-50%);
  border-radius: 6px;
  background: rgba(255,255,255,.82);
  backdrop-filter: blur(1px);
}

.result-card::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 15px;
  z-index: 2;
  width: 48%;
  max-width: 250px;
  height: 30px;
  transform: translateX(-50%);
  background: url('logo.png') center / contain no-repeat;
}

.result-card figcaption {
  position: absolute;
  left: 12px;
  top: 12px;
  z-index: 3;
  padding: 4px 11px;
  border-radius: 6px;
  background: rgba(8,43,91,.9);
  color: #fff;
  font-size: 13px !important;
  line-height: 1.2 !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0 !important;
}

.clean-main {
  background: #fff;
  padding: 46px 0 54px;
}

.service-packages {
  max-width: 1120px;
  margin: 0 auto 52px;
}

.service-packages h2,
.service-packages > p {
  text-align: center;
}

.service-packages h2 {
  margin: 0 0 10px;
  color: #082b5b;
}

.service-packages > p {
  max-width: 620px;
  margin: 0 auto 8px;
  color: #334155;
}

.service-packages .package-subnote {
  margin-bottom: 24px;
  font-size: 14px !important;
  font-weight: 400 !important;
}

.package-grid {
  display: grid;
  grid-template-columns: repeat(4,minmax(0,1fr));
  gap: 16px;
}

.package-card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 245px;
  padding: 22px 18px;
  border: 1px solid rgba(255,255,255,.12);
  border-top: 0;
  border-radius: 10px;
  background: linear-gradient(180deg, #0b2d5a 0%, #061b42 100%);
  color: #fff;
  box-shadow: 0 12px 26px rgba(2,8,23,.16);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.package-card:hover,
.package-card:focus-within {
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.24);
  box-shadow: 0 16px 34px rgba(2,8,23,.22);
}

.package-card h3 {
  margin: 0 0 14px;
  padding-left: 1.35em;
  color: #fff;
  text-indent: -1.35em;
  overflow-wrap: anywhere;
}

.package-card p {
  margin: 0;
  color: #d8e4f2;
  overflow-wrap: anywhere;
}

.package-price {
  margin-top: auto;
  padding-top: 16px;
  color: #cdebc2;
}

.package-price strong {
  position: relative;
  z-index: 0;
  display: inline-block;
  width: fit-content;
  margin-top: 6px;
  padding: 6px 12px 7px;
  background: transparent;
  color: #fff;
  transform: none;
  box-shadow: none;
}

.package-price strong::before {
  content: "";
  position: absolute;
  left: -8px;
  right: -8px;
  top: 50%;
  z-index: -1;
  height: 70%;
  border-radius: 999px 46% 999px 42%;
  background: #49a532;
  transform: translateY(-48%) rotate(-2deg);
  clip-path: polygon(3% 26%, 18% 13%, 42% 18%, 67% 9%, 91% 19%, 100% 38%, 96% 74%, 77% 86%, 50% 79%, 25% 91%, 0 72%);
}

.package-price span {
  display: block;
  margin-top: 5px;
  color: #64748b;
}

.package-note {
  display: block;
  max-width: 900px;
  margin: 22px auto 0;
  padding-top: 16px;
  padding-bottom: 8px;
  border-top: 1px solid #e5e7eb;
  color: #334155;
  text-align: center;
}

.package-note p {
  margin: 0;
}

.main-grid {
  display: block;
  margin-top: 56px;
  margin-bottom: 48px;
}

.main-grid > div:first-child {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 34px;
  align-items: start;
}

.clean-process,
.why-clean {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
}

.clean-process h2,
.why-clean h2 {
  margin: 0 0 8px !important;
  color: #082b5b;
  text-align: center;
}

.clean-process > p,
.why-lead {
  max-width: 430px;
  margin: 0 auto 18px !important;
  color: #475569;
  text-align: center;
}

.clean-steps {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  padding-left: 4px;
  text-align: left;
}

.clean-steps::before {
  content: "";
  position: absolute;
  left: 22px;
  top: 22px;
  bottom: 22px;
  width: 1px;
  background: #d4ead0;
}

.clean-step {
  position: relative;
  display: grid;
  grid-template-columns: 38px 1fr;
  gap: 12px;
  align-items: start;
  padding: 0 0 22px;
}

.clean-step:last-child {
  padding-bottom: 0;
}

.clean-circle {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  margin: 0;
  padding: 0;
  border: 1px solid #49a532;
  border-radius: 50%;
  background: #fff;
  color: #49a532;
  font-size: 15px !important;
  font-weight: 900;
  line-height: 1 !important;
  text-align: center;
}

.clean-step-content {
  display: grid;
  align-content: start;
  min-height: 38px;
  padding-top: 11px;
}

.clean-step h3 {
  margin: 0 0 3px;
  color: #082b5b;
}

.clean-step p {
  margin: 0;
  color: #334155;
}

.why-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}

.why-item {
  display: grid;
  grid-template-columns: 38px minmax(0,1fr);
  gap: 12px;
  align-items: start;
  min-width: 0;
  padding: 10px 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.why-icon {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 2px solid #d4ead0;
  border-radius: 50%;
  background: #f5fbf2;
  color: #3c8f2a;
  font-size: 15px;
  font-weight: 900;
}

.why-icon.home-icon {
  display: grid;
  place-items: center;
}

.why-icon.home-icon svg {
  display: block;
  width: 22px;
  height: 22px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.why-item > div:last-child {
  display: grid;
  align-content: start;
  min-height: 38px;
  padding-top: 10px;
}

.why-item strong {
  display: block;
  margin: 0 0 3px;
  color: #082b5b;
  overflow-wrap: anywhere;
}

.why-item p {
  margin: 0;
  color: #334155;
  overflow-wrap: anywhere;
}

.clean-side {
  max-width: 980px;
  margin: 48px auto 0;
  padding: 28px 30px;
  border: 1px solid #dbe3ea;
  border-radius: 10px;
  background: #fff;
  color: #081a36;
  box-shadow: 0 14px 32px rgba(2,8,23,.08);
}

.clean-request h2,
.clean-side p {
  text-align: center;
}

.clean-request h2 {
  margin: 0 0 12px;
  color: #082b5b;
}

.clean-side p {
  margin: 0 0 16px;
  color: #334155;
}

.clean-form {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
}

.clean-form input,
.clean-form textarea {
  width: 100%;
  padding: 12px;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  font: inherit;
}

.clean-form textarea,
.package-choice,
.upload-box,
.clean-form button {
  grid-column: 1 / -1;
}

.clean-form textarea {
  min-height: 86px;
  resize: vertical;
}

.package-choice {
  padding: 12px;
  border: 1px solid #dbe3ea;
  border-radius: 8px;
  background: #f8fafc;
}

.choice-title {
  display: block;
  margin: 0 0 9px;
  color: #082b5b;
}

.choice-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 8px 12px;
}

.package-choice label {
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: 8px;
  align-items: center;
  color: #334155;
  font-weight: 700;
}

.package-choice input {
  width: 16px;
  height: 16px;
  accent-color: #49a532;
}

.upload-box {
  display: grid;
  grid-template-columns: 1fr minmax(170px,.9fr);
  gap: 12px;
  align-items: center;
  padding: 14px;
  border: 1px dashed #94a3b8;
  border-radius: 8px;
  color: #475569;
  text-align: left;
}

.upload-box strong {
  display: block;
  color: #082b5b;
}

.upload-box input {
  padding: 9px;
  background: #fff;
}

.clean-form button {
  border: 0;
  cursor: pointer;
}

.hp-field {
  display: none;
}

@media (max-width: 1100px) {
  .clean-hero-card {
    display: none;
  }

  .clean-video-grid,
  .before-grid,
  .main-grid > div:first-child {
    grid-template-columns: 1fr;
  }

  .surface-grid {
    grid-template-columns: repeat(3,1fr);
  }

  .before-copy {
    position: static;
  }

  .package-grid {
    grid-template-columns: repeat(2,1fr);
  }

}

@media (max-width: 700px) {
  .clean-page .container {
    max-width: 100%;
    padding-left: 18px;
    padding-right: 18px;
    overflow: hidden;
  }

  .clean-page header .container {
    overflow: visible;
  }

  .clean-hero {
    min-height: auto;
    background: url('hero-flaechenreinigung.webp') center top / auto 255px no-repeat #fff;
  }

  .clean-hero .container {
    min-height: auto;
    padding-top: 275px;
    padding-bottom: 34px;
  }

  .clean-hero-card {
    display: grid;
    top: 14px;
    right: 18px;
    width: 152px;
    z-index: 2;
  }

  .clean-service {
    grid-template-columns: 20px minmax(0,1fr);
    gap: 6px;
    width: 100%;
    padding: 7px 8px;
    border-radius: 6px;
  }

  .clean-icon-large {
    width: 20px;
    height: 20px;
    font-size: 16px;
  }

  .clean-service strong {
    font-size: 8px;
    line-height: 1.08;
    white-space: nowrap;
  }

  .clean-service span {
    font-size: 6.5px;
    line-height: 1.12;
  }

  .clean-hero h1 {
    font-size: 28px;
    line-height: 1.05;
  }

  .clean-lead {
    margin-top: 12px;
    font-size: 14px;
    line-height: 1.45;
  }

  .clean-benefits {
    grid-template-columns: 1fr;
    gap: 12px;
    margin-top: 22px;
  }

  .clean-benefit {
    grid-template-columns: 38px 1fr;
    gap: 10px;
  }

  .clean-benefit-icon {
    width: 38px;
    height: 38px;
    font-size: 20px;
  }

  .clean-actions {
    margin-top: 22px;
  }

  .clean-actions .btn {
    padding: 9px 14px;
    font-size: 12px;
  }

  .clean-video {
    padding: 18px 0;
  }

  .clean-video-grid {
    gap: 12px;
  }

  .video-link {
    width: 100%;
    margin-top: 24px;
    padding: 10px 14px;
    font-size: 11px;
  }

  .video-frame {
    border-radius: 8px;
    box-shadow: 0 12px 26px rgba(2,8,23,.12);
  }

  .surface-grid {
    grid-template-columns: repeat(2,1fr);
    gap: 10px;
  }

  .surface-card,
  .surface-card img {
    min-height: 126px;
    height: 126px;
  }

  .before-after {
    padding: 24px 0;
  }

  .result-gallery {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .result-card.featured {
    grid-column: auto;
    grid-row: auto;
  }

  .result-card img {
    min-height: 0;
  }

  .result-card::before {
    width: 56%;
    height: 44px;
    bottom: 9px;
  }

  .result-card::after {
    width: 50%;
    height: 34px;
    bottom: 14px;
  }

  .clean-main {
    padding: 24px 0;
  }

  .service-packages {
    max-width: 270px;
  }

  .package-grid {
    grid-template-columns: 1fr;
  }

  .package-card {
    min-height: auto;
    padding: 18px 14px;
  }

  .package-note,
  .clean-form,
  .choice-grid,
  .upload-box {
    grid-template-columns: 1fr;
  }

  .clean-side {
    width: calc(100% - 6px);
    margin-right: 6px;
    padding: 20px 18px;
    box-shadow: none;
  }

  .clean-process {
    width: calc(100% - 6px);
    margin-right: 6px !important;
    margin-bottom: 36px !important;
  }

  .clean-steps {
    padding-left: 4px;
  }

  .clean-steps::before {
    left: 22px;
  }

  .clean-step {
    grid-template-columns: 38px 1fr;
    padding-bottom: 20px;
  }

  .clean-step-content {
    padding-top: 10px;
  }

  .why-grid {
    gap: 10px;
    width: calc(100% - 6px);
    margin-right: 6px;
  }

  .why-item {
    grid-template-columns: 38px minmax(0,1fr);
    gap: 10px;
    padding: 13px 12px;
  }

  .why-icon {
    width: 38px;
    height: 38px;
    font-size: 15px;
  }

  .why-item > div:last-child {
    min-height: 38px;
    padding-top: 10px;
  }
}

.clean-actions .btn{
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  box-sizing:border-box!important;
  min-width:0!important;
  min-height:0!important;
  border:0!important;
  padding:11px 20px!important;
  font-size:14px!important;
  line-height:1!important;
  border-radius:999px!important;
}

@media (max-width:700px){
  .clean-actions{
    gap:14px!important;
    margin-top:22px!important;
    align-items:flex-start!important;
  }

  .clean-actions .btn{
    display:inline-flex!important;
    align-items:center!important;
    justify-content:center!important;
    box-sizing:border-box!important;
    min-width:0!important;
    min-height:0!important;
    border:0!important;
    padding:9px 14px!important;
    font-size:12px!important;
    line-height:1.35!important;
    border-radius:999px!important;
  }

  .clean-benefit h3{
    font-size:13px!important;
    line-height:1.15!important;
  }
}
/* Mobile typography scale */
@media (max-width:700px){
  .clean-hero h1{font-size:22px!important;line-height:1.08!important;letter-spacing:0!important}
  .clean-lead{font-size:13px!important;line-height:1.48!important}
  .clean-page main section:not(.clean-hero) h2,.clean-page h2{font-size:15px!important;line-height:1.24!important}
  .clean-page main h3,.clean-page .package-card h3,.clean-page .clean-step-content h3,.clean-page h3{font-size:13px!important;line-height:1.22!important}
  .clean-page p,.clean-page li{font-size:13px!important;line-height:1.5!important}
}

/* Clean why-list without card backgrounds */
.clean-page .why-clean .why-item,
.clean-page .why-clean .why-item:hover,
.clean-page .why-clean .why-item:focus-within{
  transform:none!important;
  padding:10px 0!important;
  border:0!important;
  border-radius:0!important;
  background:transparent!important;
  box-shadow:none!important;
}

@media (max-width:700px){
  .clean-page .why-clean .why-item,
  .clean-page .why-clean .why-item:hover,
  .clean-page .why-clean .why-item:focus-within{
    padding:10px 0!important;
  }
}
