.gallery-container{width:100%}.gallery-loading{display:flex;align-items:center;justify-content:center;padding:5rem 0}.gallery-loading-content{text-align:center}.gallery-spinner{animation:spin 1s linear infinite;border-radius:50%;height:3rem;width:3rem;border-bottom:2px solid var(--primary);margin:0 auto 1rem}@keyframes spin{to{transform:rotate(1turn)}}.gallery-loading-text{color:var(--text-secondary)}.gallery-masonry{column-count:1;gap:1.5rem}@media (min-width:640px){.gallery-masonry{column-count:2}}@media (min-width:1024px){.gallery-masonry{column-count:3}}@media (min-width:1280px){.gallery-masonry{column-count:4}}.gallery-item{margin-bottom:1.5rem;break-inside:avoid;cursor:pointer;transition:all .3s ease}.gallery-item:hover{transform:scale(1.02)}.gallery-image-container{position:relative;overflow:hidden;border-radius:.75rem;box-shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -1px rgba(0,0,0,.06);background:var(--surface);padding:.5rem;transition:all .3s ease}.gallery-image-container:hover{box-shadow:0 25px 50px -12px rgba(0,0,0,.25)}.gallery-image{transition:transform .3s ease}.gallery-image,.gallery-video{width:100%;height:auto;border-radius:.5rem}.gallery-video{display:block;object-fit:cover;background:#000}.gallery-item:hover .gallery-image{transform:scale(1.05)}.gallery-image-container:hover .gallery-video{filter:brightness(.85)}.gallery-empty{grid-column:1/-1;text-align:center;padding:5rem 0}.gallery-empty-content{color:var(--text-muted)}.gallery-empty-title{font-size:1.125rem;margin-bottom:.5rem}.gallery-filter-bar{display:flex;flex-direction:column;gap:1rem;margin-bottom:2.5rem;padding:1.25rem 1.5rem;border-radius:1.25rem;border:1px solid rgba(255,255,255,.08);background:linear-gradient(135deg,rgba(255,255,255,.04),rgba(255,255,255,0));backdrop-filter:blur(12px)}.gallery-filter-scroll{display:flex;flex-wrap:wrap;gap:.75rem}.gallery-filter-button{padding:.45rem 1.25rem;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:.95rem;font-weight:500;cursor:pointer;transition:transform .2s ease,background .2s ease,color .2s ease,border .2s ease}.gallery-filter-button:hover{transform:translateY(-1px);border-color:var(--primary);color:var(--text-primary)}.gallery-filter-button.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 10px 30px rgba(0,0,0,.15)}.gallery-image-meta{position:absolute;left:.75rem;right:.75rem;bottom:.75rem;display:flex;flex-wrap:wrap;gap:.35rem;z-index:2;pointer-events:none}.gallery-tag-chip{padding:.2rem .9rem;border-radius:999px;background:rgba(0,0,0,.55);color:#f8fafc;font-size:.75rem;letter-spacing:.02em;text-transform:uppercase}.gallery-filter-reset{margin-top:.5rem;padding:.4rem 1rem;border-radius:999px;border:1px solid var(--border);background:transparent;color:var(--text-primary);cursor:pointer;transition:all .2s ease}.gallery-filter-reset:hover{border-color:var(--primary);color:var(--primary)}.gallery-video-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;color:#fff;font-weight:500;text-transform:uppercase;font-size:.75rem;letter-spacing:.08em;pointer-events:none;background:linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,.65));opacity:0;transition:opacity .3s ease;border-radius:.75rem;z-index:1}.gallery-image-container:hover .gallery-video-overlay{opacity:1}.gallery-video-icon{width:2rem;height:2rem}