/*#nav-modal, #nav-modal .modal-content {background-color:#000000 !important}
.modal-dialog-slideout {background-color:#000000 !important}
#nav-modal .close{color:#ffffff !important; opacity:1 !important;}*/

body {
text-transform: uppercase;
}

a, button, .btn {
text-transform: uppercase !important;
}


#nav-modal, #nav-modal .modal-content {background-color:#ffffff !important}
.modal-dialog-slideout {background-color:#ffffff !important}
#nav-modal .close{color:#000000 !important; opacity:1 !important;}

.megamenu-link-padding {
padding-bottom: 2rem;
}

.dropdown-toggle > a{
display: flex;
align-items: center;
flex-direction: row-reverse;
gap: 0.5em;
}

.megamenu-items > a,
.megamenu-items .dropdown-toggle {
display: inline-flex;
margin: 0;
align-items: center;
height: 100%;
font-weight: 700;
}

.megamenu-items:has(a[href="/capabilities"]) .dropdown-menu {
margin-top: 0.5rem !important;
}

.megamenu-items:has(a[href="/capabilities"]) .dropdown-menu::before {
content: "";
display: block;
position: absolute;
top: -10px;
left: 0;
width: 100%;
height: 10px;
background-color: transparent;
}

.fa-angle-down:before {
display: none !important;
}

.megamenu-items > a::after,
.megamenu-items > .dropdown > .dropdown-toggle > a::after {
text-decoration: underline !important;
}

button.dropdown-toggle{
text-decoration: none !important;
}

a.capabilities-dropdown {
display: revert;
align-items: center;
gap: 0.5rem;
}

a.capabilities-dropdown::after {
content: "\f078";
font-family: 'Font Awesome 5 Pro';
font-weight: 400;
display: inline-block;
}

.capabilities-dropdown ul>a:hover {
background-color: transparent !important;
text-decoration: underline !important;
}

.hover-effect:hover {
/*background-color: #e9ecef;*/
text-decoration: underline !important;
}

.hover-underline-animation {
display: inline-block;
position: relative;
}

.hover-underline-animation::after {
content: '';
position: absolute;
width: 100%;
transform: scaleX(0);
height: 2px;
/*padding-top: 2px;*/
bottom: 0;
left: 0;
background-color: white;
transform-origin: bottom right;
transition: transform 0.25s ease-out;
}

.hover-underline-animation:hover::after {
transform: scaleX(1);
transform-origin: bottom left;
}

.hover-underline-animation-black {
display: inline-block;
position: relative;
}

.hover-underline-animation-black::after {
content: '';
position: absolute;
width: 100%;
transform: scaleX(0);
height: 2px;
bottom: 0;
left: 0;
background-color: black;
transform-origin: bottom right;
transition: transform 0.25s ease-out;
}

.hover-underline-animation-black:hover::after {
transform: scaleX(1);
transform-origin: bottom left;
}

div[id="nav-modal___BV_modal_body_"] li.nav-item > a.nav-link{
color: #000000;
}


li.nav-item.collapsed > a.nav-link,
li.nav-item.not-collapsed > a.nav-link {
display: flex;
justify-content: space-between;
align-items: center;
}

li.nav-item.collapsed > a.nav-link::after,
li.nav-item.not-collapsed > a.nav-link::after {
content: "\f078";
font-family: 'Font Awesome 5 Pro';
font-weight: 400;
display: inline-block;
gap: 0.5rem;
transition: transform 0.35s ease;
}

li.nav-item.not-collapsed > a.nav-link::after {
transform: rotate(180deg);
}

li.nav-item.collapsed > a.nav-link::after {
transform: rotate(0deg);
}

li.nav-item.d-block.pl-3 > a.nav-link:active,
li.nav-item.nav-item > a.nav-link.text-white:active {
background-color: #ffffff0f;
}

a.nav-link[aria-current="page"] {
background-color: #ffffff0f;
/*color: #ffdb4d !important;*/
text-decoration: underline !important;
text-decoration-thickness: 1px;
text-underline-offset: 6px;
}

div:has(a.nav-link[aria-current="page"]) {

& > div.collapse {
display: block !important;
}

& > li.nav-item > a.nav-link::after {
transform: rotate(180deg);
}
}

a.nav-link[aria-current="page"]::after {
transform: scaleX(1);
}

header[id="nav-modal___BV_modal_header_"] > h5::after {
content: "";
display: inline-block;
width: 120px; /* adjust */
height: 40px; /* adjust */
background: url("https://store-media.mpowerpromo.com/667f0a2d1d97a770f11a9c31/assets/Physx-Logo-Horizontal-New-1758842723876.png") no-repeat center;
background-size: contain;
margin-left: 8px;
}

.header-icons-hover-effect i{
color: white;
}

.header-icons-hover-effect-black i{
color: black;
}

.header-icons-hover-effect i:hover {
opacity: 75%;
}

.btn-started {
color: black;
background-color: transparent;
border: 2px solid black;
font-weight: 700;
}

.btn-started:hover {
color: white;
background-color: black;
}

.btn-started-mobile {
background-color: transparent;
margin-top: 1rem;
margin-bottom: 1rem;
border: 2px solid black;
}

.btn-started-mobile a{
color: white;
font-weight: 700;
padding: 0px !important;
}

.btn-started-mobile:active {
background-color: white;

}

.btn-started-mobile a:active{
color: black !important;
}

.desktop-header {
display: none !important;
}

.mobile-header {
display: block !important;
}

@media (min-width: 768px) {
.desktop-header {
display: block !important;
}

.mobile-header {
display: none !important;
}
}

.logo:hover {
opacity: 90%;
}

.image-container {
position: relative;
display: inline-block;
}

.zoom-frame {
position: relative;
width: 100%;
height: auto;
overflow: hidden;
display: block;
}

.overlay-image {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
width: 60%;
height: auto;
pointer-events: none;
}

.image-zoom-hover {
display: block;
transition: transform 0.3s ease;
}

.zoom-frame .image-zoom-hover {
margin-bottom: -1px;
}

.image-container:hover .image-zoom-hover{
transform: scale(1.1);
}

.black-white .wrapper{
pointer-events: all !important;
}

.black-white img{
filter: grayscale(100%);
}

.black-white img:hover {
filter: grayscale(0%);
}

footer a:hover {
/*opacity: 75%;*/
/*text-decoration: underline !important;*/
font-weight: 700
}

.navbar-class{
padding-bottom: 0px !important;
}

.color-gray{
color: gray;
}

.small-link{
font-size: 0.8rem;
font-weight: 700;
margin-bottom: 0;
}

@media (min-width: 768px) {

.bottom-footer a:not(:last-child)::after {
content: "|";
margin-left: 0.75rem;
margin-right: 0.75rem;
color: #000 !important;
}

.bottom-footer a:not(:last-child)::after:hover {
opacity: 100% !important;
color: #000 !important;
}

}

.faq-question span {
font-weight: 700;
}

.btn-dark:hover {
opacity: 85%;
}

.color-new-gray, .fa-shopping-cart:before {
color: #9b9ea1 !important;
}

.header-icons-hover-effect-new i:hover, .fa-shopping-cart:hover:before {
color: #000 !important;
}

.border-bottom {
style="border-bottom:1px solid #000"
}

.border-top {
style="border-top:1px solid #000"
}

div[id="listed"] {
background-color: black !important;
}

footer .nav-link {
text-transform: uppercase;
/*color: #9b9ea1*/
}

html {scroll-behavior: smooth;}
.back-to-top {
position: fixed;
bottom: 75px;
right: 5px;
z-index: 9999999;
background-color: #000;
color: #fff;
width: 50px;
height: 50px;
text-align: center;
line-height: 50px;
font-size: 20px;
border-radius: 50%;
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.2);
display: none; /* Initially hidden */
transition: opacity 0.3s;
}

