@charset "UTF-8";

/*------------------------------------*\
    #FONT FACE SETTINGS
\*------------------------------------*/

/*
 * Legal Disclaimer
 *
 * These Fonts are licensed only for use on these domains and their subdomains:
 * katjaschloz.de
 *
 * It is illegal to download or use them on other websites.
 *
 * While the @font-face statements below may be modified by the client, this
 * disclaimer may not be removed.
 *
 * Lineto.com, 2017
 */

@font-face {
  font-family: 'Circular';
  src: url('../fonts/circular/lineto-circular-book.eot');
  src: url('../fonts/circular/lineto-circular-book.eot?#iefix') format('embedded-opentype');
 font-weight: normal;
 font-style: normal;
}

@font-face {
  font-family: 'Circular';
  src: url('../fonts/circular/lineto-circular-bold.eot');
  src: url('../fonts/circular/lineto-circular-bold.eot?#iefix') format('embedded-opentype');
 font-weight: bold;
 font-style: normal;
}

/*------------------------------------*\
    #PSEUDO CLASSES
\*------------------------------------*/

::selection {
  background: rgba(128,128,128,.25); 
}
::-moz-selection {
  background: rgba(128,128,128,.25); 
}

/*------------------------------------*\
    #GENERAL SETTINGS
\*------------------------------------*/

* {
  border: 0px;
  margin: 0px;
  padding: 0px;
    
  text-decoration: none;
  text-rendering: optimizeLegibility;
  
  -webkit-tap-highlight-color: rgba(255,255,255,0);
  
  -webkit-font-smoothing: antialiased;
  
  word-wrap: break-word;
  
  font-family: "Circular", Helvetica, Arial, sans-serif;
  font-weight: normal;
  font-style: normal;
    
  color: rgba(0,0,0,1);
  
  font-size: 1em;
  line-height: 1;
  
  text-transform: none;
  
  
}

/*------------------------------------*\
    #LINKS
\*------------------------------------*/

a {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  font-style: inherit;

  line-height: inherit;
  
  letter-spacing: inherit;
  color: inherit;
  
  text-transform: inherit;
  
  cursor: pointer;
}

/*------------------------------------*\
    #SPAN, BOLD, ITALIC
\*------------------------------------*/

span, strong, em, b, i {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  font-style: inherit;

  line-height: inherit;
  
  letter-spacing: inherit;
  color: inherit;
  
  text-transform: inherit;
  
}

b { font-weight: bold; }
i { font-style: italic; }

/*------------------------------------*\
    #BUTTONS
\*------------------------------------*/

button {
  background: transparent;
  outline: none;
  border: 0;
  border-radius: 0;
  cursor: pointer;
  font-weight: inherit;
}


/*------------------------------------*\
    #LISTS
\*------------------------------------*/

ul, li {
  list-style: none;
}

/*------------------------------------*\
    #LAYOUT
\*------------------------------------*/


/*--- general view -------------------*/

.view {
  position: fixed;
  left: 0%;
  top: 0%;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.view.scrollable { 
  width: 100%;
  padding: 0;
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;
}

.view.absolute { 
  position: absolute;
}

.view.relative { 
  position: relative;
  height: auto;
}

.view#imprint {
  z-index: 200;
  display: none;
}

/*--- vertical centered -------------*/
/*--- container         -------------*/

.container--v-center {
  position: absolute;
  display: block;
  top: 0%;
  left: 0%;
  width: 100%;
  height: 100%;
}

.container--v-center.scrollable {
  overflow-y: scroll;
}

.v-center--outer {
  display: table;
  width: 100%;
  height: 100%;
}

.v-center--inner {
  display: table-row;
  width: 100%;
  height: 100%;
}

.v-center {
  display: table-cell;
  vertical-align: middle;
}


/*--- container corner ---------------*/

.container--corner {
  z-index: 2;
  position: fixed;
}

.container--corner.top-left  { top: 0; left: 0; }
.container--corner.top-right { top: 0; right: 0; }

.container--top,
.container--bottom {
  z-index: 2;
  position: fixed;
  width: 100%;
  left: 0;
  box-sizing: border-box;
}

.container--top    { top: 0; }
.container--bottom { bottom: 0; }

/*--- content-frames -----------------*/

.c-frame {
  position: relative;
  overflow: hidden;
  margin: 0 auto;
  box-sizing: border-box;
  width: 100%;
}

