@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@500;700&family=Lato:wght@400;700&display=swap";:root{--gold: #C9A84C;--gold-light: #F5E6C0;--gold-dark: #8B6914;--cream: #FDF8EF;--cream-dark: #F2E8D5;--brown: #3D2B1F;--brown-mid: #6B4A36;--green: #2E6B4F;--green-light: #D6EDE3;--green-dark: #1A4530;--orange: #C4641A;--orange-light: #FDEBD8;--red: #B03030;--red-light: #FADDDD;--purple: #5C3A8A;--purple-light: #EDE5F8;--radius: 16px;--radius-sm: 10px;--shadow: 0 4px 20px rgba(61, 43, 31, .1);--shadow-lg: 0 8px 32px rgba(61, 43, 31, .15)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%}body{font-family:Lato,sans-serif;background:var(--cream);color:var(--brown);min-height:100%}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--cream-dark)}::-webkit-scrollbar-thumb{background:var(--gold);border-radius:2px}.serif{font-family:Playfair Display,serif}.text-gold{color:var(--gold)}.text-center{text-align:center}.w-full{width:100%}.app-shell{width:100%;max-width:540px;min-height:100vh;margin:0 auto;display:flex;flex-direction:column}.app-header{background:linear-gradient(160deg,#3d2b1f,#6b4a36);padding:24px 20px 20px;text-align:center;position:relative;overflow:hidden;flex-shrink:0}.app-header:after{content:"✝";position:absolute;bottom:-10px;right:20px;font-size:80px;color:#ffffff0a;line-height:1;pointer-events:none}.app-header h1{font-family:Playfair Display,serif;font-size:clamp(18px,5vw,24px);font-weight:700;color:var(--gold-light);line-height:1.3;margin-bottom:4px}.app-header p{font-size:13px;color:#f5e6c0b3}.cross-deco{display:inline-block;color:var(--gold);font-size:18px;margin-bottom:8px;letter-spacing:8px}.page-content{flex:1;padding:20px 16px 32px;display:flex;flex-direction:column;gap:16px}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .35s ease both}.pop-in{animation:popIn .4s cubic-bezier(.34,1.56,.64,1) both}.slide-down{animation:slideDown .3s ease both}
