/*@import "Schrift.css";*/
/* 
    Created on : 30.12.2024, 16:35:26
    Author     : Josef
*/

/*******************************************************/
/*Grundeinstellungen  und allgemeine Formate           */
/*******************************************************/

*
{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
:root
{
    /*################# Fonts ########################*/
    --font-base: 'Source Sans 3', sans-serif;
    --font-heading: 'Source Sans 3', sans-serif;
    
    --weight-normal: 400;
    --weight-bold: 600;
    
    --font-schnitt-normal: .01rem;
    --font-schnitt-geperrt: .8rem;
    
    /*############ Seiteneinstellungen ###############*/
    --seiteninhaltbreite_max:950px;
    --seiteninhaltbreite_min:250px;
    --menuebreite: 80%;
     
    /*############ Farben ############################*/
    --schrift-farbe:white; /*#3f3943;*/
    --fg-color: var(--schrift-farbe);
    --fg-link: var(--schrift-farbe);
    --fg-ueberschrift: #98B3D0;
    --bk-color: #3f3943; /*#f8faD5; #efe8cd;*/
    
    /* Downloadlink*/
    --fg-download-link:#0000f0;
    
    /*############ Schrift Farben ###################*/
   
    --wichtig-color:#ff20ff;  
    --achtung-color:#FF0000;
    --paragraph-col: var(--bg-header);
    --fg-Ueberschrift1: var(--schrift-farbe);
    --fg-Ueberschrift2: var(--schrift-farbe);
    
    /* dito Mobil */
    --bk-color-mobil: #efe8cd ;
    
    --bg-SliderTextbox:  #98B3D000;
     
 
    
    /* Navigations-Variablen */
    /* ####################normales Menue###################*/
    
    --fg-navi-hauptmen-col:#000000;/*Normaler Vordergrund Hauptmenue */
    --bg-navi-hauptmen-col:#ffffff; /*Normaler Hintergrund Hauptmenue transparent*/ 
    --fg-navi-hauptmen-hov-col:#FFFFFF;/*wie normaler Vordergrund Hauptmenue hover auch schwarz*/
    --bg-navi-hauptmen-hov-col:#ffffff00;/*wie normaler Hinterdergrund Hauptmenue hover transparent*/
    
    --fg-navi-sub-men-col:#000000;  /* normales Submenue Vordergrund*/
    --bg-navi-sub-men-col:#F0F0F0;/* normales Submenue Hintergrund*/
    --fg-navi-sub-hov-col:#ffffff;  /* normales Submenue hover Vordergund*/
    --bg-navi-sub-hov-col:#000000;  /* normales Submenue hover Hintergund*/
    
    --fg-nav-ul-li-a-hover:#000000;/* Normales Navi List... Link Hover Hintergund */
    
    /* ####################### Navigation Mobile ##################*/
    --HamburgerMemue-off-col:#00f0f0;
    --HamburgerMemue-on-col:#ff00D8;
    
    --fg-mobil-hauptmen-link-col:#0040e0; /*Mobile Einzel-Link Vordergrund*/
    --fg-mobil-hover-col:#ffffff;         /*Mobile hover Vordergrund*/
    --bg-mobil-hover-col:#606060;         /*Mobile hover hintergrund*/
    --fg-mobil-hauptmen-sub-col:#f000f0;/*0020f0; Eintrag Ueberschrift des Submenues Vordergrund*/
    --bg-mobil-menueplane-col: #F0F0F0; /*Eintrag Ueberschrift des Submenues Hintergrund*/
    --fg-mobil-submen-hover-col:#000000;
    --bg-mobil-submen-hover-col:#000000;  
    
    --fg-MobilLinkColor:#000000; /*#8B2323;*/
    --fg-MobilSubMenueColor:#ff9000;
  
    --br-MobilNav-col:#ffffff; /*Das ist der hintergund für das ganze Mobile Menue*/

    /* Kopf-Variablen */
    /*hsl(60,100%,50%); #efe8cd;*/
    --bg-header: #98B3D0;
    --fg-header:#000000;
    
    /* Fussvariablen */
    --bg-footer:#98B3D0;
    --fg-footer: #000000;
    --fg-footer-link: #000000;
}
/*********************************************************************************************/
.angebote-details summary 
{
    font-size: 1.2rem;
    font-weight: bold;
    cursor: pointer;
    padding: 0.5rem 1rem;
    background-color: #040404;
    border-radius: 5px;
    margin-bottom: 1rem;
    user-select: none;
}

/*.angebot-boxen 
{
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
}

.angebot {
    border: 1px solid #fff;
    padding: 1rem;
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0,f,f,0.05);
}

.angebot-boxen {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1rem;
    padding: 1rem;
}

.angebot {
    padding: 1rem;
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}

###########################################################
.angebot-boxen {
    column-count: 1;
    column-gap: 1rem;
    padding: 1rem;
}

@media (min-width: 600px) {
    .angebot-boxen {
        column-count: 3;
    }
}

@media (min-width: 900px) {
    .angebot-boxen {
        column-count: 4;
    }
}

.angebot {
    padding: 1rem;
    border-radius: 8px;
    margin-bottom: 1rem;
    display: inline-block;
    width: 100%;
    box-sizing: border-box;
}
*/

.angebot-gruppe {
    margin-bottom: 0.5rem;
}

.gruppen-titel {
    font-size: 1.1rem;
    font-weight: bold;
    margin: 0 0 0.5rem;
    color: #98b3d0;
    border-bottom: 2px solid #ccc;
}

.angebot-boxen {
    column-count: 1;
    column-gap: .5rem;
}

@media (min-width: 400px) {
    .angebot-boxen {
        column-count: 2;
    }
}


@media (min-width: 650px) {
    .angebot-boxen {
        column-count: 3;
    }
}

@media (min-width: 900px) {
    .angebot-boxen {
        column-count: 4;
    }
}

.angebot {
    background: #f9f9f9;
    border: 1px solid #ccc;
    padding: 1rem;
    border-radius: 8px;
    margin-bottom: 1rem;
    display: inline-block;
    width: 100%;
    box-sizing: border-box;
}
/***********************************************************************************************/
.ankauf
{
    display:inline-block;
    margin-left: 0;
    margin-right: 0;
}

/**********************************************************************************************/

h1,h2,h3
{
  font-family: var(--font-heading);
  font-weight: var(--weight-bold);
  color: var(--schrift-farbe);
}
h3
{
    font-size: 1.4rem;
}

p
{
  font-family: var(--font-base);
  font-weight: var(--weight-normal);  
  color: var(--schrift-farbe);
}

.slideshow {
    padding-top: 10px;
    position: relative;
    max-width: 600px;
    width: 100%;
    margin: 0 auto;
    /*cursor: pointer;*/
  
}

.beschraenkteSeite
{
    padding-top: 10px;
    position: relative;
    max-width: 750px;
    width: 100%;
    margin: 0 auto; 
}

.slide {
    z-index: 101;
    display: none;
    cursor: pointer;
}

.silder_img 
{
    max-width: 100%;
    border-radius: 10px;
    display: block;       /* Verhindert zusätzlichen Leerraum unter den Bildern */
    width: 100%;          /* Passt das Bild an die Breite des Containers an */
    height: auto;         /* Beibehaltung des Seitenverhältnisses */
    margin: 0 auto;
}

.slidetxtContainer
{
    display: flex;
    justify-content: center;  /* Zentriert den Block horizontal */
    margin-top: .4rem;
    margin-bottom: 3rem;
    margin-left: 0;
    margin-right: 0;
    font-size: 14px;
    background: var(--bg-SliderTextbox);
    padding-top: 10px;
    padding-bottom: 10px;
    border-radius: 1vw;
    white-space: pre-line;
}

.silder_p {
   
    color: var(--fg-color);
    font-weight: var(--weight-bold);
    display: inline-block;    /* Der Block passt sich in Breite und Höhe dem Text an */
    text-align: left;         /* Text innerhalb des Blocks ist linksbündig */
    line-height: 0.8; 
}

.sliderbutton 
{
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.4s ease;
    position: absolute;
    top: 40px;
    transform: translateY(-50%);
    background: rgba(0, 0, 0, 0.5);
    color: white;
    border: none;
    font-weight: bold;
               /* Padding relativ zur Bildschirmbreite */
    cursor: pointer;
    font-size: 15px;         /* Schriftgröße relativ zur Breite des Bildschirms */
    width: 50px;            /* Button-Breite relativ zur Breite des Bildschirms */
    height: 35px;           /* Button-Höhe relativ zur Breite des Bildschirms */
  
    border-radius: 40%; 
}

.sliderbutton.visible {
    opacity: 1;
    visibility: visible;
}



.prev { left: 1vw; }
.next { right: 1vw; }
/*************************************************************************************************/

main 
{
    display: inline;
   
}

/*******************************************************/
/*Der body Tag                                         */
/*******************************************************/
body
{
    font-family: var(--font-base);
    text-rendering: optimizeLegibility;
    position:relative;
    background-color: var(--bk-color) ;
    /*max-width:  var(--seiteninhaltbreite_max);
    min-width: var(--seiteninhaltbreite_min);*/
    color: var(--schrift-farbe);
    font-size:12.0pt ;
    font-weight: 500;
    letter-spacing: 0.05em;
    margin-right: auto;
    margin-left: auto;
    letter-spacing: 0.01em;
}

/*******************************************************/
/* Formatierungen Grundeinstellungen fuer Seiten       */
/* diese werden für die verschiedenen Seitenformate    */
/* durch die Media Aweissung jeweils überschrieben     */
/*******************************************************/

header
{   
    display: block;
    width: 100%;
    height: auto;
    padding-bottom: 0.25rem;
    margin-left: auto;
    margin-right: auto;
    margin-top:0.5rem;
   /* margin-bottom: 2.5rem;
    background-color: #f0f000;*/
}

.rslogo
{
    margin-left: auto;
    margin-right: auto;
    margin-bottom: .5rem;
    margin-top: .5rem;
  /*  background-color: var(--bk-color) ;*/
}
.imground
{
    border-radius: .5rem;
}

.logoimgcenter
{
  display: block;
  margin-left: auto;
  margin-right: auto;
  width: 50%;
  height: auto;
  padding-top: 1%;
}


.logoimg
{
    width: auto;
    height: auto;
    opacity: 0.7;
    max-width: 100%;
    max-height: 100%;
}

/******************************************************/
/*Seiteneinstellungen                                 */
/******************************************************/
/*Layout der Seite Rand 5% links und Rechts so wie beschränkung auf --seiteninhaltbreite_max */
.seitenkopf
{
    width: 100%;
    height: auto;
    /*padding-top: 2.5rem;*/
    /*max-width:  var(--seiteninhaltbreite_max);
    min-width: var(--seiteninhaltbreite_min);*/
    margin-bottom: 1.0rem;
    margin-top: 0.3rem;
    margin-left:auto;
    margin-right: auto;
    /*position:absolut; */
    background-color: var(--bg-header);
    border-radius: .35rem
}

.Seitenlayout
{
    width: 100%;
    margin-left: auto; 
    margin-right: auto; 
    margin-bottom: 0;
}
.Seiteneinleitung
{
    font-family: var(--font-base);
    color: var(--schrift-farbe);
    font-size: 0.9rem;
}

.Seiteninhalt
{
    width:94%;
    padding-top: 0.7rem;
    padding-bottom: 0;
   /* max-width:  var(--seiteninhaltbreite_max);
    min-width: var(--seiteninhaltbreite_min);*/
    margin-bottom: 0;
    margin-top: 0;
    margin-left:auto;
    margin-right: auto;
    /*position:relative;
    background-color: #90909000;*/
}


/*###########################################################################*/
/* Regeln+++ */

.Rand5Prozent
{
    padding-left: 5%;
    padding-right: 5%;
}
/*Seiten-Ueberschrift*/ 
.r-s-ueberschrift1
{
    height: auto;
    font-family: var(--font-base);
    font-weight: 700;
    margin-bottom: 1rem;
    font-size: 1.5rem;
    color: var(--fg-Ueberschrift); 
}

/*Seiten-Unterueberschrift*/
.r-s-ueberschrift2
{
    height: auto;
    font-family: var(--font-base);
    font-weight: 600;
    font-size: 1.3rem; 
    color: var(--fg-Ueberschrift);
} 

.r-s-ueberschrift1zentriert
{
    height: auto;
    font-family: var(--font-base);
    font-weight: 700;
    margin-bottom: 1rem;
    font-size: 2.2rem;
    color: var(--fg-Ueberschrift); 
    text-align: center;
}

.elementzentrieren
{
    margin-right: auto ;
    margin-left: auto ;
}

.Ueberschrift 
{
    text-justify: auto ;
    text-align:justify;
    -moz-hyphens: auto;
    -o-hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto; 
    font-family: var(--font-base);
    font-size: 1.5rem;
    line-height: 1.1;
    margin-top: 1.9rem ;
    margin-bottom: 0.8rem ;
    color: var(--schrift-farbe);
    
}


.Subtitelschrift 
{
    /*text-justify: auto ;*/
    /*text-align:justify;*/
    -moz-hyphens: auto;
    -o-hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto; 
    font-family: var(--font-base);
    font-size: 1.00rem;
    line-height: 1.08;
    margin-top: 0.5rem ;
    /*margin-bottom: 0.1rem ;*/
    color: var(--schrift-farbe);
    
}


/*

.Ueberschrift
{
    font-family: var(--font-base);
    text-align: center;
    margin-top: 0.3rem;
    margin-bottom: 1rem;
    font-size: 1.65rem;
    width: 90%;
    color: var(--fg-Ueberschrift); 
}
*/
.Ueberschrift_center
{
    text-align: center;
    -moz-hyphens: auto;
    -o-hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto; 
    font-family: var(--font-base);
    font-size: 1.1rem;
    line-height: 1.1;
    margin-top: 1.9rem ;
    margin-bottom: 0.8rem ;
    color:  var(--fg-Ueberschrift); 
    
}


.Ueberschrift1{
    margin-right:-2.25pt;
    text-align: left;
    font-size:16.0pt;
    line-height:100%;
    color:  var(--fg-Ueberschrift); 
    font-weight:500;
    margin-bottom: 8px;
    -moz-hyphens: auto;
    -o-hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto; 
}

.Ueberschrift2{
    font-size:12.0pt;
    /*line-height:130%;*/
    color:  var(--fg-Ueberschrift); 
    font-weight:500;
    padding-bottom: 5px;
    -moz-hyphens: auto;
    -o-hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto; 
}

/* Paragraph Überschrift linklsbündig*/
.Paragraph
{
    margin-right:-2.25pt;
    text-align:justify;
    font-size:14.0pt;
    line-height:100%;
    color: var(--paragraph-col);
    padding-bottom: 3px;
    -moz-hyphens: auto;
    -o-hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto; 
}

/* Paragraph Überschrift zentrisch*/
.ParagraphCenterNormal
{
    margin-right:-2.25pt;
    text-align:center;
    font-size:14.0pt;
    color: var(--paragraph-col);
}

.ParagraphCenter
{
    margin-right:-2.25pt;
    text-align:center;
    font-size:14.0pt;
    line-height:100%;
    color: var(--paragraph-col);
}

.Bildseite
{
    width: 100%;
    height: auto;
}

.column {
  float: left;
  width: 50%;
}

/* Clear floats after the columns */
.row:after {
  content: "";
  display: table;
  clear: both;
}
/* Kontakte */
.Kontakteflex
{
    display: flex;
    width: 100%;
    flex: 1;
    flex-wrap: wrap;
    justify-content: space-evenly;
}

.Kontakte2Spaltenrechts
{
    flex-basis: 45%;
    max-width: 45%;
    min-width: 220px;
    height:100%;
    align-items: start;
    flex-direction: row;
   /* border: 2px solid red;
    background: yellow;*/
}

.Kontakte2Spaltenlinks
{
    flex-basis: 45%;
    max-width: 45%;
    min-width: 200px;
    height:100%;
    align-items: end;
}

/************************************* Hierher alles zum Fuss */

    .footer-line {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 1em;
        margin: 0.4em 0;
    }

    .footer-line a {
        white-space: nowrap;
        font-family: var(--font-base);
        font-size: .9rem;
        font-weight: 700;
        text-decoration: underline;
        color: var(--fg-footer-link);
    }

    .footer-text {
        margin: 0.3em 0;
    }
    
footer
{
    font-size: 0.9em;
    padding-left: 0;
    padding-right: 0;
    padding-top: 10px;
    padding-bottom: 15px;
    text-align: center;
    width:100%;
    height: auto;
    background-color: var(--bg-footer);
    color: var(--fg-footer);
    border-radius: .3rem; 
    display: inline-block;
    
    position: static; 
    margin-bottom: 1rem;
    margin-top: 1rem;
    font-family: var(--font-base);
    font-weight: 600;
    letter-spacing: 0.06rem;
  
}

footer a
{ 
    font-family: var(--font-base);
    font-size: .9rem;
    font-weight: 700;
    text-decoration: underline;
    color: var(--fg-footer-link);
    
  
}

.flexfuss
{
    display: flex;
    width: 100%;
    flex: 1;
    flex-wrap: wrap;
    justify-content: space-between;
    justify-items: center;
}

.fussverlinkung_links
{
    flex-basis: 50%;
    max-width: 50%;
    min-width: 75px;
    height:100%;
   
}

.fussverlinkung_rechts
{
    flex-basis: 50%;
    max-width: 50%;
    min-width: 75px;
    height:100%;
}

.fussinfo_links
{
    width:100px;
}

.fussinfo_rechts
{
    width:100px;
}
/*****************************************************/
.fliesstext
{
    font-family: var(--font-base);
    font-size: 100%;
    font-weight: lighter;
}

.KontaktEinruecken
{
    padding-left: 2px;
}

.Kontaktkathegogie
{
    font-family: var(--font-base);
    font-weight: 600;
    font-size: 125%;
}


.fliesstextcolor
{
    color: var(--schrift-farbe);
}

.wichtig
{
    font-weight: 500;
    color: var(--wichtig-color); 
}

.kursiv
{
    font-style: italic;
}

.wichtigtext
{
    font-weight: lighter;
    color: var(--wichtig-color); 
}

.mittig
{
    text-align: center;
}

.InfoKopf
{
    font-weight: 600;
}

.InfoRumpf
{
    padding-left: 5px; 
}

.radius-medium 
{
  border-radius: .5rem;
  float:left;
  margin-right: 10px;
}

.radius
{
  border-radius: .6rem;
}

.einruecken
{
    margin-left: 20pt
}


/*******************************************************/
/*Links                                                */
/*******************************************************/
a 
{
    color: var(--fg-link);
    font-weight: 500;
}

h4
{
    margin-top:0px;
    margin-bottom:15px;
}

video
{
    width: 100%;
    height: auto;
    border-radius:15px
}

/*Blocksatz fuer Texte*/
.Blocksatz
{
    text-justify: auto ;
    text-align:justify;
    -moz-hyphens: auto;
    -o-hyphens: auto;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    hyphens: auto; 
}

.Downloadlinks{
    color: var(--fg-download-link); 
    text-align:center;
    text-decoration: underline;
    font-weight:500;
}

.clear
{
    width: 0;
    height: 0;
    clear: both;
}

.displayCenter
{
    padding-top: 10px;
    display: block;
    margin-left: auto;
    margin-right: auto;
    width:60%;
    padding-bottom: 8px;
}

/************************************************************/
/* EintragsDiv Eintragszeile                                */
/************************************************************/

.EintragsDiv
{
    float:left;
    width: 100%;
    height:auto;
}

.Videodiv
{
    margin-right:.7rem;
    margin-left: -2rem;
    width:350px; 
    height:250px; 
    border-radius: .5rem; 
    background: black;
}

.EintragsDiv figure
{
    margin-right:.7rem;
    margin-left: -2rem;
    width:350px; 
    height:250px; 
    clear: both;
    float: left;
}

.EintragsDiv figure figcaption
{
    text-align: center;
}

.EintragsDiv figure img
{ 
    border-radius: .5rem; 
    width:340px; 
    height:190px; 
}

.EintragsDiv .Videodiv
{
    margin-right:.7rem;
    margin-left: -2rem;
    margin-bottom: .7rem;
    width:340px; 
    height:250px; 
    padding: 5px;
    float: left;
    background: black;
}

.EintragsDiv > p
{
  font-family: var(--font-base);
  font-size: 0.9rem;
  line-height: 1.1;
  margin-top: .2rem ;
  color: var(--schrift-farbe);
}


.SchriftFarbe
{
 color: var(--schrift-farbe);   
}




.font-0 {
   font-size: 0
}

.font-base {
   font-size: 1.8rem
}

.font-xxsmall {
   font-size: 1.3rem
}

.font-xsmall {
   font-size: 1.4rem
}

.font-small {
   font-size: 1.5rem
}

.font-medium {
   font-size: 2rem
}

.font-large {
   font-size: 2.5rem
}

.font-xlarge {
   font-size: 3.5rem
}

.font-xxlarge {
   font-size: 4.2rem
}

.font-huge {
   font-size: 5.2rem
}

.kontaktetxt
{
    color: rgba(255, 245, 210, 0.8);
    font-weight: 400;
    font-size: 1.25rem;
}

.mdiv {
 margin: 0;
 padding: 2rem;
 display: flex;
 justify-content: center;
}

.wrapper {
 display: grid;
 grid-auto-flow: column;
 grid-auto-columns: max-content;
 gap: 2rem;
}

.block {
    color:yellow;
  padding: 0 1.5rem 0 1.5rem;
  text-align: left;
}

@media (max-width: 700px) {
  .wrapper {
    grid-auto-flow: row;
    grid-auto-columns: unset;
    grid-template-columns: 1fr;
    gap: 0;
  }

  .block {
    width: 100%;
  }
}



