.gallery-container{padding:2rem;max-width:1400px;margin:0 auto}.loading,.error,.no-photos{text-align:center;padding:4rem 2rem;font-size:1.2rem;color:#666}.error{color:#d32f2f}.retry-button{margin-top:1rem;padding:.75rem 1.5rem;background-color:#1976d2;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background-color .3s}.retry-button:hover{background-color:#1565c0}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem;margin-top:2rem}.photo-item{position:relative;cursor:pointer;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .3s,box-shadow .3s;background-color:#f5f5f5}.photo-item:hover{transform:translateY(-4px);box-shadow:0 4px 16px #0003}.photo-item img{width:100%;height:250px;object-fit:cover;display:block}.photo-placeholder{width:100%;height:250px;display:flex;align-items:center;justify-content:center;background-color:#e0e0e0;color:#666;font-size:.9rem;padding:1rem;text-align:center}.photo-title{padding:.75rem;background-color:#fff;font-size:.9rem;color:#333;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.modal{position:fixed;inset:0;background-color:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal-content{position:relative;max-width:90vw;max-height:90vh;background-color:#fff;border-radius:8px;overflow:hidden;display:flex;flex-direction:column}.modal-close{position:absolute;top:1rem;right:1rem;background-color:#000000b3;color:#fff;border:none;border-radius:50%;width:40px;height:40px;font-size:1.5rem;cursor:pointer;z-index:1001;display:flex;align-items:center;justify-content:center;transition:background-color .3s}.modal-close:hover{background-color:#000000e6}.modal-content img{max-width:100%;max-height:70vh;object-fit:contain;display:block}.modal-placeholder{padding:4rem;text-align:center;color:#666}.modal-title{padding:1rem;font-size:1.2rem;font-weight:600;color:#333;border-top:1px solid #e0e0e0}.modal-description{padding:0 1rem 1rem;color:#666;line-height:1.6}@media(max-width:768px){.gallery-container{padding:1rem}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.photo-item img,.photo-placeholder{height:150px}.modal{padding:1rem}.modal-content{max-width:100%;max-height:100%}}.navigation{display:flex;flex-wrap:nowrap;justify-content:center;align-items:center;list-style:none;padding-left:0;margin:16px auto}.nav-item{display:inline-flex;margin:0 16px}.nav-link{padding:4px}.nav-link:hover{background:#0000000d}.App{min-height:100vh;display:flex;flex-direction:column}.App-header{background:#fff;color:#000;padding:2rem;text-align:center}.App-header h1{margin:0;font-size:2.5rem;font-weight:600}main{flex:1;background-color:#fff}@media(max-width:768px){.App-header{padding:1.5rem}.App-header h1{font-size:2rem}}.center-text{text-align:center;margin:1 rem}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}
