*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;font-weight:400;color:#1a1a2e;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{scroll-behavior:smooth}body{min-width:320px;min-height:100vh;background:#fefefe;overflow-x:hidden}.bg-gradient-wrap{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none}.bg-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.45}.bg-orb--1{width:600px;height:600px;background:#e0c3fc;top:-10%;right:-15%;animation:orb-float-1 18s ease-in-out infinite}.bg-orb--2{width:500px;height:500px;background:#c4b5fd;top:30%;left:-20%;animation:orb-float-2 22s ease-in-out infinite}.bg-orb--3{width:450px;height:450px;background:#fbcfe8;bottom:5%;right:-5%;animation:orb-float-3 20s ease-in-out infinite}.bg-orb--4{width:350px;height:350px;background:#bfdbfe;top:60%;left:10%;animation:orb-float-1 25s ease-in-out infinite reverse}@keyframes orb-float-1{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-20px) scale(1.05)}66%{transform:translate(-20px,15px) scale(.95)}}@keyframes orb-float-2{0%,to{transform:translate(0) scale(1)}33%{transform:translate(-25px,30px) scale(1.08)}66%{transform:translate(20px,-10px) scale(.97)}}@keyframes orb-float-3{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-30px,-25px) scale(1.06)}}@media(max-width:768px){.bg-orb{filter:blur(80px);opacity:.3}.bg-orb--1{width:300px;height:300px;top:-5%;right:-20%}.bg-orb--2{width:250px;height:250px;top:30%;left:-25%}.bg-orb--3{width:220px;height:220px;bottom:10%;right:-15%}.bg-orb--4{width:200px;height:200px;top:60%;left:-10%}}@media(prefers-reduced-motion:reduce){.bg-orb{animation:none}}.navbar{position:fixed;top:0;left:0;right:0;z-index:10;display:flex;align-items:center;justify-content:center;height:3.5rem;padding:2rem 0;background:#ffffff73;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.5);transition:background .3s ease,box-shadow .3s ease}.navbar--scrolled{background:#ffffffb3;box-shadow:0 1px 8px #0000000d}.navbar-title{font-family:Newsreader,Georgia,Times New Roman,serif;font-size:1.5rem;font-weight:500;letter-spacing:.01em;text-decoration:none;cursor:pointer;background:linear-gradient(90deg,#1a1a2e,#7c3aed,#a78bfa,#7c3aed,#1a1a2e);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:title-gradient 6s ease-in-out infinite}@keyframes title-gradient{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.scroll-top{position:fixed;bottom:2rem;right:2rem;z-index:10;width:44px;height:44px;border-radius:50%;border:none;background:#ffffffb3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 2px 12px #00000014;color:#6b7280;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(10px);pointer-events:none;transition:opacity .4s ease,transform .4s ease,background .3s ease,color .3s ease}.scroll-top--visible{opacity:1;transform:translateY(0);pointer-events:auto}.scroll-top:hover{background:#a78bfa;color:#fff;box-shadow:0 4px 16px #a78bfa4d}.app{max-width:1100px;margin:0 auto;padding:3.5rem 1.5rem 0;position:relative;z-index:1}.app-header{text-align:center;padding:5rem 1rem 3rem}.app-header h1{font-family:Newsreader,Georgia,Times New Roman,serif;font-size:3rem;font-weight:500;font-style:italic;color:#1a1a2e;letter-spacing:-.01em;margin-bottom:.5rem;line-height:1.15}.app-header p{font-family:Inter,system-ui,sans-serif;font-size:1.05rem;color:#6b7280;font-weight:400;letter-spacing:.01em}@media(max-width:768px){.app-header{padding:3rem 1rem 2rem}.app-header h1{font-size:2.2rem}.app-header p{font-size:.95rem}.scroll-top{bottom:1.5rem;right:1.5rem}}@media(prefers-reduced-motion:reduce){.navbar-title{animation:none;background-position:0% 50%}}.timeline{position:relative;padding:2rem 0 0}.timeline-track{position:absolute;left:50%;top:0;bottom:0;width:2px;background:linear-gradient(180deg,transparent 0%,#e5e7eb 8%,#e5e7eb 92%,transparent 100%);transform:translate(-50%)}.timeline-track-fill{position:absolute;left:50%;top:0;width:2px;background:linear-gradient(180deg,#c4b5fd,#a78bfa);transform:translate(-50%);border-radius:0 0 2px 2px;transition:height .1s linear;z-index:1}.timeline-node{position:relative;display:flex;align-items:flex-start;margin-bottom:3rem;width:100%}.timeline-node:last-of-type{margin-bottom:0}.timeline-node--left{justify-content:flex-start;padding-right:calc(50% + 2rem)}.timeline-node--right{justify-content:flex-end;padding-left:calc(50% + 2rem)}.timeline-dot{position:absolute;left:50%;top:1.5rem;width:14px;height:14px;border-radius:50%;background:#d4d4d8;border:3px solid #ffffff;box-shadow:0 0 0 2px #d4d4d840;transform:translate(-50%);z-index:2;transition:background .5s ease,box-shadow .5s ease,transform .3s ease}.timeline-dot-ping{position:absolute;inset:-4px;border-radius:50%;background:#a78bfa;opacity:0;transform:scale(.8);transition:opacity .3s ease}.timeline-node--active .timeline-dot{background:#a78bfa;box-shadow:0 0 0 3px #a78bfa30,0 0 12px #a78bfa25;transform:translate(-50%) scale(1.15)}.timeline-node--active .timeline-dot-ping{opacity:.4;animation:dot-ping 2s cubic-bezier(0,0,.2,1) infinite}@keyframes dot-ping{0%{transform:scale(.8);opacity:.4}75%,to{transform:scale(2.2);opacity:0}}.timeline-node:hover .timeline-dot{transform:translate(-50%) scale(1.2)}.timeline-card{width:100%;padding:1.5rem;background:#fff9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.7);border-radius:16px;box-shadow:0 1px 3px #0000000a;transition:box-shadow .4s ease,transform .3s ease,border-color .4s ease;cursor:default;will-change:transform}.timeline-card:hover{box-shadow:0 8px 24px #00000012}.timeline-node--active .timeline-card{border-color:#a78bfa33;box-shadow:0 2px 8px #a78bfa0f}.timeline-date{display:inline-block;font-size:.75rem;font-weight:600;color:#a78bfa;background:#a78bfa14;padding:.2rem .7rem;border-radius:99px;margin-bottom:.6rem;letter-spacing:.02em;transition:background .3s ease}.timeline-node--active .timeline-date{background:#a78bfa22}.timeline-location{font-family:Newsreader,Georgia,Times New Roman,serif;font-size:1.35rem;font-weight:500;color:#1a1a2e;margin-bottom:.3rem;line-height:1.3}.timeline-food{font-size:.95rem;color:#6b7280;line-height:1.4}.timeline-images{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.5rem;margin-top:1rem}.timeline-images img{width:100%;border-radius:8px;object-fit:cover;aspect-ratio:1}.timeline-footer{display:flex;flex-direction:column;align-items:center;padding-top:3rem;padding-bottom:50vh;position:relative}.timeline-footer-dot{width:8px;height:8px;border-radius:50%;background:#a78bfa;margin-bottom:1.5rem;opacity:.5;animation:footer-dot-pulse 3s ease-in-out infinite}@keyframes footer-dot-pulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.7;transform:scale(1.3)}}.timeline-footer-text{font-family:Newsreader,Georgia,Times New Roman,serif;font-style:italic;font-size:1.1rem;color:#a78bfa;opacity:.6;letter-spacing:.02em}.timeline-card-wrapper{opacity:0;transform:translateY(30px);width:100%}.timeline-node--left .timeline-card-wrapper{transform:translate(-20px,30px)}.timeline-node--right .timeline-card-wrapper{transform:translate(20px,30px)}.timeline-card-wrapper--visible{opacity:1;transform:translate(0);transition:opacity .8s cubic-bezier(.25,1,.5,1),transform .8s cubic-bezier(.25,1,.5,1)}@media(max-width:768px){.timeline{padding:1rem 0 0}.timeline-footer{padding-top:2rem;padding-bottom:40vh}.timeline-footer-text{font-size:1rem}.timeline-track,.timeline-track-fill{left:.75rem}.timeline-node{margin-bottom:2rem}.timeline-node--left,.timeline-node--right{padding-left:1rem;padding-right:0;justify-content:flex-start}.timeline-dot{left:.75rem;width:12px;height:12px;top:1.2rem}.timeline-card{padding:1.2rem}.timeline-location{font-size:1.15rem}.timeline-food{font-size:.9rem}.timeline-node--left .timeline-card-wrapper,.timeline-node--right .timeline-card-wrapper{transform:translate(20px,20px)}.timeline-card-wrapper--visible{transform:translate(0)}}@media(prefers-reduced-motion:reduce){.timeline-card-wrapper{opacity:1;transform:none;transition:none}.timeline-card-wrapper--visible{transition:none}.timeline-card:hover{transform:none}.timeline-card{will-change:auto}.timeline-node:hover .timeline-dot,.timeline-node--active .timeline-dot{transform:translate(-50%)}.timeline-dot-ping{animation:none;display:none}.timeline-track-fill{transition:none}}
