/*Google Fonts*/
@import url('https://fonts.googleapis.com/css?family=Abril+Fatface');
@import url('https://fonts.googleapis.com/css?family=Montserrat:500,600,700');
@import url('https://fonts.googleapis.com/css?family=Source+Sans+Pro:400,600,700');

body,
html {
    height: 100%;
    width: 100%;
}

body {
    font-size: 1rem;
    font-family: 'Source Sans Pro', sans-serif;
}

img {
    max-width: 100%;
    height: auto;
}

section {
    overflow-x: hidden;
}

h1,
h2 {
    word-break: break-word;
}

/* ========== Top Navigation ========== */
.top-nav {
    height: 100px;
    transition: 0.2s ease-in;
    -webkit-transition: 0.2s ease-in;
    -moz-transition: 0.2s ease-in;
    background-color: #ffffff;
}

/* Navbar links */
.top-nav .navbar-nav li .nav-link {
    color: #000000;
    font-size: 16px;
    padding: 6px 22px;
    margin: 6px 5px 0 20px;
    font-weight: 600;
    text-transform: uppercase;
    transition: 0.2s ease-in;
    -webkit-transition: 0.2s ease-in;
    -moz-transition: 0.2s ease-in;
}

/* Align navbar links to the right using float */
.top-nav .navbar-nav {
    float: right;
}

.top-nav .navbar-nav li {
    display: inline-block;
    /* keeps links horizontal */
}


/* Hover & Active */
.top-nav li a.nav-link:hover,
.top-nav .nav-item.active a.nav-link {
    color: #fff;
    background-color: #000000;
    border-color: #000000;
    border-radius: 50px;
    transition: 0.5s ease-in;
    -webkit-transition: 0.5s ease-in;
    -moz-transition: 0.5s ease-in;
}

/* Logo */
.top-nav .navbar-brand {
    padding: 0;
    display: flex;
    align-items: center;
    font-size: 22px;
    color: #fff;
    font-family: 'Montserrat', sans-serif;
}

.nav-logo {
    margin-top: 0px;
    height: 90px;
    width: 200px;
    object-fit: contain;
}

/* Scrolled / Sticky header */
.top-nav.light-header {
    height: 80px;
    background-color: #ffffff;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.23);
    transition: 0.5s ease-in;
    -webkit-transition: 0.5s ease-in;
    -moz-transition: 0.5s ease-in;
    z-index: 9999;
}

/* Light header logo */
.top-nav.light-header .nav-logo {
    height: 80px;
    width: 200px;
    object-fit: contain;
}

/* @media (max-width: 991px) {
    .top-nav {
        height: auto;
        padding: 12px 15px;
    }

    .top-nav .navbar-nav {
        float: none;
        text-align: center;
    }

    .top-nav .navbar-nav li {
        display: block;
        margin: 8px 0;
    }

    .top-nav .navbar-nav li .nav-link {
        margin: 0;
        padding: 10px 18px;
        display: inline-block;
    }

    .nav-logo {
        height: 75px;
        width: auto;
        margin: auto;
    }
} */

/* =================================================
   MOBILE NAVBAR FIX (≤991px)
================================================= */
@media (max-width: 991px) {

    .top-nav {
        height: auto;
        padding: 10px 15px;
        background: #ffffff;
        box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    }

    /* Logo */
    .nav-logo {
        height: 65px;
        width: auto;
    }

    /* Hamburger button */
    .navbar-toggler {
        border: none;
        outline: none;
        box-shadow: none;
        padding: 6px;
    }

    .navbar-toggler-icon img {
        font-size: 24px;
        width: 30px;
        height: 30px;
        margin-left:-40px;
    }

    /* Dropdown menu */
    .navbar-collapse {
        position: absolute;
        top: 100%;
        left: 0;
        width: 100%;
        background: #ffffff;
        padding: 20px 0;
        border-radius: 0 0 18px 18px;
        box-shadow: 0 12px 30px rgba(0,0,0,0.15);
    }

    /* Nav list */
    .top-nav .navbar-nav {
        width: 100%;
        text-align: center;
        margin: 0;
    }

    .top-nav .navbar-nav .nav-item {
        display: block;
        margin: 6px 0;
    }

    /* Nav links */
    .top-nav .navbar-nav .nav-link {
        display: block;
        width: 88%;
        margin: auto;
        padding: 14px 0;
        font-size: 15px;
        font-weight: 600;
        border-radius: 50px;
    }

    /* Hover & active */
    .top-nav .navbar-nav .nav-link:hover,
    .top-nav .navbar-nav .nav-item.active .nav-link {
        background: #000;
        color: #fff;
    }
}


/* ========== Top Navigation Ends ========== */


/* ========== Page Loading Style ========== */
.loaders {
    width: 100%;
    box-sizing: border-box;
    display: flex;
    flex: 0 1 auto;
    flex-direction: row;
    flex-wrap: wrap;
}

.loaders .loader {
    box-sizing: border-box;
    display: flex;
    flex: 0 1 auto;
    flex-direction: column;
    flex-grow: 1;
    flex-shrink: 0;
    flex-basis: 25%;
    max-width: 25%;
    height: 200px;
    align-items: center;
    justify-content: center;
}

.loader {
    display: table;
    height: 100%;
    position: fixed;
    width: 100%;
    z-index: 1200;
}

.loader-bg {
    background: #0F0A06;
}

.loader-inner {
    display: table-cell;
    text-align: center;
    vertical-align: middle;
}

.page-loader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #fff;
    /* or transparent */
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 99999;
}

.loader-logo {
    width: 300px;
    /* adjust size */
    height: 200px;
    animation: logoPulse 1.5s infinite ease-in-out;
}

@keyframes logoPulse {
    0% {
        transform: scale(1);
        opacity: 1;
    }

    50% {
        transform: scale(0.9);
        opacity: 0.6;
    }

    100% {
        transform: scale(1);
        opacity: 1;
    }
}

/* ========== Page Loading Style Ends ========== */


/* ================= Footer Base ================= */

.footer {
    background: linear-gradient(180deg, #121212 0%, #1c1c1c 100%);
    padding: 80px 0 40px;
    font-family: 'Poppins', sans-serif;
    position: relative;
    clear: both;
}

.footer-block {
    background-color: #1f1f1f;
    padding: 50px 40px 25px;
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4);
}

/* ================= Footer Base Ends ================= */


/* ================= Widget ================= */

.footer-widget {
    margin-bottom: 35px;
}

.footer-widget .widget-title {
    font-family: 'Abril Fatface', cursive;
    color: #ffffff;
    font-size: 24px;
    font-weight: 200;
    margin-bottom: 25px;
    position: relative;
    padding-bottom: 10px;
}

.footer-widget .widget-title::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 40px;
    height: 2px;
    background-color: #ffffff;
}

.footer-widget p,
.footer-widget li,
.footer-widget a {
    color: #b5b5b5;
    font-size: 18px;
    font-family: Georgia, 'Times New Roman', Times, serif;
    line-height: 28px;
}

/* ================= Widget Ends ================= */


/* ================= Remove Bullets ================= */

.footer-widget ul {
    list-style: none;
    padding-left: 0;
    margin: 0;
}

/* ================= Remove Bullets Ends================= */

/* ================= Contact ================= */

.footer .contact li {
    position: relative;
    padding-left: 38px;
    margin-bottom: 14px;
}

.footer .contact li i {
    position: absolute;
    left: 0;
    top: 4px;
    color: #ffffff;
    font-size: 16px;
}

/* ================= Contact Ends================= */


/* ================= Quick Menu ================= */

.footer-widget ul li a {
    display: inline-block;
    transition: all 0.3s ease;
}

.footer-widget ul li a:hover {
    color: #ffffff;
    padding-left: 6px;
    text-decoration: none;
}

/* ================= Quick Menu Ends================= */


/* ================= Social Icons ================= */

.social-icons {
    display: flex;
    gap: 12px;
    margin-top: 20px;
    flex-wrap: wrap;
}

.social-icons a {
    width: 38px;
    height: 38px;
    background: #2a2a2a;
    color: #ffffff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}

.social-icons a:hover {
    background-color: #ffffff;
    color: #121212;
    transform: translateY(-2px);
    text-decoration: none;
}

/* ================= Social Icons Ends================= */


/* ================= Tiny Footer ================= */

.tiny-footer {
    margin-top: 30px;
    padding-top: 20px;
    border-top: 1px solid #2f2f2f;
    text-align: center;
}

.copyright-content {
    font-family: Georgia, 'Times New Roman', Times, serif;
    color: #888;
    font-size: 16px;
    font-weight: 600px;
    letter-spacing: 0.5px;
}

/* ================= Tiny Footer Ends================= */


/* ================= Footer Map ================= */

.footer-map {
    width: 100%;
    margin-top: 40px;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
}

.footer-map iframe {
    width: 100%;
    height: 300px;
    border: 0;
    filter: grayscale(100%) contrast(1.1);
}


@media (max-width: 991px) {

    .footer {
        padding: 60px 0 30px;
        text-align: center;
    }

    .footer-block {
        padding: 35px 25px 30px;
    }

    .footer-widget {
        margin-bottom: 30px;
    }

    .footer-widget .widget-title {
        font-size: 22px;
    }

    .footer-widget .widget-title::after {
        left: 50%;
        transform: translateX(-50%);
    }

    .footer-widget p,
    .footer-widget li,
    .footer-widget a {
        font-size: 16px;
        line-height: 26px;
    }

    /* Contact list fix */
    .footer .contact li {
        padding-left: 0;
        text-align: center;
    }

    .footer .contact li i {
        position: static;
        display: block;
        margin-bottom: 6px;
        font-size: 17px;
    }

    /* Social icons */
    .social-icons {
        justify-content: center;
        margin-top: 15px;
    }

    /* Map */
    .footer-map iframe {
        height: 240px;
    }

    .tiny-footer {
        margin-top: 25px;
    }
}

@media (max-width: 768px) {

    .footer {
        padding: 55px 0 25px;
    }

    .footer-block {
        padding: 30px 20px;
    }

    .footer-widget {
        margin-bottom: 26px;
    }

    .footer-widget .widget-title {
        font-size: 20px;
        margin-bottom: 20px;
    }

    .footer-widget p,
    .footer-widget li,
    .footer-widget a {
        font-size: 15.5px;
        line-height: 25px;
    }

    .social-icons a {
        width: 36px;
        height: 36px;
        font-size: 14px;
    }

    .footer-map iframe {
        height: 220px;
    }

    .copyright-content {
        font-size: 14.5px;
    }
}

@media (max-width: 480px) {

    .footer {
        padding: 50px 0 20px;
    }

    .footer-block {
        padding: 25px 18px;
        border-radius: 10px;
    }

    .footer-widget {
        margin-bottom: 22px;
    }

    .footer-widget .widget-title {
        font-size: 18px;
    }

    .footer-widget p,
    .footer-widget li,
    .footer-widget a {
        font-size: 14.5px;
        line-height: 24px;
    }

    .footer .contact li i {
        font-size: 16px;
    }

    .social-icons {
        gap: 10px;
    }

    .social-icons a {
        width: 34px;
        height: 34px;
    }

    .footer-map iframe {
        height: 200px;
    }

    .copyright-content {
        font-size: 13.5px;
        line-height: 22px;
    }
}


/* ================= Footer Map Ends ================= */


/* ================= Footer Base Ends ================= */


/* ========== Intro Header ========== */

.intro {
    float: left;
    width: 100%;
    display: flex;
    align-items: center;
    min-height: 100vh;
    position: relative;
    z-index: 1;
    margin-bottom: -60px;
}

.intro.intro-small {
    height: 60%;
}

.intro-bg {
    background-image: url("../img/hero.webp");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
}

.caption-container {
    width: 50rem;
    margin: 0 auto;
}

.caption-two-panel {
    display: flex;
    align-items: center;
}

.intro h1 {
    font-weight: 700;
    font-family: 'Abril Fatface', cursive;
    line-height: 1.3;
    font-size: 4.3rem;
    margin-bottom: 40px;

    /* 👇 MOVES HEADING LEFT */
    margin-left: -20px;
}

.intro-caption {
    max-width: 520px;

    /* 👇 MOVES CONTENT RIGHT */
    padding-left: 40px;
}

.intro-caption .btn i {
    float: left;
    margin-right: 15px;
}

.intro .carousel-item {
    height: 100vh;
}

.intro .carousel-caption {
    top: 25%;
}

#home {
    display: flex;
    align-items: center;
}

