/* Hover Boxes Section */
.hover-boxes-section { 
    padding: 0px 0 40px 0;
    overflow: hidden;
}
.hover-boxes-section .section-title h2 { 
        font-size: 4rem;
    font-weight: 700;
    color: #9ec43d;
    text-align: center;
    margin: 0 0 40px 0;
    text-transform: uppercase;
    
}

.hover-boxes-container {
    display: flex;
    justify-content: center;
    align-items: stretch;
    gap: 0;
    max-width: 100%;
    margin: 0 auto;
    flex-wrap: wrap;
}

.hover-box {
    position: relative;
    width: 120px;
    height: 430px;
    margin: 0 6px;
    overflow: hidden;
    cursor: pointer;
    transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    background: linear-gradient(135deg, #2c2c2c 0%, #1a1a1a 100%);
    border-radius: 20px;
}

/* Background image - always visible */
.background-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 1;
    transition: all 0.4s ease;
    border-radius: 20px;
}

.hover-content {
    position: absolute;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
    top: 0;
    left: 0;
    z-index: 3;
    opacity: 0;
    visibility: hidden;
    transition: all 0.4s ease;
    background: rgba(0, 0, 0, 0.8);
    padding: 0 5px 0 5px;
    box-sizing: border-box;
}
.hover-content.h-client-content {
    position: absolute;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
    top: 0;
    left: 0;
    z-index: 3;
    opacity: 0;
    visibility: hidden;
    transition: all 0.4s ease;
    background: #fff;
    padding: 15px;
    box-sizing: border-box;
}

.hover-main {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    height: 100%;
}

.brand-logos { 
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 10px;
    padding: 5px 10px;
    align-content: center;
}
.brand-logos.h-client-logos { 
    padding: 20px 10px;
    display: block;
    /* display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 10px; 
    align-content: center; */
}
.brand-logos.h-client-logos img { 
    width: 100%;
    height: auto;
    object-fit: contain;
}

.hover-box::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(0deg, rgb(0 0 0) 0%, rgb(0 0 0 / 62%) 50%, rgb(135 135 135 / 80%) 100%);
    z-index: 2;
    transition: opacity 0.4s ease;
        border-radius: 15px;
}

.hover-box:hover::before,
.hover-box.active::before {
    opacity: 0.3;
}

/* Show hover-content on hover or when active */
.hover-box:hover .hover-content,
.hover-box.active .hover-content {
    opacity: 1;
    visibility: visible;
        padding: 3px 20px 0px 10px;
}

/* Mobile touch improvements */
@media (max-width: 768px) {
    .hover-content {
        transition: all 0.3s ease;
    }
    
    .hover-box.active .hover-content {
        opacity: 1 !important;
        visibility: visible !important;
    }
    
    /* Ensure content is always visible on mobile when active */
    .hover-box.active .hover-main,
    .hover-box.active .brand-logos {
        opacity: 1;
        transform: none;
        align-items: flex-start;
    }
}

/* First hover-box open by default - only when active */
.hover-box:first-child.active .hover-content {
    opacity: 1;
    visibility: visible;
    padding: 3px 20px 0px 10px;
}

.hover-box:first-child.active {
    width: 560px;
    transform: translateY(0px);
    box-shadow: 0 20px 40px rgba(0,0,0,0.6);
}

.hover-box:first-child.active::before {
    opacity: 0.3;
}

.hover-box:first-child.active .background-image {
    transform: scale(1.1);
    filter: blur(2px) brightness(0.3);
}

/* Main logo in hover content */
.main-logo {
    max-width: 100%; 
    object-fit: contain; 
    transition: all 0.4s ease;
    filter: brightness(1);
    height: 100%;
}

/* Brand logos styling */
.brand-logos img {
    width: 90px;
    height: 50px;
    object-fit: contain;
    background: #fff;
    border-radius: 2px;
    /* padding: 0px;
        border: 1px solid #373737; */
    transition: all 0.3s ease;
    opacity: 0.9;
}

.brand-logos img:hover {
    /* transform: scale(1.1); 
    box-shadow: 0 4px 12px rgba(255, 255, 255, 0.3); */
     opacity: 1;
}

.hover-box:hover .background-image,
.hover-box.active .background-image {
    transform: scale(1.1);
    filter: blur(2px) brightness(0.3);
}

.hover-title {
    position: absolute;
    right: 0;
    bottom: 80px;
    left: 0;
    transform: translateY(50%) rotate(-90deg);
    transform-origin: center center;
    color: #fff;
    font-size: 22px;
    font-weight: 700;
    letter-spacing: 3px;
    text-transform: uppercase;
    text-align: center;
    z-index: 99;
    white-space: nowrap;
    transition: all 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    text-shadow: 2px 2px 4px rgba(0,0,0,0.8);
    pointer-events: none;
}

.hover-box:hover .hover-title,
.hover-box.active .hover-title {
    transform: translateY(0) rotate(0deg);
    bottom: 22px;
    letter-spacing: 1px;
    left: 18px;
    right: auto;
    text-align: left;
    font-size: 20px;
    color: #fff;
    text-shadow: 2px 2px 8px rgba(0,0,0,0.9);
}
.hover-box:hover .h-client-title,
.hover-box.active .h-client-title {
    transform: translateX(4%) rotate(0deg);
    bottom: 25px;
    letter-spacing: 0px;
    left: 0;
    font-size: 22px;
    color: #000000;
    text-shadow: none;
    font-weight: bold;
}

.hover-box:hover,
.hover-box.active {
    width: 560px;
    transform: translateY(0px); 
}
 

/* Responsive Design */
@media (min-width: 1921px) 
{

    .hover-title { 
        font-size: 22px;
        bottom: 120px;
        text-align: left;
}
.brand-logos img {
    width: 100%;
    height: 53px; 
}

.hover-box {  
    height: 450px;
}

    .hover-box:hover,
    .hover-box.active,
    .hover-box:first-child.active {
        width: 660px;
    }

    .hover-box:hover .hover-content,
    .hover-box.active .hover-content,
    .hover-box:first-child.active .hover-content {
        align-items: stretch;
        padding: 8px 16px 8px 8px;
    }

    .hover-box:hover .hover-main,
    .hover-box.active .hover-main,
    .hover-box:first-child.active .hover-main {
        flex: 0 0 200px;
        width: 200px;
        min-width: 200px;
        max-width: 200px;
        height: 100%;
        align-items: stretch;
        justify-content: flex-start;
        overflow: hidden;
    }

    .hover-box:hover .main-logo,
    .hover-box.active .main-logo,
    .hover-box:first-child.active .main-logo {
        width: 100%;
        height: 100%;
        max-width: none;
        min-height: 100%;
        object-fit: contain;
        object-position: top center;
        display: block;
    }

    .hover-box:hover .brand-logos,
    .hover-box.active .brand-logos,
    .hover-box:first-child.active .brand-logos {
        flex: 1;
        min-width: 0;
        grid-template-columns: repeat(3, 1fr);
        align-content: start;
        padding: 8px 10px 40px 10px;
    }
}

