* {
  box-sizing: border-box; margin: 0; padding: 0;
}

body {
    margin: 0px;
    font-family: 'Montserrat';
}


html { overflow-y: scroll;}
body { background:#ebebeb; font-size: 11px; color: #534741; font-family: Kalnia, Manrope, Montserrat, Arial, Helvetica, sans-serif;}


h1 {
    font-family: "Kalnia", serif;
/*-- font-family: 'Montserrat'; --*/
    font-weight: 900;
    letter-spacing: -0.5px;
}

h2 {
    font-family: "Kalnia", serif;
    font-size: 180%;
    font-weight: 500;
}

h3 {
    clear: both;
    font-family: "Kalnia", serif;
    font-size: 200%;
    font-weight: 900;
    text-align: center;
    color: #b7b7b7;
    padding-bottom: 2%;
}

h4 {  
    font-family: "Manrope", sans-serif;
    font-size: 150%;
    font-weight: 500;
}

p {
    font-family: "Manrope", sans-serif;
    font-weight: 500;    
    font-size: 120%;
}

#content{
    width: 80%;
    margin: auto;
    padding: 0;
    text-align: left;
}

#content a {
    color: #534741;
    text-decoration: none;
}



/*-- NAVIGATION --*/
    
#headerwrap {
    position: fixed; 
	top: 0px;
	left: 0px;
	width: 100%; 
/*--     background: -webkit-linear-gradient(220deg, rgba(255, 255, 255, .5), rgba(255, 255, 255, 0), rgba(255, 255, 255, 0)); white linear gradient --*/
/*--  background-color: rgba(255, 255, 255, 0.8); white --*/
/*--     background: -webkit-linear-gradient(255deg, rgba(223, 171, 81, 0.1), rgba(229, 94, 96, 0.2), rgba(95, 170, 234, 0.1)); multicolor linear gradient --*/
    z-index: 999;
}

    
#headerbar {
	width: 100%;	
	max-width: 85%;
	margin: auto;               
}

.nav {
  width: 100%;
  position: relative;   
  font-family: 'Montserrat';
  font-weight: 700;
}


.nav > .nav-btn {
  display: none;
}

.nav > .nav-links {
  display: inline;
  float: right;
  font-size: 1.2em;
}

.nav > .nav-links > a {
  display: inline-block;
  padding: 12px 16px 30px 0;
  text-decoration: none;
  text-align: center;
  color: #534741;
}


/* vvv newly added monogram on right of nav vvv */
.nav > .nav-links > a > img {
    position: relative;
    top: 10px;
    height: 28px;
}



.nav > .nav-links > a:hover {   
  color: #ec5f59;
}

.nav > #nav-check {
  display: none;
}

.nav > .nav-links span {
  color: #ec5f59;
}


/* HERO */

#herowrap {
    position: relative;
}

#herowrap > img { 
    object-fit: cover;
    width: 100%;
    max-height: 640px;
 /*   max-height: 75vh;  'more scalable' */
}

#herotext {
    position: absolute;
    left: 16%;
    top: 12%;
    width: 80%;
    color: #534741;
}

#herotext > #dnlogo > a > img {
    width: 76px; 
    height: auto;
    float: left;
}


.slogan {
    margin-left: 44%;
}

.slogan div {
    display: inline-block; 
    vertical-align: top;
}

.slogan #ready {
    padding: 10% 6% 0 0;
    line-height: 180%;
    text-align: right;
    text-transform: none;
}

.slogan #lets {
    font-size: 300%;
    padding: 10% 0 0 0;
    line-height: 152%;
}



#titlewrap {
    position: relative;
}

#titlewrap > img { 
    object-fit: cover;
    width: 100%;
    max-height: 440px;
}


.titles {
    margin: 4% 0 0 56%;
    line-height: 200%;
}

.titles h1 {
    font-size: 340%;
    line-height: 78%;
}

.titles h2 {
    font-weight: 900;
}

.titles h4 {
    font-size: 140%;
}

.titles img {
    padding-bottom: 2%;
}

.titles a {
    text-decoration: none;
    color: #534741;
/*  color: #bc4ec0; */
}