.btn {
    font-family: 'Montserrat', sans-serif;
    font-size: 1rem;
    font-weight: 600;
    padding: 18px;

}

.btn-primary {
    background-color: #000000;
    border-color: #000000;
}

.btn-primary:hover,
.btn-primary:focus {
    background-color: #585858;
    border-color: #000000;
}

.btn-capsul {
    border-radius: 30px;
}

@media (max-width: 991px) {

    .intro {
        min-height: auto;
        padding: 120px 20px 90px;
        margin-bottom: 0;
        text-align: center;
        display: flex;
        align-items: center;
        height:100%;
    }

    .intro-bg {
        background-position: center top;
    }

    .caption-container {
        width: 100%;
        max-width: 100%;
    }

    .caption-two-panel {
        flex-direction: column;
        align-items: center;
        gap: 30px;
    }

    .intro h1 {
        font-size: 2.8rem;
        line-height: 1.25;
        margin: 0 0 28px 0;
        margin-left: 0; /* remove desktop shift */
    }

    .intro-caption {
        max-width: 100%;
        padding-left: 0;
    }

    .intro-caption p {
        font-size: 1.05rem;
        line-height: 1.65;
        margin-bottom: 28px;
    }

    .btn {
        padding: 16px 28px;
        font-size: 0.95rem;
    }

    /* Carousel safety */
    .intro .carousel-item {
        min-height: 90vh;
        height: auto;
    }

    .intro .carousel-caption {
        position: static;
        transform: none;
    }
}

@media (max-width: 768px) {

    .intro {
        padding: 100px 18px 80px;
    }

    .intro h1 {
        font-size: 2.4rem;
        line-height: 1.22;
    }

    .intro-caption p {
        font-size: 1rem;
        line-height: 1.6;
    }

    .btn {
        width: 100%;
        max-width: 280px;
        padding: 14px 0;
    }
}

@media (max-width: 480px) {

    .intro {
        padding: 90px 16px 70px;
    }

    .intro h1 {
        font-size: 2.05rem;
        line-height: 1.2;
    }

    .intro-caption p {
        font-size: 0.95rem;
    }

    .btn {
        font-size: 0.9rem;
    }
}



/* ========== Intro Header Ends ========== */


/* ========== About Section ========== */

.about-section {
    /* height controls how much of the image is shown */
    min-height: 500px;
    /* adjust this as needed */
    background: url("../img/about.jpg") no-repeat center;
    background-size: cover;
    /* keeps the whole image visible */
    background-color: #f5f5f5;
    /* optional: fill empty space */
    color: #000000;
    display: block;
    align-items: center;
    /* vertically center content */
    justify-content: flex-start;
    /* align content to left */
    background-position: right center;
    justify-content: center;
    padding: 100px 50px;
    /* horizontal spacing for content */
    margin-bottom: -60px;
}

.about-content h2 {
    font-family: 'Abril Fatface', cursive;
    font-size: 4.3rem;
    margin-bottom: 25px;
    position: relative;
    color: #fff;
}

/* accent underline */
.about-content h2::after {
    content: "";
    width: 70px;
    height: 4px;
    background: #ffffff;
    display: block;
    margin-top: 12px;
}

.about-intro {
    font-size: 1.3rem;
    line-height: 1.5;
    color: #ffffff;
    margin-bottom: 24px;
}

/* points (no bullets) */
.about-points {
    font-family: Georgia, 'Times New Roman', Times, serif;
    display: grid;
    gap: 18px;
    margin-bottom: 40px;
}

.about-points .point {
    display: inline-block;
    /* fits the box to the text */
    background-color: #7b7b7b;
    /* black background */
    padding-left: 40px;
    position: relative;
    font-size: 1.2rem;
    color: #ffffff;
    line-height: 1.2;
}

/* ================= ABOUT POINTS SINGLE BACKGROUND ================= */
.about-points {
    background-color: #7b7b7b;
    /* single background for all points */
    padding: 30px 28px;
    border-radius: 12px;
}

/* Remove individual background effect visually */
.about-points .point {
    background-color: transparent;
    display: block;
    color: #ffffff;
}


/* custom icon */
.about-points .point::before {
    content: "✦";
    position: absolute;
    left: 0;
    top: 0;
    color: #ffffff;
    font-size: 1.2rem;
}

/* highlighted final text as black box */
.about-highlight {
    display: inline-block;
    /* fits the box to the text */
    background-color: #696969;
    /* black background */
    color: #ffffff;
    /* white text */
    font-size: 1.2rem;
    font-weight: 800;
    /* removed 'px', font-weight is just a number */
    padding: 10px 20px;
    /* add some space inside the box */
    line-height: 1.7;
    border-radius: 5px;
    /* optional: rounded corners */
    margin-top: -10px;
    /* adjust vertical spacing */
}

@media (max-width: 992px) {

  .about-section {
    padding: 80px 30px;
    background-position: center;
    min-height: auto;
    margin-bottom: 0;
  }

  .about-content h2 {
    font-size: 2.8rem;
  }

  .about-intro {
    font-size: 1.15rem;
  }

  .about-points {
    padding: 26px 24px;
  }
}

@media (max-width: 768px) {

  .about-section {
    padding: 70px 20px;
    background-position: center top;
    text-align: left;
  }

  .about-content h2 {
    font-size: 2.3rem;
    line-height: 1.2;
  }

  .about-content h2::after {
    width: 45px;
    height: 3px;
  }

  .about-intro {
    font-size: 1.05rem;
    line-height: 1.6;
  }

  .about-points {
    padding: 22px 20px;
    gap: 14px;
  }

  .about-points .point {
    font-size: 1.05rem;
    padding-left: 28px;
    line-height: 1.4;
  }

  .about-points .point::before {
    top: 2px;
    font-size: 1rem;
  }

  .about-highlight {
    font-size: 1.05rem;
    padding: 10px 18px;
    margin-top: 12px;
    display: inline-block;
  }
}

@media (max-width: 480px) {

  .about-section {
    padding: 60px 16px;
  }

  .about-content h2 {
    font-size: 2rem;
  }

  .about-intro {
    font-size: 1rem;
  }

  .about-points {
    padding: 18px 16px;
  }

  .about-points .point {
    font-size: 0.95rem;
    padding-left: 26px;
  }

  .about-highlight {
    font-size: 0.95rem;
    padding: 8px 14px;
  }
}


/* ========== About Section Ends========== */

/* ========== Services Section ========== */

.services-section {
    position: relative;
    padding: 80px 0;
    background: #313131;
    background-size: cover;
    color: #ffffff;
}

/* Container */
.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* Header */
.services-header {
    text-align: center;
    margin-bottom: 60px;
}

.services-header h2 {
    font-family: 'Abril Fatface', cursive;
    font-size: 4.3rem;
    margin-bottom: 25px;
    position: relative;
}

.services-header h4 {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-size: 1.3rem;
    line-height: 1.5;
    color: #ffffff;
    margin-bottom: 24px;
}

.services-header p {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-size: 1.3rem;
    line-height: 1.5;
    color: #000000;
    margin-bottom: 24px;
}

/* Grid Layout */
.services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 30px;
}

/* Service Card */
.service-card {
    background: #ffffff;
    border-radius: 14px;
    padding: 25px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.08);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.service-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 22px 45px rgba(0, 0, 0, 0.15);
}

/* Image Wrapper */
.service-img {
    width: 100%;
    overflow: hidden;
    border-radius: 12px;
    margin-bottom: 20px;
}

/* Image */
.service-img img {
    width: 100%;
    height: 220px;
    object-fit: cover;
    display: block;
}

/* Title */
.service-card h3 {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-weight: 200px;
    font-size: 2rem;
    margin-bottom: 25px;
    position: relative;
    color: #000;
}

/* Paragraph */
.service-card p {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-size: 1.2 rem;
    line-height: 1.4;
    color: #000000;
    margin-bottom: 20px;
}

/* List (No Bullets) */
.service-list {
    font-family: Georgia, 'Times New Roman', Times, serif;
    display: grid;
    gap: 18px;
    margin-bottom: 40px;
    list-style: none;
}

.service-list li {
    padding-left: 30px;
    position: relative;
    font-size: 1rem;
    color: #6e6e6e;
    line-height: 1.2;
}

.service-list li::before {
    content: "✦";
    position: absolute;
    left: 0;
    top: 0;
    color: #000000;
    font-size: 1.2rem;
}

/* Note Text */
.service-note {
    position: relative;
    bottom: 10px;
    color: #ffffff;
    font-size: 1rem;
    font-weight: 800;
    line-height: 0.50;
    margin-top: 10px;
}

/* Center Last Card */
.service-center {
    grid-column: 1 / -1;
    max-width: 520px;
    margin: 0 auto;
}

/* Move heading below image */
.services-grid .service-card:last-child h3 {
    margin-top: 15px;
    font-size: 1.6rem;
    font-weight: 800;
    text-align: left;
}

/* Right side content */
.services-grid .service-card:last-child p,
.services-grid .service-card:last-child .service-list {
    margin-top: 10px;
}

/* Make last service card full width */
.services-grid .service-card:last-child {
    grid-column: 1 / -1;
    /* spans all columns */
    display: grid;
    max-width: 100%;
}

.services-grid .service-card:last-child {
    display: grid;
    grid-template-columns: 1fr 1fr;
    /* image + content */
    gap: 30px;
    align-items: center;
}

