@charset "UTF-8";

/*
Theme Name: odt2025
Version: 1.1
*/

:root {
    /*Colors*/
    --color-primary: #0A0203;
    --color-secondary: #F47630;
    --color-tertiary: #d3d1d2;
    --color-black-light: #0A0203;
    --color-black: #0A0203;
    --color-gray: #999999;
    --color-gray-light: #dcddde;
    --color-white: #ffffff;

    /*Fonts*/
    --font-family-primary: "lato", sans-serif;
    --font-family-secondary: "cinzel", sans-serif;


    /*Font Sizes*/
    --font-size-xs: 0.75rem;
    --font-size-sm: 0.875rem;
    --font-size-rg: 1rem;
    --font-size-rg-md: 1.125rem;
    --font-size-md: 1.25rem;
    --font-size-mdlg: 1.5rem;
    --font-size-lg: 2rem;
    --font-size-lgxl: 3rem;
    --font-size-xl: 4rem;

    /*Font Weights*/
    --font-weight-reg: 400;
    --font-weight-med: 500;
    --font-weight-semi-bold: 600;
    --font-weight-bold: 700;
}


/***************
General
***************/

html,
body {
    height: 100%;
}

html {
    background-color: var(--color-white);
    scroll-padding-top: 100px;
}

body {
    font-family: var(--font-family-primary);
    font-weight: var(--font-weight-med);
    color: var(--color-primary);
    background-color: var(--color-white);
}

#content {
	/* padding-bottom: 5rem; */
	position: relative;
	min-height: 1100px;
}

body.home #content {
	padding-bottom: 0;
}

h1 {
	font-family: var(--font-family-tertiary);
	font-weight: var(--font-weight-reg);
	color: var(--color-white);
}

h2,h3 {
	font-family: var(--font-family-secondary);
	letter-spacing: 0.2rem;
	text-transform: uppercase;
}

.page-sections article {
	padding: 4rem 1rem;
	border-bottom: 1px solid var(--color-gray-light);
}


/***************
Navigation
***************/

header.primary-nav .navbar-dark {
	background: linear-gradient(to bottom, rgba(10,2,3,0.5),rgba(10,2,3,0));
	padding: 1rem 0;
}

header.primary-nav .navbar-dark.active {
	background-color: rgba(10,2,3,0.9);
}

.primary-nav .navbar-collapse {
	padding: 1rem;
}

div#primary-nav.show {
	background-color: rgba(0,0,0,0.9);
}

div#primary-nav ul.dropdown-menu.show {
	background-color: rgba(10,2,3,0.9);
	border: none;
	border-radius: 0;
}

.dropdown-item {
	text-shadow: none;
}

.dropdown-item.active, .dropdown-item:active {
	background-color: var(--color-gray-light);
	color: var(--color-black);
}

.navbar-dark .navbar-toggler {
    border: none;
}

a.navbar-brand img,
a.footer-brand img {
	width: 200px;
}

@media (min-width: 992px) {
	a.navbar-brand img,
	a.footer-brand img {
		width: 200px;
	}
}

ul.nav li {
	padding: 0 0.5rem;
	font-family: var(--font-family-secondary);
	font-weight: var(--font-weight-med);
	text-shadow: 0px 0px 10px var(--color-black);
	/* border-left: 1px solid var(--color-primary); */
}

ul.nav li:first-of-type,
ul.nav li:last-of-type {
	border-left: none;
}

ul.nav li.nav-btn a {
    border: none;
    border-radius: 0;
    color: var(--color-black);
    background-color: var(--color-primary);
    text-transform: uppercase;
    padding: 0.5rem 1.5rem !important;
    text-align: center;
}

ul.nav li.nav-btn a:hover,
ul.nav li.nav-btn a:active,
ul.nav li.nav-btn a:focus {
    color: var(--color-black);
    background-color: var(--color-white);
}

ul.nav li a {
	font-family: var(--font-family-secondary);
	font-weight: 500;
	color: var(--color-white);
	font-size: var(--font-size-xs);
	text-transform: uppercase;
	letter-spacing: 0.15rem;
}

ul.nav li a:active,
ul.nav li a:focus,
ul.nav li a:hover {
	color: var(--color-secondary);
}

@media (max-width: 1100px) {
	ul.nav li {
		padding: 0;
		border-left: none;
	}
}


