body {
    font-family: Arial, sans-serif;
    display: flex;
    justify-content: center;
    align-items:center;
    margin: 0;
    background-color: #fafafa;
    font-size: 1em;
}



/* General container stacking structure */
.container {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    background-color: #f9f9f9; /* Light background for visibility */
    margin:0 20px;
}

.marquee-row {
    width: 100%; /* Full width */
    overflow: hidden; /* Hide overflow */
    background-color: #010101; /* Background color for visibility */
    color:gold;
    position: relative; /* Necessary for absolute positioning of content */
}

.marquee {
    display: inline-block; /* Make it inline-block for width calculations */
    white-space: nowrap; /* Prevent text from wrapping */
    font-size: 1em;
    animation: marquee 25s linear infinite; /* Animation settings */
}

.marquee .highlight{
    background-color: gold;
    font-weight:bold;
    color: #101010;
    padding:4px;
    border-radius: 6px;
}

@keyframes marquee {
    0% {
        transform: translateX(30%); /* Start from right */
    }
    100% {
        transform: translateX(-100%); /* Move to left completely off screen */
    }
}


.top-row {
    background-color: #f9f9f9;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px;
    /*background-color: #fff;*/
    /*border-bottom: 2px solid #ddd;*/
    margin-bottom: 20px;
    width: 100%;
    box-sizing: border-box;
}

.first-row {
    position: relative; /* Relative positioning for overlapping */
    height: 700px; /* Adjust as needed */
    /*background-color: lightgreen; /* Visible color for testing */
}

.first-row-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
}

/* Both main-row and photogrids are absolutely positioned to overlap */
.main-row {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1; /* Ensure it stacks above photogrids */
    display: flex;
    flex-direction: column;
    /*background-color: lightcoral; /* For visibility */
    align-items: flex-start;
    justify-content: flex-end;
    background-color: transparent;
}

.hero-row {
    /*height: 200px;
    /*background-color: lightyellow; /* Visible color for testing */
    margin-left: 20px;
    display: flex;
    flex-direction: column;
    text-align: left; /* Center text */
}

.services-row {
    max-width:60%;
    display: grid;
    grid-template-columns: repeat(5, 1fr); /* 5 columns */
    grid-template-rows: repeat(2, auto);   /* 2 rows */
    gap: 20px;  /* Adjust the gap between grid items */
    padding: 20px;
}

.photogrids {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0; /* Stacks behind the main-row */
    /*background-color: lightpink; /* Visible color for testing */
}

.services-row-small{
    display:none;
}

/* second-row stacking */
.second-row {
    display: flex;
    background-color: #000000; /* Visible color for testing */
}

.gReview-row, .contact-row {
    flex: 1;
    /*height: 200px;*/
    margin: 10px;
}

.gReview-row {
    background-color: #fcfcfc;
    border-radius: 30px;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 20px;
}

.contact-row {
    /*background-color: lightgoldenrodyellow;*/
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 20px; /* Optional: Space between each grid item */
    flex: 1; /* Ensures it shares space with gReview-row */
}

.footer-row {
    height:fit-content;
    background-color: darkslategray;
    margin-top: 20px;
}

/******************************************************************************************************/


/**********************TOP-ROW*****************************************/
/* Top Row Flex Layout */
/* Title Section: Logo and Name in a Flex Row */
.toprow-title {
    display: flex;
    align-items: center;
}

/* Logo Styling */
.toprow-logo img {
    width: 80px;
    height: auto;
    background-color: black; /* Black background for logo */
    padding: 10px;
    border-radius: 8px;
    margin-right: 20px;
}

/* Name Styling */
.toprow-name {
    font-size: 24px;
    font-weight: bold;
    color: #101010;
}

/* Open Status Section */
.toprow-openstatus {
    background-color: white;
    border-radius: 8px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    padding: 20px;
    margin-bottom: 20px;
    text-align: center;
    font-family: Arial, sans-serif;
}

/* Styling for the isOpen-row card */

/* Default styling for isOpen-Date */
.isOpen-Date {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 10px;
}

/* Styling for isOpen-Status when open or closed */
.isOpen-Status {
    font-size: 20px;
    font-weight: bold;
    color: white;
    padding: 10px;
    margin-bottom: 10px;
    border-radius: 4px;
}

/* Green background for open status */
.isOpen-Status.open {
    background-color: #28a745; /* Green for OPEN */
}

/* Grey background for closed status */
.isOpen-Status.closed {
    background-color: #6c757d; /* Grey for CLOSED */
}

/* Styling for open type (e.g., Walk-In, Appointment) */
.isOpen-Type div {
    display: inline-block;
    padding: 5px 10px;
    margin: 5px;
    border-radius: 4px;
    color: white;
    font-weight: bold;
}

