html, body {
    overflow-x: hidden;
    width: 100%;
}

/*************header************************/
:root {

            --primary-color: #afba42;
            /* Logo Olive/Lime Green */
            --primary-hover: #9ca637;
            /* Slightly deeper green for button hover states */
            --secondary-color: #2d3134;
            /* Logo Slate Grey */
            --dark-color: #111315;
            --white-color: #ffffff;

            --font-primary: "Exo 2", sans-serif;

            --radius-xs: 6px;
            --radius-sm: 10px;
            --radius-md: 16px;
            --radius-lg: 24px;
            --radius-xl: 32px;

            --shadow-sm: 0 4px 12px rgba(0, 0, 0, 0.06);
            --shadow-md: 0 12px 32px rgba(0, 0, 0, 0.08);
            --shadow-lg: 0 24px 60px rgba(0, 0, 0, 0.12);

            --transition-fast: 0.2s ease;
            --transition-normal: 0.35s ease;
            --transition-slow: 0.5s ease;
        }

        [data-bs-theme="light"] {
            --body-bg: #f7f8fb;
            --body-color: #111827;

            --surface-color: #ffffff;
            --surface-secondary: #f1f5f9;
            --surface-tertiary: #e9edf3;

            --heading-color: #2d3134;

            --text-color: #4b5563;
            --text-muted: #6b7280;
            --border-color: rgba(15, 23, 42, 0.08);

            --header-bg: rgba(255, 255, 255, 0.85);
            --header-border: rgba(15, 23, 42, 0.08);

            --footer-bg: #2d3134;
            --footer-text: #e2e8f0;

            --input-bg: #ffffff;
            --input-border: rgba(15, 23, 42, 0.08);

            --glow-primary: rgba(175, 186, 66, 0.15);

        }

        [data-bs-theme="dark"] {
            --body-bg: #111315;
            /* Your clean charcoal base */
            --body-color: #f8fafc;

            --surface-color: #17191c;
            --surface-secondary: #1d2124;
            --surface-tertiary: #25292e;

            --heading-color: #ffffff;
            --text-color: #d1d5db;
            --text-muted: #94a3b8;

            --border-color: rgba(255, 255, 255, 0.08);

            --header-bg: #181a1d;
            --header-border: #23272b;

            --footer-bg: #0b0c0e;
            --footer-text: #cbd5e1;

            --input-bg: #17191c;
            --input-border: rgba(255, 255, 255, 0.08);

            --primary-color: #c2ce4a;
            --primary-hover: #afba42;
            --glow-primary: rgba(194, 206, 74, 0.22);
        }


        /***********button open*********************/
        .primary-button {
            font-family: var(--font-primary);
            color: white;
            cursor: pointer;
            font-size: 11px;
            line-height: 2;
            border-radius: 10px;
            font-weight: bold;
            text-transform: uppercase;
            /*letter-spacing: 0.1rem;*/
            border: 1px solid #ffffff14;
            padding: 1rem;
            background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 531.28 200'%3E%3Cdefs%3E%3Cstyle%3E .shape %7B fill: %23CCCC52; %7D %3C/style%3E%3C/defs%3E%3Cg id='Layer_2' data-name='Layer 2'%3E%3Cg id='Layer_1-2' data-name='Layer 1'%3E%3Cpolygon class='shape' points='415.81 200 0 200 115.47 0 531.28 0 415.81 200' /%3E%3C/g%3E%3C/g%3E%3C/svg%3E%0A");
            background-color: #1d2124;
            background-size: 200%;
            background-position: 200%;
            background-repeat: no-repeat;
            transition: 0.3s ease-in-out;
            transition-property: background-position, border, color;
            position: relative;
            z-index: 1;
            display: inline-block;
            text-decoration: none;
            outline: none;
        }

        .primary-button:hover {
            border: 1px solid #181a1d;
            color: var(--heading-color);
            background-position: 40%;
        }

        .primary-button:before {
            content: "";
            position: absolute;
            background-color: #ffffff;
            width: 0.2rem;
            height: 0.2rem;
            top: -1px;
            left: -1px;
            transition: background-color 0.15s ease-in-out;
        }

        .primary-button:after {
            content: "";
            position: absolute;
            background-color: #181a1d;
            width: 0.3rem;
            height: 0.3rem;
            bottom: -1px;
            right: -1px;
            transition: background-color 0.15s ease-in-out;
        }

        .primary-button:hover:before {
            background-color: #181a1d;
        }

        .primary-button:hover:after {
            background-color: #ffffff;
        }


        .button-borders {
            position: relative;
            width: fit-content;
            height: fit-content;
            display: inline-block;
        }

        .button-borders:before {
            content: "";
            position: absolute;
            width: calc(100% + 0.6em);
            height: 50%;
            left: -0.3em;
            top: -0.3em;
            border: 1px solid #ffffff;
            border-bottom: 0px;
            pointer-events: none;
        }

        .button-borders:after {
            content: "";
            position: absolute;
            width: calc(100% + 0.6em);
            height: 50%;
            left: -0.3em;
            bottom: -0.3em;
            border: 1px solid #ffffff;
            border-top: 0px;
            z-index: 0;
            pointer-events: none;
        }

        /***********button close*********************/

