:root{font-family:Georgia,Times New Roman,serif;line-height:1.6;font-weight:400;color-scheme:light;color:#2c2c2c;background-color:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}.family-tree,.family-tree-image{background:#fdfbf7;padding:70px 20px 90px;text-align:center}.family-image-frame{max-width:900px;margin:0 auto;border:2px solid #d4af37;border-radius:14px;padding:12px;background:#fffdf7;box-shadow:0 12px 30px #00000014}.family-image{width:100%;height:auto;display:block;border-radius:10px;object-fit:contain}.tree-root{display:flex;justify-content:center;position:relative;margin-bottom:40px}.tree-root:after{content:"";position:absolute;bottom:-40px;left:50%;transform:translate(-50%);width:4px;height:40px;background:none;border-left:2px dotted #d4af37;animation:tree-grow 1s .2s ease-out forwards}.node-card{background:transparent;border:2px solid #d4af37;border-radius:10px;padding:10px 14px;display:inline-flex;align-items:center;gap:10px;box-shadow:none;transition:transform .2s ease}.node-card:hover{transform:translateY(-2px);box-shadow:none}.node-card.couple{font-family:Playfair Display,serif;font-size:18px}.node-badge{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:radial-gradient(circle,#fffdf7 45%,#f9e7a7);border:2px solid #d4af37;color:#b28a1a;box-shadow:0 4px 10px #d4af3740}.node-name{font-size:15px;color:#3e321d}.connector-root{width:2px;height:0;background:transparent;margin:0 auto;border-radius:2px;display:none}.children-grid{position:relative;margin-top:40px;padding-top:20px;display:grid;grid-template-columns:repeat(4,minmax(140px,1fr));gap:12px 10px;justify-items:center}.children-grid:before{content:"";position:absolute;top:-20px;left:5%;right:5%;height:2px;background:none;border-top:2px dotted #d4af37;border-radius:0;animation:branch-line 1s .4s ease-out forwards;opacity:0}.child{position:relative}.child:before{content:"";position:absolute;top:-20px;left:50%;transform:translate(-50%) scaleY(0);transform-origin:top;width:2px;height:20px;background:none;border-left:2px dotted #d4af37;border-radius:0;animation:tree-grow .8s .5s ease-out forwards}.child:after{content:"";position:absolute;top:-20px;left:50%;width:2px;height:2px;background:#d4af37;transform:translate(-50%)}.child.branch{padding-bottom:22px}.grand-connector{width:2px;height:20px;background:none;margin:6px auto 0;border-radius:0;transform:scaleY(0);transform-origin:top;animation:tree-grow .8s .6s ease-out forwards;border-left:2px dotted #d4af37}.grandchildren-grid{position:relative;margin-top:12px;padding-top:16px;display:grid;grid-template-columns:repeat(2,1fr);gap:14px 18px}.grandchildren-grid:before{content:"";position:absolute;top:0;left:10%;right:10%;height:2px;background:none;border-top:2px dotted #d4af37;border-radius:0;animation:branch-line 1s .6s ease-out forwards;opacity:0}.grandchild{position:relative}.grandchild:before{content:"";position:absolute;top:-16px;left:50%;transform:translate(-50%) scaleY(0);transform-origin:top;width:2px;height:16px;background:none;border-left:2px dotted #d4af37;border-radius:0;animation:tree-grow .8s .7s ease-out forwards}@keyframes branch-line{to{opacity:1}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Montserrat,sans-serif;background:#fdfbf7;color:#3e321d}.page{background:#fdfbf7;min-height:100vh}.nav{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;padding:18px 38px;background:#ffffffeb;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-bottom:1px solid rgba(212,175,55,.15)}.logo{font-family:Parisienne,cursive;font-size:28px;color:#b28a1a;letter-spacing:1px}.nav-links{display:flex;gap:22px;font-size:14px}.nav-links a{color:#3e321d;text-decoration:none;letter-spacing:.5px;font-weight:500;transition:color .2s ease}.nav-links a:hover{color:#b28a1a}.petals-overlay{position:fixed;inset:0;pointer-events:none;z-index:6}.petal{position:absolute;top:-10vh;animation:wind-petal var(--duration) linear infinite;animation-delay:var(--delay);transform-origin:center}.petal-svg{width:24px;height:28px;transform:scale(var(--scale));filter:drop-shadow(0 2px 2px rgba(180,138,26,.25));opacity:.85}@keyframes wind-petal{0%{transform:translate3d(0,-10vh,0) rotate(0);opacity:0}10%{opacity:1}50%{transform:translate3d(calc(var(--driftX) * .6),50vh,0) rotate(180deg)}to{transform:translate3d(var(--driftX),110vh,0) rotate(360deg);opacity:0}}.hero{position:relative;min-height:65vh;background:url(https://images.unsplash.com/photo-1520854221050-0f4caff449fb?auto=format&fit=crop&w=1600&q=80) center/cover no-repeat;display:flex;align-items:center;justify-content:center}.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,#00000059,#00000026 60%,#0000000d)}.hero-content{position:relative;text-align:center;color:#fff;padding:40px 24px}.hero-pretitle{font-size:14px;letter-spacing:2px;text-transform:uppercase;margin-bottom:16px}.hero-title{font-family:Playfair Display,serif;font-size:48px;font-weight:600;margin-bottom:12px;letter-spacing:2px}.hero-couple{font-size:20px;color:#fff;letter-spacing:1px;margin-bottom:6px}.hero-subtitle{font-size:16px;letter-spacing:1px;margin-bottom:24px}.hero-badge{display:inline-block;background:#d4af37d9;color:#fff;border:1px solid rgba(181,138,26,.6);border-radius:20px;padding:6px 14px;font-weight:600;letter-spacing:1px;margin:8px 0}.btn-primary{background:linear-gradient(135deg,#d4af37,#c4991f);color:#fff;border:1px solid #b58a1a;padding:12px 28px;border-radius:24px;font-weight:600;letter-spacing:1px;cursor:pointer;transition:all .2s ease}.btn-primary:hover{background:linear-gradient(135deg,#c4991f,#b58a1a);transform:translateY(-1px)}.btn-primary.ghost{background:transparent;color:#b28a1a;border:1px solid #d4af37}.btn-primary.ghost:hover{background:#fff7e0}.intro{background:#f7f1ea;text-align:center;padding:100px 24px 80px;margin-top:0}.script-title{font-family:Parisienne,cursive;font-size:38px;color:#b28a1a;margin-bottom:40px}.carousel-container{max-width:800px;margin:0 auto;overflow:hidden;border-radius:12px;box-shadow:0 8px 24px #d4af374d;position:relative}.carousel-track{display:flex;transition:transform .8s ease-in-out}.carousel-slide{min-width:100%;height:450px;display:flex;align-items:center;justify-content:center;background:#fff}.carousel-image{width:100%;height:100%;object-fit:cover}.lead{font-family:Playfair Display,serif;font-size:18px;margin-bottom:14px}.body{max-width:760px;margin:0 auto 16px;line-height:1.7;color:#4b3d2a;font-size:15px}.note{font-size:14px;color:#7a6a4a;margin-bottom:28px}.story{position:relative;min-height:50vh;background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;align-items:center;justify-content:center;padding:70px 20px}.story:before{content:"";position:absolute;inset:0;background:#ffffff26;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.story-card{position:relative;background:#ffffffdb;padding:32px 30px;max-width:760px;border-radius:10px;box-shadow:0 10px 35px #00000014;text-align:center}.section-label{font-family:Playfair Display,serif;font-size:28px;color:#b28a1a;margin-bottom:16px}.story-text{font-size:15px;line-height:1.8;color:#4b3d2a;margin-bottom:10px}.photos{background:#fffaf1;padding:70px 20px 90px;text-align:center}.carousel-container{display:flex;align-items:center;justify-content:center;gap:20px;margin:40px auto;max-width:600px}.carousel-wrapper{position:relative;flex:1;overflow:hidden;border-radius:15px;box-shadow:0 12px 30px #00000026;border:3px solid #d4af37}.carousel-image{width:100%;height:400px;object-fit:cover;display:block}.carousel-counter{position:absolute;bottom:12px;right:12px;background:#0009;color:#fff;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600}.upload-section{margin-bottom:30px;text-align:center}.upload-label{display:inline-block;cursor:pointer}.upload-btn{display:inline-block;padding:14px 28px;background:linear-gradient(135deg,#d4af37,#b28a1a);color:#fff;border-radius:10px;font-weight:600;font-size:16px;transition:all .3s ease;border:2px solid transparent}.upload-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #d4af3766}.upload-btn.uploading{opacity:.7;cursor:not-allowed}.upload-hint{font-size:13px;color:#b28a1a;margin-top:8px;font-style:italic}.carousel-btn{width:45px;height:45px;border-radius:50%;background:linear-gradient(135deg,#d4af37,#b28a1a);color:#fff;border:none;font-size:20px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.carousel-btn:hover{transform:scale(1.1);box-shadow:0 8px 16px #d4af374d}.carousel-btn:active{transform:scale(.95)}.carousel-dots{display:flex;justify-content:center;gap:10px;margin-top:20px}.dot{width:12px;height:12px;border-radius:50%;background:#d4af374d;border:2px solid #d4af37;cursor:pointer;transition:all .3s ease}.dot.active{background:#d4af37;transform:scale(1.3)}.dot:hover{background:#d4af37b3}.details{background:#f7f1ea;padding:90px 20px 80px;text-align:center}.event-type{font-size:14px;color:#6b5a2a;font-style:italic;margin-bottom:8px}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:26px;max-width:960px;margin:0 auto}.detail-card{background:#fffaf4;border:1px solid rgba(180,138,26,.15);border-radius:12px;padding:22px 18px;box-shadow:0 8px 24px #0000000a}.detail-icon{font-size:26px;margin-bottom:10px}.mini-map-container{margin-top:10px;border:1px solid rgba(212,175,55,.3);border-radius:12px;overflow:hidden;box-shadow:0 8px 16px #0000000f}.location-btn{display:inline-block;margin-top:12px;padding:10px 20px;background:linear-gradient(135deg,#d4af37,#b28a1a);color:#fff;text-decoration:none;border-radius:8px;font-size:14px;font-weight:600;transition:all .3s ease;border:none;cursor:pointer}.location-btn:hover{transform:translateY(-2px);box-shadow:0 8px 16px #d4af374d}.detail-card h4{font-family:Playfair Display,serif;font-size:18px;margin-bottom:8px;color:#3e321d}.detail-card p{font-size:14px;color:#4b3d2a;line-height:1.6}.rsvp{text-align:center;padding:70px 20px 90px;background:#fffaf1}.rsvp .body{margin-bottom:20px}.modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0009;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.modal-content{background:#fff;border-radius:12px;padding:40px 32px;max-width:500px;width:100%;position:relative;box-shadow:0 10px 40px #0000004d;animation:modal-appear .3s ease-out}@keyframes modal-appear{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:32px;color:#999;cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;transition:color .2s}.modal-close:hover{color:#333}.modal-title{font-family:Playfair Display,serif;font-size:28px;color:#b28a1a;margin-bottom:24px;text-align:center}.rsvp-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:#4b3d2a;letter-spacing:.5px}.form-group input{padding:12px 16px;border:2px solid #e6d5b8;border-radius:8px;font-size:16px;color:#333;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#d4af37}.rsvp-form .btn-primary{margin-top:8px;width:100%}.countdown{display:grid;grid-template-columns:repeat(4,minmax(60px,1fr));gap:12px;margin:18px 0 24px}.count-box{background:#ffffff29;border:1px solid rgba(212,175,55,.4);border-radius:12px;padding:10px 8px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);color:#fff}.count-box span{display:block;font-size:22px;font-weight:700}.count-box small{font-size:12px;letter-spacing:1px}.family{background:#fdfbf7;padding:70px 20px;text-align:center}.family-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px 32px;max-width:860px;margin:0 auto}.family-column{display:flex;flex-direction:column;gap:8px}.family-member{background:#fff;border:1px solid rgba(212,175,55,.25);border-radius:10px;padding:10px 12px;color:#3e321d}@media(max-width:768px){.nav{flex-direction:column;gap:10px}.nav-links{flex-wrap:wrap;justify-content:center}.hero-title{font-size:36px}.hero-subtitle{font-size:18px}.hero-subtitle2{font-size:14px}.countdown{gap:12px;flex-wrap:wrap;margin:20px 0}.count-box{min-width:70px;padding:10px 8px;font-size:18px}.count-label{font-size:11px}.family-tree{padding:40px 15px 60px}.children-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-top:25px;padding-top:15px}.child{display:flex;flex-direction:column;align-items:center;gap:6px}.node-card{padding:8px 12px;font-size:13px;width:100%;max-width:140px;justify-content:center}.node-badge{width:36px;height:36px;min-width:36px}.node-name{font-size:12px}.grandchildren-grid{grid-template-columns:1fr;gap:10px;margin-top:8px;padding-top:12px}.child.branch{padding-bottom:12px}.story-card{padding:26px 22px}.upload-btn{padding:12px 24px;font-size:14px}.upload-hint{font-size:12px}.carousel-container{gap:12px}.carousel-image{height:300px}.carousel-btn{width:40px;height:40px;font-size:18px}.details-grid{grid-template-columns:1fr;gap:20px}.detail-card{padding:20px}.location-btn{padding:9px 18px;font-size:13px;width:100%}.detail-icon{font-size:22px}.detail-card h4{font-size:16px}.detail-card p{font-size:13px}.mini-map-container{height:140px!important}.rsvp{padding:40px 20px 60px}.rsvp h2{font-size:28px}.rsvp-buttons{flex-direction:column;gap:12px;max-width:100%}.rsvp-btn{padding:12px 20px;font-size:14px;width:100%}}@media(max-width:480px){.hero-title{font-size:28px}.hero-subtitle{font-size:16px}.children-grid{grid-template-columns:1fr;gap:10px}.node-card{max-width:120px;padding:6px 10px;font-size:12px}.node-badge{width:32px;height:32px;min-width:32px}.node-name{font-size:11px}.count-box{min-width:60px;padding:8px 6px;font-size:16px}.detail-card{padding:15px}.carousel-container{flex-direction:column;gap:15px}.carousel-image{height:250px}.carousel-wrapper{width:100%}.carousel-btn{width:38px;height:38px;font-size:16px}.detail-icon{font-size:20px}.detail-card h4{font-size:15px}.detail-card p{font-size:12px}}