/* Yellow background for walk-in */
.isOpen-Type .walk-in {
    background-color: #ffc107; /* Yellow for Walk-In */
}

/* Blue background for appointment */
.isOpen-Type .appointment {
    background-color: #007bff; /* Blue for Appointment */
}
/**********************************************************************/

/*********************************MAIN ROW*************************************/
/***********HERO ROW*****************/
.hero-row h1,
.hero-row h2{
    margin: 0;
    padding: 0;
}

.hero-tagline {
    width:fit-content;
    background-color: black; /* Black background */
    color: white; /* White text color */
    padding: 0 10px; /* Adjust padding as needed */
    border-radius: 60px; /* Optional: rounded corners */
    font-size: 1.5em; /* Adjust font size as needed */
}

.hero-call {
    font-size: 10vw; /* Very large font size that adjusts with screen size */
    font-weight: bold; /* Make the text bold */
    color: #000000; /* Adjust color as needed */
}



/*********SERVICES ROW*/
.service-grid {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background-color: #000000;
    padding: 10px;
    border-radius: 20px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); /* Card shadow */
    transition: transform 0.3s ease;
    
}

.service-grid:hover {
    transform: scale(1.05); /* Slight hover effect */
}

.service-image img {
    width: 60px;  /* Adjust the size as needed */
    height: auto;
    margin-bottom: 10px;
}

.service-text {
    font-size: 0.8em;
    text-align: center;
    font-weight: 500;
    color:#fafafa;
}

/*******************************************************************************/

