.csf-case-studies{ font-family:"Helvetica Neue",Arial,sans-serif; }
.csf-filter-bar{ display:flex; justify-content:center; gap:20px; background:#c7002a; padding:15px; flex-wrap:wrap; }
.csf-filter-group{ position:relative; }
.csf-filter-toggle{ background:#111; color:#fff; border:none; padding:10px 20px; cursor:pointer; text-transform:uppercase; }
.csf-filter-dropdown{ display:none; position:absolute; top:54px; left:50%; transform:translateX(-50%); background:#c7002a; padding:12px 18px; list-style:none; z-index:9999; min-width:420px; box-shadow:0 6px 20px rgba(0,0,0,.45); border-radius:2px; }
.csf-filter-dropdown li{ padding:6px 8px; }
.csf-filter-dropdown label{ color:#fff; cursor:pointer; font-size:14px; display:flex; align-items:center; }
.csf-filter-dropdown label span{ flex:1; }

/* checkbox look */
.csf-filter-dropdown input[type="checkbox"]{ width:18px; height:18px; margin:0; appearance:none; -webkit-appearance:none; border:2px solid rgba(255,255,255,0.35); border-radius:3px; background:rgba(255,255,255,0.02); position:relative; margin-left:auto; }
.csf-filter-dropdown input[type="checkbox"]:checked{ background:#fff; border-color:#fff; }
.csf-filter-dropdown input[type="checkbox"]:checked::after{ content:'\2713'; color:#c7002a; position:absolute; left:2px; top:-1px; font-size:14px; line-height:1; }
.csf-filter-dropdown li:hover{ background:rgba(0,0,0,0.08); }
.csf-filter-group:hover .csf-filter-dropdown, .csf-filter-group:focus-within .csf-filter-dropdown{ display:block; }
.csf-filter-toggle{ display:inline-flex; align-items:center; gap:8px; }
.csf-showall-row{ border-bottom:1px solid rgba(255,255,255,0.06); padding-bottom:8px; margin-bottom:8px; }
.csf-showall-row label{ font-weight:700; }
.csf-case-grid{ display:grid; grid-template-columns:repeat(3, 1fr); gap:18px; padding:36px; background:#111; }
.csf-case-item{ position:relative; overflow:hidden; border-radius:6px; }
.csf-case-link{ display:block; color:inherit; text-decoration:none; }
.csf-thumb{ height:320px; background:#222; }
.csf-thumb img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .35s ease; }
.csf-case-item:hover .csf-thumb img{ transform:scale(1.04); }
.csf-overlay{ position:absolute; left:0;right:0;bottom:0;background:linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0.3) 60%);color:#fff;text-shadow: 0px 0px 2px rgba(0, 0, 0, 0.5);padding:16px;text-align:center;font-size:18px; display:flex; flex-direction:column; align-items:center; gap:10px; }
.csf-details-btn{ display:inline-block; background:#c7002a; color:#fff; padding:8px 14px; text-transform:uppercase; font-weight:700; border-radius:4px; text-decoration:none; }
/* Placeholder when no featured image */
.csf-thumb-empty{ width:100%; height:100%; display:flex; align-items:center; justify-content:center; background:#2a2a2a; color:#ddd; font-weight:700; font-size:16px; }




.csf-filter-bar {
    padding: 30px !important;
}
.page-masthead {
    position: relative;
    padding-top: 20em !important;
    padding-bottom: 10em !important;
}
button.csf-filter-toggle {
    /* position: relative; */
    /* padding: 15px 20px 15px 20px; */
    border: rgba(255, 255, 255, 0.2) 1px solid;
    color: #fff;
    text-decoration: none;
    text-transform: uppercase;
    font-size: 18px;
    letter-spacing: 2px;
    cursor: pointer;
    background: transparent !important;
    font-weight: 400 !important;
    max-width: 400px !important;
    width: 100%;
    margin: 0 !important;
}

.csf-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;            
    justify-content: center;     
    align-items: center;           
    text-align: center;
  
}
button.csf-filter-toggle:hover {
    background: #000 !important;
}

.csf-filter-bar {
    gap: 0% !important;
    width: 100%;
    background: #18130c !important;
}

.csf-filter-group {
    max-width: 400px;
    width: 100%;
}

.csf-case-grid {
    background: transparent !important;
    padding: 0 !important;
    gap: 0 !important;
    border-radius: unset;
}

.csf-overlay {
    border-radius: unset;
}

.csf-case-item {
    border-radius: unset;
}

.csf-case-item h3 {
    color: #ececec !important;
    font-size: 28px !important;
    font-weight: 500 !important;
}

.csf-case-item a.csf-details-btn {
    background: transparent !important;
    border: 1px solid #ececec;
    color: #ecececec;
    border-radius: 50%;
    font-size: 18px !important;
    padding: 0;
    height: 30px;
    width: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.csf-thumb {
    position: relative; /* Important for absolute child positioning */
    align-items: center;
    display: flex;
}



 .csf-thumb {
    position: unset;
    align-items: center !important;
}

.csf-filter-bar ul#csf-filter-industry {
    background: #18130c !important;
}

.csf-filter-dropdown input[type="checkbox"] {
    border: unset !important;
    background: transparent;
}

.csf-filter-dropdown input.csf-filter-checkbox.csf-ind {
    background: transparent !important;
}

.prose li::marker, .block-editor-block-list__layout li::marker {
    display: none !important;
}

.csf-filter-bar li {
    list-style: none !important;
}

.csf-filter-dropdown input[type="checkbox"]:checked {
    background: transparent !important;
    font-size: 17px !important;
}

.csf-filter-dropdown label span {
    text-transform: uppercase;
    font-size: 18px;
    font-weight: 200;
}

.csf-filter-dropdown li {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}

.csf-filter-bar ul#csf-filter-technology {background: #18130c !important;}

.csf-showall-row label {
    flex-direction: row-reverse;
}

.csf-loadmore-wrap button#csf-load-more {
    background: #fff;
}

.csf-loadmore-wrap button#csf-load-more:after {
    border: 1px solid #005c45;
}
.csf-showall-row label {
    flex-direction: row-reverse;
    font-weight: 200;
    text-transform: uppercase;
    font-size: 18px;
}
.csf-loadmore-wrap button#csf-load-more:after {
    content: "";
    position: absolute;
    top: .3125rem;
    bottom: .3125rem;
    right: .3125rem;
    left: .3125rem;
}
.csf-filter-dropdown input[type="checkbox"]:checked::after {
    color: #fff;
}
.csf-filter-bar ul#csf-filter-technology {
    margin-top: 0;
}
.page-id-14469 div#post-14469 {
    padding-top: 0 !important;
}
.csf-loadmore-wrap button#csf-load-more {
    position: relative;
    display: inline-block;
    border: 0;
    font-size: .875rem;
    line-height: 1;
    font-weight: 400;
    text-transform: uppercase;
    text-align: center;
    transition: all .3s 
cubic-bezier(0.165, 0.84, 0.44, 1);
    padding: 20px 40px;
    color: #005c45 !important;
}
section {
    overflow: visible !important;
    position: relative;
}
.csf-case-item img.attachment-large.size-large.wp-post-image {
    width: 100% !important;
    object-fit: cover;
    height: 100%;
}

.csf-case-item a.csf-case-link {
    width: 100%;
}

.csf-thumb img{
    height: 320px !important;
}







/* Overlay title/button tweaks */
.csf-overlay h3{ margin:0; font-size:20px; font-weight:600; }

/* Responsive grid: 3 columns desktop, 2 tablet, 1 mobile */
@media (max-width: 1024px) {
	.csf-case-grid { grid-template-columns: repeat(2, 1fr); }
	.csf-thumb { height: 300px; }
	.csf-filter-bar {
    gap: 10px;
    width: 100%;
    background: #18130c !important;
}
}
@media (max-width: 768px) {
	.csf-case-grid { grid-template-columns: repeat(1, 1fr); }
	.csf-thumb { height: 220px; }
	.csf-case-item h3 {
    color: #ececec !important;
    font-size: 20px !important;
    font-weight: 500 !important;
}
.csf-filter-dropdown {
    min-width: 100%;
}
.csf-filter-dropdown label span {
    text-transform: uppercase;
    font-size: 16px;
    font-weight: 200;
}
}
.csf-loadmore-wrap{text-align:center;padding:20px;background:#111;}
.csf-loadmore-btn{background:#c7002a;color:#fff;border:none;padding:10px 30px;text-transform:uppercase;cursor:pointer;font-weight:600;}
.csf-loadmore-btn.loading{opacity:.6;cursor:wait;}
.csf-no-results{color:#fff;padding:40px;text-align:center;}
@media(max-width:768px){.csf-thumb img{height:180px;}}


.csf-no-results { background: #111; color: #fff; padding: 2em; text-align: center; }