@import"https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Sarabun:wght@300;400;600&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{min-height:100%;background:#0d1829;font-family:Sarabun,sans-serif;display:flex;align-items:center;justify-content:center;padding:2rem 1rem}#root{display:flex;align-items:center;justify-content:center;width:100%;min-height:100vh}.screen{display:none;width:100%;max-width:460px}.screen.active{display:block;animation:fadeUp .45s ease}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 20% 30%,rgba(201,168,76,.08) 0%,transparent 60%),radial-gradient(ellipse at 80% 70%,rgba(100,130,200,.07) 0%,transparent 60%);pointer-events:none;z-index:0}.screen{position:relative;z-index:1}.lock-card{background:#1a2744;border:1px solid rgba(201,168,76,.2);border-radius:24px;overflow:hidden;box-shadow:0 24px 64px #00000080}.lock-top{background:linear-gradient(160deg,#12203d,#1e2f55);padding:2.5rem 2rem 2rem;text-align:center;border-bottom:1px solid rgba(201,168,76,.15)}.ticket-tag{display:inline-block;background:#c9a84c26;color:#c9a84c;font-size:11px;letter-spacing:1.8px;text-transform:uppercase;border-radius:20px;padding:5px 16px;margin-bottom:1.25rem;border:1px solid rgba(201,168,76,.25)}.lock-plane{font-size:52px;display:block;margin:0 auto 1rem;animation:hover-anim 2.8s ease-in-out infinite}@keyframes hover-anim{0%,to{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-8px) rotate(3deg)}}.lock-top h2{font-family:Playfair Display,serif;color:#f5e6c8;font-size:24px;font-weight:700;margin-bottom:8px}.lock-top p{color:#7a91bb;font-size:13px}.lock-body{padding:2rem 2rem 2.25rem;text-align:center;background:#1a2744}.prompt{font-size:14px;color:#8fa3cc;margin-bottom:1.5rem}.pin-row{display:flex;gap:12px;justify-content:center;margin-bottom:1.5rem}.pin-box{width:56px;height:60px;border:1.5px solid rgba(201,168,76,.3);border-radius:14px;background:#ffffff0d;font-size:28px;font-weight:700;text-align:center;color:#f5e6c8;outline:none;transition:border-color .2s,transform .15s,background .2s;caret-color:transparent}.pin-box:focus{border-color:#c9a84c;background:#c9a84c14;transform:scale(1.08)}.pin-box.error{border-color:#e24b4a;animation:shake .35s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-8px)}75%{transform:translate(8px)}}.main-btn{display:inline-block;padding:13px 44px;border:none;border-radius:32px;font-size:15px;font-weight:600;font-family:Sarabun,sans-serif;cursor:pointer;letter-spacing:.5px;transition:opacity .2s,transform .1s}.main-btn.dark,.main-btn.gold{background:linear-gradient(135deg,#c9a84c,#e0be6f);color:#12203d}.main-btn:hover{opacity:.88}.main-btn:active{transform:scale(.97)}.err-msg{font-size:13px;color:#e24b4a;min-height:20px;margin-top:.75rem}.bday-card{background:#1a2744;border:1px solid rgba(201,168,76,.2);border-radius:24px;overflow:hidden;box-shadow:0 24px 64px #00000080;text-align:center}.bday-top{background:linear-gradient(160deg,#12203d,#1e2f55);padding:3rem 2rem 2.5rem;border-bottom:1px solid rgba(201,168,76,.15)}.stars-row{font-size:18px;letter-spacing:8px;margin-bottom:1.25rem;display:block}.bday-top h1{font-family:Playfair Display,serif;font-style:italic;color:#f5e6c8;font-size:28px;font-weight:400;line-height:1.3}.name-highlight{font-style:normal;font-weight:700;color:#c9a84c;font-size:44px;display:block;margin-top:4px;text-shadow:0 0 30px rgba(201,168,76,.35)}.bday-body{padding:2.25rem 2rem 2.5rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem;background:#1a2744}.heart-row{font-size:30px;letter-spacing:6px;animation:pulse 1.4s ease infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.from-text{font-size:18px;color:#d4e0f5;font-weight:600;line-height:1.8}.xoxo-text{font-family:Playfair Display,serif;font-style:italic;font-size:16px;color:#7a91bb}.friends-card{background:#1a2744;border:1px solid rgba(201,168,76,.2);border-radius:24px;overflow:hidden;box-shadow:0 24px 64px #00000080}.friends-header{background:linear-gradient(160deg,#12203d,#1e2f55);padding:1.75rem 2rem 1.5rem;text-align:center;border-bottom:1px solid rgba(201,168,76,.15)}.friends-header .tag{font-size:11px;letter-spacing:1.8px;text-transform:uppercase;color:#c9a84c;display:block;margin-bottom:6px}.friends-header h3{font-family:Playfair Display,serif;color:#f5e6c8;font-size:20px;font-weight:700}.wish-list{padding:1.5rem 1.75rem;display:flex;flex-direction:column;gap:14px}.wish-item{background:#ffffff0a;border:1px solid rgba(201,168,76,.1);border-radius:16px;padding:16px 18px}.wish-from{font-size:13px;font-weight:600;color:#c9a84c;margin-bottom:6px;display:flex;align-items:center;gap:6px}.wish-dot{width:6px;height:6px;border-radius:50%;background:#c9a84c;display:inline-block;flex-shrink:0}.wish-msg{font-size:14px;color:#c4d4ee;line-height:1.75}.back-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border:1px solid rgba(201,168,76,.3);border-radius:28px;background:transparent;color:#c9a84c;font-size:14px;font-weight:600;font-family:Sarabun,sans-serif;cursor:pointer;transition:background .2s,opacity .2s}.back-btn:hover{background:#c9a84c14}.back-btn:active{opacity:.75}.nav-row{border-top:1px solid rgba(201,168,76,.12);padding:1.25rem 1.75rem 1.75rem;display:flex;justify-content:space-between;align-items:center;gap:12px}.ticket-wrap{background:#1a2744;border:1px solid rgba(201,168,76,.2);border-radius:24px;overflow:hidden;box-shadow:0 24px 64px #00000080}.ticket-header{background:linear-gradient(160deg,#12203d,#1e2f55);padding:1.75rem 2rem 1.5rem;text-align:center;border-bottom:1px solid rgba(201,168,76,.15)}.airline-tag{font-size:11px;letter-spacing:1.8px;text-transform:uppercase;color:#c9a84c;margin-bottom:6px;display:block}.ticket-header h3{font-family:Playfair Display,serif;color:#f5e6c8;font-size:18px;font-weight:700}.tear{height:0;border-top:1.5px dashed rgba(201,168,76,.25);margin:0 1.5rem;position:relative}.tear:before,.tear:after{content:"";position:absolute;top:-13px;width:26px;height:26px;border-radius:50%;background:#0d1829;border:1px solid rgba(201,168,76,.2)}.tear:before{left:-30px}.tear:after{right:-30px}.route-row{display:flex;align-items:center;justify-content:space-between;padding:1.75rem 2rem 1rem}.city{text-align:center;flex:1}.city .code{font-family:Playfair Display,serif;font-size:42px;font-weight:700;color:#f5e6c8;line-height:1}.city .name{font-size:12px;color:#7a91bb;margin-top:6px}.mid-arrow{flex:0 0 auto;text-align:center;color:#c9a84c;font-size:24px}.mid-arrow .round-label{font-size:11px;color:#7a91bb;display:block;margin-top:4px;letter-spacing:.5px}.details-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:.5rem 2rem 1.75rem}.det{background:#ffffff0a;border:1px solid rgba(201,168,76,.12);border-radius:12px;padding:12px 16px}.det-label{font-size:11px;color:#7a91bb;text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px}.det-value{font-size:14px;font-weight:600;color:#f5e6c8}.ticket-footer{border-top:1px solid rgba(201,168,76,.12);padding:1.5rem 2rem 1.75rem;text-align:center}.barcode{font-family:monospace;font-size:9px;letter-spacing:3px;color:#c9a84c73;border:1px solid rgba(201,168,76,.15);border-radius:6px;padding:7px 14px;display:inline-block;margin-bottom:10px}.footer-note{font-size:12px;color:#7a91bb}@media(max-width:420px){.city .code{font-size:32px}.pin-box{width:46px;height:50px;font-size:22px}}
