/*------------------
HERO SECTION
-----------------*/

.hero-section {
  display: flex;
  flex-direction: column;
  position: relative;
  justify-content: center;
  height: 80vh;
}

.hero-section::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;

  background: linear-gradient(
    to right,
    color-mix(in srgb, black 70%, transparent),
    color-mix(in srgb, black 0%, transparent)
  );
}

.hero-section__img {
  position: absolute;
  top: 0;
  left: 0;
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  z-index: -2;
  object-position: 80% 20%;

  @media (max-width: 1070px) {
    object-position: 85% 20%;
  }
}

.hero-section .hero-section__inner {
  overflow: hidden;
}

.hero-section__title {
  font-size: var(--heading-xl);
  text-shadow: var(--shadow-m);
  color: var(--text-light-muted);
}

.hero-section__subtitle {
  font-size: var(--text-l);
  color: var(--text-light-muted);
  margin-bottom: var(--space-xl);
}

.hero__cta {
  color: var(--text-light-muted);
}

/*--------------
DEMO SECTION
--------------*/
.demo-section {
  position: relative;
  background: var(--secondary-ultra-light);
}

.demo-section::after {
  content: "";
  position: absolute;
  inset: 0;

  background-image: repeating-linear-gradient(
    0deg,
    rgba(0, 0, 0, 0.01),
    rgba(0, 0, 0, 0.01) 1px,
    transparent 1px,
    transparent 4px
  );

  pointer-events: none;
}

.slider-block {
  container-type: inline-size;
  container-name: slider;
}

.swiper {
  --cf-stretch: clamp(40px, 6cqi, 110px); /*Default Desktiop */
  width: 100%;
  position: relative;
}

.swiper-slide {
  position: relative;
  background: transparent;
  width: clamp(250px, 45cqi, 450px) !important; /*Muss hier sein*/
  aspect-ratio: 3/5;
  display: flex;
  align-items: center;
  border-radius: var(--radius-s);
  overflow: hidden;
  transition: transform 0.3s ease;
}

.swiper-slide::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.8);
  transition: background-color 0.3s ease;
  pointer-events: none;
  z-index: 1;
}

.swiper-slide-active::after {
  background-color: rgba(0, 0, 0, 0.5);
}

.swiper-slide img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: inherit;
  user-select: none;
}

.swiper-pagination {
  text-align: center;
  position: static !important; /*Muss hier sein*/
  margin-top: 1rem;
}

.slider-block .swiper-pagination-bullet {
  /* Müssen wir so ansteuern, weil Swiper eigene Styles höhere Spezifizität haben als ne klasse */
  width: 14px;
  height: 14px;
  background-color: var(--primary-light);
  border-radius: 50%;
  transition: all 0.3s ease-in-out;
  
}

.slider-block .swiper-pagination-bullet-active {
  width: 32px;
  height: 14px;
  border-radius: 50vh;
  background-color: var(--primary);
}

.demo-card__text {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  font-size: var(--text-l);
  text-align: center;
  justify-content: center;
  color: var(--text-light);
  font-weight: 700;
  text-shadow: var(--shadow-l);
  transform: translateY(-50%);

  background-color: var(--primary);
  box-shadow: var(--shadow-l);

  opacity: 0;
  transition: opacity 0.3s ease;
}

.swiper-slide-active .demo-card__text {
  opacity: 1;
  z-index: 2;
}



/*-----------------------
SERVICES SECTION
-----------------*/

.services-card__grid {
  display: grid;
  gap: var(--space-m);
  align-items: start;
  @media (min-width: 768px) {
    grid-template-columns: repeat(2, 1fr);
  }
}

.services-card {
  background-color: var(--white-dark);
  border-radius: var(--radius-m);
  padding-block: var(--space-m);
  padding-inline: var(--space-l);
  box-shadow: var(--shadow-m);
  transition: box-shadow 0.3s ease, background-color 0.3s ease;
}

.services-card__toggle-area {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  padding-block: 0;
  margin-block-start: 0;
  margin-block-end: 0;
  transition: max-height 0.4s ease, opacity 0.3s ease, padding 0.3s ease,
    margin 0.3s ease;
}

.services-card.is-open .services-card__toggle-area {
  opacity: 1;
  padding-block: var(--space-s);
  margin-block-start: var(--space-s);
}

.services-card li {
  position: relative;
  padding-left: 2rem;
  margin-bottom: 0.5rem;
}

.services-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.25rem;
  inline-size: 1.25rem;
  block-size: 1.25rem;
  background-image: url("../images/check.svg");
  background-repeat: no-repeat;
  background-size: contain;
}

.services-card li:last-child {
  margin-bottom: var(--space-l);
}

.services-card__preis {
  text-align: right;
  font-size: var(--text-l);
  font-weight: 700;
  color: var(--primary);
}

/*-----------------------
QUOTE SECTION
-----------------------*/
.quote-section {
  background-color: var(--primary);
}
.quote-section__inner {
  display: flex;
  justify-content: center;
  align-items: center;
}

.quote-section__quote {
  color: var(--text-light);
  font-size: var(--text-xl);
  margin-bottom: 0;
}

/*------------------
TESTIMONIALS SECTION
----------------------*/
.testimonials-section {
  container-type: inline-size;
}

.testimonials-section__inner {
  display: grid;
  gap: var(--space-s);
  justify-items: start;
  grid-template-areas:
    "heading"
    "heading-wrapper"
    "video"
    "text-wrapper";
}

