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

:root {
    --std-font-color: #464646;
    --std-link-color: rgb(145, 52, 52);
}

html, body {    
    font-size: 100%;    
    height: 100%;
    color:var(--std-font-color);
}



a:hover, a:visited, a:link, a:active {
    text-decoration: none;    
}


.topbar {
    height: 45px;
    padding: 0 10px;
    flex-direction: row;
}

.footer {
    align-self: end;
    text-align: center;
    padding: 20px;
}

.footer-hr {
    width: 100%;
}

.link-style-none {
    text-decoration: none;
}

.link-white, .link-white a:visited, .link-white a:link {
    color: white;
}
.list-style-none {
    list-style: none;
}
.list-indent-none {    
    padding: 0;
    
}

a, a:visited {
    color: var(--std-link-color);
}

.page-container {    
    min-height:100%;
    display: flex;
    flex-direction: column;
}

.main {
    flex: 1
}

.flex-grow {
    flex: 1;
    height: 100%;
}

.col {
    flex-direction: column;
}

.link-white a:hover {
  color: #08A6FD;  
  transition: .25s;
  text-decoration: none;
}
.text-center {
    text-align: center;
}
.align-center {
    align-self: center;
}
.align-end {
    align-self: end;
}
.align-items-center {
    align-items: center;
}
.justify-center {
    justify-content: center;    
}
.space-evenly {
    justify-content: space-evenly;
}
.space-around {
    justify-content: space-around;
}

.row {
    padding: 0 10px;
}

