body>.photo-modal{align-items:center;bottom:0;display:flex;height:100vh;justify-content:center;left:0;position:fixed;right:0;top:0;width:100vw;z-index:10000}.photo-modal__overlay{background-color:#000000f2;bottom:0;left:0;position:absolute;right:0;top:0;z-index:-1}.photo-modal__content{background:transparent;display:flex;flex-direction:column;height:100%;position:relative;width:100%}.photo-modal__image-container{align-items:center;display:flex;height:calc(100vh - 120px);justify-content:center;overflow:hidden;position:relative;width:100%}.photo-modal__image{max-height:100%;max-width:100%;-o-object-fit:contain;object-fit:contain}.photo-modal__info{background:#000c;bottom:0;color:#fff;left:0;padding:1rem;position:absolute;right:0}.photo-modal__title{color:#fff;font-size:1.2rem;margin:0 0 .5rem}.photo-modal__metadata{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.photo-modal__date{color:#ffa140;font-size:.9rem;margin:0}.photo-modal__link{color:#1e90ff;font-size:.9rem;text-decoration:none}.photo-modal__link:hover{text-decoration:underline}.photo-modal__tags{display:flex;flex-wrap:wrap;gap:.5rem}.photo-modal__tag{border-radius:4px;font-size:.8rem;padding:.2rem .5rem}.photo-modal__nav,.photo-modal__tag{background:#fff3;color:#fff}.photo-modal__nav{align-items:center;border:none;border-radius:50%;cursor:pointer;display:flex;height:48px;justify-content:center;position:absolute;top:50%;transform:translateY(-50%);transition:background-color .3s;width:48px}.photo-modal__nav:hover{background:#fff6}.photo-modal__nav--prev{left:2rem}.photo-modal__nav--next{right:2rem}.photo-modal__nav svg{height:24px;width:24px}.photo-modal__close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:48px;justify-content:center;position:absolute;right:2rem;top:2rem;transition:background-color .3s;width:48px}.photo-modal__close:hover{background:#fff6}.photo-modal__close svg{height:24px;width:24px}.photo-modal__counter{background:#0009;border-radius:20px;color:#fff;font-size:.9rem;left:2rem;padding:.5rem 1rem;position:absolute;top:2rem}.loading-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;opacity:0;pointer-events:none;position:absolute;right:0;top:0;transition:opacity .3s}.loading-overlay.visible{opacity:1;pointer-events:auto}@media (max-width:768px){.photo-modal__nav{height:32px;width:32px}.photo-modal__nav svg{height:20px;width:20px}.photo-modal__nav--prev{left:10px}.photo-modal__nav--next{right:10px}.photo-modal__close{height:32px;right:10px;top:10px;width:32px}.photo-modal__close svg{height:20px;width:20px}.photo-modal__counter{font-size:.8rem;left:10px;padding:.3rem .7rem;top:10px}.photo-modal__title{font-size:1rem}.photo-modal__metadata{align-items:flex-start;flex-direction:column;gap:.3rem}.photo-modal__image-container{height:calc(100% - 150px)}}.gallery-item-loader{background:#f0f0f0;border-radius:8px;height:0;overflow:hidden;padding-bottom:75%;position:relative;width:100%}.gallery-item-loader__shimmer{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#fff0,#fff3 50%,#fff0);background-size:200% 100%;height:100%;left:0;position:absolute;top:0;width:100%}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.photo-gallery__loading{padding:1rem}.photo-gallery__loading-spinner{margin-bottom:2rem}.photo-gallery__error,.photo-gallery__loading-spinner{align-items:center;display:flex;flex-direction:column;gap:1rem;text-align:center}.photo-gallery__error{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;color:#dc3545;padding:2rem}.photo-gallery__grid-container{padding:.5rem 0}.photo-gallery__header{margin-bottom:1.5rem;text-align:center}.photo-gallery__album-info{color:#666;font-size:.9rem;margin-top:.5rem}.photo-gallery__grid{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));margin-bottom:2rem}.photo-gallery__item{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;cursor:pointer;overflow:hidden;position:relative;transition:transform .3s ease,box-shadow .3s ease}.photo-gallery__item:hover{box-shadow:0 5px 15px #00000026;transform:translateY(-5px)}.photo-gallery__img{aspect-ratio:4/3;display:block;height:auto;-o-object-fit:cover;object-fit:cover;width:100%}.photo-gallery__title{background:#000000b3;bottom:0;color:#ffa140;font-size:.9rem;left:0;overflow:hidden;padding:.5rem;position:absolute;right:0;text-overflow:ellipsis;white-space:nowrap}.gallery-item-loader{animation:pulse 1.5s infinite;background-color:#f0f0f0;border-radius:8px;height:180px;width:100%}@keyframes pulse{0%{opacity:.6}50%{opacity:.8}to{opacity:.6}}
