*{margin:0;padding:0;box-sizing:border-box}:root{--primary-purple: #7c3aed;--primary-blue: #3b82f6;--primary-pink: #ec4899;--gradient-1: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-2: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--gradient-3: linear-gradient(135deg, #7c3aed, #3b82f6, #ec4899);--card-bg: rgba(255, 255, 255, .95);--shadow-lg: 0 20px 60px rgba(0, 0, 0, .15);--shadow-xl: 0 25px 80px rgba(0, 0, 0, .2);--border-radius: 20px;--border-radius-lg: 30px}body{font-family:Poppins,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden;background:#0f0f23}.animated-bg{position:fixed;inset:0;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb,#f5576c);background-size:400% 400%;animation:gradientShift 15s ease infinite;z-index:-1}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.app-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;position:relative}.app-card{background:var(--card-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);padding:50px;width:100%;max-width:650px;position:relative;animation:slideUp .6s ease;border:1px solid rgba(255,255,255,.2)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.app-header{text-align:center;margin-bottom:40px}.app-title{font-size:3rem;font-weight:800;background:var(--gradient-3);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:textGradient 3s linear infinite;display:flex;align-items:center;justify-content:center;gap:15px;text-align:center;width:100%;margin:0 auto}@keyframes textGradient{to{background-position:200% center}}.emoji-bounce{display:inline-block;animation:bounce 2s infinite;font-size:3.5rem}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.app-tagline{color:#64748b;font-size:1.1rem;margin-top:10px;font-weight:500}.meme-form{margin-bottom:30px}.form-group{margin-bottom:25px;transition:all .3s ease}.form-group.focused{transform:scale(1.02)}.input-wrapper{position:relative;width:100%}.input-icon{position:absolute;left:20px;top:50%;transform:translateY(-50%);font-size:1.5rem;z-index:1}.expense-input{width:100%;padding:18px 20px 18px 60px;font-size:1.05rem;font-family:Poppins,sans-serif;border:2px solid #e2e8f0;border-radius:50px;transition:all .3s ease;outline:none;background:#fff}.expense-input:focus{border-color:var(--primary-purple);box-shadow:0 0 0 4px #7c3aed1a;transform:translateY(-2px)}.expense-input:disabled{background:#f8fafc;cursor:not-allowed}.generate-button{width:100%;padding:18px 32px;font-size:1.15rem;font-weight:600;font-family:Poppins,sans-serif;color:#fff;background:var(--gradient-1);border:none;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 25px #7c3aed4d;display:flex;align-items:center;justify-content:center;gap:10px;position:relative;overflow:hidden}.generate-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.generate-button:hover:not(:disabled):before{left:100%}.generate-button:hover:not(:disabled){transform:translateY(-3px) scale(1.02);box-shadow:0 12px 35px #7c3aed66}.generate-button:active:not(:disabled){transform:translateY(-1px) scale(.98)}.generate-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.generate-button.loading{background:var(--gradient-2)}.button-icon{font-size:1.4rem;animation:rotate 2s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.button-spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.form-hint{text-align:center;color:#94a3b8;font-size:.9rem;margin-top:15px;animation:fadeIn .5s ease}.error-message{background:linear-gradient(135deg,#fee2e2,#fecaca);border:2px solid #fca5a5;border-radius:15px;padding:15px 20px;margin:20px 0;display:flex;align-items:center;gap:12px;animation:shake .5s ease}.error-icon{font-size:1.5rem}.error-message p{color:#991b1b;font-weight:500;margin:0}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}.shake{animation:shake .5s ease}.skeleton-container{margin:30px 0;animation:fadeIn .3s ease}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:15px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-caption{height:60px;margin-bottom:20px;border-radius:30px}.skeleton-image{height:400px;margin-bottom:20px}.skeleton-buttons{display:flex;gap:15px}.skeleton-button{height:50px;flex:1;border-radius:25px}.meme-display-container{animation:slideUpFade .6s ease;margin-top:30px}@keyframes slideUpFade{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.quote-bubble{background:var(--gradient-1);color:#fff;padding:20px 25px;border-radius:25px;position:relative;margin-bottom:25px;box-shadow:0 10px 30px #7c3aed33;display:flex;align-items:center;gap:15px;animation:popIn .5s ease}.quote-bubble:after{content:"";position:absolute;bottom:-10px;left:50px;width:0;height:0;border-left:15px solid transparent;border-right:15px solid transparent;border-top:15px solid #764ba2}@keyframes popIn{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}.quote-icon{font-size:1.8rem}.meme-caption-text{font-size:1.2rem;font-weight:600;line-height:1.4;margin:0}.meme-card{background:#fff;border-radius:var(--border-radius);overflow:hidden;box-shadow:var(--shadow-lg);margin-bottom:20px;animation:zoomIn .5s ease .2s both}@keyframes zoomIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.meme-image{width:100%;height:auto;display:block}.meme-actions{padding:20px;display:flex;gap:15px;background:#f8fafc}.action-button{flex:1;padding:14px 20px;font-size:1rem;font-weight:600;font-family:Poppins,sans-serif;border:none;border-radius:25px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px}.download-btn{background:var(--gradient-1);color:#fff;box-shadow:0 5px 20px #7c3aed4d}.download-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #7c3aed66}.share-btn{background:#fff;color:var(--primary-purple);border:2px solid var(--primary-purple)}.share-btn:hover{background:var(--primary-purple);color:#fff;transform:translateY(-2px);box-shadow:0 5px 20px #7c3aed4d}.btn-icon{font-size:1.2rem}.copy-link-btn{width:calc(100% - 40px);margin:0 20px 20px;padding:12px 20px;font-size:.95rem;font-weight:500;font-family:Poppins,sans-serif;background:linear-gradient(135deg,#f0f4f8,#e2e8f0);color:#475569;border:none;border-radius:20px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px}.copy-link-btn:hover{background:linear-gradient(135deg,#e2e8f0,#cbd5e1);transform:translateY(-1px)}.copy-link-btn.copied{background:linear-gradient(135deg,#86efac,#4ade80);color:#fff;animation:successPulse .5s ease}@keyframes successPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.copy-icon{font-size:1.1rem}.success-message{text-align:center;margin-top:20px;animation:fadeIn .5s ease .4s both}.success-message p{color:#64748b;font-size:.95rem;font-weight:500}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;z-index:9999}.confetti{position:absolute;width:10px;height:10px;background:linear-gradient(135deg,#667eea,#764ba2,#f093fb,#f5576c);animation:confettiFall linear forwards}.confetti:nth-child(2n){width:8px;height:8px;background:linear-gradient(135deg,#f5576c,#f093fb,#764ba2,#667eea)}.confetti:nth-child(3n){width:6px;height:6px;border-radius:50%}@keyframes confettiFall{to{transform:translateY(100vh) rotate(360deg);opacity:0}}.app-footer{text-align:center;margin-top:40px;padding-top:30px;border-top:1px solid #e2e8f0}.app-footer p{color:#94a3b8;font-size:.9rem}@media (max-width: 640px){.app-card{padding:30px 20px;border-radius:20px}.app-title{font-size:2.2rem;flex-direction:column;gap:10px;text-align:center;align-items:center;justify-content:center}.emoji-bounce{font-size:2.5rem}.app-tagline{font-size:1rem}.expense-input{padding:16px 20px 16px 55px;font-size:1rem}.generate-button{padding:16px 24px;font-size:1.05rem}.meme-actions{flex-direction:column}.quote-bubble{padding:18px 20px;border-radius:20px}.quote-bubble:after{left:30px}.meme-caption-text{font-size:1.1rem}.skeleton-image{height:300px}}@media (max-width: 480px){.app-title{font-size:1.8rem}.app-card{margin:10px;padding:25px 15px}}.sticky-top-banner{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#6a11cb,#2575fc);color:#fff;padding:12px 20px;box-shadow:0 4px 12px #00000026;z-index:1000;animation:slideDown .5s ease}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.sticky-top-banner .banner-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}.sticky-top-banner .banner-text{flex:1;min-width:250px}.sticky-top-banner .banner-headline{font-size:18px;font-weight:700;margin:0 0 4px;font-family:system-ui,-apple-system,sans-serif}.sticky-top-banner .banner-subline{font-size:14px;margin:0;opacity:.95;font-family:system-ui,-apple-system,sans-serif}.sticky-top-banner .banner-cta{background:#fff;color:#2575fc;padding:10px 24px;border-radius:25px;text-decoration:none;font-weight:700;font-size:15px;transition:all .3s ease;display:inline-flex;align-items:center;gap:5px;box-shadow:0 2px 8px #0000001a;font-family:system-ui,-apple-system,sans-serif}.sticky-top-banner .banner-cta:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0003;background:#f8f9ff}.sticky-top-banner .banner-close{position:absolute;top:10px;right:15px;background:transparent;border:none;color:#fff;font-size:28px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;opacity:.8;transition:opacity .3s ease;font-family:system-ui,-apple-system,sans-serif}.sticky-top-banner .banner-close:hover{opacity:1}.app-container.with-banner{padding-top:80px}.footer-banner{background:#f9f9f9;padding:30px 20px;border-top:1px solid #e5e7eb;margin-top:60px}.footer-banner-content{max-width:800px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:20px;text-align:center}.footer-banner-text{font-size:16px;color:#374151;margin:0;font-weight:500;font-family:system-ui,-apple-system,sans-serif}.footer-banner-cta{background:linear-gradient(135deg,#6a11cb,#2575fc);color:#fff;padding:12px 28px;border-radius:25px;text-decoration:none;font-weight:700;font-size:15px;transition:all .3s ease;display:inline-flex;align-items:center;gap:5px;box-shadow:0 3px 12px #6a11cb4d;font-family:system-ui,-apple-system,sans-serif}.footer-banner-cta:hover{transform:translateY(-2px);box-shadow:0 5px 20px #6a11cb66}@media (max-width: 768px){.sticky-top-banner{padding:10px 15px}.sticky-top-banner .banner-content{flex-direction:column;text-align:center;gap:12px}.sticky-top-banner .banner-headline{font-size:16px}.sticky-top-banner .banner-subline{font-size:13px}.sticky-top-banner .banner-cta{font-size:14px;padding:9px 20px}.sticky-top-banner .banner-close{top:8px;right:10px;font-size:24px}.footer-banner{padding:25px 15px}.footer-banner-content{gap:15px}.footer-banner-text{font-size:14px}.footer-banner-cta{font-size:14px;padding:10px 24px}}@media (max-width: 480px){.sticky-top-banner .banner-headline{font-size:15px}.sticky-top-banner .banner-subline{font-size:12px}}
