/* master.css  -----------------------------------------------------------------*/

/* Fonts  --------------------------------------------------------------------*/

@font-face {
  font-family: 'DM Mono';
  src:
		url('../assets/fonts/DMMono-Regular.woff2') format('woff2'),
    url('../assets/fonts/DMMono-Regular.woff') format('woff');
	font-weight: 400;
}

@font-face {
  font-family: 'DM Sans';
  src:
		url('../assets/fonts/DMSans-Regular.woff2') format('woff2'),
    url('../assets/fonts/DMSans-Regular.woff') format('woff');
	font-weight: 400;
}

/* Allgemeine CSS  -----------------------------------------------------------*/
body{
  margin: 0;
  padding: 0;
  color: #000000;
  background-color: #FFFFFF;
  font-family: 'DM Mono', monospace;
}

/* Loading Screen */
#loadingscreen{
  background-color: #FFFFFF;
  top: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  opacity: 1;
 	transition: .2s opacity;
  display: flex;
  align-items: center;
  justify-content: center;
  position: fixed;
  overflow: hidden;
  z-index: 999;
}

#loadingscreen.fadeout {
    opacity: 0;
}

.loadtitle{
  line-height: 34px;
  font-size: 20px;
}

h1, h2, p, a, footer {
  margin: 0;
  padding: 0;
}

h1, h2 {
  font-family: 'DM Sans', sans-serif;
  font-weight: 400;
}

h1 {
  grid-column-start: 1;
  z-index: 1;
}

.hi, .email, .project{
  z-index: 1;
}

.nav{
  display: grid;
  top: 0;
  border-bottom: 1px solid black;
  position: fixed;
  background-color: #FFFFFF;
  z-index: 20;
}

.raster{
  display: grid;
}

.number{
  text-align: right;
  z-index: 2;
}

a{
  color: #000000;
  text-decoration: underline;
  transition: background-color 0.3s;
}

/* Hover */
.navhover{
  box-shadow: inset 0 0 0 0 #000000;
  transition: color .3s ease-in-out, box-shadow .3s ease-in-out;
}

.navhover:hover{
  box-shadow: inset 0 -100px 0 0 #000000;
  color: white;
}

a:hover .project-txtbox{
  box-shadow: inset 0 75vh 0 0 #000000;
  color: white;
}

.defaulthover{
  box-shadow: inset 0 0 0 0 #000000;
  transition: color .3s ease-in-out, box-shadow .3s ease-in-out;
}

.defaulthover:hover{
  box-shadow: inset 100vw 0 0 0 #000000;
  color: white;
}

.lighthover{
  opacity: 1;
  transition: opacity .3s ease-in-out;
}

.lighthover:hover{
  opacity: .5;
}
/* Hover Ende */

.biglink{
 text-decoration: none;
}

.project{
  display: grid;
}

.project-txtbox{
  border-top: 1px solid black;
  display: grid;
  box-shadow: inset 0 0 0 0 #000000;
  transition: color .3s ease-in-out, box-shadow .3s ease-in-out;
}

.contact{
  display: grid;
}

.mailto{
  font-family: 'DM Sans', sans-serif;
  font-weight: 400;
}

.cur{
  cursor: url("../assets/cursor_1.cur") 30 2, auto;
}

footer{
  bottom: 0;
  border-top: 1px solid black;
  display: grid;
  background-color: #FFFFFF;
}

