/* ================================================================
   ACM PROFESSIONAL REDESIGN — custom.css
   Brand Colors Preserved: #1b3566 (Primary), #81CE97 (Accent)
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cairo:wght@300;400;500;600;700;800;900&display=swap');

/* ────────────────────────────────────────────────────────────────
   CSS VARIABLES (Design Tokens)
   ──────────────────────────────────────────────────────────────── */
:root {
    --primary: #1b3566;
    --primary-light: #2b54a0;
    --primary-dark: #132748;
    --primary-gradient: linear-gradient(135deg, #1b3566 0%, #2b54a0 60%, #3668c0 100%);
    --accent: #81CE97;
    --accent-light: #a8e0b8;
    --text-dark: #1a202c;
    --text-body: #4a5568;
    --text-muted: #a0aec0;
    --bg-body: #f8fafc;
    --bg-section: #ffffff;
    --bg-section-alt: #f1f5f9;
    --glass-bg: rgba(255, 255, 255, 0.75);
    --glass-bg-dark: rgba(27, 53, 102, 0.85);
    --glass-border: rgba(255, 255, 255, 0.4);
    --border-light: rgba(0, 0, 0, 0.05);
    --shadow-premium: 0 20px 40px rgba(0, 0, 0, 0.06), 0 1px 3px rgba(0, 0, 0, 0.04);
    --radius-sm: 8px;
    --radius-md: 14px;
    --radius-lg: 20px;
    --radius-xl: 32px;
    --transition-fast: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    --transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    --font-main: 'Cairo', 'Segoe UI', Tahoma, sans-serif;
}

/* ────────────────────────────────────────────────────────────────
   GLOBAL RESETS & TYPOGRAPHY
   ──────────────────────────────────────────────────────────────── */
html, body {
    font-family: var(--font-main) !important;
    background-color: var(--bg-body) !important;
    color: var(--text-body) !important;
    line-height: 1.7 !important;
    font-size: 15px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    scroll-behavior: smooth;
}

h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-main) !important;
    font-weight: 800 !important;
    color: var(--text-dark) !important;
    letter-spacing: -0.01em;
    line-height: 1.3 !important;
}

p {
    color: var(--text-body) !important;
    line-height: 1.8 !important;
    font-size: 15px;
}

a {
    color: var(--primary);
    transition: var(--transition-fast);
}

a:hover, a:focus {
    color: var(--primary-light) !important;
    text-decoration: none !important;
}

::selection {
    background: var(--primary) !important;
    color: #fff !important;
}

/* ────────────────────────────────────────────────────────────────
   SCROLL-TO-TOP BUTTON
   ──────────────────────────────────────────────────────────────── */
/* Floating Glass Badges */
.badge-glass {
    position: absolute !important;
    top: 15px !important;
    right: 15px !important;
    background: var(--glass-bg-dark) !important;
    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
    color: #fff !important;
    padding: 6px 14px !important;
    border-radius: 50px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    z-index: 10 !important;
    border: 1px solid rgba(255,255,255,0.15) !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1) !important;
    pointer-events: none !important;
}

/* Section Spacing Refinement */
.area-padding {
    padding: 40px 0 !important; /* Reduced from 80px */
}

/* Slider Navigation Arrows - Migrated from main.inc.php */
.intro-carousel.owl-carousel.owl-theme .owl-controls .owl-nav div.owl-prev,
.intro-carousel.owl-carousel.owl-theme .owl-controls .owl-nav div.owl-next {
    position: absolute !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    width: 60px !important;
    height: 60px !important;
    line-height: 56px !important;
    border: 1px solid rgba(255,255,255,0.2) !important;
    border-radius: 50% !important;
    backdrop-filter: blur(15px) !important;
    background: rgba(255,255,255,0.1) !important;
    transition: var(--transition) !important;
    color: #fff !important;
    font-size: 24px !important;
    z-index: 100;
}

.intro-carousel.owl-carousel.owl-theme .owl-controls .owl-nav div.owl-prev { left: 30px !important; }
.intro-carousel.owl-carousel.owl-theme .owl-controls .owl-nav div.owl-next { right: 30px !important; }

.intro-carousel.owl-carousel.owl-theme .owl-controls .owl-nav div:hover {
    background: var(--primary) !important;
    border-color: var(--primary) !important;
    box-shadow: 0 0 30px rgba(27, 53, 102, 0.5) !important;
}

#scrollUp {
    background: var(--primary-gradient) !important;
    border-radius: 50% !important;
    width: 44px !important;
    height: 44px !important;
    line-height: 44px !important;
    font-size: 18px !important;
    opacity: 1 !important;
    box-shadow: var(--shadow-lg) !important;
    transition: var(--transition) !important;
}
#scrollUp:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-xl) !important;
}

/* ────────────────────────────────────────────────────────────────
   TOP BAR
   ──────────────────────────────────────────────────────────────── */
.topbar-area {
    background: var(--primary-gradient) !important;
    border-bottom: none !important;
    padding: 2px 0 !important;
}

.topbar-left ul li a {
    font-family: var(--font-main) !important;
    font-weight: 500 !important;
    font-size: 13px !important;
    letter-spacing: 0.3px;
    opacity: 0.9;
    color: #fff !important;
    transition: var(--transition-fast) !important;
}
.topbar-left ul li a:hover {
    opacity: 1;
    color: var(--accent) !important;
}

.top-social ul li a {
    border-radius: 50% !important;
    width: 30px !important;
    height: 30px !important;
    line-height: 30px !important;
    font-size: 13px !important;
    transition: var(--transition) !important;
    opacity: 0.8;
}
.top-social ul li a:hover {
    background: rgba(255,255,255,0.2) !important;
    color: #fff !important;
    opacity: 1;
    transform: translateY(-2px);
}

/* Custom X (Twitter) Icon Workaround */
.fa-x-twitter::before {
    content: "" !important;
    display: inline-block !important;
    width: 1em !important;
    height: 1em !important;
    background-color: currentColor !important;
    mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3E%3Cpath d='M389.2 48h70.6L305.6 224.2 487 464H345L233.7 318.6 106.5 464H35.8L200.7 275.5 26.8 48H172.4L272.9 180.9 389.2 48zM364.4 421.8h39.1L151.1 88h-42L364.4 421.8z'/%3E%3C/svg%3E") no-repeat center !important;
    -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 512 512'%3E%3Cpath d='M389.2 48h70.6L305.6 224.2 487 464H345L233.7 318.6 106.5 464H35.8L200.7 275.5 26.8 48H172.4L272.9 180.9 389.2 48zM364.4 421.8h39.1L151.1 88h-42L364.4 421.8z'/%3E%3C/svg%3E") no-repeat center !important;
    vertical-align: middle !important;
}

/* Header Search Form — Modern Pill Design */
.header-search-form {
    margin-top: 5px;
}

.search-wrapper {
    display: flex;
    background: rgba(255, 255, 255, 0.1);
    border: 1.5px solid rgba(255, 255, 255, 0.2);
    border-radius: 50px;
    overflow: hidden;
    padding: 2px;
    transition: var(--transition);
}

.search-wrapper:focus-within {
    background: rgba(255, 255, 255, 0.15);
    border-color: rgba(129, 206, 151, 0.6);
    box-shadow: 0 0 15px rgba(129, 206, 151, 0.1);
}

.search-wrapper input {
    flex: 1;
    background: transparent !important;
    border: none !important;
    padding: 0 15px !important;
    color: #fff !important;
    font-size: 13px !important;
    height: 38px !important;
    outline: none !important;
}

.search-wrapper input::placeholder {
    color: rgba(255, 255, 255, 0.7);
}

.search-wrapper .btn2.add-btn {
    padding: 0 20px !important;
    height: 38px !important;
    border-radius: 40px !important;
    font-size: 12px !important;
    box-shadow: none !important;
    margin: 0 !important;
}

/* Auth Pages (Login/Register) Modern Styling */
.form-signin {
    background: #ffffff;
    padding: 40px;
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    border: 1px solid var(--border-light);
    transition: var(--transition);
    text-align: initial;
}

.form-signin:hover {
    box-shadow: var(--shadow-glow), var(--shadow-xl);
}

.form-signin .input-group-addon {
    background: var(--bg-section-alt) !important;
    border: 2px solid var(--border-light) !important;
    border-left: none !important;
    color: var(--primary) !important;
    border-radius: 0 var(--radius-md) var(--radius-md) 0 !important;
}

.form-signin .form-control {
    border-right: none !important;
    border-radius: var(--radius-md) 0 0 var(--radius-md) !important;
}

.form-signin .btn {
    width: 100%;
    margin-top: 20px;
    padding: 14px !important;
    font-size: 15px !important;
    font-weight: 700 !important;
}

.main-logo {
    height: 70px !important;
    transition: var(--transition);
}

.main-logo:hover {
    transform: scale(1.05);
}

/* Premium Card System — Unified Height & Glassmorphism */
/* Premium Card System — Unified Height & Glassmorphism */
.premium-card {
    background: var(--glass-bg) !important;
    backdrop-filter: blur(10px) !important;
    -webkit-backdrop-filter: blur(10px) !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-premium) !important;
    border: 1px solid var(--glass-border) !important;
    overflow: hidden !important;
    transition: var(--transition) !important;
    display: flex !important;
    flex-direction: column !important;
    height: 100% !important;
    margin-bottom: 30px !important;
}

.premium-card:hover {
    transform: translateY(-8px) scale(1.02) !important;
    background: #fff !important;
    box-shadow: var(--shadow-xl) !important;
    border-color: var(--accent) !important;
}

.card-image-wrapper {
    position: relative !important;
    width: 100% !important;
    padding-top: 62% !important; /* Slightly taller for better focus */
    overflow: hidden !important;
}

.card-image-wrapper img {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    transition: transform 1s ease !important;
}

.premium-card .blog-content,
.premium-card .service-content {
    padding: 25px !important;
    display: flex !important;
    flex-direction: column !important;
    flex: 1 !important;
    background: transparent !important;
}

.premium-card .card-title {
    font-size: 19px !important;
    font-weight: 800 !important;
    color: var(--primary) !important;
    margin-bottom: 12px !important;
    line-height: 1.4 !important;
    min-height: 52px !important;
    max-height: 52px !important;
    overflow: hidden !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
}

.premium-card .card-text {
    font-size: 14.5px !important;
    color: var(--text-body) !important;
    line-height: 1.7 !important;
    margin-bottom: 25px !important;
    flex-grow: 1 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.premium-card .read-more {
    font-weight: 700 !important;
    color: #fff !important;
    background: var(--primary) !important;
    padding: 10px 24px !important;
    border-radius: 50px !important;
    display: inline-flex !important;
    align-self: flex-start !important;
    align-items: center !important;
    gap: 10px !important;
    font-size: 13px !important;
    box-shadow: 0 4px 12px rgba(27, 53, 102, 0.2) !important;
    transition: var(--transition-fast) !important;
    margin-top: auto !important;
}

.premium-card .read-more:hover {
    background: var(--accent) !important;
    color: var(--primary) !important;
    transform: translateX(-5px) !important; /* RTL slide */
}

.premium-card .read-more:hover {
    color: var(--primary) !important;
    letter-spacing: 0.5px !important;
}

/* Bootstrap 3 Helper */

.blog-grid > [class*="col-"],
.all-services > [class*="col-"] {
    display: flex !important;
}
.search-wrapper {
    display: flex !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border: 1.5px solid rgba(255, 255, 255, 0.3) !important;
    border-radius: 50px !important;
    overflow: hidden !important;
    padding: 2px !important;
    transition: var(--transition) !important;
}

.search-wrapper:focus-within {
    background: rgba(255, 255, 255, 0.15);
    border-color: rgba(129, 206, 151, 0.6); /* Emerald accent on focus */
    box-shadow: 0 0 15px rgba(129, 206, 151, 0.1);
}

.search-wrapper input {
    flex: 1;
    background: transparent !important;
    border: none !important;
    padding: 0 15px !important;
    color: #fff !important;
    font-size: 13px !important;
    height: 38px !important;
    outline: none !important;
}

.premium-card .service-icon {
    position: absolute !important;
    top: 20px !important;
    right: 20px !important;
    width: 48px !important;
    height: 48px !important;
    background: var(--primary-gradient) !important;
    border-radius: 12px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: #fff !important;
    font-size: 20px !important;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2) !important;
    z-index: 10 !important;
    transition: var(--transition) !important;
}

