/* -------------------------------------- 
    COLOR HEADINGS: #111 [DARK GREY]
    COLOR FONT: #111 [DARK GREY]
    ROOT FONT-SIZE: 16px
    SITE KEY FONT: Manrope-Regular
    REM: 1rem = 16px
    REM FOR FONT-SIZE X: REM = X/16PX
    EM: 1em = 16px (for padding/margins)
    PADDING: TOP, RIGHT, BOTTOM, LEFT
 -------------------------------------- */

/* ------------------------------------ */
/* FONTS                                */
/* ------------------------------------ */

@font-face {
    font-family: "Manrope-Regular";
    src: url(Manrope-Regular.woff);
    font-display: swap;
}

@font-face  {
    font-family: "Comfortaa-SemiBold";
    src:  url(Comfortaa-SemiBold.woff);
    font-display:  swap;
}

@font-face  {
    font-family: "Comfortaa-Bold";
    src:  url(Comfortaa-Bold.woff);
    font-display:  swap;
}

@font-face  {
    font-family: "Manrope-Bold";
    src:  url(Manrope-Bold.woff);
    font-display:  swap;
}



/* ------------------------------------ */
/* BASIC SET-UP                         */
/* ------------------------------------ */

*  {
    margin:  0;
    padding:  0;
    box-sizing:  border-box;
}

.speed  {
    text-rendering:  optimizeSpeed;
}

.legibility  {
    text-rendering:  optimizeLegibility;
}

html,  body  {
    background-color:  #fff;
    font-family:  "Manrope-Regular";
    color:  #111;
    overflow-x:  hidden;
    scroll-behavior:  smooth;
}

.row  {
    max-width:  1340px;
    margin:  0 auto;
}

section  {
    padding-top:  5px;
    padding-bottom:  20px;
}

header  {
    background-image:  linear-gradient(rgba(0,  0,  0,  0),  rgba(0,  0,  0,  0.0),  rgba(0,  0,  0,  0.2)),  url("../images/hero.webp");
    background-size:  cover;
    background-position:  center;
    min-height:  100vh;
    background-attachment:  fixed;
}

/* used for floating elements */
.clearfix  {
    zoom:  1;
}

.clearfix:after  {
    content:  ".";
    clear:  both;
    display:  block;
    height:  0;
    visibility:  hidden;
}

hr  {
	margin-bottom: 2%;
	margin-top: 2%;
	height: 0.5px;
	width: 100%;
}

/* ------------------------------------ */
/* TYPOGRAPHY: KEY                      */
/* ------------------------------------ */

:root  {
    font-size:  17px;
}

h1,  
h2,  
h3,  
h4  {
    color:  #111;
    word-spacing:  0.2rem;
    width:  90%;
    margin-left:  5%;
}

/* site-wide h1 */
h1  {
    font-family: "Comfortaa-SemiBold";
    font-size:  2.5rem;
    font-weight:  200;
    text-align:  center;
    text-transform:  uppercase;
}

/* site-wide h2 */
h2  {
    font-family:  "Comfortaa-SemiBold";
    font-size:  1.5rem;
    font-weight:  200;
    text-align:  center;
    text-transform:  uppercase;
    padding-bottom:  0.8em;
    padding-top: 0.5em;
}

/* fontawesome icon in H2 */
h2 i  {
    padding-right:  0.4em;
}

h3  {
    font-family:  "Comfortaa-SemiBold";
    font-size:  1.1rem;
    line-height:  1.9rem;
    font-weight:  200;
    text-align:  center;
    text-transform:  uppercase;
    padding-top:  0.5em;
}

/* site-wide p */
p  {
    font-size:  1rem;
    line-height:  1.8rem;
    color:  #111;
    hyphens:  auto;
    width:  90%;
    margin-left:  5%;
    text-align:  justify;
    padding-top:  0.1em;
    padding-bottom:  0.9em;
}

