@charset "utf-8";
/* CSS Document */

html, body {
    height:100% !important;
    background:#000000;
    /*scroll-behavior:smooth;*/
}

/* override bootstrap max-width */
.container-fluid{
    max-width:1920px !important;
}

/* Force certain divs to show the background image at full vertical height*/
.max-height-100 {
    height:100%;
}

/* header and hero image */
.max-viewport-height {
    height:100vh;
}

.header-image-container{
    height:530px;
    width:239px;
    margin-top:3%;
    margin-right:20%;
    float:right;
    background: url(../images/logo/logo.png);
    background-repeat: no-repeat;
    background-size: contain;
    opacity: 0.8;
}

.rsd-hero {
    background-image: url(../images/shared/rsd-hero.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    margin-top:-15px;
}

.header-text-container {
    width:250px;
    margin-top:8%;
    margin-left:30%;
    float:left;
}

.header-text-container h1{
    font-size:36px !important;
    color: #7d7d7d !important;
}

.scroll-down-container { 
    margin-top:40%;
    height:70px;
    width:100%;
    scroll-behavior:smooth;
}

.scroll-down-arrow {
    position: absolute;
    bottom: 0px;
    left: 0; 
    right: 0; 
    margin-left: auto; 
    margin-right: auto; 
    width: 80px;
    height: 80px;
    background: url(../images/scroll-down.png);
    background-repeat: no-repeat;
    background-size:contain;
    opacity:0.7;
    background-color:#000000;
    border-radius:10px;
    scroll-behavior:smooth;
}
/* end header and hero image */

.main-nav-box{
    position: relative;
    display: block;
    width: 100%;
    height: 400px;
    transition: opacity .25s ease-in-out;
    opacity: 1.0;
    background-color: #000000;
}

.main-nav-box:hover {
    opacity:0.7;
}
    
/* Category Backgrounds */
.main-nav-link {
    position: relative;
    display: block;
    height: 400px !important;
    width: 100% !important;
   /* box-shadow:0px 10px 10px #ffffff;*/
}

.lifestyle-image{
    background: url(../images/shared/category-backgrounds/lifestyle-photography-background.jpg);
    background-repeat: no-repeat;
    background-position: center !important;
    background-size: cover; 
}

.product-image{
    background: url(../images/shared/category-backgrounds/product-photography-background.jpg);
    background-repeat: no-repeat;
    background-position: center !important;
    background-size: cover; 
}

.portrait-image{
    background: url(../images/shared/category-backgrounds/portrait-photography-background.jpg);
    background-repeat: no-repeat;
    background-position: center !important;
    background-size: cover; 
}

.personal-projects-image{
    background: url(../images/shared/category-backgrounds/personal-projects-photography-background.jpg);
    background-repeat: no-repeat;
    background-position: center !important;
    background-size: cover; 
}

.video-image{
    background: url(../images/shared/category-backgrounds/video-background-v2.jpg);
    background-repeat: no-repeat;
    background-position: center !important;
    background-size: cover; 
}

.contact-image{
    background: url(../images/shared/category-backgrounds/contact-background.jpg);
    background-repeat: no-repeat;
    background-position: center !important;
    background-size: cover; 
}

.resume-image{
    background: url(../images/shared/category-backgrounds/resume-background.jpg);
    background-repeat: no-repeat;
    background-position: center !important;
    background-size: cover; 
}

/* Textboxes for category images */
.categoryTextBox {
    position: absolute !important;
    right: 20px !important;
    bottom: 20px !important;
    width:auto;
    padding:15px;
    height: 70px;
    background-color: #000000;
}

/* text rules */

.main-nav-box h1, .category-header-box h1, .main-nav-box h2 {
    font-size:36px !important;
    color: #7d7d7d !important;
    opacity: 1.0;
}

h2, h3, h4, h5, p {
    color: #7d7d7d  !important;
}

h2 {
    font-size: 1.8em !important;
}

h3 {
    font-size: 1.3em !important;
}

p {
    font-size: 1em !important;
}

hr {
    color: #7d7d7d !important;
    opacity: 0.2;
}

/* resume text rules */
.textWrapper {
    width:65%;
    margin:0px auto;
}

.textWrapper p {
	text-align:left;
	font-size:18px;
	line-height:22px;
	padding-left:20px;
	color:#7d7d7d!important;
}

.textWrapper .largeText {
	font-size:26px !important;
	margin-bottom:20px;
    font-weight:bold;
}

.textWrapper .smallText {
	font-size:20px !important;
	line-height:24px;
	font-weight:bold;
	padding-left:10px;
	color:#ebebeb;
}

.textWrapper .photoText {
	font-size:18px !important;
	line-height:20px;
	font-weight:bold;
	margin:0px 0px 10px 0px;
	color:#ebebeb;
}

.textWrapper .smallTextDesc {
	font-size:18px !important;
	line-height:24px !important;
	color:#ebebeb;
}

.textWrapper .smallTextDescBold {
	font-size:18px !important;
	line-height:22px;
	margin-left:70px;
	color:#ebebeb;
	font-weight:bold;
}

.textWrapper a, a:visited {
	text-decoration:none;
}
.textWrapper a:hover {
	text-decoration:underline;
}

.textWrapper li {
	list-style:none;
	padding-left:30px;
    padding-bottom: 5px;
	text-align:left;
	font-size:18px;
	line-height:22px;
	color:#7d7d7d !important;
}

/* Category Page rules */

.category-header-box{
    position: relative;
    display: block;
    margin-top:-20px;
    width: 100%;
    height: 400px;
    background-color: #000000;
}

/* ========================= */
/* Social media footer stuff */
/* ========================= */

.socialContainer {
	position:relative;
	margin:0 auto;
	height:90px;
	width:100%;
	z-index:50;
}

.socialContainer #smContainer {
	position:relative;
	margin:10px auto;
	height:55px;
	width:300px;
}

