*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}html,body{max-width:100vw;overflow-x:hidden}body{color:#2c3e50;-webkit-font-smoothing:antialiased;background:#fff8ed;font-family:Lora,Georgia,serif;font-size:16px;line-height:1.7}h1,h2,h3,h4,h5,h6{color:#1a1a1a;font-family:Playfair Display,serif;font-weight:400;line-height:1.3}h1{margin-bottom:2rem;font-size:clamp(2.5rem,5vw,5rem)}h2{margin-bottom:2rem;font-size:clamp(2rem,4vw,3.5rem)}h3{margin-bottom:1.5rem;font-size:clamp(1.5rem,3vw,2rem)}p{margin-bottom:1.5rem;font-size:clamp(1rem,2vw,1.125rem);line-height:1.8}a{color:#a67c52;border-bottom:1px solid #0000;text-decoration:none;transition:all .3s}a:hover{color:#8b6438;border-bottom-color:#8b6438}img{max-width:100%;height:auto;display:block}::selection{color:#fff;background:#a67c52}
.container{max-width:1200px;margin:0 auto;padding:0 2rem}.hero{text-align:center;background:#fff8ed;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:4rem 2rem;display:flex;position:relative}.hero:before{content:"";opacity:.3;background:url("data:image/svg+xml,<svg width=\"60\" height=\"60\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M0 0h60v60H0z\" fill=\"none\"/><path d=\"M30 20a10 10 0 1 0 0 20 10 10 0 0 0 0-20z\" fill=\"rgba(166,124,82,0.03)\"/></svg>");position:absolute;inset:0}.hero-content{z-index:1;max-width:800px;position:relative}.hero h1{letter-spacing:-.02em;color:#1a1a1a;margin-bottom:1rem;font-size:clamp(3rem,7vw,6rem);font-weight:300}.hero .ampersand{opacity:.6;margin:0 1rem;font-size:clamp(2rem,5vw,4rem);font-style:italic;display:inline-block}.hero p{color:#5a6c7d;margin-top:2rem;font-size:clamp(1.25rem,2.5vw,1.75rem);font-style:italic}.nav{-webkit-backdrop-filter:blur(20px);z-index:1000;background:#fff8edfa;padding:1.5rem 0;transition:all .3s;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 20px #0000000d}.nav ul{flex-wrap:wrap;justify-content:center;gap:2.5rem;padding:0 2rem;list-style:none;display:flex}.nav a{text-transform:uppercase;letter-spacing:1.5px;color:#5a6c7d;border-bottom:none;font-family:Lora,serif;font-size:.95rem;font-weight:500;position:relative}.nav a:after{content:"";background:#a67c52;width:0;height:2px;transition:width .3s;position:absolute;bottom:-5px;left:0}.nav a:hover:after,.nav a.active:after{width:100%}.section{min-height:50vh;padding:8rem 2rem}.section:nth-child(2n){background:#fff4e0}.section-title{text-align:center;color:#1a1a1a;margin-bottom:4rem;font-size:clamp(2.5rem,5vw,4rem);font-weight:300;position:relative}.section-title:after{content:"";background:#a67c52;width:80px;height:3px;margin:2rem auto 0;display:block}.content{color:#4a5568;max-width:800px;margin:0 auto;font-size:1.125rem;line-height:1.9}.content p{margin-bottom:2rem}.content strong{color:#1a1a1a;font-weight:600}.story-section{background:#fff;border-radius:12px;margin:3rem 0;padding:2.5rem;box-shadow:0 4px 6px #0000000d}.image-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem;margin:4rem 0;display:grid}.image-grid img{object-fit:cover;border-radius:12px;width:100%;height:350px;transition:transform .3s,box-shadow .3s;box-shadow:0 8px 16px #0000001a}.image-grid img:hover{transform:translateY(-8px);box-shadow:0 12px 24px #00000026}.photo-gallery{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem;margin:4rem 0;display:grid}.photo-gallery img{object-fit:cover;border-radius:8px;width:100%;height:300px;transition:transform .3s}.photo-gallery img:hover{transform:scale(1.05)}.schedule-day{background:#fff;border-left:4px solid #a67c52;border-radius:12px;margin:3rem 0;padding:2.5rem;box-shadow:0 4px 6px #0000000d}.schedule-day h3{color:#a67c52;margin-bottom:1.5rem;font-size:1.75rem}.schedule-day p{color:#4a5568;margin-bottom:1rem}.faq-item{background:#fff;border-radius:12px;margin:2.5rem 0;padding:2rem;transition:box-shadow .3s;box-shadow:0 2px 4px #0000000d}.faq-item:hover{box-shadow:0 4px 8px #0000001a}.faq-item h3{color:#1a1a1a;margin-bottom:1rem;font-size:1.5rem}.faq-item p{color:#4a5568}.place-card{background:#fff;border-radius:12px;margin:2.5rem 0;padding:2rem;box-shadow:0 4px 6px #0000000d}.place-card h3{color:#a67c52;margin-bottom:1rem}.popup-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;background:#0009;animation:.3s fadeIn;position:fixed;inset:0}.popup-container{z-index:2001;width:90%;max-width:550px;animation:.4s slideUp;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.popup-content{text-align:center;background:#fff8ed;border:2px solid #a67c52;border-radius:16px;padding:3rem 2.5rem;position:relative;box-shadow:0 20px 60px #0000004d}.popup-close{color:#5a6c7d;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.5rem;transition:all .3s;display:flex;position:absolute;top:1rem;right:1rem}.popup-close:hover{color:#a67c52;background:#a67c521a;transform:rotate(90deg)}.popup-content h2{margin-bottom:1.5rem;font-family:Playfair Display,serif;font-weight:400}.popup-content p{color:#4a5568;font-size:1.05rem;line-height:1.8}.popup-button{color:#fff;cursor:pointer;letter-spacing:.5px;background:#a67c52;border:none;border-radius:8px;margin-top:.5rem;padding:.875rem 2.5rem;font-family:Lora,serif;font-size:1rem;font-weight:500;transition:all .3s}.popup-button:hover{background:#8b6343;transform:translateY(-2px);box-shadow:0 4px 12px #a67c524d}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}@media (max-width:768px){.hero h1{font-size:2.5rem}.hero .ampersand{font-size:2rem}.hero p{font-size:1.1rem}.nav{padding:1rem 0}.nav ul{gap:.75rem;padding:0 1rem}.nav a{letter-spacing:1px;font-size:.75rem}.container{padding:0 1rem}.section{padding:3rem 1rem}.section-title{margin-bottom:2rem}.story-section{margin:1.5rem 0;padding:1.5rem}.image-grid,.photo-gallery{grid-template-columns:1fr;gap:1rem}.schedule-day,.faq-item,.place-card{margin:1.5rem 0;padding:1.5rem}.popup-content{padding:2rem 1.5rem}.popup-content h2{font-size:1.5rem}.popup-content p{font-size:.95rem}.popup-button{padding:.75rem 2rem;font-size:.95rem}}