@media (min-width: 2560px) {

    .hover-box:hover,
    .hover-box.active,
    .hover-box:first-child.active {
        width: 760px;
    }

    .hover-box:hover .hover-main,
    .hover-box.active .hover-main,
    .hover-box:first-child.active .hover-main {
        flex: 0 0 220px;
        width: 220px;
        min-width: 220px;
        max-width: 220px;
    }

    .hover-box:hover .brand-logos img,
    .hover-box.active .brand-logos img,
    .hover-box:first-child.active .brand-logos img {
        width: 100%;
        height: 53px;
    }

    .h-client-logos-container .brand-logos.h-client-logos img
    {
        height: auto !important;
    }

    .hover-box:hover .hover-title,
    .hover-box.active .hover-title,
    .hover-box:first-child.active .hover-title {
        bottom: 18px;
        left: 12px;
        font-size: 22px;
        z-index: 10;
    }
}


@media (max-width: 1400px) 
{
    .hover-boxes-container {
        max-width: 1200px;
        gap: 5px;
    }
    .hover-box {
        width: 90px;
        height: 390px;
    }
    .hover-box.h-client-logo-box { 
        height: 430px;
    }
    .hover-box:hover,
    .hover-box.active {
        width: 530px;
    }
    .hover-box:first-child.active {
        width: 550px;
    }
    .hover-title { 
        font-size: 20px;
        letter-spacing: 2px;
    }
    .brand-logos img { 
        height: 45px;
    }
}

@media (max-width: 1200px) {

    .hover-boxes-section .section-title h2 { 
        font-size: 3rem; 
    
}

    .brand-logos.h-client-logos img {
    width: 100%; 
}
.brand-logos.h-client-logos { 
    grid-template-columns: 1fr 1fr 1fr 1fr; 
}

    .hover-title {
        font-size: 17px;
        letter-spacing: 2px;
        bottom: 60px;
    }
    .hover-boxes-container {
        gap: 8px;
        flex-wrap: nowrap;
        justify-content: center;
        padding: 0 15px;
    }
    .hover-box {
        width: 75px;
        height: 330px;
    }
    .hover-box:hover,
    .hover-box.active {
        width: 440px;
    }
    .hover-box:first-child.active {
        width: 440px;
    }
    .hover-box.h-client-logo-box:first-child.active {
       width: 100%;
        margin: 0 auto;
        margin-bottom: 20px;
    }
        .hover-box.h-client-logo-box {
        height: 390px;
    }
    .brand-logos {
        gap: 8px;
        padding: 15px 8px;
    }
    .brand-logos img {
        width: 70px;
        height: 36px;
    }
    .hover-box:hover .hover-title,
    .hover-box.active .hover-title {
        bottom: 18px;
        left: 14px;
        font-size: 18px;
    }
}

@media (max-width: 992px) {

    .hover-boxes-section {
        padding: 40px 0;
    }

    .hover-boxes-section .section-title h2 { 
        font-size: 2.8rem;
        margin-bottom: 30px;
    }

    .hover-box.h-client-logo-box:hover, .hover-box.h-client-logo-box.active { 
        height: 530px; 
    }

    .brand-logos.h-client-logos {
        grid-template-columns: 1fr 1fr 1fr;
    }

    .hover-boxes-container {
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        justify-content: center;
        align-items: stretch;
        gap: 6px;
        padding: 0 16px;
        max-width: 100%;
    }

    .hover-box {
        width: 58px;
        height: 320px;
        margin: 0;
        flex-shrink: 0;
        border-radius: 14px;
    }

    .hover-box:hover,
    .hover-box.active,
    .hover-box:first-child.active {
        width: 100%;
        max-width: 440px;
        transform: none;
    }

    .hover-title {
        font-size: 15px;
        letter-spacing: 2px;
        bottom: 50px;
        left: 0;
        right: 0;
        transform: translateY(50%) rotate(-90deg);
    }

    .hover-box:hover .hover-title,
    .hover-box.active .hover-title {
        transform: translateY(0) rotate(0deg);
        top: auto;
        bottom: 12px;
        left: 14px;
        right: auto;
        font-size: 16px;
        letter-spacing: 1px;
    }

    .hover-content {
        flex-direction: row;
        padding: 8px 8px 36px 8px;
        align-items: stretch;
        justify-content: space-between;
        background: rgba(0, 0, 0, 0.88);
        gap: 6px;
    }

    .hover-main {
        flex: 0 0 40%;
        width: 40%;
        margin: 0;
        text-align: center;
        min-height: auto;
        height: 100%;
        display: flex;
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-start;
    }

    .main-logo {
        width: 100%;
        max-width: 100%;
        height: 100%;
        max-height: 100%;
        object-fit: contain;
        object-position: top center;
    }

    .brand-logos {
        flex: 1;
        width: auto;
        grid-template-columns: repeat(3, 1fr);
        gap: 4px;
        padding: 0;
        align-content: start;
        justify-items: stretch;
    }
    .brand-logos img {
        width: 100%;
        max-width: 80px; 
    }

    .brand-logos.h-client-logos img {
        width: 100%; 
        margin-top: 40px;
    }
}