.socialContainer ul {
    list-style:none;
}

.socialContainer #smContainer #insBox a, .socialContainer #smContainer #lnBox a, .socialContainer #smContainer #fbBox a {
	position:relative;
	display:block;
	float:left;
	text-indent:-9999px;
	list-style:none;
	width:60px;
	height:55px;
	margin:10px 10px 20px 10px;
	background-image:url(../images/shared/social/sm_imagemap-v2.jpg);
	background-repeat:no-repeat;
	outline:none;
}

.socialContainer #smContainer #lnBox a {
	width:60px;
	background-position:-70px 0px;
}

.socialContainer #smContainer #lnBox a:hover {
	background-position:-70px -60px;
}

.socialContainer #smContainer #fbBox a {
	width:60px;
	background-position:-140px 0px;
}

.socialContainer #smContainer #fbBox a:hover {
	background-position:-140px -60px;
}

.socialContainer #smContainer #insBox a {
	width:60px;
	background-position:-0px 0px;
}

.socialContainer #smContainer #insBox a:hover {
	background-position:-0px -60px;
}
/* end social media stuff */

/* =========================================== */
/* thumbnail view for graphics and photo pages */
/* =========================================== */

#viewThumbnails {
	position:relative;
	width:870px;
	height:100%;
	min-height:100%;
	margin:0px auto;
	z-index:60;	
}

.thumbBox {
	position:relative;
	width:125px;
	height:125px;
	margin:10px;
	float:left;
	/* bgcolor for rollovers */
	background-color:#000;
}

/* rollovers */
#viewThumbnails a {
    transition: opacity .25s ease-in-out;
	opacity: 1.0;
}

#viewThumbnails a:hover {
	opacity:0.6;
}

/* photo headers */

.photoText {
    font-size: 2.5em;
    color: #959595;
}

/* ============ */
/* Contact Page */
/* ============ */

.contactContainer {
    position: relative;
    margin:30px auto;
    width: 300px !important;
}

.contactWrapper p,form {
	text-align:left;
	font-size:14px;
	line-height:16px;
	color:#333;
}

.contactWrapper .largeText {
	font-size:20px !important;
	margin-bottom:20px;
}

.contactWrapper .smallText {
	font-size:16px !important;
	line-height:20px;
	font-weight:bold;
	margin-left:50px;
	color:#666;
}

.requiredField {
	color: #900;
	font-size: 10px;
}

.recommendedField {
	color:#000;
	font-size:10px;
}

.warning {
	color:#900;
}

input, textarea {
    /*color: #cccccc;*/
    background-color: #cccccc;
    /*border-radius: 8px;*/
}

.clearIt {
    clear: both;
}

legend {
    border-bottom: 1px solid #7d7d7d !important;
    opacity: 0.3;
}

/* YouTube video fix from https://css-tricks.com/NetMag/FluidWidthVideo/Article-FluidWidthVideo.php */

.videoWrapper {
	position: relative;
	padding-bottom: 56.25%; /* 16:9 */
	padding-top: 25px;
	height: 0;
    /* rsd edit - add background loading gif */
    background-image:url(../images/loading.gif);
    background-repeat: no-repeat;
    background-position: center;
    background-color: #ffffff;
}
.videoWrapper iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/* 404 */

.error404 {
    position:relative;
    height:500px;
    width:auto;
    max-width:500px;
    margin:0px auto;
    background-image:url(../images/shared/404-2018.jpg);
    background-repeat: no-repeat;
    background-size: contain;
}

/* ============= */
/* Media queries */
/* ============= */

