:root{--font-serif:"Noto Serif KR", "Apple SD Gothic Neo", serif;--font-sans:"Noto Sans KR", "Apple SD Gothic Neo", sans-serif;--color-ivory:#fffdf7;--color-rose:#c49a9a;--color-rose-light:#f2e8e8;--color-gold:#c9a96e;--color-text:#2c2c2c;--color-text-muted:#888;--color-border:#e5e0d8}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f0ece6}#root{background:#fff;max-width:480px;min-height:100vh;margin:0 auto;box-shadow:0 0 40px #00000014}.section-label{letter-spacing:3px;color:var(--color-gold);font-size:11px;font-family:var(--font-sans);text-align:center;margin-bottom:12px;font-weight:400}.section-title{font-family:var(--font-serif);color:var(--color-text);letter-spacing:1px;text-align:center;margin-bottom:24px;font-size:22px;font-weight:400}.fade-in{opacity:0;transition:opacity .7s,transform .7s;transform:translateY(20px)}.fade-in.visible{opacity:1;transform:translateY(0)}.cover{background:var(--color-ivory);flex-direction:column;min-height:100vh;display:flex;position:relative}.cover__photo{aspect-ratio:3/4;flex-shrink:0;width:100%;position:relative;overflow:hidden}.cover__photo-img{object-fit:cover;width:100%;height:100%;display:block}.cover__photo:after{content:"";background:linear-gradient(to bottom, transparent, var(--color-ivory));pointer-events:none;height:40%;position:absolute;bottom:0;left:0;right:0}.cover__dday{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:var(--color-gold);font-family:var(--font-serif);letter-spacing:1px;background:#ffffffe0;border:1px solid #c9a96e66;border-radius:40px;padding:8px 16px;font-size:15px;position:absolute;bottom:20px;right:20px}.cover__info{text-align:center;background:var(--color-ivory);flex-direction:column;flex:1;align-items:center;gap:20px;padding:40px 32px 48px;display:flex}.cover__deco{align-items:center;gap:10px;width:100%;max-width:160px;display:flex}.cover__deco-line{background:var(--color-gold);opacity:.5;flex:1;height:1px}.cover__deco-diamond{background:var(--color-gold);flex-shrink:0;width:5px;height:5px;transform:rotate(45deg)}.cover__names{align-items:center;gap:14px;display:flex}.cover__name{font-family:var(--font-serif);color:var(--color-text);letter-spacing:3px;font-size:28px;font-weight:400}.cover__name-and{color:var(--color-gold);font-size:18px;font-family:var(--font-serif)}.cover__date{font-family:var(--font-sans);color:var(--color-text-muted);letter-spacing:.5px;flex-direction:column;align-items:center;gap:6px;font-size:14px;line-height:1.8;display:flex}.cover__date-sep{background:var(--color-border);width:24px;height:1px;display:block}.cover__venue{flex-direction:column;align-items:center;gap:4px;display:flex}.cover__venue-name{font-family:var(--font-serif);color:var(--color-text);letter-spacing:1px;font-size:15px}.cover__venue-hall{font-family:var(--font-sans);color:var(--color-text-muted);font-size:13px}.cover__scroll-hint{position:absolute;bottom:16px;left:50%;transform:translate(-50%)}.cover__scroll-hint span{background:linear-gradient(to bottom, var(--color-gold), transparent);width:1px;height:36px;animation:1.8s ease-in-out infinite scrollHint;display:block}@keyframes scrollHint{0%{opacity:0;transform-origin:top;transform:scaleY(0)}50%{opacity:1;transform:scaleY(1)}to{opacity:0;transform-origin:bottom;transform:scaleY(0)}}.greeting{text-align:center;background:#fff;padding:64px 32px}.greeting__title{font-family:var(--font-serif);color:var(--color-text);letter-spacing:2px;margin:16px 0 32px;font-size:22px;font-weight:400}.greeting__title span{color:var(--color-gold);margin:0 8px}.greeting__text{font-family:var(--font-serif);color:var(--color-text-muted);white-space:pre-line;word-break:keep-all;margin-bottom:40px;font-size:15px;line-height:2}.greeting__families{flex-wrap:wrap;justify-content:center;align-items:center;gap:20px;display:flex}.greeting__family{flex-direction:column;gap:4px;display:flex}.greeting__family-parents{color:var(--color-text-muted);font-size:13px;font-family:var(--font-sans)}.greeting__family-child{color:var(--color-text);font-size:14px;font-family:var(--font-sans);font-weight:500}.greeting__family-divider{color:var(--color-border);font-size:18px}.kakao-map{border:1px solid var(--color-border);border-radius:12px;width:100%;height:240px;overflow:hidden}.kakao-map--error{background:var(--color-bg-soft);color:var(--color-text-muted);flex-direction:column;justify-content:center;align-items:center;gap:10px;font-size:14px;display:flex}.wedding-info{text-align:center;background:var(--color-ivory);padding:64px 32px}.wedding-info__datetime{margin-bottom:24px}.wedding-info__date{font-family:var(--font-serif);color:var(--color-text);letter-spacing:.5px;margin-bottom:6px;font-size:15px}.wedding-info__time{font-family:var(--font-serif);color:var(--color-gold);letter-spacing:1px;font-size:24px;font-weight:400}.wedding-info__venue{flex-direction:column;gap:5px;margin-bottom:28px;display:flex}.wedding-info__venue-name{color:var(--color-text);font-size:18px;font-weight:500;font-family:var(--font-sans)}.wedding-info__venue-hall{color:var(--color-text-muted);font-size:14px;font-family:var(--font-sans)}.wedding-info__venue-address{color:var(--color-text-muted);font-size:13px;font-family:var(--font-sans);margin-top:6px;line-height:1.6}.wedding-info__venue-tel{color:var(--color-gold);font-size:13px;font-family:var(--font-sans);margin-top:2px;text-decoration:none;display:inline-block}.wedding-info__map-placeholder{width:100%;height:180px;color:var(--color-text-muted);border:1px solid var(--color-border);background:linear-gradient(135deg,#f0ede8 0%,#e8e4de 100%);border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:8px;margin-bottom:16px;display:flex}.wedding-info__map-icon{color:var(--color-rose);opacity:.7}.wedding-info__map-placeholder p{font-size:14px;font-family:var(--font-sans);color:var(--color-text);font-weight:500}.wedding-info__map-placeholder span{text-align:center;color:var(--color-text-muted);padding:0 24px;font-size:11px;line-height:1.5}.wedding-info__map-buttons{justify-content:center;gap:8px;margin-top:20px;display:flex}.btn{font-size:13px;font-family:var(--font-sans);cursor:pointer;white-space:nowrap;border:none;border-radius:8px;justify-content:center;align-items:center;gap:4px;padding:11px 20px;font-weight:500;text-decoration:none;transition:opacity .2s,transform .1s;display:inline-flex}.btn:hover{opacity:.85}.btn:active{transform:scale(.97)}.btn--kakao{color:#3c1e1e;background:#fee500}.btn--naver{color:#fff;background:#03c75a}.btn--copy{background:var(--color-text);color:#fff}.btn--copied{background:var(--color-gold)}.bank-info{text-align:center;background:#fff;padding:64px 32px}.bank-info__desc{color:var(--color-text-muted);font-size:14px;line-height:1.8;font-family:var(--font-sans);margin-bottom:24px}.bank-info__toggle{border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;font-size:14px;font-family:var(--font-sans);background:0 0;border-radius:8px;align-items:center;gap:8px;padding:12px 24px;transition:background .2s;display:inline-flex}.bank-info__toggle:hover{background:var(--color-ivory)}.bank-info__toggle-arrow{font-size:12px;transition:transform .3s;display:inline-block}.bank-info__toggle-arrow.open{transform:rotate(180deg)}.bank-info__accounts{text-align:left;flex-direction:column;gap:10px;margin-top:16px;display:flex}.account-item{background:var(--color-ivory);border-radius:10px;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;display:flex}.account-item__info{flex-direction:column;gap:2px;display:flex}.account-item__side{color:var(--color-rose);font-size:11px;font-family:var(--font-sans);font-weight:500}.account-item__owner{color:var(--color-text);font-size:15px;font-family:var(--font-sans);font-weight:500}.account-item__bank{color:var(--color-text-muted);font-size:12px;font-family:var(--font-sans)}.account-item__number{color:var(--color-text);letter-spacing:.5px;font-family:monospace;font-size:13px}.account-item__copy{background:var(--color-text);color:#fff;cursor:pointer;font-size:12px;font-family:var(--font-sans);border:none;border-radius:6px;flex-shrink:0;min-width:52px;padding:8px 14px;transition:background .2s}.account-item__copy.copied{background:var(--color-gold)}.gallery{text-align:center;background:var(--color-ivory);padding:64px 16px}.gallery__grid{grid-template-columns:repeat(3,1fr);gap:4px;margin-top:8px;display:grid}.gallery__item{aspect-ratio:1;background:var(--color-rose-light);cursor:pointer;border:none;padding:0;display:block;overflow:hidden}.gallery__item img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.gallery__item:hover img{transform:scale(1.05)}.lightbox{z-index:1000;background:#000000eb;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lightbox__close{color:#fff;cursor:pointer;z-index:10;opacity:.8;background:0 0;border:none;padding:8px;font-size:24px;transition:opacity .2s;position:absolute;top:20px;right:20px}.lightbox__close:hover{opacity:1}.lightbox__content{flex-direction:column;align-items:center;gap:12px;max-width:90vw;max-height:85vh;display:flex}.lightbox__slide-wrap{justify-content:center;align-items:center;max-width:90vw;max-height:80vh;display:flex;overflow:hidden}.lightbox__slide{object-fit:contain;border-radius:4px;max-width:100%;max-height:80vh;display:block}.lightbox__slide--next{animation:.3s slideInFromRight}.lightbox__slide--prev{animation:.3s slideInFromLeft}@keyframes slideInFromRight{0%{opacity:0;transform:translate(60px)}to{opacity:1;transform:translate(0)}}@keyframes slideInFromLeft{0%{opacity:0;transform:translate(-60px)}to{opacity:1;transform:translate(0)}}.lightbox__counter{color:#fff9;font-size:13px;font-family:var(--font-sans)}.lightbox__nav{color:#fff;cursor:pointer;z-index:10;background:#ffffff26;border:none;border-radius:6px;padding:12px 16px;font-size:36px;line-height:1;transition:background .2s;position:absolute;top:50%;transform:translateY(-50%)}.lightbox__nav:hover{background:#ffffff40}.lightbox__nav--prev{left:16px}.lightbox__nav--next{right:16px}.guestbook{background:#fff;padding:64px 24px 80px}.guestbook__desc{color:var(--color-text-muted);font-size:14px;font-family:var(--font-sans);text-align:center;margin-bottom:24px}.gb-write-form{background:var(--color-ivory);border-radius:12px;flex-direction:column;gap:10px;margin-bottom:32px;padding:20px;display:flex}.gb-write-form__row{gap:8px;display:flex}.gb-write-form input,.gb-write-form textarea,.gb-item__edit textarea,.modal input{border:1px solid var(--color-border);width:100%;font-size:14px;font-family:var(--font-sans);color:var(--color-text);resize:none;background:#fff;border-radius:8px;outline:none;padding:12px 14px;transition:border-color .2s}.gb-write-form input:focus,.gb-write-form textarea:focus,.gb-item__edit textarea:focus,.modal input:focus{border-color:var(--color-gold)}.gb-write-form__row input{flex:1}.gb-error{color:#e05a5a;font-size:12px;font-family:var(--font-sans)}.gb-submit-btn{background:var(--color-text);color:#fff;font-size:14px;font-family:var(--font-sans);cursor:pointer;border:none;border-radius:8px;padding:12px;font-weight:500;transition:opacity .2s}.gb-submit-btn:hover:not(:disabled){opacity:.8}.gb-submit-btn:disabled{opacity:.5;cursor:not-allowed}.guestbook__list{flex-direction:column;gap:12px;display:flex}.guestbook__empty{font-family:var(--font-sans);flex-direction:column;align-items:center;gap:8px;padding:40px 0;display:flex}.guestbook__empty p{color:var(--color-text-muted);font-size:14px}.guestbook__empty span{color:var(--color-border);font-size:12px}.gb-skeleton{background:linear-gradient(90deg,#f0ede8 25%,#e8e4de 50%,#f0ede8 75%) 0 0/200% 100%;border-radius:10px;height:88px;animation:1.4s infinite shimmer}.gb-skeleton--short{height:60px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.gb-item{background:var(--color-ivory);border-radius:10px;padding:16px}.gb-item__header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.gb-item__meta{align-items:center;gap:8px;display:flex}.gb-item__author{color:var(--color-text);font-size:14px;font-weight:500;font-family:var(--font-sans)}.gb-item__date{color:var(--color-text-muted);font-size:11px;font-family:var(--font-sans)}.gb-item__actions{gap:8px;display:flex}.gb-item__actions button{color:var(--color-text-muted);cursor:pointer;font-size:12px;font-family:var(--font-sans);background:0 0;border:none;padding:2px 4px;transition:color .2s}.gb-item__actions button:hover{color:var(--color-text)}.gb-item__content{color:var(--color-text);font-size:14px;line-height:1.7;font-family:var(--font-sans);white-space:pre-wrap}.gb-item__edit{flex-direction:column;gap:8px;display:flex}.gb-item__edit-buttons{justify-content:flex-end;gap:8px;display:flex}.gb-item__edit-cancel,.gb-item__edit-save{cursor:pointer;font-size:13px;font-family:var(--font-sans);border:none;border-radius:6px;padding:8px 16px;transition:opacity .2s}.gb-item__edit-cancel{background:var(--color-border);color:var(--color-text)}.gb-item__edit-save{background:var(--color-text);color:#fff}.modal-overlay{z-index:500;background:#0006;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:16px;flex-direction:column;gap:16px;width:100%;max-width:320px;padding:28px 24px;display:flex}.modal__title{color:var(--color-text);font-size:15px;font-weight:500;font-family:var(--font-sans);text-align:center}.modal__buttons{gap:8px;display:flex}.modal__btn{cursor:pointer;font-size:14px;font-family:var(--font-sans);border:none;border-radius:8px;flex:1;padding:12px;font-weight:500;transition:opacity .2s}.modal__btn--cancel{background:var(--color-ivory);color:var(--color-text)}.modal__btn--confirm{background:var(--color-text);color:#fff}.share-bar{z-index:100;border-top:1px solid var(--color-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffdf7f2;width:100%;max-width:480px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.share-btn{font-family:var(--font-sans);cursor:pointer;padding:16px 8px;padding-bottom:max(16px, env(safe-area-inset-bottom));background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:8px;font-size:13px;font-weight:500;transition:background .2s;display:flex}.share-btn:hover{background:#0000000a}.share-btn--url{color:var(--color-text);border-right:1px solid var(--color-border)}.share-btn--kakao{color:#3c1e1e;background:#fee50026}.share-btn--kakao:hover{background:#fee5004d}.music-btn{z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);width:42px;height:42px;color:var(--color-gold);cursor:pointer;background:#fffdf7e0;border:1px solid #c9a96e80;border-radius:50%;justify-content:center;align-items:center;gap:0;transition:background .2s,transform .2s;display:flex;position:fixed;top:20px;right:20px;overflow:visible;box-shadow:0 2px 12px #0000001a}.music-btn:active{transform:scale(.92)}.music-btn--playing svg{animation:4s linear infinite musicRotate}@keyframes musicRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.music-btn__waves{pointer-events:none;border-radius:50%;position:absolute;inset:0}.music-btn__waves span{border:1px solid #c9a96e80;border-radius:50%;animation:2s ease-out infinite musicWave;position:absolute;inset:0}.music-btn__waves span:nth-child(2){animation-delay:.6s}.music-btn__waves span:nth-child(3){animation-delay:1.2s}@keyframes musicWave{0%{opacity:.6;transform:scale(1)}to{opacity:0;transform:scale(2.2)}}
