.vertical-timeline *{box-sizing:border-box}.vertical-timeline{width:95%;max-width:1170px;margin:0 auto;position:relative;padding:2em 0}.vertical-timeline:after{content:"";display:table;clear:both}.vertical-timeline:before{content:"";position:absolute;top:0;left:18px;height:100%;width:4px;background:var(--line-color)}.vertical-timeline.vertical-timeline--one-column-right:before{right:18px;left:unset}@media only screen and (min-width:1170px){.vertical-timeline.vertical-timeline--two-columns{width:90%}.vertical-timeline.vertical-timeline--two-columns:before{left:50%;margin-left:-2px}}.vertical-timeline-element{position:relative;margin:2em 0}.vertical-timeline-element>div{min-height:1px}.vertical-timeline-element:after{content:"";display:table;clear:both}.vertical-timeline-element:first-child{margin-top:0}.vertical-timeline-element:last-child{margin-bottom:0}@media only screen and (min-width:1170px){.vertical-timeline-element{margin:4em 0}.vertical-timeline-element:first-child{margin-top:0}.vertical-timeline-element:last-child{margin-bottom:0}}.vertical-timeline-element-icon{position:absolute;top:0;left:0;width:40px;height:40px;border-radius:50%}.vertical-timeline-element-icon.shadow-size-small{box-shadow:0 0 0 2px #fff,inset 0 1px #00000014,0 2px 0 4px #0000000d}.vertical-timeline-element-icon.shadow-size-medium{box-shadow:0 0 0 3px #fff,inset 0 2px #00000014,0 3px 0 5px #0000000d}.vertical-timeline-element-icon.shadow-size-large{box-shadow:0 0 0 4px #fff,inset 0 2px #00000014,0 4px 0 6px #0000000d}.vertical-timeline--one-column-right .vertical-timeline-element-icon{right:0;left:unset}.vertical-timeline-element-icon svg{display:block;width:24px;height:24px;position:relative;left:50%;top:50%;margin-left:-12px;margin-top:-12px}@media only screen and (min-width:1170px){.vertical-timeline--two-columns .vertical-timeline-element-icon{width:60px;height:60px;left:50%;margin-left:-30px}}.vertical-timeline-element-icon{-webkit-transform:translateZ(0);-webkit-backface-visibility:hidden}.vertical-timeline--animate .vertical-timeline-element-icon.is-hidden{visibility:hidden}.vertical-timeline--animate .vertical-timeline-element-icon.bounce-in{visibility:visible;-webkit-animation:cd-bounce-1 .6s;-moz-animation:cd-bounce-1 .6s;animation:cd-bounce-1 .6s}@-webkit-keyframes cd-bounce-1{0%{opacity:0;-webkit-transform:scale(.5)}60%{opacity:1;-webkit-transform:scale(1.2)}to{-webkit-transform:scale(1)}}@-moz-keyframes cd-bounce-1{0%{opacity:0;-moz-transform:scale(.5)}60%{opacity:1;-moz-transform:scale(1.2)}to{-moz-transform:scale(1)}}@keyframes cd-bounce-1{0%{opacity:0;-webkit-transform:scale(.5);-moz-transform:scale(.5);-ms-transform:scale(.5);-o-transform:scale(.5);transform:scale(.5)}60%{opacity:1;-webkit-transform:scale(1.2);-moz-transform:scale(1.2);-ms-transform:scale(1.2);-o-transform:scale(1.2);transform:scale(1.2)}to{-webkit-transform:scale(1);-moz-transform:scale(1);-ms-transform:scale(1);-o-transform:scale(1);transform:scale(1)}}.vertical-timeline-element-content{position:relative;margin-left:60px;background:#fff;border-radius:.25em;padding:1em;box-shadow:0 3px #ddd}.vertical-timeline--one-column-right .vertical-timeline-element-content{margin-right:60px;margin-left:unset}.vertical-timeline-element--no-children .vertical-timeline-element-content{background:0 0;box-shadow:none}.vertical-timeline-element-content:after{content:"";display:table;clear:both}.vertical-timeline-element-content h2{color:#303e49}.vertical-timeline-element-content .vertical-timeline-element-date,.vertical-timeline-element-content p{font-size:13px;font-size:.8125rem;font-weight:500}.vertical-timeline-element-content .vertical-timeline-element-date{display:inline-block}.vertical-timeline-element-content p{margin:1em 0 0;line-height:1.6}.vertical-timeline-element-title,.vertical-timeline-element-subtitle{margin:0}.vertical-timeline-element-content .vertical-timeline-element-date{float:left;padding:.8em 0;opacity:.7}.vertical-timeline-element-content-arrow{content:"";position:absolute;top:16px;right:100%;height:0;width:0;border:7px solid transparent;border-right:7px solid #fff}.vertical-timeline--one-column-right .vertical-timeline-element-content-arrow{content:"";position:absolute;top:16px;right:unset;left:100%;height:0;width:0;border:7px solid transparent;border-left:7px solid #fff}.vertical-timeline--one-column-right .vertical-timeline-element-content:before{left:100%;border-left:7px solid #fff;border-right:unset}.vertical-timeline-element--no-children .vertical-timeline-element-content:before{display:none}.vertical-timeline-element--no-children .vertical-timeline-element-content-arrow{display:none}@media only screen and (min-width:768px){.vertical-timeline-element-content h2{font-size:20px;font-size:1.25rem}.vertical-timeline-element-content p{font-size:16px;font-size:1rem}.vertical-timeline-element-content .vertical-timeline-element-date{font-size:14px;font-size:.875rem}}@media only screen and (min-width:1170px){.vertical-timeline--two-columns .vertical-timeline-element-content{margin-left:0;padding:1.5em;width:44%}.vertical-timeline--two-columns .vertical-timeline-element-content-arrow{top:24px;left:100%;transform:rotate(180deg)}.vertical-timeline--two-columns .vertical-timeline-element-content .vertical-timeline-element-date{position:absolute;width:100%;left:124%;top:6px;font-size:16px;font-size:1rem}.vertical-timeline--two-columns .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content,.vertical-timeline--two-columns .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content{float:right}.vertical-timeline--two-columns .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content-arrow,.vertical-timeline--two-columns .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content-arrow{top:24px;left:auto;right:100%;transform:rotate(0)}.vertical-timeline--one-column-right .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content-arrow,.vertical-timeline--one-column-right .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content-arrow{top:24px;left:100%;right:auto;transform:rotate(0)}.vertical-timeline--two-columns .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content .vertical-timeline-element-date,.vertical-timeline--two-columns .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content .vertical-timeline-element-date{left:auto;right:124%;text-align:right}}.vertical-timeline--animate .vertical-timeline-element-content.is-hidden{visibility:hidden}.vertical-timeline--animate .vertical-timeline-element-content.bounce-in{visibility:visible;-webkit-animation:cd-bounce-2 .6s;-moz-animation:cd-bounce-2 .6s;animation:cd-bounce-2 .6s}@media only screen and (min-width:1170px){.vertical-timeline--two-columns.vertical-timeline--animate .vertical-timeline-element.vertical-timeline-element--right .vertical-timeline-element-content.bounce-in,.vertical-timeline--two-columns.vertical-timeline--animate .vertical-timeline-element:nth-child(2n):not(.vertical-timeline-element--left) .vertical-timeline-element-content.bounce-in{-webkit-animation:cd-bounce-2-inverse .6s;-moz-animation:cd-bounce-2-inverse .6s;animation:cd-bounce-2-inverse .6s}}@media only screen and (max-width:1169px){.vertical-timeline--animate .vertical-timeline-element-content.bounce-in{visibility:visible;-webkit-animation:cd-bounce-2-inverse .6s;-moz-animation:cd-bounce-2-inverse .6s;animation:cd-bounce-2-inverse .6s}}@-webkit-keyframes cd-bounce-2{0%{opacity:0;-webkit-transform:translateX(-100px)}60%{opacity:1;-webkit-transform:translateX(20px)}to{-webkit-transform:translateX(0)}}@-moz-keyframes cd-bounce-2{0%{opacity:0;-moz-transform:translateX(-100px)}60%{opacity:1;-moz-transform:translateX(20px)}to{-moz-transform:translateX(0)}}@keyframes cd-bounce-2{0%{opacity:0;-webkit-transform:translateX(-100px);-moz-transform:translateX(-100px);-ms-transform:translateX(-100px);-o-transform:translateX(-100px);transform:translate(-100px)}60%{opacity:1;-webkit-transform:translateX(20px);-moz-transform:translateX(20px);-ms-transform:translateX(20px);-o-transform:translateX(20px);transform:translate(20px)}to{-webkit-transform:translateX(0);-moz-transform:translateX(0);-ms-transform:translateX(0);-o-transform:translateX(0);transform:translate(0)}}@-webkit-keyframes cd-bounce-2-inverse{0%{opacity:0;-webkit-transform:translateX(100px)}60%{opacity:1;-webkit-transform:translateX(-20px)}to{-webkit-transform:translateX(0)}}@-moz-keyframes cd-bounce-2-inverse{0%{opacity:0;-moz-transform:translateX(100px)}60%{opacity:1;-moz-transform:translateX(-20px)}to{-moz-transform:translateX(0)}}@keyframes cd-bounce-2-inverse{0%{opacity:0;-webkit-transform:translateX(100px);-moz-transform:translateX(100px);-ms-transform:translateX(100px);-o-transform:translateX(100px);transform:translate(100px)}60%{opacity:1;-webkit-transform:translateX(-20px);-moz-transform:translateX(-20px);-ms-transform:translateX(-20px);-o-transform:translateX(-20px);transform:translate(-20px)}to{-webkit-transform:translateX(0);-moz-transform:translateX(0);-ms-transform:translateX(0);-o-transform:translateX(0);transform:translate(0)}}:root{--pal-1: #ffccea;--pal-2: #fff6e3;--pal-3: #bfecff;--pal-4: #b3a7ff;--primary-color: var(--pal-4);--accent-color: var(--pal-4);--muted-bg: var(--pal-2);--paper: var(--pal-3);--rose: var(--pal-2);--text-dark: #074f52;--text-light: #5fb0b8;--white: #fff5f2;--font-script: "Georgia", serif;--font-primary: "Inter", sans-serif;--font-mono: "JetBrains Mono", monospace;--section-padding: 3rem 2rem;--card-padding: 2rem;--border-radius: 12px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-primary);color:var(--text-dark);line-height:1.6;background:linear-gradient(135deg,var(--muted-bg) 0%,var(--pal-3) 50%,var(--pal-4) 100%);min-height:100vh;overflow-x:hidden}.password-container{display:flex;justify-content:center;align-items:center;min-height:100vh;position:relative;background:linear-gradient(45deg,var(--pal-3),var(--pal-4));background-size:400% 400%;animation:gradientShift 8s ease infinite}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.password-box{background:rgba(255,255,255,.95);padding:3rem 2.5rem;border-radius:var(--border-radius);text-align:center;box-shadow:0 20px 40px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.5);position:relative;z-index:10;max-width:400px;width:90%}.tech-decoration{font-size:3rem;margin-bottom:1rem;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.05);opacity:1}}.password-title{font-family:var(--font-primary);font-size:2rem;color:var(--primary-color);margin-bottom:1rem;font-weight:600}.password-subtitle{color:var(--text-light);margin-bottom:2rem;font-weight:400}#password-input{width:100%;padding:1rem;border:2px solid var(--pal-1);border-radius:50px;font-size:1.1rem;text-align:center;margin-bottom:1.5rem;background:var(--white);transition:all .3s ease}#password-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 20px #b1cfec4d}.password-btn{background:linear-gradient(45deg,var(--primary-color),var(--pal-1));color:#fff;border:none;padding:1rem 2.5rem;border-radius:50px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.password-btn:hover{transform:translateY(-2px);box-shadow:0 10px 25px #b1cfec66}.error-hidden{opacity:0;color:var(--primary-color);margin-top:1rem;font-weight:500;transition:opacity .3s ease}.error-show{opacity:1}.content-hidden{display:none}.background-all{background:linear-gradient(135deg,var(--paper) 0%,var(--pal-4) 100%)}.content-visible{display:block;animation:fadeIn 1s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.timeline-image{max-width:100%;height:auto;object-fit:cover;border-radius:16px;display:block;margin:12px auto;box-shadow:0 6px 18px #0642321f;border:2px solid rgba(255,255,255,.6)}width: 256px; height: 160px; object-fit: cover; border-radius: 16px; display: block; margin: 12px auto; box-shadow: 0 6px 18px rgba(6,66,50,.12); border: 2px solid rgba(255,255,255,.6); } .hero-section{text-align:center;padding:var(--section-padding);position:relative;overflow:hidden}.decorative-border{height:4px;background:linear-gradient(45deg,var(--primary-color),var(--pal-4),var(--pal-1));margin:2rem auto;max-width:300px;border-radius:2px}.bride-groom-names{font-family:var(--font-script);font-size:clamp(3rem,8vw,6rem);color:var(--primary-color);font-weight:700;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.invite-text{font-size:1.25rem;color:var(--text-light);letter-spacing:2px;margin-bottom:1rem;font-weight:400}.save-date-text{font-size:1.5rem;color:var(--text-light);text-transform:uppercase;letter-spacing:3px;margin-bottom:2rem;font-weight:300}.wedding-date{margin:2rem 0}.date-number{font-family:var(--font-script);font-size:clamp(2.5rem,6vw,4rem);color:var(--primary-color);font-weight:700;display:block}.date-year{font-size:1.8rem;color:var(--text-dark);font-weight:600}.location{font-size:1.1rem;color:var(--text-light);font-style:italic}.details-section{padding:var(--section-padding)}.details-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;max-width:1000px;margin:0 auto}.detail-card{background:linear-gradient(135deg,var(--pal-2),var(--pal-3));padding:var(--card-padding);border-radius:var(--border-radius);text-align:center;box-shadow:0 10px 30px #0000001a;transition:transform .3s ease;border:1px solid rgba(255,255,255,.6)}.card-image{width:120px;height:96px;object-fit:cover;border-radius:18px;display:block;margin:0 auto 1rem;box-shadow:0 10px 28px #06423224;border:3px solid rgba(255,255,255,.7)}.detail-card:hover{transform:translateY(-5px)}.detail-card h3{font-family:var(--font-script);font-size:2rem;color:var(--primary-color);margin-bottom:1rem;font-weight:700}.detail-card p{color:var(--text-dark);font-weight:500;margin-bottom:.5rem}.map-link{display:inline-block;margin-top:.5rem;color:var(--accent-color);font-weight:600;text-decoration:none;font-size:.95rem}.map-link:hover,.map-link:focus{text-decoration:underline;color:var(--primary-color)}.message-section{padding:var(--section-padding)}.message-container{max-width:800px;margin:0 auto;text-align:center}.message-text{font-size:1.2rem;color:var(--text-dark);margin-bottom:2rem;line-height:1.8}.cannot-attend{margin-top:1.5rem;background:linear-gradient(135deg,rgba(255,255,255,.6),rgba(255,255,255,.85));padding:1rem;border-radius:12px;border:1px solid rgba(0,0,0,.03)}.cannot-attend p{margin:0;color:var(--text-dark);font-weight:500;line-height:1.5}.footer-section{padding:3rem 2rem;color:var(--text-dark)}.footer-content{max-width:600px;margin:0 auto;text-align:center}@media (max-width: 768px){:root{--section-padding: 3rem 1rem}.password-box{padding:2rem 1.5rem}.details-container{grid-template-columns:1fr;gap:1.5rem}.photo-placeholder{padding:1.5rem}}@media (max-width: 480px){.password-title{font-size:2rem}.bride-groom-names{font-size:3rem}.message-title{font-size:2.5rem}}