@media only screen and (max-width: 1600px){
    /*.header-text-container {
        margin-top:10%;
        margin-left:30%;
    }*/
}

@media only screen and (max-width: 1200px){
    
    .main-nav-box, .category-header-box{
        height: 250px;
    }
    
    .main-nav-image{
        
    }
    
    .header-text-container {
        margin-top:14%;
        margin-left:25%;
    }
    
    .lifestyle-image{
        background: url(../images/shared/category-backgrounds/lifestyle-photography-background-1200px.jpg);
    }
    
    .product-image{
        background: url(../images/shared/category-backgrounds/product-photography-background-1200px.jpg);
    }
    
    .portrait-image{
        background: url(../images/shared/category-backgrounds/portrait-photography-background-1200px.jpg);
        background-position: center !important;
    }
    
    .personal-projects-image{
        background: url(../images/shared/category-backgrounds/personal-projects-photography-background-1200px.jpg);
    }
    
    .video-image{
        background: url(../images/shared/category-backgrounds/video-background-v2-1200px.jpg);
    }
    
    .resume-image{
        background: url(../images/shared/category-backgrounds/resume-background-1200px.jpg);
    }
    
    /* Textboxes for category images */
    .categoryTextBox {
        height: 56px !important;
    }
    
    .main-nav-box h1, .category-header-box h1, .main-nav-box h2 {
        font-size:24px !important;
    }
    
    #viewThumbnails {
	width:725px;
    margin: 0px auto !important;
    }
    
     .scroll-down-arrow {
        width: 50px;
        height: 50px;
    }
    
    .textWrapper {
        width:70%;
    }
}
    
@media only screen and (max-width: 992px){
    
    .rsd-hero {
        background-image: url(../images/shared/rsd-hero-1024.jpg);
    }

    .header-text-container {
        width:192px;
        margin-top:15%;
    }

    .header-text-container h1{
        font-size:32px !important;
    }
    
    .main-nav-box, .category-header-box{
        height: 200px;
    }
    
    .lifestyle-image{
        background: url(../images/shared/category-backgrounds/lifestyle-photography-background-1024px.jpg);
    }
    
    .product-image{
        background: url(../images/shared/category-backgrounds/product-photography-background-1024px.jpg);
    }
    
    .portrait-image{
        background: url(../images/shared/category-backgrounds/portrait-photography-background-1024px.jpg);
        background-position: center !important;
    }
    
    .personal-projects-image{
        background: url(../images/shared/category-backgrounds/personal-projects-photography-background-1024px.jpg);
    }
    
    .video-image{
        background: url(../images/shared/category-backgrounds/video-background-v2-1024px.jpg);
    }
    
    .resume-image{
        background: url(../images/shared/category-backgrounds/resume-background-1024px.jpg);
    }
    
    /* Textboxes for category images */
    .categoryTextBox {
        height: 56px !important;
    }
    
    .main-nav-box h1, .category-header-box h1, .main-nav-box h2 {
        font-size:24px !important;
    }

    #viewThumbnails {
	width:725px;
    margin: 0px auto !important;
    }
    
    .scroll-down-arrow {
        width: 50px;
        height: 50px;
    }
    
    .textWrapper {
        width:70%;
    }
}

@media only screen and (max-width: 768px) {
    
    .rsd-hero {
        background-image: url(../images/shared/rsd-hero-square.jpg);
    }
    
    .header-text-container {
        width:180px;
        margin-top: 20%;
    }

    .header-text-container h1{
        font-size:24px !important;
    }
    
    .header-image-container{
        height:400px;
        width:170px;
    }

     .main-nav-box, .category-header-box{
        height: 168px;
    }
    
    .lifestyle-image{
        background: url(../images/shared/category-backgrounds/lifestyle-photography-background-804px.jpg);
    }
    
    .product-image{
        background: url(../images/shared/category-backgrounds/product-photography-background-804px.jpg);
    }
    
    .portrait-image{
        background: url(../images/shared/category-backgrounds/portrait-photography-background-804px.jpg);
        background-position: center !important;
    }
    
    .personal-projects-image{
        background: url(../images/shared/category-backgrounds/personal-projects-photography-background-804px.jpg);
    }
    
    .video-image{
        background: url(../images/shared/category-backgrounds/video-background-v2-804px.jpg);
    }
    
    .resume-image{
        background: url(../images/shared/category-backgrounds/resume-background-804px.jpg);
    }
    
    #viewThumbnails {
	width:580px;
    margin: 0px auto !important;
    }
    
    .scroll-down-arrow {
        width: 50px;
        height: 50px;
    }
    
    .textWrapper {
        width:80%;
    }
}

