.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:320px;grid-gap:24px;gap:24px}.gallery-card{position:relative;border-radius:12px;overflow:hidden;cursor:pointer;box-shadow:0 4px 15px rgba(0,0,0,.1);transition:transform .3s ease,box-shadow .3s ease}.gallery-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px rgba(0,0,0,.15)}.card-wide{grid-column:span 2}.card-small{grid-column:span 1}.gallery-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}.gallery-card:hover .gallery-img{transform:scale(1.05)}.gallery-overlay{position:absolute;left:0;right:0;bottom:0;height:60px;padding:0 20px;display:flex;justify-content:space-between;align-items:center;background-color:rgba(0,109,56,.8);z-index:2}.overlay-text{font-size:13px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:85%}.icon-wrapper{display:flex;align-items:center;justify-content:center}.gallery-overlay img{width:20px;height:20px;filter:brightness(0) invert(1);transition:transform .3s ease}.gallery-card:hover .gallery-overlay img{transform:scale(1.2)}.modal-close-btn{position:absolute;top:-15px;right:-15px;background:white;border:none;border-radius:50%;width:30px;height:30px;font-weight:700;z-index:1056;box-shadow:0 2px 10px rgba(0,0,0,.2)}.lightbox-caption{position:absolute;bottom:0;left:0;width:100%;padding:16px 24px;background:linear-gradient(0deg,rgba(0,0,0,.85),rgba(0,0,0,0));color:#fff;font-size:15px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;text-align:center;pointer-events:none}.gallery-filter-header{display:flex;justify-content:space-between;align-items:center;padding:20px 0;margin-bottom:20px}.filter-icon-container{display:flex;align-items:center;gap:6px;flex-shrink:0}.filter-icon-btn{position:relative;display:flex;align-items:center;justify-content:center;width:48px;height:48px;border:2px solid #e0e0e0;border-radius:12px;background:white;color:#666;cursor:pointer;transition:all .3s ease;font-size:20px}.filter-icon-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background-color:#f8f9fa;box-shadow:0 4px 12px rgba(0,109,56,.15)}.filter-icon-btn.active{background-color:var(--color-primary);color:white;border-color:var(--color-primary);box-shadow:0 4px 12px rgba(0,109,56,.25)}.filter-badge{position:absolute;top:-8px;right:-8px;background:#dc3545;color:white;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}.filter-button{background-color:var(--color-primary);color:white;border-radius:5px;border:none;padding:10px}.clear-filters-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid #dc3545;border-radius:8px;background:white;color:#dc3545;cursor:pointer;transition:all .3s ease}.clear-filters-btn:hover{background-color:#dc3545;color:white;transform:scale(1.05)}.filter-summary{font-size:14px;color:#666}.active-filters-text{color:var(--color-primary);font-weight:600}.total-items-text{color:#888}.gallery-filter-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;justify-content:flex-end;align-items:center;z-index:1050;animation:fadeIn .3s ease-out}.gallery-filter-modal{background:white;width:100%;max-width:400px;height:100vh;box-shadow:-4px 0 20px rgba(0,0,0,.15);animation:slideInRight .3s ease-out;display:flex;flex-direction:column}.filter-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e9ecef;background:#f8f9fa}.filter-modal-title{margin:0;font-size:18px;font-weight:600;color:#333;display:flex;align-items:center}.filter-modal-close{background:none;border:none;color:#666;cursor:pointer;padding:8px;border-radius:6px;transition:all .3s ease}.filter-modal-close:hover{background-color:#e9ecef;color:#333}.filter-modal-body{flex:1 1;overflow-y:auto;padding:0}.filter-tabs{display:flex;border-bottom:1px solid #e9ecef;background:#f8f9fa}.filter-tab{flex:1 1;padding:16px 12px;background:none;border:none;border-bottom:2px solid transparent;color:#666;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;font-size:14px}.filter-tab:hover{background-color:#e9ecef;color:#333}.filter-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);background:white}.filter-options{padding:8px 0}.filter-option{width:100%;padding:12px 24px;background:none;text-align:left;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:space-between;border:none;border-bottom:1px solid #f8f9fa;font-size:14px}.filter-option:hover{background-color:#f8f9fa}.filter-option.selected{background-color:rgba(0,109,56,.08);color:var(--color-primary);font-weight:500}.filter-option-text{flex:1 1}.filter-option-count{color:#888;font-size:12px;margin-right:12px}.filter-check{color:var(--color-primary);font-size:16px}.filter-modal-footer{padding:16px 24px;border-top:1px solid #e9ecef;display:flex;gap:12px;justify-content:flex-end}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{transform:translateX(100%)}to{transform:translateX(0)}}@media (max-width:992px){.gallery-filter-header{padding:16px 0;flex-direction:column;gap:12px;align-items:flex-start}.filter-summary{font-size:12px;flex:1 1;min-width:0}.gallery-filter-modal{max-width:350px}.filter-modal-header{padding:16px 20px}.filter-modal-title{font-size:16px}.filter-tab{padding:12px 8px;font-size:13px}.filter-option{padding:10px 20px;font-size:13px}.filter-modal-footer{padding:12px 20px}.gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:280px}.card-wide{grid-column:span 2}}@media (max-width:576px){.gallery-filter-header{padding:12px 0;flex-direction:row;gap:8px;align-items:center}.filter-icon-btn{width:44px;height:44px;font-size:18px}.filter-badge{width:18px;height:18px;font-size:11px;top:-6px;right:-6px}.clear-filters-btn{width:32px;height:32px}.gallery-filter-modal{max-width:100vw}.filter-modal-header{padding:16px 20px}.filter-modal-title{font-size:16px}.filter-tabs{flex-direction:column}.filter-tab{padding:14px 16px;font-size:14px;justify-content:flex-start}.filter-option{padding:12px 20px;font-size:14px}.filter-modal-footer{padding:16px 20px;flex-direction:column;gap:8px}.filter-modal-footer .btn{width:100%}.gallery-grid{grid-template-columns:1fr;grid-auto-rows:240px;gap:15px}.card-small,.card-wide{grid-column:span 1}.gallery-overlay{padding:0 15px;height:50px}.overlay-text{font-size:12px}}