@import "https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400;1,500&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=Pinyon+Script&family=Petit+Formal+Script&family=Noto+Serif+KR:wght@200;300;400;500;600&family=Noto+Sans+KR:wght@200;300;400;500&display=swap";body{margin:0}#root{width:100%;max-width:100vw;overflow-x:hidden}.mag-cover{width:100%;height:100dvh;position:relative;overflow:hidden}.mag-cover-img{object-fit:cover;object-position:center 15%;width:100%;height:100%;position:absolute;inset:0}@media (width>=480px){.mag-cover{aspect-ratio:9/16;height:auto;max-height:100vh}}.mag-overlay{pointer-events:none;background:linear-gradient(#00000026 0%,#00000005 25%,#00000014 50%,#0000008c 100%);position:absolute;inset:0}.mag-ui{z-index:2;position:absolute;inset:0}.mag-wedding-title{color:#fff;letter-spacing:5px;text-shadow:0 2px 30px #00000026;font-family:Playfair Display,serif;font-size:clamp(52px,18vw,76px);font-weight:900;line-height:1;position:absolute;bottom:120px;left:16px}.mag-names{text-align:right;color:#fff;text-shadow:0 1px 12px #0000004d;position:absolute;top:50%;right:20px;transform:translateY(-50%)}.mag-name-highlight{font-family:var(--font-body-kr);letter-spacing:2px;font-size:17px;font-weight:500}.mag-name-connector{font-family:var(--font-formal);opacity:.85;margin:0 2px;font-size:16px}.mag-names-tagline{font-family:var(--font-body-kr);color:#fffffff2;margin-top:8px;font-size:14px;font-weight:300;line-height:1.8}.mag-in-month{align-items:center;gap:14px;display:flex;position:absolute;bottom:86px;left:16px}.mag-month-text{color:#ffffffeb;letter-spacing:6px;font-family:Playfair Display,serif;font-size:22px;font-weight:400}.mag-month-line{background:#ffffff80;width:100px;height:1px;display:block}.mag-invite-text{color:#ffffffb3;letter-spacing:2px;font-family:Cormorant Garamond,serif;font-size:11px;font-weight:400;line-height:1.8;position:absolute;bottom:24px;left:20px}.mag-issue{text-align:right;position:absolute;bottom:20px;right:20px}.mag-issue-label{color:#fffc;letter-spacing:1px;font-family:Playfair Display,serif;font-size:14px;line-height:1}.mag-issue-num{color:#fff;margin-top:-4px;font-family:Playfair Display,serif;font-size:42px;font-weight:700;line-height:1}.mag-barcode{justify-content:flex-end;gap:1.5px;margin-top:6px;display:flex}.mag-barcode span{background:#fff9;width:2px;display:block}.mag-scroll-hint{z-index:3;position:absolute;bottom:10px;left:50%;transform:translate(-50%)}.mag-scroll-arrow{border-bottom:1.5px solid #fff6;border-right:1.5px solid #fff6;width:16px;height:16px;animation:2s ease-in-out infinite bounce-arrow;transform:rotate(45deg)}@keyframes bounce-arrow{0%,to{opacity:.3;transform:rotate(45deg)translateY(0)}50%{opacity:.8;transform:rotate(45deg)translateY(4px)}}.gallery-scroll{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:10px;padding:0 32px 16px;display:flex;overflow-x:auto}.gallery-scroll::-webkit-scrollbar{display:none}.gallery-card{scroll-snap-align:center;aspect-ratio:4/5;border-radius:4px;flex:0 0 75%;overflow:hidden}.gallery-card img{object-fit:cover;width:100%;height:100%}.gallery-dots{justify-content:center;gap:6px;margin-top:16px;display:flex}.gallery-dot{background:var(--border);border-radius:50%;width:5px;height:5px;transition:background .3s}.gallery-dot.active{background:var(--gold)}.cal-wrap{flex-direction:column;align-items:center;display:flex}.cal-grid{text-align:center;grid-template-columns:repeat(7,1fr);width:100%;max-width:300px;display:grid}.cal-head{color:var(--text-tertiary);letter-spacing:1px;padding:8px 0;font-family:Cormorant Garamond,serif;font-size:11px}.cal-day{color:var(--text-secondary);padding:9px 0;font-family:Noto Sans KR,sans-serif;font-size:13px;font-weight:300}.cal-day.sun{color:var(--accent-rose)}.cal-day.sat{color:#7b9ebf}.cal-day.highlight{color:#fff;font-weight:500;position:relative}.cal-day.highlight:before{content:"";background:var(--gold);z-index:-1;border-radius:50%;position:absolute;inset:3px}.cal-day.empty{visibility:hidden}.cal-detail{text-align:center;color:var(--text-primary);letter-spacing:1px;margin-top:24px;font-size:14px;font-weight:300;line-height:2}.dday{font-family:var(--font-script);color:var(--gold);margin-top:16px;font-size:22px}.story-timeline{padding-left:24px;position:relative}.story-line{background:linear-gradient(to bottom, var(--border), var(--gold), var(--border));width:1px;position:absolute;top:8px;bottom:8px;left:6px}.story-item{padding-bottom:32px;position:relative}.story-item:last-of-type{padding-bottom:0}.story-dot{background:var(--gold);width:9px;height:9px;box-shadow:0 0 0 3px var(--cream), 0 0 0 4px var(--gold-light);border-radius:50%;position:absolute;top:4px;left:-21px}.story-date{font-family:var(--font-formal);letter-spacing:1px;color:var(--gold);margin-bottom:4px;font-size:14px}.story-title{color:var(--text-primary);letter-spacing:1px;margin-bottom:4px;font-size:15px;font-weight:400}.story-desc{color:var(--text-secondary);font-size:13px;font-weight:200;line-height:1.6}.account-toggle{border:1px solid var(--border);cursor:pointer;width:100%;color:var(--text-primary);letter-spacing:1px;background:#ffffff0a;border-radius:4px;justify-content:space-between;align-items:center;margin-bottom:6px;padding:14px 20px;font-family:Noto Serif KR,serif;font-size:14px;font-weight:300;transition:background .2s;display:flex}.account-toggle:active{background:var(--warm-white)}.account-toggle .arrow{color:var(--text-tertiary);font-size:10px;transition:transform .3s}.account-toggle.open .arrow{transform:rotate(180deg)}.account-list-animated{overflow:hidden}.account-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.account-item:last-child{border-bottom:none}.acct-bank{color:var(--text-tertiary);font-family:Noto Sans KR,sans-serif;font-size:12px;font-weight:300}.acct-num{color:var(--text-primary);letter-spacing:.5px;margin-top:2px;font-family:Noto Sans KR,sans-serif;font-size:14px;font-weight:400}.acct-holder{color:var(--text-secondary);margin-top:1px;font-family:Noto Sans KR,sans-serif;font-size:12px;font-weight:300}.copy-btn{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:3px;padding:6px 14px;font-family:Noto Sans KR,sans-serif;font-size:11px;font-weight:300;transition:all .2s}.copy-btn:active{background:var(--gold);color:#fff;border-color:var(--gold)}.vgb-cloud-field{width:100%;min-height:400px;margin-bottom:20px;position:relative;overflow:hidden}.vgb-cloud{-webkit-backdrop-filter:blur(16px);cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:18px;flex-direction:column;align-items:center;gap:3px;max-width:40%;padding:12px 16px;display:flex;position:absolute;box-shadow:0 8px 32px #00000026}.vgb-cloud.text{cursor:default}.vgb-cloud.playing{background:#c9a96e1f;border-color:#c9a96e4d;box-shadow:0 8px 32px #c9a96e26}.vgb-cloud-wave{align-items:center;gap:2px;height:16px;display:flex}.vgb-wave-bar{background:var(--gold-muted);border-radius:2px;width:2.5px;height:5px}.vgb-wave-bar.active{animation:.5s ease-in-out infinite alternate wave-bounce}@keyframes wave-bounce{0%{height:3px}to{height:14px}}.vgb-cloud-emoji{font-size:14px;line-height:1}.vgb-cloud-name{color:var(--text-secondary);letter-spacing:.5px;font-size:10px;font-weight:400}.vgb-cloud-text{color:var(--text-secondary);word-break:break-word;text-align:center;-webkit-line-clamp:2;-webkit-box-orient:vertical;max-width:100%;font-size:11px;font-weight:300;line-height:1.4;display:-webkit-box;overflow:hidden}.vgb-empty{text-align:center;color:var(--text-tertiary);font-size:13px;font-weight:200;line-height:2;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.vgb-empty-icon{opacity:.5;margin-bottom:8px;font-size:32px}.vgb-count{text-align:center;color:var(--text-tertiary);letter-spacing:1px;margin-bottom:16px;font-size:12px;font-weight:300}.vgb-btn-row{gap:10px;display:flex}.vgb-action-btn{border:1px solid var(--border);cursor:pointer;background:#ffffff0a;border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:6px;padding:20px 16px;transition:all .2s;display:flex}.vgb-action-btn:active{border-color:var(--gold-muted);background:#ffffff14;transform:scale(.97)}.vgb-action-icon{font-size:24px}.vgb-action-label{color:var(--text-primary);letter-spacing:.5px;font-size:13px;font-weight:300}.vgb-privacy{margin-bottom:14px}.vgb-privacy-check{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:8px;display:flex}.vgb-privacy-check input[type=checkbox]{display:none}.vgb-checkmark{border:1.5px solid var(--border);background:0 0;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;transition:all .2s;display:flex}.vgb-privacy-check input:checked+.vgb-checkmark{background:var(--gold);border-color:var(--gold)}.vgb-privacy-check input:checked+.vgb-checkmark:after{content:"✓";color:#fff;font-size:12px;line-height:1}.vgb-privacy-label{color:var(--text-secondary);font-size:12px;font-weight:300}.vgb-privacy-toggle{color:var(--text-tertiary);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;margin-top:6px;margin-left:26px;padding:0;font-size:11px;text-decoration:underline}.vgb-privacy-detail{margin-top:8px;overflow:hidden}.vgb-privacy-content{border:1px solid var(--border);color:var(--text-tertiary);background:#ffffff08;border-radius:8px;padding:12px 14px;font-size:10px;font-weight:300;line-height:1.8}.vgb-privacy-content strong{color:var(--text-secondary);font-weight:400}.vgb-privacy-content p{margin-bottom:2px}.vgb-form{border:1px solid var(--border);background:#ffffff08;border-radius:14px;padding:20px 18px}.vgb-form-row{gap:8px;margin-bottom:4px;display:flex}.vgb-input{border:1px solid var(--border);min-width:0;color:var(--text-primary);border-radius:8px;outline:none;flex:1;margin-bottom:8px;padding:11px 14px;font-size:13px;font-weight:300;transition:border-color .2s}.vgb-input:focus{border-color:var(--gold-muted)}.vgb-input::placeholder{color:var(--text-tertiary);font-size:12px}.vgb-textarea{border:1px solid var(--border);width:100%;color:var(--text-primary);resize:none;border-radius:8px;outline:none;margin-bottom:10px;padding:12px 14px;font-size:13px;font-weight:300;line-height:1.6;transition:border-color .2s}.vgb-textarea:focus{border-color:var(--gold-muted)}.vgb-textarea::placeholder{color:var(--text-tertiary)}.vgb-recorder{justify-content:center;margin:10px 0 14px;display:flex}.vgb-mic-btn{border:2px dashed var(--border);cursor:pointer;color:var(--text-secondary);background:#ffffff0a;border-radius:14px;flex-direction:column;align-items:center;gap:6px;padding:18px 28px;font-size:12px;font-weight:300;transition:all .2s;display:flex;position:relative;overflow:hidden}.vgb-mic-btn.recording{color:#c44;background:#fff5f5;border-style:solid;border-color:#e85d5d}.vgb-mic-icon{font-size:26px}.vgb-pulse{border:2px solid #e85d5d;border-radius:16px;animation:1.5s ease-out infinite pulse-ring;position:absolute;inset:-4px}@keyframes pulse-ring{0%{opacity:.6;transform:scale(1)}to{opacity:0;transform:scale(1.12)}}.vgb-preview{color:var(--gold);justify-content:center;align-items:center;gap:10px;margin-bottom:14px;font-size:12px;font-weight:300;display:flex}.vgb-play-preview{border:1px solid var(--gold-muted);color:var(--gold);cursor:pointer;background:0 0;border-radius:4px;padding:4px 10px;font-size:11px}.vgb-play-preview:active{background:var(--gold);color:#fff}.vgb-actions{gap:8px;display:flex}.vgb-cancel,.vgb-submit{cursor:pointer;border-radius:8px;flex:1;padding:12px;font-size:13px;font-weight:300;transition:all .2s}.vgb-cancel{border:1px solid var(--border);color:var(--text-secondary);background:0 0}.vgb-submit{background:var(--gold);border:1px solid var(--gold);color:#fff}.vgb-submit:disabled{opacity:.4;cursor:default}.vgb-submit:not(:disabled):active{background:#a5875e}.vgb-confetti{z-index:9999;pointer-events:none;position:fixed;top:50%;left:50%}.vgb-confetti-item{font-size:24px;position:absolute}:root{--gold:#c9a96e;--gold-light:#dcc48e;--gold-muted:#b89b5e;--cream:#0e0e0e;--warm-white:#161616;--bg-section:#111;--text-primary:#f0ede8;--text-secondary:#a8a29e;--text-tertiary:#706b66;--border:#2a2725;--accent-rose:#c4a0a0;--accent-sage:#b2bda0;--accent-terracotta:#c08b6e;--font-script:"Pinyon Script", cursive;--font-formal:"Petit Formal Script", cursive;--font-display:"Playfair Display", serif;--font-serif:"Cormorant Garamond", serif;--font-body-kr:"Noto Serif KR", serif;--font-sans-kr:"Noto Sans KR", sans-serif}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body-kr);background:var(--cream);color:var(--text-primary);-webkit-font-smoothing:antialiased;line-height:1.8;overflow-x:hidden}.wrapper{background:var(--cream);width:100%;max-width:100vw;min-height:100vh;margin:0 auto;overflow-x:hidden}@media (width>=480px){body{background:#080808;justify-content:center;display:flex}.wrapper{max-width:430px;min-height:100vh;position:relative;box-shadow:0 0 80px #0006}}.section{padding:56px 32px}.section-alt{background:var(--warm-white)}.section-label{font-family:var(--font-formal);letter-spacing:3px;color:var(--gold);text-align:center;margin-bottom:6px;font-size:14px}.section-title-kr{text-align:center;color:var(--text-primary);letter-spacing:3px;margin-bottom:28px;font-size:16px;font-weight:300}.divider{background:var(--gold-muted);opacity:.6;width:32px;height:1px;margin:0 auto 32px}.greeting p{text-align:center;color:var(--text-primary);word-break:keep-all;font-size:14px;font-weight:200;line-height:2.4}.families-row{justify-content:center;gap:40px;margin-top:8px;display:flex}.family-col{text-align:center}.family-side{color:var(--text-tertiary);letter-spacing:3px;margin-bottom:10px;font-size:11px}.family-parents{color:var(--text-secondary);font-size:14px;font-weight:300;line-height:2}.family-child{color:var(--text-primary);margin-top:2px;font-size:15px;font-weight:400}.family-relation{color:var(--text-tertiary);font-size:12px;font-weight:200}.venue-photo{border-radius:4px;width:100%;margin-bottom:24px;overflow:hidden}.venue-name{text-align:center;color:var(--text-primary);letter-spacing:2px;font-size:17px;font-weight:400}.venue-detail{text-align:center;color:var(--text-secondary);margin-top:4px;font-size:13px;font-weight:200}.venue-address{text-align:center;color:var(--text-tertiary);margin-top:12px;font-family:Noto Sans KR,sans-serif;font-size:12px;font-weight:300;line-height:1.8}.map-area{background:var(--bg-section);border-radius:4px;width:100%;height:200px;margin-top:24px;overflow:hidden}.map-area iframe{border:none;width:100%;height:100%}.transport{margin-top:20px}.transport-row{color:var(--text-secondary);align-items:baseline;padding:6px 0;font-size:13px;font-weight:300;line-height:1.6;display:flex}.transport-icon{color:var(--gold);letter-spacing:1px;flex:0 0 56px;font-size:12px;font-weight:400}.rsvp-text{text-align:center;color:var(--text-secondary);margin-bottom:24px;font-size:14px;font-weight:200;line-height:2}.rsvp-btn{border:1px solid var(--gold-muted);width:100%;max-width:240px;color:var(--gold);letter-spacing:3px;text-align:center;cursor:pointer;background:0 0;margin:0 auto;padding:14px 0;font-family:Noto Serif KR,serif;font-size:14px;font-weight:300;text-decoration:none;transition:all .3s;display:block}.rsvp-btn:active{background:var(--gold);color:#fff}.footer{text-align:center;border-top:1px solid var(--border);padding:40px 32px 60px}.footer-heart{color:var(--accent-rose);margin-bottom:12px;font-size:16px}.footer-names{font-family:var(--font-script);color:var(--text-tertiary);font-size:22px}.toast{color:#1a1a1a;opacity:0;z-index:9999;pointer-events:none;background:#fffffff2;border-radius:4px;padding:10px 24px;font-family:Noto Sans KR,sans-serif;font-size:13px;font-weight:300;transition:all .3s;position:fixed;bottom:32px;left:50%;transform:translate(-50%)translateY(16px)}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}