.back-to-top:hover {
opacity: 0.8;
color: #fafafa;
}

.container--tiny {
max-width: 740px;
}

.container--small {
max-width: 940px;
}

.megamenu-block {
max-height: 40px;
}

.nav-item-wrapper {
position: relative;
}

.nav-item-wrapper::after {
content: '';
position: absolute;
top: 100%;
left: 0;
right: 0;
height: 15px;
background-color: transparent;
}

/*div.megamenu-class div.megamenu-item::after {
content: '';
position: absolute;
top: 100%;
left: 0;
right: 0;
height: 15px;
background-color: transparent;
}*/

.nav-item-wrapper:hover .dropdown-menu {
display: block !important;
opacity: 1 !important;
visibility: visible !important;
}

.megamenu-content{
margin-top: 1rem;
overflow: visible !important;
}

.megamenu-content::before{
content: "";
display: block;
position: absolute;


top: -1rem;

left: 0;
width: 100%;

height: 1rem;

background-color: transparent;

z-index: 100;
}

.gold-hover:hover {
color: #B9985C !important;
}

div.megamenu-class div.megamenu-item > a{
font-weight: 700;
}

.modal-trigger {
cursor: pointer;
transition: 0.3s;
}

.mp-custom-modal {
display: flex;
justify-content: center;
align-items: center;
position: fixed;
z-index: 99999;
left: 0;
top: 0;
right: 0;
bottom: 0;
overflow: auto;
background-color: rgba(0, 0, 0, 0.9);
padding: 20px;
box-sizing: border-box;
}

