/* Global Defaults --------------------------------------------------------- */


.green {
  color:#557043!important;
}

.orange {
  color:#f7a833!important;
}

.red {
  color:#cc5c40!important;
}

.blue {
  color:#597f9e!important;
}

.brown {
  color:#597f9e!important;
}

.white {
  color:#f5f3ef!important;
}






:root {
	/* Beispiel-Custom-Variable  */
	--primary-500: hsl(0, 98%, 52%);
      --forest-green: #557043;
  --accent-orange: #e76f29;
  --sand: #f5f3ef;
  --text-dark: #222;
  --text-light: #6c757d;
}

body {
  font-family: "Helvetica Neue", Arial, sans-serif;
  background-color: var(--sand);
  color: var(--text-dark);
  line-height: 1.6;
}



/* Links */
a {
  text-decoration: none!important;
  
}




/*Bildrahmen */
.photo-frame-r {
  display: block;
  border: 10px solid #fff;
  box-shadow: 3px 6px 6px rgba(0,0,0,.1);
  transform: rotate(3deg);
  transition: transform .3s ease;
}

.photo-frame-r:hover {         
  transform: rotate(1deg) scale(102%);
}

.photo-frame-r-2 {
  display: block;
  border: 10px solid #fff;
  box-shadow: 3px 6px 6px rgba(0,0,0,.1);
  transform: rotate(1deg);
  transition: transform .3s ease;
}

.photo-frame-r-2:hover {         
  transform: rotate(-1deg) scale(102%);
}

.photo-frame-l {
  display: block;
  border: 10px solid #fff;
  box-shadow: 3px 6px 6px rgba(0,0,0,.1);
  transform: rotate(-3deg);
  transition: transform .3s ease;
}

.photo-frame-l:hover {
  transform: rotate(-2deg) scale(102%);
}



/*Überschriften */

h1 {
    font-family: ProgramOT;
    color: #557043!important;
    text-transform:uppercase;
    font-size: 70px!important;
    line-height: 40px!important;

}


h2 {
  font-family: ProgramOT;
  color: #f7a833;
  text-transform:uppercase;
}


h3 {
  font-family: ProgramOT;
  color: #f7a833!important;
  text-transform:uppercase;
}



/*Footer*/
.footer-title{
  font-family: ProgramOT;
  text-transform:uppercase;
  font-size: 20px!important;
}

.footer-site{
  font-size: 15px!important;
  transition: color .1s ease, transform .1s ease;
}

.footer-site:hover{
  color: #cfc6b8!important;
}






/*Main-Menu*/

.main-category {
  font-family: ProgramOT, Arial, Helvetica, sans-serif;
  
  font-size: 30px;
  text-transform: uppercase;
  padding-left:30px  !important;
  padding-right:30px!important;


    --bs-link-color:  #557043!important;
  --bs-link-hover-color:  #557043cf!important;
  --bs-link-decoration-color:  #557043!important;
}

@media (max-width: 992px) {
  .main-category {
    font-size: 20px!important;
  }}



.navbar.bg-green.text-white {
  --bs-link-color: #fff!important;
  --bs-link-hover-color: rgba(255, 255, 255, 0.8)!important;
  --bs-link-decoration-color: #fff!important;
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
 
}

 @media (max-width: 767px) {
.navbar.bg-green.text-white {

  display: none;
}


 }

/* Abstand der Zooschule‑Button 
.zooschule-button {
  font-family: ProgramOT;
  font-size: 25px;
  text-transform: uppercase;
  color: #fff;
  background-color: #f7a833;
  border-radius: 30px;
  box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.15);
  transform: rotate(-3deg);
  line-height: 20px;
  padding-top: 7px;
  transition: transform .5s ease;
}
.zooschule-button:hover {
  transform: rotate(-1deg) scale(1.02);
}

/* Responsive max-width 
@media (min-width: 1400px) {
  .maxwith-90 {
    max-width: 90vw !important;
  }
}

/* Dropdown‑Pfeil entfernen*/
.navbar-nav > li.menu-item-has-children > a::after {
  content: none !important;
  display: none !important;
}

/* ———————————————————————————————— */
/* EINFACHE GRÜNE TRENNLINIE ZWISCHEN TOP‑LEVEL MENÜPUNKTEN */

/* 1) Alte Margin‑/Padding‑Ansätze zurücksetzen */
.navbar-nav > li {
  margin: 0 !important;
  padding: 0 !important;
}

/* 2) Zwischen jedem <li> (außer dem ersten) eine grüne Linie*/

 @media (min-width: 767px) {
.navbar-nav > li + li {
  border-left: 2px solid #557043 !important;  /* grüne Trennlinie */
  padding-left: 3rem !important;              /* Abstand von Linie zu Text */
  margin-left: 3rem !important;               /* Abstand Linie zum vorherigen Link */
}
 }