.gradient {
    background-color: #ec5f59;
    background: -webkit-linear-gradient(60deg, #ec5f59, #ec5f59, #bc4ec0);
    -webkit-background-clip: 
    text;-webkit-text-fill-color: transparent;
}


.intro {
    clear: both;
    padding: 6% 30% 8% 10%;
    color: #ec5f59;  
}

.intro p {
    font-size: 140%;
    line-height: 140%;
}



/* Home/Projects Gallery */

#content .gallery {
    position: relative;

}

#content .gallery img {
    display: block;
    object-fit: cover;
    width: 100%;
    height: 34vh;
/*   height: 350px; */
    margin: 0;
}
    
.overlay {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    height: 100%;
    width: 100%;
    opacity: 0;
    transition: .5s ease;
    background: -webkit-linear-gradient(240deg, rgba(236, 95, 89, 0.8), rgba(236, 95, 89, 0.8), #bc4ec0);
/*  background-color: rgba(236, 95, 89, 0.8);  #ec5f59 */
}

.gallery:hover .overlay {
    opacity: 1;
}

.caption {
    color: white;
    font-family: "Kalnia", serif;
    font-size: 170%;
    font-weight: 400;
/*  font-variant: small-caps;  */
    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;
}  

.responsive {
    float: left;
    width: 32%;
    margin: 5px; 
}

/* use this rule for no gaps between images
.responsive {
    float: left;
    width: 33.3%;
}
 */


/* end */



/* Content pages */


#works {
    margin-top: 8%;
}

#works h2 {  
    padding: 2% 30% 0 10%;   
}

#works p {  
    padding: 1% 30% 4% 10%;   
}


.divider2 {
	margin: 8% auto;
	background: #e1e1e1; 
	width: 80%;
	height: 10px;
}



/* use this rules set for small gaps between images vvv */

#works div {
    clear: both;
    text-align: center;
}

#works img {
    display: inline-block;
    vertical-align: top;
    object-fit: cover;
    max-width: 49%;
    height: auto;
    padding: 1% 0.8% 0 0;
}

#works .large img {
    object-fit: cover;
    max-width: 98.5%;
    height: auto;
}

#works .small img {
    max-width: 32.5%;
    height: auto;
}

embed {
	display: block;
	width: 80%;
	height: 45vw;
    margin: auto;
/*  width: 650px;
	height: 400px;  orignal size */
}



/* use this rules set for no gaps between images vvv 

#works div {
    clear: both;
}

#works img {
    object-fit: cover;
    max-width: 49%;
    height: auto;
    float: left;
}

#works .large img {
    object-fit: cover;
    max-width: 98%;
    height: auto;
}

#works .small img {
    max-width: 33%;
    height: auto;
}

*/



.blurb {
    clear: both;
    padding: 8% 34% 8% 10%;
}

.blurb > #coffee > img {
    width: 32px; 
    height: auto;
    padding-bottom: 2%;
}


#footer {
    color: #ebebeb;
    font-size: 90%;
    font-weight: 200;
    text-align: center;
    padding: 2% 0;
    background-color: #534741;
}

#footer img {
    width: 18px; 
    height: auto;
    padding: 1% 0;
}




/*- VVV RESPONSIVE VVV -*/



/* 1024 */
    
@media only screen and (max-width: 1024px) {
    

#herotext > #dnlogo > a > img {
    width: 60px; 
}
    
    
.slogan #ready {
    font-size: 85%;
    padding: 16% 6% 0 0;
}

.slogan #lets {
    font-size: 230%;
    padding: 16% 0 0 0;
}
    

.titles h1 {
    font-size: 300%;
}
    
.titles h2 {
    font-size: 190%;
}

.titles h4 {
    font-size: 120%;
}

.titles img {
    width: 110px;
    height: auto;
} 
    

    
}



/* 823 */

@media only screen and (max-width: 823px) {
    
    

    
#headerbar {
	max-width: 100%;            
}
    