.bg-surface {
    background: var(--surface-color);
}
.sm-heading{
    color: var(--heading-color);
        margin-bottom: 1rem !important;
    font-size: clamp(18px, 1.4vw, 2.8vw);
    letter-spacing: 1px;
    font-weight: 600 !important;
}
.lm-heading{
    color: var(--heading-color);
            margin-bottom: 1rem !important;
    font-size: clamp(25px, 2.1vw, 2.8vw);
    letter-spacing: 1px;
    font-weight: 800 !important;
}

        body {
            background: var(--body-bg);
            color: var(--body-color);
            font-family: var(--font-primary);
            transition: background var(--transition-normal), color var(--transition-normal);
            font-size: clamp(12px, 1.2vw, 2vw); 
        }
        
        h1 {
            font-size: clamp(30px, 3.2vw, 4vw);
            font-weight: 700 !important;
            margin-bottom: 1rem !important;
        }
        h2,
        h3,
        h4,
        h5,
        h6 {
            font-size: clamp(22px, 2.5vw, 3vw);
            font-weight: 700 !important;
            margin-bottom: 1rem !important;
        }

        h1,
        h2,
        h3,
        h4,
        h5,
        h6 {
            color: var(--heading-color);
        }

        p {
            color: var(--text-color);
            font-size: clamp(12px, 1.1vw, 1.8vw);
            margin-bottom: 1rem !important;
        }

        a {
            text-decoration: none;
            transition: all var(--transition-fast);
            color: var(--body-color);
        }


        .topbar-divider {
            width: 1px;
            height: 24px;
            background: var(--text-color);
        }

        .topbar-wrapper {
            height: 68px;
            background: var(--header-bg);
            color: var(--body-color);
            border-bottom: 1px solid var(--header-border);
            overflow: hidden;
            transition: var(--transition-fast);
            display: flex;
            align-items: center;
        }

        .text-brand {
            color: var(--primary-color);
        }

        .dot {
            width: 4px;
            height: 4px;
            border-radius: 50%;
            background: var(--text-muted);
        }

        .theme-toggle {
            background: var(--surface-secondary);
            border: 1px solid var(--border-color);
            border-radius: 50px;
            padding: 6px 12px;
            cursor: pointer;
            display: flex;
            align-items: center;
            color: var(--text-color);
            transition: var(--transition-fast);
        }

        .theme-toggle:hover {
            border-color: var(--primary-color);
        }

        .sun-icon {
            display: none;
        }

        .moon-icon {
            display: block;
        }

        [data-bs-theme="dark"] .sun-icon {
            display: block;
        }

        [data-bs-theme="dark"] .moon-icon {
            display: none;
        }

        .social-icons a {
            color: var(--text-color);
            font-size: 1.1rem;
        }

        .social-icons a:hover {
            color: var(--primary-color);
        }


        [data-bs-theme="light"] .logo-dark {
            display: none;
        }

        [data-bs-theme="light"] .logo-light {
            display: block;
        }

        [data-bs-theme="dark"] .logo-dark {
            display: block;
        }

        [data-bs-theme="dark"] .logo-light {
            display: none;
        }

        .main-nav {
            background: var(--header-bg);
            box-shadow: var(--shadow-sm);
            z-index: 1000;
        }

        .nav-link {
            color: var(--body-color) !important;
            font-weight: 600;
            padding: 0.4rem 0.6rem !important;
        }

        .nav-link:hover {
            color: var(--primary-color) !important;
        }

        .mobile-sidebar {
            background: var(--header-bg);
            width: 300px;
        }

        .mobile-nav-list {
            list-style: none;
            margin: 0;
            padding: 0;
        }

        .mobile-nav-list a {
            color: var(--body-color);
            padding: 1rem 1.5rem;
            display: block;
            border-bottom: 1px solid var(--border-color);
            font-weight: 500;
            text-decoration: none;
        }

        .mobile-nav-list a:hover {
            color: var(--primary-color);
            background: var(--surface-secondary);
        }

        @media (min-width: 992px) {

            .navbar-nav .dropdown:hover>.dropdown-menu {
                display: block;
            }


            .navbar-nav .dropdown:hover>.nav-link i {
                transform: rotate(180deg);
                transition: var(--transition-fast);
                color: var(--primary-color) !important;

            }
        }

        .dropdown-menu {
            display: none;
            transition: opacity 0.3s ease;
        }

        .dropdown:hover>.dropdown-menu {
            display: block;
            opacity: 1;
        }

        .dropdown-item:hover {
            color: var(--primary-color) !important;
            padding-left: 20px;
        }