@media (max-width: 768px) {

    .hover-boxes-section {
        padding: 30px 0;
    }

    .background-image { 
        border-radius: 12px;
    }

    .hover-box::before { 
        border-radius: 12px;
    }

    .hover-boxes-section .section-title h2 { 
        font-size: 2.2rem;
        margin-bottom: 25px;
    }

    .hover-boxes-container {
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        justify-content: center;
        align-items: stretch;
        gap: 5px;
        padding: 0 12px;
        max-width: 100%;
        width: 100%;
    }

    .hover-box {
        width: 50px;
        height: 210px;
        margin: 0;
        flex-shrink: 0;
        border-radius: 12px;
    }

    .hover-box:hover,
    .hover-box.active,
    .hover-box:first-child.active {
        width: 100%;
        max-width: 360px;
        transform: none;
    }

    .hover-box.h-client-logo-box {
        width: 100%;
        height: 50px;
        margin: 0 0 10px 0;
        border-radius: 5px;
        flex-shrink: 1;
    }

    .hover-title {
        font-size: 13px;
        letter-spacing: 1.5px;
        bottom: 40px;
        left: 0;
        right: 0;
        transform: translateY(50%) rotate(-90deg);
    }

    .hover-title.h-client-title {
        font-size: 12px;
        letter-spacing: 1px;
        bottom: 16px;
        left: 20px;
        transform: none;
    }

    .hover-box:hover .hover-title,
    .hover-box.active .hover-title {
        transform: translateY(0) rotate(0deg);
        font-size: 14px;
        top: auto;
        bottom: 10px;
        left: 12px;
        right: auto;
        letter-spacing: 1px;
    }

    .hover-box.h-client-logo-box:hover, .hover-box.h-client-logo-box.active {
        height: 530px;
        width: 100%;
        margin: 0 auto 20px;
    }

    .hover-content {
        flex-direction: row;
        padding: 6px 6px 32px 6px;
        align-items: stretch;
        justify-content: space-between;
        background: rgba(0, 0, 0, 0.9);
        border-radius: 12px;
        margin: 0;
        width: 100%;
        height: 100%;
        gap: 5px;
    }

    .hover-main {
        flex: 0 0 33%;
        width: 33%;
        margin: 0;
        text-align: center;
        display: flex;
        flex-direction: column;
        justify-content: flex-start;
        align-items: stretch;
        height: 100%;
    }

    .main-logo {
        width: 100%;
        max-width: 100%;
        height: 100%;
        max-height: 100%;
        margin: 0;
        object-fit: contain;
        object-position: top center;
    }

    .brand-logos {
        flex: 1;
        width: auto;
        grid-template-columns: repeat(3, 1fr);
        gap: 3px;
        padding: 0;
        justify-items: stretch;
        align-content: start;
    }

    .brand-logos img {
        width: 100%;
        max-width: 75px;
        height: 25px;
    }
}


@media (max-width: 767px) {
    .hover-box:first-child.active .hover-content { 
        padding: 44px 10px 12px 10px;
    }

  .hover-box:hover .hover-content,
  .hover-box.active .hover-content {
    /* Show content only when .active is present */
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
  .hover-box .hover-content {
    /* Hide by default */
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.3s, visibility 0.3s;
  }
}

@media (max-width: 640px) {
    .hover-box:hover,
    .hover-box.active,
    .hover-box:first-child.active { 
        max-width: 270px; 
    }
    .brand-logos img {
        width: 100%;
        max-width: 75px;
        height: 23px;
    }
    .hover-boxes-container .hover-box:hover .hover-content, .hover-boxes-container .hover-box.active .hover-content, .hover-boxes-container .hover-box:first-child.active .hover-content {
        padding: 32px 10px 10px 12px;
    }
    .hover-box { 
        height: 200px; 
    }
}

@media (max-width: 576px) {

    .hover-box.h-client-logo-box:hover, .hover-box.h-client-logo-box.active {
        height: 300px; 
    }

    .hover-boxes-section .section-title h2 {
        font-size: 2rem; 
        margin-bottom: 20px;
    }
    .hover-boxes-section {
        padding: 20px 0;
    }

    .hover-boxes-container { 
        display: flex;
        flex-direction: column;
        flex-wrap: nowrap;
        padding: 0 14px;
        gap: 10px;
        max-width: 100%;
        width: 100%;
    }

    .hover-box {
        position: relative;
        width: 100%;
        max-width: 100%;
        height: 52px;
        margin: 0;
        border-radius: 12px;
        overflow: hidden;
    }

    .hover-box:hover,
    .hover-box.active,
    .hover-box:first-child.active {
        width: 100%;
        max-width: 100%;
        height: auto;
        min-height: 52px;
        transform: none;
        box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
    }

    .hover-title {
        font-size: 16px;
        font-weight: 700;
        letter-spacing: 2px;
        bottom: 50%;
        left: 16px;
        right: auto;
        top: auto;
        transform: translateY(50%) rotate(0deg);
        text-align: left;
    }

    .hover-box:hover .hover-title,
    .hover-box.active .hover-title {
        transform: translateY(0) rotate(0deg);
        top: 14px;
        bottom: auto;
        left: 16px;
        right: auto;
        font-size: 18px;
        letter-spacing: 1.5px;
        text-align: left;
        text-shadow: 2px 2px 6px rgba(0, 0, 0, 0.9);
    }

    .hover-content {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        padding: 0;
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-start;
        background: rgba(0, 0, 0, 0.92);
        border-radius: 12px;
        margin: 0;
        gap: 10px;
        transition: opacity 0.3s ease, visibility 0.3s ease;
    }

    .hover-box:hover .hover-content,
    .hover-box.active .hover-content {
        position: relative;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        height: auto;
        padding: 48px 12px 14px 12px;
    }

    .hover-main {
        width: 100%;
        margin: 0;
        text-align: center;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: flex-start;
        flex: 0 0 auto;
        height: 215px;
        min-height: auto;
    }

    .main-logo {
        width: auto;
        max-width: 100%;
        max-height: 215px;
        height: 100%;
        margin: 0;
        object-fit: contain;
        border-radius: 8px;
    }

    .brand-logos {
        width: 100%;
        grid-template-columns: repeat(4, 1fr);
        gap: 5px;
        padding: 0;
        max-width: none;
        justify-items: stretch;
        align-content: start;
        flex: 0 0 auto;
    }

    .brand-logos img {
        width: 100%;
        max-width: 100%;
        height: 30px;
        padding: 2px;
        border-radius: 3px;
        background: #fff;
        object-fit: contain;
    }
}

@media (max-width: 480px) {

    .brand-logos.h-client-logos img {
        width: 100%; 
        margin: 30px 0 0 0;
    }

    .hover-boxes-container {
        padding: 0 12px;
        gap: 8px;
    }

    .hover-box {
        height: 48px;
        border-radius: 10px;
    }

    .hover-box:hover,
    .hover-box.active,
    .hover-box:first-child.active {
        height: auto;
        min-height: 48px;
    }

    .hover-box.h-client-logo-box:first-child.active {
        width: 100%;
        height: 280px;
    }

    .hover-title {
        font-size: 15px;
        letter-spacing: 1.5px;
        left: 14px;
    }

    .hover-box:hover .hover-title,
    .hover-box.active .hover-title {
        font-size: 17px;
        top: 12px;
        left: 14px;
    }

    .hover-box:hover .hover-content,
    .hover-box.active .hover-content {
        padding: 44px 10px 12px 10px;
        border-radius: 10px;
        gap: 8px;
    }

    .hover-main {
        height: 250px;
        align-items: flex-start;
    }

    .main-logo {
        max-height: 250px;
    }

    .brand-logos {
        grid-template-columns: repeat(4, 1fr);
        gap: 4px;
    }

    .brand-logos img {
        max-width: 100%;
        height: 48px;
        padding: 0px;
    }
}

@media (max-width: 380px) {

    .hover-box:hover,
    .hover-box.active,
    .hover-box:first-child.active {
        height: auto;
        min-height: 46px;
    }

    .hover-title {
        font-size: 14px;
        letter-spacing: 1px;
    }

    .hover-box:hover .hover-title,
    .hover-box.active .hover-title {
        font-size: 16px;
    }

    .hover-main {
        height: 220px;
        align-items: flex-start;
    }

    .main-logo {
        max-height: 220px;
       
    }

    .brand-logos {
        grid-template-columns: repeat(4, 1fr);
        gap: 3px;
    }

    .brand-logos img {
        height: 48px;
    }
}

/* ==========================================================================
   OUR CLIENTS SECTION  —  Scoped to .h-client-logos-container
   --------------------------------------------------------------------------
   These rules apply ONLY to the "Our Clients" hover-boxes block.
   The Divisions section uses the same base classes but a DIFFERENT parent
   (no .h-client-logos-container), so it is fully untouched by this block.

   Design intent (huge screen / desktop / tablet):
     - Active panel = white card showing the supplier logo sheet image.
     - Inactive boxes = narrow strips with dark imagery + rotated white title.

   Mobile (<= 768px):
     - All boxes stack vertically as full-width accordion rows.
     - Active row expands to reveal the logo sheet image.
   ========================================================================== */

/* --- Container --- */
.h-client-logos-container {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: stretch;
    gap: 8px;
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 20px;
}

/* --- Default box (inactive strip) --- */
.h-client-logos-container .hover-box.h-client-logo-box {
    flex: 0 0 auto;
    width: 110px;
    height: 430px;
    margin: 0;
    border-radius: 18px;
    transition: width 0.45s cubic-bezier(0.25, 0.46, 0.45, 0.94),
                height 0.4s ease,
                box-shadow 0.4s ease;
}

/* --- Active panel size (desktop default) --- */
.h-client-logos-container .hover-box.h-client-logo-box:hover,
.h-client-logos-container .hover-box.h-client-logo-box.active,
.h-client-logos-container .hover-box.h-client-logo-box:first-child.active {
    width: 570px;
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.35);
}