/* Bigger image for last card */
.services-grid .service-card:last-child .service-img img {
    height: 300px;
    width: 700px;
}

@media (max-width: 992px) {

  .services-section {
    padding: 70px 0;
  }

  .services-header h2 {
    font-size: 3rem;
  }

  .services-header h4,
  .services-header p {
    font-size: 1.15rem;
    line-height: 1.6;
  }

  .service-img img {
    height: 210px;
  }
}

@media (max-width: 768px) {

  .services-section {
    padding: 60px 0;
  }

  .services-header {
    margin-bottom: 40px;
  }

  .services-header h2 {
    font-size: 2.4rem;
    line-height: 1.2;
  }

  .services-header h4,
  .services-header p {
    font-size: 1.05rem;
  }

  .services-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .service-card {
    padding: 22px;
  }

  .service-img img {
    height: 200px;
  }

  .service-card h3 {
    font-size: 1.6rem;
    margin-bottom: 18px;
  }

  .service-card p {
    font-size: 1rem;
    line-height: 1.5;
  }

  .service-list {
    gap: 14px;
    margin-bottom: 28px;
  }

  .service-list li {
    font-size: 0.95rem;
    line-height: 1.4;
    padding-left: 26px;
  }

  .service-note {
    font-size: 0.95rem;
    line-height: 1.4;
    margin-top: 12px;
  }

  /* LAST SERVICE CARD FIX */
  .services-grid .service-card:last-child {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .services-grid .service-card:last-child h3 {
    font-size: 1.4rem;
    text-align: left;
  }

  .services-grid .service-card:last-child .service-img img {
    height: 220px;
    width: 100%;
  }
}

@media (max-width: 480px) {

  .services-section {
    padding: 50px 0;
  }

  .services-header h2 {
    font-size: 2rem;
  }

  .services-header h4,
  .services-header p {
    font-size: 0.95rem;
  }

  .service-card {
    padding: 20px;
  }

  .service-img img {
    height: 180px;
  }

  .service-card h3 {
    font-size: 1.35rem;
  }

  .service-card p {
    font-size: 0.95rem;
  }

  .service-list li {
    font-size: 0.9rem;
  }

  .service-note {
    font-size: 0.9rem;
  }
}

/* ========== Services Section Ends ========== */


/* ========== Trust Section ========== */

.trust-section {
    position: relative;
    padding: 80px 0;
    background: url("../img/trust.jpg") no-repeat center center;
    background-size: cover;
    color: #ffffff;
}

/* Dark overlay for readability */
.trust-section::before {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    z-index: 1;
}

/* Keep content above overlay */
.trust-section .container {
    position: relative;
    z-index: 2;
}

/* Header */
.trust-header {
    text-align: center;
    margin-bottom: 60px;
}

.trust-header h2 {
    margin-top:50px;
    font-family: 'Abril Fatface', cursive;
    font-size: 4.3rem;
    margin-bottom: 25px;
    position: relative;
    color: #ffffff;
}

.trust-header p {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-size: 1.2rem;
    line-height: 1.4;
    color: #ffffff;
    margin-bottom: 20px;
}

/* Grid */
.trust-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 30px;
}

/* Card */
.trust-card {
    background: #f9f9f9;
    padding: 30px;
    border-radius: 14px;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.08);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.trust-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
}

/* Icon */
.trust-icon {
    width: 50px;
    height: 50px;
    background: #000000;
    color: #ffffff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.4rem;
    margin-bottom: 20px;
}

/* Text */
.trust-card p {
    font-size: 1.1rem;
    line-height: 1.7;
    color: #000000;
}

@media (max-width: 992px) {

  .trust-section {
    padding: 70px 0;
  }

  .trust-header {
    margin-bottom: 45px;
  }

  .trust-header h2 {
    font-size: 3rem;
    margin-top: 30px;
  }

  .trust-header p {
    font-size: 1.1rem;
    line-height: 1.6;
  }

  .trust-card {
    padding: 26px;
  }
}

@media (max-width: 768px) {

  .trust-section {
    padding: 60px 0;
    text-align: center;
  }

  .trust-header {
    margin-bottom: 35px;
  }

  .trust-header h2 {
    font-size: 2.4rem;
    line-height: 1.2;
    margin-top: 20px;
  }

  .trust-header p {
    font-size: 1.05rem;
    line-height: 1.6;
    margin-bottom: 15px;
  }

  .trust-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .trust-card {
    padding: 24px;
  }

  .trust-icon {
    margin: 0 auto 18px;
    width: 48px;
    height: 48px;
    font-size: 1.3rem;
  }

  .trust-card p {
    font-size: 1rem;
    line-height: 1.6;
  }
}

@media (max-width: 480px) {

  .trust-section {
    padding: 50px 0;
  }

  .trust-header h2 {
    font-size: 2rem;
  }

  .trust-header p {
    font-size: 0.95rem;
  }

  .trust-card {
    padding: 20px;
    border-radius: 12px;
  }

  .trust-icon {
    width: 44px;
    height: 44px;
    font-size: 1.2rem;
  }

  .trust-card p {
    font-size: 0.95rem;
  }
}

/* ========== Trust Section Ends ========== */


/* ========== Hygiene Section ========== */

.hygiene-section {
    padding: 90px 0;
    background-color: #f9f9f9;
}

/* Header */
.hygiene-header {
    text-align: center;
    margin-bottom: 60px;
}

.hygiene-header h2 {
    font-family: 'Abril Fatface', cursive;
    font-size: 4.3rem;
    margin-bottom: 25px;
    position: relative;
    color: #000000;
}

.hygiene-header p {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-size: 1.2rem;
    line-height: 1.4;
    color: #000000;
    margin-bottom: 20px;
}

/* Grid */
.hygiene-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 30px;
}

/* Card */
.hygiene-card {
    background: #ffffff;
    padding: 30px;
    border-radius: 14px;
    text-align: center;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.08);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.hygiene-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.15);
}

/* Icon */
.hygiene-icon {
    width: 60px;
    height: 60px;
    margin: 0 auto 20px;
    background: #000000;
    color: #ffffff;
    font-size: 1.6rem;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Title */
.hygiene-card h3 {
    font-size: 1.3rem;
    font-weight: 700;
    margin-bottom: 10px;
    color: #000000;
}

/* Text */
.hygiene-card p {
    font-size: 1rem;
    line-height: 1.6;
    color: #000000;
}

@media (max-width: 992px) {

  .hygiene-section {
    padding: 70px 0;
  }

  .hygiene-header {
    margin-bottom: 45px;
  }

  .hygiene-header h2 {
    font-size: 3rem;
  }

  .hygiene-header p {
    font-size: 1.1rem;
    line-height: 1.6;
  }

  .hygiene-card {
    padding: 26px;
  }
}

@media (max-width: 768px) {

  .hygiene-section {
    padding: 60px 0;
  }

  .hygiene-header {
    margin-bottom: 35px;
  }

  .hygiene-header h2 {
    font-size: 2.4rem;
    line-height: 1.2;
    margin-bottom: 18px;
  }

  .hygiene-header p {
    font-size: 1.05rem;
    line-height: 1.6;
    margin-bottom: 15px;
  }

  .hygiene-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .hygiene-card {
    padding: 24px;
    border-radius: 12px;
  }

  .hygiene-icon {
    width: 54px;
    height: 54px;
    font-size: 1.4rem;
    margin-bottom: 18px;
  }

  .hygiene-card h3 {
    font-size: 1.2rem;
  }

  .hygiene-card p {
    font-size: 0.95rem;
  }
}

@media (max-width: 480px) {

  .hygiene-section {
    padding: 50px 0;
  }

  .hygiene-header h2 {
    font-size: 2rem;
  }

  .hygiene-header p {
    font-size: 0.95rem;
  }

  .hygiene-card {
    padding: 20px;
  }

  .hygiene-icon {
    width: 48px;
    height: 48px;
    font-size: 1.3rem;
  }

  .hygiene-card h3 {
    font-size: 1.1rem;
  }

  .hygiene-card p {
    font-size: 0.9rem;
    line-height: 1.5;
  }
}

/* ========== Hygiene Section Ends ========== */


/* ========== Mission & Vision Section ========== */

.mv-section-full {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    min-height: 300px;
    background: #ffffff;
    margin-bottom: -300px;
}

/* Left Image */
.mv-image img {
    width: 100%;
    height: 65%;
    object-fit: cover;
}

/* Right Content */
.mv-content {
    padding: 80px 70px;
}

/* Header */
.mv-header h2 {
    font-family: 'Abril Fatface', cursive;
    font-size: 4.3rem;
    margin-bottom: 25px;
    position: relative;
    margin-top: -4px;
}

.mv-header p {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-size: 1.3rem;
    line-height: 1.5;
    color: #000000;
    margin-bottom: 24px;
}

/* Items */
.mv-item {
    display: flex;
    gap: 20px;
    margin-bottom: 35px;
}

/* Text */
.mv-text h3 {
    font-family: 'Abril Fatface', cursive;
    font-weight: 200px;
    font-size: 2rem;
    margin-bottom: 25px;
    position: relative;
}

.mv-text p {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-size: 1.2rem;
    line-height: 1.8;
    color: #000000;
    margin-bottom: -10px;
}

/* Lists */
.mv-text ul {
    font-family: Georgia, 'Times New Roman', Times, serif;
    display: grid;
    gap: 18px;
    margin-bottom: 40px;
    list-style: none;
}

.mv-text ul li {
    padding-left: 30px;
    position: relative;
    font-size: 1.2rem;
    color: #6e6e6e;
    line-height: 1.2;
}

.mv-text ul li::before {
    padding-right: 80px;
    content: "✦";
    position: absolute;
    left: 0;
    top: 0;
    color: #000000;
    font-size: 1.2rem;
}

@media (max-width: 991px) {

  .mv-section-full {
    grid-template-columns: 1fr;
    margin-bottom: 0;
  }

  .mv-image img {
    height: 320px;
    object-position: center;
  }

  .mv-content {
    padding: 60px 35px;
  }

  .mv-header h2 {
    font-size: 2.8rem;
  }

  .mv-header p {
    font-size: 1.15rem;
    line-height: 1.6;
  }

  .mv-item {
    gap: 18px;
    margin-bottom: 30px;
  }
}

@media (max-width: 768px) {

  .mv-section-full {
    display: block;
    margin-bottom: 0;
  }

  .mv-image img {
    width: 100%;
    height: 260px;
  }

  .mv-content {
    padding: 45px 22px;
    text-align: left;
  }

  .mv-header h2 {
    font-size: 2.4rem;
    line-height: 1.2;
    margin-bottom: 18px;
  }

  .mv-header p {
    font-size: 1.05rem;
    line-height: 1.6;
    margin-bottom: 22px;
  }

  .mv-item {
    flex-direction: column;
    gap: 12px;
    margin-bottom: 28px;
  }

  .mv-text h3 {
    font-size: 1.6rem;
    margin-bottom: 14px;
  }

  .mv-text p {
    font-size: 1rem;
    line-height: 1.7;
    margin-bottom: 0;
  }

  .mv-text ul {
    gap: 14px;
    margin-bottom: 30px;
  }

  .mv-text ul li {
    font-size: 1rem;
    padding-left: 26px;
    line-height: 1.4;
  }

  .mv-text ul li::before {
    font-size: 1rem;
    top: 2px;
  }
}

@media (max-width: 480px) {

  .mv-image img {
    height: 220px;
  }

  .mv-content {
    padding: 35px 18px;
  }

  .mv-header h2 {
    font-size: 2rem;
  }

  .mv-header p {
    font-size: 0.95rem;
  }

  .mv-text h3 {
    font-size: 1.4rem;
  }

  .mv-text p {
    font-size: 0.95rem;
  }

  .mv-text ul li {
    font-size: 0.95rem;
  }
}

/* ========== Mission & Vision Section Ends ========== */


/* ========== Visit Section ========== */

.visit-section {
    width: 100%;
    background: #000000;
    color: #ffffff;
    padding: 80px 0;
}

/* Layout */
.visit-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    gap: 60px;
    padding: 0 80px;
}