.c-frame.frame-s {
  width:  85%; 
  min-width: 20em; 
  max-width: 40em;
}

.c-frame.frame-m {
  width:  85%; 
  min-width: 20em; 
  max-width: 80em;
}
	
/*--- columns ------------------------*/

.column {
  position: relative;
  overflow: hidden;
  margin: 0 auto;
  box-sizing: border-box;
  width: 100%;
}

.column.half    { width: 50%; }
.column.third   { width: 33.33%; }
.column.quarter { width: 25%; }

/*------------------------------------*\
    #TEXT FORMATS
\*------------------------------------*/
	
/*--- headlines ----------------------*/

h1, h2, h3, h4, h5, h6 {
  margin: 0 auto;
  font-weight: normal;
  font-style: normal;
  font-variant: normal;
  text-align: left;
  transition: color .2s;
}


/*--- paragraphs ---------------------*/

p {
  font-weight: normal;
  font-style: normal;
  font-variant: normal;
  text-align: left;
  transition: color .2s;
}

p a {
  border-bottom: 1px solid transparent;
  transition: border-color .2s;
}

p a:hover {
  border-bottom: 2px solid rgba(0,0,0,1);
}

/*--- list-item ----------------------*/

  li b { font-weight: bold; }

/*--- paragraphs ---------------------*/
/*--- inline images ------------------*/

img.inline {
  position: relative;
  display: block;
  margin: 0 auto;
  width: 100%;
}


/*------------------------------------*\
    #HEADER
\*------------------------------------*/

header {
  z-index: 4;
  position: fixed;
  top: 0;
  left: 0;
  width: 80%;
}

#button-contact,
#button-clients {
  border-bottom: 1px solid transparent;
  transition: border-color .2s;
}

#button-contact.is-active,
#button-contact:hover,
#button-clients.is-active,
#button-clients:hover {
  border-bottom: 2px solid;
}

.button-switch {
  width: 1em;
  height: 1em;
  border-radius: 1em;
  transition: background-color .2s;
}

.button-switch.neg {
  border-color: rgba(255,255,255,1) !important;
}

.button-switch:hover,
.button-switch.active {
  background-color: rgba(0,0,0,1);
}

.button-switch.neg:hover,
.button-switch.neg.active {
  background-color: rgba(255,255,255,1);
}

nav-switch {
  z-index: 2;
}

/*------------------------------------*\
    #MAIN
\*------------------------------------*/

#view-main {
  transition: background-color .2s;
}

.flickity-viewport {
  height: 100% !important;
}

.flickity-prev-next-button,
.flickity-prev-next-button:hover {
  background: transparent;
}

.flickity-prev-next-button {
  position: absolute;
  height: 100%;
  width: 50%;
  top: 0;
  transform: none;
}

.flickity-prev-next-button.previous { left: 0; }
.flickity-prev-next-button.next { left: 50%; }


.flickity-prev-next-button svg {
  top: 50%;
  width: 1.5em;
  height: 1.5em;
  margin-top: -.75em;
}

.flickity-prev-next-button.previous svg { left: 2em; }
.flickity-prev-next-button.next svg { left: auto; right: 2em; }


.flickity-prev-next-button .arrow {
  fill: rgba(0,0,0,1);
  transition: fill .2s;
}

.main-slideshow-slide {
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  border: 8em solid transparent;
  box-sizing: border-box;
}

  .main-slideshow-slide video {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    width: 100%;
  }

#view-shade {
  z-index: 2;
}


#view-contact {
  z-index: 3;
  transition: opacity .4s;
  cursor: pointer;
}

  #view-contact .column {
    cursor: default;
  }

  #container--button-close-contact {
    z-index: 100;
  }

#view-clients {
  z-index: 3;
  transition: opacity .4s;
  cursor: pointer;
}

  #view-clients .column {
    cursor: default;
  }

  #container--button-close-clients {
    z-index: 100;
  }

/*------------------------------------*\
    #APPENDABLE CLASSES
\*------------------------------------*/

.noselect {
  -webkit-touch-callout: none;
    -webkit-user-select: none;
     -khtml-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;
}

/*--- text-size ----------------------*/

.text-l { font-size: 2em; line-height: 1.4; letter-spacing: 0.005em; }
.text-m { font-size: 1.4em; line-height: 1.4; letter-spacing: 0.005em; }
.text-s { font-size: 1em; line-height: 1.5; letter-spacing: 0.005em; }