/*************header close*****************/

/*************footer open*****************/
 .sec-bg {
            background-image: var(--bg-mob-light) !important;
            background-size: cover !important;
            background-position: right center !important;
            background-repeat: no-repeat !important;
            min-height: 350px;
            align-content: center;
        }

        [data-bs-theme="dark"] .sec-bg {
            background-image: var(--bg-mob-dark) !important;
        }

        @media (min-width: 992px) {
            .sec-bg {
                background-image: var(--bg-desk-light) !important;
            }

            [data-bs-theme="dark"] .sec-bg {
                background-image: var(--bg-desk-dark) !important;
            }
        }
        /*********cta close************/
        
  .footer-section {
            background-color: var(--header-bg);
            color: var(--body-color);
            transition: background var(--transition-normal), color var(--transition-normal);
        }

        .footer-divider {
            width: 1px;

            background: var(--text-color);
        }

        .footer-section a {
            color: var(--text-color);
            transition: var(--transition-fast);
        }

        .footer-section a:hover {
            color: var(--primary-color);
        }

        [data-bs-theme="light"] .logo-dark {
            display: block;
        }

        [data-bs-theme="light"] .logo-light {
            display: none;
        }

        [data-bs-theme="dark"] .logo-dark {
            display: none;
        }

        [data-bs-theme="dark"] .logo-light {
            display: block;
        }


        @media (min-width: 992px) {
            .border-end-md {
                border-right: 1px solid var(--border-color);
            }
        }

        .cert-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 15px;
            max-width: 150px;
        }

        .cert-grid img {
            width: 100%;
            height: auto;
        }      
        
/*************footer close*****************/

/*************hero open*****************/

        .hero-section {
            position: relative;
            padding: 100px 0;
            overflow: hidden;
            background: var(--body-bg);

        }
        .hero-section {
            background-image: var(--bg-mob-light);
            background-size: cover;
            background-position: right;
            transition: background-image 0.5s ease;
        }

        [data-bs-theme="dark"] .hero-section {
            background-image: var(--bg-mob-dark);
        }

        @media (min-width: 992px) {
            .hero-section {
                background-image: var(--bg-desk-light);
            }

            [data-bs-theme="dark"] .hero-section {
                background-image: var(--bg-desk-dark);
            }
        }

        .badge-cert {
            color: var(--primary-color);
            font-weight: 600;
            letter-spacing: 1px;
            font-size: 0.8rem;
            text-transform: uppercase;
        }

        .cert-box {
            width: 80px;
            height: 80px;
            border: 1px solid var(--border-color);
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            border-radius: var(--radius-sm);
            font-size: 0.7rem;
            color: var(--text-muted);
        }

        .cert-box img {
            width: 30px;
            margin-bottom: 5px;
        }

        /* The curved border effect from UI 
.hero-visual::before {
    content: '';
    position: absolute;
    right: 0;
    top: -10%;
    width: 600px;
    height: 600px;
    border: 2px solid rgba(175, 186, 66, 0.2);
    border-radius: 50% 0 0 50%;
    pointer-events: none;
}*/

        
        [data-bs-theme="dark"] .btn-outline-dark {
            border-color: var(--border-color);
            color: var(--text-color);
        }
        
/*************hero close*****************/

