*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}:root{color:#333;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f3ebdc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-weight:400;line-height:1.6}body{-webkit-text-size-adjust:100%;-webkit-overflow-scrolling:touch;background-color:#f3ebdc;min-width:320px;min-height:100vh;margin:0}@media (width<=768px){a,button{justify-content:center;align-items:center;min-width:44px;min-height:44px;display:inline-flex}a,button,input,select,textarea{-webkit-tap-highlight-color:#8b451333}}#root{background-color:#f3ebdc;min-height:100vh}.banner{width:100%;position:relative}.banner-content{width:100%;height:70vh;min-height:400px;max-height:600px;display:flex}.banner-text{text-align:center;background-color:#f3ebdc;flex-direction:column;justify-content:center;align-items:center;width:55%;padding:2rem;display:flex}.banner-image{background-image:url(/orchardleigh%20house2.png);background-position:100%;background-repeat:no-repeat;background-size:contain;width:45%;position:relative;overflow:hidden}.banner-image:after{content:"";pointer-events:none;position:absolute;inset:0;box-shadow:inset 0 0 20px 3px #f3ebdccc}.couple-names{letter-spacing:.05em;text-transform:uppercase;color:#333;margin:0 0 1rem;font-family:Georgia,serif;font-size:clamp(1.8rem,4vw,3rem);font-weight:300}.wedding-date{letter-spacing:.15em;text-transform:uppercase;color:#555;margin:0;font-size:clamp(1rem,2vw,1.4rem);font-weight:300}.topbar-separator{background-image:url(/top%20bar.png);background-position:50%;background-repeat:no-repeat;background-size:auto 100%;width:100%;height:150px;margin-top:50px}@media (width<=768px){.banner-content{flex-direction:column;height:auto;min-height:500px}.banner-text{width:100%;min-height:200px;padding:2rem 1rem}.banner-image{width:100%;min-height:300px}.topbar-separator{height:60px;margin-top:20px}}@media (width<=480px){.banner-content{min-height:450px}.banner-text{padding:1.5rem 1rem}.banner-image{min-height:250px}.couple-names{margin-bottom:.75rem;font-size:1.8rem}.wedding-date{font-size:1rem}.topbar-separator{height:50px}}@media (width<=375px){.banner-content{min-height:400px}.banner-text{padding:1.25rem .75rem}.banner-image{min-height:220px}.couple-names{font-size:1.6rem}.wedding-date{letter-spacing:.1em;font-size:.95rem}}.information{background-color:#f3ebdc;padding:4rem 2rem}.container{max-width:1200px;margin:0 auto}.two-column-layout{grid-template-columns:1.5fr 1fr;align-items:start;gap:4rem;display:grid}.left-column{flex-direction:column;gap:2.5rem;display:flex}.info-section{text-align:left}.info-section h3{letter-spacing:.08em;text-transform:uppercase;color:#333;margin:0 0 1rem;font-family:Georgia,serif;font-size:1.5rem;font-weight:400}.info-section h4{letter-spacing:.05em;text-transform:uppercase;color:#555;margin:1.5rem 0 .75rem;font-size:1.1rem;font-weight:500}.info-section p{color:#555;margin:.5rem 0;font-size:1rem;line-height:1.7}.info-section strong{color:#333;font-weight:500}.important-note{color:#8b4513;margin-top:.5rem;font-style:italic;display:block}.hotel-list,.price-list{margin:1rem 0;padding:0;list-style:none}.hotel-list li{background-color:#ffffff80;border-left:3px solid #ddd;margin-bottom:1.5rem;padding:1rem;line-height:1.6}.price-list li{color:#555;border-bottom:1px solid #eee;padding:.5rem 0;font-size:1rem}.price-list li:last-child{border-bottom:none}.download-link{color:#fff;background-color:#333;border-radius:4px;justify-content:center;align-items:center;min-height:44px;margin-top:.5rem;padding:.75rem 1.5rem;font-weight:500;text-decoration:none;transition:background-color .3s;display:inline-flex}.download-link:hover{background-color:#555}.info-section a.download-link[target=_blank],.info-section a.download-link[target=_blank]:hover{color:#fff;text-decoration:none}.info-section a.download-link{width:300px;max-width:100%}.contact-section{text-align:center;border-top:1px solid #ddd;padding-top:2rem}.contact-info{color:#555;margin:0;font-size:1rem}.contact-info a{color:#333;font-weight:500;text-decoration:none;transition:color .2s}.contact-info a:hover{color:#666;text-decoration:underline}.info-section a[target=_blank]{color:#333;font-weight:500;text-decoration:underline;transition:color .2s}.info-section a[target=_blank]:hover{color:#666}.right-column{position:sticky;top:2rem}.image-stack{flex-direction:column;gap:2rem;display:flex}.stacked-image{border-radius:4px;width:100%;height:auto;transition:transform .3s,box-shadow .3s;box-shadow:0 4px 12px #0000001a}.stacked-image:hover{transform:translateY(-4px);box-shadow:0 8px 20px #00000026}@media (width<=968px){.two-column-layout{grid-template-columns:1fr;gap:3rem}.right-column{order:-1;position:static}.image-stack{flex-direction:row;gap:1rem}.stacked-image{width:calc(50% - .5rem)}}@media (width<=768px){.information{padding:3rem 1.5rem}.left-column{gap:2rem}.image-stack{flex-direction:column}.stacked-image{width:100%}}@media (width<=480px){.information{padding:2rem 1rem}.info-section h3{font-size:1.3rem}.info-section h4{font-size:1rem}.hotel-list li{padding:.75rem;font-size:.95rem}.download-link{width:100%;min-height:48px;padding:1rem 1.5rem;font-size:.95rem}.info-section a[target=_blank]{align-items:center;min-height:44px;padding:.25rem 0;display:inline-flex}}@media (width<=375px){.information{padding:1.5rem .75rem}.info-section h3{font-size:1.2rem}.info-section p{font-size:.95rem}.hotel-list li{padding:.65rem;font-size:.9rem}}.timeline{background-color:#f3ebdc;padding:4rem 2rem}.section-title{letter-spacing:.1em;text-transform:uppercase;text-align:center;color:#333;margin:0 0 3rem;font-family:Georgia,serif;font-size:clamp(2rem,5vw,2.5rem);font-weight:300}.timeline-container{flex-flow:row;justify-content:center;gap:1.5rem;max-width:1400px;margin:0 auto;display:flex}.timeline-box{cursor:pointer;background-color:#ffffffb3;border-radius:8px;flex:1 1 0;padding:2rem 1.25rem;transition:transform .3s,box-shadow .3s;box-shadow:0 2px 8px #0000001a}.timeline-box:hover{transform:scale(1.05);box-shadow:0 4px 16px #00000026}.timeline-time{color:#8b4513;letter-spacing:.05em;white-space:nowrap;margin-bottom:.5rem;font-size:1.2rem;font-weight:500}.timeline-title{letter-spacing:.05em;text-transform:uppercase;color:#333;margin:0 0 .75rem;font-family:Georgia,serif;font-size:1.5rem;font-weight:400}.timeline-description{color:#555;margin:0;font-size:1rem;line-height:1.6}@media (width<=768px){.timeline{padding:3rem 1.5rem;position:relative}.timeline-container{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#8b45134d transparent;flex-flow:row;gap:1rem;margin-left:-1rem;margin-right:-1rem;padding-bottom:1rem;padding-left:1rem;padding-right:1rem;display:flex;overflow-x:auto}.timeline-container::-webkit-scrollbar{height:6px}.timeline-container::-webkit-scrollbar-track{background:0 0}.timeline-container::-webkit-scrollbar-thumb{background-color:#8b45134d;border-radius:3px}.timeline-box{scroll-snap-align:center;scroll-snap-stop:always;flex:0 0 85%;padding:1.5rem}.timeline-time{font-size:1rem}.timeline-title{font-size:1.25rem}.timeline:after{content:"";pointer-events:none;opacity:.8;background:linear-gradient(270deg,#f3ebdc,#0000);width:40px;height:80%;position:absolute;top:50%;right:1.5rem;transform:translateY(-50%)}@keyframes scroll-hint{0%,to{transform:translate(0)}50%{transform:translate(-10px)}}.timeline-container{animation:2s ease-in-out 1s 2 scroll-hint}}@media (width<=480px){.timeline-box{flex:0 0 90%}}.location-maps{background-color:#f3ebdc;padding:4rem 2rem}.location-maps .section-title{letter-spacing:.1em;text-transform:uppercase;text-align:center;color:#333;margin:0 0 3rem;font-family:Georgia,serif;font-size:clamp(2rem,5vw,2.5rem);font-weight:300}.maps-container{grid-template-columns:1fr 1fr;gap:2rem;max-width:1400px;margin:0 auto 2rem;display:grid}.map-wrapper{flex-direction:column;gap:1rem;display:flex}.map-title{letter-spacing:.05em;text-align:center;color:#8b4513;margin:0;font-family:Georgia,serif;font-size:1.25rem;font-weight:400}.google-map{border-radius:8px;width:100%;height:500px;overflow:hidden;box-shadow:0 4px 12px #00000026}.venue-marker{cursor:pointer;background-color:#dc143c;border:3px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:transform .2s;display:flex;box-shadow:0 4px 8px #0000004d}.venue-marker:hover{transform:scale(1.15)}.venue-icon{font-size:28px;line-height:1}.airport-marker{cursor:pointer;background-color:#4169e1;border:3px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:transform .2s;display:flex;box-shadow:0 4px 8px #0000004d}.airport-marker:hover{transform:scale(1.15)}.airport-icon{font-size:24px;line-height:1}.train-marker{cursor:pointer;background-color:#228b22;border:3px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;transition:transform .2s;display:flex;box-shadow:0 4px 8px #0000004d}.train-marker:hover{transform:scale(1.15)}.train-icon{font-size:22px;line-height:1}.hotel-marker{cursor:pointer;flex-direction:column;align-items:center;gap:4px;transition:transform .2s;display:flex}.hotel-marker:hover{transform:scale(1.1)}.hotel-marker .hotel-icon{background:linear-gradient(135deg,gold 0%,orange 100%);border:3px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:46px;height:46px;font-size:26px;line-height:1;animation:2s ease-in-out infinite pulse-glow;display:flex;box-shadow:0 6px 16px #ffd70099,0 2px 8px #0000004d}@keyframes pulse-glow{0%,to{box-shadow:0 6px 16px #ffd70099,0 2px 8px #0000004d}50%{box-shadow:0 8px 24px #ffd700e6,0 4px 12px #0006}}.hotel-marker .hotel-label{color:#333;white-space:nowrap;letter-spacing:.02em;background-color:#ffd700f2;border:1px solid #ffffff80;border-radius:12px;padding:4px 10px;font-size:.75rem;font-weight:600;box-shadow:0 2px 6px #0003}.maps-info{text-align:center;background-color:#ffffffb3;border-radius:8px;max-width:1400px;margin:0 auto;padding:1.5rem;box-shadow:0 2px 8px #0000001a}.maps-info p{color:#555;margin:.5rem 0;font-size:1rem;line-height:1.6}.venue-info{font-size:1.1rem!important}.maps-info strong{color:#8b4513;font-weight:600}.api-key-warning{text-align:center;background-color:#fff3cd;border:2px solid #ffc107;border-radius:8px;max-width:800px;margin:0 auto;padding:2rem}.api-key-warning p{color:#856404;margin:.5rem 0;font-size:1rem}.warning-detail{font-size:.9rem!important}@media (width<=768px){.location-maps{padding:3rem 1.5rem}.maps-container{grid-template-columns:1fr;gap:2rem}.google-map{height:400px}.map-title{font-size:1.1rem}.hotel-marker .hotel-label{padding:3px 8px;font-size:.7rem}.maps-info{padding:1rem}.maps-info p{font-size:.9rem}}@media (width<=480px){.google-map{height:350px}.venue-marker{width:40px;height:40px}.venue-icon{font-size:24px}.airport-marker{width:36px;height:36px}.airport-icon{font-size:20px}.train-marker{width:34px;height:34px}.train-icon{font-size:18px}.hotel-marker .hotel-icon{width:38px;height:38px;font-size:22px}.hotel-marker .hotel-label{padding:2px 6px;font-size:.65rem}.venue-marker,.airport-marker,.train-marker{min-width:44px;min-height:44px}.maps-info p{font-size:.9rem}}@media (width<=375px){.location-maps{padding:2.5rem 1rem}.google-map{height:320px}.map-title{font-size:1rem}.maps-info{padding:1rem .75rem}.maps-info p{font-size:.85rem}.venue-info{font-size:1rem!important}}.rsvp-form-section{background-color:#f3ebdc;padding:4rem 2rem}.contact-info-section{text-align:center;background:#ffffff80;border-radius:2px;max-width:600px;margin:0 auto 2rem;padding:1.5rem}.contact-info-intro{color:#555;letter-spacing:.05em;margin:0 0 1rem;font-size:.95rem}.contacts{flex-wrap:wrap;justify-content:center;gap:2rem;display:flex}.contact-item{flex-direction:column;gap:.25rem;display:flex}.contact-name{color:#333;letter-spacing:.05em;font-size:.95rem;font-weight:500}.contact-phone{color:#555;font-size:.9rem;text-decoration:none;transition:color .2s}.contact-phone:hover{color:#333;text-decoration:underline}.rsvp-form{background:#ffffffb3;border-radius:2px;max-width:600px;margin:0 auto;padding:3rem;box-shadow:0 2px 10px #0000000d}.form-section-title{letter-spacing:.05em;text-transform:uppercase;color:#555;border-bottom:1px solid #eee;margin:0 0 1.5rem;padding-bottom:.75rem;font-size:1.1rem;font-weight:500}.form-row{grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem;display:grid}.form-group{margin-bottom:1.5rem}.form-group label{letter-spacing:.05em;text-transform:uppercase;color:#555;margin-bottom:.5rem;font-size:.9rem;font-weight:500;display:block}.required{color:#d32f2f}.form-group input[type=text],.form-group input[type=email],.form-group input[type=tel],.form-group select,.form-group textarea{box-sizing:border-box;border:1px solid #ddd;border-radius:2px;width:100%;padding:.75rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-group input[type=text]:focus,.form-group input[type=email]:focus,.form-group input[type=tel]:focus,.form-group select:focus,.form-group textarea:focus{border-color:#888;outline:none}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#d32f2f}.form-group textarea{resize:vertical;min-height:100px}.error-message{color:#d32f2f;margin-top:.25rem;font-size:.85rem;display:block}.checkbox-group{margin:2rem 0}.checkbox-label{cursor:pointer;text-transform:none;align-items:center;font-size:1rem;font-weight:400;display:flex}.checkbox-label input[type=checkbox]{cursor:pointer;width:20px;height:20px;margin-right:.75rem}.checkbox-label span{color:#333}.submit-button{color:#fff;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;background-color:#333;border:none;border-radius:2px;width:100%;min-height:44px;margin-top:1rem;padding:1rem 2rem;font-size:1rem;font-weight:500;transition:background-color .2s}.submit-button:hover:not(:disabled){background-color:#555}.submit-button:disabled{cursor:not-allowed;background-color:#999}.status-message{text-align:center;border-radius:2px;margin-top:1.5rem;padding:1rem}.status-message.success{color:#2e7d32;background-color:#e8f5e9;border:1px solid #a5d6a7}.status-message.error{color:#c62828;background-color:#ffebee;border:1px solid #ef9a9a}.additional-guests-section{border-top:1px solid #eee;margin:2rem 0;padding-top:2rem}.accommodation-section{background-color:#ffffff4d;border:1px solid #e0e0e0;border-radius:2px;margin:1.5rem 0 2rem;padding:1.5rem}.accommodation-section .form-section-title{margin-top:0}.field-instruction{color:#666;margin:.5rem 0 1rem;font-size:.9rem;line-height:1.5}.field-note{color:#777;margin:.5rem 0 0 2rem;font-size:.85rem;font-style:italic}.room-choices{margin-top:1rem}.room-choices .form-group{margin-bottom:1rem}.room-choices .form-group:last-child{margin-bottom:0}.additional-guests-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.additional-guests-header h3{letter-spacing:.05em;text-transform:uppercase;color:#555;margin:0;font-size:1.1rem;font-weight:500}.add-guest-button{color:#333;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;background-color:#fff;border:2px solid #333;border-radius:2px;min-height:44px;padding:.6rem 1.2rem;font-size:.9rem;font-weight:500;transition:all .2s}.add-guest-button:hover{color:#fff;background-color:#333}.guest-item{background-color:#ffffff80;border:1px solid #eee;border-radius:2px;margin-bottom:1rem;padding:1.5rem}.guest-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.guest-header h4{color:#666;text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:.95rem;font-weight:500}.remove-guest-button{color:#d32f2f;cursor:pointer;background-color:#0000;border:1px solid #d32f2f;border-radius:2px;min-width:44px;min-height:44px;padding:.4rem .8rem;font-size:.85rem;transition:all .2s}.remove-guest-button:hover{color:#fff;background-color:#d32f2f}@media (width<=768px){.rsvp-form-section{padding:3rem 1rem}.contact-info-section{margin-bottom:1.5rem;padding:1.25rem 1rem}.contacts{gap:1.5rem}.rsvp-form{padding:2rem 1.5rem}.form-row{grid-template-columns:1fr;gap:0}.form-group{margin-bottom:1.75rem}.form-group input[type=text],.form-group input[type=email],.form-group input[type=tel],.form-group select,.form-group textarea{min-height:44px;padding:.875rem;font-size:16px}.checkbox-label input[type=checkbox]{width:24px;height:24px;margin-right:1rem}.submit-button{min-height:52px;padding:1.25rem 2rem;font-size:1.05rem}.add-guest-button{width:100%;min-height:48px;padding:.75rem 1.25rem}.additional-guests-header{flex-direction:column;align-items:stretch;gap:1rem}.remove-guest-button{min-height:48px;padding:.6rem 1rem}}@media (width<=480px){.rsvp-form{padding:1.5rem 1rem}.form-section-title{font-size:1rem}}.privacy{background-color:#f3ebdc;padding:2rem}.privacy-toggle-container{text-align:center;max-width:900px;margin:0 auto}.privacy-toggle{color:#555;cursor:pointer;background:0 0;border:none;padding:.75rem 1.5rem;font-family:inherit;font-size:.95rem;font-weight:500;text-decoration:underline;transition:color .2s}.privacy-toggle:hover{color:#333}.privacy-toggle:focus{outline-offset:2px;outline:2px solid #8b4513}.privacy-content{background:#ffffffb3;border-radius:4px;max-width:900px;margin:1.5rem auto 0;padding:3rem;animation:.3s ease-out slideDown;box-shadow:0 2px 10px #0000000d}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.privacy-intro{color:#555;text-align:center;margin-bottom:2rem;font-size:1.1rem;line-height:1.8}.privacy-section{margin-bottom:2.5rem}.privacy-section h3{letter-spacing:.05em;color:#333;margin:0 0 1rem;font-family:Georgia,serif;font-size:1.3rem;font-weight:500}.privacy-section p{color:#555;margin:.5rem 0;font-size:1rem;line-height:1.7}.privacy-section ul{margin:1rem 0;padding-left:2rem;list-style:outside}.privacy-section li{color:#555;margin:.5rem 0;font-size:1rem;line-height:1.7}.privacy-footer{text-align:center;color:#888;margin-top:3rem;font-size:.9rem;font-style:italic}@media (width<=768px){.privacy{padding:1.5rem}.privacy-toggle{padding:.65rem 1.25rem;font-size:.9rem}.privacy-content{padding:2rem 1.5rem}.privacy-section h3{font-size:1.2rem}.privacy-section ul{padding-left:1.5rem}}@media (width<=480px){.privacy{padding:1.25rem 1rem}.privacy-toggle{padding:.6rem 1rem;font-size:.85rem}.privacy-content{padding:1.5rem 1rem}.privacy-intro{font-size:1rem}.privacy-section h3{font-size:1.1rem}.privacy-section p,.privacy-section li{font-size:.95rem}}.app{background-color:#f3ebdc;flex-direction:column;min-height:100vh;display:flex;position:relative}.app:before{content:"";pointer-events:none;z-index:10;background-image:url(/sidebar.png);background-position:0;background-repeat:space;background-size:150px 978px;width:150px;height:calc(100% - 950px);position:absolute;top:800px;left:0}.app:after{content:"";pointer-events:none;z-index:10;background-image:url(/sidebar.png);background-position:100%;background-repeat:space;background-size:150px 978px;width:150px;height:calc(100% - 950px);position:absolute;top:800px;right:0;transform:scaleX(-1)}.bottombar-separator{background-image:url(/top%20bar.png);background-position:50%;background-repeat:no-repeat;background-size:auto 100%;width:100%;height:150px;transform:scaleY(-1)}@media (width<=768px){.app:before,.app:after{display:none}}@media (width<=480px){.bottombar-separator{height:50px;margin-bottom:15px}}@media (width<=375px){.bottombar-separator{height:40px;margin-bottom:10px}}
