*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--pink-main:#d81b7a;--pink-light:#f06292;--orange-main:#f57c00;--orange-light:#ffb74d;--teal-main:#00897b;--teal-light:#4db6ac;--blue-main:#0077b6;--blue-light:#00b4d8;--gold-main:#d4af37;--gold-light:#f5d060;--cream:#fffde7;--text-dark:#1a1a2e;--text-mid:#2d4059}body{background-image:url(/songkran_bg_updated_1775729195924.jpg);background-position:top;background-size:cover;background-attachment:fixed;min-height:100vh;padding:1.2rem 1.5rem 3rem;font-family:Sarabun,sans-serif;position:relative}body:before{content:"";pointer-events:none;z-index:0;background:linear-gradient(160deg,#00326e80 0%,#005a8c59 50%,#003c5a73 100%);position:fixed;inset:0}#app{z-index:1;max-width:1280px;margin:0 auto;position:relative}.music-bar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff2e;border:1px solid #ffffff59;border-radius:40px;justify-content:center;align-items:center;gap:.65rem;width:fit-content;margin-bottom:.85rem;margin-left:auto;margin-right:auto;padding:.4rem 1.2rem;display:flex}.music-bar span{color:#fff;letter-spacing:.3px;font-size:13px;font-weight:600}.btn-music{background:var(--pink-main);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:15px;transition:transform .2s,background .2s;display:flex}.btn-music:hover{transform:scale(1.12)}.btn-music.playing{background:var(--teal-main)}.gold-border{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#ffffff2e;border:1px solid #ffffff73;border-radius:24px;padding:2px;box-shadow:0 8px 48px #00000040,0 2px 12px #00000026}.card{-webkit-backdrop-filter:blur(24px);background:#ffffffc7;border:1px solid #ffffffa6;border-radius:23px;padding:1.75rem 2rem 2.25rem;position:relative;overflow:hidden}.card:before{display:none}.header{text-align:center;margin-bottom:1.6rem;padding-top:.85rem}.rid-logo{justify-content:center;align-items:center;gap:.85rem;margin-bottom:.85rem;display:flex}.logo-icon{border:2.5px solid var(--gold-main);background:linear-gradient(135deg,#063a1e,#1a7a42);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;display:flex;box-shadow:0 2px 14px #d4af3766}.logo-icon svg{width:36px;height:36px}.rid-logo-img{object-fit:contain;filter:drop-shadow(0 2px 8px #00000026);width:100px;height:100px;margin:0 auto .9rem;display:block}.org-name{color:#063a1e;font-size:18px;font-weight:800}.org-sub{color:var(--teal-main);font-size:12px;font-weight:500}.songkran-title{color:var(--blue-main);text-shadow:1px 1px #00000014;margin:.2rem 0 .3rem;font-family:Charm,cursive;font-size:2.8rem;line-height:1.15}.org-name-center{color:var(--teal-main);margin-bottom:.6rem;font-size:20px;font-weight:800}.header-desc{color:#444;margin-bottom:.75rem;font-size:14px;font-weight:400;line-height:1.8}.year-badge{background:linear-gradient(135deg, var(--teal-main), var(--blue-main));color:#fff;border:2px solid var(--gold-main);border-radius:20px;margin-top:.15rem;padding:.3rem 1.2rem;font-size:14px;font-weight:700;display:inline-block}.flowers{letter-spacing:.8rem;margin:.6rem 0;font-size:1.7rem}.section-label{color:var(--blue-main);align-items:center;gap:.5rem;margin:1rem 0 .6rem;font-size:14px;font-weight:800;display:flex}.section-label:before{content:"";background:linear-gradient(to bottom, var(--pink-main), var(--orange-main));border-radius:3px;width:5px;height:18px;display:inline-block}.app-layout{flex-direction:column;display:flex}.mgr-grid{grid-template-columns:repeat(4,1fr);gap:.85rem;display:grid}.mgr-grid>.mgr-card:first-child{grid-column:2/span 2}.mgr-grid>.mgr-card:first-child .mgr-poster-wrap{aspect-ratio:1567/1045;height:auto}.mgr-grid>.mgr-card:first-child .mgr-poster-img{object-position:center center}.mgr-grid>.mgr-card:first-child .mgr-label,.mgr-detail{display:none}.mgr-grid>.mgr-card:not(:first-child){grid-column:span 2}.mgr-grid>.mgr-card:not(:first-child) .mgr-poster-wrap{aspect-ratio:1567/1045;height:auto}.mgr-grid>.mgr-card:not(:first-child) .mgr-poster-img{object-position:center center}.mgr-grid>.mgr-card:not(:first-child) .mgr-label{display:none}.mgr-detail-rank{background:var(--gold-main);color:#1a1a2e;border-radius:20px;width:fit-content;padding:4px 16px;font-size:13px;font-weight:800;display:inline-block}.mgr-detail-name{color:var(--text-dark);font-size:2rem;font-weight:800;line-height:1.25}.mgr-detail-pos{color:var(--teal-main);font-size:15px;font-weight:700}.mgr-detail-greeting{color:#444;border-left:3px solid var(--gold-main);margin-top:.25rem;padding-left:1rem;font-size:14.5px;font-style:italic;line-height:1.85}.mgr-card{cursor:pointer;background:#fff;border:2.5px solid #00b4d833;border-radius:14px;transition:transform .22s,box-shadow .22s,border-color .22s;position:relative;overflow:hidden}.mgr-card:hover{border-color:var(--blue-light);transform:translateY(-4px);box-shadow:0 10px 28px #0096c838}.mgr-card.selected{border-color:var(--pink-main);border-width:3px;transform:translateY(-4px);box-shadow:0 10px 28px #d81b7a4d}.mgr-card.blurred{opacity:.4;filter:blur(3px);pointer-events:none;transition:opacity .22s,filter .22s}.check-badge{z-index:10;background:var(--pink-main);color:#fff;opacity:0;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:13px;font-weight:900;transition:opacity .2s,transform .2s;display:flex;position:absolute;top:8px;right:8px;transform:scale(0);box-shadow:0 2px 8px #0003}.mgr-card.selected .check-badge{opacity:1;transform:scale(1)}.mgr-poster-wrap{background:linear-gradient(135deg,#cde8f5,#e8f4fb);width:100%;height:340px;position:relative;overflow:hidden}.mgr-poster-img{object-fit:cover;object-position:top center;width:100%;height:100%;transition:transform .3s;display:block}.mgr-card:hover .mgr-poster-img{transform:scale(1.03)}.mgr-avatar-fallback{background:linear-gradient(135deg, var(--blue-main), var(--teal-main));flex-direction:column;justify-content:center;align-items:center;gap:.5rem;width:100%;height:100%;padding:1rem;display:none}.mgr-avatar-inner{color:#fff;background:#fff3;border:2px solid #fff9;border-radius:50%;justify-content:center;align-items:center;width:70px;height:70px;font-size:18px;font-weight:800;display:flex}.mgr-fb-name{color:#fff;text-align:center;font-size:13px;font-weight:700;line-height:1.4}.mgr-fb-pos{color:#ffffffbf;text-align:center;font-size:11px;line-height:1.4}.mgr-label{background:#00000005;border-top:1px solid #0096c81f;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.55rem .75rem .6rem;display:flex}.mgr-rank-badge{background:var(--teal-main);color:#fff;white-space:nowrap;border-radius:10px;flex-shrink:0;padding:2px 8px;font-size:10px;font-weight:700}.mgr-grid>.mgr-card:first-child .mgr-rank-badge{background:var(--gold-main);color:#1a1a2e}.mgr-name-label{color:var(--text-dark);font-size:12px;font-weight:700;line-height:1.35}.sel-count{color:var(--teal-main);min-height:1.3em;margin-top:.55rem;font-size:13px;font-weight:600}.divider{background:linear-gradient(90deg, transparent, var(--blue-light), var(--pink-light), transparent);border:none;border-radius:2px;height:2px;margin:1.1rem 0}.blessing-grid{grid-template-columns:repeat(3,1fr);gap:.55rem;margin-bottom:.85rem;display:grid}.blessing-btn{color:var(--text-mid);cursor:pointer;text-align:left;background:#f0fbff;border:1.5px solid #00b4d84d;border-radius:12px;padding:.7rem;font-family:Sarabun,sans-serif;font-size:12px;line-height:1.6;transition:all .2s}.blessing-btn:hover{border-color:var(--teal-main);background:#d0f4f8}.blessing-btn.active{background:linear-gradient(135deg, var(--pink-main), var(--orange-main));color:#fff;border-color:var(--gold-main)}.custom-area{width:100%;color:var(--text-dark);resize:vertical;background:#f0fbff;border:2px solid #00b4d84d;border-radius:12px;min-height:80px;padding:.7rem .9rem;font-family:Sarabun,sans-serif;font-size:13px;transition:border .2s}.custom-area:focus{border-color:var(--teal-main);outline:none;box-shadow:0 0 0 3px #00897b1f}.from-input{width:100%;color:var(--text-dark);background:#f0fbff;border:2px solid #00b4d84d;border-radius:12px;margin-top:.4rem;padding:.6rem .9rem;font-family:Sarabun,sans-serif;font-size:13px;transition:border .2s}.from-input:focus{border-color:var(--teal-main);outline:none;box-shadow:0 0 0 3px #00897b1f}.btn-row{gap:.65rem;margin-top:.9rem;display:flex}.btn{cursor:pointer;border:none;border-radius:14px;flex:1;justify-content:center;align-items:center;gap:.45rem;padding:.9rem;font-family:Sarabun,sans-serif;font-size:14px;font-weight:800;transition:all .22s;display:flex}.btn:disabled{opacity:.45;cursor:default}.btn-preview{background:linear-gradient(135deg, var(--pink-main), var(--orange-main));color:#fff;box-shadow:0 4px 16px #d81b7a4d}.btn-preview:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-2px)}.btn-send{background:linear-gradient(135deg, var(--teal-main), var(--blue-main));color:#fff;box-shadow:0 4px 16px #00897b4d}.btn-send:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-2px)}.btn-download{color:#fff;background:linear-gradient(135deg,#6a1b9a,#ab47bc);box-shadow:0 4px 16px #6a1b9a40}.btn-download:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-2px)}.btn-reset{color:var(--teal-main);background:0 0;border:2px solid #00b4d866;flex:none;padding:.9rem 1.1rem;font-weight:700}.btn-reset:hover{background:#f0fbff}.preview-box{border:2px solid var(--gold-main);background:linear-gradient(145deg,#0077b6,#00b4d8 60%,#00897b);border-radius:16px;margin:1rem 0 0;padding:1.3rem 1.2rem;display:none}.preview-box.show{display:block}.preview-header{color:var(--gold-light);text-align:center;letter-spacing:1px;margin-bottom:.75rem;font-size:11px;font-weight:800}.preview-to{color:#cff;text-align:center;margin-bottom:.5rem;font-size:13px}.preview-text{color:#fff;text-align:center;font-size:14px;line-height:1.85}.preview-from{color:var(--gold-light);text-align:right;margin-top:.65rem;font-size:12px}.success-box{text-align:center;border:2px solid var(--teal-main);background:linear-gradient(145deg,#e8f5e9,#f0fbff);border-radius:16px;margin-top:1rem;padding:1.6rem 1rem;display:none}.success-box.show{display:block}.success-icon{margin-bottom:.55rem;font-size:3rem}.success-title{color:var(--teal-main);font-size:17px;font-weight:800}.success-sub{color:var(--text-mid);margin-top:.4rem;font-size:13px;line-height:1.65}.gc-card-root{background:linear-gradient(145deg,#0a4d85,#0f6aa8 55%,#1382bf);width:900px;padding:56px 64px;font-family:Sarabun,sans-serif;position:relative}#greetingCard{position:fixed;top:0;left:-9999px}.gc-border{pointer-events:none;border:2.5px solid #d4af37b3;border-radius:10px;position:absolute;inset:16px}.gc-inner{pointer-events:none;border:1px solid #d4af3766;border-radius:5px;position:absolute;inset:26px}.gc-corner{width:44px;height:44px;position:absolute}.gc-corner.tl{border-top:3px solid #d4af37;border-left:3px solid #d4af37;top:28px;left:28px}.gc-corner.tr{border-top:3px solid #d4af37;border-right:3px solid #d4af37;top:28px;right:28px}.gc-corner.bl{border-bottom:3px solid #d4af37;border-left:3px solid #d4af37;bottom:28px;left:28px}.gc-corner.br{border-bottom:3px solid #d4af37;border-right:3px solid #d4af37;bottom:28px;right:28px}.gc-content{z-index:1;position:relative}.gc-logo-row{border-bottom:2px solid #d4af3773;align-items:center;gap:22px;margin-bottom:28px;padding-bottom:22px;display:flex}.gc-logo-icon{background:#ffffff1f;border:1px solid #d4af3773;border-radius:18px;flex-shrink:0;justify-content:center;align-items:center;width:102px;height:98px;padding:8px;display:flex}.gc-logo-image{object-fit:contain;width:84px;height:auto;max-height:90px;display:block}.gc-logo-icon svg{width:38px;height:44px}.gc-org-name{color:#f5d88b;font-size:22px;font-weight:800}.gc-org-sub{color:#f5d88bc7;margin-top:4px;font-size:14px}.gc-title{color:#f06292;text-shadow:2px 3px #0000004d;text-align:center;margin:0 0 12px;font-family:Charm,cursive;font-size:74px;line-height:1.1}.gc-year{text-align:center;color:#f3cf74;letter-spacing:2px;margin-bottom:18px;font-size:18px}.gc-flowers{text-align:center;letter-spacing:1rem;margin-bottom:28px;font-size:2.4rem}.gc-divider{border:none;border-top:1px solid #d4af3759;margin:0 0 24px}.gc-to{color:#f6dd95;text-align:center;margin-bottom:20px;font-size:18px;font-weight:600}.gc-blessing{color:#f8e3a5;text-align:center;max-width:700px;margin:0 auto 36px;font-size:22px;line-height:1.95}.gc-from{text-align:right;color:#f5d88b;border-top:1px solid #d4af3759;padding-top:20px;font-size:18px}.loading-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:#003c78d9;flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:none;position:fixed;inset:0}.loading-overlay.show{display:flex}.loading-spinner{border:4px solid #d4af374d;border-top-color:var(--gold-main);border-radius:50%;width:52px;height:52px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--gold-light);font-size:15px;font-weight:700}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{background:#fffffff2;border:1px solid #fffc;border-radius:20px;width:100%;max-width:800px;max-height:90vh;padding:2rem;position:relative;overflow-y:auto;box-shadow:0 20px 60px #00000059}.modal-close{cursor:pointer;color:var(--text-dark);background:0 0;border:none;justify-content:center;align-items:center;width:40px;height:40px;font-size:32px;transition:transform .2s;display:flex;position:absolute;top:1rem;right:1rem}.modal-close:hover{transform:rotate(90deg)}.modal-header{text-align:center;color:var(--text-dark);margin-bottom:1.5rem;font-size:18px;font-weight:700}.modal-card-preview{justify-content:center;max-height:62vh;margin-bottom:2rem;padding:0;display:flex;overflow-y:auto}.modal-card-preview>*{width:100%;max-width:680px;box-shadow:0 10px 30px #00000026}.modal-actions{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.modal-greet-card{background:linear-gradient(145deg,#0a4d85,#0f6aa8 55%,#1382bf);border:2px solid #d4af3780;border-radius:22px;width:100%;max-width:680px;padding:1.1rem}.modal-greet-header{text-align:center;color:#f5d88b;letter-spacing:.3px;margin-bottom:.9rem;font-weight:800}.modal-greet-body{align-items:stretch;gap:1rem;display:flex}.modal-greet-photo-wrap{aspect-ratio:600/842;background:linear-gradient(135deg,#0a4d85,#1382bf);border:2px solid #d4af378c;border-radius:14px;justify-content:center;align-items:center;width:180px;min-width:180px;display:flex;overflow:hidden}.modal-greet-photo{object-fit:contain;width:100%;height:100%}.modal-greet-photo-fallback{color:#fff;justify-content:center;align-items:center;width:100%;height:100%;font-size:1.6rem;font-weight:800;display:none}.modal-greet-text{color:#f6dd95;text-align:center;background:#0b3a6759;border:1px solid #d4af3773;border-radius:14px;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.25rem;min-width:0;margin:0;padding:.9rem 1rem;display:flex}.modal-greet-to{color:#f6dd95;text-align:center;width:100%;margin:0;font-size:1.05rem;font-weight:800}.modal-greet-message{white-space:normal;overflow-wrap:anywhere;word-break:break-word;text-align:center;width:100%;margin:0;font-size:.98rem;line-height:1.4}.modal-greet-from{text-align:center;color:#f5d88b;width:100%;margin:0;font-size:.88rem;font-weight:700}@media (width<=1100px){#app{max-width:100%}.mgr-grid{grid-template-columns:repeat(4,1fr)}.mgr-grid>.mgr-card:not(:first-child) .mgr-poster-wrap{aspect-ratio:1567/1045;height:auto}}@media (width<=768px){body{padding:1rem .85rem 2.5rem}.card{padding:1.4rem 1.1rem 1.75rem}.songkran-title{font-size:2.1rem}.org-name-center{font-size:16px}.header-desc{font-size:13px}.rid-logo-img{width:80px;height:80px}.music-bar{padding:.35rem .9rem}.music-bar span{font-size:12px}.mgr-grid{grid-template-columns:repeat(2,1fr);gap:.65rem}.mgr-poster-wrap{height:240px}.mgr-grid>.mgr-card:first-child{grid-column:1/-1}.mgr-grid>.mgr-card:first-child .mgr-poster-wrap,.mgr-grid>.mgr-card:not(:first-child) .mgr-poster-wrap{aspect-ratio:1567/1045;height:auto}.blessing-grid{grid-template-columns:1fr 1fr}.btn{padding:.78rem;font-size:13px}.btn-reset{padding:.78rem .85rem}.modal-greet-body{flex-direction:column}.modal-greet-photo-wrap{width:min(72%,220px);min-width:0;margin:0 auto}.modal-greet-text{width:100%}}@media (width<=480px){body{padding:.65rem .6rem 2rem}.gold-border{border-radius:18px}.card{border-radius:17px;padding:1.1rem .85rem 1.4rem}.rid-logo-img{width:68px;height:68px}.songkran-title{font-size:1.65rem}.org-name-center{font-size:15px}.header-desc{font-size:12px;line-height:1.7}.year-badge{padding:.25rem .9rem;font-size:12px}.music-bar span{display:none}.mgr-grid>.mgr-card:first-child{grid-column:1/-1}.mgr-grid>.mgr-card:first-child .mgr-poster-wrap{aspect-ratio:1567/1045;height:auto}.mgr-grid>.mgr-card:not(:first-child){grid-column:1/-1}.mgr-grid>.mgr-card:not(:first-child) .mgr-poster-wrap{aspect-ratio:1567/1045;height:auto}.mgr-poster-wrap{height:180px}.mgr-name-label{font-size:11px}.mgr-rank-badge{padding:1px 6px;font-size:9px}.section-label{font-size:12.5px}.blessing-btn{padding:.55rem;font-size:11px}.from-input{font-size:12px}.btn{padding:.72rem;font-size:12.5px}.modal-greet-photo-wrap{width:min(76%,185px)}.modal-greet-message{font-size:.92rem;line-height:1.38}.preview-to{font-size:11.5px}.preview-text{font-size:12.5px}.sel-count{font-size:11.5px}}