@media only screen and (max-width: 640px) {
    
    .rsd-hero {
        background-image: url(../images/shared/rsd-hero-square.jpg);
    }
    
    .header-text-container {
        width:250px;
        margin-left:15% !important;
        margin-top:15%;
    }

    .header-text-container h1{
        font-size:24px !important;
    }
    
    .header-image-container{
        height:400px;
        width:170px;
        margin-right: 15% !important;
    }
    
     .main-nav-box, .category-header-box{
        height: 136px;
    }
    
    .lifestyle-image{
        background: url(../images/shared/category-backgrounds/lifestyle-photography-background-652px.jpg);
    }
    
    .product-image{
        background: url(../images/shared/category-backgrounds/product-photography-background-652px.jpg);
    }
    
    .portrait-image{
        background: url(../images/shared/category-backgrounds/portrait-photography-background-652px.jpg);
        background-position: center !important;
    }
    
    .personal-projects-image{
        background: url(../images/shared/category-backgrounds/personal-projects-photography-background-652px.jpg);
    }
    
    .video-image{
        background: url(../images/shared/category-backgrounds/video-background-v2-652px.jpg);
    }
    
    .resume-image{
        background: url(../images/shared/category-backgrounds/resume-background-652px.jpg);
    }
    
    #viewThumbnails {
	width:435px;
    margin: 0px auto !important;
    }
    
    .scroll-down-arrow {
        width: 50px;
        height: 50px;
    }
    
    .textWrapper {
        width:90%;
    }
    
    .textWrapper p {
        padding-left:10px;
    }
    
    .textWrapper .smallText {
        padding-left:5px;
    }
    
    .textWrapper li {
        padding-left:10px;
    }
}

@media only screen and (max-width: 480px) {
    
    .rsd-hero {
        background-image: url(../images/shared/rsd-hero-square.jpg);
    }
    
    .header-text-container {
        width:240px;
        margin-left:15% !important;
        margin-top:10% !important;
    }

    .header-text-container h1{
        font-size:24px !important;
    }
    
    .header-image-container{
        height:300px;
        width:135px;
        margin-right: 15% !important;
    }
    
     .main-nav-box, .category-header-box{
        height: 136px;
    }
    
    #viewThumbnails {
        width:290px;
        margin: 0px auto !important;
    }
    
    .scroll-down-arrow {
        width: 50px;
        height: 50px;
        opacity: 0.8;
    }
    
    .textWrapper {
        width:90%;
    }
    
    .textWrapper p {
        padding-left:10px;
    }
    
    .textWrapper .smallText {
        padding-left:5px;
    }
    
    .textWrapper li {
        padding-left:0px;
    }
}

@media only screen and (max-width: 360px) {
    
    .rsd-hero {
        background-image: url(../images/shared/rsd-hero-square.jpg);
    }
    
    .header-text-container {
        width:240px;
        margin-left:15% !important;
        margin-top:8% !important;
    }

    .header-text-container h1{
        font-size:24px !important;
    }
    
    .header-image-container{
        height:260px;
        width:104px;
        margin-right: 15% !important;
    }
    
    .textWrapper {
        width:80%;
    }    .textWrapper {
        width:90%;
    }
    
    .textWrapper p {
        padding-left:10px;
    }
    
    .textWrapper .smallText {
        padding-left:5px;
    }
    
    .textWrapper li {
        padding-left:0px;
    }
}

/* ======================== */
/* Bootstrap Menu Overrides */
/* ======================== */

.navbar-default {
    background-color: #000000 !important;
  /*  border-color: #7d7d7d !important;*/
    border-color: #000000 !important;
}

@media (min-width: 768px){
    .navbar-nav {
        float:right !important;
        margin: 0;
    }
}
.navbar-default .navbar-toggle {
    border-color: #7d7d7d !important;
}

@media (max-width: 1024px) {
  .navbar-header {
      float: none;
  }
  .navbar-left,.navbar-right {
      float: none !important;
  }
  .navbar-toggle {
      display: block;
  }
  .navbar-collapse {
      border-top: 1px solid transparent;
      box-shadow: inset 0 1px 0 rgba(255,255,255,0.1);
  }
  .navbar-fixed-top {
      top: 0;
      border-width: 0 0 1px;
  }
  .navbar-collapse.collapse {
      display: none!important;
  }
  .navbar-nav {
      float: none!important;
      margin-top: 7.5px;
  }
  .navbar-nav>li {
      float: none;
  }
  .navbar-nav>li>a {
      padding-top: 10px;
      padding-bottom: 10px;
  }
  .collapse.in{
      display:block !important;
  }
}

/* ================== */
/* Lightbox Overrides */
/* ================== */

.navbar-nav>li {
    font-size:18px !important;
    text-align:right !important;
}

.lb-nav a.lb-next, .lb-nav a.lb-prev {
   /* margin-top: -20px !important;*/
}