/************PHOTOGRIDS****************************************/
.photogrids-rows {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.photogrids-row {
    display: flex;
    flex-direction: row-reverse;
    gap: 10px;
}

.photo-grid {
    width: 150px;
    height: 150px;
    overflow: hidden; /* Allows images to overflow if needed */
    border-radius: 20px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.empty {
    width: 150px;
    height: 150px;
}

.photo-grid img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
/*********************************************************/







/*************************************GREVIEW**************************************/
.gReview-items {
    display: grid;
    grid-template-columns: repeat(2, 1fr); /* 2 columns of equal width */
    grid-template-rows: repeat(3, auto); /* 3 rows with automatic height */
    gap: 10px; /* Optional: Add some space between grid items */
    width: 100%;
    max-width: 600px;
}

/* Card Style */
.gReview-card {
background-color: rgba(255, 255, 255, 1); /* Full opacity white background */
border-radius: 10px;
box-shadow: 4px 8px 16px rgba(0, 0, 0, 0.9);
padding: 20px;
margin-bottom: 15px;
opacity: 1; /* Full opacity */
transition: border 0.3s ease, transform 0.3s ease;
position: relative;
z-index: 1;
border: 2px solid #000000;
}

.gReview-card:hover {
border-image: linear-gradient(45deg, #ff6a00, #ffdd00, #00ff88, #00aaff) 1;
transform: scale(1.05);
}


/* Author Row */
.gReview-author-row {
display: flex;
flex-direction: row;
justify-content: space-between;
align-items: center;

}

.gReview-author {
font-size: 1em;
font-weight: bold;
}

.gReview-profile img {
border-radius: 50%;
width: 30px;
height: 30px;
}

/* Time Row */
.gReview-time-row {
display: flex;
flex-direction: row;
justify-content: space-between;
font-size: 0.8em;
color: #666;
margin-bottom: 10px;
}

/* Star Rating Row */
.gReview-star-row {
display: flex;
flex-direction: column;
align-items: center;
margin-bottom: 10px;
}

.star-image img {
width: 100px;
}

/* Gold color for the star image */
.star-image {
color: gold; /* Set the color for stars */
font-size: 1em; /* Adjust size based on design needs */
}


.rating-text {
margin-left: 10px;
font-size: 0.6em;
font-weight: bold;

}

/* Review Text Row */
.gReview-text-row {
display: flex;
flex-direction: row;
margin-top: 5px;
}

.review-text {
font-size: 0.9em;
line-height: 1;
color: #333;
text-align: left;
}

.gReview-button button {
background-color: black;
color: white;
border: none;
padding: 10px 20px;
font-size: 16px;
cursor: pointer;
transition: transform 0.3s ease, filter 0.3s ease;
border-radius: 5px;
}

.gReview-button button:hover {
transform: scale(1.1);
filter: brightness(1.3);
}
/***********************************************************************************/



/**************************CONTACT GRIDS************************************************/

/********************CONTACT PERSON*******/
.contact-person-card {
    display: flex;
    flex-direction: row;
    align-items: center;
    background-color: #ffffff;
    box-shadow: 4px 8px 16px rgba(0, 0, 0, 0.9);
    border: 2px solid #ccc; /* Optional border for card */
    border-radius: 24px;
    padding: 10px;
    transition: border 0.3s ease, transform 0.3s ease;
}

.contact-person-card:hover {
    border-image: linear-gradient(45deg, #ff6a00, #ffdd00, #00ff88, #00aaff) 1;
    transform: scale(1.05);
    }
    

.contact-person-image img {
    width: 100px; /* Adjust the size as needed */
    height: 100px; /* Ensure the image fits and maintains aspect ratio */
    object-fit: cover; /* Ensures the image fits the container */
    border-radius: 50%; /* Optional for rounded image */
}

.contact-person-details {
    display: flex;
    flex-direction: column;
    margin-left: 10px;
}

.contact-person-details h4,
.contact-person-details h5 {
    margin: 0;
    padding: 0;
}

.contact-person-details h5 {
    font-size: 0.9em; /* Smaller font size */
    font-style: italic; /* Make it italic */
    color: #666; /* Optional for a lighter color */
}
/*****************************

/***CONTACT-INFO-GRID*/
.contact-info-group {
    display: flex;
    flex-direction: row;
    justify-content: space-between; /* Distribute the contact grids evenly */
    gap: 20px; /* Add a 20px gap between the contact grids */
}

.contact-grid {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center; /* Center items vertically */
    padding: 15px;
    border: 1px solid #ccc; /* Optional card border */
    border-radius: 24px; /* Rounded corners */
    box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.1); /* Slight shadow */
    background-color: #fff; /* White background */
    flex: 1; /* Both grids take equal width */
    min-width: 250px; /* Minimum width to ensure responsiveness */
    transition: transform 0.3s ease; /* Animation on hover */
}

.contact-title {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 10px; /* Spacing between icon and title */
}

.contact-title img {
    width: 30px; /* Adjust size of icon */
    height: 30px; /* Ensure the icon fits well */
    object-fit: contain; /* Ensures the image fits without distortion */
}

.contact-title a img {
    width: 30px; /* Adjust as needed */
    height: 30px; /* Ensure the icon fits well */
    object-fit: contain; /* Ensures the image fits without distortion */
    transition: transform 0.3s ease; /* Smooth scaling effect */
}

.contact-title a:hover img {
    transform: scale(1.25); /* Increase the size on hover */
}

.contact-title h6 {
    margin: 0;
    font-size: 1rem;
}

.contact-detail {
    text-align: center;
    margin-top: 10px;
}

.contact-detail p, .contact-detail a {
    margin: 0;
}

.contact-detail a {
    text-decoration: none;
    color: #007BFF; /* Blue color for links */
    transition: color 0.3s ease, transform 0.3s ease; /* Animation for hover */
    display: inline-block; /* Allows scaling to work properly */
}

.contact-detail a:hover {
    color: #0056b3; /* Darker blue on hover */
    transform: scale(1.25); /* Increase the size on hover */
}

/****************CONTACT HOURS*/
.contact-operating-hours {
    display: flex;
    flex-direction: column;
    padding: 15px;
    justify-content: center;
    align-items: center;
    border: 1px solid #ccc; /* Optional card border */
    border-radius: 24px; /* Rounded corners */
    box-shadow: 0px 2px 5px rgba(0, 0, 0, 0.1); /* Slight shadow */
    background-color: #fff; /* White background */
}

.o-row {
    display: flex;
    flex-direction: row;
    align-items: center;
    margin-bottom: 10px; /* Spacing between rows */
}

.o-row img {
    width: 30px; /* Adjust as needed */
    height: 30px; /* Ensure the icon fits well */
    object-fit: contain; /* Ensures the image fits without distortion */
    margin-right: 10px; /* Spacing between image and text */
}

.o-row h5, .o-row p, .o-row h6 {
    margin: 0; /* Remove default margins */
}

.o-row p {
    font-style: italic; /* Italicize text */
}

.o-row h6{
    font-size: 1rem;
}

.o-row.r {
    color: red; /* Set text color to red */
}
/**********************************************************************************************/

/*******************WHATSAPP BUTTON*********************/
.w-b{
    display:flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.whatsapp-button {
    display: flex;
    align-items: center; /* Center text and image vertically */
    justify-content: center; /* Center text and image horizontally */
    width: 60%; /* Set width to 60% */
    padding: 20px 40px; /* Add some padding for better look */
    background-color: #25D366; /* WhatsApp green */
    color: white; /* Text color */
    border: none; /* Remove border */
    border-radius: 30px; /* Rounded corners */
    font-size: 1.5rem; /* Font size */
    cursor: pointer; /* Pointer cursor on hover */
    text-align: center; /* Center text inside button */
    transition: transform 0.3s ease; /* Scaling effect on hover */
}

.whatsapp-button img {
    width: 40px; /* Adjust as needed */
    height: 40px;
    margin-right: 10px;
}

.w-b a{
    text-decoration: none;
}

.whatsapp-button:hover {
    transform: scale(1.25); /* Slightly scale up on hover */
}

.whatsapp-button:active {
    transform: scale(1); /* Ensure it doesn't stay scaled when clicked */
}
/******************************************************************************************/

/**************************************************FOOTER************/
.footer-row {
    display: flex;
    justify-content: space-between; /* Space between the copy and developer sections */
    align-items: center; /* Align items vertically centered */
    padding: 10px; /* Add some padding if needed */
    background-color: #f1f1f1; /* Optional background color */
}

.copy {
    font-size: 0.8rem; /* Small font size for copyright text */
    color: #333; /* Optional text color */
}

.developer {
    font-size: 0.7rem; /* Even smaller font size for developer text */
    color: #007BFF; /* Optional color for developer text */
}

.developer a {
    text-decoration: none; /* Remove underline from link */
    color: inherit; /* Inherit color from .developer */
}

.developer a:hover {
    text-decoration: underline; /* Underline link on hover */
}
/***************************************************************************/















/*******************************************MEDIA BREAKPOINTS******************************/
/****************************************************************************************/

@media (max-width: 575.98px) {

    .container {
        width: 100vw; /* Set the container width to fill the viewport width */
        margin: 0; /* Remove any margins to avoid overflow */
        padding: 0; /* Remove padding if needed */
        box-sizing: border-box; /* Ensure padding and borders are included in the total width */
    }

    .top-row{
        flex-direction: column;
        gap: 10px;
    }

    .first-row {
        position: relative; /* Relative positioning for overlapping */
        height: 350px; /* Adjust as needed */
        margin-inline:5px;
    }
    
    .services-row{
        display:none;
    }
    
    .hero-row{
        margin-left: 0;
    }
    /**********************************************/
    .hero-tagline {
        width:fit-content;
        background-color: black; /* Black background */
        color: white; /* White text color */
        padding: 5px;
        border-radius: 10px; /* Optional: rounded corners */
        font-size: 0.5em; /* Adjust font size as needed */
    }
    
    .hero-call {
        font-size: 12vw; /* Very large font size that adjusts with screen size */
        font-weight: bold; /* Make the text bold */
        color: #000000; /* Adjust color as needed */
    }

    .photo-grid {
        width: 80px;
        height: 80px;
        overflow: hidden; /* Allows images to overflow if needed */
        border-radius: 10px;
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    }
    
    .empty {
        width: 80px;
        height: 80px;
    }
    
    .photo-grid img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .services-row-small{
        margin: 10px 0;
        display: grid;
        grid-template-columns: repeat(2, 1fr); /* 5 columns of equal width */
        grid-template-rows: repeat(5, auto); /* 2 rows */
        gap: 10px; /* Adjust the gap between grid items */
        padding: 20px;
    }


    .second-row{
        flex-direction: column;
    }

    .gReview-items{
        display: flex;
        flex-direction: column;
    }

    .contact-info-group{
        display: flex;
        flex-direction: column;
    }

    .o-row{
        text-align: center;
    }





}



@media (min-width: 576px) and (max-width: 767.98px) { 

    .container {
        width: 100vw; /* Set the container width to fill the viewport width */
        margin: 0; /* Remove any margins to avoid overflow */
        padding: 0; /* Remove padding if needed */
        box-sizing: border-box; /* Ensure padding and borders are included in the total width */
    }

    .top-row{
        flex-direction: column;
        gap: 10px;
    }

    .first-row {
        position: relative; /* Relative positioning for overlapping */
        height: 350px; /* Adjust as needed */
        margin-inline:5px;
    }

    .services-row{
        display: none;
    }

    .hero-tagline {
        width:fit-content;
        background-color: black; /* Black background */
        color: white; /* White text color */
        padding: 5px;
        border-radius: 30px; /* Optional: rounded corners */
        font-size: 0.8em; /* Adjust font size as needed */
    }

    .hero-call {
        font-size: 14vw; /* Very large font size that adjusts with screen size */
        font-weight: bold; /* Make the text bold */
        color: #000000; /* Adjust color as needed */
    }

    .services-row-small{
        margin: 10px 0;
        display: grid;
        grid-template-columns: repeat(5, 1fr); /* 5 columns of equal width */
        grid-template-rows: repeat(2, auto); /* 2 rows */
        gap: 10px; /* Adjust the gap between grid items */
        padding: 20px;
    }

    .photo-grid {
        width: 80px;
        height: 80px;
        overflow: hidden; /* Allows images to overflow if needed */
        border-radius: 10px;
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    }
    
    .empty {
        width: 80px;
        height: 80px;
    }
    
    .photo-grid img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .second-row{
        flex-direction: column;
    }

    .gReview-items{
        display: flex;
        flex-direction: column;
    }

    .contact-info-group{
        display: flex;
        flex-direction: column;
    }

    .o-row{
        text-align: center;
    }


}