/* BRP1 Smartphones  ---------------------------------------------------------*/
@media screen and (max-width: 991px ) {
  body{
    font-size: 3.08vw;
    line-height: 5.13vw;
  }

  .nav{
    margin: 0 0 0 3.59vw;
    column-gap: 5.13vw;
    grid-template-columns: repeat(7, 8.72vw);
    grid-template-rows: 7.31vw 7.18vw;
  }

  .nav-style{
    line-height: 7.18vw;
    font-size: 4.1vw;
  }

  .logo{
    grid-column: 1 / span 3;
    grid-row-start: 2;
  }

  .uber{
    grid-column: 6 / span 2;
    grid-row-start: 2;
  }

  .raster{
    margin: 19.62vw 0 0 3.59vw;
    gap: 5.13vw 5.13vw;
    grid-template-columns: repeat(7, 8.72vw);
    grid-auto-rows: 17.95vw;
  }

  h1{
    grid-column: 1 / span 7;
    font-size: 9.23vw;
    line-height: 10.26vw;
  }

  .h-indent{
    margin-left: 13.85vw;
  }

  .email{
    grid-column: 1 / span 7;
    grid-row-start: 6;
  }

  .hi{
    grid-column: 2 / span 5;
    grid-row-start: 7;
  }

  .number{
    grid-column-start: 1;
  }

  .one{
    grid-row-start: 10;
  }

  .two{
    grid-row-start: 17;
  }

  .three{
    grid-row-start: 24;
  }

  h2{
    font-size: 7.18vw;
    line-height: 9.23vw;
  }

  .project{
    grid-column: 2 / 7;
    gap: 5.13vw 5.13vw;
    grid-template-columns: repeat(5, 8.72vw);
    grid-auto-rows: 17.95vw;
  }

  .project-txtbox{
    grid-column: span 5;
    /* hover opt */
    height: 64.11vw;
    /* hover opt */
    gap: 5.13vw 5.13vw;
    grid-template-columns: repeat(5, 8.72vw);
    grid-auto-rows: 17.95vw;
  }

  .project-head{
    grid-column: 1 / span 4;
  }

  .project-txt{
    grid-column: 1 / span 5;
  }

  .teaser-img{
    grid-column: 1 / span 5;
    width: 64.12vw;
    grid-row: 4;
  }

  .arg{
    grid-row-start: 10;
  }

  .ti{
    grid-row-start: 17;
  }

  .kosmos{
    grid-row-start: 24;
  }

  .contact{
    grid-row-start: 31;
    gap: 5.13vw 5.13vw;
    grid-template-columns: repeat(7, 8.72vw);
    grid-auto-rows: 17.95vw;
  }

  .contact-one{
    grid-column: 1 / span 4;
  }

  .contact-two{
    grid-column: 6 / span 2;
  }

  .mailto{
    grid-column: 1 / span 7;
    grid-row-start: 33;
    font-size: 8.21vw;
    line-height: 10.26vw;
    letter-spacing: 0.13vw;
  }

  footer{
    grid-column: 1 / span 7;
    grid-row-start: 35;
    gap: 5.13vw 5.13vw;
    grid-template-columns: repeat(7, 8.72vw);
    grid-template-rows: 17.95vw 17.95vw 7.69vw;
  }

  .imp{
    grid-column: 1 / span 2;

  }

  .git{
    grid-column: 1 / span 2;
    grid-row-start: 2;
  }

  .insta{
    grid-column: 3 / span 2;
    grid-row-start: 2;
  }

  .cc{
    grid-column: 6/ span 2;
    grid-row-start: 2;
  }

  .copyright{
    grid-row-start: 3;
    grid-column: 1 / span 7;
  }

  .impressum{
    grid-row-start: 1;
    grid-column: 1 / span 7;
  }
}

