| <!DOCTYPE html> |
| <html lang="ko"> |
| <head> |
| <meta charset="UTF-8"> |
| <meta name="viewport" content="width=device-width, initial-scale=1.0"> |
| <title>μ κ·ΌλΉ β€ μ μ°¬μ° κ²°νΌμ μ²μ²©μ₯</title> |
| <script src="https://cdn.tailwindcss.com"></script> |
| <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css"> |
| <style> |
| @import url('https://fonts.googleapis.com/css2?family=Nanum+Myeongjo:wght@400;700;800&family=Noto+Serif+KR:wght@300;400;500;600;700&display=swap'); |
| |
| body { |
| font-family: 'Noto Serif KR', serif; |
| background-color: #faf6f2; |
| color: #5a4a3f; |
| overflow-x: hidden; |
| } |
| |
| .title-font { |
| font-family: 'Nanum Myeongjo', serif; |
| } |
| |
| .heart-animation { |
| animation: heartbeat 1.5s ease-in-out infinite; |
| } |
| |
| @keyframes heartbeat { |
| 0% { transform: scale(1); } |
| 25% { transform: scale(1.1); } |
| 50% { transform: scale(1); } |
| 75% { transform: scale(1.1); } |
| 100% { transform: scale(1); } |
| } |
| |
| .floating { |
| animation: floating 3s ease-in-out infinite; |
| } |
| |
| @keyframes floating { |
| 0% { transform: translateY(0px); } |
| 50% { transform: translateY(-15px); } |
| 100% { transform: translateY(0px); } |
| } |
| |
| .petal { |
| position: absolute; |
| background-size: contain; |
| background-repeat: no-repeat; |
| opacity: 0.7; |
| animation: falling linear infinite; |
| z-index: 0; |
| } |
| |
| @keyframes falling { |
| 0% { |
| transform: translate(0, -10vh) rotate(0deg); |
| opacity: 0; |
| } |
| 10% { |
| opacity: 1; |
| } |
| 90% { |
| opacity: 1; |
| } |
| 100% { |
| transform: translate(calc(var(--random-x) * 1vw), 100vh) rotate(360deg); |
| opacity: 0; |
| } |
| } |
| |
| .envelope { |
| position: relative; |
| background: #f8e8e0; |
| border-radius: 8px; |
| box-shadow: 0 10px 30px rgba(0,0,0,0.1); |
| transition: all 0.3s ease; |
| } |
| |
| .envelope:before { |
| content: ''; |
| position: absolute; |
| top: 0; |
| right: 0; |
| border-width: 0 40px 40px 0; |
| border-style: solid; |
| border-color: #e8d5cc transparent; |
| border-radius: 0 8px 0 0; |
| } |
| |
| .envelope:hover { |
| transform: translateY(-5px); |
| box-shadow: 0 15px 35px rgba(0,0,0,0.15); |
| } |
| |
| .gold-text { |
| background: linear-gradient(to right, #d4af37, #f9d423, #d4af37); |
| -webkit-background-clip: text; |
| background-clip: text; |
| color: transparent; |
| } |
| </style> |
| </head> |
| <body class="relative overflow-x-hidden"> |
| |
| <div id="petals-container"></div> |
| |
| |
| <div class="max-w-md mx-auto px-4 py-8 relative z-10"> |
| |
| <div class="text-center mb-12"> |
| <div class="text-sm gold-text font-medium mb-2">WEDDING INVITATION</div> |
| <h1 class="title-font text-4xl font-bold mb-4 text-rose-800">μ κ·ΌλΉ & μ μ°¬μ°</h1> |
| <div class="flex justify-center items-center"> |
| <div class="w-16 h-px bg-rose-300"></div> |
| <div class="mx-4 text-rose-500 heart-animation"><i class="fas fa-heart"></i></div> |
| <div class="w-16 h-px bg-rose-300"></div> |
| </div> |
| <p class="mt-4 text-sm">2025λ
4μ 16μΌ μ€ν 1μ 30λΆ</p> |
| <p class="text-sm">κ·Έλλ ννΌ νΈν
3μΈ΅ ν¬λ¦¬μ€ν λ³Όλ£Έ</p> |
| </div> |
| |
| |
| <div class="relative mb-12 rounded-xl overflow-hidden shadow-lg"> |
| <div class="absolute inset-0 bg-gradient-to-t from-black/50 to-transparent z-10"></div> |
| <img src="https://images.unsplash.com/photo-1519225421980-715cb0215aed?ixlib=rb-4.0.3&ixid=M3wxMjA3fDB8MHxwaG90by1wYWdlfHx8fGVufDB8fHx8fA%3D%3D&auto=format&fit=crop&w=1470&q=80" alt="컀ν μ¬μ§" class="w-full h-80 object-cover"> |
| <div class="absolute bottom-0 left-0 right-0 p-6 z-20 text-white text-center"> |
| <p class="text-sm mb-1">μλ‘λ₯Ό λ§λ μ§ 1,825μΌμ§Έ</p> |
| <h2 class="title-font text-2xl font-bold">μ°λ¦¬μ μ¬λμ΄ κ½νΌλ λ </h2> |
| </div> |
| </div> |
| |
| |
| <div class="envelope p-8 mb-12"> |
| <h3 class="title-font text-xl font-bold mb-6 text-center text-rose-700">μ΄λμ λ§μ</h3> |
| <div class="text-sm leading-relaxed text-center"> |
| <p class="mb-4">μ¬λνλ κ°μ‘±κ³Ό μΉκ΅¬ μ¬λ¬λΆ</p> |
| <p class="mb-4">μ ν¬ λ μ¬λμ΄ μλ‘μ λ§μμ νμΈνκ³ <br>ν¨κ» μΈμμ κ±Έμ΄κ°κΈ°λ‘ κ²°μ¬νμ΅λλ€.</p> |
| <p class="mb-4">μ€λ μκ° μ ν¬λ₯Ό μκ»΄μ£Όμκ³ μ¬λν΄μ£Όμ μ¬λ¬λΆκ»<br>μ΄ μμ€ν μ리λ₯Ό ν¨κ» νμμ΄<br>μ ν¬μ μλ‘μ΄ μΆλ°μ μΆλ³΅ν΄ μ£Όμλ©΄ κ°μ¬νκ² μ΅λλ€.</p> |
| <p>μ κ·ΌλΉ Β· μ μ°¬μ° λλ¦Ό</p> |
| </div> |
| </div> |
| |
| |
| <div class="grid grid-cols-1 md:grid-cols-2 gap-6 mb-12"> |
| <div class="envelope p-6 text-center"> |
| <div class="text-rose-600 mb-3"><i class="fas fa-calendar-alt text-2xl"></i></div> |
| <h4 class="title-font font-bold mb-2">λ μ§μ μκ°</h4> |
| <p class="text-sm">2025λ
4μ 16μΌ</p> |
| <p class="text-sm">μ€ν 1μ 30λΆ</p> |
| </div> |
| |
| <div class="envelope p-6 text-center"> |
| <div class="text-rose-600 mb-3"><i class="fas fa-map-marker-alt text-2xl"></i></div> |
| <h4 class="title-font font-bold mb-2">μ₯μ</h4> |
| <p class="text-sm">κ·Έλλ ννΌ νΈν
</p> |
| <p class="text-sm">3μΈ΅ ν¬λ¦¬μ€ν λ³Όλ£Έ</p> |
| <button onclick="openMap()" class="mt-2 text-xs text-rose-500 underline">μ§λ 보기</button> |
| </div> |
| </div> |
| |
| |
| <div class="mb-12"> |
| <h3 class="title-font text-xl font-bold mb-6 text-center text-rose-700">μ°λ¦¬μ μΆμ΅</h3> |
| <div class="grid grid-cols-3 gap-2"> |
| <div class="rounded-lg overflow-hidden h-24 bg-rose-100 flex items-center justify-center"> |
| <i class="fas fa-image text-rose-300 text-xl"></i> |
| </div> |
| <div class="rounded-lg overflow-hidden h-24 bg-amber-100 flex items-center justify-center"> |
| <i class="fas fa-image text-amber-300 text-xl"></i> |
| </div> |
| <div class="rounded-lg overflow-hidden h-24 bg-sky-100 flex items-center justify-center"> |
| <i class="fas fa-image text-sky-300 text-xl"></i> |
| </div> |
| <div class="rounded-lg overflow-hidden h-24 bg-emerald-100 flex items-center justify-center"> |
| <i class="fas fa-image text-emerald-300 text-xl"></i> |
| </div> |
| <div class="rounded-lg overflow-hidden h-24 bg-violet-100 flex items-center justify-center"> |
| <i class="fas fa-image text-violet-300 text-xl"></i> |
| </div> |
| <div class="rounded-lg overflow-hidden h-24 bg-pink-100 flex items-center justify-center"> |
| <i class="fas fa-image text-pink-300 text-xl"></i> |
| </div> |
| </div> |
| </div> |
| |
| |
| <div class="envelope p-8 mb-12"> |
| <h3 class="title-font text-xl font-bold mb-6 text-center text-rose-700">μ°Έμ μμ¬ μ λ¬</h3> |
| <div class="flex justify-center space-x-4"> |
| <button onclick="rsvp(true)" class="px-6 py-2 bg-rose-600 text-white rounded-full text-sm hover:bg-rose-700 transition">μ°Έμν©λλ€</button> |
| <button onclick="rsvp(false)" class="px-6 py-2 bg-gray-300 text-gray-700 rounded-full text-sm hover:bg-gray-400 transition">λΆμ°Έν©λλ€</button> |
| </div> |
| </div> |
| |
| |
| <div class="envelope p-8 mb-12"> |
| <h3 class="title-font text-xl font-bold mb-6 text-center text-rose-700">μΆν λ©μμ§</h3> |
| <textarea class="w-full p-3 border border-rose-200 rounded-lg focus:outline-none focus:ring-2 focus:ring-rose-300 mb-4" rows="3" placeholder="μ λ μ λΆμκ² μΆνμ λ§μ λ¨κ²¨μ£ΌμΈμ"></textarea> |
| <button class="w-full py-2 bg-rose-600 text-white rounded-lg text-sm hover:bg-rose-700 transition">λ©μμ§ λ³΄λ΄κΈ°</button> |
| </div> |
| |
| |
| <div class="text-center mb-12"> |
| <div class="floating inline-block mb-6"> |
| <img src="https://cdn-icons-png.flaticon.com/512/7437/7437891.png" alt="μ¨λ© 벨" class="w-16 h-16"> |
| </div> |
| <h3 class="title-font text-2xl font-bold mb-4 gold-text">ν¨κ»ν΄ μ£Όμ
μ κ°μ¬ν©λλ€</h3> |
| <p class="text-sm">μ¬λ¬λΆμ λ°λ»ν μΆλ³΅μ΄<br>μ ν¬μ μλ μ λμ± λΉλκ² ν κ²μ
λλ€.</p> |
| </div> |
| </div> |
| |
| |
| <div class="fixed bottom-6 right-6 z-20"> |
| <button onclick="playMusic()" class="w-12 h-12 rounded-full bg-rose-600 text-white shadow-lg flex items-center justify-center hover:bg-rose-700 transition"> |
| <i id="music-icon" class="fas fa-music"></i> |
| </button> |
| </div> |
| |
| <script> |
| |
| function createPetals() { |
| const container = document.getElementById('petals-container'); |
| const petalCount = 15; |
| |
| for (let i = 0; i < petalCount; i++) { |
| const petal = document.createElement('div'); |
| petal.className = 'petal'; |
| |
| |
| const petalTypes = ['πΈ', 'πΉ', 'πΊ', 'π»', 'πΌ', 'π΅οΈ']; |
| const randomPetal = petalTypes[Math.floor(Math.random() * petalTypes.length)]; |
| petal.textContent = randomPetal; |
| |
| |
| const size = Math.random() * 20 + 10; |
| petal.style.fontSize = `${size}px`; |
| petal.style.left = `${Math.random() * 100}vw`; |
| petal.style.top = `-${size}px`; |
| petal.style.setProperty('--random-x', Math.random() * 20 - 10); |
| petal.style.animationDuration = `${Math.random() * 5 + 5}s`; |
| petal.style.animationDelay = `${Math.random() * 5}s`; |
| |
| container.appendChild(petal); |
| } |
| } |
| |
| |
| function openMap() { |
| alert("μ§λ μ±μ΄ μ΄λ¦½λλ€. κ·Έλλ ννΌ νΈν
μμΉλ₯Ό νμν©λλ€."); |
| |
| } |
| |
| |
| function rsvp(attending) { |
| if (attending) { |
| alert("μ°Έμ μμ¬λ₯Ό μλ €μ£Όμ
μ κ°μ¬ν©λλ€! κΈ°μ λ§μμΌλ‘ κΈ°λ€λ¦¬κ² μ΅λλ€."); |
| } else { |
| alert("μμ½μ§λ§ λ€μμ κΌ λ΅ μ μκΈ°λ₯Ό λ°λλλ€. κ°μ¬ν©λλ€."); |
| } |
| } |
| |
| |
| let isPlaying = false; |
| function playMusic() { |
| isPlaying = !isPlaying; |
| const icon = document.getElementById('music-icon'); |
| |
| if (isPlaying) { |
| icon.classList.remove('fa-music'); |
| icon.classList.add('fa-pause'); |
| alert("μ¨λ© μμ
μ΄ μ¬μλ©λλ€. (μ€μ ꡬνμμλ μ€λμ€ μ¬μ μ½λλ‘ λ³κ²½)"); |
| } else { |
| icon.classList.remove('fa-pause'); |
| icon.classList.add('fa-music'); |
| alert("μμ
μ΄ μ μ§λμμ΅λλ€."); |
| } |
| } |
| |
| |
| window.onload = function() { |
| createPetals(); |
| |
| |
| setTimeout(() => { |
| createPetals(); |
| }, 3000); |
| }; |
| </script> |
| <p style="border-radius: 8px; text-align: center; font-size: 12px; color: #fff; margin-top: 16px;position: fixed; left: 8px; bottom: 8px; z-index: 10; background: rgba(0, 0, 0, 0.8); padding: 4px 8px;">Made with <img src="https://enzostvs-deepsite.hf.space/logo.svg" alt="DeepSite Logo" style="width: 16px; height: 16px; vertical-align: middle;display:inline-block;margin-right:3px;filter:brightness(0) invert(1);"><a href="https://enzostvs-deepsite.hf.space" style="color: #fff;text-decoration: underline;" target="_blank" >DeepSite</a> - 𧬠<a href="https://enzostvs-deepsite.hf.space?remix=dmae/wedding" style="color: #fff;text-decoration: underline;" target="_blank" >Remix</a></p></body> |
| </html> |