*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--gd:#1a5c2a;--gm:#2d8a47;--gb:#3db85f;--gl:#a8e6b8;--gold:#f0b429;--goldd:#c8841a;--goldl:#fdeaa0;--cream:#fdf9ef;--brown:#5c3d1e}html{scroll-behavior:smooth}body{font-family:Inter,sans-serif;background:var(--gd);overflow-x:hidden;-webkit-font-smoothing:antialiased}.app,body{min-height:100vh}.app{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;padding:1.5rem 1rem 5rem}#bg-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}.hdr{text-align:center;margin-bottom:1.8rem}.hdr-title{font-family:JetBrains Mono,monospace;font-size:clamp(2rem,6vw,3.4rem);font-weight:900;color:var(--gold);text-shadow:0 2px 8px rgba(0,0,0,.4);letter-spacing:.05em;line-height:1.1}.hdr-sub{font-size:.95rem;color:var(--gl);margin-top:.4rem;letter-spacing:.1em;text-transform:uppercase}.shamrow{font-size:1.4rem;letter-spacing:.25em;margin-top:.3rem}.card{background:var(--cream);border-radius:20px;padding:1.75rem;width:100%;max-width:620px;box-shadow:0 8px 40px rgba(0,0,0,.35),0 0 0 3px var(--gold);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--gm),var(--gold),var(--gm))}.steps{display:flex;margin-bottom:1.5rem;border-radius:12px;overflow:hidden;border:2px solid var(--gl)}.step-item{flex:1 1;padding:.55rem .2rem;text-align:center;font-family:Inter,sans-serif;font-size:clamp(.58rem,1.5vw,.68rem);font-weight:600;letter-spacing:.01em;background:#d4edda;color:#145a25;cursor:pointer;transition:all .2s;border-right:1px solid #a8e6b8}.step-item:last-child{border-right:none}.step-item.active{background:#0f3a1e;color:#f0b429;font-weight:700}.step-item.done{background:#1e7a38;color:#fff}.step-item.locked{background:#eaf7ee;color:#5a9a6a;cursor:default}.sec{font-family:Inter,sans-serif;font-size:.78rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--gd);margin-bottom:.65rem}.mode-toggle{display:grid;grid-template-columns:1fr 1fr;grid-gap:.75rem;gap:.75rem;margin-bottom:1.4rem}.mode-card{border:2px solid var(--gl);border-radius:14px;padding:1.1rem .9rem;text-align:center;cursor:pointer;background:#fff;transition:all .2s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.mode-card:hover{border-color:var(--gm);transform:translateY(-2px)}.mode-card.selected{border-color:var(--gd);background:#eaf5ed;box-shadow:0 0 0 2px var(--gm) inset}.mode-icon{font-size:2.2rem;margin-bottom:.4rem}.mode-name{font-family:Inter,sans-serif;font-size:.78rem;font-weight:700;color:var(--gd)}.mode-desc{font-size:.72rem;color:#666;margin-top:.2rem;line-height:1.3}.reveal-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:.7rem;gap:.7rem;margin-bottom:1.4rem}.rev-opt{border:2px solid var(--gl);border-radius:14px;padding:.9rem .75rem;text-align:center;cursor:pointer;background:#fff;transition:all .2s;-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative}.rev-opt:hover:not(.locked){border-color:var(--gm);transform:translateY(-2px)}.rev-opt.selected{border-color:var(--gd);background:#eaf5ed;box-shadow:0 0 0 2px var(--gm) inset}.rev-opt.locked{opacity:.38;cursor:not-allowed;filter:grayscale(.7)}.rev-badge{position:absolute;top:6px;right:8px;font-size:.58rem;font-weight:700;letter-spacing:.04em;padding:2px 6px;border-radius:20px;background:var(--gold);color:var(--gd)}.rev-icon{font-size:1.8rem;margin-bottom:.3rem}.rev-name{font-family:Inter,sans-serif;font-size:.72rem;font-weight:700;color:var(--gd)}.rev-sub{font-size:.65rem;color:#777;margin-top:.15rem}.igroup{margin-bottom:1.2rem}input[type=text],textarea{width:100%;padding:.65rem .9rem;border:2px solid var(--gl);border-radius:10px;font-family:Lato,sans-serif;font-size:.92rem;background:#fff;color:var(--gd);transition:border-color .2s;outline:none;-webkit-appearance:none}input[type=text]:focus,textarea:focus{border-color:var(--gm)}textarea{min-height:62px;resize:vertical}hr.div{border:none;border-top:1.5px solid var(--gl);margin:1.3rem 0}.msg-row{display:flex;gap:.5rem;align-items:flex-start;margin-bottom:.5rem}.msg-row textarea{flex:1 1;min-height:52px}.rm-btn{border:none;font-size:1.1rem;color:#c0392b;flex-shrink:0}.add-btn,.rm-btn{background:none;cursor:pointer;padding:.5rem}.add-btn{width:100%;border:2px dashed var(--gl);border-radius:10px;font-family:Lato,sans-serif;font-size:.88rem;color:var(--gm);font-weight:700;transition:all .2s}.add-btn:hover{border-color:var(--gm);background:#f0faf3}.theme-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));grid-gap:.55rem;gap:.55rem;margin-bottom:1.2rem}.th-btn{padding:.4rem .85rem;border:2px solid var(--gl);border-radius:20px;font-family:Lato,sans-serif;font-size:.82rem;cursor:pointer;background:#fff;color:var(--gd);transition:all .2s;font-weight:700;text-align:center}.th-btn:hover{border-color:var(--gm)}.th-btn.selected{background:var(--gd);color:#fff;border-color:var(--gd)}.nav-row{display:flex;gap:.75rem;margin-top:1rem}.btn-back{flex:0 0 auto;padding:.8rem 1.3rem;background:#fff;border:2px solid var(--gl);border-radius:12px;font-family:Lato,sans-serif;font-weight:700;font-size:.88rem;color:var(--gm);cursor:pointer;transition:all .2s}.btn-back:hover{border-color:var(--gm)}.btn-next{flex:1 1;padding:.85rem;background:linear-gradient(135deg,var(--goldd),var(--gold));border:none;border-radius:12px;font-family:Inter,sans-serif;font-size:.95rem;font-weight:700;color:var(--gd);cursor:pointer;transition:all .2s}.btn-next:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(200,132,26,.5)}.btn-next:active{transform:translateY(0)}.prev-frame{background:linear-gradient(135deg,#0f3a1e,#1a5c2a);border-radius:16px;padding:1.25rem;margin-bottom:1rem}.share-box{background:#e8f5ec;border:2px solid var(--gm);border-radius:14px;padding:1.25rem;text-align:center;margin-top:1rem}.share-title{font-family:Cinzel,serif;font-size:.95rem;font-weight:700;color:var(--gd);margin-bottom:.65rem}.share-url{background:#fff;border:2px solid var(--gl);border-radius:8px;padding:.55rem .75rem;font-size:.75rem;color:var(--gd);word-break:break-all;margin-bottom:.5rem;text-align:left;line-height:1.5}.expiry-note{font-size:.72rem;color:#888;margin-bottom:.75rem;font-style:italic}.copy-btn{padding:.55rem 1.4rem;background:var(--gd);color:#fff;border:none;border-radius:10px;font-family:Lato,sans-serif;font-weight:700;cursor:pointer;font-size:.88rem;transition:all .2s;margin-right:.5rem}.copy-btn:hover{background:var(--gm)}.share-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-top:.25rem}.email-btn{padding:.55rem 1.4rem;background:#fff;color:var(--gd);border:2px solid var(--gm);border-radius:10px;font-family:Inter,sans-serif;font-weight:700;cursor:pointer;font-size:.88rem;transition:all .2s;text-decoration:none;display:inline-block}.email-btn:hover{background:var(--gl)}.rec-view{width:100%;max-width:680px}.rec-hdr{text-align:center;margin-bottom:1.75rem}.rec-from{font-family:Lato,sans-serif;color:var(--gl);font-size:.9rem;margin-bottom:.2rem}.rec-name{font-family:Cinzel,serif;font-size:clamp(1.8rem,5vw,2.8rem);font-weight:900;color:var(--gold);text-shadow:0 2px 6px rgba(0,0,0,.3)}.sc-wrap{padding:1.25rem}.sc-hint{color:var(--gd);font-size:.88rem;text-align:center;margin-bottom:1rem}.sc-grid{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center}.sc-tile{flex-grow:0;flex-shrink:0;flex-basis:calc(50% - .45rem);min-width:140px;min-height:130px;position:relative}.sc-msg{display:flex;align-items:center;justify-content:center;padding:.85rem;font-family:Inter,sans-serif;font-size:.88rem;color:var(--gd);text-align:center;line-height:1.5;pointer-events:none;font-weight:500}.sc-cvs,.sc-msg{position:absolute;inset:0}.sc-cvs{width:100%;height:100%;touch-action:none}.env-wrap{display:flex;flex-direction:column;align-items:center;padding:1.5rem}.env-hint{font-size:.88rem;margin-top:.75rem}.env-hint,.env-msg{color:var(--gd);text-align:center}.env-msg{background:#fff;border-radius:14px;padding:1.5rem;max-width:400px;width:100%;margin-top:1.25rem;box-shadow:0 8px 30px rgba(0,0,0,.25);font-family:Lato,sans-serif;font-size:1rem;line-height:1.7;display:none}.env-sig{margin-top:.75rem;font-style:italic;color:var(--gm);font-size:.88rem}.letter-wrap{max-width:340px;display:flex;flex-direction:column;align-items:center;margin-top:1rem}.letter-paper,.letter-wrap{position:relative;width:100%}.letter-paper{background:#fff;border:1.5px solid #e0d8c0;border-radius:4px 4px 8px 8px;padding:1.4rem 1.6rem;box-shadow:0 8px 30px rgba(0,0,0,.2);font-family:Inter,sans-serif;font-size:.95rem;color:var(--gd);line-height:1.7;text-align:center;transform:translateY(60px);opacity:0;transition:transform .7s cubic-bezier(.22,1,.36,1),opacity .5s ease}.letter-paper.emerged{transform:translateY(0);opacity:1}.letter-paper:before{content:"";position:absolute;top:0;left:10%;right:10%;height:3px;background:linear-gradient(90deg,transparent,#c8841a,transparent);border-radius:2px}.letter-lines{margin:.75rem 0;text-align:left}.letter-line{height:1px;background:#e8e0d0;margin:.55rem 0;border-radius:1px}.lep-stage{position:relative;width:100%;height:290px;overflow:hidden;border-radius:16px 16px 0 0}.lep-sky{position:absolute;inset:0;background:linear-gradient(180deg,#0a2a3a,#1a5c2a)}.lep-ground{position:absolute;bottom:0;left:0;right:0;height:52px;background:var(--gm)}.lep-rainbow{position:absolute;bottom:96px;right:5%;width:95%;height:130px;border-radius:50% 50% 0 0/100% 100% 0 0;opacity:0;transition:opacity 1.1s;pointer-events:none;transform-origin:bottom right;box-shadow:0 -8px 0 0 rgba(255,0,0,.7),0 -16px 0 0 rgba(255,165,0,.7),0 -24px 0 0 rgba(255,240,0,.7),0 -32px 0 0 rgba(0,210,0,.7),0 -40px 0 0 rgba(0,100,255,.7),0 -48px 0 0 rgba(148,0,211,.7)}.lep-char{bottom:48px;font-size:2.8rem;-webkit-user-select:none;-moz-user-select:none;user-select:none;cursor:pointer;transition:none}.lep-char,.lep-pot{position:absolute;z-index:2}.lep-pot{bottom:44px;right:5%;width:58px;height:50px}.lep-pot:before{content:"";position:absolute;top:0;left:-6px;right:-6px;height:13px;background:linear-gradient(180deg,#ffe880,#c8841a);border-radius:8px;box-shadow:0 2px 5px rgba(0,0,0,.35)}.lep-pot:after{content:"";position:absolute;top:9px;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 32% 28%,#fff0a0 0,#f0b429 30%,#c8841a 65%,#8a4800 100%);border-radius:8px 8px 50% 50%/8px 8px 62% 62%;box-shadow:0 5px 0 #6a3800,0 8px 14px rgba(0,0,0,.4),inset 0 2px 4px rgba(255,255,200,.25)}.lep-bubble{position:absolute;bottom:105px;right:4%;background:#fff;border-radius:12px;padding:.8rem 1rem;font-family:Lato,sans-serif;font-size:.82rem;color:var(--gd);max-width:175px;text-align:center;box-shadow:0 4px 14px rgba(0,0,0,.2);display:none;line-height:1.5;z-index:3}.lep-coins{flex-wrap:wrap;gap:.55rem;padding:.9rem 1rem .6rem}.coin,.lep-coins{display:flex;justify-content:center}.coin{background:radial-gradient(circle at 30% 30%,#fff8d6,#f0b429 40%,#c8841a 80%,#9a5f0a);border-radius:50%;width:64px;height:64px;align-items:center;cursor:not-allowed;box-shadow:0 4px 0 #7a4800,0 6px 12px rgba(0,0,0,.35),inset 0 1px 3px hsla(0,0%,100%,.5);transition:transform .2s,box-shadow .2s;flex-shrink:0;-webkit-user-select:none;-moz-user-select:none;user-select:none;position:relative;overflow:hidden;border:2px solid #e8a020}.coin:before{content:"";position:absolute;inset:4px;border-radius:50%;border:1.5px solid hsla(0,0%,100%,.35)}.coin.unlocked{cursor:pointer;animation:coinGlow .8s ease-in-out infinite alternate}.coin.unlocked:hover{transform:scale(1.12) translateY(-2px);box-shadow:0 6px 0 #7a4800,0 10px 20px rgba(0,0,0,.4)}.coin.revealed{background:#fff;cursor:pointer;box-shadow:0 2px 0 #a8e6b8,0 4px 12px rgba(0,0,0,.2);border:2px solid var(--gold);width:auto;height:auto;min-width:80px;max-width:160px;min-height:64px;border-radius:14px;overflow:visible;flex-shrink:1}.coin.revealed:before{display:none}.coin-inner{pointer-events:none;display:flex;flex-direction:column;align-items:center;justify-content:center}.coin-shamrock{font-size:1.5rem;line-height:1}.coin-revealed-text{font-family:Inter,sans-serif;font-weight:500;color:var(--gd);text-align:center;line-height:1.4;padding:.55rem .6rem;word-break:break-word}@keyframes coinGlow{0%{box-shadow:0 4px 0 #7a4800,0 6px 12px rgba(0,0,0,.35),0 0 8px rgba(240,180,41,.4)}to{box-shadow:0 4px 0 #7a4800,0 6px 16px rgba(0,0,0,.35),0 0 20px rgba(240,180,41,.8)}}.lep-hint{text-align:center;color:var(--gd);font-size:.85rem;padding:.5rem 1rem .8rem}.hat-stage{display:flex;flex-direction:column;align-items:center;padding:1.5rem}.hat-wrap{position:relative;cursor:pointer;display:inline-block}.hat-emoji{font-size:6rem;display:block;transition:transform .3s}.hat-wrap:hover .hat-emoji{transform:scale(1.07) rotate(-4deg)}.hat-stars{position:absolute;top:-8px;left:50%;transform:translateX(-50%);font-size:1.2rem;opacity:0;transition:opacity .3s;pointer-events:none;white-space:nowrap}.hat-scroll{background:#fef9e7;border:3px solid #c8a96e;border-top:none;border-bottom:none;padding:0;width:300px;max-width:88vw;text-align:center;margin-top:0;font-family:Inter,sans-serif;color:var(--brown);line-height:1.6;box-shadow:0 6px 24px rgba(0,0,0,.25);display:none;position:relative}.hat-scroll:before{content:"";display:block;height:22px;background:radial-gradient(ellipse at 50% 0,#d4a84b 0,#c8841a 100%);border-radius:4px 4px 0 0;box-shadow:0 3px 6px rgba(0,0,0,.2)}.hat-scroll:after{content:"";display:block;height:22px;background:radial-gradient(ellipse at 50% 100%,#d4a84b 0,#c8841a 100%);border-radius:0 0 4px 4px;box-shadow:0 -3px 6px rgba(0,0,0,.2)}.hat-scroll-inner{padding:1.1rem 1.4rem}.hat-hint{color:var(--gd);font-size:.85rem;margin-top:.65rem;text-align:center}.hat-counter{font-size:.7rem;color:var(--gm);margin-top:.5rem}.expired-wrap{display:flex;flex-direction:column;align-items:center;width:100%;max-width:400px}.expired-box{background:var(--cream);border-radius:20px;padding:2.5rem;text-align:center;box-shadow:0 8px 30px rgba(0,0,0,.3),0 0 0 3px var(--gold);width:100%}.expired-icon{font-size:3rem;margin-bottom:.75rem}.expired-title{font-family:Cinzel,serif;font-size:1.4rem;font-weight:700;color:var(--gd);margin-bottom:.5rem}.expired-sub{font-size:.9rem;color:#666;line-height:1.6}.footer{position:fixed;bottom:0;left:0;right:0;text-align:center;padding:.75rem 1rem;background:rgba(10,40,18,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid rgba(168,230,184,.2);z-index:100;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem}.footer-logo{height:28px;width:auto;object-fit:contain;filter:brightness(0) invert(1)}.footer-text{font-family:Lato,sans-serif;font-size:.75rem;color:var(--gl);opacity:.8}.footer-link{color:var(--gold);text-decoration:none;font-weight:700;transition:opacity .2s}.footer-link:hover{opacity:.8}.glitter-p{position:fixed;pointer-events:none;z-index:999;font-size:1.1rem;animation:gfall 1.3s ease-out forwards}@keyframes gfall{0%{transform:translateY(-15px) rotate(0deg);opacity:1}to{transform:translateY(90px) rotate(380deg);opacity:0}}@keyframes floatIn{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes lepBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-9px)}}@keyframes unroll{0%{max-height:0;opacity:0}to{max-height:320px;opacity:1}}.anim-in{animation:floatIn .5s ease both}@media (max-width:480px){.card{padding:1.25rem 1rem;border-radius:16px}.mode-toggle{grid-template-columns:1fr 1fr;gap:.5rem}.mode-card{padding:.85rem .6rem}.reveal-grid{grid-template-columns:1fr 1fr;gap:.5rem}.steps{font-size:.55rem}.step-item{padding:.45rem .15rem}.sc-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.7rem}.coin{width:52px;height:52px;font-size:.58rem}.coin.revealed{width:auto;height:auto;min-width:72px;max-width:140px;min-height:52px}.lep-stage{height:280px}.lep-char{font-size:2.4rem}.lep-pot{font-size:2.2rem}.nav-row{flex-direction:column}.btn-back{flex:none}.hat-emoji{font-size:5rem}.hat-scroll{width:280px}.footer{flex-direction:column;gap:.3rem;padding:.6rem}.footer-logo{height:22px}}@media (max-width:360px){.hdr-title{font-size:1.7rem}}