.premium-card:hover .service-icon {
    transform: scale(1.1) rotate(-5deg) !important;
    background: var(--accent-gradient) !important;
}

/* ────────────────────────────────────────────────────────────────
   HEADER / NAVIGATION
   ──────────────────────────────────────────────────────────────── */
.header-area, header.header-five {
    background: var(--glass-bg) !important;
    backdrop-filter: blur(20px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
    border-bottom: 1px solid rgba(0,0,0,0.04) !important;
    box-shadow: 0 1px 3px rgba(0,0,0,0.04) !important;
    position: relative;
    z-index: 9999 !important; /* Extremely high to stay above sliders */
}

.header-area.stick {
    box-shadow: var(--shadow-md) !important;
    background: rgba(255,255,255,0.95) !important;
    backdrop-filter: blur(20px) saturate(180%) !important;
}

.logo a {
    transition: var(--transition) !important;
}
.logo a:hover {
    opacity: 0.85;
}

.main-menu ul.navbar-nav > li > a {
    font-family: var(--font-main) !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    color: var(--text-dark) !important;
    letter-spacing: 0.3px;
    position: relative;
    transition: var(--transition) !important;
}

.main-menu ul.navbar-nav > li > a::after {
    content: '';
    position: absolute;
    bottom: 25px;
    right: 0;
    width: 0;
    height: 3px;
    background: var(--primary-gradient);
    border-radius: 2px;
    transition: var(--transition) !important;
}

.main-menu ul.navbar-nav > li:hover > a::after,
.main-menu ul.navbar-nav > li.active > a::after {
    width: 100%;
}

.main-menu ul.navbar-nav li:hover > a,
.main-menu ul.navbar-nav li.active > a {
    color: var(--primary) !important;
}

/* Sub Menu / Dropdown */
.main-menu ul.nav li ul.sub-menu {
    border: none !important;
    border-top: 3px solid var(--primary) !important;
    border-radius: 0 0 var(--radius-md) var(--radius-md) !important;
    box-shadow: var(--shadow-xl) !important;
    background: #fff !important;
    padding: 8px 0 !important;
    min-width: 240px !important;
    animation: dropdownFade 0.3s ease;
}

@keyframes dropdownFade {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

.main-menu ul.nav li ul.sub-menu li {
    border-bottom: none !important;
}

.main-menu ul.nav li ul.sub-menu li a {
    font-family: var(--font-main) !important;
    font-weight: 500 !important;
    font-size: 13px !important;
    padding: 10px 20px !important;
    color: var(--text-body) !important;
    transition: var(--transition-fast) !important;
    border-bottom: 1px solid var(--border-light) !important;
}

.main-menu ul.nav li ul.sub-menu li:last-child a {
    border-bottom: none !important;
}

.main-menu ul.nav li:hover ul.sub-menu li a:hover,
.main-menu ul.nav li ul.sub-menu li a:hover {
    background: var(--bg-section-alt) !important;
    color: var(--primary) !important;
    padding-right: 25px !important;
}

/* ────────────────────────────────────────────────────────────────
   HERO / SLIDER
   ──────────────────────────────────────────────────────────────── */
.intro-area, .intro-5 {
    position: relative;
}

.slider-images {
    position: relative !important;
    overflow: hidden;
}

.slider-images::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(
        to bottom,
        rgba(0,0,0,0.2) 0%,
        rgba(0,0,0,0.6) 100%
    ) !important;
    pointer-events: none;
    z-index: 1;
}

.intro-content {
    background: #000; /* Prevent white flash */
    min-height: 650px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
}

.slide-layer {
    background: rgba(255, 255, 255, 0.04);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,0.1);
    padding: 50px 40px;
    border-radius: var(--radius-xl);
    max-width: 800px;
    margin: 0 auto;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
}

.slider-images img {
    transition: transform 8s ease !important;
}

.slider-overlay {
    position: absolute !important;
    inset: 0 !important;
    background: rgba(0, 0, 0, 0.45) !important;
    z-index: 2 !important;
}

.slider-content {
    z-index: 10 !important;
    position: relative !important;
}

.title2, .layer-1 h1 {
    font-family: var(--font-main) !important;
    font-weight: 900 !important;
    font-size: 48px !important;
    line-height: 1.2 !important;
    text-shadow: 0 2px 20px rgba(0,0,0,0.4) !important;
    letter-spacing: -0.5px;
}

.layer-2 p {
    font-family: var(--font-main) !important;
    font-size: 18px !important;
    font-weight: 500 !important;
    text-shadow: 0 1px 10px rgba(0,0,0,0.5) !important;
    line-height: 1.7 !important;
    opacity: 0.95;
}

.ready-btn, .ready-btn.left-btn {
    background: var(--primary-gradient) !important;
    border: none !important;
    border-radius: 50px !important;
    padding: 16px 42px !important;
    font-family: var(--font-main) !important;
    font-weight: 700 !important;
    font-size: 16px !important;
    letter-spacing: 0.5px;
    box-shadow: 0 10px 30px rgba(27, 53, 102, 0.35) !important;
    transition: var(--transition) !important;
    color: #fff !important;
    backdrop-filter: blur(5px);
}

.ready-btn:hover, .ready-btn.left-btn:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 8px 30px rgba(27, 53, 102, 0.5) !important;
    background: var(--primary-gradient) !important;
    color: #fff !important;
    border: none !important;
}

/* Slider Navigation Arrows */
.intro-carousel.owl-carousel.owl-theme .owl-controls .owl-nav {
    position: absolute;
    width: 100%;
    top: 55%; /* Slightly below center to look visually balanced with header */
    transform: translateY(-50%);
    z-index: 100;
    pointer-events: none; /* Allow clicking the slider content */
}

