* {
  box-sizing: border-box;
}

@font-face {
    font-family: 'Roboto';
    src: url('../font/RobotoCondensed-Bold.woff2') format('woff2'),
        url('../font/RobotoCondensed-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Roboto';
    src: url('../font/RobotoCondensed-Light.woff2') format('woff2'),
        url('../font/RobotoCondensed-Light.woff') format('woff');
    font-weight: light;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-Light.woff2') format('woff2'),
        url('../font/LibreFranklin-Light.woff') format('woff');
    font-weight: 300;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-BoldItalic.woff2') format('woff2'),
        url('../font/LibreFranklin-BoldItalic.woff') format('woff');
    font-weight: bold;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-ExtraBold.woff2') format('woff2'),
        url('../font/LibreFranklin-ExtraBold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-BlackItalic.woff2') format('woff2'),
        url('../font/LibreFranklin-BlackItalic.woff') format('woff');
    font-weight: 900;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-ExtraBoldItalic.woff2') format('woff2'),
        url('../font/LibreFranklin-ExtraBoldItalic.woff') format('woff');
    font-weight: bold;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-ExtraLightItalic.woff2') format('woff2'),
        url('../font/LibreFranklin-ExtraLightItalic.woff') format('woff');
    font-weight: 200;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-Italic.woff2') format('woff2'),
        url('../font/LibreFranklin-Italic.woff') format('woff');
    font-weight: normal;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-Bold.woff2') format('woff2'),
        url('../font/LibreFranklin-Bold.woff') format('woff');
    font-weight: bold;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-LightItalic.woff2') format('woff2'),
        url('../font/LibreFranklin-LightItalic.woff') format('woff');
    font-weight: 300;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-Black.woff2') format('woff2'),
        url('../font/LibreFranklin-Black.woff') format('woff');
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-ExtraLight.woff2') format('woff2'),
        url('../font/LibreFranklin-ExtraLight.woff') format('woff');
    font-weight: 200;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-ThinItalic.woff2') format('woff2'),
        url('../font/LibreFranklin-ThinItalic.woff') format('woff');
    font-weight: 100;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-SemiBoldItalic.woff2') format('woff2'),
        url('../font/LibreFranklin-SemiBoldItalic.woff') format('woff');
    font-weight: 600;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-Medium.woff2') format('woff2'),
        url('../font/LibreFranklin-Medium.woff') format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-SemiBold.woff2') format('woff2'),
        url('../font/LibreFranklin-SemiBold.woff') format('woff');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-Thin.woff2') format('woff2'),
        url('../font/LibreFranklin-Thin.woff') format('woff');
    font-weight: 100;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-MediumItalic.woff2') format('woff2'),
        url('../font/LibreFranklin-MediumItalic.woff') format('woff');
    font-weight: 500;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'Libre Franklin';
    src: url('../font/LibreFranklin-Regular.woff2') format('woff2'),
        url('../font/LibreFranklin-Regular.woff') format('woff');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}


body {
  font-family: "Roboto", sans-serif; letter-spacing: 1px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.wholepage {
  max-width: 1240px;
  margin: auto;
  background: white;
}


a {
    text-decoration: none;
    color: #000000;

}

a:hover {
   color: #cbcbcb;
}

.four-container {
  position: relative;
  width: 100%;
  max-width: 1215px; 
  height: 100vh;
  display: grid;
  grid-template-columns: 50% 50%;
  grid-gap: 20px;
}

.eight-container {
  position: relative;
  width: 100%;
  max-width: 1215px; 
  display: grid;
  grid-template-columns: 25% 25% 25% 25%;
  grid-gap: 10px;
}

.ten-container {
  position: relative;
  width: 100%;
  max-width: 1215px; 
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(17%, 1fr));
  grid-gap: 20px;
}

.square-container {
  position: relative;
  width: 100%;
  max-width: 1215px; 
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(30%, 1fr));
  grid-gap: 40px;
}

.nogap-container {
  position: relative;
  width: 100%;
  max-width: 1215px; 
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(9%, 1fr));
  grid-gap: 1px;
}

.overview-container {
  position: relative;
  width: 100%;
  max-width: 1215px; 
  display: grid;
  grid-template-columns: 33.33% 66.66%;
  align-items: baseline;
}