/* Left Text */
.visit-text h2 {
    font-family: 'Abril Fatface', cursive;
    font-size: 4.3rem;
    margin-bottom: 25px;
    position: relative;
    margin-top: -4px;
}

.visit-desc {
    font-size: 1.1rem;
    line-height: 1.8;
    margin-bottom: 30px;
    color: #dddddd;
}

/* Info */
.visit-info p {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-size: 1.3rem;
    line-height: 1.5;
    color: #ffffff;
    margin-bottom: 24px;
}

.visit-info i {
    font-size: 1.2rem;
    color: #ffffff;
    margin-right: 20px;
}

/* Map */
.visit-map iframe {
    width: 100%;
    height: 350px;
    border: none;
    border-radius: 12px;
    filter: grayscale(100%) contrast(1.1);
}

@media (max-width: 991px) {

    .visit-section {
        padding: 70px 0;
    }

    .visit-content {
        grid-template-columns: 1fr;
        gap: 40px;
        padding: 0 30px;
    }

    .visit-text h2 {
        font-size: 2.6rem;
        margin-top: 0;
    }

    .visit-desc {
        font-size: 1.05rem;
        line-height: 1.6;
    }

    .visit-info p {
        font-size: 1.1rem;
        line-height: 1.6;
    }

    .visit-map iframe {
        height: 280px;
    }
}

@media (max-width: 768px) {

    .visit-section {
        padding: 60px 0;
        text-align: center;
    }

    .visit-content {
        padding: 0 20px;
        gap: 30px;
    }

    .visit-text h2 {
        font-size: 2.4rem;
        margin-bottom: 18px;
    }

    .visit-desc {
        font-size: 1rem;
        line-height: 1.6;
        margin-bottom: 25px;
    }

    .visit-info p {
        font-size: 1rem;
        margin-bottom: 18px;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 10px;
    }

    .visit-info i {
        margin-right: 0;
        font-size: 1.1rem;
    }

    .visit-map iframe {
        height: 240px;
        border-radius: 10px;
    }
}

@media (max-width: 480px) {

    .visit-section {
        padding: 50px 0;
    }

    .visit-text h2 {
        font-size: 2rem;
    }

    .visit-desc {
        font-size: 0.95rem;
    }

    .visit-info p {
        font-size: 0.95rem;
        flex-direction: column;
        gap: 6px;
    }

    .visit-map iframe {
        height: 220px;
    }
}


/* ========== Visit Section Ends ========== */


/* ========== FAQ SECTION ========== */

.faq-section {
    padding: 90px 0;
    background: #f8f8f8;
}

/* Layout */
.faq-wrapper {
    display: grid;
    grid-template-columns: 1.2fr 0.8fr;
    gap: 60px;
    padding: 0 80px;
    align-items: start;
}

/* Left */
.faq-head h2 {
    font-family: 'Abril Fatface', cursive;
    font-size: 4.3rem;
    margin-bottom: 25px;
    position: relative;
    margin-top: -4px;
}

.faq-head p {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-size: 1.3rem;
    line-height: 1.5;
    color: #000000;
    margin-bottom: 24px;
}

/* FAQ Item */
.faq-item {
    background: #ffffff;
    border-radius: 10px;
    margin-bottom: 15px;
    overflow: hidden;
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.06);
}

/* Question */
.faq-question {
    font-family: Georgia, 'Times New Roman', Times, serif;
    width: 100%;
    padding: 18px 22px;
    background: transparent;
    border: none;
    font-size: 1.05rem;
    font-weight: 600;
    text-align: left;
    color: #000;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.faq-question span {
    font-size: 1.4rem;
    transition: transform 0.3s ease;
    border-radius:2px;
    border-color: #000;
}

/* Answer */
.faq-answer {
    font-family: Georgia, 'Times New Roman', Times, serif;
    height:200px;
    overflow: hidden;
    padding: 20 22px;
    align-items:center;
    justify-content:center;
    font-size: 22px;
    line-height: 1.5;
    color: #444;
    max-height:400px;
    transition: all 0.35s ease;
}

/* Active State */
.faq-item.active .faq-answer {
    max-height: 200px;
    padding: 0 22px 20px;
    white-space:normal;
}

.faq-item.active .faq-question span {
    transform: rotate(45deg);
}

/* Right Image */
.faq-right img {
    width: 100%;
    height: 420px;
    object-fit: cover;
    border-radius: 14px;
    position: sticky;
    top: 100px;
}

/* FAQ answer */
.faq-answer {
    max-height: 0;
    overflow: hidden;
    padding: 0 22px;
    font-size: 0.95rem;
    line-height: 1.7;
    color: #444;
    transition: max-height 0.5s ease, padding 0.35s ease;
}

/* Active FAQ */
.faq-item.active .faq-answer {
    max-height: 1000px;
    /* large enough for long content */
    padding: 10px 22px 20px;
}


@media (max-width: 991px) {

    .faq-section {
        padding: 70px 0;
    }

    .faq-wrapper {
        grid-template-columns: 1fr;
        gap: 40px;
        padding: 0 30px;
    }

    .faq-head h2 {
        font-size: 2.6rem;
        margin-top: 0;
    }

    .faq-head p {
        font-size: 1.1rem;
        line-height: 1.6;
    }

    .faq-question {
        font-size: 1rem;
        padding: 16px 18px;
    }

    .faq-answer {
        font-size: 0.95rem;
        line-height: 1.6;
    }

    .faq-right img {
        height: 280px;
        border-radius: 12px;
    }
}

@media (max-width: 768px) {

    .faq-section {
        padding: 60px 0;
    }

    .faq-wrapper {
        padding: 0 20px;
        gap: 30px;
    }

    .faq-head {
        text-align: center;
    }

    .faq-head h2 {
        font-size: 2.4rem;
        margin-bottom: 18px;
    }

    .faq-head p {
        font-size: 1rem;
        margin-bottom: 22px;
    }

    .faq-item {
        margin-bottom: 12px;
    }

    .faq-question {
        font-size: 0.95rem;
        padding: 14px 16px;
    }

    .faq-question span {
        font-size: 1.2rem;
    }

    .faq-answer {
        font-size: 0.95rem;
        padding: 0 16px;
    }

    .faq-item.active .faq-answer {
        padding: 10px 16px 18px;
    }

    .faq-right img {
        height: 240px;
    }
}

@media (max-width: 480px) {

    .faq-section {
        padding: 50px 0;
    }

    .faq-head h2 {
        font-size: 2rem;
    }

    .faq-head p {
        font-size: 0.95rem;
    }

    .faq-question {
        font-size: 0.9rem;
        padding: 12px 14px;
    }

    .faq-answer {
        font-size: 0.9rem;
        line-height: 1.6;
    }

    .faq-right img {
        height: 220px;
    }
}

/* ========== FAQ SECTION ENDS ========== */


/* ========== Contact Section ========== */

.contact-section {
    min-height: 100vh;
    /* full viewport height */
    display: flex;
    align-items: center;
    /* vertically center content */
    padding: 0;
    /* remove extra top/bottom padding */
    background: #ffffff;
}

/* Centered container with split layout */
.contact-container {
    max-width: 1200px;
    width: 100%;
    margin: auto;
    padding: 0 20px;
}

.contact-container.contact-split {
    display: flex;
    gap: 30px;
    align-items: stretch;
    /* make left & right equal height */
    width: 100%;
}

/* Left image */
.contact-left {
    flex: 1;
}

.contact-left img {
    width: 100%;
    height: 100%;
    /* full height of container */
    object-fit: cover;
    border-radius: 12px;
    /* remove rounding if full height */
}

/* Right form */
.contact-right {
    flex: 1;
    display: flex;
    align-items: center;
    /* vertically center form */
    justify-content: center;
}

/* Form Card */
.contact-form {
    width: 100%;
    max-width: 650px;
    /* compact form width */
    background: transparent;
    padding: 25px 20px;
    border-radius: 12px;
}

/* Heading */
.contact-form h2 {
    font-family: 'Abril Fatface', cursive;
    position: relative;
    margin-top: -4px;
    font-size: 2.5rem;
    margin-bottom: 15px;

}

.contact-subtext {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-size: 0.95rem;
    line-height: 1.5;
    color: #000000;
    margin-bottom: 25px;
}

/* Form Rows */
.form-row {
    display: flex;
    gap: 15px;
    margin-bottom: 15px;
    flex-wrap: wrap;
}