.mp-custom-content-wrapper {
width: 100%;
max-width: 700px;
margin: 0;
animation-name: mp-zoom;
animation-duration: 0.6s;
}

.mp-custom-content {
display: block;
width: 100%;
height: auto;
max-width: 100%;
margin: 0;
}

.mp-custom-caption {
display: block;
width: 100%;
max-width: 100%;
margin: 0;
text-align: center;
color: #ccc;
padding: 10px 0;
height: 150px;
}

@keyframes mp-zoom {
from {
transform: scale(0)
}

to {
transform: scale(1)
}
}

.mp-custom-close {
position: absolute;
top: 15px;
right: 35px;
color: #f1f1f1;
font-size: 40px;
font-weight: bold;
transition: 0.3s;
}

.mp-custom-close:hover,
.mp-custom-close:focus {
color: #bbb;
text-decoration: none;
cursor: pointer;
}

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

.mp-custom-modal {
position: fixed;
z-index: 10000;
left: 0;
top: 0;
width: 100%;
height: 100%;
overflow: auto;
background-color: rgba(0, 0, 0, 0.9);
display: flex;
align-items: center;
justify-content: center;
padding: 20px;
box-sizing: border-box;
}

.mp-custom-close {
position: absolute;
top: 20px;
right: 35px;
color: #f1f1f1;
font-size: 50px;
font-weight: bold;
transition: 0.3s;
cursor: pointer;
background: none;
border: none;
line-height: 1;
}

.mp-custom-close:hover,
.mp-custom-close:focus {
color: #bbb;
text-decoration: none;
outline: 2px solid #fff;
}