.bg-dkgray {background-color: #454545;} /* footer*/
.bg-ltblue {background-color: lightblue;} /* a href */
.bg-white {background-color:#fff;} /* Pagecontent*/
.bg-blue {background-color:rgb(73, 109, 160);} /* Topbar*/
.bg-brightblue {background-color: rgb(42, 85, 146)};
.bg-red {background-color: red;}
.bg-black {background-color: black;}
.bg-ltgray {background-color: lightgray;}
.color-default {color: #464646;}
.color-red {color: red;}
.color-white, .link-color-white {color: white;}
.color-black, .link-color-black {color: black;}
.color-gray, .link-color-gray {color: gray;}
.color-ltgray, .link-color-ltgray {color: lightgray;}
.bold {font-weight: bold}
.font-xs {font-size: 0.7rem;}
.font-sm {font-size: 0.8rem;}
.font-med {font-size: 1.0rem;}
.font-lg {font-size: 1.1rem;}
.font-xl {font-size: 1.2rem;}
.font-xxl {font-size: 1.4rem;}
.padding-15 {padding: 15px;}


.space-between {justify-content: space-between;}
.no-padding {padding: 0;}

.container {    
    display: flex;    
    width: 100%;
}

.container-md {
    display: flex;
    flex-direction: column;
    width: 100%;
}
.box-shadow-19-5 {
    box-shadow: 0px 0px 19px 5px rgba(0,0,0,0.19);
    background-color: rgb(235,235,235);

}

.flex-row {
    flex-direction: row;
}
.flex-column {
    flex-direction: column;    
}

.flex-row > div {
    padding: 0 10px;
}

.sticky {
    position: sticky;
    z-index: 15;
}

.position-top {    
    top: 0;
}


.fillwidth {
    width: 100%;
}

a:hover {
    text-decoration:underline;
}

h1 {
    font-weight: bold;
    font-size: 1.25rem;    
}

h2 {
    font-weight: bold;
    font-size: 1.2rem;
    margin:0px;
    padding:5px 0px;
}
h3 {
    font-size: 1.0rem;
    margin: 0px;
    padding: 0px 0;
}

body {
    font-family: "Lato", sans-serif; /* Establishes the font */    
    height:100vh;
    width:100%;
    line-height: 1.5;
}
p {    
    width:100%;
    padding: 5px 0;    
    /*margin: 0 0 15px 0;
    
    padding: 10px 0px;*/
}

p b{
    font-size:0.9rem;
}

ol {
    font-size:.9rem;
    padding: 2px 10px;
}
ol li {
    list-style-position: inside;
    text-indent: -1.0rem;
    margin-left: 1.0rem;       
}
ul {
  font-size:0.9rem;
  padding: 2px 10px;
  margin-bottom: 5px;

}
ul li {
    list-style-position: inside;
    text-indent: -1.0rem;
    margin-left: 1.0rem;
}

td {
  vertical-align: top;
}

table td{
    padding: 0 3px;
}


.disable-link {
    pointer-events: none;
}

.businesscard {
    background-image: url('/img/pageTitle.png');  
    background-size: cover;
    
    color: white;
    font-size: 1.25rem;
}
.businesscard a{
    color: white;
}
.businesscard a:hover{
    color: white;
}

.information {    
    display: block;
    position: relative;
    padding: 0 5px;    
}
.contact-wrapper {    
    display: block;
    width: 600px;
    text-align: center;
    margin: 0 auto;    
    line-height:initial; 
    max-width: 600px;   
}
.contact-item-12 {
    width: 100%;
}
.contact-item-6 {    
    display: inline;
    width: 45%;
}


.info-wrapper {
    display:block;
    width:100%;
    max-width:800px;
    margin: 0 auto;    
    font-size: 0.9rem;
}

.content-wrap {
    padding-bottom: 2.5rem; /* Footer height */
}
.content-wrap-large {
    padding-bottom: 10rem; /* Footer height */
}
.centered-dropbox {
    width: 100px;
    margin: 0 auto;
}

.centered-wrapper1 {
    height: 100%; /*auto*/
    margin: 0 auto;    
    border: 1px solid black;
    /*padding-bottom: 20px;*/
}

.centered-appt {
    width:1100px;
    max-width:100%;
    margin: 0 auto;    
    padding-bottom: 20px;
    font-size:0.9rem;
}

.container-flex {
    display: flex;
    justify-content: space-between;
}
.flex-item-large {
    display: inline-block;
}

.zoho-overlay {        
    height: 100vh;
    width: 100%;
    z-index: 98;
    position: absolute;
    top: 0;
    left: 0;
    background-color: gray;
    opacity: 75%;
}
.zoho-questionnaire {
    
    z-index:99;
    background-color: darkgray;

}

.footer a{
    color: #FFFFFF; /*white;*/    
}
.footer a:link a:visited {color: #FFFFFF;}

.footerleft {
    /*width:10%;*/
    position: absolute;
    left:0px;        
    padding-left: 10px;
    display:inline;
}
.copyright {
    margin: 0 auto;
    text-align:center;    
    /*position: relative;    */
    width:275px; /*80%;*/    
}
.copyright span {
    font-size:.6rem;
    font-weight:normal;
}
.disclaimer {
    justify-content:center;
    width:50%;
    position:relative;
    margin: 0 auto;
    font-size:inherit;
    text-decoration:none;
    text-align:center;
}
.footerright {     
    position: absolute;
    right: 0px;
    padding-right: 10px;
}

.topofpage {
    /*font-size: inherit;*/
    /*color: rgb(128, 128, 128);    */
    position: absolute;
    right: 0px;    
}
/*.topofpage a{
    padding-right:10px;
    font-size:inherit;
}
.topofpage a:link {color: white}
.topofpage a:visited {color: white}*/


.align-top {
    align-content: flex-start;
}

.header {    
    line-height: 1.0;
}
.header a{
    color: white;
}

.logo {
    height: 100%;
    float: left;
    padding-left: 50px;    
}
.logo img {
    height:100%;
}

.socialblock {    
    position:relative;
    display: block;
    float:left;
    padding:0px 5px 5px 50px;
    background-color:rgb(73, 109, 160);
}
.vertical-center {
    position: absolute;
    margin: 0;
    top: 50%;    
    transform: translateY(-50%);
}

.container-menu {
    padding:0 20px;
    background-color:rgb(230, 230, 230);
    height: 50px;
    line-height: 50px; 
    /*top: 45px;*/
    border-bottom: darkgray 1px solid;
    
}
.containerimage {
    margin: 0 auto;
    position:relative;    
    /*height: auto;*/
    /*top: -24px;    */
}
.containerimage img{
    width:100%;
    height:auto;
    /*object-fit:cover;*/
}
.containerimage-membership {
    margin: 0 auto;
    position:relative;    
    top: 0px;
}

.containerimage-membership img{
    width:100%;
    height:auto;
}
.photo-text {
    /*position:relative;    */
    position: absolute;
    /*display: inline-block;*/
    top:10px;
    z-index:1;
    color: white;
    font-weight: bold;
    padding: 0 5px;
    border-radius: 5px;
    margin-left:30px;
    background-color: rgba(0,0,0,0.3);
}
.photo {    
    top:0;
    left:0;
}
.photo-membership {
    position: relative;
    padding:5px 70px 5px 50px;
    top:0;
    left:0;
}

.container-pagetitle {    
    width: 100%;    
    /*position: relative;*/
    display: block;
    background:url("/img/pageTitle.png");
    background-repeat:repeat;
    line-height: 60px;
    padding: 0;
    margin: 0;
    
}
.pagetitle {
    /*margin: auto 0;*/
    line-height: 60px;
    text-align: center;        
    color: white;
}

.reviews {
    width: 100%;
    height:150px;
    
    background: url("/img/Handshake-2004x705.webp") no-repeat;
    background-position:center;
    background-size:cover;
    filter:blur(2px);
    -webkit-filter:blur(2px);
    margin-bottom: 40px;
}
.imgblackoverlay {
    background-color: rgb(0,0,0); /* Fallback color */
    background-color: rgba(0,0,0,0.3); /* Black w/opacity/see through */
    position: absolute;
    transform: translate(0,-190px);
    width: 100%;
    height: 150px; /* added to prevent stretch if goes to three lines*/
    display: flex;

}
.testimonial {        
    align-self: center;
}

.staffbio {
    border-bottom:solid;
    border-bottom-width:4px;
    border-bottom-color:rgb(80, 130, 180);
    margin-bottom:20px;
}
.getready {
    padding:5px 0px;
}
/*.getready a:hover {
    background-color: lightblue;
    
    
}
.getready a:link {
    text-decoration: underline;
    color: blue;
}*/

.clienttable {
    display:grid;
    border-collapse:collapse;
    width:100%;
}


.getready clienttable {
    border:1px solid black;
    table-layout:auto;
    width:100%;
}
.clienttable td {
    padding: 2px 5px 2px 20px;
    text-indent: -15px;
    border: 1px solid black;
    vertical-align: top;
    font-size: .8rem;
}
.clienttable tr {
    width: 100%;
}

.clienttable tr:hover>td {
    background-color:#454545;
    color: white;
}

.clienttable th {
    font-weight: bold;
    font-size: .8rem;
    text-align: center;
    border: 1px solid black;
    text-decoration: none;
    background-color:lightgrey;
}
.clienttable b {
    font-size:0.8rem;
}
.btn-large {
    width:8rem;
    height:2.5rem;
    margin: 5px 0;
    padding:0.5rem 0.5rem;
    font-size:0.9rem;
    font-weight: bold;    
    cursor:pointer;
    transition:0.3s;
    position:relative;
    border-radius: 10px;    
    border:none;
}
.btn-large:hover {
    font-size: 1.0rem;
}
.btn-red {
    /*background-color: rgb(255, 10, 10);*/
    background-color: red;
    color: white;    
}
.btn-red:hover {
    background-color: rgb(169, 0, 0);    
}
.btn-gray {
    color: var(--std-font-color);
}
.btn-gray:hover {
    background-color: #bfbdbd;
}
.btn-client {
    width:8rem;
    height:2.5rem;
    margin: 1px 0;
    padding:0.5rem 0.5rem;
    font-size:.9rem;
    font-weight: bold;    
    cursor:pointer;
    transition:0.2s;
    position:relative;
}
    .btn-client:hover {
        background-color: #bfbdbd; 
}
.span-organizer {
    font-style:italic;
    font-weight:600;
    color: #1F1F1F;
}
.googlemap {
  width: 100%;
  height: 400px;
  padding-bottom: 20px;
}


/*** End JJackson CPA Main Style Sheet ****/

/**** Side Navigation Class ********/
/**** Creates the sidenav class ****/
.menubtn {
    position: relative;
    /*margin: 15px 15px;*/
    float: right;
    z-index: 10;
    color: var(--std-font-color);
}

.sidenav {
    height: 100%;
    line-height: 1.0;
    width: 0;
    position: fixed;
    z-index: 20;
    top: 0;
    right: 0;
    background-color: #e3e3e3;
    overflow-x: hidden;
    transition: 0.5s;
    padding-top: 15px;
}

    .sidenav a {
        padding: 2px 8px 2px 20px; /*32px; */
        text-decoration: none;         
        font-size: 0.9rem;
        color: #090909;
        display: block; /*fills entire line to keep menu in one column */
        transition: 0.3s;        
    }
    .sidenav a:hover {
        /*color: #584a4a;*/            
        background-color: #b2afaf;            
    }

    .sidenav .closebtn {
        /*position: absolute;*/
        /*right: 25px;        */
        /*top: 0;                */
        position:relative;        
        text-align: right;   
        font-size: 36px;        
    }

    .sidenav ul {        
        padding: 0;
        list-style:none;         
    }

        .sidenav ul li ul {
            padding-left: 10px;
            position: relative; /*fixed;*/
            left: 0px;
            display: inherit;
            list-style:none;
        }    
    
/**** End of Side Navigation0 Class ****/

/**** @Media Screen Styles ****/






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

    html, body {
        
    }

    .topbar {
        flex-direction:column;
    }

    .sidenav a {
        padding: 5px 8px; /*32px; */
    }
    .container-md {
        flex-direction: column;
    }
    
    .container-menu {        
        height: 50px;
        line-height: 50px;
    } 
        
    .contactblock {
        text-align: center;
    }
    .centered-wrapper {
        padding: 0 5px;        
        font-size: 0.9rem;
    }    
    
    .infomiddle {
        border-top-style: solid;
        border-bottom-style: solid;
        border-right-style: none;
        border-left-style: none;     
    }
    .testimonial {
        margin-top: 20;
    }

    .logo {
        padding-left: 0;
    }

    .contact-wrapper {
        width: 100%;
    }

    .googlemap {
        width: 100%;
        height: 300px;
        padding-bottom: 10px;
    }
}


@media screen and (min-width: 450px) {
    * {
        padding:0;margin:0;
    }

    .sidenav a {
        padding: 5px 8px; /*32px; */
    }

    .topbar {
        /*display: flex;*/
        /*line-height: 45px;*/
        flex-direction: column;
    }

    .flex-lg-row {
        flex-direction: column;
    }

    .flex-lg-row > div {
        padding: 3px 0 0 0;
    }
    
    .photo-text {
        font-size: 0.5rem;
    }
    .sidenav {
        padding-top: 15px;
    }

    .sidenav a {            
        font-size: 0.9rem;        
    }
    .socialblock {
        display:none;
    }
        
    .info-wrapper {
        width: 100%;
    }
    .info-wrapper p{
        padding:5px 0px;        
    }
    .centered-wrapper {
        /*width:450px;*/
        padding: 0;
    }
    .showme500 {
        visibility: hidden;
    }

    .logo {
        height:100%;
        padding-left: 0px;        
    }

    .contact-wrapper {
        width: 100%;
    }

    .googlemap {
        width: 100%;
        height: 300px;
        padding-bottom: 10px;
    }
       
}

@media screen and (min-width: 500px) { 
    html, body {
        font-size: 12pt;
    }
    
    .menubtn {                
        font-size: 0.8rem;        
    }

    .sidenav a {
        padding: 5px 8px; /*32px; */
    }
    

    .topbar {
        /*display: flex;*/
        /*line-height: 45px;*/
        flex-direction: column;
    }
    
    .breadcrumb {
        text-align: left;
    }

    .contactblock {
        text-align: right;
    }
    
    .centered-wrapper {        
        margin: 0 auto;        
    }
    .container-menu {        
        height: 60px;
        line-height: 60px;
    }    
    .photo-text {                
        font-size: .6rem;        
        padding: 0 3px;
        margin-left:3px;                    
    }     
    .logo {
        height:100%;
        padding-left: 0px;        
    }   

    .contactblock {
        text-align: right;     
        color: white;        
    }

    .contact-wrapper {
        width: 100%;
    }

    .googlemap {
        width: 100%;
        height: 400px;
        padding-bottom: 10px;
    }
}

@media screen and (min-width: 600px) {
    html, body {
        font-size: 1.0rem;
        
    }

    .sidenav a {
        padding: 2px 8px; /*32px; */
    }

    .topbar {
        flex-direction: row;        
    }

    .flex-lg-row {
        flex-direction: row;
    }

    .flex-lg-row > div {
        padding: 0 10px;
    }

    .centered-wrapper {
        width: 600px;        
    }
    .information {
        padding-left: 5px;
        padding-right: 5px;
        font-size: 1.0rem;
    }
    .photo-text {
        margin-left: 20px;
        font-size: 0.7rem;
    }

    .logo {
        padding-left: 50px;
    }

    .container-menu {
        height: 100px;
        line-height: 100px;
    }
   
    .googlemap {
        width: 100%;
        height: 500px;
        padding-bottom: 10px;
    }
    
}

@media screen and (min-width: 900px) {    

    .container-md {
        flex-direction: row;
    }
    .footer-hr {
        display: none;
    }
    
    .footer-contactblock {
        text-align: left;
    }

    .footer-items :nth-child(2) {order: 3}

    .centered-wrapper {
        width: 100%;
        max-width:900px;        
    }
    .information {
        padding-left: 5px;
        padding-right: 5px;
        font-size: 1.0rem;
    }
    .photo-text {
        margin-left: 20px;
        font-size: 0.7rem;
    }

    .sidenav a {
        padding: 2px 8px 2px 32px;
        font-size: 1.0rem;
    }

    .googlemap {
        width: 100%;
        height: 600px;
        padding-bottom: 20px;
    }
    
    
}
