@font-face{font-family:Signatie;src:url(/assets/Signatie-wt7OoP6S.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:OldStandardTT;src:url(/assets/OldStandardTT-Regular-BNLcCIn2.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:OldStandardTT,serif;line-height:1.6;color:#333}h1,h2{font-family:Signatie,serif}h3,h4,h5,h6{font-family:OldStandardTT,serif}.hidden{display:none!important}.settings-btn{position:fixed;top:1rem;right:1rem;width:3rem;height:3rem;border-radius:50%;background:#ffffffe6;border:2px solid #ddd;font-size:1.5rem;cursor:pointer;z-index:1000;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a;transition:transform .2s}.settings-btn:hover{transform:rotate(90deg)}.settings-panel{position:fixed;top:0;right:0;width:300px;height:100vh;background:#fff;box-shadow:-2px 0 8px #0000001a;z-index:999;padding:2rem;overflow-y:auto}.settings-content h3{font-family:OldStandardTT,serif;margin-bottom:1.5rem;font-size:1.5rem}.setting-group{margin-bottom:1.5rem;display:flex;flex-direction:column;gap:.5rem}.setting-group label{font-weight:600;letter-spacing:.05em;color:#444;font-size:.9rem;text-transform:uppercase}.setting-group select{padding:.5rem;border:2px solid #ddd;border-radius:4px;font-size:1rem}.close-btn{width:100%;padding:.75rem 1.5rem;background:transparent;color:#333;border:2px solid #333;border-radius:0;cursor:pointer;margin-top:1rem;letter-spacing:.1em;text-transform:uppercase;font-size:.9rem;transition:all .3s ease;position:relative;overflow:hidden}.close-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:#333;transition:left .3s ease;z-index:-1}.close-btn:hover{color:#fff;border-color:#333}.close-btn:hover:before{left:0}.hero{position:relative;height:100vh;display:flex;align-items:center;justify-content:center;text-align:center}.hero-bg{position:absolute;top:0;left:0;width:100%;height:100%;background:#e0e0e0;z-index:-1}.hero-content{z-index:1}.hero-title{font-family:Signatie,serif;font-size:3rem;margin-bottom:1rem;color:#333}.hero-subtitle{font-size:1.5rem;margin-bottom:2rem;color:#666}.rsvp-button{display:inline-block;padding:1rem 2.5rem;background:transparent;color:#333;text-decoration:none;border:2px solid #333;border-radius:0;font-size:1.1rem;letter-spacing:.1em;text-transform:uppercase;transition:all .3s ease;position:relative;overflow:hidden}.rsvp-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:#333;transition:left .3s ease;z-index:-1}.rsvp-button:hover{color:#fff;border-color:#333}section{padding:4rem 2rem;max-width:1200px;margin:0 auto}.section-title{font-family:Signatie,serif;font-size:2.5rem;margin-bottom:2rem;text-align:center;color:#333}.schedule{overflow:hidden}.timeline{position:relative;padding:3rem 0;display:flex;justify-content:space-between;align-items:flex-start;max-width:1100px;margin:0 auto}.timeline-line{position:absolute;top:calc(3rem + 35px);left:90px;right:90px;height:2px;background:#333;z-index:0;opacity:0;transform:scaleX(0);transform-origin:left center;transition:opacity .4s ease,transform 6s cubic-bezier(.25,.1,.25,1)}.timeline.animate .timeline-line{opacity:1;transform:scaleX(1)}.timeline-item{display:flex;flex-direction:column;align-items:center;text-align:center;flex:1;max-width:180px;position:relative;z-index:1;opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.timeline-item.visible{opacity:1;transform:translateY(0)}.timeline-icon{width:70px;height:70px;border-radius:50%;background:#fff;border:2px solid #333;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-bottom:1rem;transition:transform .3s ease,box-shadow .3s ease}.timeline-icon:hover{transform:scale(1.1);box-shadow:0 4px 12px #00000026}.timeline-icon svg{width:28px;height:28px;stroke:#333;stroke-width:2;fill:none;display:block}.timeline-content{display:flex;flex-direction:column;align-items:center}.timeline-content h3{font-family:OldStandardTT,serif;font-size:1.1rem;margin:0;color:#333;line-height:1.4}.timeline-time{font-family:OldStandardTT,serif;font-size:1.4rem;font-weight:600;color:#333;margin-bottom:.25rem;letter-spacing:.02em;position:relative;display:inline-block}.timeline-time .time-suffix{position:absolute;left:100%;top:50%;transform:translateY(-50%);font-size:.75rem;font-weight:400;margin-left:2px;text-transform:uppercase;white-space:nowrap}@media(max-width:900px){.timeline{flex-direction:column;align-items:flex-start;padding:2rem 0 2rem 2rem;gap:0}.timeline-line{top:95px;bottom:95px;left:calc(2rem + 35px);right:auto;width:2px;height:auto;background:#333;transform:scaleY(0);transform-origin:top center}.timeline.animate .timeline-line{transform:scaleY(1)}.timeline-time .time-suffix{position:static;transform:none;margin-left:2px}.timeline-item{flex-direction:row;text-align:left;max-width:none;width:100%;margin-bottom:2.5rem;transform:translate(-30px)}.timeline-item:last-of-type{margin-bottom:0}.timeline-item.visible{transform:translate(0)}.timeline-icon{margin-bottom:0;margin-right:1.5rem;width:70px;height:70px;flex-shrink:0}.timeline-content{align-items:flex-start}.timeline-content h3{font-size:1.15rem}.timeline-time{font-size:1.3rem}}.map-container{width:100%;height:400px;margin-bottom:2rem;background:#e0e0e0;border-radius:8px;overflow:hidden}.map-container iframe{width:100%;height:100%;border:0;border-radius:8px;display:block}.map-placeholder{color:#666;font-size:1.2rem}.location-info{display:flex;flex-direction:column;gap:2rem}.location-info h3{font-family:OldStandardTT,serif;font-size:1.5rem;margin-bottom:1rem}.location-info p{line-height:1.7;font-size:1.05rem}.venue-details{margin-bottom:.5rem}.venue-name{font-family:OldStandardTT,serif;font-size:1.3rem;font-weight:700;margin-bottom:.75rem;color:#333}.venue-address{margin-bottom:1rem;line-height:1.8}.venue-address p{margin-bottom:.25rem;font-size:1rem}.walking-info{margin-top:1rem;padding-top:1rem;border-top:1px solid #e0e0e0;font-style:italic;color:#555}.access-info{padding-top:1rem;border-top:1px solid #e0e0e0}.access-method{margin-bottom:1.5rem}.access-method:last-child{margin-bottom:0}.access-method h4{font-family:OldStandardTT,serif;font-size:1.2rem;margin-bottom:.5rem;color:#444;font-weight:400}.access-method p{line-height:1.8;margin-bottom:0}.shuttle-info{padding-top:1rem;border-top:1px solid #e0e0e0}.shuttle-schedule{margin-bottom:1rem}.shuttle-schedule h4{font-family:OldStandardTT,serif;font-size:1.2rem;margin-bottom:1rem;color:#444;font-weight:400}.shuttle-route{margin-bottom:1.25rem;padding-left:1rem;border-left:3px solid #d4af37}.shuttle-route:last-child{margin-bottom:1rem}.route-name{font-weight:600;margin-bottom:.5rem;color:#333}.route-times{font-family:Courier New,monospace;font-size:.95rem;color:#555;line-height:1.6;margin-bottom:0}.shuttle-notice{font-size:.9rem;color:#666;line-height:1.6;font-style:italic;margin-top:1rem;padding-top:1rem;border-top:1px solid #f0f0f0}.info-section{margin-bottom:3rem}.info-section h3{font-family:OldStandardTT,serif;font-size:1.5rem;margin-bottom:1rem}.info-section p{line-height:1.8;font-size:1.05rem}.attractions-container{width:100%;max-width:1050px;margin:2rem auto 0;display:flex;gap:2rem;border-radius:8px;overflow:hidden;background:#f9f9f9;min-height:500px}.attractions-list{width:300px;flex-shrink:0;background:#fff;border-right:1px solid #e0e0e0;overflow-y:auto;max-height:500px}.attraction-item{padding:1rem 1.25rem;cursor:pointer;border-bottom:1px solid #f0f0f0;transition:background-color .2s ease}.attraction-item:hover{background-color:#f5f5f5}.attraction-item.active{background-color:#e8f4f8;border-left:4px solid #d4af37;padding-left:calc(1.25rem - 4px)}.attraction-item-title{font-family:OldStandardTT,serif;font-size:1.1rem;color:#333;display:block}.attraction-item.active .attraction-item-title{font-weight:600;color:#000}.attraction-details{flex:1;display:flex;flex-direction:column;padding:0}.attraction-progress-bar{width:100%;height:4px;background-color:#e0e0e0;position:relative;overflow:hidden}.attraction-progress-fill{height:100%;background-color:#d4af37;width:0%;transition:width 10s linear}.attraction-image-container{width:100%;height:300px;background:#e0e0e0;overflow:hidden;position:relative}.attraction-image-container img{width:100%;height:100%;object-fit:cover}.attraction-image-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#999;font-size:1.1rem}.attraction-content{padding:1.5rem;flex:1}.attraction-content h4{font-family:OldStandardTT,serif;font-size:1.8rem;margin-bottom:1rem;color:#333}.attraction-content p{line-height:1.8;font-size:1.05rem;margin-bottom:1rem;color:#555}.attraction-content #attraction-info{font-size:.95rem;color:#666;font-style:italic;padding-top:1rem;border-top:1px solid #e0e0e0;margin-top:1rem}@media(max-width:768px){.attractions-container{max-width:100%;flex-direction:column;min-height:auto;position:relative}.attractions-list{width:100%;max-height:200px;border-right:none;border-bottom:1px solid #e0e0e0;position:relative}.attractions-list:after{content:"";position:absolute;bottom:0;left:0;right:0;height:50px;background:linear-gradient(to bottom,#fff0,#fffffff2);pointer-events:none;z-index:2}.attractions-list.scrolled-bottom:after{opacity:0;transition:opacity .2s ease}.attractions-list:before{content:"Scroll for more ↓";position:absolute;bottom:8px;left:50%;transform:translate(-50%);font-size:.75rem;color:#666;background:#fffffff2;padding:4px 12px;border-radius:12px;z-index:3;box-shadow:0 1px 3px #0000001a;animation:scrollHintBounce 2s ease-in-out infinite;pointer-events:none}:lang(ja) .attractions-list:before{content:"スクロール ↓"}.attractions-list.scrolled-bottom:before{opacity:0;transition:opacity .2s ease}@keyframes scrollHintBounce{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-4px)}}.attraction-image-container{height:250px}}p{line-height:1.7}input,textarea,select,button,label{font-family:OldStandardTT,serif}.rsvp-callout{max-width:600px;margin:0 auto 2.5rem;padding:1.5rem 2rem;background:#faf8f5;border:1px solid #e8e4de;border-radius:8px;border-left:4px solid #8b7355}.rsvp-callout-title{font-family:OldStandardTT,serif;font-size:1.1rem;color:#8b7355;margin-bottom:1rem;font-weight:600}.rsvp-callout-list{list-style:none;padding:0;margin:0}.rsvp-callout-list li{font-family:OldStandardTT,serif;font-size:1rem;color:#555;padding:.4rem 0 .4rem 1.2rem;position:relative}.rsvp-callout-list li:before{content:"•";position:absolute;left:0;color:#8b7355}html[lang=en] .ja-only{display:none}.rsvp-form{max-width:800px;margin:0 auto}.guest-entry{background:#f5f5f5;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem}.guest-entry h3{font-family:OldStandardTT,serif;font-size:1.2rem;margin-bottom:1rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.75rem;font-weight:600;letter-spacing:.05em;color:#444;font-size:.95rem;text-transform:uppercase}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:2px solid #ddd;border-radius:4px;font-size:1rem;font-family:inherit}.form-group textarea{min-height:100px;resize:vertical}.form-group.checkbox-group{display:flex;align-items:center;gap:.75rem}.form-group.checkbox-group label{margin-bottom:0;cursor:pointer}.form-group.checkbox-group input[type=checkbox]{width:auto;height:1.25rem;width:1.25rem;cursor:pointer;accent-color:#d4af37}.add-guest-btn,.submit-btn{width:100%;padding:1rem 2rem;font-size:1rem;border:2px solid;border-radius:0;cursor:pointer;margin-top:1rem;letter-spacing:.1em;text-transform:uppercase;transition:all .3s ease;position:relative;overflow:hidden;background:transparent}.add-guest-btn:before,.submit-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;transition:left .3s ease;z-index:-1}.add-guest-btn{border-color:#666;color:#666}.add-guest-btn:before{background:#666}.add-guest-btn:hover{color:#fff;border-color:#666}.add-guest-btn:hover:before{left:0}.submit-btn{border-color:#333;color:#333}.submit-btn:before{background:#333}.submit-btn:hover{color:#fff;border-color:#333}.submit-btn:hover:before{left:0}@media(max-width:768px){.hero-title{font-size:2rem}.hero-subtitle{font-size:1.25rem}.section-title{font-size:2rem}.settings-panel{width:100%}}body{overflow-x:hidden}.hero{width:100%;height:100vh;overflow:hidden;margin:0!important;padding:0!important;max-width:none!important}.hero-bg{background:#f5f0e8;background-image:url(/images/traditional-hero.jpg);background-size:cover;background-position:center;background-repeat:no-repeat;width:100%;left:0}.hero-bg:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:0}.hero-title{color:#fff!important;text-shadow:0 2px 4px rgba(0,0,0,.3)}.hero-subtitle{color:#f5f5f5!important;text-shadow:0 1px 2px rgba(0,0,0,.3)}.rsvp-button{color:#fff!important;border-color:#fff!important;background:transparent}.rsvp-button:before{background:#fff!important}.rsvp-button:hover{color:#333!important;border-color:#fff!important}.rsvp-button:hover:before{left:0}.hero-content{position:relative;z-index:1}.timeline-icon{background:#fff}.section-title{color:#8b4513}