span-bold {
    font-family: "Manrope-Bold";
     word-wrap: normal;
     hyphens: auto;
}

/* ------------------------------------ */
/* TYPOGRAPHY: HERO & INDEX             */
/* ------------------------------------ */

/* HERO LANDING PAGE TYPOGRAPHY */
.hero-text-box  {
    position:  absolute;
    width:  1142px;
    left:  50%;
    top:  92%;
    -webkit-transform:  translate(-50%,  -92%);
    -ms-transform:  translate(-50%,  -92%);
    transform:  translate(-50%,  -92%);
}

.hero-text-box h1,  
.hero-text-box h2  {
    color:  #fff;
    text-align:  center;
}

.hero-text-box h1  {
    font-size: 4rem;
    margin-bottom: 0.2em;
    font-family: "Comfortaa-SemiBold"; 
    line-height: 1em; 
    text-transform: uppercase; 
    letter-spacing: 0.02em;
}

.hero-text-box h2  {
    font-family: "Comfortaa-SemiBold";
    font-size: 1.3rem;
    word-spacing: 0.1em;
    margin-top:0em;
    letter-spacing: 0.05em;
}

.site-start  {
    text-align:  center;
    padding-top:  2em;
    margin-top: 25em;
}

.site-start i  {
    color:  #fff;
    font-size: 1.2rem;
}

/*INDEX HEADINGS*/
.index-h1 {
    font-family:"Comfortaa-SemiBold";
    font-size: 1.4rem;
    margin-top: 4em;
    color: #111;
}

.index-h2 {    
    font-family: "Comfortaa-SemiBold";
    text-transform: uppercase;     
    font-size: 3.6rem;
    margin-top: -0.5em;
    margin-bottom: -0.2em;
    letter-spacing: 0.1em;
    color: #111;
}

.index-image {
    margin: 0 auto;
    text-align: center;
    margin-top: 1.2em;
    margin-bottom: 2em;
}

/* --------------------------------------------- */
/* TYPOGRAPHY: PAGES WITH 2-OF-3 AND 1-OF-3 COLS */
/* --------------------------------------------- */

.page-in-columns {
    margin-top: 4em;
}

.page-in-columns h1,  
.page-in-columns h2 {
    text-align:  left;
}
.page-in-columns h1  {
    font-size:  1.7rem;
    margin-top: -0.8em;
}
.page-in-columns h2  {
    font-size:  1.2rem;
    line-height: 2rem;
    margin-top:  -1em;
    margin-bottom: -1em;
    margin-bottom: -1em;
}

/* --------------------------------------------- */
/* TYPOGRAPHY: PAGES FULL-WIDTH                  */
/* --------------------------------------------- */

.page-full-width {
    margin-top: 4em;
}

.page-full-width h1,  
.page-full-width h2  {
    text-align:  left;
}
.page-full-width h1  {
    font-size:  1.7rem;
    margin-top: -1em;
}
.page-full-width h2  {
    font-size:  1.2rem;
    line-height: 2rem;
    margin-top:  -1em;
    margin-bottom: -1em;
    margin-bottom: -1em;
}

.page-full-width {
    padding-top: 3px;
}

/* ------------------------------------ */
/* TYPOGRAPHY: BULLETR POINTS           */
/* ------------------------------------ */

ul  {
    list-style:  none;
}

ul li span-1  {
    font-family:  "Manrope-Regular";
}

/* bullet points for lists */ 
ul.bullet-point-regular  {
    list-style:  none;
    margin-top:  0em;
    margin-left:  2.9em;
}

ul.bullet-point-regular li  {
    line-height:  1.7rem;
    counter-increment:  step-counter;
}

ul.bullet-point-regular>li::before  {
    font-family:  FontAwesome;
    color:  #111;
    content:  "\f138";
    padding-right:  1em;
    list-style-position:  outside;
}