.nav > .nav-btn {
    display: inline-block;
    position: absolute;
    right: 0px;
    top: 0px;
  }

    /*- v hamburger icon v -*/
    
  .nav > .nav-btn > label {
    display: inline-block;
    height: 64px;
    padding: 24px;
  }
  .nav > .nav-btn > label:hover {
/*- background-color: rgba(255, 255, 255, 0.2); white -*/
  }
  .nav > .nav-btn > label > span {
    display: block;
    width: 25px;
    height: 8px;
    border-top: 2px solid #534741;
  }
    
    /*- ^ hamburger icon ^ -*/
    
    
  .nav > .nav-links {
    position: absolute;
    display: block;
    width: 80px;
    background: -webkit-linear-gradient(360deg, rgba(235, 235, 235, 0.8), rgba(235, 235, 235, 1), rgba(235, 235, 235, 1));
/*- background-color: rgba(255, 255, 255, 0.8); white -*/
/*- background: -webkit-linear-gradient(245deg, rgba(223, 171, 81, 0.1), rgba(229, 94, 96, 0.5), rgba(95, 170, 234, 0.5));  multicolor -*/
/*- background: -webkit-linear-gradient(360deg, rgba(83, 71, 65, 0.9), rgba(83, 71, 65, 1), rgba(83, 71, 65, 1));  multicolor -*/
/*- background-color: rgba(83, 71, 65, 1); -*/
    height: 0px;
    transition: all 0.3s ease-in;
    overflow-y: hidden;
    top: 64px;
    right: 0px;
  }
  .nav > .nav-links > a {
    display: block;
    text-align: right;
    width: 100%;
    padding: 10px 25px 0 0;
    font-size: 0.9em;
/*- font-weight: 500;
    color: #ebebeb;  for reverse light on dark nav -*/
  }
  .nav > #nav-check:not(:checked) + .nav-links {
    height: 0px;
  }
  .nav > #nav-check:checked + .nav-links {
    height: 210px;
/*- height: 160px;  to hide monogram -*/
  }
    
    
    
.intro {
    padding: 6% 18% 8% 10%;
}
    
    
#herowrap > img { 
    min-height: 440px;
}
    
   
#content .gallery img {
    height: 260px;
}
    
    
.blurb {
    padding: 8%;
}
     
    
.divider2 {
	margin: 10% auto;
	width: 90%;
	height: 6px;
}
    
  .responsive {
    width: 47%;
  }
    

}



/* 480 */
    
@media only screen and (max-width: 480px) {
    

    
#herowrap > img { 
    min-height: 300px;
}
       
    
#titlewrap > img { 
    min-height: 300px;
}
    

#herotext {
    left: 10%;
}
    
#herotext > #dnlogo > a > img {
    width: 46px; 
    height: auto;
}
    
    
.slogan #ready {
    font-size: 60%;
    padding: 18% 6% 0 0;
}

.slogan #lets {
    font-size: 140%;
    padding: 18% 0 0 0;
}
   
    
.titles {
    margin: 6% 0 0 64%;
    line-height: 160%;
}
    
.titles h1 {
    font-size: 220%;
}
    
.titles h2 {
    font-size: 130%;
}

.titles h4 {
    font-size: 100%;
}
    
.titles img {
    width: 70px;
    height: auto;
} 
    
    
.intro {
    padding: 12% 18% 12% 6%;
}
    
.intro h2 {
    font-size: 160%;
}

.intro p {
    font-size: 120%;
}
    
    
h3 {
    font-size: 170%;
}
    
    
#content{
    width: 90%;
} 
    
 
    
.blurb {
    padding: 8% 18% 8% 6%;
}
    
.blurb h2 {
    font-size: 160%;
}
    
.blurb h4 {
    font-size: 130%;
}
    
.blurb p {
    font-size: 110%;
}
    
    
    
#works {
    margin-top: 12%;
}

#works h2 {
    font-size: 150%;
    padding: 2% 18% 0 6%;
    }  
    
#works p {
    font-size: 110%;
    padding: 1% 18% 4% 6%;
    }  

/* 
#works h3 {
    font-size: 100%;
} */ 
    
    
/* vvv single row images, disable rule to retain orig format vvv */ 
    
#works img {
    max-width: 98.5%;
    padding: 2% 0.5% 0 0;
}

/* ^^^ single row images ^^^ */ 
    
#works .small img {
    max-width: 49%;
}
    
    
img#hidesmall {
    display: none;
  }
      
embed {
    width: 95%;
	height: 55vw;
/*	width: 260px;
	height: 160px;  */
}
    
    
#footer {
    font-size: 80%;
    padding: 6% 0;
}
    
#footer img {
    width: 16px; 
    padding: 2% 0;
}

    
.responsive {
    width: 100%;
    padding-right: 2%;
  }
    
    
}