/* --- Active panel content: white card --- */
.h-client-logos-container .hover-content.h-client-content {
    flex-direction: column;
    background: #ffffff;
    padding: 20px 22px 56px 22px;
    align-items: center;
    justify-content: center;
    border-radius: 18px;
}

/* Override the SHARED .hover-box:hover .hover-content padding so client
   panel keeps its proper symmetric padding instead of inheriting the
   division section's tight padding. */
.h-client-logos-container .hover-box:hover .hover-content,
.h-client-logos-container .hover-box.active .hover-content,
.h-client-logos-container .hover-box:first-child.active .hover-content {
    padding: 20px 22px 56px 22px;
}

/* --- Logo sheet image fills the panel cleanly --- */
.h-client-logos-container .brand-logos.h-client-logos {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    padding: 0;
    margin: 0;
}

.h-client-logos-container .brand-logos.h-client-logos img {
    width: 100%;
    height: 100%;
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    object-position: center;
    display: block;
    margin: 0;
    background: transparent;
    border-radius: 0;
    opacity: 1;
}

/* --- Title: vertical white text on inactive strips --- */
.h-client-logos-container .hover-title.h-client-title {
    color: #ffffff;
    text-shadow: 2px 2px 6px rgba(0, 0, 0, 0.85);
}

/* --- Title: horizontal dark text at bottom-left of active card --- */
.h-client-logos-container .hover-box:hover .h-client-title,
.h-client-logos-container .hover-box.active .h-client-title,
.h-client-logos-container .hover-box:first-child.active .h-client-title {
    transform: rotate(0deg);
    top: 18px;
    left: 24px;
    right: auto;
    text-align: left;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 1px;
    color: #1a1a1a;
    text-shadow: none;
    z-index: 5;
    text-shadow: none !important;
}

/* ==========================================================================
   HUGE SCREEN  ( >= 2560px / 4K )
   ========================================================================== */
@media (min-width: 2560px) {
    .h-client-logos-container {
        max-width: 2000px;
        gap: 12px;
    }
    .h-client-logos-container .hover-box.h-client-logo-box {
        width: 200px;
        height: 520px;
        border-radius: 24px;
    }
    .h-client-logos-container .hover-box.h-client-logo-box:hover,
    .h-client-logos-container .hover-box.h-client-logo-box.active,
    .h-client-logos-container .hover-box.h-client-logo-box:first-child.active {
        width: 700px;
        border-radius: 24px;
    }

    .h-client-logos-container .hover-box:hover .hover-content,
    .h-client-logos-container .hover-box.active .hover-content,
     .h-client-logos-container .hover-box:first-child.active
      .hover-content {
       padding: 12px;
   }

   
    .h-client-logos-container .hover-content.h-client-content,
    .h-client-logos-container .hover-box:hover .hover-content,
    .h-client-logos-container .hover-box.active .hover-content {
        padding: 28px 30px 70px 30px;
        border-radius: 24px;
    }


    .h-client-logos-container .hover-box:hover .h-client-title,
    .h-client-logos-container .hover-box.active .h-client-title {
        bottom: 24px;
        left: 32px !important;
        font-size: 24px;
    }
}

/* ==========================================================================
   LARGE SCREEN  ( 1921px – 2559px / 2K & ultra-wide )
   ========================================================================== */
@media (min-width: 1921px) and (max-width: 2559px) {
    .h-client-logos-container {
        max-width: 1700px;
        gap: 10px;
    }
    .h-client-logos-container .hover-box.h-client-logo-box {
        width: 170px;
        height: 550px;
        border-radius: 22px;
    }
    .h-client-logos-container .hover-box.h-client-logo-box:hover,
    .h-client-logos-container .hover-box.h-client-logo-box.active,
    .h-client-logos-container .hover-box.h-client-logo-box:first-child.active {
        width: 760px;
        border-radius: 22px;
    }
    .h-client-logos-container .hover-content.h-client-content,
    .h-client-logos-container .hover-box:hover .hover-content,
    .h-client-logos-container .hover-box.active .hover-content {
        padding: 24px 26px 64px 26px;
        border-radius: 22px;
    }
    .h-client-logos-container .hover-box:hover .h-client-title,
    .h-client-logos-container .hover-box.active .h-client-title {
        bottom: 22px;
        left: 35px !important;
        font-size: 21px;
    }
}

/* ==========================================================================
   STANDARD DESKTOP / SMALL DESKTOP  ( 1201px – 1400px )
   Keeps the row layout from the design image. Slightly tighter sizing.
   ========================================================================== */