ul.bullet-point-regular li:last-child  {
    margin-bottom:  1.5em;
}

/* ------------------------------------ */
/* TOP NAVIGATION MENU                  */
/* ------------------------------------ */

#container {
    margin: 0 auto;
    scrollbar-gutter: stable both-edges;
}

.toggle,
.toggle-menu,
[id^="drop"] {
    display: none;
}

nav {
    margin: 0;
    padding: 0;
    background-color: #333;
    font-family: "Manrope-Regular";
    letter-spacing: 0.5px;
}

#logo {
    display: block;
    float: right;
    font-size: 18px;
    color: #fff;
    padding: 17px 15px 0px 15px;
    vertical-align: middle;
}

.logo-img {
    float: right;
    margin-right: 0.4em;
    margin-top: 1px;
}

nav:after {
    content: "";
    display: table;
    clear: both;
}

nav ul {
    float: left;
    margin-left: 20px;
    padding: 0;
    list-style: none;
    position: relative;
}

nav ul li {
    margin: 0px;
    display: inline-block;
    float: left;
}

nav a {
    display: block;
    padding: 23px 20px 20px 20px;
    color: #fff;
    font-size: 14px;
    text-decoration: none;
}

.drop-down a {
    font-family: "Manrope-Regular";
    font-size: 12px;
    line-height: 20px;
    border-top: 0px;
    border-bottom: 1px solid #3C3C3C;
    padding: 9px 9px 9px 15px;
}

nav i {
    margin-right: 10px;
    font-size: 13px;
}

nav ul li ul li:hover {
    background: #333;
}

nav a:hover {
    background-color:  #3C3C3C;
}

nav ul ul {
    display: none;
    position: absolute;
    top: 60.5px;
    margin-left: 0px;
}

nav ul li:hover > ul {
    display: inherit;
}

nav ul ul li {
    width: 310px;
    float: none;
    display: list-item;
    position: relative;
    text-align: left;
    background-color: #222;
}

.sticky {
    position: fixed;
    width: 100%;
    z-index: 9999;
    top: 0;
    left: 0;
    width: 100%;
}

@media all and (max-width: 725px) {
#logo {
        font-size: 90%;
        margin-top: -4px;
        float: left;
    }
    
.logo-sub {
    font-family: "Comfortaa-SemiBold";
    }

.logo-img {
    width: 112px;
    height: 25px;
    margin-top: -4px;
}

nav {
    margin: 0;
    border-bottom: 1px  #3C3C3C solid;
    padding-top: 10px;
    font-family: "Manrope-Regular"; 
}

.toggle + a,
.menu {
    display: none; 
    height: calc(100vh - 50px);
    overflow-y: scroll;
}

nav a {
    line-height: 30px;
    padding: 12px 12px 9px 12px;        
    font-size: 1.15em;  
}
    
nav .menu li:last-of-type {
          margin-bottom: 50px;
} 
    
nav .drop-down li:last-of-type {
          margin-bottom: 0px;
}     
    
nav i {
    margin-right: 0.3em;
    width: 2em;
    font-size: 18px;
}

.toggle-menu {
    display: block;
    background-color: #333;
    text-align: right;
    padding-left: 15px;
    padding-right: 10px;
    padding-top: 0em;
    color: #fff;
    text-decoration: none;
    font-size: 24px;
    line-height: 50px;
    font-family: "Manrope-Regular";
    overflow-y: scroll; 
}

.toggle-menu i {
    font-size: 30px;
}

.toggle {
    display: block;
    background-color: #333;
    text-align: left;
    padding-left: 15px;
    color: #fff;
    text-decoration: none;
    line-height: 45px;
    padding: 4px 12px 4px 12px;            
    font-size: 1.15em;
}

.toggle:hover {
    background-color: #333;
}
    
[id^="drop"]:checked + ul {
    display: block;
}