/***************
Links
***************/
a {
    color: var(--color-secondary);
    font-weight: var(--font-weight-med);
    text-decoration: none;
    transition: all .2s ease-in-out;
}

a:hover,
a:active,
a:focus {
    color: var(--color-gray);
}

/***************
Buttons
***************/
button,
.btn.btn-outline,
.btn.btn-primary,
button.btn.btn-link {
    transition: all .2s ease-in-out;
    text-decoration: none;
}

.btn.btn-primary {
    border: none;
    border-radius: 0;
    color: var(--color-white);
    background-color: var(--color-secondary);
    text-transform: uppercase;
    padding: 0.5rem 1.5rem;
}

.btn.btn-primary:hover,
.btn.btn-primary:active,
.btn.btn-primary:focus {
    background-color: var(--color-black);
    color: var(--color-white);
}

button.btn.btn-link:hover,
button.btn.btn-link:active,
button.btn.btn-link:focus {
    color: var(--color-gray);
}

.btn.btn-outline {
	font-family: var(--font-family-secondary);
	letter-spacing: 0.2rem;
    text-transform: uppercase;
    font-size: 0.8rem;
    border: 1px solid var(--color-primary);
    border-radius: 0;
    color: var(--color-primary);
    background-color: transparent;
    padding: 0.6rem 1.66rem;
	text-shadow: 0px 0px 10px var(--color-black);
}

.btn.btn-outline:hover,
.btn.btn-outline:active,
.btn.btn-outline:focus {
    background-color: var(--color-primary);
    color: var(--color-white);
	text-shadow: none;
}


input.wpcf7-submit.btn.btn-primary {
	width: 100%;
}

.wpcf7-form-control {
	border-radius: 0;
}

.mc4wp-error {
	color: red;
}

/***************
Homepage
***************/

/* billboard */
#billboard {
	position: relative;
	background: var(--color-black);
	background-size: cover;
	color: var(--color-white);
	text-shadow: 0px 0px 10px var(--color-black);
}

#billboard .billboard-content {
	display: none;
	z-index: 2;
	position: absolute;
	left: 4rem;
	right: 4rem;
	bottom: 4rem;
}

.billboard-content h1 {
	text-transform: none;
	margin-bottom: 0;
}

.billboard-content-mobile h1 small,
.billboard-content h1 small {
	font-size: var(--font-size-sm);
	text-transform: uppercase;
	letter-spacing: 0.2rem;
}

.billboard-content-mobile {
	display: block;
	background: var(--color-black);
	padding: 2rem;
}

.billboard-content-mobile .btn.btn-outline,
.billboard-content .btn.btn-outline {
	font-family: var(--font-family-secondary);
	letter-spacing: 0.2rem;
    text-transform: uppercase;
    font-size: 0.8rem;
    border: 1px solid var(--color-white);
    border-radius: 0;
    color: var(--color-white);
    background-color: transparent;
    padding: 0.6rem 1.66rem;
}

.billboard-content-mobile .btn.btn-outline:hover,
.billboard-content-mobile .btn.btn-outline:active,
.billboard-content-mobile .btn.btn-outline:focus,
.billboard-content .btn.btn-outline:hover,
.billboard-content .btn.btn-outline:active,
.billboard-content .btn.btn-outline:focus {
    background-color: var(--color-secondary);
    color: var(--color-white);
	text-shadow: none;
}

@media (min-width: 1200px) {
	#billboard .billboard-content {
		display: block;
	}
	.billboard-content-mobile {
		display: none;
	}	
}

.text-right {
	text-align: right;
}


/* services carousel */

#services-carousel div.item {
	display: inline-block;
	position: relative;
	padding: .5rem;
}

#services-carousel div.item .service-card {
	padding: 1rem;
	/* border: 1px solid var(--color-gray-light); */
	min-height: 540px;
	box-shadow: 0px 0px 10px rgba(10,2,3,0.15);
	cursor: pointer;
}

#services-carousel div.item .service-card:active,
#services-carousel div.item .service-card:focus,
#services-carousel div.item .service-card:hover {
	box-shadow: 0px 0px 10px rgba(10,2,3,0.25);
}

#services-carousel div.item .service-card h4,
#services-carousel div.item .service-card img,
#services-carousel div.item .service-card p {
	display: block;
}