.mp-custom-content-wrapper {
margin: auto;
display: block;
width: 80%;
max-width: 700px;
text-align: center;
animation: zoom 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.mp-custom-content {
width: 100%;
height: auto;
max-height: 80vh;
object-fit: contain;
}

.mp-custom-caption {
margin-top: 15px;
color: #ccc;
font-size: 1.1rem;
}

@keyframes zoom {
from {
transform: scale(0.5);
opacity: 0;
}
to {
transform: scale(1);
opacity: 1;
}
}



:root {
--hero-mobile-height: 400px;
--hero-desktop-height: 500px;
}

.mp-hero-optimized {
position: relative;
width: 100%;
display: flex;
align-items: center;
justify-content: center;
overflow: hidden;
background-color: var(--light, #f1f1f1);
min-height: var(--hero-mobile-height);
contain: layout paint;
}

@media (min-width: 768px) {
.mp-hero-optimized {
min-height: var(--hero-desktop-height);
}
}

.mp-bg-layer {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
z-index: 1;
pointer-events: none;
}

.mp-hero-bg-img {
width: 100%;
height: 100%;
object-fit: cover;
object-position: center;
will-change: transform;
}

.mp-hero-content {
position: relative;
z-index: 10;
width: 100%;
height: 100%;
text-align: center;
color: var(--white, #fff);
text-shadow: 0 1px 2px rgba(0,0,0,0.2);
}

@media (min-width: 768px) {
.mp-hero-content {
text-align: left;
padding-left: 15px;
}
}

.mp-title-img {
width: 100%;
height: auto;
max-width: 280px;
}

@media (min-width: 768px) {
.mp-title-img {
max-width: 500px;
}
}

.mp-hero-btn {
background-color: var(--primary, #008290);
border-color: var(--primary, #008290);
color: var(--white, #fff);
transition: transform 0.2s ease, background-color 0.2s ease;
}

.mp-hero-btn:hover {
background-color: #006873;
color: var(--white, #fff);
text-decoration: none;
transform: translateY(-2px);
}

.mp-fade-up {
opacity: 0;
transform: translateY(20px);
transition: opacity 0.8s ease-out, transform 0.8s ease-out;
will-change: opacity, transform;
}

.mp-fade-up.visible {
opacity: 1;
transform: translateY(0);
}

.mp-title-img {
height: auto;
width: 100%;
max-width: 300px;
}

@media (min-width: 768px) {
.mp-title-img {
max-width: 400px;
}
}

.mp-hero-content a,
.mp-hero-content button {
pointer-events: auto;
position: relative;
z-index: 11;
}

.mp-hero-btn {
background-color: #ffffff !important;
color: #000000 !important;
border: 2px solid #ffffff !important;
min-width: 200px;
transition: all 0.3s ease;
}

.mp-hero-btn:hover {
background-color: #000000 !important;
color: #ffffff !important;
border-color: #ffffff !important;
text-decoration: none;
}




/* GLOBAL UTILITIES (Reusable across site) */

/* 1. Animation State */
.mp-fade-up {
opacity: 0;
transform: translateY(20px);
transition: opacity 0.6s ease-out, transform 0.6s ease-out;
will-change: opacity, transform;
}

.mp-fade-up.visible {
opacity: 1;
transform: translateY(0);
}

/* 2. CLS Prevention & Image Fill (Square 1:1) */
.ratio-1x1 {
aspect-ratio: 1/1;
width: 100%;
background-color: #f8f9fa;
display: block;
position: relative;
overflow: hidden;
}

/* Force background image to fill the square box */
.ratio-1x1 img.image-zoom-hover {
width: 100% !important;
height: 100% !important;
object-fit: cover !important;
position: absolute;
top: 0;
left: 0;
}

/* Center AND constrain the text overlay size */
.ratio-1x1 img.overlay-image {
width: 85% !important;
height: auto !important;
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
z-index: 2;
pointer-events: none;
}




.testimonial-section {
padding-top: 4rem;
padding-bottom: 4rem;
background-color: var(--white);
}

.section-title {
color: var(--primary);
letter-spacing: 1px;
}

.mp-fade-up {
opacity: 0;
transform: translateY(30px);
transition: opacity 0.8s ease-out, transform 0.8s ease-out;
will-change: opacity, transform;
}

.mp-fade-up.visible {
opacity: 1;
transform: translateY(0);
}

.testimonial-card {
background-color: var(--primary);
color: var(--white);
border-radius: 4px;
}

.testimonial-text {
font-size: 0.95rem;
line-height: 1.6;
margin: 0;
font-weight: 300;
color: var(--white);
}

.logo-container {
width: 80px;
height: 80px;
min-width: 80px;
overflow: hidden;
padding: 10px;
background-color: var(--white);
}

.company-name {
color: var(--white);
letter-spacing: 0.5px;
}

@media (max-width: 768px) {
.testimonial-card .card-body {
padding: 1.5rem;
}
.logo-container {
width: 60px;
height: 60px;
min-width: 60px;
}
}




.overlay-image {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
width: 40%;
height: auto;
z-index: 2;
pointer-events: none;
}


@media (max-width: 768px) {
.overlay-image {
width: 60%;
}
}

@media (min-width: 1200px) {
.megamenu_d-lg-inline-block {
display: inline-block !important;
}
}

/*For Blog Posts*/
div.blog-post-sidebar.col-md-3 {
padding-left: 0;
padding-right: 0;
}

.card-image{
object-fit: cover;
aspect-ratio: 1/1;
}

/*For Hero Banner*/
.text-outline {
color: #000 !important;
-webkit-text-stroke: 3px #fff;
paint-order: stroke fill;
}

.larger-h1 {
font-size: calc(1.975rem + 1.5vw);
}