.intro-carousel.owl-carousel.owl-theme .owl-controls .owl-nav div.owl-prev,
.intro-carousel.owl-carousel.owl-theme .owl-controls .owl-nav div.owl-next {
    position: absolute !important;
    pointer-events: auto !important;
    width: 50px !important;
    height: 50px !important;
    line-height: 46px !important;
    text-align: center !important;
    border: 2px solid rgba(255,255,255,0.4) !important;
    border-radius: 50% !important;
    backdrop-filter: blur(10px) !important;
    background: rgba(255,255,255,0.1) !important;
    color: #fff !important;
    font-size: 20px !important;
    transition: var(--transition) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* Position them based on LTR/RTL */
.intro-carousel.owl-carousel.owl-theme .owl-controls .owl-nav div.owl-prev {
    left: 40px !important;
}
.intro-carousel.owl-carousel.owl-theme .owl-controls .owl-nav div.owl-next {
    right: 40px !important;
}

[dir="rtl"] .intro-carousel.owl-carousel.owl-theme .owl-controls .owl-nav div.owl-prev {
    left: auto !important;
    right: 40px !important;
}
[dir="rtl"] .intro-carousel.owl-carousel.owl-theme .owl-controls .owl-nav div.owl-next {
    right: auto !important;
    left: 40px !important;
}

.intro-carousel.owl-carousel.owl-theme:hover .owl-controls .owl-nav div.owl-next:hover,
.intro-carousel.owl-carousel.owl-theme:hover .owl-controls .owl-nav div.owl-prev:hover {
    background: var(--primary) !important;
    border-color: var(--primary) !important;
    box-shadow: 0 0 20px rgba(0,0,0,0.3) !important;
}

/* Large Display Centering Fix */
@media (min-width: 992px) {
    .intro-content {
        position: relative !important;
        display: block !important;
        height: 850px !important;
        overflow: hidden !important;
    }

    .slider-content {
        position: absolute !important;
        top: 55% !important; /* Balanced visual center */
        left: 50% !important;
        transform: translate(-50%, -50%) !important;
        width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
        z-index: 20 !important;
    }
}

/* ────────────────────────────────────────────────────────────────
   SECTION HEADINGS
   ──────────────────────────────────────────────────────────────── */
.center-head {
    padding-bottom: 50px !important;
    position: relative;
}

.center-head h3 {
    font-family: var(--font-main) !important;
    font-weight: 800 !important;
    font-size: 32px !important;
    color: var(--text-dark) !important;
    line-height: 1.3 !important;
    margin-bottom: 5px !important;
}

.center-head::after {
    background: var(--primary-gradient) !important;
    height: 4px !important;
    width: 60px !important;
    border-radius: 2px !important;
    bottom: 30px !important;
}

.left-headline h3, .left-head h4 {
    font-family: var(--font-main) !important;
    color: var(--text-dark) !important;
}

/* ────────────────────────────────────────────────────────────────
   SERVICES CARDS (Home + Services Page)
   ──────────────────────────────────────────────────────────────── */
.single-service {
    background: #fff !important;
    border: 1px solid var(--border-light) !important;
    border-radius: var(--radius-lg) !important;
    padding: 0 !important;
    overflow: hidden !important;
    box-shadow: var(--shadow-sm) !important;
    transition: var(--transition) !important;
    margin-top: 30px;
}

.single-service:hover {
    border-color: transparent !important;
    background: #fff !important;
    box-shadow: var(--shadow-xl), var(--shadow-glow) !important;
    transform: translateY(-8px) !important;
}

.single-service .service-images {
    margin-bottom: 0 !important;
    overflow: hidden;
}

.single-service .service-images img {
    width: 100% !important;
    height: 220px !important;
    object-fit: cover;
    transition: var(--transition-slow) !important;
}

.single-service:hover .service-images img {
    transform: scale(1.08) !important;
}

.single-service .service-content,
.services-5 .service-content {
    padding: 24px 20px 20px !important;
}

.services-5 .service-icon {
    width: 52px !important;
    height: 52px !important;
    line-height: 50px !important;
    border-radius: var(--radius-sm) !important;
    background: var(--primary-gradient) !important;
    box-shadow: 0 4px 12px rgba(27, 53, 102, 0.25);
}

.single-service h4 a {
    font-family: var(--font-main) !important;
    color: var(--text-dark) !important;
    font-weight: 700 !important;
    transition: var(--transition-fast) !important;
}
.single-service h4 a:hover {
    color: var(--primary) !important;
}

.single-service:hover .service-text h4 a,
.single-service:hover .service-text p {
    color: inherit !important;
}

/* ────────────────────────────────────────────────────────────────
   BLOG / ARTICLE CARDS
   ──────────────────────────────────────────────────────────────── */
.single-blog {
    background: #fff !important;
    border-radius: var(--radius-lg) !important;
    overflow: hidden !important;
    box-shadow: var(--shadow-sm) !important;
    border: 1px solid var(--border-light) !important;
    transition: var(--transition) !important;
    margin-top: 30px;
}

.single-blog:hover {
    box-shadow: var(--shadow-xl), var(--shadow-glow) !important;
    transform: translateY(-8px) !important;
    border-color: transparent !important;
}

.blog-image {
    overflow: hidden !important;
}

.blog-image img, .single-blog .blog-image img {
    transition: var(--transition-slow) !important;
    object-fit: cover;
}

.single-blog:hover .blog-image img {
    transform: scale(1.08) !important;
}

.blog-content {
    padding: 20px 24px 24px !important;
    background: #fff !important;
    border-radius: 0 0 var(--radius-lg) var(--radius-lg) !important;
}

.blog-content a h4 {
    font-family: var(--font-main) !important;
    font-size: 17px !important;
    font-weight: 700 !important;
    color: var(--text-dark) !important;
    line-height: 1.5 !important;
    transition: var(--transition-fast) !important;
}

.blog-content a h4:hover {
    color: var(--primary) !important;
}

.blog-meta {
    border-bottom: 1px solid var(--border-light) !important;
    padding: 8px 0 !important;
    margin-bottom: 12px;
}

.blog-4 .blog-meta {
    border-radius: var(--radius-sm) !important;
    background: var(--primary-gradient) !important;
}

.read-more {
    color: var(--primary) !important;
    font-weight: 700 !important;
    border-top: 1px solid var(--border-light) !important;
    padding-top: 12px !important;
    margin-top: 10px;
    display: inline-block !important;
    transition: var(--transition-fast) !important;
}
.read-more:hover {
    color: var(--primary-light) !important;
    padding-right: 8px !important;
}

/* ────────────────────────────────────────────────────────────────
   BREADCRUMB / PAGE HEADER (Internal Pages)
   ──────────────────────────────────────────────────────────────── */
.page-area {
    background: linear-gradient(135deg, #0a192f 0%, #1b3566 40%, #2b54a0 80%, #1b3566 100%) !important;
    padding: 70px 0 60px !important;
    position: relative;
    overflow: hidden;
}

/* Geometric decorative elements */
.page-area::before {
    content: '';
    position: absolute;
    top: -80px;
    left: -60px;
    width: 300px;
    height: 300px;
    border: 2px solid rgba(255,255,255,0.06);
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

.page-area::after {
    content: '';
    position: absolute;
    bottom: -120px;
    right: -80px;
    width: 400px;
    height: 400px;
    border: 2px solid rgba(255,255,255,0.04);
    border-radius: 50%;
    pointer-events: none;
    z-index: 0;
}

/* Additional geometric accents via breadcrumb container */
.page-area .breadcrumb {
    position: relative;
    z-index: 2;
}

.page-area .container {
    position: relative;
    z-index: 2;
}

/* Diagonal accent line */
.page-area .breadcumb-overlay {
    display: block !important;
    position: absolute !important;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background:
        linear-gradient(125deg, transparent 40%, rgba(255,255,255,0.03) 40%, rgba(255,255,255,0.03) 45%, transparent 45%),
        linear-gradient(125deg, transparent 55%, rgba(255,255,255,0.02) 55%, rgba(255,255,255,0.02) 60%, transparent 60%) !important;
    pointer-events: none;
    z-index: 1;
}

.section-headline.white-headline h3 {
    font-family: var(--font-main) !important;
    font-size: 34px !important;
    font-weight: 800 !important;
    color: #fff !important;
    text-shadow: 0 2px 10px rgba(0,0,0,0.15);
}

.breadcrumb-bg {
    margin-top: 12px;
}

.breadcrumb-bg li {
    color: rgba(255,255,255,0.75) !important;
    font-family: var(--font-main) !important;
    font-weight: 500 !important;
    font-size: 14px !important;
}

.breadcrumb-bg li a {
    color: rgba(255,255,255,0.9) !important;
}

.white-headline::after {
    background: rgba(255,255,255,0.4) !important;
    height: 3px !important;
    border-radius: 2px !important;
}

/* ────────────────────────────────────────────────────────────────
   CONTENT AREAS & PAGES
   ──────────────────────────────────────────────────────────────── */
.area-padding {
    padding: 80px 0 !important;
}

.page-padding {
    padding: 80px 0 40px !important;
}

.bg-color {
    background: var(--bg-section-alt) !important;
}

.blog-page-area, .single-services-page, .contact-page {
    background: var(--bg-body) !important;
}

/* Article Detail */
.blog-post-wrapper {
    background: #fff !important;
    border-radius: var(--radius-lg) !important;
    overflow: hidden;
    box-shadow: var(--shadow-md) !important;
    border: 1px solid var(--border-light);
    margin-bottom: 30px;
}

.blog-post-wrapper .blog-content {
    padding: 30px !important;
}

.blog-post-wrapper .blog-content h4 {
    font-family: var(--font-main) !important;
    font-size: 26px !important;
    font-weight: 800 !important;
    color: var(--text-dark) !important;
    margin-bottom: 20px !important;
}

.blog-banner img {
    border-radius: var(--radius-lg) var(--radius-lg) 0 0 !important;
}

/* ────────────────────────────────────────────────────────────────
   SIDEBAR
   ──────────────────────────────────────────────────────────────── */
.left-head-blog, .left-blog-page {
    background: #fff;
    border-radius: var(--radius-lg) !important;
    padding: 24px !important;
    box-shadow: var(--shadow-sm) !important;
    border: 1px solid var(--border-light);
    margin-bottom: 24px;
}

.left-blog h4 {
    font-family: var(--font-main) !important;
    font-size: 20px !important;
    font-weight: 800 !important;
    color: var(--text-dark) !important;
    padding-bottom: 12px;
    border-bottom: 3px solid var(--primary);
    margin-bottom: 16px !important;
    display: inline-block;
}

.left-blog ul li {
    border-bottom: 1px solid var(--border-light);
    padding: 8px 0;
}

.left-blog ul li:last-child {
    border-bottom: none;
}

.left-blog ul li a {
    color: var(--text-body) !important;
    font-weight: 500;
    transition: var(--transition-fast) !important;
}

.left-blog ul li a:hover {
    color: var(--primary) !important;
    padding-right: 6px;
}

.recent-single-post {
    margin-bottom: 16px !important;
    padding-bottom: 16px !important;
    border-bottom: 1px solid var(--border-light) !important;
    overflow: hidden;
}

.recent-single-post:last-child {
    border-bottom: none !important;
    margin-bottom: 0 !important;
}

.recent-single-post .post-img img {
    border-radius: var(--radius-sm) !important;
    width: 80px !important;
    height: 60px !important;
    object-fit: cover;
}

/* ────────────────────────────────────────────────────────────────
   FORMS & INPUTS
   ──────────────────────────────────────────────────────────────── */
.form-group {
    height: auto !important;
    margin-bottom: 20px !important;
}

.form-control {
    font-family: var(--font-main) !important;
    border: 2px solid var(--border-light) !important;
    border-radius: var(--radius-sm) !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    transition: var(--transition-fast) !important;
    background: #fff !important;
    height: auto !important;
    box-shadow: none !important;
}

.form-control:focus {
    border-color: var(--primary) !important;
    box-shadow: 0 0 0 3px rgba(27, 53, 102, 0.12) !important;
}

textarea.form-control {
    min-height: 140px !important;
    resize: vertical;
}

.input-group-addon {
    background: var(--bg-section-alt) !important;
    border: 2px solid var(--border-light) !important;
    border-radius: var(--radius-sm) 0 0 var(--radius-sm) !important;
    color: var(--primary) !important;
    font-size: 16px !important;
    min-width: 46px;
}

.input-group .form-control {
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0 !important;
}

/* ────────────────────────────────────────────────────────────────
   BUTTONS
   ──────────────────────────────────────────────────────────────── */
.btn, .btn2, .add-btn, .contact-btn, .btn_submit, .more-btn, .quote-btn {
    font-family: var(--font-main) !important;
    background: var(--primary-gradient) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 50px !important;
    padding: 12px 36px !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    letter-spacing: 0.3px;
    box-shadow: 0 4px 15px rgba(27, 53, 102, 0.3) !important;
    transition: var(--transition) !important;
    cursor: pointer;
    display: inline-block;
}

.btn:hover, .btn2:hover, .add-btn:hover, .contact-btn:hover, .btn_submit:hover, .more-btn:hover, .quote-btn:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 8px 25px rgba(27, 53, 102, 0.4) !important;
    color: #fff !important;
}

.btn:active, .btn2:active {
    transform: translateY(-1px) !important;
}

/* ────────────────────────────────────────────────────────────────
   ALERTS
   ──────────────────────────────────────────────────────────────── */
.alert {
    border-radius: var(--radius-md) !important;
    border: none !important;
    font-family: var(--font-main) !important;
    font-weight: 600 !important;
    padding: 16px 24px !important;
    box-shadow: var(--shadow-sm) !important;
}

.alert-success {
    background: #f0fdf4 !important;
    color: #166534 !important;
    border-right: 4px solid #22c55e !important;
}

.alert-danger {
    background: #fef2f2 !important;
    color: #991b1b !important;
    border-right: 4px solid #ef4444 !important;
}

.alert-warning {
    background: #fffbeb !important;
    color: #92400e !important;
    border-right: 4px solid #f59e0b !important;
}

/* ────────────────────────────────────────────────────────────────
   CONTACT PAGE
   ──────────────────────────────────────────────────────────────── */
.contact-page .contact-head {
    background: #fff;
    border-radius: var(--radius-lg);
    padding: 30px;
    box-shadow: var(--shadow-md);
    border: 1px solid var(--border-light);
}

.contact-head h3 {
    font-family: var(--font-main) !important;
    color: var(--text-dark) !important;
    font-size: 24px !important;
    margin-bottom: 20px !important;
}

.contact-icon .single-contact {
    margin-bottom: 15px;
}

.contact-icon .single-contact h5 {
    color: var(--text-dark) !important;
    font-weight: 700 !important;
}

.contact-icon .single-contact a {
    color: var(--text-body) !important;
    transition: var(--transition-fast) !important;
}

.contact-icon .single-contact a:hover {
    color: var(--primary) !important;
}

.contact-icon .single-contact a i {
    color: var(--primary) !important;
}

.contact-icon .single-contact span {
    color: var(--text-body) !important;
}

/* ────────────────────────────────────────────────────────────────
   LOGIN PAGE
   ──────────────────────────────────────────────────────────────── */
.form-signin {
    background: #fff;
    border-radius: var(--radius-lg);
    padding: 40px 30px;
    box-shadow: var(--shadow-lg);
    border: 1px solid var(--border-light);
}

/* ────────────────────────────────────────────────────────────────
   FOOTER
   ──────────────────────────────────────────────────────────────── */
.footer-1 {
    background: var(--primary-dark) !important;
}

.footer-1::after {
    background: var(--primary-dark) !important;
}

.footer-area-bottom {
    background: var(--primary-dark) !important;
    border-top: 1px solid rgba(255,255,255,0.08) !important;
    padding: 20px 0 !important;
}

.copyright p {
    font-family: var(--font-main) !important;
    font-size: 14px !important;
    color: rgba(255,255,255,0.6) !important;
    font-weight: 400;
}

.footer-area-bottom .form-inline label {
    color: rgba(255,255,255,0.7) !important;
    font-family: var(--font-main) !important;
    font-weight: 600 !important;
    margin-left: 12px;
}

.footer-area-bottom .form-inline .form-control {
    border-radius: 50px 0 0 50px !important;
    border: 2px solid rgba(255,255,255,0.15) !important;
    background: rgba(255,255,255,0.08) !important;
    color: #fff !important;
    font-size: 13px !important;
    padding: 10px 20px !important;
}

.footer-area-bottom .form-inline .form-control::placeholder {
    color: rgba(255,255,255,0.4);
}

.footer-area-bottom .btn, .footer-area-bottom .btn2 {
    border-radius: 0 50px 50px 0 !important;
    padding: 10px 24px !important;
}

/* ────────────────────────────────────────────────────────────────
   ABOUT PAGES
   ──────────────────────────────────────────────────────────────── */
.about-content h3,
.about-3 .about-content h3 {
    font-family: var(--font-main) !important;
    font-weight: 800 !important;
    color: var(--text-dark) !important;
}

.about-image {
    border-radius: var(--radius-lg) !important;
    overflow: hidden !important;
    box-shadow: var(--shadow-lg) !important;
}

.about-image img {
    border-radius: var(--radius-lg) !important;
    transition: var(--transition-slow) !important;
}

.about-image:hover img {
    transform: scale(1.03);
}

/* ────────────────────────────────────────────────────────────────
   COUNTER AREA
   ──────────────────────────────────────────────────────────────── */
.fun-content {
    background: var(--primary-gradient) !important;
    border-radius: var(--radius-lg);
}

.fun_text span {
    font-family: var(--font-main) !important;
    font-weight: 900 !important;
}

/* ────────────────────────────────────────────────────────────────
   TESTIMONIALS
   ──────────────────────────────────────────────────────────────── */
.single-testi {
    background: #fff !important;
    border: 1px solid var(--border-light) !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: var(--shadow-sm) !important;
    transition: var(--transition) !important;
    padding: 30px !important;
}

.single-testi:hover {
    box-shadow: var(--shadow-lg) !important;
}

.testi-img img {
    border: 3px solid var(--primary) !important;
    box-shadow: 0 4px 12px rgba(27, 53, 102, 0.2);
}

/* ────────────────────────────────────────────────────────────────
   CUSTOM MOBILE NAVIGATION (REPLACING MEANMENU)
   ──────────────────────────────────────────────────────────────── */
.mobile-nav-toggle {
    display: none;
    flex-direction: column;
    justify-content: space-between;
    width: 32px;
    height: 22px;
    background: transparent;
    border: none;
    cursor: pointer;
    padding: 0;
    z-index: 10001;
    transition: var(--transition-base);
}

.mobile-nav-toggle span,
.mobile-nav-toggle::before,
.mobile-nav-toggle::after {
    content: ""; /* Required for pseudo-elements */
    display: block;
    width: 100%;
    height: 3px;
    background: var(--primary);
    border-radius: 4px;
    transition: var(--transition-base);
}

/* Side Menu Overlay */
.mobile-nav-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(4px);
    z-index: 20000;
    opacity: 0;
    visibility: hidden;
    transition: var(--transition-slow);
}

.mobile-nav-overlay.active {
    opacity: 1;
    visibility: visible;
}

/* Side Menu Drawer */
.mobile-nav-drawer {
    position: fixed;
    top: 0;
    width: 320px;
    height: 100%;
    background: rgba(255, 255, 255, 0.98);
    backdrop-filter: blur(10px);
    z-index: 20001;
    box-shadow: 0 0 40px rgba(0, 0, 0, 0.1);
    transition: transform 0.5s cubic-bezier(0.85, 0, 0.15, 1);
    display: flex;
    flex-direction: column;
    overflow-y: auto;
}

.mobile-nav-drawer.rtl {
    right: 0;
    transform: translateX(100%);
    border-left: 1px solid var(--border-light);
}

.mobile-nav-drawer.ltr {
    left: 0;
    transform: translateX(-100%);
    border-right: 1px solid var(--border-light);
}

.mobile-nav-drawer.active {
    transform: translateX(0);
}

.mobile-nav-header {
    padding: 25px 30px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--border-light);
    margin-bottom: 20px;
}