.testimonials-section__heading {
  grid-area: heading;
}

.rating {
  display: flex;
  gap: 0.5rem;
  margin-bottom: var(--space-l);
}

.heading__wrapper {
  grid-area: heading-wrapper;
  align-self: end;
}

.testimonial__heading {
  grid-area: testimonial-heading;
  font-size: var(--text-xl);
}

.testimonial__video {
  grid-area: video;
  margin-bottom: var(--space-l);

  justify-self: start;
  
  inline-size: clamp(220px, 100%, 450px);
  aspect-ratio: 9 / 16;

  border-radius: var(--radius-s);
  overflow: hidden;
}

.testimonials__text-wrapper {
  grid-area: text-wrapper;
}

.rating__star {
  width: var(--heading-l);
  height: var(--heading-l);

  background-color: var(--primary);
  border: none;
  mask-image: url("../images/star.svg");
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
}

.testimonial__link {
  color: var(--primary);
}

@container (min-width: 700px) {
  .testimonials-section__inner {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-l);
    grid-template-areas:
      "heading ."
      "video heading-wrapper"
      "video text-wrapper";
  }
}

/*------------------
ABOUT SECTION
------------------*/
.about-section {
  background-color: var(--white-dark);
  container-type: inline-size;
}

.about-section__inner {
  display: grid;
  gap: var(--space-s);
  justify-items: start;
}

.about-section__block-eins,
.about-section__block-zwei {
  display: grid;
  gap: var(--space-s);
  justify-items: start;
  grid-template-areas:
    "heading"
    "image"
    "text-wrapper";
}

.about-section__heading {
  grid-area: heading;
  align-self: end;
}
.about-section__img {
  grid-area: image;
  align-self: center;
  justify-self: start;
  inline-size: clamp(200px, 100%, 450px);
  block-size: auto;
  margin-bottom: 2rem;
  border-radius: var(--radius-s);
}
.about__text-wrapper {
  grid-area: text-wrapper;
}

@container (min-width: 750px) {
  .about-section__block-eins {
    grid-template-columns: 1.3fr 1fr;
    gap: var(--space-l);
    grid-template-areas:
      "heading image"
      "text-wrapper image";

    justify-items: start;
    align-items: start;
  }

  .about-section__block-zwei {
    grid-template-columns: 1fr 1.3fr;
    gap: var(--space-l);
    grid-template-areas: "image text-wrapper";
    justify-items: start;
    align-items: center;
  }

  .about-section__img-eins {
    justify-self: end;
    margin-bottom: 0;
  }

  .about-section__img-zwei {
    justify-self: start;
    margin-bottom: 0;
  }
}

/*---------------
CTA SECTION
----------------*/
.cta-section {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
  block-size: 20vh;
  scroll-margin-top: 10vh;
}
.cta-section__img {
  position: absolute;
  top: 0;
  left: 0;
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  z-index: -1;
}

.cta-section__inner {
  display: flex;
  align-items: center;
  justify-content: center;
}

/*----------------
CONTACT SECTION
-----------------*/
.contact-section {
  container-type: inline-size;
}

.contact-section__inner {
  display: grid;
  gap: var(--space-m);

  grid-template-areas:
    "heading"
    "image"
    "formular";
}

.contact__img {
  inline-size: clamp(200px, 100%, 450px);
  block-size: auto;
  grid-area: image;
  border-radius: var(--radius-s);

  /*align-self: center;*/
}

.contact-section__heading {
  grid-area: heading;
  align-self: start;
  text-align: start;
}

.contact__formular-wrapper {
  grid-area: formular;
}

/* Kontaktformular */
[aria-hidden="true"] {
  display: none;
}

.kontakt {
  display: flex;
  flex-direction: column;
  border: none;
  gap: var(--space-s);
  max-width: 600px;
  margin: 2rem 0;
}

.kontaktformular__feld {
  inline-size: 100%;
  border-radius: var(--radius-s);
  font-size: var(--text-xs);
  padding-block: var(--space-s);
  padding-inline: var(--space-xs);
  border: 0.5px solid var(--text-dark-muted);
  box-shadow: var(--shadow-m);
}

.kontaktformular__feld:focus {
  border: 2px solid var(--primary);
  outline: none;
}

.kontaktformular__datenschutzhinweis,
.kontaktformular__pflichtfeld-hinweis {
  font-size: var(--text-xs);
}

/* Kontaktformular Erfolgsmeldung */

.form-status {
  margin-top: var(--space-s);
  padding: var(--space-s);
  border-radius: var(--radius-s);
  opacity: 0;
  transform: translateY(5px);
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.form-status--visible {
  opacity: 1;
  transform: translateY(0);
}

.form-status--success {
  background: #dff5e1;
  border: 1px solid #6bc48e;
  color: #2f6d41;
}

.form-status--error {
  background: #f8d7da;
  border: 1px solid #d88086;
  color: #8a2e32;
}

/*Mobil */
@container (min-width: 700px) {
  .contact-section__inner {
    grid-template-columns: 1fr 1.3fr;
    justify-items: start;
    align-items: start;
    grid-template-areas:
      "image heading"
      "image formular";
  }

  .contact-section__heading {
    margin-bottom: calc(-1 * var(--space-m));
  }
}

.datenschutz__link {
  text-decoration: underline;
}
