/* ========================================================================== */
/*  REFERENZEN – GLOBAL STYLE                                                 */
/* ========================================================================== */

.referenzen #hero_title h1 {    
  font-size: 10em;
  line-height: 0.9em;
  letter-spacing: -0.03em;
  font-family: "Poppins";
  font-weight: 600;
  margin: 0;
  color: white;
  user-select: none; 
  z-index: 0;
  padding-top: 3rem;
  display: flex;
  align-items: center;      /* vertikal zentrieren */
  gap: 0.5rem;              /* Abstand zwischen Text und Logo */
}



.referenzen #hero_title.sh h1 {    
  font-size: 7em;
  line-height: 0.9em;
  letter-spacing: -0.03em;
  font-family: "Poppins";
  font-weight: 600;
  margin: 0;
  color: white;
  user-select: none; 
  z-index: 0;
  padding-top: 3rem;
  display: flex;
  align-items: center;      /* vertikal zentrieren */
  gap: 0.5rem;              /* Abstand zwischen Text und Logo */
}





.referenzen #hero_title h1 span {
  color: #00fac9;
}

.referenzen #hero_title h1 .logo-img {
  width: 180px;
  height: auto;
  display: inline-block;
  vertical-align: middle;
  margin-left: -20px;
  margin-right: -30px;
  padding-top: 30px;
}

/* ========================================================================== */
/*  RESPONSIVE TITLES                                                        */
/* ========================================================================== */

@media only screen and (max-width: 1537px) {	
  .referenzen #hero_title h1 {   
    font-size: 7em;		 
    padding-top: 0;
  } 	
}

@media only screen and (max-width: 1024px) {	
  .referenzen #hero_title h1 {   
    font-size: 6.4em;
    letter-spacing: -0.03em;
    margin-top: -2rem;
  }
   .referenzen #hero_title h1 .logo-img { display: none; }
   .referenzen #hero_title.sh h1 { font-size: 6.0em; line-height: 0.9em; }
}

@media only screen and (max-width: 991px) {
  .referenzen #hero_title h1 {   
    font-size: 6.4em;	 	  
  }	
}

@media only screen and (max-width: 767px) {
  .referenzen #hero_title h1 { font-size: 6em; padding-top: 0.5rem; /* weniger Abstand oben */ }

  .referenzen #hero_title .post1H1 {
    margin-top: -0.5rem; /*  näher an Überschrift */
  }  
  
  .referenzen #hero_title h1 .logo-img { display: none; }

  .referenzen .title-h3 br { display: none; }

  .referenzen .title-block.referenz { text-align: left; }
}

@media only screen and (max-width: 479px) {
  .referenzen #hero_title h1 {   
    font-size: 2em;
    line-height: 0.9em;
  }
 

  .referenzen .index .title-block {
    font-size: 1.05em;
    line-height: 1.4em;
    text-align: left;
    -webkit-hyphens: auto;
    -moz-hyphens: auto;
    -ms-hyphens: auto;
  }

   .referenzen .container-width {
	  width: 100%;
	  max-width: 100%;
	  padding: 0 1.0rem;
	  padding-bottom: 0px;
	  margin-right: auto;
	  margin-left: auto;
	}
}

@media (max-width: 440px) {
  .referenzen #hero_title h1 { font-size: 4.5em; line-height: 0.9em; }
  .referenzen #hero_title.mieming h1 { font-size: 3.5em; line-height: 0.9em; }
  .referenzen #hero_title.castaneda h1 { font-size: 3.7em; line-height: 0.9em; }
  .referenzen #hero_title.mattle h1 { font-size: 3.7em; line-height: 0.9em; }
  .referenzen #hero_title.pfeifer h1 { font-size: 4.0em; line-height: 0.9em; }
  .referenzen #hero_title.jochelius h1 { font-size: 3.2em; line-height: 0.9em; }
  .referenzen #hero_title.schloessl h1 { font-size: 2.9em; line-height: 0.9em; }
  .referenzen #hero_title.sh h1 { font-size: 2.5em; line-height: 0.9em; }
  
  .referenzen #hero_title .post {
    position: relative;
    font-size: 3.5em;
  }
}