.mobile-nav-close {
    background: var(--bg-section);
    border: none;
    font-size: 28px;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: var(--primary);
    transition: var(--transition-base);
}

.mobile-nav-close:hover {
    background: var(--primary);
    color: #fff;
    transform: rotate(90deg);
}

/* Mobile Nav Body Item Styling */
.mobile-nav-body {
    padding: 0 20px 40px;
}

.mobile-nav-body .nav-item-clone {
    margin-bottom: 5px;
}

.mobile-nav-body .nav-link-clone {
    display: flex;
    align-items: center;
    padding: 12px 20px;
    font-size: 16px;
    font-weight: 600;
    color: var(--text-dark);
    text-decoration: none;
    border-radius: 12px;
    transition: var(--transition-base);
    position: relative;
}

.mobile-nav-body .nav-link-clone:hover,
.mobile-nav-body .nav-link-clone.active {
    background: var(--primary) !important;
    color: #fff !important;
    box-shadow: 0 4px 12px rgba(27, 53, 102, 0.2);
}

.mobile-nav-body .nav-link-clone i {
    margin-inline-start: 10px;
}

/* Sub-menu styling for mobile */
.mobile-nav-body ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.mobile-nav-body ul ul {
    display: none; /* Hide by default */
    padding-inline-start: 20px;
    background: rgba(27, 53, 102, 0.03);
    border-radius: 0 0 12px 12px;
    margin-top: -5px;
    margin-bottom: 10px;
}

.mobile-nav-body .nav-item-clone.has-children > .nav-link-clone::after {
    content: " \f105"; /* angle-right/left */
    font-family: FontAwesome;
    margin-inline-start: auto;
    transition: transform 0.3s ease;
}

.mobile-nav-body.rtl .nav-item-clone.has-children > .nav-link-clone::after {
    content: " \f104";
}

.mobile-nav-body .nav-item-clone.open > .nav-link-clone::after {
    transform: rotate(90deg);
}

/* Responsive Trigger */
@media (max-width: 991px) {
    .mobile-nav-toggle {
        display: flex;
    }
    
    .main-menu, .mobile-menu, #dropdown {
        display: none !important;
    }

    /* Fix Slider Centering on Mobile (Account for header height) */
    .slider-content {
        padding-top: 180px !important; /* Visual offset to clear mobile header */
        padding-bottom: 40px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        min-height: 100vh !important;
    }

    .intro-content {
        height: auto !important;
        min-height: 100vh !important;
    }

    .slide-layer {
        padding: 30px 20px !important; /* Smaller padding on mobile */
        max-width: 95% !important;
        margin: 0 auto !important;
        border-radius: var(--radius-md) !important;
    }

    .title2, .layer-1 h1 {
        font-size: 24px !important; /* Significantly smaller for mobile */
        margin-bottom: 12px !important;
        line-height: 1.3 !important;
    }

    .layer-2 p {
        font-size: 14px !important;
        line-height: 1.5 !important;
        margin-bottom: 15px !important;
    }
    
    .ready-btn, .ready-btn.left-btn {
        padding: 10px 25px !important; /* Smaller button */
        font-size: 14px !important;
    }
}

/* ────────────────────────────────────────────────────────────────
   PIE CHART (Existing)
   ──────────────────────────────────────────────────────────────── */
.statChartHolder {
    width: 50%;
    height: 70%;
    position: relative;
    top: 5px;
    display: inline-block;
}

.progress-pie-chart {
    width: 200px;
    height: 200px;
    border-radius: 50%;
    background-color: #E5E5E5;
    position: relative;
    margin: 10px auto 0;
}

.progress-pie-chart.gt-50 {
    background-color: var(--accent);
}

.ppc-progress {
    content: "";
    position: absolute;
    border-radius: 50%;
    left: calc(50% - 100px);
    top: calc(50% - 100px);
    width: 200px;
    height: 200px;
    clip: rect(0, 200px, 200px, 100px);
}

.ppc-progress .ppc-progress-fill {
    content: "";
    position: absolute;
    border-radius: 50%;
    left: calc(50% - 100px);
    top: calc(50% - 100px);
    width: 200px;
    height: 200px;
    clip: rect(0, 100px, 200px, 0);
    background: var(--accent);
    transform: rotate(60deg);
}

.gt-50 .ppc-progress {
    clip: rect(0, 100px, 200px, 0);
}

.gt-50 .ppc-progress .ppc-progress-fill {
    clip: rect(0, 200px, 200px, 100px);
    background: #E5E5E5;
}

.ppc-percents {
    content: "";
    position: absolute;
    border-radius: 50%;
    left: calc(50% - 173.91304px/2);
    top: calc(50% - 173.91304px/2);
    width: 173.91304px;
    height: 173.91304px;
    background: #fff;
    text-align: center;
    display: table;
}

.ppc-percents span {
    display: block;
    font-size: 2.6em;
    font-weight: bold;
    color: var(--accent);
}

.pcc-percents-wrapper {
    display: table-cell;
    vertical-align: middle;
}

/* ────────────────────────────────────────────────────────────────
   SEARCH BAR (Header)
   ──────────────────────────────────────────────────────────────── */
.topbar-area {
    padding: 10px 0 !important;
}

.topbar-area .row {
    display: flex !important;
    align-items: center !important;
}

.topbar-area .col-md-3,
.topbar-area .col-md-9 {
    display: flex !important;
    align-items: center !important;
}

.topbar-area .col-md-9 {
    justify-content: flex-end !important; /* Move search to the far left in RTL */
}

.topbar-area .col-md-3 {
    justify-content: flex-start !important; /* Push login/reg away from search */
}

.topbar-area .search-wrapper {
    max-width: 350px !important;
    margin-right: -15px !important; /* Absolute edge */
}

.topbar-area .topbar-left ul {
    display: flex !important;
    gap: 15px !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

.topbar-area form .btn-light:hover, .topbar-area form button:hover {
    background: rgba(255,255,255,0.25) !important;
}

/* ────────────────────────────────────────────────────────────────
   ANIMATIONS
   ──────────────────────────────────────────────────────────────── */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(30px); }
    to { opacity: 1; transform: translateY(0); }
}

.single-service, .single-blog, .single-testi, .well-services {
    animation: fadeInUp 0.6s ease both;
}

.col-md-4:nth-child(2) .single-service,
.col-md-4:nth-child(2) .single-blog {
    animation-delay: 0.1s;
}

.col-md-4:nth-child(3) .single-service,
.col-md-4:nth-child(3) .single-blog {
    animation-delay: 0.2s;
}

/* ────────────────────────────────────────────────────────────────
   RESPONSIVE REFINEMENTS
   ──────────────────────────────────────────────────────────────── */
@media (max-width: 991px) {
    .title2, .layer-1 h1 {
        font-size: 32px !important;
    }
    .layer-2 p {
        font-size: 15px !important;
    }
    .section-headline.white-headline h3 {
        font-size: 26px !important;
    }
    .center-head h3 {
        font-size: 26px !important;
    }
}

@media (max-width: 767px) {
    .title2, .layer-1 h1 {
        font-size: 26px !important;
        line-height: 1.3 !important;
    }
    .layer-2 p {
        font-size: 14px !important;
    }
    .area-padding {
        padding: 50px 0 !important;
    }
    .page-area {
        padding: 40px 0 35px !important;
    }
    .section-headline.white-headline h3 {
        font-size: 22px !important;
    }
    .center-head h3 {
        font-size: 22px !important;
    }
    .blog-post-wrapper .blog-content h4 {
        font-size: 20px !important;
    }
}

/* ================================================================
   FEEDBACK FIXES — Round 2
   ================================================================ */

/* ────────────────────────────────────────────────────────────────
   FIX 1: HERO TEXT — Semi-transparent backdrop for readability
   ──────────────────────────────────────────────────────────────── */
.slider-content {
    background: none !important;
}

.slider-content .slide-layer,
.slider-content > div {
    position: relative;
    z-index: 5;
}

.slide-layer {
    background: rgba(0, 0, 0, 0.3) !important;
    padding: 35px 40px 25px !important;
    border-radius: var(--radius-xl);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    max-width: 80%;
    margin: 0 auto;
}

/* Force white text on dark backdrop */
.slide-layer h1, .slide-layer h2, .slide-layer h3,
.slide-layer p, .slide-layer span, .slide-layer a:not(.ready-btn),
.title2, .layer-1 h1, .layer-2 p {
    color: #fff !important;
}

.layer-1 {
    background: transparent !important;
    padding: 0 0 5px !important;
}

.layer-2 {
    background: transparent !important;
    padding: 5px 0 !important;
    margin-bottom: 8px !important;
}

.layer-3 {
    margin-top: 10px;
}

/* ────────────────────────────────────────────────────────────────
   FIX 2: FORM INPUTS — Fix inconsistent icon/addon borders
   ──────────────────────────────────────────────────────────────── */
.input-group {
    display: flex !important;
    align-items: stretch !important;
}

.input-group-addon {
    background: var(--bg-section-alt) !important;
    border: 2px solid var(--border-light) !important;
    border-left: none !important;
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0 !important;
    color: var(--primary) !important;
    font-size: 16px !important;
    padding: 10px 14px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 48px !important;
    line-height: 1 !important;
}

.input-group .form-control {
    border: 2px solid var(--border-light) !important;
    border-right: none !important;
    border-radius: var(--radius-sm) 0 0 var(--radius-sm) !important;
    height: auto !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    font-family: var(--font-main) !important;
    background: #fff !important;
    box-shadow: none !important;
    transition: var(--transition-fast) !important;
}

.input-group .form-control:focus {
    border-color: var(--primary) !important;
    box-shadow: none !important;
}

.input-group .form-control:focus + .input-group-addon,
.input-group:focus-within .input-group-addon {
    border-color: var(--primary) !important;
    color: var(--primary) !important;
}

.form-group {
    height: auto !important;
    margin-bottom: 18px !important;
}

/* Textarea within input-group */
.input-group textarea.form-control {
    min-height: 120px !important;
    resize: vertical;
    border-radius: var(--radius-sm) 0 0 var(--radius-sm) !important;
}

/* Standalone select/dropdown */
select.form-control {
    border: 2px solid var(--border-light) !important;
    border-radius: var(--radius-sm) !important;
    padding: 10px 16px !important;
    appearance: auto;
    background: #fff !important;
}