.story-container {
  position: relative;
  left: 50%;
  transform: translate(-50%);
  width: 100%;
  max-width: 750px; 
  font-family: "Libre Franklin";
  font-weight: 300;
}

.text-container {
  position: relative;
  width: 100%;
  max-width: 1215px; 
}

.text-container p {
  font-family: "Libre Franklin";
  font-weight: 300;

}

.logo-container {
  position: relative;
  top: 0;
  right:0;
  left: 60;
  bottom: 0;
  text-align: right;
  margin-top:-5px;
  width: 100%;
  max-width: 1215px; 
}

.headline-container {
  position: relative;
  width: 100%;
  max-width: 1215px; 
  font-size: 4vmin;
  float: left;
  line-height: 1.25;
  column-span: all;
  word-wrap: break-word;
  word-break: break-word;

}

.headright-container {
  position: relative;
  width: 100%;
  max-width: 1215px; 
  font-size: 4vmin;
  float: right;
  line-height: 1.25;
  column-span: all;
  word-wrap: break-word;
  word-break: break-word;

}

.storyhead-container {
  position: relative;
  left: 50%;
  transform: translate(-50%);
  width: 100%;
  max-width: 750px; 
  font-size: 7vmin;
  float: left;
  line-height: 1.25;
  margin-left: -6px;
  margin-top: -21px;
  column-span: all;
  word-wrap: break-word;
  word-break: break-word;

}
.port-container {
  position: relative;
  width: 100%;
  max-width: 694px; 
}

.square {
  padding-top: 100%; /* padding trick directly on the grid item */
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
}

.notsquare {
  padding-top: 100%; /* padding trick directly on the grid item */
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
}

.image {
  padding-top: 100%; /* padding trick directly on the grid item */
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
}

.dayimage {
    width:100%;
    height:100%;
    object-fit: none;
    object-position: center;
}
    
.square .content { /* absolutely positioned */
  position: absolute;
  top: 0;
  right:0;
  left: 0;
  bottom: 0;
}

.notsquare .content { /* absolutely positioned */
  position: absolute;
  top: 0;
  right:0;
  left: 0;
  bottom: 0;
}

.overview {
  padding-top: 100%; /* padding trick directly on the grid item */
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
  background-color="#00FFFF"
}

.overview .contentcol {
  position: absolute;
  top: 0;
  right:0;
  left: 0;
  bottom: 0;
  
}

.overview .content {
  position: absolute;
  top: 0;
  right:0;
  left: 0;
  bottom: 0;
}

.adr {
    position: absolute;    
    top: 50%;
    left: 50%;
    transform:translate(-50%,-50%); 
    text-align: center;
    max-width: 50%; 

}

.square:hover .overlay {
  position: absolute;
  top: 0;
  right:0;
  left: 0;
  bottom: 0;
  opacity: 1;
}

.overview:hover .overlay {
  position: absolute;
  top: 0;
  right:0;
  left: 0;
  bottom: 0;
  opacity: 1;
}


.text-right {
  position: relative;
  width: 100%;
  max-width: 1215px; 
  padding-left: 20px;

}

p {
  font-size: 13px;
  line-height: 2;
  float: left;
  width: 100%;
  color: black;
}

h5 {
  font-size: 2vmin;
  float: left;
  letter-spacing: 0px;
}

.headlines {
  font-size: 20px;
  float: left;
  width: 100%;
  letter-spacing: 1px;
  column-span: all;
}

p.intro {
  font-size: 14px;
  line-height: 2;
   float: left;
  width: 100%;
 color: black;
   font-weight: bold;
}

p.kunden {
  font-size: 14px;
  line-height: 3;
   float: left;
  width: 100%;
 color: black;
}

p.overviewtext {
  font-size: 14px;
  line-height: 1.5;
  float: left;
  width: 100%;
  color: black;
}

p.line {
  border-bottom: 1px solid black;
}

p.opa {
opacity: 1;
}

p.logo {
text-align:right;
font-size:14px;
}

span.title {
	 /* text-align: right; */
}

.crop-center {
    height: 100%;
    width: 100% !important;
    object-fit: cover;
    object-position: center;
}

.fit {
    height: 100%;
    width: 100% !important;
    max-width: 1215px;
    object-fit: contain;
    
}