#services-carousel div.item .service-card img {
	padding: 0 0 1rem 0;
}

/* reviews */

.owl-stage-outer {
    z-index: 100;
}

.owl-carousel .owl-controls {
    margin-top: 0;
    text-align: center;
    position: absolute;
    left: 0;
    top: 0;
}

.owl-carousel .owl-nav {
    position: absolute;
    width: 100%;
    top: 40%;
    left: 0;
    font-size: 30px;
    color: #fff;
    /* text-shadow: 0px 0px 10px #000; */
    z-index: 101;
}


@media (min-width: 768px) {
    .owl-carousel .owl-nav {
        top: 45%;
    }
}

.owl-prev:hover,
.owl-next:hover {
    color: #000;
    background-color: rgba(255,255,255,0.8);
    /* text-shadow: 0px 0px 10px #fff; */
}

.owl-prev,
.owl-next {
    border-radius: 30px;
    background-color: rgba(255,255,255,0.4);
}

.owl-prev {
    float: left;
    margin-left: 30px;
    padding: 0px 15px 0 13px;
}

.owl-next {
    float: right;
    margin-right: 30px;
    padding: 0px 13px 0 15px;
}

#reviews {
	background-color: var(--color-gray-light);
    padding: 3rem 0 2rem 0;
}

#reviews-carousel button.owl-dot span {
	background-color: transparent;
	border: 1px solid var(--color-primary);
	border-radius: 0;
}

#reviews-carousel .owl-dots .owl-dot .active {
	background-color: var(--color-primary);
	border: 1px solid var(--color-primary);
}

#reviews-carousel .owl-dots .owl-dot span:active,
#reviews-carousel .owl-dots .owl-dot span:focus,
#reviews-carousel .owl-dots .owl-dot span:hover {
	background-color: var(--color-primary);
	border: 1px solid var(--color-primary);
}


/***************
Interior Pages
***************/

.interior-header {
	position: relative;
	background: var(--color-black) url('/wp-content/themes/odt2025/assets/images/interior_header_1.jpg') no-repeat center center;
	background-size: cover;
	padding: 12rem 0 0 0;
	margin-bottom: 3rem;
	min-height: 800px;
}

.interior-header .page-title {
	position: absolute;
	top: auto;
	bottom: 2rem;
	left: auto;
	right: auto;
}

.interior-header h1.entry-title {
	margin-top: 2rem;
	font-size: var(--font-size-lgxl);
	/* margin-bottom: -0.8rem; */
	text-shadow: 0px 0px 10px var(--color-black);	
}

@media (max-width: 1199.98px) {
	.interior-header {
		min-height: 600px;
	}
}

@media (max-width: 343.98px) {
	.interior-header {
		min-height: 400px;
	}
}

/* project gallery */

.project-breadcrumb {
	font-size: var(--font-size-sm);
	text-transform: uppercase;
	letter-spacing: 0.2rem;
}

.gallery-row {
	background-color: var(--color-black);
	padding: 0;
}

.gallery-row a.photo{
	padding: 0;
}

.gallery-thumbnail {
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    min-height: 200px;
}

@media (min-width: 768px) {
    .gallery-thumbnail {
        min-height: 200px;
    }
}

@media (min-width: 1200px) {
    .gallery-thumbnail {
        min-height: 300px;
    }
}

@media (min-width: 1400px) {
    .gallery-thumbnail {
        min-height: 360px;
    }
}

.hide {
    display: none !important;
}


/***************
Footer
***************/

footer {
	background-color: var(--color-white);
	padding: 3rem 0 6rem 0;
	color: var(--color-black);
}

footer .newsletter-row {
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--color-black);
	margin-bottom: 2rem;
	font-size: var(--font-size-sm);
}

footer .rule-left {
	border-left: none;
	padding-left: 1rem;
}

footer .contact-hours {
	font-size: var(--font-size-sm);
	margin-bottom: 1rem;
}

footer .copyright {
	font-size: var(--font-size-sm);
	margin-bottom: 1rem;
}

footer a.navbar-brand img {
	margin-bottom: 1rem;
}

footer .footer-menu  {
	text-align: left;
}

