:root{--header-h:5.5rem;--bg:#0f0f12;--bg-elevated:#18181c;--text:#e8e6e3;--text-muted:#9c9890;--accent:#c9a227;--danger:#e07060;--sans:"Segoe UI", system-ui, sans-serif;font-family:var(--sans);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--text);background:var(--bg)}*,:before,:after{box-sizing:border-box}html,body{height:100%;margin:0;overflow:hidden}#root{flex-direction:column;height:100%;min-height:100dvh;display:flex}.app{flex-direction:column;flex:1;min-height:0;display:flex}.app__header{text-align:center;background:var(--bg-elevated);border-bottom:1px solid #ffffff0f;flex-shrink:0;padding:.75rem 1rem}.app__title{letter-spacing:.02em;margin:0;font-size:1.125rem;font-weight:600}.app__subtitle{color:var(--text-muted);margin:.25rem 0 0;font-size:.8125rem}.app__subtitle a{color:var(--accent);text-decoration:none}.app__subtitle a:hover{text-decoration:underline}.painting-feed{scroll-snap-type:y mandatory;scroll-behavior:smooth;flex:1;min-height:0;overflow-y:auto}.painting-slide{min-height:calc(100dvh - var(--header-h));scroll-snap-align:start;scroll-snap-stop:always;background:var(--bg);border-bottom:1px solid #ffffff0f;flex-direction:column;display:flex}.painting-slide__frame{flex:1;justify-content:center;align-items:center;min-height:0;padding:.75rem;display:flex}.painting-slide__img{object-fit:contain;border-radius:4px;width:auto;max-width:100%;height:auto;max-height:min(72dvh,720px);box-shadow:0 8px 32px #00000073}.painting-slide__placeholder{min-height:200px;color:var(--text-muted);border:1px dashed #ffffff1f;border-radius:4px;justify-content:center;align-items:center;width:100%;max-width:480px;font-size:.9rem;display:flex}.painting-slide__meta{text-align:center;flex-shrink:0;padding:1rem 1.25rem 1.5rem}.painting-slide__title{margin:0;font-size:1.25rem;font-weight:600;line-height:1.3}.painting-slide__artist{color:var(--text-muted);margin:.35rem 0 0;font-size:1rem}.painting-slide__year{color:var(--text-muted);margin:.25rem 0 0;font-size:.9rem}.painting-slide__links{color:var(--text-muted);margin:.75rem 0 0;font-size:.75rem}.painting-slide__links a{color:var(--accent);text-decoration:none}.painting-slide__links a:hover{text-decoration:underline}.painting-feed__sentinel{width:100%;height:1px}.painting-feed__status{text-align:center;color:var(--text-muted);padding:.75rem;font-size:.875rem}.painting-feed__status--center{flex:1;justify-content:center;align-items:center;min-height:40dvh;display:flex}.painting-feed__error{text-align:center;color:var(--danger);padding:1rem;font-size:.875rem}.painting-feed__error button{font:inherit;cursor:pointer;color:var(--text);background:var(--bg-elevated);border:1px solid #ffffff26;border-radius:6px;margin-top:.5rem;padding:.4rem .9rem}.painting-feed__error button:hover{background:#ffffff0f}.painting-feed__end{text-align:center;color:var(--text-muted);margin:0;padding:1rem;font-size:.8rem}
