@import"https://fonts.googleapis.com/css2?family=Great+Vibes&family=Lato:ital,wght@0,300;0,400;1,300&display=swap";:root{--bg: #0a0a0a;--surface: #141414;--text: #f0e6d8;--muted: #a09080;--accent: #c41e3a;--display: "Great Vibes", "Brush Script MT", cursive;--body: "Lato", sans-serif}*{margin:0;padding:0;box-sizing:border-box}html,body{font-family:var(--body);font-weight:300;line-height:1.8;background:var(--bg);color:var(--text);width:100vw}h1,h2,h3{font-family:var(--display);font-weight:700;line-height:1.15}#app{position:relative;width:100vw;height:100vh;overflow:hidden;background:var(--bg)}.slide{position:absolute;inset:0;width:100%;height:100%;visibility:hidden;display:flex}.slide.active{visibility:visible}.photo-half{width:55%;height:100%;overflow:hidden;flex-shrink:0}.photo-half img{width:100%;height:100%;object-fit:cover;object-position:center}.text-half{width:45%;height:100%;display:flex;flex-direction:column;justify-content:center;padding:3rem 4rem;background:var(--surface);flex-shrink:0}.slide.photo-left{flex-direction:row-reverse}.slide.photo-right{flex-direction:row}.slide-heading{font-family:var(--display);font-size:clamp(2.5rem,4vw,4rem);color:var(--text);margin-bottom:2rem;max-width:480px;line-height:1.2}.slide-body{font-family:var(--body);font-size:clamp(1rem,1.3vw,1.15rem);font-weight:300;line-height:1.8;color:var(--muted);margin-bottom:.6rem;max-width:460px}.slide-hero{flex-direction:column}.slide-hero .hero-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 15%}.slide-hero .hero-overlay{position:absolute;inset:0;background:radial-gradient(ellipse at center,#0a0a0a00,#0a0a0a80);pointer-events:none}.slide-hero .hero-content{position:relative;z-index:2;text-align:center;margin:auto;padding:2rem}.hero-title{font-size:clamp(4rem,11vw,10rem);color:var(--text);letter-spacing:.02em;line-height:1.1;text-shadow:0 4px 30px rgba(0,0,0,.5)}.hero-title .word{display:inline-block;margin-right:.25em}.hero-next{position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%);z-index:2;background:none;border:none;color:var(--muted);cursor:pointer;padding:.5rem;opacity:.5;transition:opacity .3s,color .3s}.hero-next:hover{opacity:1;color:var(--accent)}.slide-colophon{flex-direction:column;align-items:center;justify-content:center;text-align:center;background:linear-gradient(to bottom,var(--bg),#000)}.colophon-title{font-size:clamp(2rem,4vw,3.5rem);color:var(--text);margin-bottom:1.5rem}.colophon-body{font-size:clamp(1rem,1.5vw,1.25rem);color:var(--muted);font-style:italic;margin-bottom:3rem;max-width:600px}.photographer-link{display:inline-flex;align-items:center;gap:.3em;text-decoration:none;font-family:var(--body);font-size:1rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;margin-top:2rem;transition:opacity .3s}.photographer-link:hover{opacity:.8}.link-genx{color:var(--text)}.link-photo{color:var(--accent)}.gallery-link{display:inline-block;font-family:var(--body);font-size:.85rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);text-decoration:none;margin-top:1.5rem;margin-bottom:1.5rem;transition:color .3s}.gallery-link:hover{color:var(--text)}.progress-dots{position:fixed;right:1.5rem;top:50%;transform:translateY(-50%);z-index:100;display:flex;flex-direction:column;gap:.7rem}.dot{width:6px;height:6px;border-radius:50%;border:none;padding:0;cursor:pointer;background:var(--muted);opacity:.2;transition:all .3s ease}.dot:hover{opacity:.6;transform:scale(1.3)}.dot.active{background:var(--accent);opacity:1;transform:scale(1.4);box-shadow:0 0 8px #c41e3a59}.gallery-wrap{min-height:100vh;padding:3rem 4rem;background:var(--bg)}.gallery-header{display:flex;align-items:center;gap:2rem;margin-bottom:3rem}.gallery-back{font-family:var(--body);font-size:.85rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .3s;white-space:nowrap}.gallery-back:hover{color:var(--accent)}.gallery-title{font-family:var(--display);font-size:clamp(2.5rem,5vw,4rem);color:var(--text);margin:0}.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.gallery-item{position:relative;aspect-ratio:3/4;overflow:hidden;border-radius:4px;background:var(--surface)}.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease,opacity .3s}.gallery-item:hover img{transform:scale(1.03);opacity:.85}.download-btn{position:absolute;bottom:.75rem;right:.75rem;width:36px;height:36px;border-radius:50%;background:#0009;backdrop-filter:blur(4px);color:var(--text);display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(4px);transition:opacity .3s,transform .3s,background .3s;text-decoration:none;cursor:pointer;border:none}.gallery-item:hover .download-btn{opacity:1;transform:translateY(0)}.download-btn:hover{background:var(--accent)}.gallery-footer{margin-top:4rem;text-align:center}@media(max-width:900px){.slide:not(.slide-hero):not(.slide-colophon){flex-direction:column}.photo-half{width:100%;height:55%}.text-half{width:100%;height:45%;padding:2rem}.slide-heading,.slide-body{max-width:none}.progress-dots{right:.75rem;gap:.5rem}.dot{width:5px;height:5px}.hero-title{font-size:clamp(3.5rem,14vw,7rem)}.gallery-grid{grid-template-columns:repeat(2,1fr)}.gallery-wrap{padding:2rem}}@media(max-width:600px){.gallery-grid{grid-template-columns:1fr;gap:1rem}.gallery-wrap{padding:1.5rem}.gallery-header{flex-direction:column;align-items:flex-start;gap:.5rem}}