/* ────────────────────────────────────────────────────────────────
   FIX 3: SERVICES CARDS — Better internal spacing
   ──────────────────────────────────────────────────────────────── */
/* Services page (blog-content used inside service cards) */
.blog-page-area .single-blog .blog-content,
.single-blog .blog-content {
    padding: 24px !important;
}

.blog-page-area .single-blog .blog-content h3,
.single-blog .blog-content h3 {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--primary) !important;
    margin-top: 8px !important;
    margin-bottom: 12px !important;
    line-height: 1.5 !important;
}

.blog-page-area .single-blog .blog-content p,
.single-blog .blog-content p {
    margin-top: 8px !important;
    margin-bottom: 12px !important;
    line-height: 1.7 !important;
    font-size: 14px !important;
    color: var(--text-body) !important;
}

.blog-page-area .single-blog .blog-content .image-scale img,
.single-blog .blog-content .image-scale img {
    border-radius: var(--radius-md) !important;
    margin-bottom: 12px;
}

.single-blog .blog-content .read-more {
    margin-top: 14px !important;
    padding-top: 14px !important;
}

/* Services page fixed-height cards */
.blog-content[style*="height:380px"] {
    height: auto !important;
    min-height: 0 !important;
}

/* ────────────────────────────────────────────────────────────────
   FIX 4: FOOTER — Move social icons + professional redesign
   ──────────────────────────────────────────────────────────────── */
/* Social icons moved to footer only */
.top-social {
    display: none !important;
}

/* Footer complete overhaul */
.footer-1, .footer-1::after {
    background: linear-gradient(180deg, #0f2240 0%, #0a192f 100%) !important;
}

.footer-about-top {
    background: transparent !important;
    top: 0 !important;
    margin-bottom: 0 !important;
    padding: 60px 0 30px !important;
}

.footer-head h4 {
    font-family: var(--font-main) !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    color: #fff !important;
    padding-bottom: 14px;
    border-bottom: 3px solid var(--primary-light);
    margin-bottom: 20px !important;
    display: inline-block;
}

.footer-head p {
    color: rgba(255, 255, 255, 0.6) !important;
    font-size: 14px !important;
    line-height: 1.8 !important;
}

.footer-list li a {
    color: rgba(255, 255, 255, 0.65) !important;
    font-family: var(--font-main) !important;
    font-size: 14px !important;
    font-weight: 400 !important;
    padding: 6px 0 !important;
    transition: var(--transition-fast) !important;
}

.footer-list li a:hover {
    color: #fff !important;
    padding-right: 8px !important;
}

.footer-list li a::after {
    display: none !important;
}

/* Footer Social Icons (shown here instead of topbar) */
.footer-icons {
    margin-top: 20px !important;
}

.footer-icons h5 {
    color: rgba(255, 255, 255, 0.7) !important;
    font-family: var(--font-main) !important;
    font-weight: 600 !important;
    font-size: 16px !important;
}

.footer-icons ul li a {
    color: rgba(255, 255, 255, 0.7) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    width: 42px !important;
    height: 42px !important;
    line-height: 40px !important;
    font-size: 18px !important;
    border-radius: 50% !important;
    transition: var(--transition) !important;
    margin-left: 8px !important;
}

.footer-icons ul li a:hover {
    background: var(--primary-gradient) !important;
    border-color: transparent !important;
    color: #fff !important;
    transform: translateY(-3px);
}

/* Footer bottom bar */
.footer-area-bottom {
    background: rgba(0, 0, 0, 0.3) !important;
    border-top: 1px solid rgba(255, 255, 255, 0.06) !important;
    padding: 18px 0 !important;
}

.copyright p, .copyright a {
    color: rgba(255, 255, 255, 0.5) !important;
    font-family: var(--font-main) !important;
    font-size: 13px !important;
}

/* Newsletter subscription in footer */
.suscribe-input input {
    background: rgba(255, 255, 255, 0.08) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    border-radius: var(--radius-sm) !important;
    color: #fff !important;
    font-family: var(--font-main) !important;
    font-size: 14px !important;
    padding: 12px 16px !important;
    height: auto !important;
    transition: var(--transition-fast) !important;
}

.suscribe-input input:focus {
    border-color: var(--primary-light) !important;
    background: rgba(255, 255, 255, 0.12) !important;
}

.suscribe-input button {
    background: var(--primary-gradient) !important;
    border: none !important;
    border-radius: var(--radius-sm) !important;
    color: #fff !important;
    font-family: var(--font-main) !important;
    font-weight: 700 !important;
    padding: 12px 24px !important;
    margin-top: 12px !important;
    transition: var(--transition) !important;
}

.suscribe-input button:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 15px rgba(27, 53, 102, 0.4) !important;
}

/* ────────────────────────────────────────────────────────────────
   FIX 5: LOGIN PAGE — Complete redesign
   ──────────────────────────────────────────────────────────────── */
.single-services-page .form-signin,
.form-signin {
    background: #fff !important;
    border-radius: var(--radius-xl) !important;
    padding: 50px 40px !important;
    box-shadow: var(--shadow-xl) !important;
    border: 1px solid var(--border-light) !important;
    max-width: 440px;
    margin: 0 auto;
    position: relative;
    overflow: hidden;
}

.form-signin::before {
    content: '';
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    height: 5px;
    background: var(--primary-gradient);
}

.single-services-page {
    background: var(--bg-body) !important;
}

.single-services-page .form-signin .form-group,
.form-signin .form-group {
    margin-bottom: 20px !important;
}

.single-services-page .form-signin .btn,
.form-signin .btn {
    width: 100% !important;
    padding: 14px !important;
    font-size: 16px !important;
    border-radius: var(--radius-md) !important;
    margin-top: 10px !important;
}

.form-signin label {
    font-family: var(--font-main) !important;
    font-weight: 500 !important;
    color: var(--text-body) !important;
    font-size: 14px !important;
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}

.form-signin label input[type="checkbox"] {
    accent-color: var(--primary);
    width: 18px;
    height: 18px;
}

/* Password recovery link */
.single-services-page + div a,
div.row > div.col-md-12.text-center > a {
    color: var(--primary) !important;
    font-family: var(--font-main) !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    transition: var(--transition-fast) !important;
    display: inline-block;
    margin-top: 15px;
}

div.row > div.col-md-12.text-center > a:hover {
    color: var(--primary-light) !important;
}

/* Login page default info alert */
.single-services-page .alert-warning,
.page-padding .alert-warning {
    border-radius: var(--radius-md) !important;
    max-width: 440px;
    margin: 0 auto 20px !important;
    text-align: center;
    font-size: 13px !important;
}

/* ────────────────────────────────────────────────────────────────
   FIX 6: ARTICLES & MEDIA LIST — Professional card layout
   ──────────────────────────────────────────────────────────────── */
/* Article/Media list cards (horizontal layout: image + content) */
.blog-page-area .single-blog {
    border-radius: var(--radius-lg) !important;
    overflow: hidden !important;
    box-shadow: var(--shadow-sm) !important;
    border: 1px solid var(--border-light) !important;
    margin-bottom: 24px !important;
    margin-top: 24px !important;
    transition: var(--transition) !important;
    padding: 0 !important;
    background: #fff !important;
}

.blog-page-area .single-blog:hover {
    box-shadow: var(--shadow-lg) !important;
    transform: translateY(-4px) !important;
}

/* Image inside horizontal blog card */
.blog-page-area .single-blog .blog-image {
    overflow: hidden !important;
    height: 100% !important;
}

.blog-page-area .single-blog .blog-image img {
    width: 100% !important;
    height: 100% !important;
    min-height: 200px !important;
    object-fit: cover !important;
    border-radius: 0 !important;
    transition: var(--transition-slow) !important;
}

.blog-page-area .single-blog:hover .blog-image img {
    transform: scale(1.05) !important;
}

/* Content area inside horizontal blog card */
.blog-page-area .single-blog .blog-content {
    background: #fff !important;
    padding: 24px 28px !important;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 200px;
}

/* Category Badge */
.blog-page-area .badge,
.badge {
    background: var(--primary-gradient) !important;
    color: #fff !important;
    font-family: var(--font-main) !important;
    font-weight: 600 !important;
    font-size: 12px !important;
    padding: 5px 14px !important;
    border-radius: 50px !important;
    letter-spacing: 0.3px;
    display: inline-block !important;
    margin-bottom: 10px !important;
    width: auto !important;
    float: none !important;
}

.badge a {
    color: #fff !important;
}

/* Footer contact info */
.footer-contact-info p {
    color: rgba(255, 255, 255, 0.6) !important;
    font-size: 14px !important;
    margin-bottom: 10px !important;
    line-height: 1.8 !important;
}

/* Article title in list */
.blog-page-area .blog-content h3 {
    font-family: var(--font-main) !important;
    font-size: 19px !important;
    font-weight: 800 !important;
    color: var(--text-dark) !important;
    line-height: 1.5 !important;
    margin-bottom: 10px !important;
    transition: var(--transition-fast) !important;
}

.blog-page-area .blog-content h3:hover {
    color: var(--primary) !important;
}

/* Pagination */
.pagination {
    margin: 40px 0 10px !important;
}

.pagination > li > a,
.pagination > li > span {
    font-family: var(--font-main) !important;
    font-weight: 600 !important;
    border-radius: var(--radius-sm) !important;
    padding: 8px 14px !important;
    margin: 0 3px !important;
    border: 1px solid var(--border-light) !important;
    background: #fff !important;
    color: var(--text-body) !important;
    transition: var(--transition-fast) !important;
}

.pagination > .active > a,
.pagination > .active > span {
    background: var(--primary-gradient) !important;
    border-color: transparent !important;
    color: #fff !important;
    box-shadow: 0 2px 8px rgba(27, 53, 102, 0.3) !important;
}

.pagination > li > a:hover {
    background: var(--primary) !important;
    border-color: var(--primary) !important;
    color: #fff !important;
}

/* Sidebar improvements for articles/media */
.left-blog h4::after {
    background: var(--primary) !important;
    height: 3px !important;
    border-radius: 2px !important;
    width: 40px !important;
}

.blog-left-content {
    margin-top: 0 !important;
}

/* ================================================================
   FEEDBACK FIXES — Round 3
   ================================================================ */

/* ────────────────────────────────────────────────────────────────
   FIX: CARDS — Services, Articles, Media professional redesign
   ──────────────────────────────────────────────────────────────── */

/* === SERVICES PAGE CARDS (Vertical) === */
.blog-page-area .single-blog .blog-content[style*="height:380px"],
.blog-page-area .single-blog .blog-content[style*="height: 380px"],
.blog-content[style*="height:380px"],
.blog-content[style*="height: 380px"] {
    height: auto !important;
}

/* Service card container */
.blog-page-area .col-md-4 .single-blog {
    background: #fff !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: 0 4px 20px rgba(0,0,0,0.06) !important;
    overflow: hidden !important;
    transition: var(--transition) !important;
    border: 1px solid var(--border-light) !important;
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
}

.blog-page-area .col-md-4 .single-blog:hover {
    transform: translateY(-6px) !important;
    box-shadow: 0 16px 40px rgba(27, 53, 102, 0.15) !important;
    border-color: var(--primary) !important;
}

/* Service card image */
.blog-page-area .col-md-4 .single-blog .blog-content .image-scale img {
    border-radius: 0 !important;
    height: 200px !important;
    width: 100% !important;
    object-fit: cover !important;
    transition: var(--transition) !important;
}

.blog-page-area .col-md-4 .single-blog:hover .image-scale img {
    transform: scale(1.05) !important;
}

.blog-page-area .col-md-4 .single-blog .image-scale {
    display: block !important;
    overflow: hidden !important;
    border-radius: var(--radius-lg) var(--radius-lg) 0 0 !important;
}

/* Service card body */
.blog-page-area .col-md-4 .single-blog .blog-content {
    height: auto !important;
    min-height: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    padding: 24px 20px 20px !important;
    flex: 1 !important;
}