.sub-menu {
  color:#557043!important;
}












/* Akzent unter Haupt-Slogan */
.accent {
  letter-spacing: 0.05em;
  color: var(--forest-green);
  position: relative;
}

.accent::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -6px;
  width: 80px;
  height: 4px;
  background: var(--accent-orange);
  transform: translateX(-50%);
}

/* Abschnittsüberschriften */
.section-title {
  font-size: 1.75rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--forest-green);
  margin-bottom: 1rem;
  position: relative;
}

/* Tier-Listen */
.animal-list {
  padding-left: 1rem;
  margin-bottom: 1rem;
}

.animal-list li {
  margin-bottom: 0.25rem;
}

/* Bilder */
img {
  object-fit: cover;
}

/* Responsive tweaks */
@media (max-width: 767.98px) {
  .section-title {
    font-size: 1.5rem;
  }
}




/* ----------------------------------------------------------
   Infobox Buchungen
   ---------------------------------------------------------- */


.info-box {
  padding-top: 1.5rem;
}

.facts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
}

.facts-list li {
  background-color: #ffffff;
  border-radius: 2rem;
  box-shadow: 0 0.25rem 0.5rem rgba(0, 0, 0, 0.05);
  padding: 0.5rem 1rem;
  display: flex;
  align-items: center;
  font-size: 0.95rem;
  white-space: nowrap;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.facts-list li:hover {
  transform: translateY(-4px);
  box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
  background-color: #e9ecef;
}

.facts-list img {
  width: 1.5rem;
  height: auto;
  margin-right: 0.5rem;
}

@media (max-width: 767.98px) {
  .facts-list {
    justify-content: flex-start;
  }
}












/* ----------------------------------------------------------
   Landing 1
   ---------------------------------------------------------- */


/* 1. Social Icons fixed left */


.social-icons {
  position: fixed;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  z-index: 1000;
  background-color: #557043ac;
  border-radius: 0px 5px 5px 0px;
  width: 40px;
  box-shadow: 1.5px 1.5px 6px rgba(0,0,0,.3);
}
.social-icon {
  display: block;
  margin: .5rem;
}
.social-icon img {
  transition: transform .6s ease-in-out;
}
.social-icon:hover img {
  transform: rotate(360deg);
}

/* 2. Info Icons */
.info-link {
  overflow: hidden;
}
.info-icon {
  transition: transform .3s ease;
}
.info-link:hover .info-icon {
  transform: scale(1.05);
}

.title-infos {
  font-family: "ProgramOT"!important;
  font-size: 30px;
  color:#557043;
  text-transform: uppercase;
}

.sub-infos {
  font-size: 18px;
  font-style: bold;
  color:#557043;
  line-height: 0.2;
}




















/* Highlight‑Karussell */
.highlight-carousel {
  overflow: visible;
  padding-top: 2rem;
}

.highlight-carousel .container {
  position: relative;
}

.highlight-carousel .carousel-inner,
.highlight-carousel .carousel-item,
.highlight-carousel .row {
  overflow: visible;
}

/* Prev/Next‑Buttons außerhalb der Cards, fest 35×35 px */
.highlight-carousel .carousel-control-prev,
.highlight-carousel .carousel-control-next {
  width: 35px;
  height: 35px;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0.8;
  color: #557043;
}

.highlight-carousel .carousel-control-prev {
  left: -1rem;
}

.highlight-carousel .carousel-control-next {
  right: -1rem;
}

/* Eigene Bilder für Prev/Next‑Buttons, fest 35×35 px */
.highlight-carousel .carousel-control-prev-icon,
.highlight-carousel .carousel-control-next-icon {
  background-image: none;       /* Standard‑SVG entfernen */
  width: 35px;
  height: 35px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 35px 35px;   /* keine Skalierung */
}

/* Pfad zum eigenen „Zurück“‑Icon */
.highlight-carousel .carousel-control-prev-icon {
  background-image: url('https://wingster-waldzoo.de/wp-content/uploads/2025/07/icon-prev.png');
}

/* Pfad zum eigenen „Vor“‑Icon */
.highlight-carousel .carousel-control-next-icon {
  background-image: url('https://wingster-waldzoo.de/wp-content/uploads/2025/07/icon-next.png');
}

/* Card‑Grundstyle */
.highlight-card {
  overflow: visible !important;
  transform-origin: center top;
  transition: transform .3s ease;
}

.highlight-card:hover {
  transform: rotate(0deg) scale(1.02) !important;
}

/* Bilder in Originalgröße (kein Scaling) */
.highlight-card .card-img-top {
  display: block;
  width: auto;
  max-width: none;
  height: auto;
  border: 7px solid #fff;
}

/* Neuer Titel‑Style */
.carousel-title {
  position: absolute;
  bottom: 1rem;
  left: 1rem;
  margin: 0;
  color: #fff;
  text-shadow: 0 4px 6px rgba(0,0,0,0.6);
  padding: .2rem .5rem;
  font-size: 2rem;
  line-height: 0.8;
  font-family: ProgramOT;
  text-transform: uppercase;
}

/* „Mehr entdecken“-Link */
.more-btn {
  display: inline-block;
  font-weight: 600;
  text-decoration: none;
  color: inherit;
}












/* 4. Shortcuts */

.shortcuts .shortcut {
  position: relative;
  overflow: hidden;
  min-width: 50%;
  text-align: center;
  padding: 100px 0px 100px 0px!important;
}

@media (max-width: 767.98px) {
  .shortcuts .shortcut { width: 100% !important; }
}

.bg-green  { background-color: #557043; }
.bg-blue   { background-color: #5f7a97; }
.bg-orange { background-color: #f7a539; }
.bg-red    { background-color: #c9572d; }

.shortcut::before {
  content: "";
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0.02;
  transform: scale(1); 
  transition: transform 3s ease, 
              opacity   3s ease; 
  pointer-events: none;
  z-index: 0;
  will-change: transform, opacity;
}

.kasten-1::before { background-image: url("https://wingster-waldzoo.de/wp-content/uploads/2025/07/shortcut-background-pattern-01.png"); }
.kasten-2::before { background-image: url("https://wingster-waldzoo.de/wp-content/uploads/2025/07/shortcut-background-pattern-02.png"); }
.kasten-3::before { background-image: url("https://wingster-waldzoo.de/wp-content/uploads/2025/07/shortcut-background-pattern-03.png"); }
.kasten-4::before { background-image: url("https://wingster-waldzoo.de/wp-content/uploads/2025/07/shortcut-background-pattern-04.png"); }

.shortcut > * { position: relative; z-index: 1; }

.shortcut:hover::before {
  transform: scale(1.1);
  opacity: 0.05;   
}

.btn-landing  {
  background-color: #554d41;
  font-family: "ProgramOT";
  font-size: 20px;
  color: #f4f0ea!important;
  text-transform: uppercase;
  padding: 5px 50px 2px 50px;
  transition: transform .25s ease, background-color 0.25s ease;
}

.btn-landing:hover {
transform: scale(1.01);
background-color: #71695c;
}

.btn-small  {
   font-size: 15px;
  font-weight: 600;
background-color: #f4f0ea;
color: #554d41!important;
border: #554d41;
border-style: solid;
border-width: 2px;
  transition: background-color 0.25s ease;
}

.btn-small:hover {

  background-color: #554d41;
  color: #f4f0ea!important;
  border: #554d41;
  border-style: solid;
  border-width: 2px;
}

.btn-small:active {

  background-color: #554d41;
  color: #f4f0ea!important;
  border: #554d41;
  border-style: solid;
  border-width: 2px;
}

.pretitle-landing {
  font-size: 35px;
  font-family: "ProgramOT";
  text-transform: uppercase;
}


.title-landing {
  font-size: 60px;
  line-height: 40px;
}




/* 5. Event */
.preview-text {
    max-width: 45ch;      /* ~45 Zeichen pro Zeile */
  }

@media (min-width: 768px) {   /* md und größer */
  .gx-big { --bs-gutter-x: 4.5rem; }
}



/* 6. Kontakt */
.contact {
  background: transparent; /* Body-Hintergrund kommt durch */
}
.contact-img {
  position: absolute;
 bottom: 0px;
  left: -20px;
  max-width: 350px;
  z-index: 1;
}

 .contact-title {
font-size: 35px;
 }

 .nummer {
  font-family: ProgramOT;
  font-size: 65px;
  color: #f7a833;
 }


/* 7. Hero-Text*/
.hero-landing {
  position: relative;
}
.hero-landing-text {
  position: absolute;
  top: 50%;
  left: 20%;
  transform: translateY(-50%);
  z-index: 2;
}

/* Basis-Styles (Desktop ≥ 1460 px) */
.herotitle-1 {
  font-size: 150px !important;
  line-height: 100px;
  color: #f7a539;
}
.herotitle-2 {
  font-size: 54px !important;
  line-height: 20px;
}
.herotitle-3 {
  font-size: 85px !important;
  line-height: 75px;
}
.herotitle-4 {
  font-size: 90px !important;
  line-height: 55px;
}

/* Breakpoint 1 */
@media (max-width: 1459px) {
  .herotitle-1 { font-size: 110px!important; line-height: 80px; }
  .herotitle-2 { font-size: 42px!important;  line-height: 26px; }
  .herotitle-3 { font-size: 65px!important;  line-height: 58px; }
  .herotitle-4 { font-size: 72px!important;  line-height: 45px; }
}

/* Breakpoint 2 */
@media (max-width: 767px) {
  .herotitle-1 { font-size: 64px!important; line-height: 52px; }
  .herotitle-2 { font-size: 28px!important; line-height: 20px; }
  .herotitle-3 { font-size: 40px!important; line-height: 36px; }
  .herotitle-4 { font-size: 46px!important; line-height: 32px; }
}

/* 7. NochFragen-Text*/


.fragenoffen-1 {
  font-size: 100px !important;
  line-height: 100px;
  color: #f7a539;
}
.fragenoffen-2 {
  font-size: 73px !important;
  line-height: 25px;
  color: #557043;
}
.fragenoffen-3 {
  font-size: 77px !important;
  line-height: 55px;
}


@media (max-width: 991.98px) {
  .fragenoffen {
    white-space: nowrap;         
  }
  .fragenoffen br {
    display: none;              
  }
  .fragenoffen-1,
  .fragenoffen-2,
  .fragenoffen-3 {
    display: inline;         
    font-size: clamp(22px, 6vw, 40px) !important;
    line-height: 1.1;
    color: #f7a539 !important; 
    margin-right: 0.25em;  
  }
  .fragenoffen-3 { margin-right: 0; } 
}





/* ========== Tabellen ==========  ==========  ==========  ==========  ========== */


table {
  width: 100%;
  border-collapse: collapse;
  font-family: sans-serif;
}

thead tr {
  background-color: #557043;
  color: #f5f3ef;
  font-family: 'ProgramOT', sans-serif;
  text-transform: uppercase;
  text-align: left;
}

thead th {
  padding: 12px 16px;
}

tbody tr:nth-child(even) {
  background-color: rgba(255, 255, 255, 0.01);
}

tbody tr:nth-child(odd) {
  background-color: rgba(0, 0, 0, 0.01);
}

tbody td {
  padding: 12px 16px;
  text-align: left;
}







/* ========== Excerpt-Pfeil ▸ an den Text anlehnen */
.read-more-arrow {
  font-weight: 700;
  display: inline-block;
  margin-left: .25rem;
}






/* ========== Das Riss-Bild */
.hero-tear-bottom {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: auto;
  z-index: 3;       
  pointer-events: none;
}


.hero-tear-top {
  position: absolute;
  top: 110px;      
  left: 0;
  width: 100%;
  height: auto;
  z-index: 2;
  pointer-events: none;
}

.footer-tear-top {
  position: absolute;
  top: -4px;      
  left: 0;
  width: 100%;
  height: auto;
  z-index: 2;
  pointer-events: none;
}

.footer {
  position: relative;
  overflow: visible;
  background-color: #557043!important
}

.footer-tear-top-alt {
  position: absolute;
  top: -45px;      
  left: 0;
  width: 100%;    
  height: auto;
  display: block;
  pointer-events: none;
  z-index: 10; 
}















/*Tier-Listen*/

.list-border-gefaehrten {
  border-left: 3px solid #597f9e;
  padding-left: 1rem;      
}

.list-border-bambus {
  border-left: 3px solid #f7a833;
  padding-left: 1rem;      
}

.list-border-tropen {
  border-left: 3px solid #cc5c40;
  padding-left: 1rem;      
}

.list-border-taiga {
  border-left: 3px solid #557043;
  padding-left: 1rem;      
}

.list-border-lemuren {
  border-left: 3px solid #597f9e;
  padding-left: 1rem;      
}






.zoohub {
  background-color: #ced3b4!important;
}




/* Übersicht Führungen */


/* 2. Basis-Übergang */
.tour-card { transition: transform .25s ease; }

/* 3. Hover-Effekt – abhängig von der Position der Spalte
      (nicht des Ankers!), darum :nth-child() auf .col  */
.row .col:nth-child(odd)  .tour-card:hover { transform: rotate(-2deg) scale(1.00); }
.row .col:nth-child(even) .tour-card:hover { transform: rotate( 2deg) scale(1.00); }





/*Zooguide im Formular ausblenden*/
.zooguide {display: none!important;}
.ahbfield_service {display: none!important;}

@media (min-width: 576px) {
h1 {
    font-size: 40px!important;
    line-height: 30px!important;
}}



/* Zooguide intern   */


.tabcontent table {
    margin-bottom: 1.5rem;      /* Abstand nach unten */
}

.cpappbheadermth                    
{
    background-color: #557043 !important;
    padding: .1rem 0 !important;
    color: #557043 !important;
    
}

.cpappbheadermtd                                   
{
    background-color: #557043 !important;
    border: none !important;
    padding: .1rem 1rem !important;  
        font-size: 1.3rem;            
    font-weight: 700;
    line-height: 1.2;
    color: #fff;  
}

.cpappbth {
  background-color: #ced3b4 !important;
  padding: .1rem 7px !important; 
}