/* Form Group */
.form-group {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.form-group.full-width {
    flex: 1 1 100%;
}

/* Labels */
.form-group label {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-weight: 600;
    margin-bottom: 3px;
    color: #000;
}

/* Inputs */
.form-group input,
.form-group textarea {
    font-family: Georgia, 'Times New Roman', Times, serif;
    padding: 14px 16px;
    border: 1px solid #ccc;
    border-radius: 12px;
    font-size: 1rem;
    outline: none;
    transition: all 0.3s ease;
}

.form-group input:focus,
.form-group textarea:focus {
    border-color: #3b3b3b;
    box-shadow: 0 0 10px rgb(87, 87, 87);
}

/* Textarea */
textarea {
    min-height: 80px;
    resize: none;
}

/* Button */
.btn-submit {
    background: #000;
    color: #fff;
    border: none;
    border-radius: 30px;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.3s ease;
    padding: 10px 24px;
    font-size: 0.95rem;
}

.btn-submit:hover {
    background: #b1b1b1;
    color: #000;
}

/* ------------------ Tablets / Small Laptops ≤ 991px ------------------ */
@media (max-width: 991px) {
    .contact-container.contact-split {
        flex-direction: column;
        gap: 20px;
    }

    /* Left image stacked above form */
    .contact-left img {
        width: 100%;
        height: 260px;
        object-fit: cover;
        border-radius: 12px;
    }

    /* Right form */
    .contact-right {
        width: 100%;
        padding: 20px 0;
        justify-content: center;
        align-items: flex-start;
    }

    /* Form card adjustments */
    .contact-form {
        max-width: 100%;
        padding: 25px 20px;
    }

    .contact-form h2 {
        font-size: 2.2rem;
        margin-bottom: 15px;
    }

    .contact-subtext {
        font-size: 0.95rem;
        margin-bottom: 20px;
    }

    .form-row {
        flex-direction: column;
        gap: 15px;
    }
}

/* ------------------ Tablets / Medium Devices ≤ 768px ------------------ */
@media (max-width: 768px) {
    .contact-left img {
        height: 220px;
    }

    .contact-form h2 {
        font-size: 2rem;
    }

    .contact-subtext {
        font-size: 0.9rem;
    }

    .form-group input,
    .form-group textarea {
        padding: 12px 14px;
        font-size: 0.95rem;
    }

    .btn-submit {
        padding: 10px 20px;
        font-size: 0.9rem;
    }
}

/* ------------------ Small Mobile Devices ≤ 480px ------------------ */
@media (max-width: 480px) {
    .contact-section {
        padding: 30px 0;
    }

    .contact-left img {
        height: 200px;
        border-radius: 10px;
    }

    .contact-form {
        padding: 20px 15px;
    }

    .contact-form h2 {
        font-size: 1.8rem;
        text-align: center;
    }

    .contact-subtext {
        font-size: 0.85rem;
        text-align: center;
    }

    .form-row {
        flex-direction: column;
        gap: 12px;
    }

    .form-group input,
    .form-group textarea {
        padding: 10px 12px;
        font-size: 0.9rem;
    }

    .btn-submit {
        width: 100%;
        font-size: 0.9rem;
        padding: 10px 0;
    }
}

/* ========== Contact Section Ends ========== */


/* ================= Blog Creative ================= */
.blog-creative {
    padding: 90px 0;
    background: #f9f9f9;
}

.blog-title {
    text-align: center;
    font-family: 'Abril Fatface', cursive;
    font-size: 3rem;
    margin-bottom: 10px;
}

.blog-subtitle {
    text-align: center;
    color: #777;
    margin-bottom: 70px;
    font-size: 1.05rem;
}

/* Blog Row */
.blog-row {
    display: flex;
    align-items: center;
    margin-bottom: 80px;
    background: #fff;
    border-radius: 25px;
    box-shadow: 0 18px 45px rgba(0, 0, 0, 0.08);
    overflow: hidden;
}

/* Reverse layout */
.blog-row.reverse {
    flex-direction: row-reverse;
}

/* Image */
.blog-img img {
    width: 100%;
    height: 100%;
    min-height: 340px;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.blog-row:hover .blog-img img {
    transform: scale(1.08);
}

/* Content */
.blog-content {
    padding: 45px 50px;
}

.blog-date {
    display: inline-block;
    font-size: 0.85rem;
    letter-spacing: 1px;
    color: #828282;
    margin-bottom: 10px;
}

.blog-content h3 {
    font-size: 1.8rem;
    margin-bottom: 18px;
    line-height: 1.3;
}

.blog-content p {
    font-size: 1.05rem;
    color: #555;
    line-height: 1.7;
    margin-bottom: 25px;
}

/* Button */
.blog-btn {
    display: inline-block;
    padding: 12px 32px;
    border-radius: 40px;
    background: #000;
    color: #fff;
    font-size: 0.95rem;
    text-decoration: none;
    transition: all 0.3s ease;
}

.blog-btn:hover {
    text-decoration: none;
    background: #878787;
    color: #000000;
    transform: translateY(-3px);
}

/* ------------------ Medium Devices ≤ 991px ------------------ */
@media (max-width: 991px) {

    .blog-creative {
        padding: 60px 20px;
    }

    .blog-title {
        font-size: 2.4rem;
        margin-bottom: 15px;
    }

    .blog-subtitle {
        font-size: 0.95rem;
        margin-bottom: 50px;
    }

    .blog-row,
    .blog-row.reverse {
        flex-direction: column;
        margin-bottom: 50px;
    }

    .blog-img img {
        width: 100%;
        height: auto;
        min-height: 220px;
        border-radius: 20px 20px 0 0;
    }

    .blog-content {
        padding: 25px 20px;
        text-align: center;
    }

    .blog-content h3 {
        font-size: 1.5rem;
        margin-bottom: 15px;
    }

    .blog-content p {
        font-size: 1rem;
        line-height: 1.6;
        margin-bottom: 20px;
    }

    .blog-btn {
        padding: 10px 26px;
        font-size: 0.9rem;
    }
}

/* ------------------ Tablets / Small Devices ≤ 768px ------------------ */
@media (max-width: 768px) {

    .blog-creative {
        padding: 50px 15px;
    }

    .blog-title {
        font-size: 2.1rem;
    }

    .blog-subtitle {
        font-size: 0.9rem;
        margin-bottom: 40px;
    }

    .blog-img img {
        min-height: 200px;
    }

    .blog-content h3 {
        font-size: 1.4rem;
    }

    .blog-content p {
        font-size: 0.95rem;
    }

    .blog-btn {
        padding: 10px 22px;
        font-size: 0.85rem;
    }
}

/* ------------------ Small Mobile Devices ≤ 480px ------------------ */
@media (max-width: 480px) {

    .blog-creative {
        padding: 40px 12px;
    }

    .blog-title {
        font-size: 1.8rem;
    }

    .blog-subtitle {
        font-size: 0.85rem;
        margin-bottom: 35px;
    }

    .blog-img img {
        min-height: 180px;
    }

    .blog-content {
        padding: 20px 15px;
    }

    .blog-content h3 {
        font-size: 1.3rem;
        margin-bottom: 12px;
    }

    .blog-content p {
        font-size: 0.9rem;
        line-height: 1.5;
    }

    .blog-btn {
        padding: 8px 20px;
        font-size: 0.85rem;
    }
}


/* ================= Blog Creative Ends ================= */


/* ================= Testimonial Intro ================= */

.testimonial-intro {
    padding: 80px 0;
    background: #fff;
    text-align: center;
}

.testimonial-intro h2 {
    font-family: 'Abril Fatface', cursive;
    font-size: 3rem;
}

.testimonial-intro h4 {
    color: #ff8c00;
    margin: 15px 0;
}

.testimonial-intro p {
    max-width: 900px;
    margin: 25px auto;
    font-size: 1.05rem;
    line-height: 1.7;
    color: #555;
}

.intro-points {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 18px;
    margin-top: 25px;
}

.intro-points span {
    background: #f5f5f5;
    padding: 10px 18px;
    border-radius: 30px;
    font-size: 0.95rem;
}

/* ================= Trusted Clients ================= */
.trusted-clients {
    background: #fafafa;
    padding: 60px 0;
    text-align: center;
}

.trusted-clients h3 {
    margin-bottom: 35px;
}

.client-types {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 20px;
}

.client-types div {
    background: #fff;
    padding: 18px;
    border-radius: 15px;
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.08);
    font-weight: 500;
}

/* ================= Testimonial Intro Ends ================= */


/* ================= Testimonials ================= */

.testimonial-section {
    padding: 90px 0;
    background: #fff;
}

.testimonial-section h3 {
    text-align: center;
    margin-bottom: 60px;
    font-size: 2.4rem;
}

.testimonial-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 30px;
}

.testimonial-card {
    background: #fff;
    padding: 35px 30px;
    border-radius: 20px;
    box-shadow: 0 15px 40px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s ease;
}

.testimonial-card:hover {
    transform: translateY(-6px);
}

.stars {
    color: #ff8c00;
    font-size: 1.2rem;
    margin-bottom: 15px;
}

.testimonial-card p {
    font-size: 1rem;
    color: #555;
    line-height: 1.6;
    margin-bottom: 20px;
}

.testimonial-card h4 {
    margin-bottom: 5px;
}

.testimonial-card span {
    font-size: 0.9rem;
    color: #777;
}