/*************counter open*****************/
  .counter-section {
            position: relative;
            z-index: 10;
            margin-top: -110px;
        }

        .counter-box {
            background-color: var(--surface-color);
            border-color: var(--border-color) !important;
        }

        .counter-item {
            display: flex;
            flex-direction: column;
            justify-content: center;
            align-items: center;
            padding: 20px 0;
            text-align: center;
        }

        @media (min-width: 992px) {
            .counter-item:not(:last-child) {
                border-right: 1px solid var(--border-color);
            }
        }
        .counter-item h3 {
            margin: 5px 0;
            color: var(--heading-color);
        }
/*************counter close*****************/



/*************about open*****************/
    .year-badge {
            position: absolute;
            bottom: 20px;
            left: 20px;
            width: 140px;
            text-align: center;
            border-left: 4px solid var(--primary-color);
            background-color: var(--surface-color) !important;
        }

        .about-section {
            background-color: var(--body-bg);
        }

        [data-bs-theme="dark"] .year-badge {
            background-color: var(--surface-color) !important;
            color: var(--heading-color);
        }
        .img-dark-mode {
            display: none !important;
        }

        [data-bs-theme="dark"] .img-light-mode {
            display: none !important;
        }

        [data-bs-theme="dark"] .img-dark-mode {
            display: block !important;
        }
/*************about close*****************/

/*************category open*****************/
 #category-section {
            padding: 80px 0;
            background: var(--body-bg);
        }

        .cat-card {
            background: var(--surface-color);
            border: 1px solid var(--border-color);
            border-radius: var(--radius-md);
            padding: 25px;
            text-align: center;
            transition: var(--transition-normal);
        }

        .cat-card:hover {
            transform: translateY(-10px);
            box-shadow: var(--shadow-md);
        }

        .cat-card-img {
            width: 100%;
            height: 160px;
            object-fit: contain;
            margin-bottom: 20px;
        }

        .card-head a {
            color: var(--heading-color);
            text-decoration: none;
            font-weight: 600;
            font-size: 1.1rem;
        }

        .control-btn {
            background: var(--surface-secondary);
            border: 1px solid var(--border-color);
            color: var(--text-color);
            width: 50px;
            height: 50px;
            border-radius: 50%;
            cursor: pointer;
            transition: var(--transition-fast);
        }

        .control-btn:hover {
            background: var(--primary-color);
            color: white;
        }

        @media (max-width: 767px) {
            .swiper-slide {
                width: 50%;
            }
        }

        @media (min-width: 768px) {
            .swiper-slide {
                width: 33.33%;
            }
        }

        @media (min-width: 1024px) {
            .swiper-slide {
                width: 25%;
            }
        }

        @media (min-width: 1600px) {
            .swiper-slide {
                width: 16.66%;
            }
        }
/*************category close*****************/

/*************choose-us open*****************/
        .feature-card {
            background: rgba(255, 255, 255, 0.03);
            transition: var(--transition-normal);
        }

        .feature-card:hover {
            background: rgba(175, 186, 66, 0.1);
            border-color: var(--primary-color) !important;
            transform: translateY(-5px);
        }

        .why-choose-us {
            background-size: cover;
            background-position: center;
            background-attachment: fixed;
        }
/*************choose-us close*****************/


/*************ticker open*****************/
.ticker-wrapper {
            display: flex;
            width: 100%;
            overflow: hidden;
        }

        .ticker-track {
            display: flex;
            white-space: nowrap;
            animation: marquee 200s linear infinite;
        }

        .move-left .ticker-track {
            animation-direction: reverse;
        }

        @keyframes marquee {
            from {
                transform: translateX(0);
            }

            to {
                transform: translateX(-50%);
            }
        }

        .ticker-item {
            flex: 0 0 auto;
            background: var(--surface-color);
            padding: 15px 30px;
            border-radius: var(--radius-sm);
            box-shadow: var(--shadow-sm);
            font-family: var(--font-primary);
            font-weight: 600;
            color: var(--heading-color);
            font-size: clamp(14px, 1.2vw, 18px);
            display: flex;
            align-items: center;
            white-space: nowrap;
            margin: 0 15px;
            transition: var(--transition-normal);
            border: 1px solid var(--border-color);
        }

        .ticker-item:hover {
            transform: translateY(-5px);
            box-shadow: var(--shadow-md);
            color: var(--primary-color);
            border-color: var(--primary-color);
        }

        .ticker-svg i {
            color: var(--primary-color);
            font-size: 1.2rem;
        }
/*************ticker close*****************/



