

/*buttons*/
.updated_button {
    background-color: #00508b;
    color: #f9f9f9 !important;
    border: none;
}

.updated_button:hover {
    background-color: #3a74a3 !important;
    color: #ffffff !important;
    box-shadow: 0px 5px 9px rgba(0, 80, 139, 0.8); /* Glow effect only at the bottom */
    --tw-shadow-color: rgba(0, 80, 139, 0.3);
}

.updated_button:active {
    background-color: #003b5c !important;
}

.updated_button:focus {
    background-color: #003b5c !important;
}




@media (prefers-reduced-motion: no-preference) {
    :root {
        scroll-behavior: smooth;
    }
}

body {
    font-family: "Inter", sans-serif;
}

#app_content {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    margin: 0;
}

.hero-section {
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 80%, #fff),
        repeating-linear-gradient(
            to right,
            rgba(0, 0, 0, 0.07),
            rgba(0, 0, 0, 0.07) 1px,
            transparent 1px,
            transparent 40px
        ),
        repeating-linear-gradient(
            to bottom,
            rgba(0, 0, 0, 0.07),
            rgba(0, 0, 0, 0.07) 1px,
            transparent 1px,
            transparent 40px
        );
    background-size: 40px 40px;
    background-color: #ffffff;

    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.hero-section::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(
        to bottom,
        rgba(255, 255, 255, 0) 20%,
        rgba(255, 255, 255, 1)
    );
    z-index: 1;
    pointer-events: none;
}

.app_hero {
    position: relative;
    z-index: 2;
}

/*trusted_by_clients*/
.trusted-carousel-wrapper {
    --item-width: 120px; /* Increased size to fit the wider carousel */
    --item-gap: 10px;
    --total-items: 10; /* Adjusted for seamless looping */
    --animation-offset: calc(
        (var(--item-width) + var(--item-gap)) * var(--total-items) * -1
    );
    --animation-speed: 13s; /* Adjusted for smooth motion */

    width: 100%;
    max-width: 600px; /* Increased width to 600px */

    overflow: hidden;
    position: relative;
}

.trusted-carousel-wrapper::before,
.trusted-carousel-wrapper::after {
    content: "";
    position: absolute;
    width: 20%;
    height: 100%;
    z-index: 1;
    top: 0;
}

.trusted-carousel-wrapper::before {
    left: 0;
    background-image: linear-gradient(
        to right,
        var(--bs-body-bg) 0%,
        transparent 50%
    );
}

.trusted-carousel-wrapper::after {
    right: 0;
    background-image: linear-gradient(
        to left,
        var(--bs-body-bg) 0%,
        transparent 50%
    );
}

.trusted-carousel {
    display: flex;
    gap: var(--item-gap);
    animation: trusted-slide var(--animation-speed) linear infinite;
}

.trusted-item {
    flex: 1 0 var(--item-width);
    text-align: center;
    padding: 0.5rem;
}

.trusted-item > img {
    width: 65%;
    height: auto;
    object-fit: contain;
}