.text-underline { display: inline; border-bottom: 1px solid; }

/*--- colors -------------------------*/

.bg-blue   { background-color: rgba(0,0,255,1); }
.bg-red    { background-color: rgba(255,0,0,1); }
.bg-white  { background-color: rgba(255,255,255,1); }
.bg-black  { background-color: rgba(0,0,0,1); }

.bg-white-trans { background-color: rgba(255,255,255,0.9); }
.bg-black-trans { background-color: rgba(0,0,0,0.93); }

.c-blue  { color: rgba(0,0,255,1); }
.c-red   { color: rgba(255,0,0,1); }
.c-white { color: rgba(255,255,255,1); }
.c-black { color: rgba(0,0,0,1); }
.c-grey  { color: rgba(155,155,155,1); }

.bor-blue       { border-color: rgba(0,0,255,1); }
.bor-red        { border-color: rgba(255,0,0,1); }
.bor-white      { border-color: rgba(255,255,255,1); }
.bor-black      { border-color: rgba(0,0,0,1); }
.bor-grey       { border-color: rgba(155,155,155,1); }
.bor-light-grey { border-color: rgba(224,224,224,1); }

.align-right  { text-align: right; }
.align-center { text-align: center; }

.up-case     { text-transform: uppercase; }
.text-inline { display: inline; }

/*--- margins and padding ------------*/

.mar-t-0-25 { margin-top:  .25em; }
.mar-t-0-5 { margin-top:  .5em; }
.mar-t-1   { margin-top:   1em; }
.mar-t-2   { margin-top:   2em; }
.mar-t-3   { margin-top:   3em; }
.mar-t-4   { margin-top:   4em; }
.mar-t-5   { margin-top:   5em; }
.mar-t-10  { margin-top:  10em; }
.mar-t-20  { margin-top:  20em; }
.mar-t-40  { margin-top:  40em; }

.mar-b-0-25 { margin-bottom: .25em; }
.mar-b-0-75 { margin-bottom: .75em; }
.mar-b-0-5  { margin-bottom: .5em;  }
.mar-b-1    { margin-bottom:  1em;  }
.mar-b-1-5  { margin-bottom:  1.5em;  }
.mar-b-2    { margin-bottom:  2em;  }
.mar-b-2-5  { margin-bottom:  2.5em;  }
.mar-b-3    { margin-bottom:  3em;  }
.mar-b-5    { margin-bottom:  5em;  }
.mar-b-10   { margin-bottom: 10em;  }
.mar-b-15   { margin-bottom: 15em;  }
.mar-b-20   { margin-bottom: 20em;  }

.mar-l-0-5 { margin-left:   .5em; }
.mar-l-1 { margin-left:   1em; }
.mar-l-2 { margin-left:   2em; }
.mar-l-3 { margin-left:   3em; }

.mar-r-1 { margin-right:  1em; }
.mar-r-2 { margin-right:  2em; }
.mar-r-3 { margin-right:  3em; }
.mar-r-4 { margin-right:  4em; }
.mar-r-5 { margin-right:  5em; }

.mar-tb-1 { margin-top: 1em; margin-bottom: 1em; }
.mar-tb-2 { margin-top: 2em; margin-bottom: 2em; }
.mar-tb-3 { margin-top: 3em; margin-bottom: 3em; }
.mar-tb-5 { margin-top: 5em; margin-bottom: 5em; }
.mar-tb-10 { margin-top: 10em; margin-bottom:10em; }

.mar-lr-1 { margin-left: 1em; margin-right: 1em; }
.mar-lr-2 { margin-left: 2em; margin-right: 2em; }
.mar-lr-3 { margin-left: 3em; margin-right: 3em; }

.mar-a-1 { margin: 1em; }
.mar-a-2 { margin: 2em; }
.mar-a-3 { margin: 3em; }

.pad-t-0-25 { padding-top:    .25em; }
.pad-t-1    { padding-top:    1em; }
.pad-t-2    { padding-top:    2em; }
.pad-t-3    { padding-top:    3em; }
.pad-t-10   { padding-top:   10em; }

.pad-b-0-25 { padding-bottom: .25em; }
.pad-b-0-4  { padding-bottom: .4em; }
.pad-b-0-5  { padding-bottom: .5em; }
.pad-b-1    { padding-bottom:  1em;  }
.pad-b-2    { padding-bottom:  2em;  }
.pad-b-3    { padding-bottom:  3em;  }

