@font-face{font-family:Lonely Study;src:url(/fonts/Lonely%20Study.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Loverine;src:url(/fonts/Loverine.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Papernotes;src:url(/fonts/Papernotes.woff2) format("woff2"),url(/fonts/PapernotesRegular.woff) format("woff"),url(/fonts/Papernotes.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Papernotes;src:url(/fonts/Papernotes%20Bold.woff2) format("woff2"),url(/fonts/PapernotesBold.woff) format("woff"),url(/fonts/Papernotes%20Bold.otf) format("opentype");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:Papernotes Sketch;src:url(/fonts/Papernotes%20Sketch.woff2) format("woff2"),url(/fonts/Papernotes%20Sketch.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:#2d2d2d;background:#faf9f7;line-height:1.6;min-height:100vh}#root{min-height:100vh}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.gallery{display:flex;flex-direction:column;gap:10rem;padding:4rem 2rem;max-width:1200px;margin:0 auto}.gallery-item{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}.gallery-item.image-left{grid-template-areas:"media content"}.gallery-item.image-right{grid-template-areas:"content media"}.gallery-media{grid-area:media;position:relative;aspect-ratio:4/3;overflow:hidden;border-radius:20px;background:linear-gradient(135deg,#f5f5f5,#e8e8e8);cursor:pointer;box-shadow:0 10px 40px #0000001a,0 0 0 1px #ffffff80 inset;transition:box-shadow .4s ease}.gallery-media:hover{box-shadow:0 20px 60px #00000026,0 0 0 1px #fffc inset}.gallery-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.03,.98,.52,.99)}.gallery-media:hover img{transform:scale(1.08)}.gallery-media video{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.03,.98,.52,.99)}.gallery-media:hover video{transform:scale(1.08)}.gallery-content{grid-area:content;padding:1.5rem;animation:fadeInContent .6s ease both}.gallery-item:nth-child(1) .gallery-content{animation-delay:.1s}.gallery-item:nth-child(2) .gallery-content{animation-delay:.2s}.gallery-item:nth-child(3) .gallery-content{animation-delay:.3s}.gallery-item:nth-child(4) .gallery-content{animation-delay:.4s}@keyframes fadeInContent{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.gallery-date{display:inline-block;font-size:.85rem;color:#e85a8f;font-weight:600;margin-bottom:1rem;text-transform:uppercase;letter-spacing:1px;padding:.4rem .8rem;background:#e85a8f1a;border-radius:20px}.gallery-caption{font-family:Papernotes,sans-serif;font-size:1.3rem;color:#374151;line-height:1.8;font-weight:400}@media(max-width:768px){.gallery{padding:2rem 1rem;gap:4rem}.gallery-item{grid-template-columns:1fr;gap:1.5rem}.gallery-item.image-left,.gallery-item.image-right{grid-template-areas:"media" "content"}.gallery-media{border-radius:16px;aspect-ratio:16/10}.gallery-content{padding:.5rem;text-align:center}.gallery-date{font-size:.8rem}.gallery-caption{font-size:1.1rem;line-height:1.7}}@media(hover:none)and (pointer:coarse){.gallery-item{transform:none!important}.gallery-media:active{transform:scale(.98);transition:transform .1s ease}.gallery-media:active img{transform:scale(1.02)}}@media(prefers-reduced-motion:reduce){.gallery-content{animation:none}.gallery-media img{transition:none}}.lightbox{position:fixed;inset:0;z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;opacity:0;visibility:hidden;transition:opacity .4s ease,visibility .4s ease}.lightbox.open{opacity:1;visibility:visible}.lightbox-backdrop{position:absolute;inset:0;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.lightbox-close{position:absolute;top:1.5rem;right:1.5rem;z-index:10;width:48px;height:48px;background:#fff;border:none;border-radius:50%;font-size:1.8rem;color:#2d2d2d;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 15px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.lightbox-close:hover{transform:scale(1.1);box-shadow:0 4px 20px #00000026}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:48px;height:48px;background:#fff;border:none;border-radius:50%;font-size:2rem;color:#2d2d2d;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 15px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.lightbox-nav:hover{transform:translateY(-50%) scale(1.1);box-shadow:0 4px 20px #00000026}.lightbox-prev{left:1.5rem}.lightbox-next{right:1.5rem}.lightbox-content{position:relative;z-index:5;max-width:90vw;max-height:70vh;display:flex;align-items:center;justify-content:center}.lightbox-image,.lightbox-video{max-width:100%;max-height:70vh;border-radius:12px;box-shadow:0 10px 50px #0003;transform:scale(.9);opacity:0;transition:transform .4s cubic-bezier(.34,1.56,.64,1),opacity .4s ease}.lightbox.open .lightbox-image,.lightbox.open .lightbox-video{transform:scale(1);opacity:1}.lightbox-info{position:relative;z-index:5;text-align:center;margin-top:1.5rem;max-width:600px;transform:translateY(20px);opacity:0;transition:transform .4s ease .1s,opacity .4s ease .1s}.lightbox.open .lightbox-info{transform:translateY(0);opacity:1}.lightbox-date{color:#e85a8f;font-weight:500;font-size:.9rem}.lightbox-caption{font-family:Papernotes,sans-serif;font-size:1.2rem;margin-top:.5rem;color:#555;line-height:1.7;white-space:pre-wrap}@media(max-width:768px){.lightbox{padding:1rem}.lightbox-close{top:1rem;right:1rem;width:40px;height:40px;font-size:1.5rem}.lightbox-nav{width:40px;height:40px;font-size:1.5rem}.lightbox-prev{left:.5rem}.lightbox-next{right:.5rem}.lightbox-content,.lightbox-image,.lightbox-video{max-height:60vh}}.app{min-height:100vh;position:relative}.parallax-bg{position:fixed;inset:0;z-index:-1;overflow:hidden;background:linear-gradient(135deg,#fdf2f8,#faf5ff,#f0f9ff)}.parallax-layer{position:absolute;border-radius:50%;filter:blur(30px);opacity:.7;will-change:transform;transform:translateZ(0);backface-visibility:hidden}.layer-1{width:500px;height:500px;top:-100px;left:-100px;background:radial-gradient(circle,rgba(244,114,182,.6) 0%,transparent 70%)}.layer-2{width:450px;height:450px;top:20%;right:-100px;background:radial-gradient(circle,rgba(192,132,252,.6) 0%,transparent 70%)}.layer-3{width:550px;height:550px;top:50%;left:-150px;background:radial-gradient(circle,rgba(96,165,250,.55) 0%,transparent 70%)}.layer-4{width:400px;height:400px;top:70%;right:-50px;background:radial-gradient(circle,rgba(251,113,133,.55) 0%,transparent 70%)}.layer-5{width:480px;height:480px;top:-50px;right:10%;background:radial-gradient(circle,rgba(34,211,238,.5) 0%,transparent 70%)}.layer-6{width:520px;height:520px;top:40%;left:30%;background:radial-gradient(circle,rgba(129,140,248,.5) 0%,transparent 70%)}.layer-7{width:450px;height:450px;top:80%;left:10%;background:radial-gradient(circle,rgba(56,189,248,.5) 0%,transparent 70%)}.layer-8{width:400px;height:400px;top:90%;left:50%;background:radial-gradient(circle,rgba(167,139,250,.5) 0%,transparent 70%)}.gradient-overlay{position:absolute;inset:0;will-change:background;transform:translateZ(0)}.light-streams{position:absolute;inset:0;overflow:hidden;pointer-events:none}.light-stream{position:absolute;width:2px;height:200%;background:linear-gradient(to bottom,transparent 0%,rgba(255,255,255,.8) 20%,rgba(255,255,255,.9) 50%,rgba(255,255,255,.8) 80%,transparent 100%);transform:rotate(25deg) translateZ(0);animation:streamFlow 8s linear infinite;opacity:0;filter:blur(1px);box-shadow:0 0 15px #fff6;will-change:transform,opacity}.stream-1{left:10%;animation-delay:0s;animation-duration:7s}.stream-2{left:25%;animation-delay:-2s;animation-duration:9s;width:3px}.stream-3{left:45%;animation-delay:-4s;animation-duration:6s}@keyframes streamFlow{0%{transform:rotate(25deg) translateY(-100%);opacity:0}5%{opacity:.6}50%{opacity:.8}95%{opacity:.6}to{transform:rotate(25deg) translateY(50%);opacity:0}}.content{position:relative;z-index:1}.hero{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:3rem;text-align:center}.hero-content{margin-bottom:3rem}.hero h1{font-family:Lonely Study,Georgia,serif;font-size:clamp(3.5rem,12vw,7rem);font-weight:400;color:#1f2937;margin-bottom:1.5rem;letter-spacing:.02em;background:linear-gradient(135deg,#831843,#6b21a8,#1e40af);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-family:Papernotes,sans-serif;font-size:clamp(1.2rem,3vw,1.6rem);color:#6b7280;font-weight:400}.scroll-hint{display:flex;flex-direction:column;align-items:center;gap:.75rem;color:#9ca3af;font-size:.9rem;animation:fadeInUp 1s ease .5s both}.scroll-arrow{width:24px;height:24px;border-right:2px solid #d1d5db;border-bottom:2px solid #d1d5db;transform:rotate(45deg);animation:bounce 2s infinite}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,20%,50%,80%,to{transform:rotate(45deg) translateY(0)}40%{transform:rotate(45deg) translateY(8px)}60%{transform:rotate(45deg) translateY(4px)}}@media(max-width:768px){.parallax-layer{filter:blur(40px);opacity:.5}.layer-1{width:300px;height:300px}.layer-2{width:250px;height:250px}.layer-3{width:350px;height:350px}.layer-4{width:200px;height:200px}.hero{min-height:80vh;padding:2rem}}.footer-note{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:3rem 2rem 6rem;text-align:center}.footer-note p{font-family:Papernotes,Georgia,serif;font-size:clamp(1.5rem,4vw,2.4rem);max-width:700px;margin:0 auto;line-height:1.4;background:linear-gradient(135deg,#e98d4a,#e85a8f,#a855f7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@media(prefers-reduced-motion:reduce){.parallax-layer,.parallax-bg:before,.parallax-bg:after{animation:none}.light-stream{animation:none;opacity:.3}.scroll-arrow,.scroll-hint{animation:none}}