.logo-name {
    font-size: 11px;
    font-weight: 700;
    color: var(--bs-secondary-color, #555); /* Bootstrap fallback color */
    margin-top: 0.5rem;
}

@keyframes trusted-slide {
    100% {
        transform: translateX(var(--animation-offset));
    }
}

/*about_us*/

@media (min-width: 700px) {
    .ab_txt {
        padding: 5vw !important;
    }
}

@media (min-width: 1023px) {
    .ab_txt {
        padding: 10vw !important;
    }
}

@media (max-width: 600px) {
    .about_image img {
        height: 400px !important;
    }
}

@media (min-width: 700px) {
    .about_image img {
        height: 380px !important;
    }
}

@media (min-width: 999px) {
    .about_image img {
        height: 530px !important;
    }
}

.about_statis h4,
p {
    font-size: 15px;
}

.about_statis h4 {
    color: #00508b;
}

.about_statis {
    background-color: #ffffff;
    box-shadow: rgba(0, 80, 139, 0.2) 0px 2px 8px 0px;
}

/*services cards*/
.product-card {
    background-color: #f9f9f9;
    padding: 20px;
    text-align: center;
}

.product-card img {
    max-width: 400px;
}

.services_color h2 {
    color: #00508b;
}

.cc_camera_bg {
    background: conic-gradient(from 0deg, #eef8ff, #dceeff, #c0e0ff, #eef8ff);
}

.biometric_bg {
    background: linear-gradient(to bottom, #e8f4fd 25%, #d8d5ff);
}

.networking_bg {
    background: conic-gradient(from 0deg, #eef8ff, #dceeff, #c0e0ff, #eef8ff);
}
.custom_cctv_bg {
    background: conic-gradient(from 0deg, #eef8ff, #dceeff, #c0e0ff, #eef8ff);
}

.access_controls_bg {
    background: linear-gradient(to bottom, #d8ecfb, #3e5870),
        linear-gradient(to top, #acd1f7, #d9effe);
    background-blend-mode: overlay;
}

.product-card h2 {
    font-weight: 600;
    color: #00508b;
}

.product-title {
    font-size: 1.5rem;
}
.product-subtitle {
    font-size: 1rem;
}
.product-image {
    max-width: 80%;
    height: auto;
    margin: 15px 0;
}

/*installation Process*/

.ins_prcs h3 {
    font-size: 18px;
    font-weight: 600;
}

/*client reviews*/
.swiper-slide {
    min-width: 350px;
}

/* only on sm to large devices */
@media (min-width: 768px) {
    .swiper-slide {
        min-width: 350px;
    }
}

/*query image*/
@media (max-width: 575.98px) {
    .query_img img {
        margin-bottom: 1.4rem;
    }
}

@media (max-width: 768.98px) {
    .query_img img {
        max-height: 400px;
    }
}

/*modal*/
.modal-content {
    border-radius: 8px;
    box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.1);
}

.list-group-item a {
    color: #00508b;
    font-weight: 500;
}

.item_hover a:hover {
    text-decoration: underline !important;
    color: #003b5c;
}

.unstyled-button {
    background: none;
    border: none;
    padding: 0;
    margin: 0;
    font: inherit;
    color: inherit;

    cursor: pointer;
}

.unstyled-button:focus {
    outline: none;
}

.unstyled-button:hover {
    text-decoration: underline; /* Adds underline on hover */
}

/*contact us*/
.contact-link {
    text-decoration: none;
    color: #000; /* Default color */
    transition: color 0.3s ease;
}

.contact-link:hover {
    color: #00508b; /* Hover color */
}

.contact-link:active {
    color: #3a74a3; /* Active color */
}

/* Toast Styling */
.toast {
    display: none; /* Initially hidden */
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    background-color: #3a74a3;
    color: #fff;
    padding: 10px 20px;
    border-radius: 5px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.2);
    font-size: 0.875rem;
    z-index: 1000;
    text-align: center;
}

.toast.show {
    display: block;
    opacity: 1;
    animation: fadeOut 3s forwards;
}

@keyframes fadeOut {
    0%,
    90% {
        opacity: 1;
    }
    100% {
        opacity: 0;
        display: none;
    }
}

.loc_lks button {
    font-size: 15px !important;
}

.mod-hf h5 {
    font-size: medium;
}

/*brand tags products page*/
.brand_tags span {
    padding: 6px;
    border-radius: 8px;

    box-shadow: rgba(50, 50, 105, 0.15) 0px 2px 5px 0px,
        rgba(0, 0, 0, 0.05) 0px 1px 1px 0px;
}

.pr_ft th {
    font-weight: 400 !important;
    color: #646464;
}

.pr_ft {
    margin-top: 1rem;
}

.pr_ft td {
    font-weight: 400 !important;
    color: #646464;
}

.pr-h3 {
    font-size: 1.3rem;
}

.pr-bg {
    background: #fefefe;
}

/* About_us Page*/

.mission-section {
    background: url("/images/11.webp") no-repeat center center;
    background-size: cover;
    height: 45vh;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 20px;
}

.mission-statement {
    padding: 60px 60px;
}

.mission-statement h1 {
    font-size: 2.5rem;
}

@media (max-width: 768.76px) {
    .mission-statement h1 {
        font-size: 1.8rem;
    }

    .mission-statement {
        padding: 30px 30px;
    }

    .mission-section {
        padding: 5px;
    }
}

@media (max-width: 430.67px) {
    .mission-statement h1 {
        font-size: 1rem;
    }

    .mission-statement {
        padding: 20px 20px;
    }

    .mission-section {
        height: 39vh;
    }
}

.accordion-button:not(.collapsed) {
    font-weight: 500;
    
    border-bottom: 1.2px solid #d0d0d0;
    border-radius: 0 !important;
    box-shadow: none;
}

.accordion-body{
    font-weight: 500;
    background: #f5fbff;
}

/*floating*/
.btn-floating:hover img {
    margin-bottom: 0px;
}

.btn-floating {
    position: fixed;
    right: 25px;
    overflow: hidden;
    width: 45px;
    height: 45px;
    border-radius: 100px !important;
    border: 0;
    z-index: 9999;
    color: white;
    transition: 0.2s;
    display: flex;
    justify-content: center;
    align-items: center;
}

.btn-floating:hover {
    width: auto;
    padding: 0 20px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: 0.2s ease-in-out;
}

.btn-floating span {
    font-size: 16px;
    font-weight: 500;
    margin-left: 5px;
    transition: 0.2s;
    line-height: 0px;
    display: none;
}

.btn-floating:hover span {
    display: inline-block;
}

/* Phone */
.btn-floating.phone {
    bottom: 81px;
    background-color: #004176;
}

.btn-floating.phone:hover {
    background-color: #00508b;
}

/* WhatsApp */
.btn-floating.whatsapp {
    background-color: #34af23;
    bottom: 144px;
}

.btn-floating.whatsapp:hover {
    background-color: #1f7a12;
}


.white-button {
    background-color: #fff !important;
    color: #00508b !important;
    border: none;
}

.white-button:hover {
    background-color: #fafafa !important;
    color: #00508b !important;
    border: none;
}


.area-links-container {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 24px;
    justify-content: center;
    align-items: center;
    font-size: 12px;
}
.area-link-btn {
    padding: 10px 18px;
    border: 1px solid #e5e5e5;
    border-radius: 999px;
    background: #fff;
    color: #333;
    text-decoration: none;
    font-weight: 400;
    transition: all 0.25s ease;
}
.area-link-btn:hover {
    color: #00508b;
    border-color: #ccc;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
}

.area-link-btn.active {
    background-color: #00508b;
    color: #fff;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    pointer-events: none;
}