@media (max-width: 1400px) {
    .h-client-logos-container {
        max-width: 1200px;
        gap: 6px;
        padding: 0 18px;
    }
    .h-client-logos-container .hover-box.h-client-logo-box {
        width: 95px;
        height: 410px;
        border-radius: 16px;
    }
    .h-client-logos-container .hover-box.h-client-logo-box:hover,
    .h-client-logos-container .hover-box.h-client-logo-box.active,
    .h-client-logos-container .hover-box.h-client-logo-box:first-child.active {
        width: 560px;
        border-radius: 16px;
    }
    .h-client-logos-container .hover-content.h-client-content,
    .h-client-logos-container .hover-box:hover .hover-content,
    .h-client-logos-container .hover-box.active .hover-content {
        padding: 18px 20px 52px 20px;
        border-radius: 16px;
    }
    .h-client-logos-container .hover-box:hover .h-client-title,
    .h-client-logos-container .hover-box.active .h-client-title {
        bottom: 16px;
        left: 22px;
        font-size: 17px;
    }
}

/* ==========================================================================
   LAPTOP / iPad LANDSCAPE  ( 993px – 1200px )
   Keep SINGLE-ROW design (active card + 5 narrow strips), no wrapping.
   Fits 1024 x 768 perfectly: 440 + 75*5 + 5*5 + 28 = 868px.
   ========================================================================== */
@media (max-width: 1200px) {
    .h-client-logos-container {
        flex-wrap: nowrap;
        justify-content: center;
        gap: 5px;
        padding: 0 14px;
        max-width: 100%;
        margin: 0 auto;
    }
    .h-client-logos-container .hover-box.h-client-logo-box {
        flex: 0 0 auto;
        width: 75px;
        height: 330px;
        margin: 0;
        min-width: 0;
        border-radius: 14px;
    }
    /* Active panel — applies to ANY active/hovered box (not only first) */
    .h-client-logos-container .hover-box.h-client-logo-box:hover,
    .h-client-logos-container .hover-box.h-client-logo-box.active,
    .h-client-logos-container .hover-box.h-client-logo-box:first-child.active {
        flex: 0 0 auto;
        width: 440px;
        height: 330px;
        min-height: 0;
        margin: 0;
        border-radius: 14px;
    }
    .h-client-logos-container .hover-content.h-client-content,
    .h-client-logos-container .hover-box:hover .hover-content,
    .h-client-logos-container .hover-box.active .hover-content {
        padding: 44px 16px 15px 16px !important;
        border-radius: 14px;
    }
    .h-client-logos-container .hover-title.h-client-title {
        font-size: 15px;
        letter-spacing: 2px;
        bottom: 60px;
    }
    .h-client-logos-container .hover-box:hover .h-client-title,
    .h-client-logos-container .hover-box.active .h-client-title,
    .h-client-logos-container .hover-box:first-child.active .h-client-title {
        bottom: 14px;
        left: 18px;
        font-size: 15px;
        letter-spacing: 1px;
    }
}

/* ==========================================================================
   TABLET  ( 769px – 992px )
   Single-row design preserved at smaller tablet widths.
   Fits 768+ : 360 + 60*5 + 5*5 + 24 = 709px.
   ========================================================================== */
@media (max-width: 992px) {
    .h-client-logos-container {
        flex-wrap: nowrap;
        gap: 5px;
        padding: 0 12px;
    }
    .h-client-logos-container .hover-box.h-client-logo-box {
        flex: 0 0 auto;
        width: 60px;
        height: 260px;
        border-radius: 12px;
    }
    .h-client-logos-container .hover-box.h-client-logo-box:hover,
    .h-client-logos-container .hover-box.h-client-logo-box.active,
    .h-client-logos-container .hover-box.h-client-logo-box:first-child.active {
        flex: 0 0 auto;
        width: 360px;
        max-width: none;          /* kill inherited 340px cap from shared rule */
        height: 260px;
        min-height: 0;
    }
    .h-client-logos-container .hover-content.h-client-content,
    .h-client-logos-container .hover-box:hover .hover-content,
    .h-client-logos-container .hover-box.active .hover-content {
        padding: 22px 14px 0px 14px !important;
        border-radius: 12px;
    }
    .h-client-logos-container .hover-title.h-client-title {
        font-size: 14px;
        letter-spacing: 1.5px;
        bottom: 50px;
    }
    .h-client-logos-container .hover-box:hover .h-client-title,
    .h-client-logos-container .hover-box.active .h-client-title,
    .h-client-logos-container .hover-box:first-child.active .h-client-title {
        top: 7px;
        left: 16px;
        font-size: 14px;
        letter-spacing: 1px;
    }
}

/* ==========================================================================
   MOBILE — STACKED ACCORDION  ( <= 768px )
   All 6 boxes stack vertically as full-width rows. The active row uses
   NATURAL FLOW (position: relative) so the card height grows to match the
   image's natural aspect — image renders at full container width, no caps.
   ========================================================================== */
@media (max-width: 768px) {
    .h-client-logos-container {
        flex-direction: column;
        flex-wrap: nowrap;
        gap: 10px;
        padding: 0 14px;
        max-width: 100%;
        width: 100%;
    }
    /* Inactive strip — full width, fixed height */
    .h-client-logos-container .hover-box.h-client-logo-box,
    .h-client-logos-container .hover-box.h-client-logo-box:first-child {
        flex: 0 0 auto;
        width: 100%;
        max-width: none;
        height: 58px;
        margin: 0;
        border-radius: 10px;
    }
    /* Active card — full width, height grows with content (image) */
    .h-client-logos-container .hover-box.h-client-logo-box:hover,
    .h-client-logos-container .hover-box.h-client-logo-box.active,
    .h-client-logos-container .hover-box.h-client-logo-box:first-child.active {
        width: 100%;
        max-width: none;          /* kill inherited 300px / 340px cap */
        height: auto;
        min-height: 0;
        border-radius: 10px;
        background: #ffffff;
        box-shadow: 0 8px 22px rgba(0, 0, 0, 0.18);
    }
    /* Hide background image + dark overlay when active so the white card stays clean.
       Selector covers BOTH .background-image class AND the direct-child <img>
       (defensive — protects against any markup edge-case where class isn't applied). */
    .h-client-logos-container .hover-box.h-client-logo-box:hover .background-image,
    .h-client-logos-container .hover-box.h-client-logo-box.active .background-image,
    .h-client-logos-container .hover-box.h-client-logo-box:first-child.active .background-image,
    .h-client-logos-container .hover-box.h-client-logo-box:hover > img,
    .h-client-logos-container .hover-box.h-client-logo-box.active > img,
    .h-client-logos-container .hover-box.h-client-logo-box:first-child.active > img {
        display: none !important;
    }
    .h-client-logos-container .hover-box.h-client-logo-box:hover::before,
    .h-client-logos-container .hover-box.h-client-logo-box.active::before,
    .h-client-logos-container .hover-box.h-client-logo-box:first-child.active::before {
        display: none;
    }
    /* Inactive title: centered vertically, horizontal white text on dark imagery */
    .h-client-logos-container .hover-title.h-client-title {
        position: absolute;
        top: 50%;
        left: 20px;
        right: auto;
        bottom: auto;
        transform: translateY(-50%) rotate(0deg);
        text-align: left;
        font-size: 15px;
        letter-spacing: 1.5px;
        color: #ffffff;
        text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.85);
    }
    /* Active title: SITS IN NATURAL FLOW at top of card — dark text */
    .h-client-logos-container .hover-box:hover .h-client-title,
    .h-client-logos-container .hover-box.active .h-client-title,
    .h-client-logos-container .hover-box:first-child.active .h-client-title {
        position: relative;
        top: auto;
        left: auto;
        right: auto;
        bottom: auto;
        transform: none;
        display: block;
        width: 100%;
        padding: 14px 18px 6px 18px;
        margin: 0;
        text-align: left;
        font-size: 16px;
        letter-spacing: 1px;
        color: #1a1a1a;
        text-shadow: none;
        z-index: 5;
    }
    /* Active hover-content: NATURAL FLOW — card grows with image */
    .h-client-logos-container .hover-box:hover .hover-content,
    .h-client-logos-container .hover-box.active .hover-content,
    .h-client-logos-container .hover-box:first-child.active .hover-content {
        position: relative;
        top: auto;
        left: auto;
        flex-direction: column;
        align-items: stretch;
        justify-content: flex-start;
        width: 100%;
        height: auto;
        padding: 0 0 14px 0 !important;
        background: #ffffff;
        border-radius: 10px;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
    }
    /* Brand-logos wrapper: full width, content-driven height */
    .h-client-logos-container .brand-logos.h-client-logos {
        display: block;
        width: 100%;
        height: auto;
        padding: 0 14px;
        margin: 0;
    }
    /* THE IMAGE — full size, natural aspect ratio, no caps */
    .h-client-logos-container .brand-logos.h-client-logos img {
        display: block;
        width: 100%;
        height: auto;
        max-width: 100%;
        max-height: none;       /* kill cap — let image be its natural size */
        object-fit: contain;
        margin: 0;
        background: transparent;
    }
}