/*************map open*****************/
        .leaflet-container {
            background: #dddddd00 !important;
        }
        .leaflet-control-attribution {
            display: none !important;
        }
        .map-tooltip {
            background: var(--surface-color) !important;
            color: var(--heading-color) !important;
            border: 1px solid var(--primary-color) !important;
            border-radius: var(--radius-xs) !important;
            font-weight: 600 !important;
        }

        .leaflet-interactive:hover {
            fill-opacity: 0.7 !important;
            cursor: pointer;
        }        .leaflet-container {
            background: #dddddd00 !important;
        }
        .leaflet-control-attribution {
            display: none !important;
        }
        .map-tooltip {
            background: var(--surface-color) !important;
            color: var(--heading-color) !important;
            border: 1px solid var(--primary-color) !important;
            border-radius: var(--radius-xs) !important;
            font-weight: 600 !important;
        }

        .leaflet-interactive:hover {
            fill-opacity: 0.7 !important;
            cursor: pointer;
        }
/*************map close*****************/


/*************home blog open*****************/
.blog-card-large {
    min-height: 400px;
}

.blog-card-small {
    background: var(--surface-color);
    transition: var(--transition-normal);
    border-color: var(--border-color);
}

.blog-card-small:hover {
    border-color: var(--primary-color) !important;
}

.card-img-overlay {
    background: linear-gradient(transparent 50%, rgba(0,0,0,0.8));
}
/*************home blogclose*****************/







/*************about US page*****************/







/*************vision open*****************/
.vm-card {
    transition: var(--transition-normal);
    border: 1px solid var(--border-color) !important;
}

.vm-card:nth-child(odd) {
    background-color: var(--primary-color) !important;
}

.vm-card:nth-child(odd) .sm-heading,
.vm-card:nth-child(odd) .text-muted {
    color: #181a1d !important;   
}

.vm-card:nth-child(even) {
    background-color: var(--surface-color) !important;
}

.vm-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-md); }
/*************vision close*****************/


























/****************blog*******************/
/* ==========================================================================
   FIXED: blogs.php ASYMMETRICAL IMAGE SCALE BUG
   The object-fit rule is critical here to crop the image symmetrically 
   within its container rather than stretching its source proportions.
   ========================================================================== */

/* 1. Reset Global image default for clean layout engine baseline */
.blogs-page img {
    width: 100%;
    height: 100%;
    object-fit: cover; /* Forces source file to aspect-match rather than stretch */
    object-position: center;
    transition: transform var(--transition-normal);
}

/* 2. Blog Archive Header Graphics Structure */
.blog-header-graphic {
    width: 280px; height: 280px;
    border: 4px solid var(--border-color);
    background: var(--surface-color);
}

/* 3. Archive Grid Components Theme Adaptation */
.blog-card-large {
    transition: var(--transition-normal);
}
.blog-stream-item {
    transition: var(--transition-normal);
}
.blog-stream-item:hover,
.blog-card-large:hover {
    border-color: var(--primary-color) !important;
    box-shadow: var(--shadow-md);
}

/* 4. Large Featured Card Image scaling bounds */
.blog-card-large .job-hero-wrapper {
    overflow: hidden;
    background: var(--surface-secondary);
}

/* 5. Stream List Image container limits on mobile */
.stream-img-wrapper {
    width: 100%;
    height: 180px;
}

/* Standard Tablet+ & Desktop viewport width scale logic */
@media (min-width: 768px) {
    .stream-img-wrapper {
        width: 220px !important;
        height: 140px !important;
        flex-shrink: 0; /* Prevents long text from crushing the left container */
    }
}

/* Premium zoom effect on card hover states */
.blog-card-large:hover .job-hero-wrapper img,
.blog-stream-item:hover .stream-img-wrapper img {
    transform: scale(1.05);
}

/* ==========================================================================
   STICKY SIDEBAR WIDGET INTERACTIVE SPECIFICS
   ========================================================================== */
.custom-input {
    background-color: var(--input-bg) !important;
    border: 1px solid var(--input-border) !important;
    color: var(--body-color) !important;
    transition: var(--transition-fast);
}
.custom-input:focus {
    border-color: var(--primary-color) !important;
    box-shadow: 0 0 0 4px var(--glow-primary) !important;
}

.sidebar-menu-item {
    border-color: var(--border-color) !important;
    color: var(--text-muted) !important;
    transition: var(--transition-fast);
}
.sidebar-menu-item:hover {
    color: var(--primary-color) !important;
    padding-left: 6px;
}

.form-accent-dash {
    width: 4px;
    height: 24px;
    background: var(--primary-color);
    border-radius: 4px;
    display: inline-block;
}

