/* about  */
.page-title {
    /* height: 100vh; */
}

.opm-welcome-section {
    position: relative;
    background-color: #f3f3f3;
    overflow: hidden;
}

/* Subtle palm background */
.opm-welcome-section::before {
    content: "";
    position: absolute;
    inset: 0;
    background: url('../images/plambg.webp');
    background-size: contain;
    opacity: 0.04;
    background-repeat: no-repeat;
}

/* Inner spacing */
.opm-welcome-section .container {
    padding-top: 100px;
    padding-bottom: 100px;
    position: relative;
    z-index: 2;
}

/* Vertical alignment WITHOUT bootstrap flex */
.opm-welcome-section .row {
    display: flex;
    align-items: center;
}

/* LEFT SIDE */
.opm-welcome-section .opm-left-content h2 {
    font-size: 42px;
    font-weight: 500;
    letter-spacing: 3px;
    line-height: 1.2;
    color: #111;
}

.opm-welcome-section .opm-left-content h5 {
    font-size: 14px;
    letter-spacing: 4px;
    margin-top: 20px;
    color: #333;
}

/* BUTTON AREA */
.opm-welcome-section .opm-btn-wrapper {
    margin-top: 40px;
}

/* MAIN BUTTON */
.opm-welcome-section .opm-animated-btn {
    position: relative;
    display: inline-block;
    text-decoration: none;
    height: 55px;
    line-height: 55px;
    padding-left: 70px;
    padding-right: 25px;
    transition: 0.4s ease;
    align-items: inherit;
    /* padding-top: 14px; */
    background: #f3f3f3;
    display: flex;
    align-items: center;
    width: fit-content;
}



/* CIRCLE */
.opm-welcome-section .opm-circle-btn {
    position: absolute;
    left: 0;
    top: 0;
    width: 55px;
    height: 55px;
    border-radius: 50%;
    background: var(--btn-color);
    text-align: center;
    line-height: 55px;
    color: #fff;
    transition: 0.4s ease;
    z-index: 2;
}


/* TEXT */
.opm-welcome-section .opm-link-text {
    font-size: 21px;
    letter-spacing: 2px;
    color: #111;

    font-weight: 700;
    position: relative;
    z-index: 2;
    transition: 0.4s ease;
    line-height: 1.4 !important;
    /* YEH NAYI LINE ADD KI HAI GAP KAM KARNE KE LIYE */
    margin: 0 !important;
    /* Agar ye alag-alag tags mein hain toh extra space hatayega */
    display: block;
    /* Text ko sahi se align karne ke liye */
}

/* EXPANDING BACKGROUND */
.opm-welcome-section .opm-animated-btn:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    height: 55px;
    width: 55px;
    background: var(--btn-color);
    border-radius: 50px;
    transition: 0.5s ease;
    z-index: 1;
}

/* HOVER EFFECT */
.opm-welcome-section .opm-animated-btn:hover:before {
    width: 100%;
}

.opm-welcome-section .opm-animated-btn:hover .opm-link-text {
    color: #fff;
}

.opm-welcome-section .opm-animated-btn:hover .opm-circle-btn {
    background: transparent;
}

.opm-welcome-section .opm-animated-btn:hover .opm-arrow {
    transform: translateX(6px);
    transition: 0.3s ease;
}

/* RIGHT SIDE TEXT */
.opm-welcome-section .opm-right-content p {
    font-size: 17px;
    line-height: 1.8;
    color: #222;
}

/* ===================================--------------------------------======================= */

/* =========================================
   OPM STORY SECTION
========================================= */

.opm-story-section {
    position: relative;
    background: #eaf1f5;
}

.opm-story-section .row {
    display: flex;
}

.opm-story-section .opm-story-content {
    padding-right: 60px;
}

.opm-story-section .opm-story-item {
    display: flex;
    align-items: flex-start;
    margin-bottom: 45px;
}

.opm-story-section .opm-icon i {
    font-size: 50px;
    color: var(--btn-color);
}

.opm-story-section .opm-icon {
    width: 50px;
    height: 50px;
    border-radius: 8px;
    /* background: #d7eef9; */
    text-align: center;
    line-height: 50px;
    font-size: 20px;
    color: #1aa3d8;
    margin-right: 20px;
    flex-shrink: 0;
}

.opm-story-section .opm-text h4 {
    font-size: 21px;
    letter-spacing: 2px;
    font-weight: 600;
    margin-bottom: 10px;
    color: #111;
}

.opm-story-section .opm-text p {
    font-size: 16px;
    line-height: 1.7;
    color: #333;
}

.opm-story-section .opm-story-image {
    position: sticky;
    top: 100px;
}

.opm-story-section .opm-story-image img {
    width: 100%;
    border-radius: 18px 0px 0px 18px;
    display: block;
}

/* =======================-------------------========================================== */

/* ========================================
   OPM CONTACT CTA SECTION
======================================== */

.opm-contact-cta {
    position: relative;
    background-image: url('../images/bg-co.webp');
    /* replace */
    background-size: cover;
    background-position: center;
    color: #fff;
}



/* Vertical alignment without bootstrap flex utilities */
.opm-contact-cta .row {
    display: flex;
    /* align-items: center; */
}

/* LEFT TITLE */
.opm-contact-cta .opm-cta-left h2 {
    font-size: 50px;
    font-weight: 300;
    letter-spacing: 4px;
    margin: 0;
    color: var(--white-color);
}

/* RIGHT TEXT */
.opm-contact-cta .opm-cta-right p {
    font-size: 18px;
    line-height: 1.8;
    opacity: 0.9;
}

/* BUTTON WRAPPER */
.opm-contact-cta .opm-cta-buttons {
    margin-top: 40px;
}

/* PRIMARY BUTTON */
.opm-contact-cta .opm-btn-primary {
    display: inline-block;
    background: var(--btn-color);
    color: #fff;
    text-decoration: none;
    padding: 18px 45px;
    border-radius: 40px;
    font-size: 14px;
    letter-spacing: 2px;
    transition: 0.4s ease;
}

/* OUTLINE BUTTON */
.opm-contact-cta .opm-btn-outline {
    display: inline-block;
    border: 2px solid #fff;
    color: #fff;
    text-decoration: none;
    padding: 16px 45px;
    border-radius: 40px;
    font-size: 14px;
    letter-spacing: 2px;
    margin-left: 25px;
    transition: 0.4s ease;
}

/* Hover Effects */
.opm-contact-cta .opm-btn-primary:hover {
    background: #1f8db8;
}

.opm-contact-cta .opm-btn-outline:hover {
    background: #fff;
    color: #1f2f55;
}