footer .footer-menu ul#menu-footer-menu {
	list-style: none;
	font-family: var(--font-family-secondary);
	font-weight: 500;
	color: var(--color-black);
	font-size: var(--font-size-xs);
	text-transform: uppercase;
	letter-spacing: 0.15rem;
	padding-left: 0;
}

footer .footer-menu ul#menu-footer-menu li {
	display: block;
	text-align: left;
}

footer .footer-menu ul#menu-footer-menu li a {
	color: var(--color-primary);
}

footer .footer-menu ul#menu-footer-menu li a:active,
footer .footer-menu ul#menu-footer-menu li a:focus,
footer .footer-menu ul#menu-footer-menu li a:hover {
	color: var(--color-black);
}

footer ul.social-media {
	text-align: left;
	list-style: none;
	padding-left: 0;
}

footer ul.social-media li {
	display: inline-block;
	padding: 0 0.25rem;
	font-size: var(--font-size-mdlg);
}

footer ul.social-media li:first-of-type {
	padding: 0 0.25rem 0 0;
}

footer ul.social-media li:last-of-type {
	padding: 0 0 0 0.25rem;
}

footer p.accreditations {
	font-size: var(--font-size-xs);
	text-align: left;
	margin-top: 1rem;
	line-height: 1.1;
}

@media (min-width: 992px) {
	footer .rule-left {
		border-left: 1px solid var(--color-black);
		padding-left: 2rem;
	}

	footer .copyright {
		text-align: left;
	}

	footer ul.social-media {
		text-align: right;
	}

	footer .footer-menu  {
		text-align: right;
	}

	footer .footer-menu ul#menu-footer-menu li {
		display: inline-block;
		text-align: right;
		margin-left: 1rem;
	}

	footer p.accreditations {
		text-align: right;
	}
}


/***************
Carousels
***************/
/*Make carousel items same height*/
.owl-stage {
    display: flex;
}

.owl-item {
    display: flex;
    flex: 1 0 auto;
    /* padding: 0 1rem; */
}

.item {
    display: flex;
    flex-grow: 1;
    height: 100%;
}
/*End Make carousel items same height*/

#reviews-carousel .item {
	display: block;
	text-align: left;
}

#reviews-carousel .item em {
	color: var(--color-primary);
}

/*Carousel Nav*/
.owl-theme .owl-nav [class*=owl-] {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    margin: auto;
}

.owl-theme .owl-nav [class*=owl-]:hover {
    background-color: transparent;
}

.owl-theme .owl-nav [class*=owl-]:hover img {
    filter: brightness(0) invert(1);
}

.interior-content .owl-theme .owl-nav [class*=owl-]:hover img {
    filter: brightness(50%) invert(0);
}

.owl-nav {
    margin-top: 0;
}

.owl-nav button.owl-prev i,
.owl-nav button.owl-next i {
	background-color: var(--color-primary) !important;
	/* border-radius: 0; */
	padding: .3rem .5rem;
}

.owl-nav button.owl-prev {
    left: -2.5rem;
}

.owl-nav button.owl-next {
    right: -2.5rem;
}

/*Owl Dots*/
.owl-theme .owl-dots .owl-dot span {
    background: transparent;
    border: 1px solid var(--color-primary);
    /* border-radius: 0; */
}

.owl-theme .owl-dots .owl-dot.active span {
    background: var(--color-primary);
}

/* Reviews Owl Dots*/
#reviews .owl-theme .owl-dots .owl-dot span {
    background: transparent;
    border: 1px solid var(--color-primary);
    /* border-radius: 0; */
}

#reviews .owl-theme .owl-dots button.active span {
    background: var(--color-primary);
}

/***************
Blog
***************/

.blog-row {
	padding: 0;
	background: var(--color-black);
}

.blog-row div.blog-item {
	padding: 0 !important;
	position: relative;
}

.blog-row div.blog-item a div.blog-title {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 2;
	padding: 1rem;
	background: linear-gradient(to top, rgba(10,2,3,0.5),rgba(10,2,3,0));
	color: var(--color-white);
	text-transform: uppercase;
	font-size: var(--font-size-sm);
	letter-spacing: 0.2rem;
	text-align: center;
	text-shadow: 0px 0px 10px var(--color-black);
}

.blog-row div.blog-item a:active div.blog-title,
.blog-row div.blog-item a:focus div.blog-title,
.blog-row div.blog-item a:hover div.blog-title {
	background: rgba(10,2,3,0.5);
}