/* ==========================================================================
   SMALL MOBILE  ( <= 576px )
   Same accordion model as 768, just tighter spacing.
   ========================================================================== */
@media (max-width: 576px) {
    .h-client-logos-container {
        gap: 8px;
        padding: 0 12px;
    }
    .h-client-logos-container .hover-box.h-client-logo-box,
    .h-client-logos-container .hover-box.h-client-logo-box:first-child {
        height: 54px;
        border-radius: 9px;
    }
    .h-client-logos-container .hover-box.h-client-logo-box:hover,
    .h-client-logos-container .hover-box.h-client-logo-box.active,
    .h-client-logos-container .hover-box.h-client-logo-box:first-child.active {
        width: 100%;
        max-width: none;
        height: auto;
        min-height: 0;
        border-radius: 9px;
    }
    .h-client-logos-container .hover-box:hover .hover-content,
    .h-client-logos-container .hover-box.active .hover-content,
    .h-client-logos-container .hover-box:first-child.active .hover-content {
        padding: 0 0 12px 0 !important;
        border-radius: 9px;
    }
    .h-client-logos-container .hover-title.h-client-title {
        font-size: 14px;
        left: 18px;
    }
    .h-client-logos-container .hover-box:hover .h-client-title,
    .h-client-logos-container .hover-box.active .h-client-title,
    .h-client-logos-container .hover-box:first-child.active .h-client-title {
        font-size: 15px;
        padding: 12px 16px 4px 16px;
        left: 0 !important;
    }
    .h-client-logos-container .brand-logos.h-client-logos {
        padding: 0 12px;
    }
}

/* ==========================================================================
   EXTRA-SMALL MOBILE  ( <= 480px )
   ========================================================================== */
@media (max-width: 480px) {
    .h-client-logos-container {
        gap: 7px;
        padding: 0 10px;
    }
    .h-client-logos-container .hover-box.h-client-logo-box,
    .h-client-logos-container .hover-box.h-client-logo-box:first-child {
        height: 50px;
        border-radius: 8px;
    }
    .h-client-logos-container .hover-box.h-client-logo-box:hover,
    .h-client-logos-container .hover-box.h-client-logo-box.active,
    .h-client-logos-container .hover-box.h-client-logo-box:first-child.active {
        width: 100%;
        max-width: none;
        height: auto;
        min-height: 0;
        border-radius: 8px;
    }
    .h-client-logos-container .hover-box:hover .hover-content,
    .h-client-logos-container .hover-box.active .hover-content,
    .h-client-logos-container .hover-box:first-child.active .hover-content {
        padding: 0 0 10px 0 !important;
        border-radius: 8px;
    }
    .h-client-logos-container .hover-title.h-client-title {
        font-size: 13px;
        letter-spacing: 1.2px;
        left: 16px;
    }
    .h-client-logos-container .hover-box:hover .h-client-title,
    .h-client-logos-container .hover-box.active .h-client-title,
    .h-client-logos-container .hover-box:first-child.active .h-client-title {
        font-size: 14px;
        padding: 10px 14px 4px 14px;
        left: 0 !important;
    }
    .h-client-logos-container .brand-logos.h-client-logos {
        padding: 0 10px;
    }
}

/* ==========================================================================
   TINY MOBILE  ( <= 380px )
   ========================================================================== */
@media (max-width: 380px) {
    .h-client-logos-container .hover-box.h-client-logo-box,
    .h-client-logos-container .hover-box.h-client-logo-box:first-child {
        height: 46px;
    }
    .h-client-logos-container .hover-box.h-client-logo-box:hover,
    .h-client-logos-container .hover-box.h-client-logo-box.active,
    .h-client-logos-container .hover-box.h-client-logo-box:first-child.active {
        height: auto;
        min-height: 0;
    }
    .h-client-logos-container .hover-title.h-client-title {
        font-size: 12px;
    }
    .h-client-logos-container .hover-box:hover .h-client-title,
    .h-client-logos-container .hover-box.active .h-client-title,
    .h-client-logos-container .hover-box:first-child.active .h-client-title {
        font-size: 13px;
        padding: 9px 12px 3px 12px;
    }
}

/* ==========================================================================
   DIVISIONS SECTION  —  UNIVERSAL GLOW & BEAUTIFY  (all screen sizes)
   --------------------------------------------------------------------------
   Scoped STRICTLY to .hover-boxes-container so the "Our Clients" section
   (.h-client-logos-container) is fully untouched.

   Design language (applies to phone / tablet / laptop / desktop / 4K):
     - Premium dark diagonal gradient on every hover-box
     - Soft brand-green ambient outer glow + subtle inner highlight
     - Glowing brand-green accent stripe pinned to the LEFT edge
     - Title gets heavier weight + delicate brand-tinted text-shadow
     - Active state: lifts, intensifies the glow, brand-green ring inset
   --------------------------------------------------------------------------
   Pixel sizes (stripe width, glow blur) scale UP at larger breakpoints so
   the effect stays proportional on huge / 4K displays. Mobile keeps its
   horizontal-pill specific overlay + title-left tweaks below.
   ========================================================================== */