.overlay {
  position: absolute; 
  background: rgb(255, 255, 255);
  background: rgba(255, 255, 255, 0.8);
  color: #f1f1f1; 
  width: 100%;
  transition: .35s ease;
  opacity:0;
  color: black;
  font-family: "Libre Franklin";
  font-size: 12px;
  padding: 10px;
  text-align: center;
  
}

.figure {
  color: black;
  font-family: "Libre Franklin";
  font-size: 11px;
  text-transform: uppercase;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  text-align: center;
  
}

span.m {
  position: absolute;
  left: 5px;
  top: 0px;
  content: "\2261";
}

span.fontred {
  color: red
}

span.fontred:hover {
  color: #cbcbcb
}

span.kunden {
display: inline-block;
margin-left: 20px;  
font-size: 14px;
  line-height: 2.5;
   float: left;
  width: 100%;
 color: black;
}


        .sidebar {
            height: 100%;
            width: 25px;
            position: fixed;
            z-index: 1;
            background-color: white;
            overflow-x: hidden;
            transition: 0.5s;
            padding-top: 60px;
            padding-left: 5px;
            white-space: nowrap;
        }
        
        .sidebar a {
            padding: 8px 8px 8px 32px;
            text-decoration: none;
            font-size: 14px;
            color: #000000;
            display: block;
            transition: 0.3s;
        }
        
        .sidebar a:hover {
            color: #cbcbcb;
        }
        
        .sidebar .closebtn {
            position: absolute;
            top: 0;
            right: 15px;
            font-size: 36px;
            margin-left: 50px;
        }
        
        .icon-text {
            vertical-align: middle;
        }
        
        #main {
            transition: margin-left .5s;
            padding: 16px;
            margin-left: 30px;
        }

        /* On smaller screens, where height is less than 450px, change the style of the sidenav (less padding and a smaller font size) */
        
@media screen and (max-width: 450px) {
.sidebar {
box-shadow: 1px 2px;
width: 33px;
}
   
  .square-container {
   position: relative;
   width: 100%;
   max-width: 450px; 
   display: grid;
   grid-template-columns: repeat(1, minmax(0, 1fr));
   }

  .four-container {
   position: relative;
   width: 100%;
   max-width: 450px; 
   display: grid;
   grid-template-columns: repeat(1, minmax(0, 1fr));
   }

.nogap-container {
  position: relative;
  width: 100%;
  max-width: 1215px; 
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(29%, 1fr));
  grid-gap: 1px;
}

p.overviewtext {
  font-size: 12px;
}

p.kunden {
  font-size: 12px;
  line-height: 2;
   float: left;
  width: 100%;
 color: black;
}

span.kunden {
  font-size: 12px;
  line-height: 2;
   float: left;
  width: 100%;
 color: black;
}

.porthead {
font-size:7vmin;
float:left;
color:white;
}

.porttext {
font-size:5vmin;
line-height:1.5;
float: left;
color:white;
}

p.logo {
  font-size: 3vmin;
}

.overview {
  padding-right: 10px;
}

.headline-container {
  width: 100%;
  max-width: 1215px; 
  font-size: 8vmin;
  margin-top: 0px;
  margin-left: 0px;
  letter-spacing: 1px;

}

.logo-container {
  position: relative;
  top: 0;
  right:0;
  left: 60;
  bottom: 0;
  text-align: right;
  margin-top:-5px;
  width: 100%;
  max-width: 1215px; 

}

.storyhead-container {
  width: 100%;
  max-width: 750px; 
  font-size: 12vmin;
  margin-top: 0px;
  margin-left: 0px;
  letter-spacing: 1px;
    word-wrap: break-word;
  word-break: break-word;


}

.figure {
  color: black;
  font-size: 10px;
  text-transform: uppercase;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  text-align: center;
  
}


        }

@media only screen and (min-width: 200px) and (max-width: 1100px) {
       
p.kunden {
  font-size: 12px;
  line-height: 2;
   float: left;
  width: 100%;
 color: black;
}

.logo-container {
  font-size: 5vmin;

}

.nogap-container {
  position: relative;
  width: 100%;
  max-width: 1215px; 
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(24%, 1fr));
  grid-gap: 1px;
}

@media only screen and (min-width: 200px) and (max-width: 2500px) {

.porthead {
font-size:5vmin;
color:white;
}

.porttext {
font-size:3vmin;
line-height:1.5;
color:white;
}

h5 {
  font-size: 7vmin;
}

.logo-container {
  font-size: 2vmin;

}

}