/* ================= CTA ================= */
.testimonial-cta {
    background: linear-gradient(135deg, #000, #222);
    color: #fff;
    padding: 80px 0;
    text-align: center;
}

.testimonial-cta h3 {
    font-size: 2.4rem;
    margin-bottom: 20px;
}

.testimonial-cta p {
    max-width: 750px;
    margin: 0 auto 30px;
    line-height: 1.6;
}

.cta-contact {
    display: flex;
    justify-content: center;
    gap: 35px;
    font-size: 1.1rem;
    margin-bottom: 20px;
}

@media (max-width: 768px) {
    .cta-contact {
        flex-direction: column;
        gap: 10px;
    }
}

/* ================= Testimonials ================= */


/* ================= Page Header  ================= */

.page-header {
    position: relative;
    padding: 50px 0;
    text-align: center;
    background: #000000;
    margin-top: 90px;
}

.page-header h2 {
    font-family: 'Abril Fatface', cursive;
    position: relative;
    color: #ffffff;
    font-size: 70px;
    font-weight: 700;
    margin-top: 30px;
    ;
    margin-bottom: 25px;
    padding-bottom: 15px;
}

.page-header h2::after {
    position: absolute;
    content: "";
    width: 100px;
    height: 2px;
    left: calc(50% - 50px);
    bottom: 0;
    background: #121518;
}

.page-header a {
    font-family: Georgia, 'Times New Roman', Times, serif;
    position: relative;
    padding: 0 12px;
    font-size: 22px;
    color: #ffffff;
}

.page-header a:hover {
    color: #656565;
    text-decoration: none;
}

.page-header a::after {
    position: absolute;
    content: "/";
    width: 8px;
    height: 8px;
    top: -2px;
    right: -7px;
    text-align: center;
    color: #ffffff;
}

.page-header a:last-child::after {
    display: none;
}

/* ================= Page Header Responsive ≤ 991px ================= */
@media (max-width: 991px) {

    .page-header {
        padding: 40px 15px; /* tighter vertical & horizontal padding */
        margin-top: 70px; /* reduce top spacing */
    }

    .page-header h2 {
        font-size: 36px; /* scale down heading */
        margin-top: 20px;
        margin-bottom: 20px;
        padding-bottom: 10px;
    }

    .page-header h2::after {
        width: 60px; /* smaller underline */
        left: calc(50% - 30px);
        height: 2px;
        background: #121518;
    }

    .page-header a {
        font-size: 16px; /* smaller breadcrumb text */
        padding: 0 8px;
    }

    .page-header a::after {
        font-size: 16px; /* scale down slash */
        top: 0;
        right: -6px;
    }
}


/* ================= Page Header  ================= */


/* ================= SERVICES PAGE ================= */
.services-modern {
    width: 100%;
    padding: 80px 8%;
    display: flex;
    flex-direction: column;
    gap: 90px;
    background: #ffffff;
}

/* Individual service row */
.services-modern>div {
    display: grid;
    grid-template-columns: 1fr 1.1fr;
    gap: 60px;
    align-items: center;
}

/* Alternate layout */
.services-modern>div:nth-child(even) {
    grid-template-columns: 1.1fr 1fr;
}

.services-modern>div:nth-child(even) .service-image {
    order: 2;
}

/* ================= IMAGE ================= */
.service-image {
    width: 100%;
    height: 420px;
    border-radius: 18px;
    overflow: hidden;
}

.service-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ================= CONTENT ================= */
.services-modern h2 {
    font-family: 'Abril Fatface', cursive;
    font-size: 3rem;
    margin-bottom: 20px;
    letter-spacing: 1px;
}

.services-modern p {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-size: 1.15rem;
    line-height: 1.7;
    color: #333;
    margin-bottom: 18px;
}

/* ================= LIST ================= */
.services-modern ul {
    list-style: none;
    padding: 0;
    margin: 20px 0 25px;
    display: grid;
    gap: 12px;
}

.services-modern ul li {
    position: relative;
    padding-left: 26px;
    font-size: 1.05rem;
    color: #555;
}

.services-modern ul li::before {
    content: "✦";
    position: absolute;
    left: 0;
    color: #000;
    font-size: 1.1rem;
}



/* ================= BUTTON ================= */
.service-btn {
    display: inline-block;
    padding: 14px 34px;
    background: #000;
    color: #fff;
    border-radius: 40px;
    font-size: 0.95rem;
    font-weight: 600;
    letter-spacing: 1px;
    text-decoration: none;
    transition: all 0.3s ease;
}

.service-btn:hover {
    background: #333;
    color: #ffffff;
    transform: translateY(-2px);
}

/* ================= SERVICE EXTRA ================= */
.service-extra {
    padding: 90px 8%;
    display: flex;
    flex-direction: column;
    gap: 80px;
    background: #fafafa;
}

/* Blocks */
.extra-block {
    background: #ffffff;
    padding: 50px 50px;
    border-radius: 18px;
    box-shadow: 0 14px 35px rgba(0, 0, 0, 0.08);
}

/* Dark variation */
.extra-block.dark {
    background: #000;
    color: #fff;
}

.extra-block.dark li,
.extra-block.dark p {
    color: #ddd;
}

/* Light variation */
.extra-block.light-bg {
    background: #f4f4f4;
}

/* Headings */
.extra-block h2 {
    font-family: 'Abril Fatface', cursive;
    font-size: 2.8rem;
    margin-bottom: 20px;
}

.extra-block h4 {
    font-size: 1.3rem;
    margin-top: 25px;
}

/* Paragraph */
.extra-block p {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-size: 1.1rem;
    line-height: 1.8;
    margin-bottom: 18px;
}

/* Lists */
.extra-block ul {
    list-style: none;
    padding: 0;
    margin: 20px 0;
    display: grid;
    gap: 14px;
}

.extra-block ul li {
    position: relative;
    padding-left: 28px;
    font-size: 1.05rem;
}

.extra-block ul li::before {
    content: "✦";
    position: absolute;
    left: 0;
    color: #000;
}

.extra-block.dark ul li::before {
    color: #fff;
}

/* Note */
.extra-note {
    font-weight: 600;
    margin-top: 15px;
}

/* CTA */
.service-cta {
    text-align: center;
    padding: 70px 40px;
    background: #000;
    color: #fff;
    border-radius: 20px;
}

.service-cta h2 {
    font-family: 'Abril Fatface', cursive;
    font-size: 3rem;
    margin-bottom: 15px;
}

.cta-contact {
    font-size: 1.2rem;
    margin: 20px 0;
}

/* ================= GROOMING PACKAGES ================= */

.package-block {
    background: #000;
    /* dark background for all cards */
    padding: 60px 8%;
    border-radius: 20px;
    color: #ffffff;
}

.package-intro {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-size: 1.1rem;
    max-width: 800px;
    margin: 0 auto 40px auto;
    color: #fff;
    text-align: center;
}

/* Single row layout */
.package-row {
    display: flex;
    flex-wrap: nowrap;
    gap: 25px;
    justify-content: center;
    align-items: stretch;
}

/* Card - same style for all */
.package-card {
    flex: 1 1 220px;
    max-width: 260px;
    background: #111;
    padding: 35px 25px;
    border-radius: 18px;
    box-shadow: 0 14px 35px rgba(0, 0, 0, 0.3);
    text-align: center;
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    align-items: center;
    color: #ffffff;
}

.package-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 18px 45px rgba(0, 0, 0, 0.5);
}

/* Icon */
.package-icon {
    color: #ffd700;
    /* gold for all icons */
    margin-bottom: 18px;
}

/* Card Title */
.package-card h4 {
    font-size: 1.25rem;
    margin-bottom: 12px;
    font-weight: 600;
}

/* Description */
.package-card p {
    font-size: 0.95rem;
    line-height: 1.6;
    color: #ddd;
}

/* Note */
.extra-note {
    margin-top: 35px;
    font-weight: 600;
    font-size: 0.95rem;
    color: #fff;
    text-align: center;
}

/* Why Choose Us Section */
.choose-us {
    background: #f4f4f4;
    padding: 60px 8%;
    border-radius: 18px;
}

.choose-us h2 {
    font-family: 'Abril Fatface', cursive;
    font-size: 2.8rem;
    margin-bottom: 40px;
    text-align: center;
}

/* Grid row */
.choose-row {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 30px;
}

/* Card */
.choose-card {
    background: #fff;
    flex: 1 1 220px;
    padding: 40px 20px;
    border-radius: 18px;
    text-align: center;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
    transition: all 0.3s ease;
}

.choose-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 14px 35px rgba(0, 0, 0, 0.12);
}

/* Number highlight */
.choose-number {
    font-size: 3.5rem;
    font-weight: 800;
    color: #000;
    margin-bottom: 15px;
    font-family: 'Abril Fatface', cursive;
}

/* Icons for other cards */
.choose-icon {
    font-size: 3rem;
    color: #000;
    margin-bottom: 15px;
}

/* Text */
.choose-text {
    font-size: 1.1rem;
    font-weight: 600;
    color: #555;
    line-height: 1.4;
}

/* ================= CTA SECTION ================= */

.service-cta {
    background: linear-gradient(135deg, #000, #222);
    color: #fff;
    text-align: center;
    padding: 80px 20px;
    border-radius: 20px;
    margin: 60px 8%;
    box-shadow: 0 14px 35px rgba(0, 0, 0, 0.15);
}

.service-cta h2 {
    font-family: 'Abril Fatface', cursive;
    font-size: 3rem;
    margin-bottom: 20px;
}

.service-cta .cta-contact {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    font-size: 1.15rem;
    margin-bottom: 12px;
}

.service-cta .cta-contact i {
    color: #fff;
    font-size: 1.2rem;
}

.service-cta .cta-subtitle {
    display: block;
    margin-bottom: 30px;
    font-size: 1rem;
    color: #ccc;
}

.cta-btn {
    display: inline-block;
    padding: 16px 42px;
    background: #ff8c00;
    color: #fff;
    font-size: 1.05rem;
    font-weight: 600;
    letter-spacing: 1px;
    border-radius: 50px;
    text-decoration: none;
    transition: all 0.3s ease;
}

.cta-btn:hover {
    background: #ffa500;
    transform: translateY(-3px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.3);
    text-decoration: none;
    color: #fff;
}

/* ================= CTA SECTION ENDS================= */


/* ================= SERVICE VISUAL GRID ================= */
.service-visual {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 35px;
    padding: 100px 8%;
    background: #fafafa;
    justify-content: center;
}

/* ================= SERVICE CARD ================= */
.service-card {
    background: #fff;
    border-radius: 22px;
    box-shadow: 0 12px 35px rgba(0, 0, 0, 0.1);
    padding: 35px 30px;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    height: 100%;
    transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.service-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.18);
}

/* ================= SERVICE CARD ENDS ================= */

/* ================= ICON ================= */
.card-icon {
    width: 72px;
    height: 72px;
    margin-bottom: 18px;
}

.card-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

/* ================= TITLE ================= */
.service-card h2 {
    font-family: 'Abril Fatface', cursive;
    font-size: 1.9rem;
    margin-bottom: 15px;
    color: #000;
}

/* ================= TEXT ================= */
.service-card p {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-size: 1.02rem;
    line-height: 1.7;
    color: #555;
    margin-bottom: 18px;
}

/* ================= LIST ================= */

.service-card ul {
    list-style: none;
    padding: 0;
    margin: 20px 0;
    display: grid;
    gap: 12px;
}

.service-card ul li {
    position: relative;
    padding-left: 26px;
    font-size: 1.02rem;
    color: #555;
    text-align: left;
}

.service-card ul li::before {
    content: "✦";
    position: absolute;
    left: 0;
    color: #000;
    font-size: 1.25rem;
}

/* ================= LIST Ends ================= */

/* ================= CARD TYPES ================= */

.service-card.corporate {
    border-top: 6px solid #1e90ff;
}

.service-card.home {
    border-top: 6px solid #28a745;
}

.service-card.wedding {
    border-top: 6px solid #ff1493;
}

.service-card.express-senior {
    border-top: 6px solid #ff8c00;
}

.service-card.custom {
    border-top: 6px solid #6a5acd;
}

/* ================= CARD TYPES Ends ================= */