.blog-page-area .col-md-4 .blog-content h3 {
    font-size: 18px !important;
    font-weight: 800 !important;
    color: var(--primary) !important;
    font-family: var(--font-main) !important;
    margin-bottom: 10px !important;
    line-height: 1.5 !important;
}

.blog-page-area .col-md-4 .blog-content p {
    font-size: 13.5px !important;
    line-height: 1.8 !important;
    color: var(--text-body) !important;
    margin-bottom: 16px !important;
    flex: 1 !important;
}

/* "More" button — styled as a real button */
.blog-page-area .col-md-4 .blog-content .read-more,
.blog-content .read-more {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    visibility: visible !important;
    opacity: 1 !important;
    background: var(--primary-gradient) !important;
    color: #fff !important;
    font-weight: 700 !important;
    font-family: var(--font-main) !important;
    font-size: 13px !important;
    padding: 8px 24px !important;
    border-radius: 20px !important;
    margin-top: auto !important;
    text-align: center !important;
    transition: var(--transition) !important;
    border: none !important;
    width: fit-content !important;
    text-decoration: none !important;
    float: none !important;
    letter-spacing: 0.3px;
}

.blog-page-area .col-md-4 .blog-content .read-more:hover,
.blog-content .read-more:hover {
    background: linear-gradient(135deg, #2b54a0, #1b3566) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(27, 53, 102, 0.3) !important;
    color: #fff !important;
}

/* Ensure row has equal-height columns for services */
.blog-page-area .blog-left-content > .col-md-4 {
    display: flex !important;
    margin-bottom: 30px !important;
}

/* === ARTICLES & MEDIA CARDS (Horizontal) === */
.blog-page-area .col-md-12 > .single-blog,
.blog-page-area .col-md-8 .single-blog {
    background: #fff !important;
    border-radius: var(--radius-lg) !important;
    box-shadow: 0 4px 20px rgba(0,0,0,0.06) !important;
    border: 1px solid var(--border-light) !important;
    overflow: hidden !important;
    margin-bottom: 24px !important;
    transition: var(--transition) !important;
}

.blog-page-area .col-md-12 > .single-blog:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 12px 30px rgba(27, 53, 102, 0.1) !important;
    border-color: rgba(27, 53, 102, 0.2) !important;
}

/* Article card row alignment */
.blog-page-area .single-blog > .row {
    display: flex !important;
    align-items: stretch !important;
}

/* Article image */
.blog-page-area .single-blog .blog-image {
    padding: 0 !important;
    overflow: hidden !important;
    height: 100% !important;
}

.blog-page-area .single-blog .blog-image img {
    height: 100% !important;
    width: 100% !important;
    min-height: 200px !important;
    object-fit: cover !important;
    transition: var(--transition) !important;
}

.blog-page-area .single-blog:hover .blog-image img {
    transform: scale(1.05) !important;
}

.blog-page-area .single-blog .blog-image a {
    display: block !important;
    height: 100% !important;
    overflow: hidden !important;
}

/* Article content area */
.blog-page-area .single-blog .col-md-8 .blog-content,
.blog-page-area .single-blog .col-sm-8 .blog-content {
    padding: 24px 28px !important;
    height: auto !important;
    min-height: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
}

/* Badge styling */
.blog-page-area .single-blog .badge {
    background: var(--primary-gradient) !important;
    color: #fff !important;
    padding: 6px 16px !important;
    border-radius: 20px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    font-family: var(--font-main) !important;
    display: inline-block !important;
    margin-bottom: 10px !important;
    float: none !important;
}

.blog-page-area .single-blog .badge a {
    color: #fff !important;
}

/* Article title */
.blog-page-area .single-blog .blog-content h3 {
    font-size: 19px !important;
    font-weight: 800 !important;
    color: var(--primary) !important;
    font-family: var(--font-main) !important;
    line-height: 1.6 !important;
    margin: 4px 0 10px !important;
    transition: var(--transition-fast) !important;
}

.blog-page-area .single-blog .blog-content h3:hover {
    color: var(--primary-light) !important;
}

/* Article excerpt */
.blog-page-area .single-blog .blog-content p {
    font-size: 14px !important;
    line-height: 1.8 !important;
    color: var(--text-body) !important;
    margin-bottom: 12px !important;
}

/* Article "more" link uses same gradient button */
.blog-page-area .single-blog .col-md-8 .read-more,
.blog-page-area .single-blog .col-sm-8 .read-more {
    margin-top: 8px !important;
}

/* === SIDEBAR === */
.left-head-blog {
    position: sticky !important;
    top: 100px !important;
}

.left-blog-page {
    background: #fff !important;
    border-radius: var(--radius-lg) !important;
    padding: 24px !important;
    box-shadow: 0 4px 20px rgba(0,0,0,0.06) !important;
    border: 1px solid var(--border-light) !important;
    margin-bottom: 20px !important;
}

.left-blog h4 {
    font-size: 18px !important;
    font-weight: 800 !important;
    font-family: var(--font-main) !important;
    color: var(--primary) !important;
    margin-bottom: 18px !important;
    padding-bottom: 12px !important;
    border-bottom: 2px solid var(--border-light) !important;
}

.left-blog h4::after {
    display: none !important;
}

/* Sidebar recent posts */
.recent-single-post {
    display: flex !important;
    align-items: flex-start !important;
    gap: 12px !important;
    padding: 12px 0 !important;
    border-bottom: 1px solid var(--border-light) !important;
}

.recent-single-post:last-child {
    border-bottom: none !important;
}

.recent-single-post .post-img {
    flex-shrink: 0 !important;
    width: 70px !important;
    height: 70px !important;
    border-radius: var(--radius-sm) !important;
    overflow: hidden !important;
}

.recent-single-post .post-img img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

.recent-single-post .pst-content p {
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 1.5 !important;
    margin-bottom: 4px !important;
}

.recent-single-post .pst-content .date-type {
    font-size: 11px !important;
    color: var(--text-muted) !important;
}

/* Sidebar categories */
.left-blog ul {
    list-style: none !important;
    padding: 0 !important;
}

.left-blog ul li {
    padding: 8px 0 !important;
    border-bottom: 1px solid var(--border-light) !important;
}

.left-blog ul li:last-child {
    border-bottom: none !important;
}

.left-blog ul li a {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--text-body) !important;
    font-family: var(--font-main) !important;
    transition: var(--transition-fast) !important;
}

.left-blog ul li a:hover {
    color: var(--primary) !important;
    padding-right: 8px !important;
}

/* === PAGINATION === */
.pagination {
    gap: 4px !important;
    margin-top: 30px !important;
}

.pagination .page-item .page-link,
.pagination li a {
    border-radius: var(--radius-sm) !important;
    border: 1px solid var(--border-light) !important;
    color: var(--primary) !important;
    font-family: var(--font-main) !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    padding: 8px 14px !important;
    transition: var(--transition-fast) !important;
}

.pagination .page-item.active .page-link,
.pagination li.active a {
    background: var(--primary-gradient) !important;
    color: #fff !important;
    border-color: var(--primary) !important;
}

.pagination .page-item .page-link:hover,
.pagination li a:hover {
    background: var(--primary) !important;
    color: #fff !important;
    border-color: var(--primary) !important;
}

/* ────────────────────────────────────────────────────────────────
   FIX: SELECT BOX height matching regular inputs
   ──────────────────────────────────────────────────────────────── */
/* Force identical height on ALL form-control elements */
.form-control,
.input-group .form-control,
select.form-control,
.input-group select.form-control {
    height: 46px !important;
    min-height: 46px !important;
    max-height: 46px !important;
    padding: 0 16px !important;
    font-size: 14px !important;
    font-family: var(--font-main) !important;
    line-height: 46px !important;
    border: 2px solid var(--border-light) !important;
    background: #fff !important;
    box-sizing: border-box !important;
}

/* Input within input-group — no right border */
.input-group .form-control,
.input-group select.form-control {
    border-right: none !important;
    border-radius: var(--radius-sm) 0 0 var(--radius-sm) !important;
}

/* Standalone form-control has all borders */
.form-control:not(.input-group .form-control) {
    border-radius: var(--radius-sm) !important;
}

/* Addon icon matches field height */
.input-group-addon {
    height: 46px !important;
    min-height: 46px !important;
    max-height: 46px !important;
    line-height: 46px !important;
    padding: 0 14px !important;
    border: 2px solid var(--border-light) !important;
    border-left: none !important;
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0 !important;
    background: var(--bg-section-alt) !important;
    color: var(--primary) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 46px !important;
    font-size: 16px !important;
}

select.form-control {
    appearance: auto;
    -webkit-appearance: auto;
    cursor: pointer;
}

select.form-control:focus,
.form-control:focus {
    border-color: var(--primary) !important;
    box-shadow: none !important;
    outline: none !important;
}

.input-group:focus-within .input-group-addon {
    border-color: var(--primary) !important;
}

/* Textarea exceptions — allow taller */
textarea.form-control,
.input-group textarea.form-control {
    height: auto !important;
    min-height: 120px !important;
    max-height: none !important;
    line-height: 1.6 !important;
    padding: 12px 16px !important;
    resize: vertical;
}



/* GLOBAL STABILITY */
*, *::before, *::after {
    box-sizing: border-box !important;
}

