.flex-row{flex-direction:row}.block{display:block}.hidden{display:none}.inline-block{display:inline-block}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.max-w-xs{max-width:20rem}.max-w-2xl{max-width:42rem}.max-w-full{max-width:100%}.px-2{padding-left:.5rem;padding-right:.5rem}.pb-20{padding-bottom:5rem}.m-0{margin:0}.mt-3{margin-top:.75rem}.text-black{color:#000}.text-gray-400{color:#9ca3af}.text-blue-500{color:#3b82f6}.text-orange-600{color:#ea580c}.text-orange-700{color:#c2410c}.text-orange-800{color:#9a3412}.text-green-400{color:#10b981}.bg-blue-500{background-color:#3b82f6}.bg-blue-600{background-color:#2563eb}.bg-green-500{background-color:#10b981}.border-blue-300{border-color:#93c5fd}.border-blue-600{border-color:#2563eb}.border-blue-700{border-color:#1d4ed8}.border-orange-200{border-color:#fed7aa}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a}.translate-x-full{transform:translateX(100%)}.-translate-x-full{transform:translateX(-100%)}.transition-all{transition:all .2s ease-in-out}.transition-colors{transition:color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out}.transition-opacity{transition:opacity .2s ease-in-out}.hover\:bg-gray-100:hover{background-color:#f3f4f6}.hover\:bg-blue-600:hover{background-color:#2563eb}.hover\:text-gray-600:hover{color:#4b5563}.hover\:text-gray-800:hover{color:#1f2937}.hover\:border-gray-400:hover{border-color:#9ca3af}.hover\:border-blue-300:hover{border-color:#93c5fd}.focus\:outline-none:focus{outline:none}.focus\:ring-2:focus,.focus\:ring-blue-500:focus{box-shadow:0 0 0 2px #3b82f680}.disabled{background-color:#f3f4f6;cursor:not-allowed}.opacity-0{opacity:0}.group:hover .group-hover\:opacity-100{opacity:1}.resize-none{resize:none}.whitespace-pre-wrap{white-space:pre-wrap}.break-words{word-break:break-word}.animate-spin{animation:spin 1s linear infinite}.content-with-nav{padding-bottom:140px}.ask-feature-message-container.ai,.ask-feature-message-container.user{margin-bottom:1rem;width:100%}.ask-feature-message-bubble.user{border-radius:1rem;max-width:20rem;position:relative}.ask-feature-message-bubble.ai{border-radius:1rem;box-shadow:0 1px 3px 0 #0000001a;position:relative}.ask-feature-message-text{word-break:break-word}.ask-feature-avatar.ai,.ask-feature-avatar.user{align-items:center;border-radius:50%;box-shadow:0 1px 3px 0 #0000001a;display:flex;flex-shrink:0;height:2.5rem;justify-content:center;width:2.5rem}.ask-feature-textarea:focus{box-shadow:0 0 0 2px #3b82f680}.ask-feature-send-button{background-color:#3b82f6;color:#fff}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-blue:#2563eb;--primary-green:#10b981;--primary-white:#fff;--light-blue:#dbeafe;--light-green:#d1fae5;--dark-blue:#1e40af;--dark-green:#059669;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto",sans-serif;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--spacing-1:0.25rem;--spacing-2:0.5rem;--spacing-3:0.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--spacing-16:4rem;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;background-color:var(--gray-50);color:#111827;color:var(--gray-900);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-family);line-height:1.6}.App{display:flex;flex-direction:column;min-height:100vh}.container{margin:0 auto;max-width:100%;padding:0 1rem;padding:0 var(--spacing-4)}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}.btn{align-items:center;border:none;border-radius:.75rem;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-size:1rem;font-size:var(--font-size-base);font-weight:600;justify-content:center;min-height:44px;padding:.75rem 1.5rem;padding:var(--spacing-3) var(--spacing-6);text-decoration:none;transition:all .2s ease-in-out}.btn-primary{background:linear-gradient(135deg,#2563eb,#10b981);background:linear-gradient(135deg,var(--primary-blue),var(--primary-green));box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--shadow-md);color:#fff;color:var(--primary-white)}.btn-primary:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.btn-secondary{background:#fff;background:var(--primary-white);border:2px solid #2563eb;border:2px solid var(--primary-blue);color:#2563eb;color:var(--primary-blue)}.btn-secondary:hover{background:#2563eb;background:var(--primary-blue);color:#fff;color:var(--primary-white)}.btn-ghost{background:#0000;border:1px solid #d1d5db;border:1px solid var(--gray-300);color:#4b5563;color:var(--gray-600)}.btn-ghost:hover{background:#f3f4f6;background:var(--gray-100);color:#111827;color:var(--gray-900)}.btn-outline{background:#0000;border:2px solid #2563eb;border:2px solid var(--primary-blue);color:#2563eb;color:var(--primary-blue)}.btn-outline:hover{background:#2563eb;background:var(--primary-blue);color:#fff;color:var(--primary-white)}.card{background:#fff;background:var(--primary-white);border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;box-shadow:var(--shadow-md);padding:1.5rem;padding:var(--spacing-6)}.card-gradient{background:linear-gradient(135deg,#dbeafe,#d1fae5);background:linear-gradient(135deg,var(--light-blue),var(--light-green));border:none}.input{border:2px solid #d1d5db;border:2px solid var(--gray-300);border-radius:.75rem;border-radius:var(--radius-lg);font-size:1rem;font-size:var(--font-size-base);min-height:44px;padding:.75rem 1rem;padding:var(--spacing-3) var(--spacing-4);transition:border-color .2s ease-in-out;width:100%}.input:focus{border-color:#2563eb;border-color:var(--primary-blue);box-shadow:0 0 0 3px #2563eb1a;outline:none}.nav-bottom{background:#fff;background:var(--primary-white);border-top:1px solid var(--gray-200);height:80px;padding:var(--spacing-2) 0}.nav-item{color:var(--gray-500);font-size:.75rem;font-size:var(--font-size-xs);min-width:60px;padding:var(--spacing-2);text-decoration:none;transition:color .2s ease-in-out}.nav-item.active{color:var(--primary-blue)}.nav-item:hover{color:#2563eb;color:var(--primary-blue)}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .6s ease-out}.animate-bounce{animation:bounce 2s infinite}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.main-content{min-height:calc(100vh - 80px);padding-bottom:20px}.text-primary{color:#2563eb;color:var(--primary-blue)}.text-green{color:#10b981;color:var(--primary-green)}.text-gray-500{color:var(--gray-500)}.text-gray-600{color:var(--gray-600)}.text-gray-900{color:var(--gray-900)}.bg-primary{background-color:#2563eb;background-color:var(--primary-blue)}.bg-green{background-color:#10b981;background-color:var(--primary-green)}.bg-white{background-color:var(--primary-white)}.bg-gray-50{background-color:var(--gray-50)}.rounded-sm{border-radius:.375rem;border-radius:var(--radius-sm)}.rounded-md{border-radius:.5rem;border-radius:var(--radius-md)}.rounded-lg{border-radius:.75rem;border-radius:var(--radius-lg)}.rounded-xl{border-radius:1rem;border-radius:var(--radius-xl)}.rounded-2xl{border-radius:1.5rem;border-radius:var(--radius-2xl)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.p-2{padding:var(--spacing-2)}.p-4{padding:var(--spacing-4)}.p-6{padding:var(--spacing-6)}.p-8{padding:var(--spacing-8)}.m-2{margin:var(--spacing-2)}.m-4{margin:var(--spacing-4)}.m-6{margin:var(--spacing-6)}.m-8{margin:var(--spacing-8)}.mb-2{margin-bottom:var(--spacing-2)}.mb-4{margin-bottom:var(--spacing-4)}.mb-6{margin-bottom:var(--spacing-6)}.mb-8{margin-bottom:var(--spacing-8)}.mt-2{margin-top:var(--spacing-2)}.mt-4{margin-top:var(--spacing-4)}.mt-6{margin-top:var(--spacing-6)}.mt-8{margin-top:var(--spacing-8)}.h-full{height:100%}@media (max-width:640px){.container{padding:0 .75rem;padding:0 var(--spacing-3)}.card{padding:1rem;padding:var(--spacing-4)}.btn{font-size:1.125rem;font-size:var(--font-size-lg);padding:1rem 1.5rem;padding:var(--spacing-4) var(--spacing-6)}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast:high){:root{--primary-blue:#00f;--primary-green:green;--gray-500:#000}}.min-h-screen{min-height:100vh}.flex{display:flex}.flex-col{flex-direction:column}.flex-1{flex:1 1}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.space-x-2>*+*{margin-left:.5rem}.space-x-3>*+*{margin-left:.75rem}.space-x-4>*+*{margin-left:1rem}.space-y-2>*+*{margin-top:.5rem}.space-y-3>*+*{margin-top:.75rem}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.inset-0{bottom:0;left:0;right:0;top:0}.top-0{top:0}.right-0{right:0}.bottom-0{bottom:0}.left-0{left:0}.z-10{z-index:10}.z-50{z-index:50}.w-full{width:100%}.w-8{width:2rem}.w-10{width:2.5rem}.w-12{width:3rem}.w-16{width:4rem}.w-20{width:5rem}.w-24{width:6rem}.w-80{width:20rem}.w-96{width:24rem}.h-1{height:.25rem}.h-2{height:.5rem}.h-8{height:2rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.h-20{height:5rem}.h-80{height:20rem}.h-96{height:24rem}.max-w-sm{max-width:24rem}.max-w-md{max-width:28rem}.max-w-lg{max-width:32rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.py-4{padding-bottom:1rem;padding-top:1rem}.py-6{padding-bottom:1.5rem;padding-top:1.5rem}.py-8{padding-bottom:2rem;padding-top:2rem}.m-2{margin:.5rem}.m-4{margin:1rem}.m-6{margin:1.5rem}.m-8{margin:2rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mb-12{margin-bottom:3rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-12{margin-top:3rem}.mx-auto{margin-left:auto;margin-right:auto}.ml-2{margin-left:.5rem}.ml-4{margin-left:1rem}.mr-2{margin-right:.5rem}.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem}.text-lg,.text-xl{line-height:1.75rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-8xl{font-size:6rem;line-height:1}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.leading-relaxed{line-height:1.625}.text-white{color:#fff}.text-gray-500{color:#6b7280}.text-gray-600{color:#4b5563}.text-gray-700{color:#374151}.text-gray-900{color:#111827}.text-blue-600{color:#2563eb}.text-blue-800{color:#1e40af}.text-green-600{color:#10b981}.text-green-800{color:#059669}.text-red-600{color:#dc2626}.text-yellow-500{color:#eab308}.text-yellow-600{color:#ca8a04}.text-yellow-800{color:#854d0e}.text-orange-500{color:#f97316}.text-purple-600{color:#9333ea}.bg-white{background-color:#fff}.bg-gray-50{background-color:#f9fafb}.bg-gray-100{background-color:#f3f4f6}.bg-gray-200{background-color:#e5e7eb}.bg-blue-50{background-color:#eff6ff}.bg-blue-100{background-color:#dbeafe}.bg-green-50{background-color:#f0fdf4}.bg-green-100{background-color:#dcfce7}.bg-yellow-50{background-color:#fefce8}.bg-orange-50{background-color:#fff7ed}.bg-purple-50{background-color:#faf5ff}.bg-red-50{background-color:#fef2f2}.border{border-width:1px}.border-2{border-width:2px}.border-t{border-top-width:1px}.border-b{border-bottom-width:1px}.border-gray-200{border-color:#e5e7eb}.border-gray-300{border-color:#d1d5db}.border-blue-500{border-color:#3b82f6}.border-white{border-color:#fff}.border-transparent{border-color:#0000}.rounded{border-radius:.25rem}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.shadow-sm{box-shadow:0 1px 2px 0 #0000000d}.shadow-md{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}.shadow-xl{box-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a}.shadow-2xl{box-shadow:0 25px 50px -12px #00000040}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-90{opacity:.9}.transform{transform:translateZ(0)}.scale-105{transform:scale(1.05)}.-translate-x-1\/2{transform:translateX(-50%)}.-translate-y-1\/2{transform:translateY(-50%)}.-top-40{top:-10rem}.-right-40{right:-10rem}.-bottom-40{bottom:-10rem}.-left-40{left:-10rem}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,fill,stroke,-webkit-text-decoration-color;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,-webkit-text-decoration-color;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-shadow{transition-duration:.15s;transition-property:box-shadow;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-300{transition-duration:.3s}.hover\:bg-gray-50:hover{background-color:#f9fafb}.hover\:bg-opacity-30:hover{background-opacity:.3}.hover\:shadow-md:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a}.hover\:shadow-lg:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}.hover\:shadow-2xl:hover{box-shadow:0 25px 50px -12px #00000040}.hover\:scale-105:hover{transform:scale(1.05)}.focus\:outline-none:focus{outline:2px solid #0000;outline-offset:2px}.focus\:ring-2:focus,.focus\:ring-blue-500:focus{box-shadow:0 0 0 2px #3b82f6}.focus\:border-transparent:focus{border-color:#0000}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.text-opacity-90{color:#ffffffe6}.text-opacity-70{color:#ffffffb3}.backdrop-blur-sm{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.flex-shrink-0{flex-shrink:0}.animate-bounce{animation:bounce 1s infinite}.welcome-container{background:linear-gradient(135deg,#60a5fa,#3b82f6,#10b981);display:flex;flex-direction:column;min-height:100vh;overflow:hidden}.welcome-background{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0}.welcome-background-circle{background:#ffffff1a;border-radius:50%;position:absolute}.welcome-background-circle.large{height:320px;right:-160px;top:-160px;width:320px}.welcome-background-circle.large.bottom{bottom:-160px;left:-160px;right:auto;top:auto}.welcome-background-circle.center{background:#ffffff0d;height:384px;left:50%;top:50%;transform:translate(-50%,-50%);width:384px}.welcome-background-circle.mobile{display:none}.welcome-content{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:space-between;min-height:0;padding:16px;position:relative;z-index:10}.welcome-logo{flex-shrink:0;margin-bottom:16px;text-align:center}.welcome-mascot{animation:float 3s ease-in-out infinite;margin-bottom:16px}.welcome-logo-img{border-radius:50%;box-shadow:0 8px 32px #0003;height:80px;object-fit:cover;width:80px}.welcome-title{color:#fff;font-size:32px;font-weight:700;margin-bottom:8px}.welcome-subtitle{color:#ffffffe6;font-size:20px}.welcome-message{flex-shrink:0;margin-bottom:24px;max-width:448px;padding:0 16px;text-align:center}.welcome-message h2{color:#fff;font-size:24px;font-weight:600;margin-bottom:16px}.welcome-message p{color:#ffffffe6;font-size:18px;line-height:1.6}.welcome-features{grid-gap:12px;display:grid;flex-shrink:0;gap:12px;grid-template-columns:1fr 1fr;margin-bottom:24px;max-width:384px;padding:0 16px}.welcome-feature{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:12px;display:flex;flex-direction:column;padding:16px}.welcome-feature-icon{color:#fff;font-size:24px;margin-bottom:8px}.welcome-feature-text{color:#fffc;font-size:12px;font-weight:500}.welcome-buttons{flex-shrink:0;max-width:384px;padding:0 16px;width:100%}.welcome-button-primary{background:#3b82f6;border:none;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;color:#fff;cursor:pointer;font-size:18px;font-weight:600;margin-bottom:16px;padding:16px;transition:all .3s ease;width:100%}.welcome-button-primary:hover{box-shadow:0 25px 50px -12px #00000040;transform:scale(1.05)}.welcome-button-secondary{background:#fff3;border:1px solid #ffffff4d;border-radius:16px;color:#fff;cursor:pointer;flex:1 1;font-size:18px;font-weight:600;padding:16px;transition:all .3s ease}.welcome-button-secondary:hover{background:#ffffff4d}.welcome-button-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.welcome-footer{flex-shrink:0;margin-top:16px;padding:0 16px;text-align:center}.welcome-footer-text{color:#ffffffb3;font-size:14px;margin-bottom:16px}.welcome-footer-links{display:flex;gap:24px;justify-content:center}.welcome-footer-link{color:#fff9;font-size:14px;text-decoration:none;transition:all .3s ease}.welcome-footer-link:hover{color:#fff;text-decoration:underline}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-10px) rotate(5deg)}}@media (max-width:768px){.welcome-background-circle.center,.welcome-background-circle.large{display:none}.welcome-background-circle.mobile{display:block}.welcome-background-circle.mobile.top{background:#ffffff0d;height:128px;right:40px;top:80px;width:128px}.welcome-background-circle.mobile.bottom{background:#ffffff0d;bottom:80px;height:96px;left:40px;width:96px}.welcome-content{justify-content:space-between;padding:12px}.welcome-logo{margin-bottom:12px}.welcome-logo-img{height:60px;width:60px}.welcome-title{font-size:24px}.welcome-subtitle{font-size:16px}.welcome-message{margin-bottom:16px}.welcome-message h2{font-size:20px}.welcome-message p{font-size:16px}.welcome-features{gap:8px;margin-bottom:16px}.welcome-feature{padding:12px}.welcome-feature-icon{font-size:20px}.welcome-feature-text{font-size:11px}.welcome-button-primary,.welcome-button-secondary{font-size:16px;padding:12px}.welcome-footer{margin-top:12px}.welcome-footer-links{gap:16px}}.login-container{align-items:center;background:linear-gradient(to bottom right,#eff6ff,#e0e7ff);display:flex;justify-content:center;min-height:100vh;padding:1rem}.login-card{background-color:#fff;border-radius:1rem;box-shadow:0 25px 50px -12px #00000040;max-width:28rem;padding:2rem;width:100%}.login-header{margin-bottom:2rem;text-align:center}.login-logo{align-items:center;background:linear-gradient(90deg,#2563eb,#4f46e5);border-radius:50%;display:flex;height:4rem;justify-content:center;margin:0 auto 1rem;width:4rem}.login-logo-img{border-radius:50%;height:100%;object-fit:cover;width:100%}.login-title{color:#111827;font-size:1.875rem;font-weight:700;margin-bottom:.5rem}.login-subtitle{color:#4b5563}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-button{border:none;border-radius:.5rem;cursor:pointer;font-weight:500;outline:none;padding:.75rem 1rem;transform:translateY(0);transition:all .3s;width:100%}.login-button:focus{ring:2px solid #3b82f6;ring-offset:2px;outline:none}.login-button:disabled{background-color:#9ca3af;color:#e5e7eb;cursor:not-allowed}.login-button:not(:disabled):hover{box-shadow:0 25px 50px -12px #00000040;transform:translateY(-2px) scale(1.02)}.login-button:not(:disabled):active{transform:translateY(0) scale(.98)}.login-button.primary{background:linear-gradient(90deg,#06b6d4,#2563eb);color:#fff}.login-button.primary:hover:not(:disabled){background:linear-gradient(90deg,#0891b2,#1d4ed8)}.login-button.secondary{background-color:#9ca3af;color:#e5e7eb}.login-button-content{align-items:center;display:flex;justify-content:center}.login-spinner{animation:spin 1s linear infinite;border-bottom:2px solid #fff;border-radius:50%;height:1.25rem;margin-right:.5rem;width:1.25rem}.login-footer{margin-top:1.5rem;text-align:center}.login-footer-text{color:#4b5563}.login-link{color:#2563eb;font-weight:500;text-decoration:none;transition:color .2s}.login-link:hover{color:#1d4ed8}.login-divider{margin-top:1.5rem}.login-divider-line{position:relative}.login-divider-line:before{background-color:#d1d5db;content:"";height:1px;left:0;position:absolute;right:0;top:50%}.login-divider-text{display:flex;font-size:.875rem;justify-content:center;position:relative}.login-divider-span{background-color:#fff;color:#6b7280;padding:0 .5rem}.signup-container{align-items:center;background:linear-gradient(to bottom right,#eff6ff,#e0e7ff);display:flex;justify-content:center;min-height:100vh;padding:1rem}.signup-card{background-color:#fff;border-radius:1rem;box-shadow:0 25px 50px -12px #00000040;max-width:28rem;padding:2rem;width:100%}.signup-header{margin-bottom:2rem;text-align:center}.signup-logo{align-items:center;background:linear-gradient(90deg,#2563eb,#4f46e5);border-radius:50%;display:flex;height:4rem;justify-content:center;margin:0 auto 1rem;width:4rem}.signup-logo-img{border-radius:50%;height:100%;object-fit:cover;width:100%}.signup-title{color:#111827;font-size:1.875rem;font-weight:700;margin-bottom:.5rem}.signup-subtitle{color:#4b5563}.signup-form{display:flex;flex-direction:column;gap:1.5rem}.form-label{display:block;margin-bottom:.5rem}.form-input{outline:none;padding:.75rem 1rem;width:100%}.form-input:focus{ring:2px solid #3b82f6;border-color:#0000}.form-input::placeholder{color:#9ca3af}.form-select{background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;outline:none;padding:.75rem 1rem;transition:all .2s;width:100%}.form-select:focus{ring:2px solid #3b82f6;border-color:#0000}.signup-button{border:none;border-radius:.5rem;cursor:pointer;font-weight:500;outline:none;padding:.75rem 1rem;transform:translateY(0);transition:all .3s;width:100%}.signup-button:focus{ring:2px solid #3b82f6;ring-offset:2px;outline:none}.signup-button:disabled{background-color:#9ca3af;color:#e5e7eb;cursor:not-allowed}.signup-button:not(:disabled):hover{box-shadow:0 25px 50px -12px #00000040;transform:translateY(-2px) scale(1.02)}.signup-button:not(:disabled):active{transform:translateY(0) scale(.98)}.signup-button.primary{background:linear-gradient(90deg,#06b6d4,#2563eb);color:#fff}.signup-button.primary:hover:not(:disabled){background:linear-gradient(90deg,#0891b2,#1d4ed8)}.signup-button.secondary{background-color:#9ca3af;color:#e5e7eb}.signup-button-content{align-items:center;display:flex;justify-content:center}.signup-spinner{animation:spin 1s linear infinite;border-bottom:2px solid #fff;border-radius:50%;height:1.25rem;margin-right:.5rem;width:1.25rem}.signup-footer{margin-top:1.5rem;text-align:center}.signup-footer-text{color:#4b5563}.signup-link{color:#2563eb;font-weight:500;text-decoration:none;transition:color .2s}.signup-link:hover{color:#1d4ed8}.signup-divider{margin-top:1.5rem}.signup-divider-line{position:relative}.signup-divider-line:before{background-color:#d1d5db;content:"";height:1px;left:0;position:absolute;right:0;top:50%}.signup-divider-text{display:flex;font-size:.875rem;justify-content:center;position:relative}.signup-divider-span{background-color:#fff;color:#6b7280;padding:0 .5rem}.guest-button{margin-top:1.5rem}.guest-button-link{border:1px solid #d1d5db;border-radius:.5rem;color:#374151;display:flex;font-weight:500;justify-content:center;padding:.75rem 1rem;text-decoration:none;transition:background-color .2s;width:100%}.guest-button-link:hover{background-color:#f9fafb}.badge-wrapper{display:inline-block;position:relative}.badge{align-items:center;background:#fef3c7;background:var(--badge-bg,#fef3c7);border:2px solid #d97706;border:2px solid var(--badge-color,#d97706);border-radius:.75rem;box-shadow:0 2px 4px #0000001a;cursor:pointer;display:flex;gap:.5rem;overflow:hidden;padding:.5rem .75rem;position:relative;transition:all .2s}.badge:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.badge-small{font-size:.75rem;padding:.375rem .5rem}.badge-medium{font-size:.875rem;padding:.5rem .75rem}.badge-large{font-size:1rem;padding:.75rem 1rem}.badge-icon{font-size:1.25em;line-height:1}.badge-content{display:flex;flex-direction:column;gap:.25rem}.badge-name{color:#d97706;color:var(--badge-color,#d97706);font-weight:600;line-height:1.2}.badge-description{color:#6b7280;font-size:.75em;line-height:1.2}.badge-rarity-indicator{background-color:#6b7280;background-color:var(--rarity-color,#6b7280);height:100%;position:absolute;right:0;top:0;width:4px}.badge-common{background:#f3f4f6;border-color:#6b7280}.badge-uncommon{background:#ecfdf5;border-color:#10b981}.badge-rare{background:#eff6ff;border-color:#3b82f6}.badge-epic{background:#f5f3ff;border-color:#8b5cf6}.badge-legendary{background:#fffbeb;border-color:#f59e0b;box-shadow:0 0 10px #f59e0b4d}.badge-legendary:hover{box-shadow:0 0 15px #f59e0b80}.badge-tooltip{background:#1f2937;border-radius:.5rem;bottom:100%;box-shadow:0 4px 6px #0000001a;color:#fff;margin-bottom:.5rem;max-width:250px;min-width:200px;padding:.75rem;pointer-events:none;z-index:1000}.badge-tooltip,.badge-tooltip:after{left:50%;position:absolute;transform:translateX(-50%)}.badge-tooltip:after{border:6px solid #0000;border-top-color:#1f2937;content:"";top:100%}.tooltip-name{color:#fff;font-size:.875rem;font-weight:600;margin-bottom:.25rem}.tooltip-description{color:#d1d5db;font-size:.75rem;line-height:1.4;margin-bottom:.5rem}.tooltip-rarity{color:#9ca3af;font-size:.7rem;text-transform:capitalize}.tooltip-rarity span{font-weight:600}.badge-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));padding:1rem 0}.badge-list{display:flex;flex-wrap:wrap;gap:.75rem;padding:.5rem 0}.badge-collection{gap:1.5rem}.badge-category,.badge-collection{display:flex;flex-direction:column}.badge-category{gap:.75rem}.badge-category-title{font-size:1rem;margin-bottom:.5rem}.badge-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.badge-modal-content{background:#fff;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a;display:flex;flex-direction:column;max-height:90vh;max-width:900px;overflow:hidden;width:100%}.badge-modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.5rem}.badge-modal-title{color:#111827;font-size:1.5rem;font-weight:700;margin:0}.badge-modal-close{align-items:center;background:none;border:none;border-radius:.5rem;color:#6b7280;cursor:pointer;display:flex;font-size:1.25rem;justify-content:center;padding:.5rem;transition:all .2s}.badge-modal-close:hover{background:#f3f4f6;color:#111827}.badge-modal-progress{background:#f9fafb;border-bottom:1px solid #e5e7eb;padding:1.5rem}.progress-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.progress-text{font-size:.875rem;font-weight:500}.progress-percentage{color:#2563eb;font-size:1rem;font-weight:600}.progress-bar-container{background:#e5e7eb;border-radius:4px;height:8px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg,#2563eb,#3b82f6);border-radius:4px;height:100%;transition:width .3s ease}.badge-modal-body{flex:1 1;overflow-y:auto;padding:1.5rem}.badge-category-section{margin-bottom:2rem}.badge-category-section:last-child{margin-bottom:0}.badge-category-title{color:#111827;font-size:1.125rem;font-weight:600;margin-bottom:1rem}.badge-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.badge-item-container{position:relative;transition:transform .2s;width:100%}.badge-item-container .badge{align-items:center;flex-direction:column;gap:.75rem;justify-content:center;min-height:140px;padding:1rem;text-align:center;width:100%}.badge-item-container .badge .badge-icon{font-size:2.5rem;margin-bottom:.25rem}.badge-item-container .badge .badge-content{gap:.5rem;width:100%}.badge-item-container .badge .badge-name{font-size:.875rem;font-weight:600}.badge-item-container .badge .badge-description{color:#6b7280;font-size:.75rem;line-height:1.3}.badge-item-container.earned{opacity:1}.badge-item-container.earned .badge{border-style:solid;border-width:2px}.badge-item-container.locked{filter:grayscale(.5);opacity:.6}.badge-item-container.locked .badge{background:#f3f4f6!important;border-color:#9ca3af!important}.badge-locked-overlay{align-items:center;background:#0000004d;border-radius:.75rem;bottom:0;display:flex;justify-content:center;left:0;pointer-events:none;position:absolute;right:0;top:0}.lock-icon{font-size:2rem;opacity:.8}@media (max-width:768px){.badge-modal-content{border-radius:0;max-height:100vh;max-width:100%}.badge-grid{gap:.75rem;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.badge-modal-body,.badge-modal-header,.badge-modal-progress{padding:1rem}}.dashboard-container{background-color:#f9fafb;min-height:100vh}.dashboard-content{display:flex;flex-direction:column;gap:1.5rem;padding:1rem}.loading-screen{align-items:center;background:linear-gradient(to bottom right,#eff6ff,#e0e7ff);display:flex;justify-content:center;min-height:100vh}.loading-content{text-align:center}.loading-spinner{animation:spin 1s linear infinite;border-bottom:2px solid #2563eb;border-radius:50%;height:3rem;margin:0 auto 1rem;width:3rem}.loading-text{color:#4b5563}.logo-container{align-items:center;background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:.5rem;display:flex;height:2rem;justify-content:center;width:2rem}.logo-img{border-radius:.5rem;height:100%;object-fit:cover;width:100%}.top-bar-right{align-items:center;display:flex;gap:.5rem}.user-info{text-align:right}.user-level{color:#111827;font-size:.875rem;font-weight:500}.user-title{color:#6b7280;font-size:.75rem}.profile-button,.trophy-icon{align-items:center;background-color:#dbeafe;border-radius:50%;color:#2563eb;display:flex;height:2.5rem;justify-content:center;width:2.5rem}.profile-button{border:none;cursor:pointer;padding:.5rem;transition:all .2s}.profile-button:hover{background-color:#bfdbfe;color:#1d4ed8;transform:scale(1.05)}.admin-button{align-items:center;background-color:#d1fae5;border:none;border-radius:50%;color:#10b981;cursor:pointer;display:flex;height:2.5rem;justify-content:center;padding:.5rem;transition:all .2s;width:2.5rem}.admin-button:hover{background-color:#a7f3d0;color:#059669;transform:scale(1.05)}.logout-button{align-items:center;background-color:#fee2e2;border:none;border-radius:50%;color:#ef4444;cursor:pointer;display:flex;height:2.5rem;justify-content:center;padding:.5rem;transition:all .2s;width:2.5rem}.logout-button:hover{background-color:#fecaca;color:#dc2626;transform:scale(1.05)}.greeting-section{text-align:center}.greeting-title{color:#111827;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.greeting-subtitle{color:#4b5563}.progress-card{background-color:#fff;border-radius:.75rem;box-shadow:0 1px 2px 0 #0000000d;padding:1rem}.progress-header{justify-content:space-between;margin-bottom:.75rem}.progress-header,.streak-info{align-items:center;display:flex}.streak-info{gap:.5rem}.streak-icon{color:#f97316}.streak-text{color:#111827;font-weight:600}.xp-info{align-items:center;display:flex;gap:.5rem}.xp-icon{color:#eab308}.xp-text{color:#111827;font-weight:600}.sync-info{color:#6b7280;font-size:.75rem}.sync-indicator{align-items:center;display:flex;gap:.25rem}.sync-dot{animation:pulse 2s infinite;background-color:#10b981;border-radius:50%;height:.5rem;width:.5rem}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.progress-bar-container{background-color:#e0e0e0;border-radius:.375rem;height:.75rem;width:100%}.progress-bar-fill{background-color:#2563eb;border-radius:.375rem;box-shadow:0 1px 2px 0 #0000000d;height:.75rem;transition:all .3s}.progress-text{color:#6b7280;font-size:.75rem;margin-top:.25rem}.fact-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:1rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;padding:1.5rem}.fact-card.completed{background-color:#f0fdf4;border-color:#bbf7d0}.fact-card-content{margin-bottom:1rem;text-align:center}.fact-category{align-items:center;background-color:#dbeafe;border-radius:9999px;color:#1e40af;display:inline-flex;font-size:.875rem;font-weight:500;margin-bottom:.75rem;padding:.25rem .75rem}.fact-title{color:#111827;font-size:1.25rem;font-weight:700;margin-bottom:.75rem}.fact-content{color:#374151;line-height:1.625}.fact-button{background:linear-gradient(90deg,#06b6d4,#2563eb);border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-weight:500;padding:.75rem;transition:all .2s;width:100%}.fact-button:hover{background:linear-gradient(90deg,#0891b2,#1d4ed8);transform:translateY(-1px)}.fact-completed-message{margin-top:1.5rem;text-align:center}.fact-completed-content{background-color:#fef3c7;border:1px solid #fde68a;border-radius:.5rem;padding:1rem}.fact-completed-text{color:#92400e;font-weight:500}.fact-completed-subtext{color:#d97706;font-size:.875rem;margin-top:.25rem}.completed-fact-card{background-color:#f0fdf4;border:1px solid #bbf7d0;border-radius:1rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;padding:1.5rem}.completed-fact-content{text-align:center}.completed-icon-container{align-items:center;background-color:#dcfce7;border-radius:50%;display:inline-flex;height:4rem;justify-content:center;margin-bottom:1rem;width:4rem}.completed-icon{color:#16a34a;font-size:1.5rem}.completed-title{color:#14532d;font-size:1.25rem;font-weight:700;margin-bottom:.5rem}.completed-text{color:#15803d;margin-bottom:.75rem}.streak-card{background-color:#fed7aa;border:1px solid #fdba74;border-radius:.5rem;margin-top:.75rem;padding:.75rem}.streak-text-completed{color:#9a3412;font-weight:500}.streak-subtext{color:#c2410c;font-size:.875rem}.quick-actions{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.action-button{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 2px 0 #0000000d;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;padding:1rem;text-align:left;transition:all .2s}.action-button:hover{border-color:#2563eb;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-2px)}.action-icon{font-size:1.5rem;margin-bottom:.5rem}.action-icon.learn{color:#2563eb}.action-icon.ask{color:#16a34a}.action-title{color:#111827;font-weight:600}.action-subtitle{color:#4b5563;font-size:.875rem}.badges-card{background-color:#fff;border-radius:.75rem;box-shadow:0 1px 2px 0 #0000000d;padding:1rem}.badges-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.badges-title{color:#111827;font-weight:600;margin:0}.view-all-badges-btn{background:none;border:none;border-radius:.375rem;color:#2563eb;cursor:pointer;font-size:.875rem;font-weight:500;padding:.25rem .5rem;transition:background .2s}.view-all-badges-btn:hover{background:#eff6ff}.badges-list{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.badge-more-btn{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:.5rem;color:#6b7280;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem .75rem;transition:all .2s}.badge-more-btn:hover{background:#e5e7eb;color:#111827}.badges-empty{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:2rem 1rem;text-align:center}.badges-empty-icon{color:#d1d5db;font-size:3rem;margin-bottom:.75rem}.badges-empty-text{color:#6b7280;font-size:.875rem;margin:0}.content-with-nav{padding-bottom:120px}.dashboard-footer{border-top:1px solid #e5e7eb;margin-top:2rem;padding:1.5rem 1rem}.dashboard-footer-links{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.dashboard-footer-link{color:#6b7280;font-size:.875rem;text-decoration:none;transition:color .2s}.dashboard-footer-link:hover{color:#2563eb;text-decoration:underline}.learning-container{background-color:#f9fafb;min-height:100vh}.learning-content{padding-bottom:120px}.learning-loading{align-items:center;background:linear-gradient(to bottom right,#eff6ff,#e0e7ff);display:flex;justify-content:center;min-height:100vh}.learning-loading-content{text-align:center}.learning-spinner{animation:spin 1s linear infinite;border-bottom:2px solid #2563eb;border-radius:50%;height:3rem;margin:0 auto 1rem;width:3rem}.learning-loading-text{color:#4b5563}.learning-top-bar{background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 2px 0 #0000000d;padding:.75rem 1rem}.learning-top-content{align-items:center;display:flex;justify-content:space-between}.learning-top-left{align-items:center;display:flex;gap:.75rem}.learning-back-button{background:none;border:none;color:#4b5563;cursor:pointer;font-size:1rem}.learning-title{color:#111827;font-size:1.25rem;font-weight:700}.learning-main{padding:1rem}.learning-header{margin-bottom:2rem;text-align:center}.learning-header-title{color:#111827;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.learning-header-subtitle{color:#4b5563}.learning-courses-loading{padding:2rem 0;text-align:center}.learning-courses-spinner{animation:spin 1s linear infinite;border-bottom:2px solid #2563eb;border-radius:50%;height:2rem;margin:0 auto 1rem;width:2rem}.learning-courses-loading-text{color:#4b5563}.learning-courses-grid{display:flex;flex-direction:column;gap:1rem}.learning-course-card{background-color:#fff;border:2px solid #0000;border-radius:.75rem;box-shadow:0 1px 2px 0 #0000000d;cursor:pointer;padding:1.5rem;transition:all .2s}.learning-course-card:hover:not(.locked){box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.learning-course-card.locked{opacity:.6}.learning-course-content{align-items:flex-start;display:flex;gap:1rem}.learning-course-thumbnail{font-size:2.25rem}.learning-course-info{flex:1 1}.learning-course-header{align-items:center;display:flex;gap:.5rem;margin-bottom:.5rem}.learning-course-title{color:#111827;font-size:1.125rem;font-weight:600;margin:0}.learning-course-icon{color:#9ca3af}.learning-course-icon.completed{color:#10b981}.learning-course-description{color:#4b5563;margin:0 0 1rem}.learning-course-footer{align-items:center;display:flex;justify-content:space-between}.learning-course-stats{align-items:center;display:flex;gap:1rem}.learning-course-lessons{color:#6b7280;font-size:.875rem}.learning-course-progress-container{background-color:#e5e7eb;border-radius:9999px;height:.5rem;width:6rem}.learning-course-progress-bar{border-radius:9999px;height:.5rem;transition:all .3s}.learning-course-progress-bar.blue{background-color:#3b82f6}.learning-course-progress-bar.green{background-color:#10b981}.learning-course-progress-bar.purple{background-color:#8b5cf6}.learning-course-progress-bar.orange{background-color:#f97316}.learning-course-status{border-radius:9999px;font-size:.875rem;font-weight:500;padding:.25rem .75rem}.learning-course-status.blue{background-color:#dbeafe;border:1px solid #bfdbfe;color:#1e40af}.learning-course-status.green{background-color:#dcfce7;border:1px solid #bbf7d0;color:#166534}.learning-course-status.purple{background-color:#f3e8ff;border:1px solid #e9d5ff;color:#7c3aed}.learning-course-status.orange{background-color:#fed7aa;border:1px solid #fdba74;color:#9a3412}.learning-tips{background:linear-gradient(90deg,#eff6ff,#f0fdf4);border-radius:.75rem;margin-top:2rem;padding:1.5rem}.learning-tips-title{color:#111827;font-weight:600;margin-bottom:.75rem}.learning-tips-list{color:#374151;display:flex;flex-direction:column;font-size:.875rem;gap:.5rem;list-style:none;margin:0;padding:0}.learning-tips-list li{margin:0}.ask-feature-container{background-color:#f9fafb;display:flex;flex-direction:column;min-height:100vh}.ask-feature-top-bar{background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px 0 #0000001a;padding:.75rem 1rem}.ask-feature-top-bar-content{align-items:center;display:flex;justify-content:space-between}.ask-feature-top-bar-left{align-items:center;display:flex;gap:.75rem}.ask-feature-back-button{background:none;border:none;color:#6b7280;cursor:pointer;font-size:1rem}.ask-feature-title{color:#111827;font-size:1.25rem;font-weight:700}.ask-feature-top-bar-right{align-items:center;color:#6b7280;display:flex;font-size:.875rem;gap:.5rem}.ask-feature-ai-icon{color:#3b82f6}.ask-feature-service-unavailable{align-items:center;color:#ea580c;display:flex;font-size:.75rem;gap:.25rem}.ask-feature-test-connection{background-color:#10b981;border:none;border-radius:.25rem;color:#000;cursor:pointer;font-size:.75rem;margin-left:.5rem;padding:.25rem .5rem}.ask-feature-chat-container,.ask-feature-messages-area{display:flex;flex:1 1;flex-direction:column}.ask-feature-messages-area{gap:1rem;overflow-y:auto;padding:1rem}.ask-feature-loading-history{align-items:center;display:flex;justify-content:center;padding:2rem 0}.ask-feature-loading-spinner{align-items:center;color:#6b7280;display:flex;gap:.5rem}.ask-feature-spinner{animation:spin 1s linear infinite;border:2px solid #3b82f6;border-radius:50%;border-top-color:#0000;height:1rem;width:1rem}.ask-feature-service-warning{background-color:#fff7ed;border:1px solid #fed7aa;border-radius:.5rem;margin-bottom:1rem;padding:1rem}.ask-feature-warning-content{align-items:center;color:#9a3412;display:flex;gap:.5rem}.ask-feature-warning-text{color:#c2410c;font-size:.875rem;margin-top:.25rem}.ask-feature-welcome{padding:2rem 0;text-align:center}.ask-feature-welcome-icon{align-items:center;background-color:#dbeafe;border-radius:50%;display:flex;height:4rem;justify-content:center;margin:0 auto 1rem;width:4rem}.ask-feature-welcome-icon svg{color:#2563eb;font-size:1.5rem}.ask-feature-welcome-title{color:#111827;font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.ask-feature-welcome-subtitle{color:#6b7280;margin-bottom:1.5rem}.ask-feature-prompts-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:1fr;margin:0 auto;max-width:28rem}.ask-feature-prompt-button{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;cursor:pointer;font-size:.875rem;padding:.75rem;text-align:left;transition:background-color .2s}.ask-feature-prompt-button:hover{background-color:#f9fafb}.ask-feature-previous-prompts{margin-top:2rem}.ask-feature-previous-title{align-items:center;color:#374151;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;margin-bottom:.75rem}.ask-feature-previous-icon{color:#3b82f6}.ask-feature-previous-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:1fr;margin:0 auto;max-width:28rem}.ask-feature-previous-button{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;cursor:pointer;font-size:.875rem;padding:.75rem;text-align:left;transition:background-color .2s}.ask-feature-previous-button:hover{background-color:#f3f4f6}.ask-feature-previous-content{color:#111827}.ask-feature-previous-timestamp{color:#6b7280;font-size:.75rem;margin-top:.25rem}.ask-feature-message-container{margin-bottom:1rem;width:100%}.ask-feature-message-container.user{display:flex;justify-content:flex-end}.ask-feature-message-container.ai{display:flex;justify-content:flex-start}.ask-feature-message-wrapper{align-items:flex-end;display:flex;gap:.5rem;justify-content:flex-end;max-width:20rem;width:100%}.ask-feature-message-wrapper.ai{align-items:flex-start;gap:.75rem;justify-content:flex-start;max-width:42rem}.ask-feature-message-content{align-items:flex-end;display:flex;flex-direction:column}.ask-feature-message-content.ai{align-items:flex-start}.ask-feature-message-bubble{border-radius:1rem;box-shadow:0 1px 3px 0 #0000001a;max-width:20rem;position:relative}.ask-feature-message-bubble.user{background-color:#2563eb;box-shadow:0 10px 15px -3px #0000001a;color:#000}.ask-feature-message-bubble.ai{background-color:#fff;border:1px solid #e5e7eb;color:#111827}.ask-feature-message-text{font-size:.875rem;font-weight:500;line-height:1.5;padding:.75rem 1rem;text-align:right;white-space:pre-wrap;word-break:break-words}.ask-feature-message-text.ai{font-weight:400;text-align:left}.ask-feature-message-tail{height:0;position:absolute;top:1rem;width:0}.ask-feature-message-tail.user{border-bottom:8px solid #0000;border-left:8px solid #2563eb;border-top:8px solid #0000;right:0;transform:translateX(100%)}.ask-feature-message-tail.ai{border-bottom:8px solid #0000;border-right:8px solid #fff;border-top:8px solid #0000;left:0;transform:translateX(-100%)}.ask-feature-message-timestamp{align-items:center;display:flex;flex-direction:row-reverse;gap:.5rem;margin-top:.5rem}.ask-feature-message-timestamp.ai{flex-direction:row}.ask-feature-timestamp-text{color:#6b7280;font-size:.75rem;text-align:right}.ask-feature-timestamp-text.ai{text-align:left}.ask-feature-message-actions{align-items:center;display:flex;gap:.25rem;opacity:0;transition:opacity .2s}.ask-feature-message-container:hover .ask-feature-message-actions{opacity:1}.ask-feature-action-button{background:none;border:none;border-radius:.25rem;color:#9ca3af;cursor:pointer;font-size:.875rem;padding:.25rem;transition:all .2s}.ask-feature-action-button:hover{background-color:#f3f4f6;color:#4b5563;transform:scale(1.1)}.ask-feature-action-button:active{transform:scale(.95)}.ask-feature-avatar{align-items:center;border-radius:50%;box-shadow:0 1px 3px 0 #0000001a;display:flex;flex-shrink:0;height:2.5rem;justify-content:center;width:2.5rem}.ask-feature-avatar.user{background-color:#2563eb;border:2px solid #1d4ed8}.ask-feature-avatar.ai{background-color:#f3f4f6;border:1px solid #e5e7eb}.ask-feature-avatar svg{font-size:.875rem}.ask-feature-avatar.user svg{color:#000}.ask-feature-avatar.ai svg{color:#3b82f6}.ask-feature-typing-container{display:flex;justify-content:flex-start;margin-bottom:1rem}.ask-feature-typing-wrapper{align-items:flex-start;display:flex;gap:.75rem;max-width:42rem}.ask-feature-typing-bubble{background-color:#fff;border:1px solid #e5e7eb;border-radius:1rem;box-shadow:0 1px 3px 0 #0000001a;color:#111827;position:relative}.ask-feature-typing-content{padding:.75rem 1rem}.ask-feature-typing-text{align-items:center;display:flex;gap:.5rem}.ask-feature-typing-dots{display:flex;gap:.25rem}.ask-feature-typing-dot{animation:bounce 1.4s ease-in-out infinite both;background-color:#9ca3af;border-radius:50%;height:.5rem;width:.5rem}.ask-feature-typing-dot:nth-child(2){animation-delay:.1s}.ask-feature-typing-dot:nth-child(3){animation-delay:.2s}.ask-feature-typing-tail{border-bottom:8px solid #0000;border-right:8px solid #fff;border-top:8px solid #0000;height:0;left:0;position:absolute;top:1rem;transform:translateX(-100%);width:0}.ask-feature-previous-section{background-color:#f9fafb;border-radius:.5rem;margin:0 1rem 1rem;padding:1rem}.ask-feature-previous-section-title{align-items:center;color:#374151;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;margin-bottom:.75rem}.ask-feature-previous-section-icon{color:#3b82f6}.ask-feature-previous-section-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.ask-feature-previous-section-button{background-color:#fff;border:1px solid #e5e7eb;border-radius:9999px;color:#374151;cursor:pointer;font-size:.875rem;padding:.5rem .75rem;transition:all .2s}.ask-feature-previous-section-button:hover{background-color:#f3f4f6;border-color:#93c5fd}.ask-feature-input-container{background-color:#fff;border-top:1px solid #e5e7eb;padding:1rem}.ask-feature-input-wrapper{align-items:flex-end;display:flex;gap:.75rem}.ask-feature-input-field{flex:1 1;position:relative}.ask-feature-textarea{border:1px solid #d1d5db;border-radius:9999px;max-height:7.5rem;min-height:3rem;outline:none;padding:.75rem 3rem .75rem 1rem;resize:none;transition:all .2s;width:100%}.ask-feature-textarea:focus{ring:2px;ring-color:#3b82f6;border-color:#0000}.ask-feature-textarea:disabled{background-color:#f3f4f6;cursor:not-allowed}.ask-feature-textarea:not(:disabled):hover{border-color:#9ca3af}.ask-feature-send-button{align-items:center;border:none;border-radius:50%;cursor:pointer;display:flex;height:2rem;justify-content:center;position:absolute;right:.5rem;top:50%;transform:translateY(-50%);transition:all .2s;width:2rem}.ask-feature-send-button:disabled{background-color:#d1d5db;color:#6b7280;cursor:not-allowed}.ask-feature-send-button:not(:disabled){background-color:#3b82f6;color:#fff}.ask-feature-send-button:not(:disabled):hover{background-color:#2563eb;transform:translateY(-50%) scale(1.05)}.ask-feature-input-footer{align-items:center;color:#6b7280;display:flex;font-size:.75rem;justify-content:space-between;margin-top:.75rem}.ask-feature-input-footer-left{align-items:center;display:flex;gap:1rem}.ask-feature-status-indicator{align-items:center;display:flex;gap:.25rem}.ask-feature-status-dot{background-color:#10b981;border-radius:50%;height:.5rem;width:.5rem}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.icon-snapshot:before{content:"📸";margin-right:4px}.icon-refresh:before{content:"🔄";margin-right:4px}.icon-download:before{content:"⬇️";margin-right:4px}.icon-chart:before{content:"📈";margin-right:4px}.icon-settings:before{content:"⚙️";margin-right:4px}.icon-trend-up:before{content:"↗";margin-right:4px}.icon-trend-down:before{content:"↘";margin-right:4px}.icon-calendar:before{content:"📅";margin-right:4px}.icon-graph:before{content:"📊";margin-right:4px}.icon-clock:before{content:"⏱️";margin-right:4px}.toggle-container,.toggle-wrapper{position:relative}.toggle-wrapper{background-color:#f9fafb;border:none;border-radius:1rem;display:flex;padding:.125rem;width:12rem}.toggle-slider{background-color:#e5e7eb;border:none;border-radius:.75rem;bottom:.25rem;box-shadow:0 1px 2px 0 #0000000d;position:absolute;top:.25rem;transition:all .3s ease-out;width:calc(50% - 2px)}.toggle-slider.all-time{transform:translateX(0)}.toggle-slider.daily{transform:translateX(100%)}.toggle-button{background:none;border:none;border-radius:.75rem;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:500;padding:.5rem 1rem;position:relative;transition:color .3s ease;z-index:10}.toggle-button.active{color:#1f2937}.toggle-button.inactive{color:#d1d5db}.toggle-button:hover{color:#6b7280}.portfolio-container{background-color:#f9fafb;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;min-height:100vh}.portfolio-top-bar{background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;padding:12px 16px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.portfolio-top-bar-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px}.portfolio-back-button{background:none;border:none;border-radius:6px;color:#6b7280;cursor:pointer;font-size:16px;padding:8px;transition:background-color .2s}.portfolio-back-button:hover{background-color:#f3f4f6}.portfolio-title{color:#111827;font-size:28px;font-weight:700;margin:0}.portfolio-main-content{box-sizing:border-box;flex:1 1;margin:0 auto;max-width:1200px;padding:16px;width:100%}.portfolio-content-grid{grid-gap:24px;display:grid;gap:24px}.portfolio-summary-card{background-color:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px;transition:box-shadow .2s}.portfolio-summary-card:hover{box-shadow:0 4px 6px #0000001a}.portfolio-summary-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:16px}.portfolio-summary-title{color:#111827;font-size:24px;font-weight:600;margin:0}.portfolio-action-buttons{display:flex;flex-wrap:wrap;gap:8px}.portfolio-refresh-button{align-items:center;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:none;border-radius:8px;box-shadow:0 2px 4px #3b82f64d;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;overflow:hidden;padding:10px 16px;position:relative;transition:all .2s}.portfolio-refresh-button:hover{background:linear-gradient(135deg,#2563eb,#1e40af);box-shadow:0 4px 8px #3b82f666;transform:translateY(-1px)}.portfolio-refresh-button:active{transform:translateY(0)}.portfolio-refresh-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.portfolio-refresh-icon{height:16px;transition:transform .2s;width:16px}.portfolio-refresh-button:hover .portfolio-refresh-icon{transform:rotate(180deg)}.portfolio-refresh-spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}.portfolio-watchlist-button{align-items:center;background-color:#10b981;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 16px;text-decoration:none;transition:all .2s}.portfolio-watchlist-button:hover{background-color:#059669;transform:translateY(-1px)}.portfolio-graph-button{align-items:center;background-color:#8b5cf6;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 16px;transition:all .2s}.portfolio-graph-button:hover{background-color:#7c3aed;transform:translateY(-1px)}.portfolio-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:16px}.portfolio-stat-item{text-align:left}.portfolio-stat-label{color:#6b7280;font-size:18px;margin-bottom:6px}.portfolio-stat-value{color:#111827;font-size:32px;font-weight:700;margin:0}.portfolio-gainloss-section{border-top:1px solid #e5e7eb;margin-top:16px;padding-top:16px}.portfolio-gainloss-content{align-items:center;display:flex;justify-content:space-between}.portfolio-gainloss-label{color:#6b7280;font-size:18px}.portfolio-gainloss-values{text-align:right}.portfolio-gainloss-amount{font-size:20px;font-weight:600}.portfolio-gainloss-percent{font-size:16px;margin-left:8px}.portfolio-gainloss-positive{color:#059669}.portfolio-gainloss-negative{color:#dc2626}.portfolio-search-container{margin-bottom:24px}.portfolio-search-input{background-color:#fff;border:1px solid #d1d5db;border-radius:12px;box-sizing:border-box;font-size:18px;padding:16px 20px 16px 48px;transition:all .2s;width:100%}.portfolio-search-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.portfolio-search-icon{color:#9ca3af;font-size:18px;left:16px;position:absolute;top:50%;transform:translateY(-50%)}.portfolio-stock-list{grid-gap:12px;display:grid;gap:12px}.portfolio-stock-item{background-color:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;cursor:pointer;padding:16px;transition:all .2s}.portfolio-stock-item:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-1px)}.portfolio-stock-content{align-items:center;display:flex;gap:16px;justify-content:space-between}.portfolio-stock-info{flex:1 1;min-width:0}.portfolio-stock-symbol{color:#111827;font-size:20px;font-weight:600;margin-bottom:6px}.portfolio-stock-name{color:#6b7280;font-size:16px;margin-bottom:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.portfolio-stock-price{color:#111827;font-size:20px;font-weight:600;text-align:right}.portfolio-buy-button{background-color:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s;white-space:nowrap}.portfolio-buy-button:hover{background-color:#2563eb}.portfolio-mystocks-card{background-color:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}.portfolio-mystocks-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:16px}.portfolio-mystocks-title{color:#111827;font-size:24px;font-weight:600;margin:0}.portfolio-toggle-container{align-items:center;display:flex}.portfolio-toggle-wrapper{background-color:#f3f4f6;border-radius:8px;display:flex;padding:2px;position:relative}.portfolio-toggle-slider{background-color:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a;height:calc(100% - 4px);left:2px;position:absolute;top:2px;transition:transform .2s;width:calc(50% - 2px)}.portfolio-toggle-slider.all-time{transform:translateX(0)}.portfolio-toggle-slider.daily{transform:translateX(100%)}.portfolio-toggle-button{background:none;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;position:relative;transition:color .2s;z-index:1}.portfolio-toggle-button.active{color:#111827}.portfolio-toggle-button.inactive{color:#6b7280}.portfolio-holdings-list{grid-gap:12px;display:grid;gap:12px}.portfolio-holding-item{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.portfolio-holding-header{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:12px}.portfolio-holding-info{flex:1 1;min-width:0}.portfolio-holding-symbol{color:#111827;font-size:20px;font-weight:600;margin-bottom:6px}.portfolio-holding-details{color:#6b7280;font-size:16px;margin-bottom:6px}.portfolio-holding-current-price{font-size:16px;font-weight:500}.portfolio-holding-current-price.positive{color:#059669}.portfolio-holding-current-price.negative{color:#dc2626}.portfolio-holding-current-price.neutral{color:#3b82f6}.portfolio-holding-value{text-align:right}.portfolio-holding-total-value{color:#111827;font-size:20px;font-weight:600;margin-bottom:6px}.portfolio-holding-total-label{color:#6b7280;font-size:16px}.portfolio-sell-button{background-color:#6b7280;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .2s;white-space:nowrap}.portfolio-sell-button:hover{background-color:#4b5563}.portfolio-holding-gainloss{align-items:center;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;padding-top:12px}.portfolio-holding-gainloss-values{text-align:right}.portfolio-holding-gainloss-amount{font-size:18px;font-weight:500;margin-bottom:4px}.portfolio-holding-gainloss-percent{font-size:16px}.portfolio-empty-state{padding:32px 16px;text-align:center}.portfolio-empty-title{color:#111827;font-size:24px;font-weight:600;margin-bottom:12px}.portfolio-empty-description{color:#6b7280;font-size:16px;margin-bottom:20px}.portfolio-empty-debug{color:#9ca3af;font-size:12px;margin-top:8px}.portfolio-loading-container{align-items:center;display:flex;justify-content:center;padding:32px}.portfolio-loading-spinner{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;height:32px;width:32px}.portfolio-loading-text{color:#6b7280;margin-left:12px}.portfolio-modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:16px;position:fixed;right:0;top:0;z-index:1000}.portfolio-modal{background-color:#fff;border-radius:12px;max-height:90vh;max-width:400px;overflow-y:auto;padding:24px;width:100%}.portfolio-modal-title{color:#111827;font-size:18px;font-weight:600;margin-bottom:16px}.portfolio-modal-content{grid-gap:16px;display:grid;gap:16px}.portfolio-modal-field{grid-gap:8px;display:grid;gap:8px}.portfolio-modal-label{color:#374151;font-size:14px;font-weight:500}.portfolio-modal-input{border:1px solid #d1d5db;border-radius:8px;font-size:16px;padding:12px;transition:border-color .2s}.portfolio-modal-input:focus{border-color:#3b82f6;outline:none}.portfolio-modal-price{color:#111827;font-size:20px;font-weight:700}.portfolio-modal-summary{background-color:#f9fafb;border-radius:8px;padding:12px}.portfolio-modal-summary-row{display:flex;font-size:14px;justify-content:space-between;margin-bottom:4px}.portfolio-modal-summary-row:last-child{margin-bottom:0}.portfolio-modal-summary-value{font-weight:600}.portfolio-modal-actions{display:flex;gap:12px;margin-top:24px}.portfolio-modal-button{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:12px;transition:all .2s}.portfolio-modal-button-cancel{background-color:#f3f4f6;color:#374151}.portfolio-modal-button-cancel:hover{background-color:#e5e7eb}.portfolio-modal-button-primary{background-color:#3b82f6;color:#fff}.portfolio-modal-button-primary:hover{background-color:#2563eb}.portfolio-modal-button-secondary{background-color:#6b7280;color:#fff}.portfolio-modal-button-secondary:hover{background-color:#4b5563}.portfolio-modal-button:disabled{cursor:not-allowed;opacity:.5}.portfolio-bottom-nav{background-color:#fff;border-top:1px solid #e5e7eb;bottom:0;display:flex;justify-content:space-around;padding:8px 0;position:-webkit-sticky;position:sticky;z-index:100}.portfolio-nav-item{align-items:center;background:none;border:none;color:#6b7280;cursor:pointer;display:flex;flex-direction:column;font-size:12px;gap:4px;padding:8px 12px;text-decoration:none;transition:color .2s}.portfolio-nav-item:hover{color:#374151}.portfolio-nav-item.active{color:#3b82f6}.portfolio-nav-icon{font-size:20px}.portfolio-locked-container{background-color:#f9fafb;display:flex;flex-direction:column;min-height:100vh}.portfolio-locked-content{align-items:center;display:flex;flex:1 1;justify-content:center;padding:24px}.portfolio-locked-card{max-width:400px;text-align:center;width:100%}.portfolio-locked-icon{align-items:center;background-color:#f3f4f6;border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto 24px;width:80px}.portfolio-locked-icon svg{color:#9ca3af;font-size:32px}.portfolio-locked-title{color:#111827;font-size:24px;font-weight:700;margin-bottom:16px}.portfolio-locked-description{color:#6b7280;line-height:1.5;margin-bottom:24px}.portfolio-locked-progress{background-color:#dbeafe;border-radius:12px;margin-bottom:24px;padding:16px}.portfolio-locked-progress-text{color:#1e40af;font-size:14px}.portfolio-locked-button{background-color:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:background-color .2s}.portfolio-locked-button:hover{background-color:#2563eb}@media (max-width:768px){.portfolio-main-content{padding:12px}.portfolio-content-grid{gap:16px}.portfolio-mystocks-card,.portfolio-summary-card{padding:16px}.portfolio-summary-header{align-items:stretch;flex-direction:column}.portfolio-action-buttons{justify-content:center}.portfolio-stats-grid{gap:12px;grid-template-columns:1fr}.portfolio-stock-content{align-items:stretch;flex-direction:column;gap:12px}.portfolio-stock-info,.portfolio-stock-price{text-align:center}.portfolio-holding-header{align-items:stretch;flex-direction:column;gap:12px}.portfolio-holding-info,.portfolio-holding-value{text-align:center}.portfolio-modal{margin:16px;max-width:none}.portfolio-modal-actions{flex-direction:column}.portfolio-nav-item{font-size:11px;padding:6px 8px}.portfolio-nav-icon{font-size:18px}}@media (max-width:480px){.portfolio-top-bar{padding:8px 12px}.portfolio-title{font-size:24px}.portfolio-main-content{padding:8px}.portfolio-content-grid{gap:12px}.portfolio-mystocks-card,.portfolio-summary-card{padding:12px}.portfolio-action-buttons{flex-direction:column;width:100%}.portfolio-graph-button,.portfolio-refresh-button,.portfolio-watchlist-button{justify-content:center;width:100%}.portfolio-stat-value{font-size:28px}.portfolio-holding-item,.portfolio-stock-item{padding:12px}.portfolio-modal{margin:8px;padding:16px}.portfolio-locked-content{padding:16px}.portfolio-locked-card{max-width:none}.portfolio-dropdown{max-height:250px}.portfolio-dropdown-item{font-size:13px;padding:12px 14px}.portfolio-featured-toggle,.portfolio-holdings-toggle{font-size:14px;padding:12px 14px}}.portfolio-search-container{margin-bottom:16px;position:relative}.portfolio-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #00000026;left:0;margin-top:4px;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.portfolio-dropdown-item{align-items:center;border-bottom:1px solid #f3f4f6;cursor:pointer;display:flex;font-size:14px;justify-content:space-between;padding:14px 16px;transition:all .2s}.portfolio-dropdown-item:hover{background-color:#f3f4f6}.portfolio-dropdown-item:last-child{border-bottom:none}.portfolio-dropdown-item strong{color:#111827;font-weight:600}.portfolio-dropdown-item>div:first-child{color:#374151;flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.portfolio-dropdown-item>div:last-child{color:#059669;font-weight:600;margin-left:12px;white-space:nowrap}.portfolio-featured-container,.portfolio-holdings-dropdown-container{margin-bottom:16px;position:relative}.portfolio-featured-toggle,.portfolio-holdings-toggle{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 1px 2px #0000000d;color:#111827;cursor:pointer;display:flex;font-size:15px;font-weight:600;justify-content:space-between;padding:14px 16px;transition:all .2s;width:100%}.portfolio-featured-toggle:hover,.portfolio-holdings-toggle:hover{background-color:#f9fafb;border-color:#d1d5db;box-shadow:0 2px 4px #0000001a}.portfolio-featured-toggle:active,.portfolio-holdings-toggle:active{transform:translateY(1px)}.portfolio-featured-toggle span:last-child,.portfolio-holdings-toggle span:last-child{color:#6b7280;font-size:12px;transition:transform .2s}.portfolio-featured-toggle span:first-child,.portfolio-holdings-toggle span:first-child{align-items:center;display:flex}.portfolio-featured-dropdown,.portfolio-holdings-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 12px #00000026;left:0;margin-top:4px;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:999}.portfolio-holding-dropdown-item{padding:14px 16px}.watchlist-container{background-color:#f9fafb;min-height:100vh}.watchlist-content{padding-bottom:120px}.watchlist-loading{align-items:center;background:linear-gradient(to bottom right,#eff6ff,#e0e7ff);display:flex;justify-content:center;min-height:100vh}.watchlist-loading-content{text-align:center}.watchlist-spinner{animation:spin 1s linear infinite;border-bottom:2px solid #2563eb;border-radius:50%;height:3rem;margin:0 auto 1rem;width:3rem}.watchlist-loading-text{color:#4b5563}.watchlist-top-bar{background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 2px 0 #0000000d;padding:.75rem 1rem}.watchlist-top-content{align-items:center;display:flex;justify-content:space-between}.watchlist-top-left{align-items:center;display:flex;gap:.75rem}.watchlist-back-button{background:none;border:none;color:#4b5563;cursor:pointer;font-size:1rem}.watchlist-title{color:#111827;font-size:1.25rem;font-weight:700}.watchlist-top-right{align-items:center;display:flex;gap:.5rem}.watchlist-toggle-button{background:none;border:none;border-radius:.5rem;color:#6b7280;cursor:pointer;padding:.5rem;transition:all .2s}.watchlist-toggle-button:hover{background-color:#f3f4f6;color:#374151}.watchlist-add-button{align-items:center;background-color:#3b82f6;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;gap:.25rem;padding:.5rem 1rem;transition:background-color .2s}.watchlist-add-button:hover{background-color:#2563eb}.watchlist-main{padding:1rem}.watchlist-search{margin-bottom:1.5rem}.watchlist-search-container{position:relative}.watchlist-search-icon{color:#9ca3af;left:.75rem;position:absolute;top:50%;transform:translateY(-50%)}.watchlist-search-input{border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;outline:none;padding:.75rem 1rem .75rem 2.5rem;transition:all .2s;width:100%}.watchlist-search-input:focus{ring:2px solid #3b82f6;border-color:#0000}.watchlist-empty{padding:3rem 0;text-align:center}.watchlist-empty-icon{color:#d1d5db;font-size:4rem;margin:0 auto 1rem}.watchlist-empty-title{color:#111827;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.watchlist-empty-text{color:#4b5563;margin-bottom:1.5rem}.watchlist-empty-button{align-items:center;background-color:#3b82f6;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;gap:.5rem;margin:0 auto;padding:.75rem 1.5rem;transition:background-color .2s}.watchlist-empty-button:hover{background-color:#2563eb}.watchlist-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(1,1fr)}@media (min-width:768px){.watchlist-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.watchlist-grid{grid-template-columns:repeat(3,1fr)}}.watchlist-stock-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 2px 0 #0000000d;padding:1.5rem;transition:box-shadow .2s}.watchlist-stock-card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.watchlist-stock-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.watchlist-stock-info h3{color:#111827;font-size:1.125rem;font-weight:700;margin:0}.watchlist-stock-info p{color:#4b5563;font-size:.875rem;margin:0}.watchlist-stock-actions{display:flex;gap:.5rem}.watchlist-action-button{background:none;border:none;border-radius:.5rem;color:#9ca3af;cursor:pointer;padding:.5rem;transition:all .2s}.watchlist-action-button:hover{background-color:#eff6ff;color:#3b82f6}.watchlist-action-button.delete:hover{background-color:#fef2f2;color:#dc2626}.watchlist-price-info{display:flex;flex-direction:column;gap:.5rem}.watchlist-price-row{align-items:center;display:flex;justify-content:space-between}.watchlist-price-label{color:#4b5563;font-size:.875rem}.watchlist-price-value{color:#111827;font-size:1.125rem;font-weight:700}.watchlist-change-container{align-items:center;display:flex;gap:.25rem}.watchlist-change.positive{color:#16a34a}.watchlist-change.negative{color:#dc2626}.watchlist-change-value{font-weight:600}.watchlist-notes{background-color:#f9fafb;border-radius:.5rem;margin-top:1rem;padding:.75rem}.watchlist-notes-text{color:#374151;font-size:.875rem;margin:0}.watchlist-date{color:#6b7280;font-size:.75rem;margin-top:1rem}.watchlist-modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:50}.watchlist-modal{background-color:#fff;border-radius:.75rem;box-shadow:0 25px 50px -12px #00000040;max-width:28rem;width:100%}.watchlist-modal-content{padding:1.5rem}.watchlist-modal-title{color:#111827;font-size:1.25rem;font-weight:700;margin-bottom:1rem}.watchlist-modal-form{gap:1rem}.watchlist-modal-form,.watchlist-modal-group{display:flex;flex-direction:column}.watchlist-modal-label{color:#374151;display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.watchlist-modal-input{border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;outline:none;padding:.75rem;transition:all .2s;width:100%}.watchlist-modal-input:focus{ring:2px solid #3b82f6;border-color:#0000}.watchlist-modal-textarea{border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;height:5rem;outline:none;padding:.75rem;resize:none;transition:all .2s;width:100%}.watchlist-modal-textarea:focus{ring:2px solid #3b82f6;border-color:#0000}.watchlist-modal-buttons{display:flex;gap:.75rem;margin-top:1.5rem}.watchlist-modal-button{border:none;border-radius:.5rem;cursor:pointer;flex:1 1;font-weight:500;padding:.5rem 1rem;transition:all .2s}.watchlist-modal-button.cancel{background-color:#fff;border:1px solid #d1d5db;color:#374151}.watchlist-modal-button.cancel:hover{background-color:#f9fafb}.watchlist-modal-button.primary{background-color:#3b82f6;color:#fff}.watchlist-modal-button.primary:hover{background-color:#2563eb}.nav-bottom{background-color:#fff;border-top:1px solid #e5e7eb;bottom:0;display:flex;justify-content:space-around;left:0;padding:.5rem 0;position:fixed;right:0;z-index:50}.nav-item{align-items:center;background:none;border:none;color:#6b7280;cursor:pointer;display:flex;flex-direction:column;padding:.5rem;transition:color .2s}.nav-item.active{color:#2563eb}.nav-item span{font-size:.75rem;margin-top:.25rem}.forum-container{background:#f5f5f5;min-height:100vh;padding-bottom:80px}.forum-top-bar{background:#fff;border-bottom:1px solid #e0e0e0;padding:1rem;position:-webkit-sticky;position:sticky;top:0;z-index:100}.forum-top-content{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin:0 auto;max-width:1200px}.forum-back-btn{align-items:center;background:none;border:none;color:#3b82f6;cursor:pointer;display:flex;font-size:1rem;gap:.5rem;padding:.5rem}.forum-title{color:#1f2937;flex:1 1;font-size:1.5rem;font-weight:700}.forum-create-btn{align-items:center;background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1.5rem}.forum-create-btn:hover{background:#2563eb}.forum-main-content{margin:0 auto;max-width:1200px;padding:1.5rem}.forum-filters{display:flex;gap:1rem;margin-bottom:1.5rem}.forum-filter-select{background:#fff;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;font-size:.9rem;padding:.75rem}.forum-posts-list{display:flex;flex-direction:column;gap:1rem}.forum-post-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;cursor:pointer;padding:1.5rem;transition:all .2s}.forum-post-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.forum-post-card-header{align-items:start;display:flex;justify-content:space-between;margin-bottom:.75rem}.forum-post-card-title{color:#1f2937;flex:1 1;font-size:1.25rem;font-weight:600}.forum-post-card-header-right{align-items:center;display:flex;gap:.5rem}.forum-post-card-category{background:#e0e7ff;border-radius:12px;color:#4f46e5;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.forum-post-card-delete-btn{align-items:center;background:#fee2e2;border:none;border-radius:6px;color:#dc2626;cursor:pointer;display:flex;font-size:.875rem;justify-content:center;padding:.5rem;transition:all .2s}.forum-post-card-delete-btn:hover{background:#fecaca;transform:scale(1.1)}.forum-post-card-meta{color:#6b7280;display:flex;font-size:.875rem;gap:1rem;margin-bottom:1rem}.forum-post-card-stats{color:#6b7280;display:flex;font-size:.875rem;gap:1.5rem}.forum-post-detail{background:#fff;border-radius:12px;margin-bottom:1.5rem;padding:2rem}.forum-post-header{align-items:start;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1.5rem}.forum-post-title{color:#1f2937;font-size:2rem;font-weight:700;margin-bottom:.75rem}.forum-post-info{color:#6b7280;display:flex;font-size:.9rem;gap:1rem}.forum-author{color:#3b82f6;font-weight:500}.forum-category{background:#e0e7ff;border-radius:12px;color:#4f46e5;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.forum-post-actions{align-items:center;display:flex;gap:.75rem}.forum-like-btn{align-items:center;background:#f3f4f6;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1.5rem}.forum-delete-btn,.forum-like-btn.liked{background:#fee2e2;color:#dc2626}.forum-delete-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;justify-content:center;padding:.75rem;transition:all .2s}.forum-delete-btn:hover{background:#fecaca;transform:scale(1.05)}.forum-post-content{color:#374151;font-size:1.1rem;line-height:1.8;margin-bottom:2rem;white-space:pre-wrap}.forum-comments-section{border-top:1px solid #e0e0e0;margin-top:2rem;padding-top:2rem}.forum-comments-title{color:#1f2937;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem}.forum-comment-form{margin-bottom:2rem}.forum-comment-input{border:1px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:1rem;margin-bottom:.75rem;padding:1rem;resize:vertical;width:100%}.forum-comment-btn{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem}.forum-comment-btn:hover{background:#2563eb}.forum-comments-list{display:flex;flex-direction:column;gap:1.5rem}.forum-comment{background:#f9fafb;border-left:3px solid #3b82f6;border-radius:8px;padding:1.5rem}.forum-comment-header{display:flex;justify-content:space-between;margin-bottom:.75rem}.forum-comment-author{color:#3b82f6;font-weight:500}.forum-comment-date{color:#6b7280;font-size:.875rem}.forum-comment-content{color:#374151;line-height:1.6;margin-bottom:.75rem}.forum-comment-like{align-items:center;background:none;border:none;color:#6b7280;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem}.forum-comment-like.liked{color:#dc2626}.forum-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.forum-modal{background:#fff;border-radius:12px;max-height:90vh;max-width:600px;overflow-y:auto;padding:2rem;width:100%}.forum-modal-title{color:#1f2937;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.forum-modal-input,.forum-modal-select{margin-bottom:1rem}.forum-modal-input,.forum-modal-select,.forum-modal-textarea{border:1px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:1rem;padding:.75rem;width:100%}.forum-modal-textarea{margin-bottom:1.5rem;resize:vertical}.forum-modal-actions{display:flex;gap:1rem;justify-content:flex-end}.forum-modal-btn{border:none;border-radius:8px;cursor:pointer;font-weight:500;padding:.75rem 1.5rem}.forum-modal-btn-cancel{background:#f3f4f6;color:#374151}.forum-modal-btn-primary{background:#3b82f6;color:#fff}.forum-modal-btn-primary:hover{background:#2563eb}.forum-bottom-nav{background:#fff;border-top:1px solid #e0e0e0;bottom:0;display:flex;justify-content:space-around;left:0;padding:.75rem 0;position:fixed;right:0;z-index:100}.forum-nav-item{align-items:center;background:none;border:none;color:#6b7280;cursor:pointer;display:flex;flex-direction:column;font-size:.75rem;gap:.25rem;padding:.5rem}.forum-nav-icon{font-size:1.25rem}.forum-loading{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:50vh}.forum-spinner{animation:spin 1s linear infinite;border:4px solid #e0e0e0;border-radius:50%;border-top-color:#3b82f6;height:40px;width:40px}.forum-empty{color:#6b7280;padding:4rem 2rem;text-align:center}.forum-empty-icon{color:#d1d5db;font-size:4rem;margin-bottom:1rem}@media (max-width:768px){.forum-main-content{padding:1rem}.forum-post-detail{padding:1.5rem}.forum-post-title{font-size:1.5rem}.forum-filters{flex-direction:column}}.forum-leaderboard-card{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;margin-bottom:1.5rem;padding:1.5rem}.forum-leaderboard-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.forum-leaderboard-header h2{align-items:center;color:#1f2937;display:flex;font-size:1.25rem;gap:.5rem;margin:0}.forum-close-btn{background:none;border:none;color:#6b7280;cursor:pointer;font-size:1.5rem;line-height:1;padding:.25rem .5rem}.forum-close-btn:hover{color:#1f2937}.forum-leaderboard-list{display:flex;flex-direction:column;gap:.75rem}.forum-leaderboard-item{align-items:center;background:#f9fafb;border-radius:8px;display:flex;gap:1rem;padding:.75rem}.forum-leaderboard-rank{font-size:1.25rem;min-width:40px;text-align:center}.rank-number{color:#6b7280;font-weight:600}.forum-leaderboard-user{align-items:center;display:flex;flex:1 1;justify-content:space-between}.forum-leaderboard-name{color:#1f2937;font-weight:500}.forum-leaderboard-points{color:#3b82f6;font-weight:600}.forum-top-actions{align-items:center;display:flex;gap:.75rem}.forum-leaderboard-btn{align-items:center;background:#f59e0b;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:background-color .2s}.forum-leaderboard-btn:hover{background:#d97706}.forum-contribution-badge{align-items:center;background:#fef3c7;border-radius:6px;color:#92400e;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem .75rem}.forum-contribution-btn{align-items:center;background:#f59e0b;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;padding:.5rem 1rem;transition:background-color .2s}.forum-contribution-btn:hover{background:#d97706}.forum-post-card-contribution{align-items:center;color:#f59e0b;display:inline-flex;font-size:.875rem}.forum-post-card-contribution-btn{background:none;border:none;border-radius:4px;color:#f59e0b;cursor:pointer;padding:.25rem .5rem;transition:background-color .2s}.forum-post-card-contribution-btn:hover{background:#fef3c7}.user-stats-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.user-stats-modal{background:#fff;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;margin:auto;max-height:90vh;max-width:90vw;overflow-y:auto;position:relative;width:600px;z-index:1001}.user-stats-modal-header{background:#fff;border-bottom:1px solid #e5e7eb;display:flex;justify-content:flex-end;padding:1rem;position:-webkit-sticky;position:sticky;top:0;z-index:10}.user-stats-modal-close{align-items:center;background:none;border:none;border-radius:.5rem;color:#6b7280;cursor:pointer;display:flex;font-size:1.5rem;justify-content:center;padding:.5rem;transition:all .2s}.user-stats-modal-close:hover{background:#f3f4f6;color:#111827}.user-stats-modal-content{padding:2rem}.user-stats-modal-error,.user-stats-modal-loading{color:#6b7280;padding:4rem 2rem;text-align:center}.user-stats-modal-loading .loading-spinner{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#2563eb;height:3rem;margin:0 auto 1rem;width:3rem}.user-stats-profile{border-bottom:1px solid #e5e7eb;margin-bottom:2rem;padding-bottom:2rem;text-align:center}.user-stats-avatar,.user-stats-avatar-default{border:4px solid #e5e7eb;border-radius:50%;box-shadow:0 4px 6px -1px #0000001a;height:5rem;margin:0 auto 1rem;object-fit:cover;width:5rem}.user-stats-avatar-default{align-items:center;display:flex;justify-content:center}.user-stats-initials{color:#fff;font-size:2rem;font-weight:700}.user-stats-name{color:#111827;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.user-stats-level{color:#6b7280;font-size:.875rem}.user-stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);margin-bottom:2rem}.user-stat-card{background:linear-gradient(to bottom right,#eff6ff,#e0e7ff);border:1px solid #dbeafe;border-radius:.75rem;padding:1.5rem;text-align:center;transition:all .2s}.user-stat-card:hover{box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-2px)}.user-stat-icon{align-items:center;border-radius:50%;color:#fff;display:flex;font-size:1.25rem;height:3rem;justify-content:center;margin:0 auto .75rem;width:3rem}.user-stat-icon.xp{background:linear-gradient(135deg,#eab308,#f59e0b)}.user-stat-icon.streak{background:linear-gradient(135deg,#f97316,#ef4444)}.user-stat-icon.portfolio{background:linear-gradient(135deg,#2563eb,#3b82f6)}.user-stat-icon.earnings{background:linear-gradient(135deg,#10b981,#059669)}.user-stat-icon.investing{background:linear-gradient(135deg,#06b6d4,#0891b2)}.user-stat-icon.quizzes{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.user-stat-icon.facts{background:linear-gradient(135deg,#ec4899,#db2777)}.user-stat-icon.lessons{background:linear-gradient(135deg,#6366f1,#4f46e5)}.user-stat-value{color:#111827;font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.user-stat-label{color:#6b7280;font-size:.875rem;font-weight:500}.user-stats-badges{border-top:1px solid #e5e7eb;margin-top:2rem;padding-top:2rem}.user-stats-section-title{align-items:center;color:#111827;display:flex;font-size:1.25rem;font-weight:600;gap:.5rem;margin-bottom:1rem}.user-stats-badges-list{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}@media (max-width:640px){.user-stats-modal{max-height:95vh;width:95vw}.user-stats-grid{grid-template-columns:1fr}.user-stats-modal-content{padding:1.5rem}}.leaderboard-container{background:linear-gradient(135deg,#2563eb,#10b981);color:#fff;min-height:100vh;padding:2rem}.leaderboard-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.header-left{align-items:center;display:flex;gap:1rem}.back-button{background:#fff3;gap:.5rem}.back-button:hover{background:#ffffff4d;transform:translateX(-3px)}.leaderboard-title{align-items:center;color:#fff;display:flex;font-size:2.5rem;font-weight:700;gap:1rem;margin:0}.leaderboard-controls{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.type-selector{display:flex;flex-wrap:wrap;gap:1rem}.type-button{align-items:center;background:#ffffff1a;border:2px solid #fff3;border-radius:12px;color:#fff;cursor:pointer;display:flex;flex:1 1;font-size:1rem;font-weight:500;gap:.5rem;justify-content:center;min-width:150px;padding:1rem;transition:all .3s ease}.type-button:hover{background:#fff3;border-color:#fff6}.type-button.active{background:#ffffff4d;border-color:#fff;box-shadow:0 4px 12px #0003}.my-rank-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:2px solid #ffffff4d;border-radius:16px;padding:1.5rem}.rank-label{color:#fff;font-size:.9rem;margin-bottom:.5rem;opacity:.9}.rank-value{color:#fff;font-size:2.5rem;font-weight:700;margin-bottom:1rem}.rank-stats{display:flex;flex-direction:column;gap:.5rem}.stat-item{align-items:center;display:flex;justify-content:space-between}.stat-label{color:#fff}.stat-value{font-size:1.1rem;font-weight:600}.leaderboard-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:16px;padding:1.5rem}.leaderboard-list{display:flex;flex-direction:column;gap:1rem}.leaderboard-entry{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:2px solid #fff3;border-radius:12px;display:flex;gap:1.5rem;padding:1.5rem;transition:all .3s ease}.leaderboard-entry:hover{background:#fff3;border-color:#fff6;box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.leaderboard-entry.current-user{background:#ffd70033;border-color:#ffd70080;box-shadow:0 4px 16px #ffd7004d}.entry-rank{font-size:1.5rem;font-weight:700;min-width:60px}.entry-avatar-container,.entry-rank{align-items:center;display:flex;justify-content:center}.entry-avatar-container{cursor:pointer;height:50px;min-width:50px;transition:transform .2s;width:50px}.entry-avatar-container:hover{transform:scale(1.1)}.entry-avatar{object-fit:cover}.entry-avatar,.entry-avatar-default{border:2px solid #ffffff4d;border-radius:50%;box-shadow:0 2px 4px #0003;height:50px;width:50px}.entry-avatar-default{align-items:center;display:flex;justify-content:center}.entry-avatar-initials{color:#fff;font-size:1.25rem;font-weight:700}.rank-icon{font-size:2.5rem}.rank-icon.gold{color:gold;filter:drop-shadow(0 2px 4px rgba(255,215,0,.5))}.rank-icon.silver{color:silver;filter:drop-shadow(0 2px 4px rgba(192,192,192,.5))}.rank-icon.bronze{color:#cd7f32;filter:drop-shadow(0 2px 4px rgba(205,127,50,.5))}.rank-number{color:#fff;font-size:1.5rem;font-weight:700;opacity:.9}.entry-info{display:flex;flex:1 1;flex-direction:column;gap:.75rem}.entry-name{align-items:center;color:#fff;display:flex;font-size:1.2rem;font-weight:600;gap:.5rem}.you-badge{background:#ffd7004d;border:1px solid #ffd70080;border-radius:12px;color:gold;font-size:.8rem;font-weight:600;padding:.25rem .75rem}.entry-details{display:flex;flex-wrap:wrap;gap:1.5rem}.detail-item{align-items:center;display:flex;gap:.5rem}.detail-label{color:#fff;font-size:.9rem;opacity:.8}.detail-value{color:#fff;font-size:.95rem;font-weight:600}.detail-value.positive{color:#4ade80}.detail-value.negative{color:#f87171}.entry-primary-value{min-width:150px;text-align:right}.primary-label{color:#fff;font-size:.85rem;margin-bottom:.25rem;opacity:.8}.primary-amount{color:#fff;font-size:1.5rem;font-weight:700}.primary-amount.positive{color:#4ade80}.primary-amount.negative{color:#f87171}.your-entry-separator{align-items:center;display:flex;gap:1rem;margin:2rem 0}.separator-line{background:#ffffff4d;flex:1 1;height:2px}.separator-text{color:#fff;font-size:.9rem;opacity:.8;white-space:nowrap}.loading-spinner{color:#fff;font-size:1.2rem}.empty-state,.loading-spinner{padding:4rem;text-align:center}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state p{color:#fff;font-size:1.2rem;opacity:.8}.leaderboard-footer{color:#fff;font-size:.9rem;margin-top:2rem;opacity:.8;text-align:center}.leaderboard-footer p{color:#fff}@media (max-width:768px){.leaderboard-container{padding:1rem}.leaderboard-title{color:#fff;font-size:1.8rem}.type-selector{flex-direction:column}.type-button{color:#fff;min-width:100%}.leaderboard-entry{align-items:flex-start;flex-direction:column;gap:1rem}.entry-avatar-container,.entry-rank{align-self:flex-start}.entry-primary-value{text-align:left;width:100%}.entry-details{flex-direction:column;gap:.5rem}.detail-label,.detail-value,.entry-name,.primary-amount,.primary-label,.rank-label,.rank-value,.stat-label,.stat-value{color:#fff}}@media (max-width:480px){.leaderboard-container{padding:.75rem}.leaderboard-title{font-size:1.5rem}.type-button{font-size:.9rem;padding:.75rem}.leaderboard-entry{padding:1rem}.entry-name{font-size:1rem}.detail-label,.detail-value{font-size:.85rem}.primary-amount{font-size:1.2rem}}.terms-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:2rem 0}.terms-content{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000001a;margin:0 1rem;max-width:800px;padding:3rem}.terms-header{margin-bottom:2rem;text-align:center}.terms-content h1{color:#2d3748;font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.terms-content h2{border-bottom:2px solid #e2e8f0;color:#2d3748;font-size:1.5rem;font-weight:600;margin-bottom:1rem;margin-top:2rem;padding-bottom:.5rem}.terms-content h3{color:#4a5568;font-size:1.2rem;font-weight:600;margin-bottom:.75rem;margin-top:1.5rem}.terms-content p{color:#4a5568;line-height:1.6;margin-bottom:1rem}.terms-content ul{margin-bottom:1rem;padding-left:1.5rem}.terms-content li{color:#4a5568;line-height:1.6;margin-bottom:.5rem}.terms-content strong{color:#2d3748;font-weight:600}.disclaimer{background:#fed7d7;border:1px solid #feb2b2;border-radius:8px;color:#c53030;font-weight:600;margin:1rem 0;padding:1rem}.contact-info{background:#f7fafc}@media (max-width:768px){.terms-content{margin:0 .5rem;padding:2rem 1.5rem}.terms-content h1{font-size:2rem}.terms-content h2{font-size:1.3rem}}.privacy-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:2rem 0}.privacy-content{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000001a;margin:0 1rem;max-width:900px;padding:3rem}.privacy-header{margin-bottom:2rem;text-align:center}.privacy-content h1{color:#2d3748;font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.last-updated{color:#718096;font-style:italic;margin-bottom:2rem;text-align:center}.privacy-content h2{border-bottom:2px solid #e2e8f0;color:#2d3748;font-size:1.5rem;font-weight:600;margin-bottom:1rem;margin-top:2rem;padding-bottom:.5rem}.privacy-content h3{color:#4a5568;font-size:1.2rem;font-weight:600;margin-bottom:.75rem;margin-top:1.5rem}.privacy-content h4{color:#2d3748;font-size:1rem;font-weight:600;margin-bottom:.5rem;margin-top:1rem}.privacy-content p{color:#4a5568;line-height:1.6;margin-bottom:1rem}.privacy-content ul{margin-bottom:1rem;padding-left:1.5rem}.privacy-content li{color:#4a5568;line-height:1.6;margin-bottom:.5rem}.privacy-content strong{color:#2d3748;font-weight:600}.info-section{background:#f7fafc;border-left:4px solid #667eea;border-radius:8px;margin:1rem 0;padding:1.5rem}.info-section h4{color:#2d3748;margin-top:0}.info-section ul{margin-bottom:0}.info-section li{margin-bottom:.25rem}.contact-info{background:#e6fffa;border:1px solid #81e6d9;border-radius:8px;margin:1rem 0;padding:1.5rem}.contact-info p{color:#234e52;margin-bottom:.5rem}.legal-notice{background:#e6fffa;border:1px solid #81e6d9;border-radius:8px;margin-top:2rem;padding:1rem}.legal-notice p{color:#234e52;font-size:.9rem;margin:0}@media (max-width:768px){.privacy-content{margin:0 .5rem;padding:2rem 1.5rem}.privacy-content h1{font-size:2rem}.privacy-content h2{font-size:1.3rem}.info-section{padding:1rem}}.patchnotes-container{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:2rem 0}.patchnotes-content{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000001a;margin:0 1rem;max-width:900px;padding:3rem}.patchnotes-header{margin-bottom:3rem;text-align:center}.back-button{background:#f7fafc;color:#667eea;display:inline-block;font-weight:600;margin-bottom:1rem;padding:.5rem 1rem}.back-button:hover{background:#e2e8f0;color:#4a5568}.patchnotes-content h1{color:#2d3748;font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.subtitle{color:#718096;font-size:1.1rem;margin-bottom:2rem;text-align:center}.patch-version{border-bottom:2px solid #e2e8f0;margin-bottom:3rem;padding-bottom:2rem}.patch-version:last-of-type{border-bottom:none}.version-header{justify-content:space-between;margin-bottom:1.5rem}.version-header,.version-info{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.version-header h2{font-size:1.8rem;font-weight:700;margin:0}.version-major{color:#e53e3e}.version-minor{color:#3182ce}.version-patch{color:#38a169}.version-type{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}.version-major+.version-type{background:#fed7d7;color:#c53030}.version-minor+.version-type{background:#bee3f8;color:#2c5282}.version-patch+.version-type{background:#c6f6d5;color:#22543d}.version-date{color:#718096;font-size:.9rem;margin:0}.change-group{margin-bottom:1.5rem}.change-category{border-left:3px solid #667eea;color:#4a5568;font-size:1.2rem;font-weight:600;margin-bottom:.75rem;margin-top:1rem;padding-left:.5rem}.change-list{list-style:none;margin-bottom:1rem;padding-left:0}.change-list li{color:#4a5568;line-height:1.8;margin-bottom:.5rem;padding-left:1.5rem;position:relative}.change-list li:before{color:#667eea;content:"•";font-size:1.2rem;font-weight:700;left:0;position:absolute}.patchnotes-footer{border-top:1px solid #e2e8f0;margin-top:3rem;padding-top:2rem;text-align:center}.footer-note{color:#4a5568;line-height:1.6;margin:0}.footer-note a{color:#667eea;font-weight:600;text-decoration:none}.footer-note a:hover{text-decoration:underline}.legal-links{border-top:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;margin-top:2rem;padding-top:2rem}.legal-link{background:#f7fafc;border-radius:8px;color:#667eea;font-weight:600;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.legal-link:hover{background:#e2e8f0;color:#4a5568}@media (max-width:768px){.patchnotes-content{margin:0 .5rem;padding:2rem 1.5rem}.patchnotes-content h1{font-size:2rem}.version-header{align-items:flex-start;flex-direction:column}.version-header h2{font-size:1.5rem}.change-category{font-size:1.1rem}.legal-links{flex-direction:column;gap:1rem}.legal-link{text-align:center;width:100%}}.profile-container{background-color:#f9fafb;min-height:100vh}.profile-content{gap:1.5rem;margin:0 auto;max-width:800px;padding:1rem}.profile-content,.profile-loading{display:flex;flex-direction:column}.profile-loading{align-items:center;background:linear-gradient(to bottom right,#eff6ff,#e0e7ff);gap:1rem;justify-content:center;min-height:100vh}.profile-loading .loading-spinner{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#2563eb;height:3rem;width:3rem}@keyframes spin{to{transform:rotate(1turn)}}.top-bar{background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 2px 0 #0000000d;padding:.75rem 1rem}.top-bar-content{justify-content:space-between}.top-bar-content,.top-bar-left{align-items:center;display:flex}.top-bar-left{gap:.75rem}.back-button{border-radius:.5rem;color:#6b7280;height:2.5rem;justify-content:center;text-decoration:none;transition:all .2s;width:2.5rem}.back-button:hover{background-color:#f3f4f6;color:#111827}.app-title,.back-icon{font-size:1.25rem}.app-title{color:#111827;font-weight:700;margin:0}.profile-header{align-items:center;background-color:#fff;border-radius:1rem;box-shadow:0 1px 2px 0 #0000000d;display:flex;flex-direction:column;gap:1rem;padding:2rem;text-align:center}.profile-picture-container{display:inline-block;position:relative}.profile-picture{object-fit:cover}.profile-picture,.profile-picture-default{border:4px solid #e5e7eb;border-radius:50%;box-shadow:0 4px 6px -1px #0000001a;height:8rem;width:8rem}.profile-picture-default{align-items:center;display:flex;justify-content:center}.profile-initials{color:#fff;font-size:2.5rem;font-weight:700}.profile-picture-edit{align-items:center;background-color:#2563eb;border:3px solid #fff;border-radius:50%;bottom:0;box-shadow:0 2px 4px #0003;color:#fff;cursor:pointer;display:flex;height:2.5rem;justify-content:center;position:absolute;right:0;transition:all .2s;width:2.5rem}.profile-picture-edit:hover{background-color:#1d4ed8;transform:scale(1.1)}.camera-icon{font-size:1rem}.profile-name{color:#111827;font-size:1.875rem;font-weight:700;margin:0}.profile-email{color:#6b7280;font-size:1rem;margin:0}.edit-button{align-items:center;background-color:#2563eb;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:.5rem;margin-top:.5rem;padding:.75rem 1.5rem;transition:all .2s}.edit-button:hover{background-color:#1d4ed8;box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-1px)}.edit-icon{font-size:1rem}.profile-form-container{background-color:#fff;border-radius:1rem;box-shadow:0 1px 2px 0 #0000000d;padding:1.5rem}.profile-form{gap:1.5rem}.form-group,.profile-form{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-label{align-items:center;color:#374151;display:flex;font-size:.875rem;font-weight:500;gap:.5rem}.label-icon{color:#6b7280;font-size:1rem}.form-input{background-color:#fff;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem;padding:.75rem;transition:all .2s}.form-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.form-input:disabled{background-color:#f3f4f6;cursor:not-allowed}.form-value{align-items:center;background-color:#f9fafb;border-radius:.5rem;color:#111827;display:flex;font-size:1rem;min-height:2.75rem;padding:.75rem}.form-value.read-only{color:#6b7280;font-style:italic}.form-actions{border-top:1px solid #e5e7eb;display:flex;gap:1rem;margin-top:1rem;padding-top:1.5rem}.cancel-button,.save-button{align-items:center;border:none;border-radius:.5rem;cursor:pointer;display:flex;flex:1 1;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:all .2s}.cancel-button{background-color:#f3f4f6;color:#374151}.cancel-button:hover:not(:disabled){background-color:#e5e7eb}.save-button{background-color:#2563eb;color:#fff}.save-button:hover:not(:disabled){background-color:#1d4ed8;box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-1px)}.cancel-button:disabled,.save-button:disabled{cursor:not-allowed;opacity:.6}.button-icon{font-size:1rem}.profile-stats{background-color:#fff;border-radius:1rem;box-shadow:0 1px 2px 0 #0000000d;padding:1.5rem}.stats-title{color:#111827;font-size:1.25rem;font-weight:600;margin-bottom:1rem}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.stat-card{border:none;border-radius:.75rem;box-shadow:0 4px 6px -1px #0000001a;padding:1.5rem}.stat-value{color:#fff;font-size:2rem;margin-bottom:.5rem}.stat-label{color:#ffffffe6;font-size:.875rem;font-weight:500}@media (min-width:640px){.stats-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width:640px){.profile-header{padding:1.5rem}.profile-picture,.profile-picture-default{height:6rem;width:6rem}.profile-initials{font-size:2rem}.form-actions{flex-direction:column}.cancel-button,.save-button{width:100%}}.not-found-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.not-found-content{background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:500px;padding:3rem 2rem;text-align:center;width:100%}.not-found-icon{color:#667eea;font-size:4rem;margin-bottom:1rem}.not-found-title{color:#333;font-size:6rem;font-weight:700;line-height:1;margin:0}.not-found-subtitle{color:#666;font-size:1.5rem;font-weight:500;margin:.5rem 0 1rem}.not-found-description{color:#888;line-height:1.6;margin-bottom:2rem}.not-found-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.not-found-btn{align-items:center;border:none;border-radius:10px;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.not-found-btn.primary{background:#667eea;color:#fff}.not-found-btn.primary:hover{background:#5a6fd8;transform:translateY(-2px)}.not-found-btn.secondary{background:#f8f9fa;border:2px solid #e9ecef;color:#333}.not-found-btn.secondary:hover{background:#e9ecef;transform:translateY(-2px)}@media (max-width:480px){.not-found-content{padding:2rem 1.5rem}.not-found-title{font-size:4rem}.not-found-actions{flex-direction:column}.not-found-btn{justify-content:center;width:100%}}.admin-panel{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.admin-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;display:flex;justify-content:space-between;margin-bottom:30px;padding:20px}.admin-header h1{color:#333;font-size:2rem;margin:0}.back-button{align-items:center;background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;gap:8px;padding:10px 20px;transition:all .3s ease}.back-button:hover{background:#5568d3;transform:translateY(-2px)}.admin-user-info{align-items:center;color:#667eea;display:flex;font-weight:600;gap:8px}.admin-tabs{display:flex;gap:10px;margin-bottom:20px}.admin-tabs button{align-items:center;background:#fff;border:none;border-radius:8px;color:#666;cursor:pointer;display:flex;flex:1 1;font-size:1rem;font-weight:600;gap:8px;justify-content:center;padding:15px 20px;transition:all .3s ease}.admin-tabs button:hover{background:#f0f0f0;transform:translateY(-2px)}.admin-tabs button.active{background:#667eea;color:#fff}.admin-content{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:30px}.loading{color:#666;font-size:1.2rem;padding:40px;text-align:center}.analytics-view{width:100%}.analytics-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 6px #0000001a;color:#fff;padding:25px;text-align:center}.stat-icon{font-size:2.5rem;margin-bottom:10px;opacity:.9}.stat-value{font-size:2.5rem;font-weight:700;margin-bottom:5px}.stat-label{font-size:.9rem;opacity:.9}.analytics-sections{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-top:30px}.analytics-section{background:#f8f9fa;border-radius:12px;padding:20px}.analytics-section h2{color:#333;font-size:1.5rem;margin-bottom:20px;margin-top:0}.top-users-list{display:flex;flex-direction:column;gap:10px}.top-user-item{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;gap:15px;padding:15px}.top-user-item .rank{color:#667eea;font-size:1.2rem;font-weight:700;min-width:40px}.top-user-item .name{color:#333;flex:1 1;font-weight:600}.top-user-item .xp{color:#764ba2;font-weight:600}.top-user-item .level{color:#666;font-size:.9rem}.recent-activity-list{display:flex;flex-direction:column;gap:10px;max-height:400px;overflow-y:auto}.activity-item{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;font-size:.9rem;gap:15px;padding:12px}.activity-item .activity-type{background:#667eea;border-radius:4px;color:#fff;font-size:.8rem;padding:4px 10px;text-transform:uppercase}.activity-item .activity-user{color:#333;flex:1 1}.activity-item .activity-time{color:#666;font-size:.85rem}.users-view{width:100%}.users-header{margin-bottom:20px}.search-box{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;gap:10px;padding:12px 15px}.search-box input{background:#0000;border:none;flex:1 1;font-size:1rem;outline:none}.users-table{overflow-x:auto}.users-table table{border-collapse:collapse;width:100%}.users-table th{background:#667eea;color:#fff;font-weight:600;padding:15px;text-align:left}.users-table td{border-bottom:1px solid #e0e0e0;padding:15px}.users-table tr:hover{background:#f8f9fa}.status-badges{display:flex;flex-wrap:wrap;gap:5px}.badge{border-radius:4px;font-size:.8rem;font-weight:600;padding:4px 10px}.badge.admin{background:#fbbf24;color:#78350f}.badge.master-admin{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 2px 4px #f59e0b4d;color:#fff;font-weight:700}.badge.banned{background:#ef4444;color:#fff}.badge.active{background:#10b981;color:#fff}.master-admin-badge{background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:12px;box-shadow:0 2px 4px #f59e0b4d;color:#fff;font-size:.75rem;font-weight:700;margin-left:10px;padding:4px 12px}.admin-level-badge{border-radius:8px;font-size:.7rem;font-weight:600;margin-left:10px;padding:4px 10px}.admin-level-badge.level-3{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.admin-level-badge.level-2{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.admin-level-badge.level-1{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff}.badge.level-3{background:#3b82f6;color:#fff}.badge.level-2{background:#10b981;color:#fff}.badge.level-1{background:#8b5cf6;color:#fff}.admin-communication-view{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;padding:20px}.communication-header{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.message-filters{display:flex;gap:10px}.message-filters button{background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;padding:8px 16px;transition:all .3s}.message-filters button.active{background:#667eea;border-color:#667eea;color:#fff}.btn-compose{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px}.compose-message{background:#f8f9fa;border-radius:8px;padding:20px}.compose-message,.send-to-section{margin-bottom:20px}.send-to-section>label{color:#333;display:block;font-size:1rem;font-weight:600;margin-bottom:12px}.send-to-options{gap:12px;padding-left:0}.send-to-options,.send-to-type{display:flex;flex-direction:column}.send-to-type{align-items:flex-start;gap:8px}.send-to-type>label{align-items:center;cursor:pointer;display:flex;font-weight:500;gap:10px;padding:4px 0;-webkit-user-select:none;user-select:none;width:100%}.send-to-type>label input[type=radio]{cursor:pointer;flex-shrink:0;height:18px;margin:0;width:18px}.send-to-type select{background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:.95rem;margin-left:28px;max-width:400px;padding:10px 12px;transition:border-color .2s;width:calc(100% - 28px)}.send-to-type select:hover{border-color:#667eea}.send-to-type select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.level-checkboxes{background:#fff;border:1px solid #ddd;border-radius:6px;display:flex;flex-wrap:wrap;gap:16px;margin-left:28px;max-width:400px;padding:12px 16px;width:calc(100% - 28px)}.level-checkboxes label{align-items:center;cursor:pointer;display:flex;font-weight:400;gap:8px;padding:4px 0;-webkit-user-select:none;user-select:none}.level-checkboxes input[type=checkbox]{cursor:pointer;flex-shrink:0;height:18px;margin:0;width:18px}.level-broadcast{background:#e0f2fe;border-radius:4px;color:#0369a1;font-size:.85rem;padding:4px 8px}.compose-message h3{color:#333;font-size:1.25rem;font-weight:600;margin:0 0 20px}.compose-message input[type=text],.compose-message textarea{border:1px solid #ddd;border-radius:6px;box-sizing:border-box;font-family:inherit;font-size:1rem;margin:8px 0;padding:12px;transition:border-color .2s;width:100%}.compose-message input[type=text]:focus,.compose-message textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.compose-message select{background:#fff;border:1px solid #ddd;border-radius:6px;box-sizing:border-box;cursor:pointer;font-family:inherit;font-size:1rem;margin:8px 0;padding:12px;transition:border-color .2s;width:100%}.compose-message select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.compose-actions{display:flex;gap:10px;margin-top:10px}.compose-actions button{border:none;border-radius:6px;cursor:pointer;font-weight:600;padding:10px 20px}.compose-actions button:first-child{background:#667eea;color:#fff}.compose-actions button:last-child{background:#e0e0e0;color:#333}.messages-list{max-height:600px;overflow-y:auto}.message-item{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:15px;padding:15px}.message-item.unread{background:#f8f9ff;border-left:4px solid #667eea}.message-header{align-items:center;display:flex;font-size:.9rem;justify-content:space-between;margin-bottom:10px}.message-subject{color:#333;font-weight:600;margin-bottom:8px}.message-body{color:#555;line-height:1.6;margin:10px 0}.message-footer{align-items:center;color:#888;display:flex;font-size:.85rem;justify-content:space-between;margin-top:10px}.priority{border-radius:4px;font-size:.75rem;font-weight:600;padding:4px 8px}.priority.urgent{background:#ef4444;color:#fff}.priority.high{background:#f59e0b;color:#fff}.priority.normal{background:#3b82f6;color:#fff}.priority.low{background:#10b981;color:#fff}.broadcast{background:#8b5cf6;border-radius:4px;color:#fff;font-size:.75rem;padding:4px 8px}.user-notes-section{border-top:2px solid #e0e0e0;margin-top:20px;padding-top:20px}.user-notes-section h3{color:#333;margin-bottom:15px}.add-note-form{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.add-note-form textarea{border:1px solid #ddd;border-radius:6px;font-size:1rem;padding:10px;resize:vertical;width:100%}.add-note-form select{border:1px solid #ddd;border-radius:6px;padding:8px}.add-note-form button{align-self:flex-start;background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px}.notes-list{max-height:300px;overflow-y:auto}.note-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:10px;padding:12px}.note-item.resolved{opacity:.7}.note-header{font-size:.9rem;justify-content:space-between;margin-bottom:8px}.note-header,.note-header-left{align-items:center;display:flex}.note-header-left{flex-wrap:wrap;gap:8px}.note-type{border-radius:4px;font-size:.75rem;font-weight:600;padding:4px 8px}.note-type.bot_flag{background:#ef4444;color:#fff}.note-type.suspicious{background:#f59e0b;color:#fff}.note-type.recommendation{background:#10b981;color:#fff}.note-type.general{background:#6b7280;color:#fff}.resolved-badge{background:#10b981;border-radius:4px;color:#fff;font-size:.7rem;padding:4px 8px}.note-body{color:#555;line-height:1.5;margin:8px 0}.note-footer{color:#888;font-size:.8rem}.btn-delete-note{align-items:center;background:#ef4444;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:.85rem;gap:4px;padding:6px 10px;transition:all .3s}.btn-delete-note:hover{background:#dc2626}.account-management-section{border-top:2px solid #e0e0e0;margin-top:20px;padding-top:20px}.account-management-section h3{color:#333;margin-bottom:15px}.add-money-form{display:flex;flex-direction:column;gap:10px}.add-money-form input{border:1px solid #ddd;border-radius:6px;font-size:1rem;padding:10px}.add-money-form button{align-self:flex-start;background:#10b981;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:10px 20px}.admin-transactions-section{border-top:1px solid #e0e0e0;margin-top:25px;padding-top:20px}.admin-transactions-section h4{color:#333;font-size:1.1rem;margin-bottom:15px}.transactions-list{max-height:300px;overflow-y:auto}.transaction-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:10px;padding:12px;position:relative}.transaction-item.admin-transaction{background:#f0fdf4;border-left:4px solid #10b981}.transaction-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.transaction-amount{font-size:1.1rem;font-weight:700}.transaction-amount.positive{color:#10b981}.transaction-details{color:#555;font-size:.9rem;line-height:1.6}.transaction-reason{color:#666;font-style:italic;margin:4px 0}.transaction-date{color:#888;font-size:.85rem;margin-top:4px}.admin-transaction-badge{background:#10b981;border-radius:4px;color:#fff;font-size:.7rem;font-weight:600;padding:4px 8px;position:absolute;right:8px;top:8px}.admin-level-modal{max-width:600px}.admin-level-selection{margin-bottom:20px}.admin-level-selection label{color:#333;display:block;font-weight:600;margin-bottom:10px}.admin-level-select{background:#fff;border:2px solid #ddd;border-radius:8px;cursor:pointer;font-size:1rem;margin-bottom:15px;padding:12px;width:100%}.admin-level-select:focus{border-color:#667eea;outline:none}.level-description{background:#f8f9fa;border-left:4px solid #667eea;border-radius:8px;padding:15px}.level-info{color:#555;line-height:1.6;margin:0}.level-info.level-1{border-left-color:#8b5cf6}.level-info.level-2{border-left-color:#10b981}.level-info.level-3{border-left-color:#3b82f6}.level-info.master-admin{border-left-color:#f59e0b}.btn-edit-admin{background:#8b5cf6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 12px;transition:all .3s}.btn-edit-admin:hover{background:#7c3aed}.btn-action.btn-edit-admin{align-items:center;background:#8b5cf6;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;padding:10px 20px}.btn-action.btn-confirm{background:#10b981;color:#fff}.btn-action.btn-cancel{background:#e0e0e0;color:#333}.action-buttons{display:flex;flex-wrap:wrap;gap:8px}.action-buttons button{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:.9rem;justify-content:center;padding:8px 12px;transition:all .3s ease}.btn-view{background:#3b82f6;color:#fff}.btn-view:hover{background:#2563eb}.btn-ban{background:#ef4444;color:#fff}.btn-ban:hover{background:#dc2626}.btn-unban{background:#10b981;color:#fff}.btn-unban:hover{background:#059669}.btn-delete{background:#dc2626;color:#fff}.btn-delete:hover{background:#b91c1c}.btn-admin{background:#f59e0b;color:#fff}.btn-admin:hover{background:#d97706}.btn-remove-admin{background:#6b7280;color:#fff}.btn-remove-admin:hover{background:#4b5563}.action-buttons button:disabled{cursor:not-allowed;opacity:.5}.pagination{align-items:center;display:flex;gap:20px;justify-content:center;margin-top:20px;padding:20px}.pagination button{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;padding:10px 20px;transition:all .3s ease}.pagination button:hover:not(:disabled){background:#5568d3;transform:translateY(-2px)}.pagination button:disabled{cursor:not-allowed;opacity:.5}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 10px 25px #0003;max-height:90vh;max-width:600px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px}.modal-header h2{color:#333;margin:0}.close-button{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:1.5rem;padding:5px 10px;transition:all .3s ease}.close-button:hover{background:#f0f0f0;color:#333}.modal-body{padding:20px}.user-details{margin-bottom:20px}.detail-row{align-items:center;border-bottom:1px solid #f0f0f0;display:flex;gap:10px;padding:12px 0}.detail-row:last-child{border-bottom:none}.detail-row strong{color:#333;min-width:150px}.ban-reason-input{margin-bottom:15px}.ban-reason-input input{border:1px solid #e0e0e0;border-radius:6px;font-size:1rem;outline:none;padding:10px;width:100%}.ban-reason-input input:focus{border-color:#667eea}.modal-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}.btn-action{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:1rem;font-weight:600;gap:8px;justify-content:center;min-width:150px;padding:12px 20px;transition:all .3s ease}.btn-action:hover:not(:disabled){box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.btn-action:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.admin-header{align-items:flex-start;flex-direction:column;gap:15px}.analytics-grid,.analytics-sections{grid-template-columns:1fr}.users-table{font-size:.9rem}.users-table td,.users-table th{padding:10px}.action-buttons{flex-direction:column}.action-buttons button{width:100%}.modal-content{width:95%}}
/*# sourceMappingURL=main.9ce190e3.css.map*/