/* BRP2 Tablet (Portrait)  ---------------------------------------------------*/
@media screen and (min-width: 580px) and (max-width: 991px ) {
  body{
    font-size: 1.68vw;
    line-height: 2.88vw;
  }

  .nav{
    margin: 0 0 0 3.36vw;
    column-gap: 2.88vw;
    grid-template-columns: repeat(8, 8.63vw);
    grid-template-rows: 6.71vw 3.84vw;
  }

  .nav-style{
    line-height: 3.84vw;
    font-size: 2.4vw;
  }

  .uber{
    grid-column: 6 / span 3;
  }

  .raster{
    margin: 13.43vw 0 0 3.36vw;
    gap: 2.88vw 2.88vw;
    grid-template-columns: repeat(8, 8.63vw);
    grid-auto-rows: 11.51vw;
  }

  h1{
    font-size: 7.67vw;
    line-height: 8.63vw;
  }

  .h-indent{
    margin-left: 11.51vw;
  }

  .email{
    grid-column: 2 / span 3 ;
    grid-row-start: 8;
  }

  .hi{
    grid-column: 6 / span 3;
    grid-row-start: 8;
  }

  .one{
    grid-row-start: 11;
  }

  .two{
    grid-row-start: 15;
  }

  .three{
    grid-row-start: 19;
  }

  h2{
    font-size: 4.32vw;
    line-height: 5.76vw;
  }

  .project{
    grid-column: 2 / span 7;
    gap: 2.88vw 2.88vw;
    grid-template-columns: repeat(7, 8.63vw);
    grid-auto-rows: 11.51vw;
  }

  .project-txtbox{
    grid-column: span 3;
    /* hover opt */
    height: 40.29vw;
    /* hover opt */
    gap: 2.88vw 2.88vw;
    grid-template-columns: repeat(3, 8.63vw);
    grid-auto-rows: 11.51vw;
  }

  .project-head{
    grid-column: 1 / span 3;
  }

  .project-txt{
    grid-column: 1 / span 3;
  }

  .teaser-img{
    grid-column: 5 / span 3;
    width: 31.65vw;
    grid-row: 1;
  }

  .arg{
    grid-row-start: 11;
  }

  .ti{
    grid-row-start: 15;
  }

  .kosmos{
    grid-row-start: 19;
  }

  .contact{
    grid-row-start: 23;
    gap: 2.88vw 2.88vw;
    grid-template-columns: repeat(8, 8.63vw);
    grid-auto-rows: 11.51vw;
  }

  .contact-two{
    grid-column: 6 / span 3;
  }

  .mailto{
    grid-column: 1;
    grid-row-start: 25;
    font-size: 8vw;
    line-height: 9.11vw;
    letter-spacing: 0;
  }

  footer{
    grid-column: 1 / span 8;
    grid-row-start: 28;
    gap: 2.88vw 2.88vw;
    grid-template-columns: repeat(8, 8.63vw);
    grid-template-rows: 11.51vw 4.08vw;
  }

  .git{
    grid-column: 3 / span 2;
    grid-row-start: 1;
  }

  .insta{
    grid-column: 5 / span 2;
    grid-row-start: 1;
  }

  .cc{
    grid-column: 7/ span 2;
    grid-row-start: 1;
  }

  .copyright{
    grid-row-start: 2;
    grid-column: 1 / span 7;
  }

  .impressum{
    grid-column: 1 / span 5;
  }
}