html, body {
    overflow-x: hidden !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* DESKTOP HEADER FIX */
.header-five {
    position: fixed !important;
    top: 0 !important;
    width: 100% !important;
    z-index: 9998 !important;
}

/* ────────────────────────────────────────────────────────────────
   MOBILE & RESPONSIVENESS (2025 Standard)
   ──────────────────────────────────────────────────────────────── */

@media (max-width: 991px) {
    body { font-size: 14px !important; }
    
    .header-five { position: relative !important; z-index: 1 !important; }

    .section-headline h3 { font-size: 24px !important; }
    .page-area { padding: 60px 0 !important; }

    .service-feature-inner {
        margin-bottom: 20px !important;
        min-height: auto !important;
        padding: 20px !important;
    }

    .table {
        display: block !important;
        width: 100% !important;
        overflow-x: auto !important;
    }
}

@media (max-width: 767px) {
    /* Fixed Mobile Header Bar */
    .mobile-menu-area {
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        width: 100% !important;
        height: 60px !important;
        background: #ffffff !important;
        z-index: 999999 !important;
        border-bottom: 2px solid var(--primary) !important;
        box-shadow: 0 4px 15px rgba(0,0,0,0.15) !important;
        display: block !important;
        visibility: visible !important;
    }

    .mobile-menu-area .logo {
        position: absolute !important;
        right: 15px !important;
        top: 50% !important;
        transform: translateY(-50%) !important;
        z-index: 1000000 !important;
        display: block !important;
        visibility: visible !important;
        width: auto !important;
    }
    
    .mobile-menu-area .logo img {
        max-height: 40px !important;
        width: auto !important;
    }

    /* MeanMenu customization */
    .mean-container .mean-bar { 
        background: transparent !important;
        z-index: 999999 !important;
        position: absolute !important;
        top: 15px !important;
        left: 15px !important;
        width: 40px !important;
    }

    .mean-container a.meanmenu-reveal {
        left: 0 !important;
        right: auto !important;
        top: 0 !important;
        z-index: 1000001 !important;
        color: var(--primary) !important;
        text-indent: 0 !important;
        font-size: 24px !important;
    }

    .mean-container .mean-nav {
        margin-top: 60px !important;
        background: #ffffff !important;
        z-index: 999998 !important;
        position: absolute !important;
        width: 100% !important;
        left: 0 !important;
        box-shadow: 0 10px 40px rgba(0,0,0,0.2) !important;
    }

    .mean-container .mean-nav ul li a {
        text-align: right !important;
        padding: 15px 25px !important;
    }

    /* Layout spacing */
    html, body { padding-top: 0 !important; margin: 0 !important; }
    body { padding-top: 60px !important; }
    
    div[style*="margin-top:130px"],
    div[style*=" margin-top:130px"] {
        margin-top: 20px !important;
    }
    
    .slider-area { margin-top: 0 !important; }
    .intro-content { min-height: 400px !important; }
    .title2 { font-size: 24px !important; line-height: 1.2 !important; }
    
    .premium-card [style*="padding: 35px"] { padding: 15px !important; }
}

/* UI Enhancement Globals */
.rich-text-content { word-wrap: break-word !important; line-height: 1.8 !important; }
.rich-text-content img { max-width: 100% !important; height: auto !important; border-radius: 12px !important; }

/* MODAL OVER HEADER FIX */
.modal {
    z-index: 2000000 !important;
}
.modal-backdrop {
    z-index: 1060 !important; /* Standard but higher than header if needed */
}
/* Ensure backdrop is below modal but above header */
.modal-backdrop {
    z-index: 1999999 !important;
}

/* ────────────────────────────────────────────────────────────────
   FIX: Hide social icons from topbar (now in footer only)
   ──────────────────────────────────────────────────────────────── */
.top-social {
    display: none !important;
}

/* ────────────────────────────────────────────────────────────────
   FIX: TOPBAR search field & buttons — Professional styling
   ──────────────────────────────────────────────────────────────── */
.topbar-area form .form-control {
    height: 34px !important;
    min-height: 34px !important;
    max-height: 34px !important;
    padding: 0 14px !important;
    font-size: 13px !important;
    line-height: 34px !important;
    background: rgba(255, 255, 255, 0.12) !important;
    border: 1px solid rgba(255, 255, 255, 0.25) !important;
    border-radius: 0 20px 20px 0 !important;
    color: #fff !important;
    font-family: var(--font-main) !important;
    transition: var(--transition-fast) !important;
}

.topbar-area form .form-control::placeholder {
    color: rgba(255, 255, 255, 0.5) !important;
}

.topbar-area form .form-control:focus {
    background: rgba(255, 255, 255, 0.2) !important;
    border-color: rgba(255, 255, 255, 0.4) !important;
    box-shadow: none !important;
}

.topbar-area form .btn-light,
.topbar-area form button[type="submit"] {
    height: 34px !important;
    padding: 0 18px !important;
    font-size: 13px !important;
    font-family: var(--font-main) !important;
    font-weight: 600 !important;
    border-radius: 20px 0 0 20px !important;
    background: rgba(255, 255, 255, 0.15) !important;
    border: 1px solid rgba(255, 255, 255, 0.25) !important;
    border-left: none !important;
    color: #fff !important;
    cursor: pointer;
    transition: var(--transition-fast) !important;
    line-height: 34px !important;
    margin: 0 !important;
}

.topbar-area form .btn-light:hover,
.topbar-area form button[type="submit"]:hover {
    background: rgba(255, 255, 255, 0.3) !important;
}

.topbar-left ul li a {
    font-size: 12px !important;
    padding: 6px 8px !important;
}

/* ────────────────────────────────────────────────────────────────
   FIX: FOOTER newsletter — aligned & professional
   ──────────────────────────────────────────────────────────────── */
.footer-area-bottom .form-inline {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    flex-wrap: nowrap !important;
}

.footer-area-bottom .form-inline label {
    color: rgba(255, 255, 255, 0.7) !important;
    font-family: var(--font-main) !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    white-space: nowrap;
    margin: 0 !important;
}

.footer-area-bottom .form-inline .form-control {
    height: 36px !important;
    min-height: 36px !important;
    max-height: 36px !important;
    padding: 0 14px !important;
    font-size: 13px !important;
    line-height: 36px !important;
    background: rgba(255, 255, 255, 0.08) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0 !important;
    color: #fff !important;
    font-family: var(--font-main) !important;
    flex: 1;
    min-width: 180px;
}

.footer-area-bottom .form-inline .form-control:focus {
    border-color: var(--primary-light) !important;
    background: rgba(255, 255, 255, 0.12) !important;
}

.footer-area-bottom .form-inline .btn,
.footer-area-bottom .form-inline button {
    height: 36px !important;
    padding: 0 20px !important;
    font-size: 13px !important;
    font-family: var(--font-main) !important;
    font-weight: 700 !important;
    border-radius: var(--radius-sm) 0 0 var(--radius-sm) !important;
    background: var(--primary-gradient) !important;
    border: none !important;
    color: #fff !important;
    cursor: pointer;
    transition: var(--transition) !important;
    white-space: nowrap;
    line-height: 36px !important;
    margin: 0 !important;
}

.footer-area-bottom .form-inline .btn:hover,
.footer-area-bottom .form-inline button:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 15px rgba(27, 53, 102, 0.4) !important;
}
/* ????????????????????????????????????????????????????????????????
   MOBILE & RESPONSIVENESS FIXES (2025 Standard)
   ???????????????????????????????????????????????????????????????? */

@media (max-width: 991px) {
    body { font-size: 14px !important; }
    
    /* Fix Content Margin Overlap */
    div[style*=" margin-top:130px"] {
 margin-top: 90px !important;
 }
 
 .header-five {
 position: fixed !important;
 background: #fff !important;
 }

 /* Breadcrumb Adjustments */
 .section-headline h3 {
 font-size: 24px !important;
 }
 .page-area {
 padding: 60px 0 !important;
 }

 /* Service/Course Features */
 .service-feature-inner {
 margin-bottom: 20px !important;
 min-height: auto !important;
 padding: 20px !important;
 }

 /* Logo Sizing for Mobile */
 .logo img {
 max-height: 50px !important;
 }

 /* Horizontal Scroll Fixes */
 .container {
 overflow: hidden !important;
 }
 
 .table {
 display: block !important;
 width: 100% !important;
 overflow-x: auto !important;
 -webkit-overflow-scrolling: touch !important;
 }
}

@media (max-width: 767px) {
 /* Top bar is hidden but search might remain */
 .search-wrapper {
 margin: 10px 0 !important;
 }
 
 div[style*="margin-top:130px"] {
 margin-top: 80px !important;
 }
 
 .single-page-head h2 {
 font-size: 22px !important;
 }
 
 .down-btn {
 width: 100% !important;
 text-align: center !important;
 }

 /* MeanMenu customization */
 .mean-container .mean-nav {
 background: var(--primary-gradient) !important;
 border-radius: var(--radius-md) !important;
 margin-top: 10px !important;
 box-shadow: var(--shadow-xl) !important;
 }
 .mean-container .mean-nav ul li a {
 color: #fff !important;
 border-top: 1px solid rgba(255,255,255,0.1) !important;
 font-family: var(--font-main) !important;
 font-weight: 500 !important;
 }
}

/* Content Wrapper Helper */
.rich-text-content {
 word-wrap: break-word !important;
 overflow-wrap: break-word !important;
 max-width: 100% !important;
 line-height: 1.8 !important;
}
.rich-text-content img {
 max-width: 100% !important;
 height: auto !important;
 border-radius: var(--radius-md) !important;
 margin: 15px 0 !important;
}

/* Fine-tuning Slider for Mobile */
@media (max-width: 767px) {
    .title2 {
        font-size: 26px !important;
        line-height: 1.2 !important;
        margin-bottom: 10px !important;
    }
    .intro-content {
        min-height: 450px !important;
    }
    .slide-layer {
        padding: 30px 20px !important;
        margin: 0 10px !important;
    }
    .layer-2 p {
        font-size: 14px !important;
        line-height: 1.5 !important;
    }
    .ready-btn {
        padding: 12px 30px !important;
        font-size: 14px !important;
    }
    
    /* Adjust static header height on mobile */
    .header-area {
        padding: 5px 0 !important;
    }
    .logo img {
        max-height: 45px !important;
    }
}

/* Fix global content overlap and spacing */
body {
    background-color: #f8fafc !important;
}

/* Content div margin adjustment */
div[style*=" margin-top:130px"] {
 margin-top: 80px !important;
 padding: 0 !important;
}

/* Page Area (Breadcrumb) Upgrade */
.page-area {
 position: relative !important;
 padding: 100px 0 60px !important;
 background: linear-gradient(rgba(27, 53, 102, 0.8), rgba(27, 53, 102, 0.9)), url(../img/background/page-bg.jpg) !important;
 background-size: cover !important;
 background-position: center !important;
 margin-bottom: 40px !important;
}

.breadcrumb-bg {
 background: rgba(255, 255, 255, 0.1) !important;
 backdrop-filter: blur(5px) !important;
 padding: 10px 25px !important;
 border-radius: 50px !important;
 display: inline-block !important;
 border: 1px solid rgba(255, 255, 255, 0.2) !important;
}

.breadcrumb-bg li {
 color: #fff !important;
 font-size: 14px !important;
 font-weight: 500 !important;
}

.breadcrumb-bg li a {
 color: rgba(255, 255, 255, 0.8) !important;
 transition: var(--transition-fast) !important;
}

.breadcrumb-bg li a:hover {
 color: var(--accent) !important;
 text-decoration: none !important;
}



/* UI Enhancement Tokens */
.rich-text-content { word-wrap: break-word !important; line-height: 1.8 !important; }
.rich-text-content img { max-width: 100% !important; height: auto !important; border-radius: 12px !important; }

.page-area {
    padding: 100px 0 60px !important;
    background: linear-gradient(rgba(27, 53, 102, 0.85), rgba(27, 53, 102, 0.95)), url("../img/background/page-bg.jpg") !important;
    background-size: cover !important;
    background-position: center !important;
}

.breadcrumb-bg {
    background: rgba(255, 255, 255, 0.1) !important;
    backdrop-filter: blur(8px) !important;
    padding: 10px 25px !important;
    border-radius: 50px !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
}

/* Card responsiveness for mobile */
@media (max-width: 767px) {
    .premium-card [style*="padding: 35px"] { padding: 15px !important; }
    .premium-card h2 { font-size: 20px !important; }
}

/* ================================================================
   Survey Results UI/UX Pro Max Styles (Dashboard & Frontend)
   ================================================================ */

body, #page-wrapper {
    background-color: #F8FAFC !important;
}

h1.page-header, h2.page-header, h3.page-header, h4.page-header, h5.page-header, h6.page-header, .page-header {
    font-weight: 700;
    font-size: 15px !important;
    color: #1E293B;
    border-bottom: 2px solid #E2E8F0;
    padding-bottom: 15px;
    margin-top: 15px;
    margin-bottom: 20px;
    background-color: #ffffff;
    padding: 15px 20px;
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}
.page-header a {
    color: #3B82F6;
    text-decoration: none;
    font-size: 15px !important;
}
.page-header a:hover {
    color: #2563EB;
}

.panel {
    border-radius: 12px;
    border: none;
    box-shadow: 0 4px 6px -1px rgba(0,0,0,0.05), 0 2px 4px -1px rgba(0,0,0,0.03);
    background: #FFFFFF;
    overflow: hidden;
    margin-bottom: 25px;
}

.panel-heading {
    background-color: #FFFFFF !important;
    color: #0F172A !important;
    border-bottom: 1px solid #F1F5F9 !important;
    font-size: 1.15rem;
    font-weight: 600;
    padding: 18px 24px;
}

.panel-primary > .panel-heading {
    border-bottom: 2px solid #3B82F6 !important;
}

.panel-body {
    padding: 24px;
}

.table {
    margin-bottom: 0;
    border-collapse: separate;
    border-spacing: 0;
}
.table-bordered {
    border: none;
}
.table > tbody > tr > td, .table > tbody > tr > th {
    vertical-align: middle;
    padding: 16px 24px;
    border-top: none;
    border-bottom: 1px solid #F1F5F9;
}
.table > tbody > tr > td:first-child {
    color: #64748B;
    font-weight: 500;
}
.table > tbody > tr > td:nth-child(2) {
    color: #1E293B;
    font-weight: 500;
}

.table-hover > tbody > tr:hover {
    background-color: #F8FAFC;
    transition: background-color 0.2s ease;
}

tr[style*="background-color: #535353"] {
    background-color: #1E293B !important;
    color: #FFFFFF !important;
}
tr[style*="background-color: #535353"] th {
    border-bottom: none !important;
}
tr[style*="background-color: #d16d0c"] {
    background-color: #F1F5F9 !important;
    color: #0F172A !important;
}
tr[style*="background-color: #d16d0c"] td {
    font-weight: 600 !important;
}

