.gallery-hero{background:linear-gradient(135deg,#2c862c,#1e582b);color:#fff;padding:6rem 2rem 4rem;text-align:center;position:relative;overflow:hidden}.gallery-hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url(/images/gallery-hero.JPG) center/cover;opacity:.2}.hero-content h1{font-size:var(--font-size-heading);margin-bottom:1rem;position:relative;z-index:2}.hero-subtitle{font-size:var(--font-size-body);max-width:600px;margin:0 auto;opacity:.9;position:relative;z-index:2}.gallery-controls{background:#fff;border-bottom:1px solid var(--color-light-to-grey);position:sticky;top:80px;z-index:100;box-shadow:0 2px 10px rgb(0 0 0 / .1);display:flex;justify-content:center}.filter-buttons{display:flex;justify-content:center;flex-wrap:wrap;gap:.8rem;max-width:1200px;margin:0 1rem;padding:.5rem 0}.filter-btn{background:#fff0;border:2px solid #2c862c;color:var(--color-green-to-white);padding:.6rem 1.2rem;border-radius:25px;cursor:pointer;font-weight:500;transition:var(--transition)}.filter-btn:hover,.filter-btn.active{background:#2c862c;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px rgb(44 134 44 / .3)}.gallery-section{padding:3rem 0;margin:0 5rem}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-bottom:3rem}.gallery-item{opacity:0;transform:translateY(20px);animation:fadeInUp 0.6s ease forwards}@keyframes fadeInUp{to{opacity:1;transform:translateY(0)}}.gallery-card{position:relative;border-radius:12px;overflow:hidden;box-shadow:0 4px 15px rgb(0 0 0 / .1);transition:var(--transition);background:#fff;cursor:pointer;height:100%}.gallery-card:hover{transform:translateY(-8px);box-shadow:0 12px 30px rgb(0 0 0 / .15)}.gallery-image{width:100%;height:250px;object-fit:cover;display:block;transition:var(--transition)}.video-card .gallery-image{filter:brightness(.9)}.play-button{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:rgb(255 255 255 / .9);width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.play-button i{color:var(--color-primary);font-size:1.5rem;margin-left:3px}.video-card:hover .play-button{background:var(--color-primary);transform:translate(-50%,-50%) scale(1.1)}.video-card:hover .play-button i{color:#fff}.card-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to bottom,transparent 0%,rgb(0 0 0 / .8) 100%);display:flex;align-items:flex-end;padding:1.5rem;opacity:0;transition:var(--transition)}.gallery-card:hover .card-overlay{opacity:1}.overlay-content{color:#fff;transform:translateY(20px);transition:var(--transition)}.gallery-card:hover .overlay-content{transform:translateY(0)}.overlay-content h3{font-size:1.2rem;margin-bottom:.5rem;font-weight:600}.overlay-content p{font-size:.9rem;opacity:.9;margin-bottom:1rem}.overlay-content i{font-size:1.2rem;color:#fff}.load-more-container{text-align:center;margin-top:3rem;display:flex;flex-direction:row;justify-content:center}.load-more-btn{background:var(--color-primary);color:#fff;border:none;padding:1rem 2rem;border-radius:25px;cursor:pointer;font-weight:500;transition:var(--transition);display:inline-flex;align-items:center;gap:.5rem}.load-more-btn:hover{background:var(--color-dark-green);transform:translateY(-2px);box-shadow:0 6px 20px rgb(44 134 44 / .3)}.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgb(0 0 0 / .9);z-index:1000;opacity:0;transition:opacity 0.3s ease}.modal.show{display:flex;align-items:center;justify-content:center;opacity:1}.modal-content{background:#fff;border-radius:12px;max-width:90%;max-height:90%;width:800px;position:relative;transform:scale(.9);transition:transform 0.3s ease}.modal.show .modal-content{transform:scale(1)}.close-btn{position:absolute;top:1rem;right:1.5rem;font-size:2rem;color:#fff;cursor:pointer;z-index:10;background:rgb(0 0 0 / .5);width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.close-btn:hover{background:rgb(0 0 0 / .8);transform:rotate(90deg)}.modal-body{display:flex;flex-direction:column;max-height:80vh}.modal-image-container{flex:1;background:#000;display:flex;align-items:end;justify-content:center;min-height:400px}.modal-image-container img{max-width:100%;max-height:500px;object-fit:contain}.video-container{width:100%;padding:0;align-items:end}.g-vid-pos{display:flex;align-items:end}.video-container iframe{width:100%;height:400px;border:none}.modal-info{padding:1.5rem;background:#fff}.modal-info h3{color:var(--color-text-primary);margin-bottom:.5rem;font-size:1.3rem}.modal-info p{color:var(--color-text-gray);margin-bottom:1rem;line-height:1.5}.modal-meta{display:flex;align-items:center;gap:1rem}.category-tag{background:#2c862c;color:#fff;padding:.3rem .8rem;border-radius:15px;font-size:.8rem;font-weight:500}.modal-nav{position:absolute;top:50%;left:0;right:0;display:flex;justify-content:space-between;padding:0 1rem;transform:translateY(-50%);pointer-events:none}.nav-btn{background:rgb(0 0 0 / .5);color:#fff;border:none;width:50px;height:50px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);pointer-events:all}.nav-btn:hover{background:rgb(0 0 0 / .8);transform:scale(1.1)}.nav-btn:disabled{opacity:.3;cursor:not-allowed;transform:none}@media (max-width:768px){.gallery-hero{padding:5rem 1rem 3rem}.filter-buttons{gap:.5rem}.gallery-section{margin:0 1rem}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.modal-content{max-width:100%;max-height:100%}.modal-nav{padding:0 .5rem}.nav-btn{width:40px;height:40px}.video-container iframe{height:300px}}@media (max-width:480px){.gallery-grid{grid-template-columns:1fr}.filter-buttons-container{width:100%;padding:0}.filter-buttons{justify-content:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch;touch-action:pan-x;overscroll-behavior-x:contain;scroll-behavior:smooth;flex-wrap:nowrap;margin:0;padding:.5rem 1rem;max-height:none;scrollbar-width:none;-ms-overflow-style:none}.filter-buttons::-webkit-scrollbar{display:none}.filter-btn{flex-shrink:0;white-space:nowrap;flex-grow:0;flex-basis:auto}.filter-buttons{cursor:grab}.filter-buttons:active{cursor:grabbing}.modal-body{max-height:90vh}.modal-image-container{min-height:300px}.video-container iframe{height:250px}}[data-theme="dark"] .modal-info,[data-theme="dark"] .gallery-controls{background-color:#37373a}