@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes glow{0%,to{box-shadow:0 0 20px #7c3aed4d}50%{box-shadow:0 0 30px #7c3aed99}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fadeIn{animation:.5s ease-out fadeIn}.animate-slideIn{animation:.5s ease-out slideIn}.animate-slideInRight{animation:.5s ease-out slideInRight}.animate-float{animation:3s ease-in-out infinite float}.animate-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}.animate-shimmer{animation:2s linear infinite shimmer}.animate-glow{animation:2s ease-in-out infinite glow}.animate-spin{animation:1s linear infinite spin}.glass{-webkit-backdrop-filter:blur(12px);background:#18181bb3;border:1px solid #3f3f4680}.gradient-text{background:linear-gradient(135deg,#7c3aed 0%,#06b6d4 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.gradient-border{background:#18181b;position:relative}.gradient-border:before{content:"";-webkit-mask-composite:xor;border-radius:inherit;pointer-events:none;background:linear-gradient(135deg,#7c3aed 0%,#06b6d4 100%);padding:1px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#fff 0 0),linear-gradient(#fff 0 0);-webkit-mask-position:0 0,0 0;-webkit-mask-size:auto,auto;-webkit-mask-repeat:repeat,repeat;-webkit-mask-clip:content-box,border-box;-webkit-mask-origin:content-box,border-box;-webkit-mask-composite:xor;mask-composite:exclude;-webkit-mask-source-type:auto,auto;mask-mode:match-source,match-source}.hover-glow{transition:box-shadow .3s}.hover-glow:hover{box-shadow:0 0 20px #7c3aed66,0 0 40px #06b6d433}
:root{--primary-purple:#7c3aed;--cyan-accent:#06b6d4;--bg-main:#09090b;--bg-card:#18181b;--bg-elevated:#27272a;--text-primary:#fafafa;--text-secondary:#a1a1aa;--border-color:#3f3f46}.glass{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#18181bb3;border:1px solid #3f3f4680}.gradient-text{background:linear-gradient(162.35deg,#7c3aed 0%,#06b6d4 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hover-glow{transition:box-shadow .3s}.hover-glow:hover{box-shadow:0 0 20px #7c3aed4d}.animate-fadeIn{animation:.5s ease-out fadeIn}.animate-slideIn{animation:.5s ease-out slideIn}.animate-slideInRight{animation:.5s ease-out slideInRight}.animate-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite pulse}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}