/* Category Progress Bars */
.progress {
    height: 20px;
    border-radius: 99px;
    background-color: #E2E8F0;
    box-shadow: inset 0 1px 2px rgba(0,0,0,0.05);
    margin-bottom: 0;
    margin-top: 5px;
}
.progress-bar {
    box-shadow: none;
    line-height: 20px;
    font-size: 13px;
    font-weight: 600;
    border-radius: 99px;
    color: #ffffff;
}

/* Labels */
.label {
    border-radius: 9999px;
    padding: 6px 14px !important;
    font-weight: 500;
    display: inline-block;
}
.label-success {
    background-color: #ECFDF5;
    color: #059669;
    border: 1px solid #A7F3D0;
}
.label-danger {
    background-color: #FEF2F2;
    color: #DC2626;
    border: 1px solid #FECACA;
}
.label-warning {
    background-color: #FFFBEB;
    color: #D97706;
    border: 1px solid #FDE68A;
}

/* Pie Chart */
.statChartHolder {
    width: 100%;
    position: relative;
    padding: 20px 0;
    display: flex;
    justify-content: center;
}
.progress-pie-chart {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background-color: #E2E8F0;
  position: relative;
  box-shadow: 0 4px 10px rgba(0,0,0,0.05);
}
.progress-pie-chart.gt-50 {
  background-color: #3B82F6;
}
.ppc-progress {
  content: "";
  position: absolute;
  border-radius: 50%;
  left: calc(50% - 100px);
  top: calc(50% - 100px);
  width: 200px;
  height: 200px;
  clip: rect(0, 200px, 200px, 100px);
}
.ppc-progress .ppc-progress-fill {
  content: "";
  position: absolute;
  border-radius: 50%;
  left: calc(50% - 100px);
  top: calc(50% - 100px);
  width: 200px;
  height: 200px;
  clip: rect(0, 100px, 200px, 0);
  background: #3B82F6;
  transform: rotate(60deg);
  transition: transform 1s ease-out;
}
.gt-50 .ppc-progress {
  clip: rect(0, 100px, 200px, 0);
}
.gt-50 .ppc-progress .ppc-progress-fill {
  clip: rect(0, 200px, 200px, 100px);
  background: #E2E8F0;
}
.ppc-percents {
  content: "";
  position: absolute;
  border-radius: 50%;
  left: calc(50% - 173.9px/2);
  top: calc(50% - 173.9px/2);
  width: 173.9px;
  height: 173.9px;
  background: #FFFFFF;
  text-align: center;
  display: table;
  box-shadow: inset 0 2px 4px rgba(0,0,0,0.05);
}
.ppc-percents span {
  display: block;
  font-size: 2.5em;
  font-weight: 700;
  color: #1E293B;
}
.pcc-percents-wrapper {
  display: table-cell;
  vertical-align: middle;
}

/* ---------------------------------------------------
    PRINT STYLES - Professional PDF Report
----------------------------------------------------- */
/* Global Print Header Hidden by Default on Screen */
.print-header, .brand-header { display: none; }

@media print, .is-generating-pdf {
    /* Hide everything and reset layout */
    body * { visibility: hidden !important; }
    #wrapper, .page-area, .header-area, footer, .breadcumb-area { display: none !important; padding: 0 !important; margin: 0 !important; height: 0 !important; }
    
    #printable-report, #printable-report * { visibility: visible !important; }
    
    .print-header, .brand-header {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
    }
    
    #printable-report {
        position: relative !important;
        width: 780px !important;
        margin: 0 auto !important;
        padding: 40px !important;
        background: white !important;
        direction: rtl !important;
        font-family: 'Droid Arabic Kufi', sans-serif !important;
    }

    .no-print { display: none !important; }

    .row {
        display: table !important;
        width: 100% !important;
        border-spacing: 20px 0 !important;
        border-collapse: separate !important;
        float: none !important;
    }

    .col-md-6, .col-md-12 {
        display: table-cell !important;
        vertical-align: top !important;
        float: none !important;
    }

    .col-md-6 { width: 50% !important; }
    .col-md-12 { width: 100% !important; }

    .print-header {
        display: block !important;
        text-align: center;
        margin-bottom: 60px;
        padding: 30px;
        background: #F8FAFC;
        border-radius: 16px;
        border: 1px solid #E2E8F0;
    }

    .panel {
        border: 1px solid #E2E8F0 !important;
        box-shadow: none !important;
        border-radius: 20px !important;
        background: #FFFFFF !important;
        overflow: hidden;
    }

    .panel-heading {
        background-color: #F1F5F9 !important;
        border-bottom: 1px solid #E2E8F0 !important;
        padding: 20px !important;
    }

    .progress {
        background-color: #F1F5F9 !important;
        height: 10px !important;
    }

    h2, h4, h5, h6 { color: #0F172A !important; }
}


/* ────────────────────────────────────────────────────────────────
   ASSESSMENT & SURVEY STYLES
   ──────────────────────────────────────────────────────────────── */
.assessment-container { display: flex !important; gap: 30px !important; margin-top: 40px !important; align-items: flex-start !important; }
.assessment-sidebar { width: 280px !important; flex-shrink: 0 !important; position: sticky !important; top: 100px !important; height: fit-content !important; z-index: 10; }
.assessment-content { flex-grow: 1 !important; min-width: 0 !important; }

/* Category Stepper */
.cat-stepper { background: white; border-radius: 16px; border: 1px solid #E2E8F0; overflow: hidden; box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05); }
.cat-item { display: flex; align-items: center; gap: 12px; padding: 15px 20px; border-bottom: 1px solid #F1F5F9; color: #64748B; cursor: pointer; transition: all 0.2s; text-decoration: none !important; }
.cat-item:last-child { border-bottom: none; }
.cat-item.active { background: #F8FAFC; color: #0F172A; border-right: 4px solid #3B82F6; }
.cat-item:hover:not(.active) { background: #F1F5F9; color: #334155; }
.cat-num { width: 28px; height: 28px; border-radius: 50%; background: #F1F5F9; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; }
.cat-item.active .cat-num { background: #3B82F6; color: white; }

/* Question Cards */
.q-card { background: white; border-radius: 20px; border: 1px solid #E2E8F0; padding: 25px; margin-bottom: 25px; transition: all 0.3s ease; }
.q-card:hover { border-color: #CBD5E1; box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.04); }
.q-header { display: flex; gap: 15px; margin-bottom: 20px; }
.q-num { color: #94A3B8; font-weight: 800; font-size: 14px; margin-top: 3px; }
.q-text { color: #1E293B; font-weight: 600; font-size: 16px; line-height: 1.6; }

/* Selection Chips */
.chip-group { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 20px; }
.chip-label { position: relative; flex: 1; min-width: 120px; cursor: pointer; }
.chip-label input { position: absolute; opacity: 0; cursor: pointer; }
.chip-content { display: flex; align-items: center; justify-content: center; gap: 8px; padding: 12px; border-radius: 12px; border: 2px solid #F1F5F9; background: #fff; transition: all 0.2s; font-weight: 700; font-size: 14px; text-align: center; }
.chip-label:hover .chip-content { border-color: #E2E8F0; background: #F8FAFC; }
.chip-label input:checked+.chip-content { border-color: #3B82F6; background: #EFF6FF; color: #1D4ED8; }
.chip-label input[value="1"]:checked+.chip-content { border-color: #10B981; background: #ECFDF5; color: #065F46; }
.chip-label input[value="2"]:checked+.chip-content { border-color: #EF4444; background: #FEF2F2; color: #991B1B; }
.chip-label input[value="3"]:checked+.chip-content { border-color: #F59E0B; background: #FFFBEB; color: #92400E; }

/* Sticky Progress Header */
.sticky-progress { position: sticky; top: 0; z-index: 100; background: rgba(255, 255, 255, 0.9); backdrop-filter: blur(8px); padding: 15px 0; border-bottom: 1px solid #E2E8F0; margin-bottom: 30px; display: flex; align-items: center; justify-content: space-between; }
.submit-btn { background: #0F172A; color: white !important; padding: 12px 40px; border-radius: 12px; font-weight: 700; border: none; transition: all 0.2s; cursor: pointer; }
.submit-btn:hover { background: #1E293B; transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); }

/* Admin Feedback & Edit Features */
.admin-feedback { background: #EFF6FF; border-radius: 12px; border-right: 4px solid #3B82F6; padding: 15px; margin-top: 15px; }
.admin-feedback-title { font-weight: 800; color: #1D4ED8; font-size: 13px; margin-bottom: 5px; }
.admin-comment { color: #1E40AF; font-size: 14px; line-height: 1.5; }
.file-section { background: #F8FAFC; border-radius: 12px; padding: 20px; margin-top: 15px; border: 1px dashed #CBD5E1; }
.file-title { font-weight: 800; color: #475569; font-size: 13px; margin-bottom: 15px; display: flex; align-items: center; gap: 8px; }

@media (max-width: 992px) {
    .assessment-container { flex-direction: column; }
    .assessment-sidebar { width: 100%; position: static; order: -1; }
}

/* ────────────────────────────────────────────────────────────────
   CLIENT DASHBOARD / MY TOOLS
   ──────────────────────────────────────────────────────────────── */
.my-tools-section { background: #F8FAFC; }
.tool-card { background: white; border-radius: 20px; border: 1px solid #E2E8F0; transition: all 0.3s ease; overflow: hidden; }
.tool-card:hover { transform: translateY(-5px); box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.05), 0 10px 10px -5px rgba(0, 0, 0, 0.02) !important; border-color: #CBD5E1; }
.tool-card-body { padding: 30px; }
.tool-info { display: flex; gap: 20px; margin-bottom: 25px; }
.tool-icon { width: 60px; height: 60px; border-radius: 15px; display: flex; align-items: center; justify-content: center; font-size: 24px; flex-shrink: 0; }
.tool-text { flex-grow: 1; }
.tool-title { font-weight: 800; color: #0F172A; margin-bottom: 8px; font-size: 18px; line-height: 1.4; }
.tool-desc { color: #64748B; font-size: 14px; margin: 0; line-height: 1.6; }
.progress-container { margin-bottom: 30px; }
.progress-label { display: flex; justify-content: space-between; font-size: 13px; color: #475569; margin-bottom: 8px; }
.tool-actions { display: flex; gap: 12px; }
.btn-action { flex: 1; padding: 12px; border-radius: 12px; text-align: center; font-size: 14px; font-weight: 700; text-decoration: none !important; transition: all 0.2s; display: flex; align-items: center; justify-content: center; gap: 8px; }
.btn-edit { background: #F1F5F9; color: #334155; }
.btn-edit:hover { background: #E2E8F0; color: #0F172A; }
.btn-print { background: #0F172A; color: white !important; }
.btn-print:hover { background: #1E293B; transform: scale(1.02); }
.empty-state { padding: 80px 20px; background: white; border-radius: 20px; border: 2px dashed #E2E8F0; }

/* ────────────────────────────────────────────────────────────────
   PDF GENERATION & REPORT STYLES
   ──────────────────────────────────────────────────────────────── */
#printable-report.mode-free .prof-only { display: none !important; }
#printable-report.mode-prof td.prof-only, #printable-report.mode-prof th.prof-only { display: table-cell !important; }
#printable-report.mode-prof div.prof-only, #printable-report.mode-prof .row.prof-only { display: block !important; }
.is-generating-pdf td.prof-only, .is-generating-pdf th.prof-only { display: table-cell !important; }
.is-generating-pdf div.prof-only, .is-generating-pdf .row.prof-only { display: block !important; }
.is-generating-pdf, .is-generating-pdf body { height: auto !important; overflow: visible !important; width: 100% !important; }
.is-generating-pdf #printable-report { padding: 20px !important; width: 100% !important; margin: 0 !important; display: block !important; background: white !important; height: auto !important; overflow: visible !important; }
.is-generating-pdf tr, .is-generating-pdf .panel { page-break-inside: avoid !important; }
.is-generating-pdf .table th, .is-generating-pdf .table td { padding: 6px 8px !important; font-size: 11px !important; line-height: 1.7 !important; vertical-align: middle !important; }
.is-generating-pdf h4, .is-generating-pdf h5 { margin: 5px 0 !important; }
.is-generating-pdf .col-md-6 { width: 48% !important; float: left !important; margin: 1%; }