/* --- BASE GLOW (applies to ALL sizes) --- */
.hover-boxes-container .hover-box {
    background: linear-gradient(135deg, #1f1f1f 0%, #0a0a0a 100%);
    border: 1px solid rgba(255, 255, 255, 0.06);
    box-shadow:
        0 6px 18px rgba(0, 0, 0, 0.55),
        0 0 22px rgba(158, 196, 61, 0.06),
        inset 0 1px 0 rgba(255, 255, 255, 0.07);
    transition: width 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94),
                transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94),
                box-shadow 0.35s ease,
                border-color 0.35s ease;
}

/* Glowing brand-green accent stripe pinned to the LEFT edge */
.hover-boxes-container .hover-box::after {
    content: '';
    position: absolute;
    top: 16%;
    bottom: 16%;
    left: 0;
    width: 3px;
    background: linear-gradient(180deg,
        transparent 0%,
        #b4dd4d 50%,
        transparent 100%);
    border-radius: 0 4px 4px 0;
    box-shadow:
        0 0 10px rgba(158, 196, 61, 0.85),
        0 0 20px rgba(158, 196, 61, 0.45);
    opacity: 0.9;
    z-index: 4;
    pointer-events: none;
    transition: width 0.35s ease, box-shadow 0.35s ease, opacity 0.35s ease;
}

/* Title — heavier weight + soft brand-glow shadow (works on rotated text too) */
.hover-boxes-container .hover-title {
    font-weight: 800;
    text-shadow:
        2px 2px 8px rgba(0, 0, 0, 0.9),
        0 0 2px rgba(158, 196, 61, 0.5);
}

/* ACTIVE / HOVER state — lift, intensify glow, brand-green ring */
.hover-boxes-container .hover-box:hover,
.hover-boxes-container .hover-box.active,
.hover-boxes-container .hover-box:first-child.active {
    border-color: rgba(158, 196, 61, 0.55);
    box-shadow:
        0 14px 34px rgba(0, 0, 0, 0.6),
        0 0 32px rgba(158, 196, 61, 0.28),
        inset 0 0 0 1px rgba(158, 196, 61, 0.35);
}

.hover-boxes-container .hover-box:hover::after,
.hover-boxes-container .hover-box.active::after,
.hover-boxes-container .hover-box:first-child.active::after {
    width: 4px;
    opacity: 1;
    box-shadow:
        0 0 14px rgba(158, 196, 61, 1),
        0 0 28px rgba(158, 196, 61, 0.7);
}

.hover-boxes-container .hover-box:hover .hover-title,
.hover-boxes-container .hover-box.active .hover-title,
.hover-boxes-container .hover-box:first-child.active .hover-title {
    text-shadow:
        2px 2px 10px rgba(0, 0, 0, 0.95),
        0 0 4px rgba(158, 196, 61, 0.55);
}

/* ==========================================================================
   HUGE SCREEN  ( >= 1921px )  —  Scale up halos for proportional feel
   ========================================================================== */
@media (min-width: 1921px) {
    .hover-boxes-container .hover-box {
        box-shadow:
            0 8px 24px rgba(0, 0, 0, 0.55),
            0 0 32px rgba(158, 196, 61, 0.08),
            inset 0 1px 0 rgba(255, 255, 255, 0.07);
    }
    .hover-boxes-container .hover-box::after {
        width: 4px;
        box-shadow:
            0 0 14px rgba(158, 196, 61, 0.9),
            0 0 26px rgba(158, 196, 61, 0.5);
    }
    .hover-boxes-container .hover-box:hover,
    .hover-boxes-container .hover-box.active,
    .hover-boxes-container .hover-box:first-child.active {
        box-shadow:
            0 18px 42px rgba(0, 0, 0, 0.65),
            0 0 42px rgba(158, 196, 61, 0.32),
            inset 0 0 0 1px rgba(158, 196, 61, 0.4);
    }
    .hover-boxes-container .hover-box:hover::after,
    .hover-boxes-container .hover-box.active::after,
    .hover-boxes-container .hover-box:first-child.active::after {
        width: 5px;
        box-shadow:
            0 0 18px rgba(158, 196, 61, 1),
            0 0 36px rgba(158, 196, 61, 0.75);
    }
}

/* ==========================================================================
   4K  ( >= 2560px )  —  Slightly bolder stripe + larger ambient glow
   ========================================================================== */
@media (min-width: 2560px) {
    .hover-boxes-container .hover-box {
        box-shadow:
            0 10px 28px rgba(0, 0, 0, 0.55),
            0 0 40px rgba(158, 196, 61, 0.09),
            inset 0 1px 0 rgba(255, 255, 255, 0.07);
    }
    .hover-boxes-container .hover-box::after {
        width: 5px;
        top: 14%;
        bottom: 14%;
    }
    .hover-boxes-container .hover-box:hover,
    .hover-boxes-container .hover-box.active,
    .hover-boxes-container .hover-box:first-child.active {
        box-shadow:
            0 22px 50px rgba(0, 0, 0, 0.65),
            0 0 52px rgba(158, 196, 61, 0.34),
            inset 0 0 0 1.5px rgba(158, 196, 61, 0.42);
    }
    .hover-boxes-container .hover-box:hover::after,
    .hover-boxes-container .hover-box.active::after,
    .hover-boxes-container .hover-box:first-child.active::after {
        width: 6px;
    }
}

/* ==========================================================================
   MOBILE  ( <= 576px )  —  Horizontal pill specific tweaks
   --------------------------------------------------------------------------
   The base glow already applies; here we just refine items that are
   specific to the horizontal stacked-pill layout:
     - Switch the dark overlay to a left→right gradient so the title side
       stays readable while imagery whispers through on the right.
     - Push title slightly right so it doesn't kiss the glowing stripe.
   ========================================================================== */
@media (max-width: 576px) {
    .hover-boxes-container .hover-box::before {
        background: linear-gradient(90deg,
            rgba(0, 0, 0, 0.92) 0%,
            rgba(0, 0, 0, 0.72) 45%,
            rgba(0, 0, 0, 0.42) 100%);
    }
    .hover-boxes-container .hover-title {
        left: 22px;
    }
    .hover-boxes-container .hover-box.active .hover-title,
    .hover-boxes-container .hover-box:first-child.active .hover-title {
        left: 22px;
    }
}

/* --- Extra small phones --- */
@media (max-width: 480px) {
    .hover-boxes-container .hover-box::after {
        top: 14%;
        bottom: 14%;
        width: 3px;
    }
    .hover-boxes-container .hover-title {
        left: 20px;
    }
    .hover-boxes-container .hover-box.active .hover-title,
    .hover-boxes-container .hover-box:first-child.active .hover-title {
        left: 20px;
    }
}