.pad-l-1 { padding-left: 1em; }
.pad-l-2 { padding-left: 2em; }
.pad-l-3 { padding-left: 3em; }
.pad-l-20 { padding-left: 20em; }

.pad-r-1 { padding-right: 1em; }
.pad-r-2 { padding-right: 2em; }
.pad-r-3 { padding-right: 3em; }

.pad-tb-0-25 { padding-top: .25em;  padding-bottom: .25em; }
.pad-tb-0-5 { padding-top: .5em;  padding-bottom: .5em;  }
.pad-tb-0-8 { padding-top: .8em;  padding-bottom: .8em;  }
.pad-tb-1   { padding-top: 1em;   padding-bottom: 1em;   }
.pad-tb-1-5 { padding-top: 1.5em; padding-bottom: 1.5em; }
.pad-tb-2   { padding-top: 2em;   padding-bottom: 2em;   }
.pad-tb-2-5 { padding-top: 2.5em;   padding-bottom: 2.5em; }
.pad-tb-3   { padding-top: 3em;   padding-bottom: 3em;   }
.pad-tb-5   { padding-top: 5em;   padding-bottom: 5em;   }
.pad-tb-8   { padding-top: 8em;   padding-bottom: 8em;   }

.pad-lr-0-5   { padding-left: .5em;   padding-right: .5em; }
.pad-lr-1   { padding-left: 1em;   padding-right: 1em;   }
.pad-lr-1-5 { padding-left: 1.5em; padding-right: 1.5em; }
.pad-lr-2   { padding-left: 2em;   padding-right: 2em;   }
.pad-lr-5   { padding-left: 5em;   padding-right: 5em;   }
.pad-lr-3   { padding-left: 3em;   padding-right: 3em;   }
.pad-lr-4   { padding-left: 4em;   padding-right: 4em;   }
.pad-lr-8   { padding-left: 8em;   padding-right: 8em;   }
.pad-lr-10  { padding-left: 10em;  padding-right: 10em;  }
.pad-lr-12  { padding-left: 12em;  padding-right: 12em;  }

.pad-lr-fit { padding-left: 9.5%;  padding-right: 9.5%;  }

.pad-a-1 { padding: 1em; }
.pad-a-2 { padding: 2em; }
.pad-a-3 { padding: 3em; }

/*--- margins and padding ------------*/
/*--- border width -------------------*/

.bor-1 { border-width: 1px; border-style: solid; }
.bor-2 { border-width: 2px; border-style: solid; }
.bor-3 { border-width: 3px; border-style: solid; }

.bor-t-1 { border-top-width: 1px; border-style: solid; }
.bor-b-1 { border-bottom-width: 1px; border-style: solid; }
.bor-b-2 { border-bottom-width: 2px; border-style: solid; }


/*--- layout -------------------------*/

.clear       { clear: both; }
.float-left  { float: left; }
.float-right { float: right; }

/*--- misc ---------------------------*/

.hidden { display: none; }
.opaque { opacity: 1; }
.transparent { opacity: 0; }

.blured {
  -webkit-filter: blur(5px);
     -moz-filter: blur(5px);
       -o-filter: blur(5px);
      -ms-filter: blur(5px);
          filter: blur(5px);
}

/*------------------------------------*\
    #RESPONSIVE
\*------------------------------------*/


@media all and (max-width: 1800px), all and (max-height: 900px) {
  body { font-size: .85em; }
}

@media all and (max-width: 1600px) {
  body { font-size: .8em; }
}

@media all and (max-width: 1400px) {
  body { font-size: .75em; }
}

@media all and (max-width: 1300px) {
  body { font-size: .7em; }
}

@media all and (max-width: 1200px) {
  body { font-size: .55em; }
}

@media all and (max-width: 700px) {
  
  .container--corner.top-left.pad-l-20 {
    padding-left: 15em;
  }
  
  .column.quarter,
  .column.half {
    width: 100%;
  }
  
  .flickity-prev-next-button {
    display: none;
  }
  
  .main-slideshow-slide {
    border-top: 7em solid transparent;
    border-bottom: 7em solid transparent;
    border-left: 2em solid transparent;
    border-right: 2em solid transparent;
  }
  
}