@media (max-width: 360px) {
  .referenzen #hero_title h1 { font-size: 4.2em; }
}

/* ========================================================================== */
/*  HEADLINES & CONTENT                                                      */
/* ========================================================================== */

.referenzen .index .title-h3 {
  font-size: 2.4em;
  line-height: 1.1em;
  letter-spacing: 3px;
  text-transform: none;
  padding-bottom: 2rem;
  font-family: "Poppins";  
}

.referenzen .headline-flex {
  display: flex;
  justify-content: flex-end;
  text-align: right;
}

.referenzen .content-body {
  display: flex;
  justify-content: flex-end;
  text-align: right;
  padding-left:6rem;
}

@media (max-width: 768px) {
  .referenzen .headline-flex,
  .referenzen .content-body {
    justify-content: flex-start;
    text-align: left;
  }
}

.referenzen .headline {
  color: #fff;
  font-size: 2em;
  padding-bottom: 1rem;
}

@media (max-width: 1024px) {  
 .referenzen .headline {
    font-size: 1.8em;
    padding-bottom: 1rem;
	font-weight:400;	
  }
  .referenzen .content-body {
  display: flex;
  justify-content: flex-end;
  text-align: right;
  padding-left:0rem;
  }
}

@media (max-width: 440px) {  
	.referenzen .index .title-h3 {
	  font-size: 1.8em;
	  line-height: 1.1em;
	  letter-spacing: 0px;
	  text-transform: none;
	  padding-bottom: 2rem;	  
	}
    
  .referenzen .headline {
    font-size: 1.5em;
    padding-bottom: 1rem;
	font-weight:400;
  }

  .referenzen .headline br { display: none; }

  .referenzen .content-body .font-bigger {	
    font-size: 1.05em;
    line-height: 1.4em;  
    -webkit-hyphens: auto;
    -moz-hyphens: auto;
    -ms-hyphens: auto; 
	text-align:justify;
  }
}

/* ========================================================================== */
/*  YEAR / LEISTUNGEN BLOCK                                                  */
/* ========================================================================== */

.year-wrapper {
  text-align: center;
  padding-bottom: 100px;
}

.year-wrapper figure {
  margin: 0;
  display: inline-block;
  vertical-align: bottom;
}

.year-wrapper .year {
  display: inline-block;
  vertical-align: bottom;
  text-align: left;
  font-size: 25px;
  color: #fff;
  text-transform: uppercase;
  padding-left: 20px;
}

.year-right img { width: 100%; }

.year-left {
  font-size: 18px;
}

.year-left p {
  margin-bottom: 30px;
}

.year-left ul {
  margin: 0 0 30px 0;
  list-style: none;
  text-align: right;
}

.year-left ul li {
  padding-bottom: 12px;
  font-size: 1.05em;
}

@media (min-width: 1024px) {
 .referenzen .order-first {
    -ms-flex-order: -1;
    order: -1;
  }
}

.referenzen .font-bigger {
  font-size: 1.15em;
  line-height: 1.6em;
}

/* ========================================================================== */
/*  IMAGE WRAPPER / OVERLAY TEXT                                             */
/* ========================================================================== */

.referenzen .image-wrapper {
  position: relative;
  display: inline-block;
  transform: none; /* Standard: keine Verschiebung */
  transition: transform 0.3s ease; /* weich animieren */
}

.referenzen .image-wrapper img {
  width: 100%;
  height: auto;
  display: block;
  filter: grayscale(100%);
  transition: filter 0.5s ease;
}

.referenzen .image-wrapper:hover img {
  filter: grayscale(0%);
}