/* CTA Card Box override context */
.widget-cta-box {
    background: var(--surface-color);
    border-color: var(--border-color) !important;
}

/* ==========================================================================
   PAGINATION THEME MAP
   ========================================================================== */
.pagination .page-link {
    background: var(--surface-color);
    border-color: var(--border-color);
    color: var(--text-color);
    padding: 10px 16px;
    transition: var(--transition-fast);
}
.pagination .page-item.active .page-link {
    background: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: var(--dark-color) !important;
}
.pagination .page-link:hover {
    border-color: var(--primary-color);
    background: var(--surface-secondary);
}

/* Utility constraints limit line heights overflows */
.line-clamp-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
/* ==========================================================================
   SINGLE BLOG ENGINE VIEW ARCHITECTURE (`single-blog.php`)
   ========================================================================== */
article {
    background: var(--surface-color);
    border-color: var(--border-color) !important;
}

.detail-hero-img-box {
    background: var(--surface-secondary);
    border: 1px solid var(--border-color);
}

/* Safe Formatting rules for inline layout output payloads ($blog['content']) */
.blog-rendered-markup {
    color: var(--text-color) !important;
}

.blog-rendered-markup h3, 
.blog-rendered-markup h4 {
    color: var(--heading-color);
    font-weight: 700;
    margin-top: 2rem;
    margin-bottom: 1rem;
}

.blog-rendered-markup p {
    color: var(--text-color);
    margin-bottom: 1.25rem;
}

.blog-rendered-markup ul, 
.blog-rendered-markup ol {
    padding-left: 1.5rem;
    margin-bottom: 1.5rem;
}

.blog-rendered-markup li {
    margin-bottom: 0.5rem;
    color: var(--text-color);
}

.blog-rendered-markup strong {
    color: var(--heading-color);
}

.blog-rendered-markup a {
    color: var(--primary-color);
    font-weight: 600;
    text-decoration: none;
    transition: var(--transition-fast);
}

.blog-rendered-markup a:hover {
    color: var(--primary-hover);
    text-decoration: underline;
}

/* Pull-quote Container Frame specs */
.quote-signature-box {
    background: var(--surface-secondary);
}

/* ==========================================================================
   STICKY SIDEBAR WIDGET INTERACTIVE SPECIFICS
   ========================================================================== */
.sidebar-menu-item {
    border-color: var(--border-color) !important;
    color: var(--text-color) !important;
    transition: var(--transition-fast);
}

.sidebar-menu-item:hover {
    color: var(--primary-color) !important;
    padding-left: 6px;
}

.toc-item {
    border-left: 2px solid var(--border-color);
    padding-left: 12px;
    color: var(--text-muted) !important;
    transition: var(--transition-fast);
}

.toc-item:hover {
    color: var(--primary-color) !important;
    border-left-color: var(--primary-color);
}

.widget-cta-box {
    background: var(--surface-color);
    border-color: var(--border-color) !important;
}

/* Custom Uniform Search & Input Form Elements overrides */
.custom-input {
    background-color: var(--input-bg) !important;
    border: 1px solid var(--input-border) !important;
    color: var(--body-color) !important;
    transition: var(--transition-fast);
}

.custom-input:focus {
    border-color: var(--primary-color) !important;
    box-shadow: 0 0 0 4px var(--glow-primary) !important;
}

.btn-brand {
    background-color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: var(--dark-color) !important;
    font-weight: 600;
}

.btn-brand:hover {
    background-color: var(--primary-hover) !important;
    border-color: var(--primary-hover) !important;
    color: var(--dark-color) !important;
}

.btn-outline-brand {
    border-color: var(--primary-color) !important;
    color: var(--primary-color) !important;
    transition: var(--transition-fast);
}

.btn-outline-brand:hover {
    background-color: var(--primary-color) !important;
    color: var(--dark-color) !important;
}

/* ==========================================================================
   PAGINATION THEME MAP
   ========================================================================== */
.pagination .page-link {
    background: var(--surface-color);
    border-color: var(--border-color);
    color: var(--text-color);
    padding: 10px 16px;
    transition: var(--transition-fast);
}

.pagination .page-item.active .page-link {
    background: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: var(--dark-color) !important;
}

.pagination .page-link:hover {
    border-color: var(--primary-color);
    background: var(--surface-secondary);
}

/* Utility constraints limit line heights overflows */
.line-clamp-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