/* --- Tiny phones — softer glow so it doesn't dominate the small pill --- */
@media (max-width: 380px) {
    .hover-boxes-container .hover-box {
        box-shadow:
            0 4px 14px rgba(0, 0, 0, 0.5),
            0 0 16px rgba(158, 196, 61, 0.05),
            inset 0 1px 0 rgba(255, 255, 255, 0.06);
    }
    .hover-boxes-container .hover-box::after {
        width: 2.5px;
        box-shadow:
            0 0 8px rgba(158, 196, 61, 0.85),
            0 0 16px rgba(158, 196, 61, 0.4);
    }
    .hover-boxes-container .hover-title {
        left: 18px;
    }
    .hover-boxes-container .hover-box.active .hover-title,
    .hover-boxes-container .hover-box:first-child.active .hover-title {
        left: 18px;
    }
}

/* ==========================================================================
   DIVISIONS SECTION  —  ACTIVE TITLE → TOP-LEFT  ( >= 577px )
   --------------------------------------------------------------------------
   Brings the tablet / desktop / huge / 4K active-state title up to the
   TOP-LEFT, matching the polished mobile design. The hover-content gets
   enough top padding so the main logo + brand-logos grid don't collide
   with the title.

   - Strictly scoped to .hover-boxes-container → "Our Clients" section
     (.h-client-logos-container) is fully untouched.
   - :not(.h-client-title) added defensively so the Clients title class
     (.hover-title.h-client-title) is NEVER hit, even if markup changes.
   - Mobile (<= 576px) keeps its existing top-left design as-is.
   ========================================================================== */
@media (min-width: 577px) {
    .hover-boxes-container .hover-box:hover .hover-title:not(.h-client-title),
    .hover-boxes-container .hover-box.active .hover-title:not(.h-client-title),
    .hover-boxes-container .hover-box:first-child.active .hover-title:not(.h-client-title) {
        top: 12px;
        bottom: auto;
        left: 22px;
    }
    /* Symmetric top + bottom breathing room so the bottom shows a clean
       visible gap just like the top, not a tight squeeze against the edge. */
    .hover-boxes-container .hover-box:hover .hover-content,
    .hover-boxes-container .hover-box.active .hover-content,
    .hover-boxes-container .hover-box:first-child.active .hover-content {
        padding-top: 50px;
        padding-bottom: 15px;
    }
    /* Brand-logos: zero its own vertical padding so the gap is owned
       cleanly by hover-content (no double-stacking, no asymmetry). */
    .hover-boxes-container .hover-box:hover .brand-logos,
    .hover-boxes-container .hover-box.active .brand-logos,
    .hover-boxes-container .hover-box:first-child.active .brand-logos {
        padding-top: 0;
        padding-bottom: 0;
    }
}

/* --- Tablet sweet spot ( 769px – 992px ) — smaller card, smaller offset --- */
@media (min-width: 769px) and (max-width: 992px) {
    .hover-boxes-container .hover-box:hover .hover-title:not(.h-client-title),
    .hover-boxes-container .hover-box.active .hover-title:not(.h-client-title),
    .hover-boxes-container .hover-box:first-child.active .hover-title:not(.h-client-title) {
        top: 8px;
        left: 13px;
    }
    .hover-boxes-container .hover-box:hover .hover-content,
    .hover-boxes-container .hover-box.active .hover-content,
    .hover-boxes-container .hover-box:first-child.active .hover-content {
        padding: 36px 20px 10px 0;
    }

    .brand-logos img { 
        height: 41px;
        max-width: 80px;
    }
}

/* --- Small tablets / large phones ( 577px – 768px ) --- */
@media (min-width: 577px) and (max-width: 768px) {
    .hover-boxes-container .hover-box:hover .hover-title:not(.h-client-title),
    .hover-boxes-container .hover-box.active .hover-title:not(.h-client-title),
    .hover-boxes-container .hover-box:first-child.active .hover-title:not(.h-client-title) {
        top: 7px;
        left: 14px;
    }
    .hover-boxes-container .hover-box:hover .hover-content,
    .hover-boxes-container .hover-box.active .hover-content,
    .hover-boxes-container .hover-box:first-child.active .hover-content {
      
        padding: 32px 10px 10px 12px;
    }
}

/* --- Huge ( >= 1921px ) — proportional uplift --- */
@media (min-width: 1921px) {
    .hover-boxes-container .hover-box:hover .hover-title:not(.h-client-title),
    .hover-boxes-container .hover-box.active .hover-title:not(.h-client-title),
    .hover-boxes-container .hover-box:first-child.active .hover-title:not(.h-client-title) {
        top: 13px;
        left: 20px;
    }
    .hover-boxes-container .hover-box:hover .hover-content,
    .hover-boxes-container .hover-box.active .hover-content,
    .hover-boxes-container .hover-box:first-child.active .hover-content {
        padding-top: 50px;
        padding-bottom: 20px;
        padding-left: 20px;
    }
    /* Brand-logos: zero vertical padding so the symmetric hover-content
       padding owns the gap cleanly. */
    .hover-boxes-container .hover-box:hover .brand-logos,
    .hover-boxes-container .hover-box.active .brand-logos,
    .hover-boxes-container .hover-box:first-child.active .brand-logos {
        padding: 0 10px;
    }
}

/* --- 4K ( >= 2560px ) --- */
@media (min-width: 2560px) {
    .hover-boxes-container .hover-box:hover .hover-title:not(.h-client-title),
    .hover-boxes-container .hover-box.active .hover-title:not(.h-client-title),
    .hover-boxes-container .hover-box:first-child.active .hover-title:not(.h-client-title) {
        top: 15px;
        left: 30px;
    }
    .hover-boxes-container .hover-box:hover .hover-content,
    .hover-boxes-container .hover-box.active .hover-content,
    .hover-boxes-container .hover-box:first-child.active .hover-content {
        padding-top: 58px;
        padding-bottom: 18px;
        padding-left: 20px;
    }
}

/* ==========================================================================
   TOUCH DEVICES  —  KILL "STICKY HOVER" DOUBLE-OPEN
   --------------------------------------------------------------------------
   On touch screens a tapped box keeps a lingering :hover state, which made a
   previously tapped box stay open while a newly tapped box also opened
   (two panels open at once). Open/close is driven purely by the JS-managed
   .active class here, so a box that is :hover but NOT .active must stay
   collapsed. Desktop (hover: hover) is unaffected — real hover still works.
   ========================================================================== */
@media (hover: none) {
    .hover-box:hover:not(.active) .hover-content {
        opacity: 0 !important;
        visibility: hidden !important;
        pointer-events: none !important;
        position: absolute !important;
    }
}