.referenzen .image-overlay-text {
  position: absolute;
  bottom: -80px;
  left: -80px;
  color: white;
  font-size: 3rem;
  letter-spacing: 0.9em;
  line-height: 1.1;
  font-weight: 400;
  z-index: 2;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.6);
  pointer-events: none;
  text-transform: uppercase;
}

.referenzen .image-overlay-text .line1,
.referenzen .image-overlay-text .line2 {
  display: block;
}

/* --- Desktop: ab 992px Verschiebung nach rechts --- */
@media (min-width: 992px) {
  .referenzen .image-wrapper {
    transform: translateX(8rem);
  }
}

/* --- Desktop mittlere Breite: 769px–991px --- */
@media (min-width: 769px) and (max-width: 991px) {  
   .referenzen .image-wrapper {
    transform: translateX(4rem);
  }
  .referenzen .image-overlay-text {
    bottom: -80px;
    left: -40px;    
    font-size: 1.8rem;
    letter-spacing: 0.9em;
    line-height: 1.1;
  }
  .referenzen .headline {  
   font-size: 1.6em;  
  }

  .referenzen .headline br {  
   display:none;
  }
}

@media (max-width: 991px) {
.container-width {
    width: 960px;
  }
  .referenzen .font-bigger {
  font-size: 1.15em;
  line-height: 1.6em; 
  }
}


@media (max-width: 1200px) {  
.container-width {
    width: 1000px;
 }

.referenzen .content-body .font-bigger {	
    font-size: 1.15em;
    line-height: 1.4em;  
    -webkit-hyphens: auto;
    -moz-hyphens: auto;
    -ms-hyphens: auto; 	
  }
  .referenzen .headline br {  
   display:none;
  }
}


/* --- Mobile: max-width 768px --- */
@media (max-width: 768px) {
  .referenzen .image-wrapper {
    transform: none;
  }

  .referenzen .image-overlay-text {
    bottom: -80px;
    left: 10px;
    font-size: 2.8em;
    color: white;
    z-index: 5;
    transform: none;
  }
}


/* --- Mobile: max-width 768px --- */
@media (max-width: 1200px) {  
   .referenzen .image-wrapper {
     transform: translateX(4rem);
  }
  
  
  .referenzen .image-overlay-text {
    bottom: -80px;
    left: -40px;
    font-size: 1.6em;
    color: white;
    z-index: 5;
    transform: none;
  } 
  
  .referenzen .title-block {
   text-align: center;
   font-size:1.2em;   
   }
}

@media (max-width: 440px) {  
 .referenzen .image-wrapper {
    transform: translateX(0); /* besser zentrieren, kein Versatz nötig */    
  } 
  
  .referenzen .image-wrapper figure {
    width: 90%;               /* Breite anpassen */
    margin: 0 auto;           /* zentrieren */
  }


  .referenzen .image-wrapper img {
    width: 100%;              /* volle Breite des figure */
    height: auto;
    display: block;
    filter: grayscale(100%);
    transition: filter 0.5s ease;
  } 

   /* Photo-Credit unter dem Bild */
  .referenzen .image-wrapper figure .photo-credit {
    position: static;  
    display: block;
    text-align: left;  /* oder center, falls gewünscht */
    margin-top: 0.5rem;
  }

  .referenzen .image-overlay-text {	 
    bottom: -80px;
    left: 20px;
    color: white;
    font-size: 1.7rem;	  
  }


}

/* --- Photo Credit --- */
.referenzen .image-wrapper figure {
  position: relative;
}

.referenzen .image-wrapper figure .photo-credit {
  position: absolute;
  bottom: 20px;
  right: 10px;
  font-size: 11px;
  letter-spacing: 0.08em;
  color: #cdcdcd;
  padding: 2px 6px;
  border-radius: 3px;
  white-space: nowrap;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  transform: rotate(180deg);
  background: rgba(17,17,17,0.5);
  z-index: 10;
}