/* ================= MOBILE RESPONSIVE ================= */
@media (max-width: 991px) {

    /* ===== SERVICES MODERN ===== */
    .services-modern {
        padding: 60px 20px;
        gap: 60px;
    }

    .services-modern>div {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .services-modern>div:nth-child(even) {
        grid-template-columns: 1fr;
    }

    .services-modern>div:nth-child(even) .service-image {
        order: 0;
    }

    .service-image {
        height: 320px;
    }

    .services-modern h2 {
        font-size: 2.2rem;
        text-align: center;
    }

    .services-modern p {
        font-size: 1.05rem;
        text-align: center;
    }

    .services-modern ul {
        justify-items: center;
    }

    .services-modern ul li {
        text-align: left;
        max-width: 420px;
    }

    .service-btn {
        margin: 0 auto;
        display: block;
        width: fit-content;
    }

    /* ===== SERVICE EXTRA ===== */
    .service-extra {
        padding: 70px 20px;
        gap: 60px;
    }

    .extra-block {
        padding: 40px 30px;
    }

    .extra-block h2 {
        font-size: 2.2rem;
        text-align: center;
    }

    .extra-block p {
        font-size: 1.05rem;
    }

    /* ===== GROOMING PACKAGES ===== */
    .package-block {
        padding: 60px 20px;
    }

    .package-row {
        flex-wrap: wrap;
        gap: 25px;
    }

    .package-card {
        max-width: 100%;
    }

    /* ===== WHY CHOOSE US ===== */
    .choose-us {
        padding: 60px 20px;
    }

    .choose-us h2 {
        font-size: 2.2rem;
    }

    .choose-row {
        justify-content: center;
    }

    .choose-card {
        max-width: 320px;
    }

    /* ===== CTA SECTION ===== */
    .service-cta {
        margin: 60px 20px;
        padding: 60px 25px;
    }

    .service-cta h2 {
        font-size: 2.2rem;
    }

    .cta-btn {
        padding: 14px 36px;
        font-size: 1rem;
    }

    /* ===== SERVICE VISUAL GRID ===== */
    .service-visual {
        grid-template-columns: repeat(2, 1fr);
        padding: 70px 20px;
        gap: 25px;
    }

    .service-card h2 {
        font-size: 1.6rem;
    }
}


@media (max-width: 576px) {

    .services-modern {
        padding: 50px 16px;
        gap: 50px;
    }

    .service-image {
        height: 260px;
    }

    .services-modern h2 {
        font-size: 1.9rem;
    }

    .services-modern p {
        font-size: 1rem;
    }

    .extra-block {
        padding: 32px 22px;
    }

    .extra-block h2 {
        font-size: 1.9rem;
    }

    .package-card {
        padding: 30px 20px;
    }

    .choose-number {
        font-size: 2.8rem;
    }

    .choose-icon {
        font-size: 2.5rem;
    }

    .service-visual {
        grid-template-columns: 1fr;
    }

    .service-card {
        padding: 30px 22px;
    }

    .service-card h2 {
        font-size: 1.5rem;
    }

    .service-card p,
    .service-card ul li {
        font-size: 0.98rem;
    }
}


/* ================= SERVICES PAGE Ends ================= */


/* ================= POPUP STYLES ================= */

.popup-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.75);
    display: none;
    z-index: 9999;
}

.popup-box {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);

    background: #fff;
    max-width: 900px;
    width: 90%;
    display: flex;
    border-radius: 10px;
    overflow: hidden;
}


/* Close Button */
.popup-close {
    position: absolute;
    top: 10px;
    right: 15px;
    font-size: 26px;
    cursor: pointer;
    color: #fff;
    background: red;
    width: 30px;
    height: 30px;
    text-align: center;
    line-height: 30px;
    border-radius: 50%;
}

/* Left Image */
.popup-left {
    width: 45%;
    background: #000;
}

.popup-left img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Right Form */
.popup-right {
    width: 55%;
    padding: 40px;
}

.popup-right h3 {
    margin-bottom: 30px;
    font-weight: 500;
    font-family: 'Abril Fatface', cursive;
}

.popup-right input,
.popup-right select {
    font-family: Georgia, 'Times New Roman', Times, serif;
    width: 100%;
    border-radius: 12px;
    padding: 12px;
    margin-bottom: 15px;
    border: 1px solid #7b7b7b;
    outline: none;
}

.popup-right button {
    width: 100%;
    background: #292929;
    color: #fff;
    padding: 12px;
    border: none;
    font-weight: bold;
    cursor: pointer;
}

.popup-right button :hover {
    text-decoration: none;
    background: #848484;
    color: #fff;
}

.popup-right small {
    display: block;
    text-align: center;
    margin-top: 10px;
    color: #777;
}


@keyframes popupZoom {
    from {
        transform: scale(0.85);
        opacity: 0;
    }

    to {
        transform: scale(1);
        opacity: 1;
    }
}

@media (max-width: 768px) {

    /* Popup overlay */
    .popup-overlay {
        padding: 15px;
        align-items: center;
        justify-content: center;
    }

    /* Popup container */
    .popup-box {
        width: 100%;
        max-width: 100%;
        height: auto;
        max-height: 90vh;
        flex-direction: column;
        border-radius: 16px;
        overflow-y: auto;
    }

    /* Left image section */
    .popup-left {
        width: 100%;
        height: 180px;
    }

    .popup-left img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    /* Right content section */
    .popup-right {
        width: 100%;
        padding: 25px 20px;
        text-align: center;
    }

    /* Popup heading */
    .popup-right h2,
    .popup-right h3 {
        font-size: 1.6rem;
        margin-bottom: 12px;
    }

    /* Popup text */
    .popup-right p {
        font-size: 1rem;
        line-height: 1.6;
    }

    /* Form inputs */
    .popup-right input,
    .popup-right textarea,
    .popup-right select {
        width: 100%;
        font-size: 15px;
        padding: 12px 14px;
    }

    /* Submit button */
    .popup-right button,
    .popup-right .btn {
        width: 100%;
        padding: 14px;
        font-size: 1rem;
        border-radius: 30px;
    }

    /* Close button */
    .popup-close {
        top: 10px;
        right: 10px;
        font-size: 22px;
    }
}

/* ================= POPUP STYLES ================= */

/* ================= FRANCHISE PAGE  ================= */

.franchise-hero {
    position: relative;
    padding: 140px 20px;
    text-align: center;
    color: #000;
}

.franchise-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at top, rgba(93, 93, 93, 0.35), transparent 60%);
    pointer-events: none;
}

.franchise-hero h1 {
    font-family: 'Abril Fatface', cursive;
    font-size: 5rem;
    margin-bottom: 20px;
    letter-spacing: 1px;
}

.franchise-hero h1 span {
    color: #000;
}

.franchise-hero p {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-size: 1.15rem;
    line-height: 1.7;
    color: #333;
    margin-bottom: 18px;
}

.franchise-hero .btn {
    border-radius: 40px;
    padding: 14px 44px;
    position: relative;
    overflow: hidden;
}

.franchise-hero .btn::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(120deg, transparent, rgba(255, 255, 255, .4), transparent);
    transform: translateX(-100%);
    transition: .5s;
}

.franchise-hero .btn:hover::before {
    transform: translateX(100%);
}

.franchise-why {
    padding: 90px 0;
    margin-top: -100px;
}

.franchise-why h2 {
    font-family: 'Abril Fatface', cursive;
    font-size: 3rem;
    margin-bottom: 20px;
    letter-spacing: 1px;
    margin-bottom: 60px;
    ;
}

.franchise-why h4 {
    font-family: 'Abril Fatface', cursive;
    font-size: 1.3rem;
    margin-top: 25px;
}

.franchise-why p {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-size: 1.15rem;
    line-height: 1.7;
    color: #333;
    margin-bottom: 18px;
}

.franchise-why .why-card {
    background: rgba(255, 255, 255, .9);
    backdrop-filter: blur(10px);
    border-radius: 18px;
    padding: 46px;
    border: 1px solid rgba(124, 179, 66, .3);
    transition: .4s;
    position: relative;
}

.franchise-why .why-card::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(135deg, rgba(93, 93, 93, 0.35), transparent);
    opacity: 0;
    transition: .4s;
}

.nh-investment .container {
    max-width: 980px;
    /* try 900px–1000px */
}

.franchise-why .why-card:hover::after {
    opacity: 1;
}

.franchise-why .why-card:hover {
    transform: translateY(-14px);
}

.franchise-investment {
    padding: 90px 0;
    margin-top: -100px;
}

.franchise-investment h2 {
    font-family: 'Abril Fatface', cursive;
    font-size: 3rem;
    margin-bottom: 20px;
    letter-spacing: 1px;
    margin-bottom: 60px;
    ;
}

.franchise-investment h4 {
    font-family: 'Abril Fatface', cursive;
    font-size: 1.3rem;
    margin-top: 25px;
}

.franchise-investment p {
    font-size: 1.15rem;
    line-height: 1.7;
    color: #333;
    margin-bottom: 18px;
}

.franchise-investment .investment-box {
    background: #fff;
    padding: 30px;
    border-radius: 16px;
    position: relative;
    transition: .35s;
}

.franchise-investment .investment-box::before {
    content: "";
    position: absolute;
    inset: -2px;
    border-radius: inherit;
    background: rgba(176, 176, 176, 0.9);
    z-index: -1;
    opacity: .4;
}

.franchise-investment .investment-box:hover {
    transform: scale(1.05);
}

.franchise-process {
    padding: 90px 0;
    margin-top: -100px;
}

.franchise-process h2 {
    font-family: 'Abril Fatface', cursive;
    font-size: 3rem;
    margin-bottom: 20px;
    letter-spacing: 1px;
    margin-bottom: 60px;
    ;
}

.franchise-process h4 {
    font-family: 'Abril Fatface', cursive;
    font-size: 1.3rem;
    margin-top: 25px;
}

.franchise-process p {
    font-family: Georgia, 'Times New Roman', Times, serif;
    font-size: 1.15rem;
    line-height: 1.7;
    color: #333;
    margin-bottom: 18px;
}

.franchise-process .process-steps {
    max-width: 700px;
    margin: auto;
    position: relative;
}

.franchise-process .process-steps::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 0;
    width: 3px;
    height: 100%;
    background: linear-gradient(120deg, transparent, rgba(100, 100, 100, 0.4), transparent);
    transform: translateX(-50%);
}

.franchise-process .step {
    width: 48%;
    padding: 20px 28px;
    background: #fff;
    border-radius: 14px;
    margin-bottom: 30px;
    position: relative;
}

.franchise-process .step:nth-child(odd) {
    margin-left: auto;
}

.franchise-process .step::after {
    content: "";
    position: absolute;
    top: 20px;
    width: 14px;
    height: 14px;
    background: #000000;
    border-radius: 50%;
}

.franchise-process .step:nth-child(odd)::after {
    left: -22px;
}

.franchise-process .step:nth-child(even)::after {
    right: -22px;
}