time.entry-date {
	text-transform: uppercase;
	letter-spacing: 0.2rem;
	font-size: var(--font-size-sm);
}

figure.post-thumbnail {
	margin-top: 1rem;
}

header.entry-header {
	margin-bottom: 1rem;
}

header.entry-header h1.entry-title {
	display: none;
}

.wp-caption-text {
	font-size: var(--font-size-sm);
}

footer.entry-footer {
	padding: 0 0 1.5rem 0;
}

.alignleft {
	display: inline;
	float: left;
	margin: 1rem 1rem 1rem 0;
}

.alignright {
	display: inline;
	float: right;
	margin: 1rem 0 1rem 1rem;
}

@media (max-width: 413.97px) {
	.alignleft {
		display: block;
		float: none;
		margin: 0.5rem 0;
	}
	
	.alignright {
		display: block;
		float: none;
		margin: 0.5rem 0;
	}
}

/*Post Navigation*/

.navigation.post-navigation {
	margin: 1rem 0 3rem;
}

.navigation.pagination {
	background-color: var(--color-white);
}

.navigation.pagination .nav-links,
.navigation.post-navigation .nav-links {
    padding: 1rem 0 1rem 1rem;
    width: 100%;
}

.navigation.pagination .nav-links .prev,
.navigation.post-navigation .nav-previous {
    float: left;
}

.navigation.pagination .nav-links .next,
.navigation.post-navigation .nav-next {
    float: right;
}

.navigation.pagination .page-numbers {
    display: none;
}

.navigation.pagination .prev.page-numbers,
.navigation.pagination .next.page-numbers {
    display: block;
}

#archives-dropdown-2 {
    display: block;
    width: 75%;
    height: calc(1.5em + .75rem + 2px);
    padding: .375rem .75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: #495057;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid #ced4da;
    border-radius: .25rem;
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}

/*Sidebar*/

.sidebars-row {
	margin: 2rem 0 3rem;
	border-top: 1px solid var(--color-gray-light);
	padding-top: 2rem;
}

.widget h2 {
	font-family: var(--font-family-tertiary);
	font-size: var(--font-size-md);
}

.widget ul {
  --icon-space: 1.3em;
  list-style: none;
  padding: 0 0 0 0.2em;
}

.widget ul li {
  padding-left: var(--icon-space);
}

.widget ul li:before {
  content: "\f0c8"; /* FontAwesome Unicode */
  color: var(--color-gray);
  font-size: var(--font-size-xs) !important;
  font-family: "Font Awesome 6 Pro" !important;
  display: inline-block;
  margin-left: calc( var(--icon-space) * -1.2 );
  width: var(--icon-space);
  -webkit-font-smoothing: antialiased;
  font: var(--fa-font-sharp-solid);
}

.widget_search {
    padding-bottom: 1rem;
}

.widget_search label span,
.widget_archive label {
    display: none;
}

.search .search-form {
    display: none;
}

form.search-form label {
    display: none;
}

.wp-block-search__input,
.search-field,
#archives-dropdown-2,
#archives-dropdown-3 {
    display: block;
    width: 100%;
    height: calc(1.5em + .75rem + 2px);
    padding: .375rem .75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: var(--color-primary);
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid var(--color-primary);
    border-radius: 0rem;
    transition: border-color .15s ease-in-out,box-shadow .15s ease-in-out;
}

.search-submit {
	font-family: var(--font-family-secondary);
	letter-spacing: 0.2rem;
    text-transform: uppercase;
    font-size: 0.8rem;
    border: 1px solid var(--color-primary);
    border-radius: 0;
    color: var(--color-primary);
    background-color: transparent;
    padding: 0.8rem 1.66rem 0.6rem;
    margin-top: 0.5rem;
}

.search-submit:hover,
.search-submit:active,
.search-submit:focus {
    background-color: var(--color-primary);
    color: var(--color-white);
	text-shadow: none;
}

@media (min-width: 768px) {
    .search .search-form {
        display: block;
    }
}

@media (min-width: 992px) {
    .widget_search .search-field,
    #archives-dropdown-2 {
        width: 15rem;
    }
}

/* Text meant only for screen readers. */
.screen-reader-text {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
    word-wrap: normal !important;
}