body { font-family: 'Plus Jakarta Sans', sans-serif; -webkit-font-smoothing: antialiased; background-color: #f0f4f8; overflow-x: hidden; }

.phone-mockup { width: 100%; max-width: 320px; aspect-ratio: 9/19.5; max-height: 82vh; border: 12px solid #0f172a; border-radius: 40px; overflow: hidden; position: relative; box-shadow: 0 30px 60px -15px rgba(0, 0, 0, 0.3); background: #fff; flex-shrink: 0; margin: 0 auto; }
.phone-notch { position: absolute; top: 0; left: 50%; transform: translateX(-50%); width: 100px; height: 22px; background: #0f172a; border-bottom-left-radius: 16px; border-bottom-right-radius: 16px; z-index: 50; }

.scrollbar-hide::-webkit-scrollbar { display: none; }
[v-cloak] { display: none; }

.custom-slider { overflow-x: auto; scroll-behavior: smooth; padding-bottom: 8px; -ms-overflow-style: none; scrollbar-width: none; scroll-snap-type: x mandatory; }
.custom-slider::-webkit-scrollbar { display: none; }

.glass-panel { background: rgba(255, 255, 255, 0.95); backdrop-filter: blur(30px); border: 1px solid rgba(255, 255, 255, 1); box-shadow: 0 10px 40px -10px rgba(0,0,0,0.06); }
.dark .glass-panel { background: rgba(30, 41, 59, 0.85); border-color: rgba(51, 65, 85, 1); box-shadow: 0 10px 40px -10px rgba(0,0,0,0.5); }

.input-modern { background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 16px; padding: 16px 20px; transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); width: 100%; font-weight: 500; color: #1e293b; }
.dark .input-modern { background: #0f172a; border-color: #334155; color: #f8fafc; }
.input-modern:focus { border-color: #6366f1; background: #ffffff; box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.15); outline: none; transform: translateY(-2px); }
.dark .input-modern:focus { background: #1e293b; box-shadow: 0 0 0 4px rgba(99, 102, 241, 0.25); }

.upload-box { border: 2px dashed #cbd5e1; border-radius: 20px; transition: all 0.3s ease; position: relative; overflow: hidden; background: #f8fafc; cursor: pointer; }
.dark .upload-box { border-color: #475569; background: #1e293b; }
.upload-box:hover { border-color: #6366f1; background: #eef2ff; }
.dark .upload-box:hover { border-color: #6366f1; background: #0f172a; }

.upload-input { position: absolute; inset: 0; opacity: 0; cursor: pointer; z-index: 10; width: 100%; height: 100%; }

@keyframes slideUpFade { 0% { opacity: 0; transform: translateY(20px); } 100% { opacity: 1; transform: translateY(0); } }
.animate-slide-up { animation: slideUpFade 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards; }
@keyframes fadeIn { 0% { opacity: 0; } 100% { opacity: 1; } }
.animate-fade-in { animation: fadeIn 0.3s ease-out forwards; }

.pb-safe { padding-bottom: env(safe-area-inset-bottom, 24px); }
.bg-chevron { background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23d1d5db' fill-opacity='0.3'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E"); }
.glowing-orb { position: absolute; border-radius: 50%; filter: blur(70px); opacity: 0.65; pointer-events: none; mix-blend-screen; }
@keyframes blob { 0% { transform: translate(0px, 0px) scale(1); } 33% { transform: translate(30px, -50px) scale(1.1); } 66% { transform: translate(-20px, 20px) scale(0.9); } 100% { transform: translate(0px, 0px) scale(1); } }
.animate-blob { animation: blob 10s infinite alternate; }
.animation-delay-2000 { animation-delay: 2s; }
.animation-delay-4000 { animation-delay: 4s; }