.drop-down a {
    border-top: 0px;
    border-bottom: 1px solid #3C3C3C;
    border-right: 1px solid  #3C3C3C;
    border-left: 1px solid  #3C3C3C;
    margin-top: 2px;
    padding-top: 7px;  
    font-size: 1.15em;
    line-height: 1.6em;
}

.drop-down {
    width: 100%;
    margin-left: 0%;
}

.drop-down a {
    padding: 6px 12px 6px 12px;
}

nav ul li {
    display: block;
    width: 100%; 
}

nav ul ul .toggle,
nav ul ul a {
    padding: 0 40px;
}

nav ul ul ul a {
    padding: 0 80px;
}

nav a:hover,
nav ul ul ul a {
    background-color: #333;
}

nav ul li ul li .toggle,
nav ul ul a,
nav ul ul ul a {
    color: #fff;
    padding-bottom: 5px;
    background-color:  #3C3C3C;
}

nav ul ul {
    float: left;
    position: static;
    color: #ffffff;
    width: 100%;
}

nav ul ul li:hover > ul,
nav ul li:hover > ul {
    display: none;
}

nav ul ul li {
    display: block;
    width: 100%;
    border-bottom: 1px solid  #3C3C3C;
}

nav ul ul ul li {
    position: static;
    width: 100%;
}

.sticky {
    position: fixed;
    width: 100%;
    z-index: 9999;
    top: 0;
    left: 0;
    width: 100%;
}

}

/* --------------------------------- */
/* INDEX PAGE: EXPLORE CATEGORIES    */
/* --------------------------------- */

.all-categories h2 {
    font-size: 1.2em;
    margin-bottom: 20px;
    margin-top: 15px;
}

.all-categories-bottom {
    margin-left: 0%;
    width: 100%;
}

.all-categories-bottom h2 {
    font-size: 1.2em;
    margin-bottom: 20px;
    margin-top: 15px;
}

.categories-index  {
    margin-left:  5%;
    margin-bottom:  1.3em;
    margin-top: 0em;
    width: 92.5%;
}

.single-category-index {
    border: dotted 1px #525252;
    border-radius: 0.2em;
    width: 95%;
    padding: 0.2em 0.5em 1.3em 0.4em;
    margin-bottom:2em;  
    page-break-inside: avoid;
}

.categories-index h3  {
    padding: 0.8em 0.1em 0 0.1em;
    padding-right:  0em;
    margin-left:  0em;
    width:  100%;
    font-family: "Comfortaa-Bold";
    font-size:  0.8em;
    line-height:  1.7em;
    text-transform:  uppercase;
    color:  #111;
    text-align: left;
    hyphens: auto;
}

.categories-index p  {
    font-family: "Manrope-Regular";
    font-size:  0.8em;
    line-height: 1.5em;
    text-transform:  none;
    color:  #111;
    text-align: left;
    hyphens: auto;
    margin-left: 0%;
}

.categories-index img  {
    float: right;
    margin-right:  0%;
    margin-top: 2.5%;
    margin-right:-1.5%;
    
}

.goto-category {
    border-radius: 1px;
    color: #000;
    font-size: 0.75em;
    text-transform: uppercase;
    font-family: "Comfortaa-Bold";
    text-decoration: underline;
    padding-top: 10px;
}

.single-category-index i {
    color: #111;
}

/* ------------------------------------ */
/* LINKS                                */ 
/* ------------------------------------ */

/* BLACK LINKS */
a.goto-black:link  {
    text-decoration:  underline;
    color:  #111;
    line-height:  1.5rem;
}
a.goto-black:visited  {
    text-decoration:  underline;
    color:  #111;
}
a.goto-black:hover  {
    text-decoration:  underline;
    color:  #111;
}
a.goto-black:active  {
    text-decoration:  underline;
    color:  #111;
}

