@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Inter:wght@400;500;600&display=swap";.app{min-height:100vh;display:flex}.invite-shell{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:18px}.invite-card{width:100%;max-width:430px;min-height:calc(100vh - 36px);background:linear-gradient(#fcf7f0e0,#fcf7f0eb),url(/paper-texture.jpg);background-size:cover;background-position:center;border-radius:30px;box-shadow:0 18px 50px #5c3f271f;position:relative;overflow:hidden;padding:30px 20px 24px;display:flex;flex-direction:column;justify-content:center}.invite-card:before{content:"";position:absolute;inset:14px;border-radius:22px;border:1px solid rgba(173,132,86,.2);pointer-events:none}.header,.scratch-section,.action-area,.names{position:relative;z-index:1}.header{text-align:center;margin-bottom:18px}.eyebrow{margin:0 0 8px;text-transform:uppercase;letter-spacing:.28em;font-size:.75rem;color:var(--muted)}.title{margin:0;font-family:Cormorant Garamond,serif;font-size:2.5rem;line-height:.95;font-weight:600;color:var(--text)}.subtitle{margin:10px auto 0;max-width:260px;color:var(--muted);font-size:.95rem}.scratch-section{display:flex;justify-content:center;margin:16px 0 10px}.heart-stage{position:relative;width:min(84vw,320px);aspect-ratio:340 / 320;margin:auto}.heart-stage,.scratch-canvas{touch-action:none;-webkit-user-select:none;user-select:none}.scratch-canvas{display:block;touch-action:none;z-index:2;cursor:pointer}.heart-date-layer,.scratch-canvas,.heart-svg{position:absolute;inset:0;width:100%;height:100%}.heart-date-layer{display:flex;align-items:center;justify-content:center;text-align:center;padding:48px 42px 58px;pointer-events:none;z-index:1}.scratch-canvas{display:block;touch-action:none;z-index:2}.heart-svg{position:absolute;inset:0;width:100%;height:100%;z-index:3;pointer-events:none;opacity:.95}.date-block{display:flex;flex-direction:column;gap:6px;align-items:center;transform:translateY(-2px);opacity:.88}.date-label{text-transform:uppercase;letter-spacing:.22em;font-size:.68rem;color:var(--muted)}.date-main{font-family:Cormorant Garamond,serif;font-size:2.05rem;line-height:1;font-weight:700;color:var(--text)}.date-year{text-transform:uppercase;letter-spacing:.18em;color:var(--muted);font-size:.95rem}.names{text-align:center;margin-bottom:22px}.names h2{margin:0;font-family:Cormorant Garamond,serif;font-size:2.1rem;font-weight:600;letter-spacing:.04em}.names p{margin:8px 0 0;color:var(--muted);font-size:.95rem}.action-area{position:relative;z-index:1;min-height:56px;display:flex;align-items:center;justify-content:center;margin:8px 0 18px}.helper{margin:0;text-align:center;color:var(--muted);font-size:.9rem}.calendar-btn{width:100%;max-width:320px;border:0;border-radius:999px;background:linear-gradient(180deg,#caa06b,#ab7e50);color:#fffdf8;padding:15px 18px;font-size:.96rem;font-weight:600;box-shadow:0 10px 24px #a67c523d;cursor:pointer}.calendar-btn:active{transform:scale(.99)}.calendar-btn-pop{animation:popIn .45s ease}@keyframes popIn{0%{opacity:0;transform:translateY(10px) scale(.94)}to{opacity:1;transform:translateY(0) scale(1)}}@media(min-width:768px){.invite-shell{padding:30px}.invite-card{max-width:460px;min-height:780px;padding:34px 28px 28px}.title{font-size:3rem}.names h2{font-size:2.4rem}}.deboss{color:#8b6d4f;text-shadow:.6px .6px 0 rgba(255,255,255,.65),-.6px -.6px 0 rgba(160,120,80,.35)}:root{font-family:Inter,system-ui,sans-serif;color:#4b3427;background:#f6efe6;line-height:1.5;font-weight:400;--bg: #f6efe6;--paper: #fcf7f0;--text: #4b3427;--muted: #8a6f5a;--gold: #d4af37;--gold-deep: #b8891f;--button: #a67c52;--button-text: #fffdf9;--shadow: 0 12px 40px rgba(92, 63, 39, .12)}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%;width:100%}body{background:radial-gradient(circle at top,rgba(255,255,255,.45),transparent 35%),linear-gradient(180deg,#f8f1e8,#f2e7da);color:var(--text)}
