/* Bonneyajou-inspired, classic A mood (ivory + serif) */
:root{--bg:#f3eee7;--ink:#2b2a28;--muted:#6c6964;--line:#ded6cd;--btn:#2b2a28;--btnText:#f7f2ec;--shadow:0 10px 26px rgba(0,0,0,0.06);}
*{box-sizing:border-box}html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--ink);font-family:"Noto Serif KR",serif;letter-spacing:-0.2px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
.bg-grain{position:fixed;inset:0;pointer-events:none;opacity:.11;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='120' height='120' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");mix-blend-mode:multiply}
.wrap{max-width:560px;margin:0 auto;padding:18px 16px 42px;display:flex;flex-direction:column;gap:14px}
.cover{position:relative;min-height:92vh;display:grid;place-items:stretch;overflow:hidden;border-bottom:1px solid var(--line)}
.cover-media{position:absolute;inset:0}
.cover-img{width:100%;height:100%;object-fit:cover;transform:scale(1.05);filter:saturate(.98) contrast(.98)}
.cover-overlay{position:absolute;inset:0;background:radial-gradient(80% 60% at 50% 30%, rgba(243,238,231,0.0), rgba(243,238,231,0.75)),linear-gradient(to bottom, rgba(0,0,0,0.22), rgba(0,0,0,0.06), rgba(0,0,0,0.22))}
.cover-fallback{position:absolute;inset:0;background:linear-gradient(180deg, rgba(255,255,255,0.35), rgba(255,255,255,0.12));place-items:center}
.fallback-box{background:rgba(247,242,236,0.92);border:1px solid var(--line);border-radius:18px;padding:18px 16px;box-shadow:var(--shadow);text-align:center}
.fallback-title{font-weight:600}.fallback-sub{margin-top:6px;color:var(--muted);font-size:13px}
.cover-content{position:relative;padding:56px 18px 28px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:12px;text-align:center}
.kicker{font-family:"Cormorant Garamond",serif;letter-spacing:0.22em;text-transform:uppercase;font-size:12px;color:rgba(255,255,255,0.9)}
.names{margin:6px 0 2px;font-family:"Cormorant Garamond",serif;letter-spacing:0.08em;font-weight:500;color:#fff;font-size:44px;line-height:1.0}
.names .dot{display:inline-block;margin:0 8px;opacity:.9}
.meta{color:rgba(255,255,255,0.92);font-size:14px;line-height:1.55}
.cover-actions{width:min(420px,92%);display:flex;gap:10px;margin-top:10px}
.scroll-hint{margin-top:12px;display:flex;flex-direction:column;align-items:center;gap:6px;color:rgba(255,255,255,0.85);font-family:"Cormorant Garamond",serif;letter-spacing:0.18em;text-transform:uppercase;font-size:12px}
.scroll-dot{width:10px;height:16px;border:1px solid rgba(255,255,255,0.8);border-radius:99px;position:relative}
.scroll-dot:after{content:"";position:absolute;left:50%;top:4px;width:2px;height:3px;transform:translateX(-50%);background:rgba(255,255,255,0.9);border-radius:99px;animation:scroll 1.4s infinite ease-in-out}
@keyframes scroll{0%{opacity:0;transform:translate(-50%,0)}25%{opacity:1}70%{opacity:0;transform:translate(-50%,6px)}100%{opacity:0}}
.card{background:linear-gradient(180deg, rgba(255,255,255,0.35), rgba(255,255,255,0.12));border:1px solid var(--line);border-radius:18px;padding:22px 18px;box-shadow:var(--shadow);backdrop-filter:blur(2px)}
.section-title{margin:0 0 14px;text-align:center;font-family:"Cormorant Garamond",serif;letter-spacing:0.22em;font-weight:600;color:var(--muted);font-size:13px}
.poem{margin:0;text-align:center;line-height:1.95;font-size:15px}
.subtle{color:var(--muted)}.small{font-size:12px;margin:0 2px}.mini-note{margin-top:14px;font-size:12px}
code{background:rgba(0,0,0,0.04);padding:2px 6px;border-radius:8px}
.family{margin:18px 0 6px;display:flex;flex-direction:column;gap:10px}
.family-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:12px 12px;border:1px dashed var(--line);border-radius:14px}
.family-label{color:var(--muted);font-size:13px}.family-name{font-size:16px;font-weight:600}
.info-grid{margin-top:12px;display:grid;gap:10px}
.info-item{display:flex;gap:12px;align-items:flex-start}
.info-k{width:44px;flex:0 0 44px;color:var(--muted);font-size:13px}
.info-v{font-size:14px;line-height:1.65}
.countdown-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.cd-item{text-align:center;padding:12px 10px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,0.18)}
.cd-num{font-family:"Cormorant Garamond",serif;font-size:26px;font-weight:600}
.cd-lbl{margin-top:2px;font-size:11px;letter-spacing:0.08em;text-transform:uppercase;color:var(--muted)}
.btn{border:1px solid var(--btn);background:var(--btn);color:var(--btnText);text-decoration:none;display:inline-flex;align-items:center;justify-content:center;height:44px;padding:0 14px;border-radius:14px;font-size:13px;width:100%;cursor:pointer;user-select:none}
.btn:active{transform:translateY(1px)}.btn-ghost{background:transparent;color:var(--btn)}.btn-small{height:40px;font-size:12px}
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:8px}
.gimg{border-radius:14px;overflow:hidden;border:1px solid var(--line);aspect-ratio:1/1;background:rgba(0,0,0,0.03);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:12px}
.gimg img{width:100%;height:100%;object-fit:cover;display:block}.gimg button{all:unset;width:100%;height:100%;cursor:pointer}
.place-title{font-size:16px;font-weight:600;text-align:center}
.place-addr{margin-top:6px;text-align:center;color:var(--muted);font-size:13px;line-height:1.6}
.place-tel{margin-top:8px;text-align:center;font-size:13px}
.place-tel a{color:var(--ink)}
.map-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin:14px 0}
.map-embed iframe{width:100%;height:260px;border:0;border-radius:14px;background:#fff;border:1px solid var(--line)}
.howto{margin-top:16px}
.howto-title{margin:16px 0 10px;font-size:14px;color:var(--ink)}
.bullets{margin:0;padding-left:18px;color:var(--muted);line-height:1.85;font-size:13px}
.bullets b{color:var(--ink);font-weight:600}
.shuttle{border:1px solid var(--line);border-radius:14px;padding:12px 12px;background:rgba(255,255,255,0.18)}
.shuttle-row{display:flex;justify-content:space-between;gap:12px;padding:8px 0}
.shuttle-row + .shuttle-row{border-top:1px dashed var(--line)}
.shuttle-k{color:var(--muted);font-size:13px}.shuttle-v{font-size:13px;font-weight:600}
.accordion{margin-top:10px;display:flex;flex-direction:column;gap:10px}
.acc-head{width:100%;border:1px solid var(--line);background:rgba(255,255,255,0.18);border-radius:14px;padding:14px 14px;display:flex;justify-content:space-between;align-items:center;font-family:"Noto Serif KR",serif;font-size:14px;cursor:pointer}
.acc-ico{font-family:system-ui,sans-serif;font-size:18px;color:var(--muted)}
.acc-body{display:none;padding:10px 10px 2px}
.acc-body.open{display:block}
.account-card{border:1px dashed var(--line);border-radius:14px;padding:12px 12px;margin-bottom:10px;background:rgba(255,255,255,0.12)}
.account-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.account-name{font-weight:600}
.account-bank{color:var(--muted);font-size:13px;margin-top:4px}
.account-num{margin-top:8px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px}
.copy-btn{border:1px solid var(--btn);background:transparent;color:var(--btn);border-radius:12px;height:36px;padding:0 12px;font-size:12px;cursor:pointer;white-space:nowrap}
.form{margin-top:10px}.row{display:grid;gap:8px;margin:12px 0}
.lbl{color:var(--muted);font-size:13px}
.inp{width:100%;border:1px solid var(--line);background:rgba(255,255,255,0.22);border-radius:14px;padding:12px 12px;font-family:"Noto Serif KR",serif;font-size:14px;outline:none}
.inp:focus{border-color:#c9bfb5}
.seg{display:flex;gap:14px;color:var(--ink);font-size:14px}
.seg input{accent-color:#2b2a28}
.form-status{margin-top:10px;font-size:13px;color:var(--muted)}
.form-status.ok{color:#14532d}.form-status.bad{color:#7f1d1d}
.guest-list{margin-top:14px;display:flex;flex-direction:column;gap:10px}
.msg{border:1px solid var(--line);border-radius:14px;padding:12px 12px;background:rgba(255,255,255,0.18)}
.msg-top{display:flex;justify-content:space-between;gap:10px}
.msg-name{font-weight:600}.msg-time{color:var(--muted);font-size:12px}
.msg-body{margin-top:8px;color:var(--ink);line-height:1.7;font-size:14px;white-space:pre-wrap}
.end{margin-top:6px;text-align:center;padding:22px 0 8px;color:var(--muted)}
.end-line{font-family:"Cormorant Garamond",serif;font-size:18px;letter-spacing:0.08em;color:var(--ink)}
.end-subtle{margin-top:6px;font-size:13px}
.to-top{display:inline-block;margin-top:12px;color:var(--muted);text-decoration:none;border-bottom:1px dashed var(--line);padding-bottom:2px}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,0.82);display:none;align-items:center;justify-content:center;padding:24px 16px;z-index:50}
.lightbox.open{display:flex}
.lb-img{max-width:min(720px,100%);max-height:82vh;border-radius:18px;border:1px solid rgba(255,255,255,0.18)}
.lb-close{position:fixed;top:18px;right:16px;width:44px;height:44px;border-radius:999px;border:1px solid rgba(255,255,255,0.18);background:rgba(255,255,255,0.08);color:#fff;font-size:26px;cursor:pointer}
[data-reveal]{opacity:0;transform:translateY(10px);transition:opacity .8s ease,transform .8s ease}
.revealed{opacity:1;transform:none}
@media (max-width:360px){.names{font-size:36px}.cover-actions{flex-direction:column}.map-actions{grid-template-columns:1fr}.countdown-grid{gap:8px}.cd-num{font-size:22px}}
