.card{position:relative;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;text-decoration:none;border:1px solid #2a2a2a;background:#000;height:400px}.card__image{position:absolute;inset:0;overflow:hidden}.card__image img{width:100%;height:100%;object-fit:cover;transform:scale(1);filter:grayscale(1) brightness(.6);transition:transform .6s ease,filter .5s ease}.card__content{position:relative;z-index:2;padding:24px;color:#ccc}.card__meta{display:flex;align-items:center;gap:12px;margin-bottom:12px}.card__label{font-size:12px;font-weight:700;color:var(--primary);border:1px solid var(--primary);padding:2px 8px}.card__year{font-size:12px;opacity:.6}.card__title{font-size:22px;font-weight:800;color:#fff;margin-bottom:10px}.card__description{font-size:14px;line-height:1.5;margin-bottom:16px}.card__footer{font-size:14px;color:var(--primary)}.card:hover .card__image img{transform:scale(1.1);filter:grayscale(0) brightness(.85)}.gallery-grid{width:100%}.gallery-grid__inner{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:24px}@media(min-width:700px){.gallery-grid__inner{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1200px){.gallery-grid__inner{grid-template-columns:repeat(3,minmax(0,1fr))}}.gallery main{color:#eee;width:100%;margin-top:60px;min-width:340px;background:#0c1916}.gallery main h2{color:#e1cd5f;font-family:UAFSans-Bold;font-size:45px}.gallery main .page-header{padding:56px 32px 48px;background:linear-gradient(90deg,#0c1916,#1b222c);border-bottom:1px solid hsla(0,0%,100%,.06)}.gallery main .page-header .title-icon{display:flex;align-items:center;gap:14px;margin-bottom:14px}.gallery main .page-header .title-icon svg{width:35px;height:35px;color:var(--primary);flex-shrink:0}.gallery main .page-header .title-icon h2{margin:0;color:#f3f3f1;font-size:56px;line-height:.95;font-weight:800;text-transform:uppercase;letter-spacing:.04em}.gallery main .page-header p{margin:0;max-width:920px;color:#9fa6b2;font-size:18px;line-height:1.55;font-weight:500}.gallery main .gallery-content{background-color:#050b12;padding-bottom:50px;min-height:calc(100vh - 400px)}.gallery main .grid-wrapper{padding:0 32px}.gallery main .gallery-empty-state{margin:0;padding:70px 20px;text-align:center;color:#9fa6b2;font-size:20px;line-height:1.5;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border:1px solid hsla(0,0%,100%,.08);background:#060d16}.gallery main .gallery-skeleton-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:24px}.gallery main .gallery-skeleton-card{height:400px;padding:24px;border:1px solid #263140;background:linear-gradient(135deg,#0b141f,#111b29);display:flex;flex-direction:column;justify-content:flex-end;gap:12px}.gallery main .gallery-skeleton-card__chip,.gallery main .gallery-skeleton-card__text,.gallery main .gallery-skeleton-card__title{position:relative;overflow:hidden;background:hsla(0,0%,100%,.08)}.gallery main .gallery-skeleton-card__chip:after,.gallery main .gallery-skeleton-card__text:after,.gallery main .gallery-skeleton-card__title:after{content:"";position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.12) 50%,rgba(255,255,255,0));animation:gallery-skeleton-shimmer 1.4s infinite}.gallery main .gallery-skeleton-card__chip{width:140px;height:28px}.gallery main .gallery-skeleton-card__title{width:68%;height:34px}.gallery main .gallery-skeleton-card__text{width:100%;height:18px}.gallery main .gallery-skeleton-card__text--short{width:78%}@keyframes gallery-skeleton-shimmer{to{transform:translateX(100%)}}.gallery main .filters{display:flex;flex-wrap:wrap;align-items:center;gap:28px;padding:24px 32px;background:#050b12;border-bottom:1px solid hsla(0,0%,100%,.06)}.gallery main .filter{display:flex;align-items:center;gap:16px;min-width:0}.gallery main .filter .filter-name{display:flex;align-items:center;gap:10px;flex-shrink:0}.gallery main .filter .filter-name svg{width:18px;height:18px;color:#8f98a7;flex-shrink:0}.gallery main .filter .filter-name .label{margin:0;color:#8f98a7;font-size:13px;line-height:1;font-weight:700;text-transform:uppercase;letter-spacing:.08em;white-space:nowrap}.gallery main .filter ul{display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0;list-style:none}.gallery main .filter li{margin:0;padding:0}.gallery main .filter button{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:0 14px;border:1px solid #263140;background:rgba(0,0,0,0);color:#9aa3b0;font-size:14px;line-height:1;font-weight:700;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;border-radius:0;outline:none;transition:background-color .25s ease,border-color .25s ease,color .25s ease,transform .25s ease}.gallery main .filter li:hover button{border-color:var(--primary);color:#f2f2f0}.gallery main .filter li.active button{background:var(--primary);border-color:var(--primary);color:#050b12}@media(max-width:991px){.gallery main .page-header{padding:44px 24px 36px}.gallery main .page-header .title-icon h2{font-size:44px}.gallery main .page-header p{font-size:16px}.gallery main .filters{gap:20px;padding:20px 24px}.gallery main .grid-wrapper{padding:0 24px}.gallery main .filter{width:100%;align-items:flex-start;flex-direction:column;gap:12px}}@media(max-width:640px){.gallery main .page-header{padding:36px 16px 28px}.gallery main .page-header .title-icon{gap:10px;margin-bottom:12px}.gallery main .page-header .title-icon svg{width:24px;height:24px}.gallery main .page-header .title-icon h2{font-size:34px}.gallery main .page-header p{font-size:15px;line-height:1.5}.gallery main .filters{gap:18px;padding:16px}.gallery main .grid-wrapper{padding:0 16px}.gallery main .filter .filter-name{gap:8px}.gallery main .filter .filter-name .label{font-size:12px}.gallery main .filter ul{gap:6px}.gallery main .filter button{min-height:36px;padding:0 12px;font-size:12px}.gallery main .gallery-empty-state{padding:52px 16px;font-size:16px}}@media(min-width:700px){.gallery main .gallery-skeleton-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1200px){.gallery main .gallery-skeleton-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}