/* WHITE LINKS */
a.goto-white:link  {
    text-decoration:  underline;
    color:  #fff;
    line-height:  1.5rem;
}
a.goto-white:visited  {
    text-decoration:  underline;
    color:  #fff;
}
a.goto-white:hover  {
    text-decoration:  underline;
    color:  #fff;
}
a.goto-white:active  {
    text-decoration:  underline;
    color:  #fff;
}

/* ------------------------------------ */
/* BREADCRUMBS                          */ 
/* ------------------------------------ */
.breadcrumb  {
    margin:  1.1em 0em 3.2em 5%;
    list-style:  none;
    width:  90%;
    line-height:  1.5rem;
    color:  #111;
    text-align:  left;
    background-color:  #f4f4f4;
    border-radius:  2px;
    padding-top:  0.3em;
    padding-bottom:  0.28em;
    padding-left:  0.6em;
}
.breadcrumb-item  {
    font-family:  "Comfortaa-SemiBold";
    display:  inline;
    font-size:  0.8rem;
}
.breadcrumb li:not(:last-child):after  {
    font-family:  FontAwesome;
    font-size:  0.7rem;
    padding:  0em 0.5em 0em 0.7em;
    content:  "\f101";
}
.breadcrumb li:last-of-type  {
    color:  #111;
    text-decoration:  none;
    content:  none;
    text-transform:  uppercase;
}
a.breadcrumb-link:hover,  
a.breadcrumb-link:visited,  
a.breadcrumb-link:link  {
    color:  #111;
    text-decoration:  underline;
}

/* ----------------------------------- */
/* IMAGES                              */
/* ----------------------------------- */

.image-2-of-3-cols-square  {
    float:  left;
    margin:  1.3em 0.8em 0em 0em;
}

/* ------------------------------------ */
/* INCLUDE RHS: COLUMN                  */ 
/* ------------------------------------ */

.rhs-column {
    margin-top: -0.4em;
}

.rhs-column img {
    margin-top: 1.5em;
}

/* ------------------------------------ */
/* CONTACT FORM                         */ 
/* ------------------------------------ */
.contact-form  {
    font-family:  "Manrope-Regular";
    margin-left:  5%;
    margin-top:  1em;
}
.email-comment  {
    margin-bottom:  0.8em;
}
.contact-submit-button  {
    font-family:  "Comfortaa-SemiBold";
    font-size:  1em;
    color:  #fff;
    background-color:  #111;
    padding:  0.4em 0.8em 0.3em 0.8em;
    border:  1px solid #fff;
    border-radius:  4px;
    margin-top:  1em;
}

.contact-page {
    margin-top: 1.5em;
    margin-left: 2.5%;
}

/* ----------------------------------- */
/* SEPARATORS */
/* ----------------------------------- */

.quote-with-icon {
    margin-top: 20px;
    margin-bottom: 20px;
}

.line-icon {
    text-align: center;
    background-position: center center;
}

.line-icon::before, .line-icon::after {
    width: 30%;
    height: 1px;
    border-top: 1px solid #111;
    display: inline-block;
    content:'';
    margin-left: 1%;
    margin-right: 1%;
}

.line-icon-text {
    font-family: "Manrope-Regular"; 
    color: #111; 
    width: 65%; 
    margin-left: 17.5%; 
    padding-top: 15px; 
    padding-bottom: 15px; 
    text-align: center;
    font-style: italic;
}

/* ------------------------------------ */
/* BUTTONS: LOVE & SHARE                */ 
/* ------------------------------------ */
/* positioning */
.love-it {
text-align: center;
}
.share-buttons  {
    margin: 0 auto;
    text-align: center;
    margin-bottom: 2em;
    margin-top: 2em;
}
.shareon-positioning  {
    margin-top:  -0.3em;
}