/* ========================================================================== */
/*  PROJECT GRID                                                             */
/* ========================================================================== */

/* Carousel Container */
.projects-carousel .project {
  position: relative;
  color: #fff;
  overflow: hidden;
  text-decoration: none;
  padding-bottom: 2rem;
  box-sizing: border-box;
}

/* Bilder / Hover */
.projects-carousel .project img {
  width: 100%;
  height: auto;
  display: block;
  filter: grayscale(100%);
  transition: all 0.3s ease-out;
}

.projects-carousel .project:hover img {
  filter: grayscale(0%);
}

/* Overlay Text */
.projects-carousel .project .txt1 {
  font-size: 1.3em;
  font-weight: 300;
  position: absolute;
  left: 10%;
  right: 10px;
  top: 5%;
  letter-spacing: 0.05em;
  transition: all 0.3s ease-out;
}

.projects-carousel .project .txt5 {
  font-size: 1.0em;
  font-weight: 300;
  position: absolute;
  left: 10%;
  right: 10px;
  top: 12%;
  letter-spacing: 0.05em;
  transition: all 0.3s ease-out;
}

.projects-carousel .project .over1 {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(17,17,17,0.5);
  transition: all 0.3s ease-out;
}

.projects-carousel .project:hover .over1 {
  opacity: 0;
  transform: scale(0.1);
}

/* Photo Credit */
.projects-carousel .project figure .photo-credit {
  position: absolute;
  bottom: 50px;
  left: 10px;
  font-size: 12px;
  color: #fff;
  padding: 2px 6px;
  
  white-space: nowrap;
  transform: rotate(-90deg) translateY(100%);
  transform-origin: bottom left;
  background: rgba(0, 0, 0, 0.5); /* halbtransparentes Schwarz */
}

/* Owl Carousel Nav Buttons */
.projects-carousel .owl-nav button {
  background: rgba(0,0,0,0.5);  
  color: white;
  border: 1px solid #fff;;
  padding: 0.5rem 1rem;  
  cursor: pointer;
  border-radius: 3px;
  transition: background 0.3s;
  width: 4rem;          /* Breite der Pfeile */
  height: 4rem;         /* Höhe der Pfeile */
  font-size: 2rem;      /* Symbolgröße, z.B. FontAwesome oder Text */
}

.projects-carousel .owl-nav button:focus-visible {
  outline: 3px solid #00fac9; /* sichtbarer Focus für Screenreader */
  outline-offset: 2px;
}

.projects-carousel .owl-nav button:hover {
  background: rgba(0,0,0,0.8);
}

/* Owl Carousel - keine Dots */
.projects-carousel .owl-dots {
  display: none;
}


/* Owl Carousel Nav Buttons - Mobile + Tablet nebeneinander */
@media (max-width: 1024px) {
  .projects-carousel .owl-nav {
    display: flex;           /* Flex-Container */
    justify-content: center; /* zentrieren */
    gap: 1rem;               /* Abstand zwischen Pfeilen */
  }

  .projects-carousel .owl-nav button {
    display: inline-flex;    /* inline-flex, damit sie nebeneinander bleiben */
    align-items: center;     /* vertikal zentrieren */
    justify-content: center; /* horizontal zentrieren */
    width: 3rem;
    height: 3rem;
    padding: 0;
    font-size: 1.5rem;
  }
}













/* ========================================================================== */
/*  VIDEO (HOCHFORMAT)                                                       */
/* ========================================================================== */

.referenzen .golf-video {
  width: 100%;
  aspect-ratio: 2 / 3;
  object-fit: cover;
  display: block;
  margin: 0 auto;
  filter: grayscale(100%);
  transition: filter 0.3s ease;
}

.referenzen .project:hover .golf-video {
  filter: grayscale(0%);
}

.referenzen .project video,
.referenzen .project img {
  width: 100%;
  height: auto;
  display: block;
}
