*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--cream: #faf8f5;--cream-dark: #f0ebe4;--brown: #2c1810;--brown-mid: #5c3d2e;--brown-light: #9b6b52;--gold: #b8912a;--gold-light: #d4a843;--text: #2c1810;--text-muted: #7a5c4a;--border: #d9cfc7;--shadow-lg: 0 8px 40px rgba(44,24,16,.16)}html,body,#root{height:100%;font-family:DM Sans,sans-serif;background:var(--cream-dark);color:var(--text)}.page-center{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background:radial-gradient(ellipse at 20% 20%,rgba(184,145,42,.08) 0%,transparent 60%),radial-gradient(ellipse at 80% 80%,rgba(44,24,16,.06) 0%,transparent 60%),var(--cream-dark)}.card{background:#fff;border-radius:20px;box-shadow:var(--shadow-lg);max-width:380px;width:100%;overflow:hidden;border:1px solid var(--border);position:relative}.card-top-bar,.card-bottom-bar{height:6px;background:linear-gradient(90deg,var(--gold),var(--gold-light),var(--gold))}.greeting{padding:2rem 2rem 1.5rem;text-align:center}.greeting-label{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:.5rem}.guest-name{font-family:Cormorant Garamond,serif;font-size:2rem;font-weight:600;color:var(--brown);line-height:1.2;margin-bottom:.75rem}.category-badge{display:inline-block;font-size:.75rem;letter-spacing:.08em;color:var(--brown-light);border:1px solid var(--border);border-radius:99px;padding:.2rem .85rem}.divider{height:1px;background:var(--border);margin:0 2rem}.qr-wrap{padding:1.75rem 2rem 2rem;display:flex;flex-direction:column;align-items:center;gap:1.25rem}.qr-img{width:220px;height:220px;border-radius:12px;border:1.5px solid var(--border);display:block}.qr-hint{font-size:.78rem;color:var(--text-muted);text-align:center;line-height:1.6;max-width:260px}.notfound-box{text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}.ornament{font-size:1.5rem;color:var(--gold)}.notfound-text{font-family:Cormorant Garamond,serif;font-size:1.25rem;color:var(--text-muted)}.loading-ring{width:36px;height:36px;border:3px solid var(--cream-dark);border-top-color:var(--brown-light);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.page-content{display:flex;flex-direction:column;align-items:center;gap:1.25rem;width:100%;max-width:380px}.download-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.75rem;background:var(--brown);color:var(--cream);border:none;border-radius:99px;font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:500;letter-spacing:.02em;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s;box-shadow:0 2px 12px #2c18102e}.download-btn:hover:not(:disabled){background:var(--brown-mid);transform:translateY(-1px);box-shadow:0 4px 18px #2c181038}.download-btn:disabled{opacity:.7;cursor:not-allowed}.btn-spinner{width:14px;height:14px;border:2px solid rgba(250,248,245,.35);border-top-color:var(--cream);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