.shareon  {
    font-size:  0 !important;
    margin-left: -10px;
}
.shareon>*  {
    display:  inline-block;
    position:  relative;
    height:  27px;
    min-width:  19px;
    margin:  0px 5px 20px 13px;
    padding:  6px 0px;
    background-color: #fff;
    border-radius:  3px;
    border:  0;
    box-sizing:  content-box;
    color:  #fff;
    line-height:  1.5;
    transition:  opacity 300ms ease;
    vertical-align:  middle;
}
.shareon> :hover  {
    border:  0;
    cursor:  pointer;
    opacity:  0.7;
}
.shareon> :not(:empty)  {
    font-size:  16px;
    text-decoration:  none;
}
.shareon> :not(:empty)::before  {
    position:  relative;
    height:  100%;
    width:  0px;
    top:  0;
    left:  0;
    background-position:  0 50%;
}.shareon>.facebook i  {
    color: #111;
    font-size:  2em;
}.shareon>.linkedin i  {
    color: #111;
    font-size:  2.1em;
}.shareon>.reddit i  {
    color: #111;
    font-size:  2em;
}.shareon>.twitter i  {
    color: #111;
    font-size:  2em;
}.shareon>.viber i  {
    color: #111;
    font-size:  2.1em;
    padding-top:1px;
    margin-left: -3px;
}.shareon>.whatsapp  i {
    color: #111;
    font-size:  2.25em;
    margin-top: -2px;
}

/* ----------------------------------- */
/* FOOTER */
/* ----------------------------------- */

footer {
    background-color: #111;
}

footer img {
    margin-left: 0%;
    overflow: hidden;
}

footer ul {
    text-align: center;
    list-style: none;
    padding-bottom: 10px;
    width: 80%;
    margin-left: 14.33%;
}

footer li {
    display: inline-block;
    background-color: #111;
    color: #fff;
    margin: 20px 15px 20px 15px;
    text-align: left;
    line-height: 150%;
    font-size: 90%;
    width: 20%;
    line-height: 190%;
    font-weight: 300;
    vertical-align:top;
}

footer img {
    margin-top: 50px;
}

footer p {
    font-family: "Comfortaa-SemiBold"; 
    font-size: 80%;
    color: #fff;
    text-align: center;
    padding-bottom: 10px;
}

.copyright  {
    background-color: #111;
    color:  #fff;
    text-align:  center;
    font-size:  0.7em;
}

/* ------------------------------------ */
/* SPACER                               */
/* ------------------------------------ */
.spacer {
    margin-top: 100px;
}

/* ----------------------------------- */
/* ONLY DISPLAY ON MOBILE PHONE        */
/* ----------------------------------- */

@media screen and (min-width:480px) {
    .display-only-480 {
        display: none;
}
}

/* ----------------------------------- */
/* FOR MEDIA SCREEN LESS THAN 1030     */
/* ----------------------------------- */

@media only screen and (max-width: 1030px) and (min-width: 480px) {
  
header  {
    background-attachment:  scroll;
    width:  100%;
}
header img  {
    max-width:  100%;
}
    
.hero-text-box  {
    width:  100%;
}
    
.hero-text-box h1  {
    font-size:  3rem;
    margin-bottom:  0.6em;
}
.hero-text-box h2  {
    font-size:  1.2rem;
    word-spacing:  0.1em;
    margin-top:  -1em;
}
  
.all-categories,    
.all-categories-bottom {
    text-align: center;
    margin: 0 auto;
    margin-left: 1%;
}      
    
.categories-index img  {
    width: 40%;
    height: auto;
    margin-top: 10px;
}
    
.rhs-column {
        text-align: center;
        margin: 0 auto;
}
    
.rhs-column a {
        padding: 2em;
}    
    
footer li .break-rel br {
        display: none;
}  
    
footer ul {
    text-align: center;
    list-style: none;
    padding-bottom: 0px;
    width: 80%;
    margin-left: 10%;
}
    
footer li {
    background-color: #111;
    color: #fff;
    text-align: center;
    font-size: 1.1em;
    width: 120%;
    margin-left: -10%;
}
}