/* BRP3 Desktop (klein)  -----------------------------------------------------*/
@media screen and (min-width: 992px) {
  body{
    font-size: 0.9259vw;
    line-height: 1.62vw;
  }

  .nav{
    margin: 0 0 0 3.47vw;
    column-gap: 1.62vw;
    grid-template-columns: repeat(10, 7.73vw);
    grid-template-rows: 3.47vw 2.08vw;
  }

  .nav-style{
    line-height: 2.08vw;
    font-size: 1.39vw;
  }

  .logo{
    grid-column: 1 / span 2;
    grid-row-start: 2;
  }

  .uber{
    grid-column: 9 / span 2;
    grid-row-start: 2;
  }

  .raster{
    margin: 7.17vw 0 0 3.47vw;
    gap: 1.62vw 1.62vw;
    grid-template-columns: repeat(10, 7.73vw);
    grid-auto-rows: 7.29vw;
  }

  h1{
    font-size: 4.86vw;
    line-height: 5.3vw;
  }

  .h-indent{
    margin-left: 9.35vw;
  }

  .email{
    grid-column: 2 / 4;
    grid-row-start: 5;
  }

  .hi{
    grid-column: 9 / 11;
    grid-row-start: 4;
  }

  .number{
    grid-column-start: 1;
  }

  .one{
    grid-row-start: 6;
  }

  .two{
    grid-row-start: 9;
  }

  .three{
    grid-row-start: 12;
  }

  h2{
    font-size: 2.78vw;
    line-height: 3.7vw;
  }

  .project{
    grid-column: 2 / 9;
    gap: 1.62vw 1.62vw;
    grid-template-columns: repeat(7, 7.73vw);
    grid-auto-rows: 7.29vw;
  }

  .project-txtbox{
    grid-column: span 4;
    /* hoveropt */
    height: 16.2vw;
    /* hoveropt */
    gap: 1.62vw 1.62vw;
    grid-template-columns: repeat(4, 7.73vw);
    grid-auto-rows: 7.29vw;
  }

  .project-head{
    grid-column: 1 / span 4;
    grid-row-start: 1;
  }

  .project-txt{
    grid-column: 1 / span 4;
    grid-row-start: 2;
    columns: 2;
    column-gap: 1.62vw;
  }

  .teaser-img{
    grid-column: 6 / span 2;
    width: 17.08vw;
  }

  .arg{
    grid-row-start: 6;
  }

  .ti{
    grid-row-start: 9;
  }

  .kosmos{
    grid-row-start: 12;
  }

  .contact{
    grid-row-start: 15;
    gap: 1.62vw 1.62vw;
    grid-template-columns: repeat(10, 7.73vw);
    grid-auto-rows: 7.29vw;
  }

  .contact-one{
    grid-column: 1 / span 5;
  }

  .contact-two{
    grid-column: 7 / span 2;
  }

  .mailto{
    grid-column: 3 / span 6;
    grid-row-start: 17;
    font-size: 4.86vw;
    line-height: 5.3vw;
    letter-spacing: 0.03vw;
  }

  footer{
    grid-column: 1 / span 10;
    grid-row-start: 19;
    gap: 1.62vw 1.62vw;
    grid-template-columns: repeat(10, 7.73vw);
    grid-template-rows: 7.29vw 2.2vw;
  }

  .imp{
    grid-column: 1 / span 2;

  }

  .git{
    grid-column: 5 / span 2;
  }

  .insta{
    grid-column: 7 / span 2;
  }

  .cc{
    grid-column: 9/ span 2;
  }

  .copyright{
    grid-row-start: 2;
    grid-column: 1 / span 5;
  }

  .impressum{
    grid-column: 1 / span 4;
  }
}

/* BRP4 Desktop (groß): static------------------------------------------------*/
@media screen and (min-width: 1600px) {
  body{
    font-size: 16px;
    line-height: 28px;
  }

  .nav{
    margin: 0 0 0 6vw;
    column-gap: 28px;
    grid-template-columns: repeat(10, 132px);
    grid-template-rows: 60px 36px;
  }

  .nav-style{
    line-height: 36px;
    font-size: 24px;
  }

  .raster{
    margin: 124px 0 0 6vw;
    gap: 28px 28px;
    grid-template-columns: repeat(10, 132px);
    grid-auto-rows: 126px;
  }

  h1{
    font-size: 84px;
    line-height: 92px;
  }

  .h-indent{
    margin-left: 160px;
  }

  h2{
    font-size: 48px;
    line-height: 64px;
  }

  .project{
    gap: 28px 28px;
    grid-template-columns: repeat(7, 132px);
    grid-auto-rows: 126px;
  }

  .project-txtbox{
    /* hoveropt */
    height: 280px;
    /* hoveropt */
    gap: 28px 28px;
    grid-template-columns: repeat(4, 132px);
    grid-auto-rows: 126px;
  }

  .project-txt{
    column-gap: 28px;
  }

  .teaser-img{
    width: 292px;
  }

  .contact{
    gap: 28px 28px;
    grid-template-columns: repeat(10, 132px);
    grid-auto-rows: 126px;
  }

  .mailto{
    font-size: 84px;
    line-height: 92px;
    letter-spacing: 0.5px;
  }

  footer{
    gap: 28px 28px;
    grid-template-columns: repeat(10, 132px);
    grid-template-rows: 126px 38px;
  }
}