.franchise-support {
    padding: 90px 0;
    margin-top: -100px;
    background: linear-gradient(135deg, #111, #000);
}

.franchise-support h2 {
    font-family: 'Abril Fatface', cursive;
    font-size: 3rem;
    margin-bottom: 20px;
    letter-spacing: 1px;
    margin-bottom: 60px;
    color: #ffffff;
}

.franchise-support ul {
    max-width: 700px;
    margin: auto;
    font-family: Georgia, 'Times New Roman', Times, serif;
    display: grid;
    gap: 18px;
    list-style: none;
}

.franchise-support li {
    padding: 14px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    transition: .3s;
    padding-left: 50px;
    position: relative;
    font-size: 1.2rem;
    color: #6e6e6e;
    line-height: 1.2;
}

.franchise-support li:hover {
    color: #ffffff;
    transform: translateX(10px);
}


.franchise-support ul li::before {
    padding-right: 80px;
    content: "✦";
    position: absolute;
    left: 0;
    top: 0;
    color: #ffffff;
    font-size: 1.2rem;
}

@media (max-width: 768px) {

    .franchise-process .process-steps::before {
        left: 10px;
    }

    .franchise-process .step {
        width: 100%;
        margin-left: 30px;
    }

    .franchise-process .step::after {
        left: -30px !important;
        right: auto;
    }
}

/* ================= FRANCHISE PAGE ENDS ================= */


/* =========================================================
   FINAL MOBILE RESPONSIVE FIX — ADD AT BOTTOM ONLY
========================================================= */

/* ---------- GLOBAL MOBILE SAFETY ---------- */
@media (max-width: 991px) {
    * {
        box-sizing: border-box;
    }

    body,
    html {
        overflow-x: hidden;
    }

    section {
        overflow-x: hidden;
    }
}

/* ================= SUPPORT PAGE ================= */

/* ================= Letter Wrapper ================= */
.letter-wrapper {
    padding: 120px 15px;
    background: radial-gradient(circle at top, #ffffff 0%, #e6e6e6 65%);
}

/* ================= Paper ================= */
.letter-paper {
    max-width: 960px;
    margin: auto;
    background: linear-gradient(180deg, #ffffff 0%, #f9f9f9 100%);
    padding: 90px 75px;
    border-radius: 18px;
    box-shadow:
        0 35px 70px rgba(0, 0, 0, 0.15),
        inset 0 0 0 1px rgba(0, 0, 0, 0.15);
    position: relative;
    overflow: hidden;
}

/* Ornamental border */
.letter-paper::before {
    content: "";
    position: absolute;
    inset: 18px;
    border-radius: 16px;
    border: 1px dashed rgba(0, 0, 0, 0.35);
    pointer-events: none;
}

/* Corner ornament */
.letter-paper::after {
    content: "✦";
    position: absolute;
    top: 22px;
    right: 28px;
    font-size: 1.4rem;
    color: rgba(0, 0, 0, 0.45);
}

/* ================= Header ================= */
.letter-head {
    text-align: center;
    margin-bottom: 70px;
}

.letter-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 70px;
    height: 70px;
    font-size: 2.6rem;
    color: #000;
    margin-bottom: 20px;
}

/* Title */
.letter-head h1 {
    font-family: 'Cinzel', serif;
    font-size: 2.8rem;
    font-weight: 800;
    letter-spacing: 3px;
    color: #000;
    position: relative;
    display: inline-block;
    padding-bottom: 18px;
}

/* Black divider */
.letter-head h1::after {
    content: "✦ ✦ ✦";
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    font-size: 0.8rem;
    letter-spacing: 10px;
    color: rgba(0, 0, 0, 0.6);
}

/* ================= Intro ================= */
.letter-intro {
    font-family: 'Source Serif 4', serif;
    font-size: 1.2rem;
    line-height: 2.05;
    color: #222;
    margin-bottom: 70px;
    text-align: justify;
    margin-top: -40px;
}

/* ================= Sections ================= */
.letter-section {
    position: relative;
    padding-left: 95px;
    margin-bottom: 70px;
}

/* Vertical timeline */
.letter-section::before {
    content: "";
    position: absolute;
    left: 42px;
    top: 55px;
    width: 1px;
    height: calc(100% - 55px);
    background: linear-gradient(to bottom,
            rgba(0, 0, 0, 0.5),
            rgba(0, 0, 0, 0));
}

.letter-section h3 {
    font-family: 'Playfair Display', serif;
    font-size: 1.8rem;
    font-weight: 700;
    margin-bottom: 18px;
    color: #000;
}

/* Section number */
.sec-no {
    position: absolute;
    left: 0;
    top: -10px;
    font-family: 'Cinzel', serif;
    font-size: 3.1rem;
    font-weight: 700;
    color: rgba(0, 0, 0, 0.25);
}

/* Paragraphs */
.letter-section p {
    font-family: 'Source Serif 4', serif;
    font-size: 1.2rem;
    line-height: 1.95;
    color: #222;
    margin-bottom: 14px;
}

/* ================= Lists ================= */
.letter-section ul {
    padding-left: 0;
    margin-top: 16px;
}

.letter-section ul li {
    list-style: none;
    position: relative;
    padding-left: 36px;
    margin-bottom: 14px;
    font-family: 'Source Serif 4', serif;
    font-size: 1.2rem;
    color: #111;
}

/* Minimal diamond bullets */
.letter-section ul li::before {
    content: "◆";
    position: absolute;
    left: 0;
    top: 2px;
    font-size: 0.8rem;
    color: #000;
}

/* Nested list */
.letter-section ul ul {
    margin-top: 10px;
    padding-left: 22px;
}

/* ================= Signature ================= */
.letter-sign {
    text-align: right;
    margin-top: 90px;
}

.letter-sign::before {
    content: "";
    display: block;
    width: 140px;
    height: 2px;
    background: #000;
    margin-left: auto;
    margin-bottom: 16px;
}

.letter-sign p {
    font-family: 'Cinzel', serif;
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: 2px;
    color: #000;
}

/* ================= Responsive ================= */
@media (max-width: 991px) {
    .letter-paper {
        padding: 55px;
    }

    .letter-section {
        padding-left: 65px;
    }

    .sec-no {
        font-size: 2.4rem;
    }
}

@media (max-width: 576px) {
    .letter-paper {
        padding: 32px 24px;
    }

    .letter-head h1 {
        font-size: 2.1rem;
    }

    .letter-section {
        padding-left: 0;
    }

    .letter-section::before {
        display: none;
    }

    .sec-no {
        position: relative;
        display: block;
        margin-bottom: 6px;
    }
}

/* ================= SUPPORT PAGE Ends ================= */

/* ================= BLOG INNER PAGE ================= */

/* ===== Blog Left Float Layout ===== */
.bw-blog-left-wrap {
    background: #fff;
    color: #111;
    font-family: 'Georgia', serif;
    padding: 80px 20px;
}

.bw-blog-container {
    max-width: 900px;
    margin: auto;
}

/* Header */
.bw-blog-header {
    text-align: center;
    margin-bottom: 50px;
}

.bw-blog-tag {
    display: inline-block;
    font-size: 0.85rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: #666;
    margin-bottom: 12px;
}

.bw-blog-title {
    font-size: 2.5rem;
    font-weight: 700;
    line-height: 1.3;
    margin-bottom: 12px;
}

.bw-blog-meta {
    font-size: 0.9rem;
    color: #777;
}

/* Content with left-floating image */
.bw-blog-content-wrap {
    display: flex;
    flex-direction: column;
}

.bw-blog-left-img {
    float: none;
    /* Remove float to take full width */
    width: 100%;
    /* Full width of the container */
    height: 400px;
    /* Maintain aspect ratio automatically */
    max-width: 100%;
    /* Ensure it doesn’t exceed container */
    margin: 0 0 30px 0;
    /* Space below the image */
    border-radius: 12px;
    object-fit: cover;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.1);
    transition: transform 0.3s;
}

.bw-blog-left-img:hover {
    transform: scale(1.02);
    /* Subtle zoom on hover */
}

/* Text content */
.bw-blog-content {
    overflow: hidden;
    /* clears float */
}

.bw-blog-content p {
    font-size: 1.05rem;
    line-height: 1.8;
    margin-bottom: 22px;
    color: #222;
}

/* Intro paragraph style */
.bw-intro {
    font-size: 1.15rem;
    font-weight: 500;
    border-left: 4px solid #111;
    padding-left: 18px;
    margin-bottom: 28px;
}

/* Headings */
.bw-blog-content h2 {
    font-size: 1.7rem;
    margin: 50px 0 18px;
    color: #111;
    position: relative;
}

.bw-blog-content h2::after {
    content: "";
    display: block;
    width: 50px;
    height: 2px;
    background: #111;
    margin-top: 6px;
}

.bw-blog-content h3 {
    font-size: 1.35rem;
    margin: 30px 0 15px;
}

/* Lists */
.bw-list,
.bw-steps {
    margin-bottom: 30px;
    padding-left: 20px;
}

.bw-list li,
.bw-steps li {
    font-size: 1.05rem;
    margin-bottom: 10px;
}

/* Quote */
.bw-quote {
    margin: 50px 0;
    padding-left: 25px;
    border-left: 4px solid #111;
    font-size: 1.25rem;
    font-style: italic;
}

/* Responsive */
@media (max-width: 992px) {
    .bw-blog-left-img {
        float: none;
        width: 100%;
        max-width: 100%;
        margin: 0 0 25px 0;
    }
}

@media (max-width: 768px) {

    /* Wrapper */
    .bw-blog-left-wrap {
        padding: 50px 16px;
    }

    .bw-blog-container {
        max-width: 100%;
    }

    /* Header */
    .bw-blog-header {
        margin-bottom: 35px;
    }

    .bw-blog-tag {
        font-size: 0.75rem;
        letter-spacing: 1.5px;
    }

    .bw-blog-title {
        font-size: 1.9rem;
        line-height: 1.35;
    }

    .bw-blog-meta {
        font-size: 0.85rem;
    }

    /* Image */
    .bw-blog-left-img {
        width: 100%;
        max-width: 100%;
        height: 240px;
        margin: 0 0 22px 0;
        border-radius: 10px;
    }

    /* Content */
    .bw-blog-content p {
        font-size: 1rem;
        line-height: 1.75;
        margin-bottom: 18px;
    }

    /* Intro paragraph */
    .bw-intro {
        font-size: 1.05rem;
        padding-left: 14px;
        border-left-width: 3px;
    }

    /* Headings */
    .bw-blog-content h2 {
        font-size: 1.45rem;
        margin: 36px 0 14px;
    }

    .bw-blog-content h2::after {
        width: 40px;
    }

    .bw-blog-content h3 {
        font-size: 1.2rem;
        margin: 24px 0 12px;
    }

    /* Lists */
    .bw-list,
    .bw-steps {
        padding-left: 18px;
    }

    .bw-list li,
    .bw-steps li {
        font-size: 1rem;
        margin-bottom: 8px;
    }

    /* Quote */
    .bw-quote {
        font-size: 1.1rem;
        margin: 35px 0;
        padding-left: 18px;
        border-left-width: 3px;
    }
}

@media (max-width: 480px) {

    .bw-blog-title {
        font-size: 1.65rem;
    }

    .bw-blog-left-img {
        height: 200px;
    }

    .bw-blog-content p {
        font-size: 0.95rem;
    }

    .bw-blog-content h2 {
        font-size: 1.35rem;
    }

    .bw-blog-content h3 {
        font-size: 1.15rem;
    }

    .bw-quote {
        font-size: 1.05rem;
    }
}

/* ================= BLOG INNER PAGE ================= */

/* ================= FLOATING ICON ================= */

.floating-appointment-btn {
    position: fixed;
    right: 40px;
    bottom: 30px;
    width: 60px;
    height: 60px;
    background-color: #000000;
    color: #fff;
    font-size: 24px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.3);
    z-index: 9999;
    transition: all 0.3s ease;
}

.floating-appointment-btn:hover {
    background-color: #ffffff;
    transform: scale(1.1);
    color: #000000;
}


/* Mobile View */
@media (max-width: 767px) {
    .floating-appointment-btn {
        right: 15px;
        bottom: 20px;
        width: 70px;
        height: 70px;
        font-size: 30px;
        box-shadow: 0 6px 15px rgba(0, 0, 0, 0.25);
    }
}

/* ================= FLOATING ICON ENDS ================= */