:root{--bg-deep: #0c0611;--bg-plum: #241038;--gold: #e6c873;--gold-bright: #f3d98a;--gold-deep: #b8923f;--gold-line: rgba(230, 200, 115, .45);--ivory: #f4ecdf;--muted: #c3b4cf;--font-script: "Great Vibes", cursive;--font-serif: "Cormorant Garamond", serif;--font-sans: "Montserrat", sans-serif}*{margin:0;padding:0;box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{min-height:100dvh;background:radial-gradient(ellipse at 50% -10%,var(--bg-plum) 0%,var(--bg-deep) 65%) fixed;color:var(--ivory);font-family:var(--font-serif);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}.app{position:relative;min-height:100dvh}.magic-dust{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}.btn-gold{display:inline-block;padding:.85rem 2.4rem;font-family:var(--font-sans);font-size:.82rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;color:#2a1606;background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));border:none;border-radius:999px;cursor:pointer;box-shadow:0 8px 24px #b8923f52,inset 0 1px #fff6;transition:transform .3s ease,box-shadow .3s ease}.btn-gold:hover{transform:translateY(-2px);box-shadow:0 12px 30px #b8923f73,inset 0 1px #ffffff80}.btn-gold:active{transform:translateY(0)}.reveal{opacity:0;transform:translateY(18px);animation:reveal 1s cubic-bezier(.2,.7,.2,1) forwards;animation-delay:var(--d, 0s)}@keyframes reveal{to{opacity:1;transform:none}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-9px)}}.intro{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(ellipse at center,#24103899,#0c0611e6 70%);transition:opacity 1s ease,transform 1.1s ease,visibility 1.1s}.intro.is-leaving{opacity:0;visibility:hidden;transform:scale(1.06)}.intro__content{text-align:center}.intro__crown{width:clamp(70px,20vw,92px);margin-bottom:.4rem;animation:float 4.5s ease-in-out infinite;filter:drop-shadow(0 6px 18px rgba(230,200,115,.35))}.intro__eyebrow{font-family:var(--font-serif);font-style:italic;font-size:clamp(1rem,4vw,1.2rem);color:var(--muted);margin-bottom:.2rem}.intro__name{font-family:var(--font-script);font-size:clamp(4rem,18vw,6.5rem);font-weight:400;line-height:1;color:var(--gold-bright);text-shadow:0 0 34px rgba(243,217,138,.4)}.intro__age{display:flex;align-items:center;justify-content:center;gap:.9rem;margin-top:.9rem;font-family:var(--font-sans);font-weight:300;font-size:clamp(.78rem,3.4vw,.95rem);letter-spacing:.42em;text-transform:uppercase;color:var(--ivory)}.intro__age .line{width:clamp(26px,9vw,46px);height:1px;background:linear-gradient(90deg,transparent,var(--gold-line),transparent)}.intro .btn-gold{margin-top:2.6rem}.card-stage{position:relative;z-index:10;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:clamp(34px,9vw,70px) 18px;animation:stageIn 1.2s ease forwards}@keyframes stageIn{0%{opacity:0}to{opacity:1}}.card{position:relative;width:100%;max-width:430px;background:linear-gradient(160deg,#2d1442f5,#0f0816fc);border-radius:14px;box-shadow:0 30px 70px #000000a6,0 0 0 1px #e6c8731f,inset 0 0 40px #b8923f14}.card__flower{position:absolute;width:clamp(36px,1vw,82px);z-index:1;pointer-events:none;opacity:.92;filter:drop-shadow(0 6px 14px rgba(0,0,0,.5))}.card__flower--tl{top:-2px;left:20px;transform:rotate(-10deg)}.card__flower--br{bottom:22px;right:20px;transform:rotate(10deg)}.card__frame{position:relative;z-index:2;margin:14px;border:1px solid var(--gold-line);border-radius:9px;padding:3px}.card__inner{border:1px solid rgba(230,200,115,.22);border-radius:6px;padding:clamp(28px,7vw,40px) clamp(20px,6vw,34px);display:flex;flex-direction:column;align-items:center;text-align:center}.card__crown{width:clamp(46px,13vw,58px);margin-bottom:.7rem;filter:drop-shadow(0 4px 12px rgba(230,200,115,.3))}.card__eyebrow{font-style:italic;font-size:clamp(.95rem,3.6vw,1.1rem);color:var(--muted);margin-bottom:.3rem}.card__title{font-family:var(--font-script);font-weight:400;font-size:clamp(2.1rem,9vw,2.9rem);line-height:1.1;color:var(--gold-bright);text-shadow:0 0 22px rgba(243,217,138,.25)}.ornament{display:flex;align-items:center;justify-content:center;gap:.7rem;width:70%;margin:1.1rem 0;color:var(--gold);font-size:.7rem}.ornament span{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--gold-line),transparent)}.card__message{font-size:clamp(1.04rem,4.2vw,1.16rem);line-height:1.75;color:var(--ivory);max-width:34ch;margin:0 auto}.card__details{list-style:none;display:flex;flex-direction:column;gap:1.35rem;width:100%;margin-top:.4rem}.detail{display:flex;flex-direction:column;gap:.18rem}.detail__label{font-family:var(--font-sans);font-weight:500;font-size:.66rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold)}.detail__value{font-size:clamp(1.16rem,4.6vw,1.32rem);font-weight:600;color:var(--ivory)}.detail__sub{font-style:italic;font-size:clamp(.9rem,3.6vw,1rem);color:var(--muted)}.card__rsvp{margin-top:2rem}.card__rsvp-note{margin-top:.9rem;font-style:italic;font-size:.9rem;color:var(--muted)}.music-btn{position:fixed;right:16px;bottom:16px;width:48px;height:48px;z-index:1000;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid var(--gold-line);background:#241038bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);cursor:pointer;transition:box-shadow .3s ease,background .3s ease}.music-btn.is-playing{background:#b8923f38;box-shadow:0 0 16px #e6c87366}.music-bars{display:flex;align-items:flex-end;gap:2px;height:16px}.music-bars i{width:2px;height:35%;background:var(--gold-bright);border-radius:1px;transition:height .3s ease}.music-btn.is-playing .music-bars i{animation:bars .9s ease-in-out infinite}.music-btn.is-playing .music-bars i:nth-child(2){animation-delay:.25s}.music-btn.is-playing .music-bars i:nth-child(3){animation-delay:.5s}@keyframes bars{0%,to{height:30%}50%{height:100%}}@media (min-width: 768px){.card{max-width:470px}.card__message{max-width:36ch}.card__flower{width:92px}.card__flower--tl{top:-12px;left:20px}.card__flower--br{bottom:26px;right:16px}}@media (prefers-reduced-motion: reduce){.reveal,.intro__crown,.card-stage{animation:none!important;opacity:1!important;transform:none!important}}
