:root{--bg-primary: #0A0F1E;--bg-secondary: #0D1426;--bg-card: #111827;--bg-card-hover: #161f30;--border-color: #1F2937;--border-light: #374151;--accent-primary: #6366F1;--accent-primary-hover: #4f52d4;--accent-primary-glow: rgba(99, 102, 241, .25);--accent-secondary: #10B981;--accent-secondary-glow: rgba(16, 185, 129, .2);--danger: #EF4444;--danger-hover: #dc2626;--danger-glow: rgba(239, 68, 68, .2);--warning: #F59E0B;--warning-glow: rgba(245, 158, 11, .2);--info: #3B82F6;--text-primary: #F9FAFB;--text-secondary: #9CA3AF;--text-muted: #6B7280;--text-disabled: #4B5563;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .6);--shadow-glow: 0 0 24px rgba(99, 102, 241, .15);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--navbar-height: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-family);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}img{max-width:100%;display:block}a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-primary-hover)}button{cursor:pointer;font-family:var(--font-family);border:none;background:none}input,select,textarea{font-family:var(--font-family)}ul,ol{list-style:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 24px}.container-sm{width:100%;max-width:480px;margin:0 auto;padding:0 24px}.container-md{width:100%;max-width:768px;margin:0 auto;padding:0 24px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.gap-8{gap:32px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mt-8{margin-top:32px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.w-full{width:100%}.text-center{text-align:center}.text-right{text-align:right}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:600;letter-spacing:.01em;transition:all var(--transition-base);white-space:nowrap;position:relative;overflow:hidden;border:1px solid transparent}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-sm{padding:6px 14px;font-size:13px}.btn-lg{padding:14px 28px;font-size:16px}.btn-primary{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);box-shadow:0 0 0 0 var(--accent-primary-glow)}.btn-primary:hover{background:var(--accent-primary-hover);border-color:var(--accent-primary-hover);box-shadow:0 4px 20px var(--accent-primary-glow);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--accent-secondary);color:#fff;border-color:var(--accent-secondary)}.btn-secondary:hover{background:#0da271;box-shadow:0 4px 20px var(--accent-secondary-glow);transform:translateY(-1px)}.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn-danger:hover{background:var(--danger-hover);box-shadow:0 4px 20px var(--danger-glow);transform:translateY(-1px)}.btn-outline{background:transparent;color:var(--text-primary);border-color:var(--border-light)}.btn-outline:hover{background:#ffffff0d;border-color:var(--text-secondary)}.btn-outline-primary{background:transparent;color:var(--accent-primary);border-color:var(--accent-primary)}.btn-outline-primary:hover{background:var(--accent-primary-glow)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover{background:#ffffff0d;color:var(--text-primary)}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;transition:border-color var(--transition-base),box-shadow var(--transition-base)}.card:hover{border-color:var(--border-light);box-shadow:var(--shadow-md)}.card-sm{padding:16px}.card-clickable{cursor:pointer}.card-clickable:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.form-group{display:flex;flex-direction:column;gap:6px}.label{font-size:13px;font-weight:500;color:var(--text-secondary);letter-spacing:.02em;text-transform:uppercase}.input{width:100%;padding:11px 14px;background:#ffffff0a;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:15px;font-family:var(--font-family);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);outline:none}.input::placeholder{color:var(--text-muted)}.input:focus{border-color:var(--accent-primary);background:#6366f10f;box-shadow:0 0 0 3px var(--accent-primary-glow)}.input:disabled{opacity:.5;cursor:not-allowed}.input-group{position:relative;display:flex;align-items:center}.input-group .input{padding-right:44px}.input-group-icon{position:absolute;right:14px;color:var(--text-muted);pointer-events:none}.input-error{border-color:var(--danger)}.input-error:focus{border-color:var(--danger);box-shadow:0 0 0 3px var(--danger-glow)}.error-text{font-size:12px;color:var(--danger);margin-top:2px}.helper-text{font-size:12px;color:var(--text-muted);margin-top:2px}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:600;letter-spacing:.02em}.badge-success{background:#10b98126;color:var(--accent-secondary);border:1px solid rgba(16,185,129,.25)}.badge-danger{background:#ef444426;color:var(--danger);border:1px solid rgba(239,68,68,.25)}.badge-warning{background:#f59e0b26;color:var(--warning);border:1px solid rgba(245,158,11,.25)}.badge-info{background:#3b82f626;color:var(--info);border:1px solid rgba(59,130,246,.25)}.badge-neutral{background:#9ca3af26;color:var(--text-secondary);border:1px solid rgba(156,163,175,.25)}.table-wrapper{width:100%;overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-color)}table{width:100%;border-collapse:collapse;font-size:14px}thead{background:#ffffff08;border-bottom:1px solid var(--border-color)}thead th{padding:12px 16px;text-align:left;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}tbody tr{border-bottom:1px solid rgba(31,41,55,.6);transition:background var(--transition-fast)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:#ffffff05}tbody td{padding:14px 16px;color:var(--text-primary);vertical-align:middle}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;animation:fadeIn var(--transition-base) ease}.modal{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg),0 0 60px #00000080;animation:slideUp var(--transition-base) ease}.modal-lg{max-width:640px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color)}.modal-title{font-size:18px;font-weight:700;color:var(--text-primary)}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-muted);transition:all var(--transition-fast)}.modal-close:hover{background:#ffffff14;color:var(--text-primary)}.modal-body{padding:24px}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border-color)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}.spinner-sm{width:20px;height:20px;border-width:2px}.spinner-lg{width:60px;height:60px;border-width:4px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:64px 24px}.loading-text{color:var(--text-secondary);font-size:14px}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14,#ffffff0a 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}.skeleton-text{height:16px;border-radius:4px}.skeleton-card{height:160px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}@keyframes toastIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.animate-fadeIn{animation:fadeIn var(--transition-base) ease}.animate-slideUp{animation:slideUp var(--transition-base) ease}.animate-pulse{animation:pulse 2s infinite}.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);min-width:300px;max-width:420px;box-shadow:var(--shadow-lg);pointer-events:all;animation:toastIn .3s ease forwards}.toast.removing{animation:toastOut .3s ease forwards}.toast-icon{font-size:18px;flex-shrink:0;margin-top:1px}.toast-content{flex:1}.toast-title{font-size:14px;font-weight:600;color:var(--text-primary);line-height:1.4}.toast-message{font-size:13px;color:var(--text-secondary);margin-top:2px;line-height:1.4}.toast-close{color:var(--text-muted);padding:2px;flex-shrink:0;border-radius:4px;transition:color var(--transition-fast)}.toast-close:hover{color:var(--text-primary)}.toast-success{border-left:3px solid var(--accent-secondary)}.toast-error{border-left:3px solid var(--danger)}.toast-info{border-left:3px solid var(--info)}.toast-warning{border-left:3px solid var(--warning)}.toast-progress{height:2px;background:var(--accent-primary);border-radius:0 0 var(--radius-lg) var(--radius-lg);position:absolute;bottom:0;left:0;animation:shrink 4s linear forwards}@keyframes shrink{0%{width:100%}to{width:0%}}.navbar{height:var(--navbar-height);background:#0a0f1ed9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100}.navbar-inner{display:flex;align-items:center;justify-content:space-between;height:100%}.navbar-logo{font-size:22px;font-weight:800;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.03em}.navbar-actions{display:flex;align-items:center;gap:12px}.navbar-user{display:flex;align-items:center;gap:10px}.navbar-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),#8B5CF6);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0;overflow:hidden}.navbar-avatar-img{width:100%;height:100%;object-fit:cover}.navbar-username{font-size:14px;font-weight:500;color:var(--text-primary)}.hamburger{display:none;flex-direction:column;gap:5px;padding:4px;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.hamburger:hover{background:#ffffff14}.hamburger-line{width:22px;height:2px;background:var(--text-secondary);border-radius:var(--radius-full);transition:all var(--transition-base)}.mobile-menu{display:none;position:absolute;top:var(--navbar-height);left:0;right:0;background:var(--bg-card);border-bottom:1px solid var(--border-color);padding:16px 24px;flex-direction:column;gap:12px;animation:slideDown .2s ease}.mobile-menu.open{display:flex}.auth-page{min-height:calc(100vh - var(--navbar-height));display:flex;align-items:center;justify-content:center;padding:40px 16px;background:radial-gradient(ellipse at top,rgba(99,102,241,.08) 0%,transparent 60%)}.auth-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:40px;width:100%;max-width:440px;box-shadow:var(--shadow-lg);animation:slideUp .3s ease}.auth-title{font-size:26px;font-weight:800;color:var(--text-primary);margin-bottom:6px;letter-spacing:-.02em}.auth-subtitle{font-size:15px;color:var(--text-secondary);margin-bottom:28px}.auth-form{display:flex;flex-direction:column;gap:18px}.auth-divider{text-align:center;margin-top:20px;font-size:14px;color:var(--text-muted)}.auth-divider a{color:var(--accent-primary);font-weight:500}.auth-divider a:hover{color:var(--accent-primary-hover)}.step-progress{display:flex;align-items:center;gap:8px;margin-bottom:28px}.step-dot{width:8px;height:8px;border-radius:50%;background:var(--border-light);transition:all var(--transition-base)}.step-dot.active{width:24px;border-radius:4px;background:var(--accent-primary)}.step-dot.done{background:var(--accent-secondary)}.step-label{font-size:13px;color:var(--text-muted);margin-left:auto}.otp-container{display:flex;gap:10px;justify-content:center;margin:8px 0}.otp-input{width:52px;height:58px;text-align:center;font-size:22px;font-weight:700;background:#ffffff0a;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-family);transition:all var(--transition-fast);outline:none}.otp-input:focus{border-color:var(--accent-primary);background:#6366f114;box-shadow:0 0 0 3px var(--accent-primary-glow)}.otp-input.filled{border-color:var(--accent-secondary);background:#10b9810f}.mpin-container{display:flex;gap:12px;justify-content:center;margin:8px 0}.mpin-input{width:60px;height:64px;text-align:center;font-size:26px;font-weight:700;background:#ffffff0a;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-family);transition:all var(--transition-fast);outline:none}.mpin-input:focus{border-color:var(--accent-primary);background:#6366f114;box-shadow:0 0 0 3px var(--accent-primary-glow)}.mpin-input.filled{border-color:var(--accent-secondary)}.landing-hero{min-height:calc(100vh - var(--navbar-height));display:flex;align-items:center;position:relative;overflow:hidden;padding:80px 0}.hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 20% 50%,rgba(99,102,241,.12) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(16,185,129,.08) 0%,transparent 40%),radial-gradient(ellipse at 60% 80%,rgba(99,102,241,.06) 0%,transparent 40%);pointer-events:none}.hero-orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;pointer-events:none}.hero-orb-1{width:400px;height:400px;background:var(--accent-primary);top:-100px;left:-100px;opacity:.08}.hero-orb-2{width:300px;height:300px;background:var(--accent-secondary);bottom:-50px;right:100px;opacity:.06}.hero-content{position:relative;z-index:1;text-align:center;max-width:800px;margin:0 auto}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;background:#6366f11f;border:1px solid rgba(99,102,241,.25);border-radius:var(--radius-full);font-size:13px;font-weight:500;color:var(--accent-primary);margin-bottom:28px}.hero-title{font-size:clamp(36px,6vw,72px);font-weight:900;line-height:1.1;letter-spacing:-.03em;color:var(--text-primary);margin-bottom:20px}.gradient-text{background:linear-gradient(135deg,var(--accent-primary) 0%,#8B5CF6 50%,var(--accent-secondary) 100%);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientShift 4s ease infinite}.hero-subtitle{font-size:clamp(16px,2.5vw,20px);color:var(--text-secondary);max-width:600px;margin:0 auto 40px;line-height:1.7}.hero-actions{display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}.stats-bar{background:var(--bg-card);border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);padding:20px 0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);divide:auto}.stat-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px;border-right:1px solid var(--border-color)}.stat-item:last-child{border-right:none}.stat-value{font-size:22px;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.stat-label{font-size:13px;color:var(--text-secondary)}.features-section{padding:100px 0}.section-eyebrow{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--accent-primary);margin-bottom:12px;text-align:center}.section-title{font-size:clamp(28px,4vw,42px);font-weight:800;letter-spacing:-.02em;text-align:center;margin-bottom:16px}.section-subtitle{font-size:17px;color:var(--text-secondary);text-align:center;max-width:540px;margin:0 auto 60px;line-height:1.7}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.feature-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:28px;transition:all var(--transition-base);position:relative;overflow:hidden}.feature-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent,rgba(99,102,241,.04));opacity:0;transition:opacity var(--transition-base)}.feature-card:hover{border-color:#6366f166;transform:translateY(-4px);box-shadow:0 12px 40px #0006,0 0 0 1px #6366f11a}.feature-card:hover:before{opacity:1}.feature-icon{width:52px;height:52px;background:#6366f11f;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:16px;border:1px solid rgba(99,102,241,.2)}.feature-title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.feature-desc{font-size:14px;color:var(--text-secondary);line-height:1.65}.how-section{padding:80px 0;background:linear-gradient(180deg,transparent,rgba(99,102,241,.04),transparent)}.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:60px;position:relative}.steps-grid:before{content:"";position:absolute;top:30px;left:calc(16.67% + 32px);right:calc(16.67% + 32px);height:2px;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary));opacity:.3}.step-card{text-align:center;position:relative}.step-number{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),#8B5CF6);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:900;color:#fff;margin:0 auto 20px;box-shadow:0 0 30px var(--accent-primary-glow)}.step-title{font-size:17px;font-weight:700;margin-bottom:8px;color:var(--text-primary)}.step-desc{font-size:14px;color:var(--text-secondary);line-height:1.65}.cta-section{padding:100px 0;text-align:center;background:radial-gradient(ellipse at center,rgba(99,102,241,.1) 0%,transparent 70%)}.cta-title{font-size:clamp(28px,4vw,48px);font-weight:900;letter-spacing:-.02em;margin-bottom:16px}.cta-subtitle{font-size:17px;color:var(--text-secondary);margin-bottom:36px}.landing-footer{background:var(--bg-card);border-top:1px solid var(--border-color);padding:32px 0;text-align:center}.footer-logo{font-size:20px;font-weight:800;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:8px}.footer-text{font-size:13px;color:var(--text-muted)}.dashboard-page{min-height:calc(100vh - var(--navbar-height));padding:32px 0 64px}.dashboard-header{margin-bottom:32px}.dashboard-greeting{font-size:26px;font-weight:800;letter-spacing:-.02em;color:var(--text-primary)}.dashboard-date{font-size:14px;color:var(--text-secondary);margin-top:4px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.section-heading{font-size:18px;font-weight:700;color:var(--text-primary)}.portfolios-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.portfolio-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:22px;cursor:pointer;transition:all var(--transition-base);position:relative}.portfolio-card:hover{border-color:var(--accent-primary);box-shadow:0 8px 32px #0006,0 0 0 1px #6366f126;transform:translateY(-2px)}.portfolio-card-name{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:16px;padding-right:32px}.portfolio-card-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}.portfolio-stat{display:flex;flex-direction:column;gap:2px}.portfolio-stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.portfolio-stat-value{font-size:15px;font-weight:700;color:var(--text-primary)}.portfolio-stat-value.positive{color:var(--accent-secondary)}.portfolio-stat-value.negative{color:var(--danger)}.portfolio-delete-btn{position:absolute;top:16px;right:16px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-muted);transition:all var(--transition-fast);opacity:0}.portfolio-card:hover .portfolio-delete-btn{opacity:1}.portfolio-delete-btn:hover{background:#ef444426;color:var(--danger)}.portfolio-stock-count{margin-top:14px;padding-top:14px;border-top:1px solid var(--border-color);font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:4px}.empty-state{text-align:center;padding:80px 24px;background:var(--bg-card);border:1px dashed var(--border-light);border-radius:var(--radius-xl)}.empty-state-icon{font-size:56px;margin-bottom:16px;opacity:.6}.empty-state-title{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.empty-state-desc{font-size:14px;color:var(--text-secondary);margin-bottom:24px;max-width:360px;margin-left:auto;margin-right:auto}.portfolio-detail-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.back-btn{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:var(--text-secondary);transition:color var(--transition-fast);padding:6px 12px;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:transparent}.back-btn:hover{color:var(--text-primary);background:#ffffff0d}.portfolio-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.summary-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:18px}.summary-card-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:6px}.summary-card-value{font-size:22px;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.summary-card-value.positive{color:var(--accent-secondary)}.summary-card-value.negative{color:var(--danger)}.search-wrapper{position:relative}.search-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);max-height:260px;overflow-y:auto;z-index:50;box-shadow:var(--shadow-lg);animation:slideDown .15s ease}.search-dropdown-item{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid rgba(31,41,55,.6)}.search-dropdown-item:last-child{border-bottom:none}.search-dropdown-item:hover{background:#6366f114}.search-dropdown-item-symbol{font-size:14px;font-weight:700;color:var(--text-primary)}.search-dropdown-item-name{font-size:12px;color:var(--text-secondary);margin-top:1px}.search-dropdown-item-price{font-size:14px;font-weight:600;color:var(--accent-secondary)}.search-no-results{padding:20px;text-align:center;font-size:14px;color:var(--text-muted)}.text-positive{color:var(--accent-secondary)}.text-negative{color:var(--danger)}.text-neutral{color:var(--text-secondary)}.divider{height:1px;background:var(--border-color);margin:24px 0}@media (max-width: 1024px){.features-grid,.portfolio-summary-grid,.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-item:nth-child(2){border-right:none}}@media (max-width: 768px){.hamburger{display:flex}.navbar-actions{display:none}.features-grid,.steps-grid{grid-template-columns:1fr}.steps-grid:before{display:none}.hero-actions{flex-direction:column;align-items:stretch}.hero-actions .btn{width:100%}.auth-card{padding:28px 20px}.otp-container{gap:8px}.otp-input{width:44px;height:50px;font-size:18px}.mpin-container{gap:10px}.mpin-input{width:52px;height:56px;font-size:22px}.portfolios-grid{grid-template-columns:1fr}.portfolio-summary-grid{grid-template-columns:repeat(2,1fr)}.toast-container{left:12px;right:12px;bottom:12px}.toast{min-width:unset;width:100%}.modal{max-height:95vh}}@media (max-width: 480px){.container{padding:0 16px}.portfolio-summary-grid{grid-template-columns:1fr 1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.no-select{user-select:none;-webkit-user-select:none}.cursor-pointer{cursor:pointer}.opacity-50{opacity:.5}.opacity-0{opacity:0}.success-color{color:var(--accent-secondary)}.danger-color{color:var(--danger)}.warning-color{color:var(--warning)}.primary-color{color:var(--accent-primary)}.stock-detail-page{padding-top:calc(var(--navbar-height) + 32px);padding-bottom:64px;min-height:100vh}.stock-header-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:28px 32px;display:flex;align-items:flex-start;justify-content:space-between;gap:24px;margin-bottom:24px}.stock-symbol-badge{display:inline-flex;align-items:center;background:#6366f11f;border:1px solid rgba(99,102,241,.3);color:var(--accent-primary);font-size:13px;font-weight:700;letter-spacing:.04em;padding:4px 12px;border-radius:var(--radius-full);margin-bottom:10px;font-family:Courier New,monospace}.stock-company-name{font-size:24px;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;margin-bottom:10px;line-height:1.2}.stock-tag{display:inline-block;background:#ffffff0f;border:1px solid var(--border-color);color:var(--text-secondary);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;padding:3px 10px;border-radius:var(--radius-full);margin-right:6px}.stock-price-display{text-align:right;flex-shrink:0}.stock-price-value{font-size:32px;font-weight:800;color:var(--text-primary);letter-spacing:-.02em;line-height:1;margin-bottom:6px}.stock-price-change{font-size:15px;font-weight:700;margin-bottom:4px}.stock-price-change.positive{color:var(--accent-secondary)}.stock-price-change.negative{color:var(--danger)}.stock-last-updated{font-size:11px;color:var(--text-muted)}.time-range-selector{display:flex;gap:4px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-full);padding:4px;width:fit-content;margin-bottom:20px}.time-range-btn{background:none;border:none;color:var(--text-muted);font-size:13px;font-weight:600;padding:6px 18px;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-family)}.time-range-btn:hover{color:var(--text-primary)}.time-range-btn.active{background:var(--accent-primary);color:#fff}.chart-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;margin-bottom:24px}.stock-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.stock-stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px 20px}.stock-stat-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.stock-stat-value{font-size:18px;font-weight:700;color:var(--text-primary)}.phase-cards-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.phase-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px}.phase-card-icon{font-size:28px;margin-bottom:12px}.phase-card-title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.phase-card-body{font-size:13px;color:var(--text-secondary);line-height:1.6;margin-bottom:14px}.phase-badge{display:inline-block;background:#f59e0b1f;border:1px solid rgba(245,158,11,.3);color:var(--warning);font-size:11px;font-weight:700;padding:3px 10px;border-radius:var(--radius-full);letter-spacing:.03em}.phase-card-code{display:block;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:8px 12px;font-size:12px;color:var(--accent-primary);margin-top:4px;word-break:break-all}.risk-metrics-body{display:flex;flex-direction:column;gap:10px;margin-top:4px}.risk-metrics-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.risk-metrics-label{font-size:13px;color:var(--text-secondary)}.risk-metrics-value{font-size:14px;font-weight:600;color:var(--text-primary)}.risk-metrics-updated{font-size:11px;color:var(--text-muted);margin-top:6px}.chart-source-badge{position:absolute;top:12px;right:14px;font-size:11px;color:var(--text-muted);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-full);padding:2px 10px;z-index:1}.risk-badge.risk-unknown{background:#6b72801f;color:var(--text-muted);border:1px solid rgba(107,114,128,.25)}.trade-signal-body{display:flex;flex-direction:column;gap:12px;margin-top:4px}.trade-signal-badge{display:inline-block;font-size:22px;font-weight:800;letter-spacing:.08em;padding:6px 20px;border-radius:var(--radius-sm);text-align:center;width:fit-content}.signal-buy{background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3)}.signal-hold{background:#f59e0b26;color:#f59e0b;border:1px solid rgba(245,158,11,.3)}.signal-sell{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.trade-signal-confidence{display:flex;flex-direction:column;gap:4px}.trade-signal-conf-label{font-size:12px;color:var(--text-secondary)}.trade-signal-conf-bar{height:6px;background:var(--bg-secondary);border-radius:var(--radius-full);overflow:hidden}.trade-signal-conf-fill{height:100%;background:var(--accent-primary);border-radius:var(--radius-full);transition:width .4s ease}.trade-signal-features{display:flex;flex-direction:column;gap:4px}.trade-signal-feat-title{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}.trade-signal-feat-row{display:flex;justify-content:space-between;font-size:12px}.trade-signal-feat-name{color:var(--text-secondary)}.trade-signal-feat-val{color:var(--text-primary);font-weight:600}.predictions-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:20px 24px;margin-bottom:20px}.predictions-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:8px}.predictions-title{font-size:16px;font-weight:700;color:var(--text-primary)}.predictions-legend{display:flex;gap:12px;flex-wrap:wrap}.pred-legend-dot{font-size:11px;font-weight:600;padding:2px 10px;border-radius:var(--radius-full);display:flex;align-items:center;gap:4px}.pred-linear_regression{background:#6366f11f;color:#6366f1}.pred-arima{background:#f59e0b1f;color:#f59e0b}.pred-lstm{background:#10b9811f;color:#10b981}.pred-prophet{background:#ec48991f;color:#ec4899}.pred-horizon-tabs{display:flex;gap:6px;margin-bottom:14px}.pred-horizon-btn{padding:4px 12px;border-radius:6px;border:1px solid var(--border-color);background:transparent;color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}.pred-horizon-btn:hover{border-color:var(--accent-primary);color:var(--text-primary)}.pred-horizon-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.predictions-empty{min-height:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);font-size:13px;gap:10px;text-align:center}.add-to-portfolio-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px 28px;margin-bottom:24px}.add-to-portfolio-title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:18px}.add-to-portfolio-grid{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:12px;align-items:end}.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:14px;font-weight:500;margin-bottom:20px;cursor:pointer;background:none;border:none;padding:0;font-family:var(--font-family);transition:color var(--transition-fast)}.back-link:hover{color:var(--text-primary)}@media (max-width: 768px){.stock-header-card{flex-direction:column;align-items:flex-start}.stock-price-display{text-align:left}.stock-stats-grid{grid-template-columns:1fr 1fr}.phase-cards-grid{grid-template-columns:1fr}.add-to-portfolio-grid{grid-template-columns:1fr 1fr}}.index-portfolios-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(420px,1fr));gap:16px}.index-portfolio-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;display:flex;align-items:center;gap:20px;cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.index-portfolio-card:hover{border-color:var(--accent-primary);box-shadow:0 0 0 1px #6366f133,var(--shadow-md);transform:translateY(-2px)}.index-portfolio-flag{font-size:40px;flex-shrink:0;line-height:1}.index-portfolio-info{flex:1;min-width:0}.index-portfolio-name{font-size:17px;font-weight:800;color:var(--text-primary);letter-spacing:-.01em;margin-bottom:2px}.index-portfolio-label{font-size:12px;font-weight:600;color:var(--accent-primary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.index-portfolio-desc{font-size:13px;color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.index-portfolio-meta{display:flex;flex-direction:column;align-items:center;gap:8px;flex-shrink:0}.index-portfolio-count{display:flex;flex-direction:column;align-items:center;background:#6366f114;border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-md);padding:8px 14px;min-width:64px}.index-portfolio-count-num{font-size:22px;font-weight:800;color:var(--accent-primary);line-height:1}.index-portfolio-count-label{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}.index-portfolio-arrow{font-size:18px;color:var(--text-muted);transition:color var(--transition-fast),transform var(--transition-fast)}.index-portfolio-card:hover .index-portfolio-arrow{color:var(--accent-primary);transform:translate(4px)}@media (max-width: 768px){.index-portfolios-grid{grid-template-columns:1fr}.index-portfolio-card{flex-wrap:wrap}}.sector-accordion{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;transition:border-color var(--transition-fast)}.sector-accordion:hover{border-color:var(--sector-color, var(--accent-primary))}.sector-accordion-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:none;border:none;cursor:pointer;color:var(--text-primary);font-family:var(--font-family);transition:background var(--transition-fast);text-align:left}.sector-accordion-header:hover{background:#ffffff08}.sector-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.sector-accordion-name{font-size:15px;font-weight:700;letter-spacing:-.01em}.sector-stock-badge{display:inline-block;background:#ffffff12;border:1px solid var(--border-color);color:var(--text-secondary);font-size:11px;font-weight:600;padding:2px 9px;border-radius:var(--radius-full);letter-spacing:.02em}.sector-accordion-chevron{font-size:16px;color:var(--text-muted);transition:transform var(--transition-base);display:inline-block;line-height:1}.sector-accordion-body{border-top:1px solid var(--border-color);overflow-x:auto}.sector-table{width:100%;border-collapse:collapse;font-size:13px}.sector-table thead tr{background:#ffffff05}.sector-table th{padding:10px 14px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-color);white-space:nowrap;text-align:left}.sector-table td{padding:10px 14px;border-bottom:1px solid rgba(31,41,55,.6);color:var(--text-primary);vertical-align:middle}.sector-table tbody tr:last-child td{border-bottom:none}.sector-table tbody tr:hover{background:#ffffff06}.index-stock-row{cursor:pointer;transition:background .12s}.index-stock-row:hover{background:#6366f112!important}.index-stock-row:hover td{color:var(--text-primary)}.cluster-info-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;background:#6366f10f;border:1px solid rgba(99,102,241,.15);border-radius:var(--radius-md);padding:10px 16px;font-size:13px;color:var(--text-secondary);margin-bottom:16px}.cluster-legend-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:8px}.cluster-legend-card{display:flex;align-items:center;gap:10px;border:1px solid;border-radius:var(--radius-md);padding:12px 14px}.cluster-legend-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.global-stats-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:32px}.global-stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px 20px;display:flex;flex-direction:column;gap:6px;transition:border-color var(--transition-fast)}.global-stat-card:hover{border-color:var(--border-light)}.global-stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.global-stat-value{font-size:20px;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.global-stat-value.positive{color:var(--accent-secondary)}.global-stat-value.negative{color:var(--danger)}.portfolio-switcher{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:13px;padding:6px 10px;cursor:pointer;outline:none;transition:border-color var(--transition-fast)}.portfolio-switcher:hover,.portfolio-switcher:focus{border-color:var(--accent-primary);color:var(--text-primary)}.risk-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.05em;padding:2px 7px;border-radius:var(--radius-full);border:1px solid}.risk-badge.risk-low{color:#10b981;background:#10b9811a;border-color:#10b9814d}.risk-badge.risk-med{color:#f59e0b;background:#f59e0b1a;border-color:#f59e0b4d}.risk-badge.risk-high{color:#ef4444;background:#ef44441a;border-color:#ef44444d}.settings-page{min-height:calc(100vh - var(--navbar-height));padding:40px 0 80px}.settings-header{margin-bottom:32px}.settings-title{font-size:28px;font-weight:800;letter-spacing:-.03em;color:var(--text-primary);margin-bottom:6px}.settings-subtitle{font-size:14px;color:var(--text-muted)}.settings-layout{display:flex;flex-direction:column;gap:24px}.settings-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.settings-section-header{padding:20px 24px 0}.settings-section-title{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.settings-section-desc{font-size:13px;color:var(--text-muted);margin-bottom:0}.settings-section-body{padding:20px 24px 24px}.settings-form{display:flex;flex-direction:column;gap:20px}.settings-fields-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.settings-avatar-row{display:flex;align-items:center;gap:20px}.settings-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),#8B5CF6);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:800;color:#fff;cursor:pointer;position:relative;overflow:hidden;flex-shrink:0;border:2px solid var(--border-light);transition:border-color var(--transition-fast)}.settings-avatar:hover{border-color:var(--accent-primary)}.settings-avatar-img{width:100%;height:100%;object-fit:cover}.settings-avatar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;letter-spacing:.05em;color:#fff;opacity:0;transition:opacity var(--transition-fast)}.settings-avatar:hover .settings-avatar-overlay{opacity:1}.settings-actions{display:flex;justify-content:flex-end;padding-top:4px;border-top:1px solid var(--border-color)}.mpin-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.mpin-input{font-size:22px;letter-spacing:.3em;text-align:center;max-width:160px}.navbar-settings-btn{font-size:16px;padding:6px 10px}.sentiment-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:20px 24px;margin-bottom:20px}.sentiment-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.sentiment-title{font-size:16px;font-weight:700;color:var(--text-primary)}.sentiment-badge{font-size:12px;font-weight:700;padding:4px 12px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px}.sentiment-bullish{background:#10b98126;color:#10b981}.sentiment-bearish{background:#ef444426;color:#ef4444}.sentiment-neutral{background:#9ca3af26;color:#9ca3af}.sentiment-body{display:flex;flex-direction:column;gap:12px}.sentiment-scores{display:flex;flex-direction:column;gap:10px}.sentiment-score-row{display:flex;align-items:center;gap:12px}.sentiment-score-label{font-size:11px;font-weight:600;color:var(--text-muted);width:52px;flex-shrink:0}.sentiment-bar-track{flex:1;height:8px;background:#ffffff0f;border-radius:4px;position:relative;overflow:hidden}.sentiment-bar-fill{position:absolute;height:100%;border-radius:4px;transition:width .4s ease}.sentiment-bar-fill.positive{background:#10b981}.sentiment-bar-fill.negative{background:#ef4444}.sentiment-bar-center{position:absolute;left:50%;top:0;bottom:0;width:1px;background:#fff3}.sentiment-score-value{font-size:12px;font-weight:600;color:var(--text-secondary);width:46px;text-align:right;flex-shrink:0}.sentiment-meta{font-size:11px;color:var(--text-muted);padding-top:4px}.sentiment-empty{min-height:80px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);font-size:13px;gap:8px}.sentiment-articles{margin-top:16px;border-top:1px solid var(--border-color);padding-top:14px}.sentiment-articles-title{font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.sentiment-article-row{display:block;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.04);text-decoration:none;transition:opacity .15s}.sentiment-article-row:last-child{border-bottom:none}.sentiment-article-row:hover{opacity:.8}.sentiment-article-meta{display:flex;align-items:center;gap:8px;margin-bottom:4px}.sentiment-article-source{font-size:11px;color:var(--text-muted);font-weight:500}.sentiment-article-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;text-transform:uppercase}.badge-positive{background:#10b98126;color:#10b981}.badge-negative{background:#ef444426;color:#ef4444}.badge-neutral{background:#9ca3af1a;color:#9ca3af}.sentiment-article-title{font-size:13px;color:var(--text-primary);line-height:1.4}.chat-page{display:flex;height:calc(100vh - 64px);background:var(--bg-primary);overflow:hidden}.chat-sidebar{width:260px;min-width:260px;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden}.chat-sidebar-header{padding:16px;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.chat-sidebar-title{font-size:16px;font-weight:700;color:var(--accent-primary);margin:0}.chat-new-btn{background:var(--accent-primary);color:#fff;border:none;border-radius:6px;padding:6px 12px;font-size:12px;cursor:pointer;font-weight:600;transition:opacity .2s}.chat-new-btn:hover{opacity:.85}.chat-session-list{flex:1;overflow-y:auto;padding:8px}.chat-empty-hint{font-size:12px;color:var(--text-muted);text-align:center;padding:24px 8px}.chat-session-item{position:relative;padding:10px 12px;border-radius:8px;cursor:pointer;margin-bottom:4px;transition:background .15s}.chat-session-item:hover{background:var(--bg-tertiary)}.chat-session-item.active{background:#6366f126;border:1px solid rgba(99,102,241,.3)}.chat-session-title{font-size:13px;color:var(--text-primary);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px;padding-right:20px}.chat-session-meta{display:flex;gap:6px;align-items:center}.chat-mode-badge{font-size:10px;padding:2px 6px;border-radius:4px;font-weight:600;text-transform:uppercase}.mode-public{background:#10b98126;color:#10b981}.mode-private{background:#6366f126;color:#6366f1}.mode-action{background:#f59e0b26;color:#f59e0b}.chat-session-count{font-size:11px;color:var(--text-muted)}.chat-session-delete{position:absolute;top:8px;right:8px;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;line-height:1;padding:0 4px;opacity:0;transition:opacity .15s}.chat-session-item:hover .chat-session-delete{opacity:1}.chat-session-delete:hover{color:#ef4444}.chat-main{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);gap:12px;flex-wrap:wrap}.chat-toolbar-title{font-size:15px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}.chat-toolbar-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.chat-mode-selector{display:flex;gap:4px;background:var(--bg-tertiary);border-radius:8px;padding:3px}.chat-mode-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:5px 10px;border-radius:6px;font-size:12px;font-weight:500;transition:all .15s;white-space:nowrap}.chat-mode-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.chat-mode-btn.active{background:var(--accent-primary);color:#fff}.chat-model-select{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:8px;padding:6px 10px;font-size:13px;cursor:pointer;outline:none;max-width:200px}.chat-model-select:focus{border-color:var(--accent-primary)}.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.chat-loading{text-align:center;color:var(--text-muted);font-size:13px;padding:40px}.chat-welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;text-align:center;padding:40px 20px;gap:12px}.chat-welcome-icon{font-size:48px}.chat-welcome h3{font-size:20px;color:var(--text-primary);margin:0}.chat-welcome-sub{font-size:14px;color:var(--text-muted);margin:0}.chat-suggestions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:8px}.chat-suggestion-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);border-radius:20px;padding:8px 14px;font-size:13px;cursor:pointer;transition:all .15s}.chat-suggestion-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.chat-bubble{display:flex;gap:10px;max-width:80%}.chat-bubble.user{flex-direction:row-reverse;align-self:flex-end}.chat-bubble.assistant{align-self:flex-start}.chat-bubble-avatar{width:32px;height:32px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;border:1px solid var(--border-color)}.chat-bubble-content{display:flex;flex-direction:column;gap:4px}.chat-bubble.user .chat-bubble-content{align-items:flex-end}.chat-bubble-text{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:10px 14px;font-size:14px;color:var(--text-primary);line-height:1.5;margin:0;white-space:pre-wrap;word-break:break-word}.chat-bubble.user .chat-bubble-text{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.chat-bubble-time{font-size:11px;color:var(--text-muted);padding:0 4px}.chat-action-btn{background:#10b98126;border:1px solid rgba(16,185,129,.4);color:#10b981;border-radius:8px;padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;align-self:flex-start}.chat-action-btn:hover{background:#10b98140}.typing-indicator{display:flex;align-items:center;gap:4px;padding:10px 14px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px}.typing-indicator span{width:6px;height:6px;background:var(--text-muted);border-radius:50%;animation:typing-bounce 1.2s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing-bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.chat-input-area{display:flex;align-items:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--border-color);background:var(--bg-secondary)}.chat-input{flex:1;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;color:var(--text-primary);font-size:14px;padding:10px 14px;resize:none;outline:none;font-family:inherit;line-height:1.5;max-height:120px;overflow-y:auto;transition:border-color .2s}.chat-input:focus{border-color:var(--accent-primary)}.chat-input::placeholder{color:var(--text-muted)}.chat-send-btn{background:var(--accent-primary);color:#fff;border:none;border-radius:10px;width:40px;height:40px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .2s}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.chat-send-btn:not(:disabled):hover{opacity:.85}.chat-widget{position:fixed;bottom:24px;right:24px;z-index:1000;display:flex;flex-direction:column;align-items:flex-end;gap:10px}.chat-widget-toggle{width:52px;height:52px;border-radius:50%;background:var(--accent-primary);color:#fff;border:none;font-size:22px;cursor:pointer;box-shadow:0 4px 20px #6366f166;transition:transform .2s,box-shadow .2s;display:flex;align-items:center;justify-content:center}.chat-widget-toggle:hover{transform:scale(1.08);box-shadow:0 6px 24px #6366f180}.chat-widget-window{width:320px;height:420px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;box-shadow:0 8px 32px #0006;display:flex;flex-direction:column;overflow:hidden;animation:chat-widget-in .2s ease-out}@keyframes chat-widget-in{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.chat-widget-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border-color);background:var(--bg-tertiary);font-size:14px;font-weight:600;color:var(--text-primary)}.chat-widget-fullscreen{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:16px;padding:2px 4px;transition:color .15s}.chat-widget-fullscreen:hover{color:var(--accent-primary)}.chat-widget-messages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px}.chat-widget-hint{font-size:12px;color:var(--text-muted);text-align:center;padding:20px 8px;margin:0}.chat-widget-bubble{max-width:85%;padding:8px 12px;border-radius:10px;font-size:13px;line-height:1.4}.chat-widget-bubble p{margin:0}.chat-widget-bubble.user{background:var(--accent-primary);color:#fff;align-self:flex-end}.chat-widget-bubble.assistant{background:var(--bg-tertiary);color:var(--text-primary);align-self:flex-start;border:1px solid var(--border-color)}.chat-widget-input-row{display:flex;gap:6px;padding:10px;border-top:1px solid var(--border-color)}.chat-widget-input{flex:1;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:13px;padding:7px 10px;outline:none}.chat-widget-input:focus{border-color:var(--accent-primary)}.chat-widget-send{background:var(--accent-primary);color:#fff;border:none;border-radius:8px;width:34px;height:34px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}.chat-widget-send:disabled{opacity:.4;cursor:not-allowed}.mpin-modal{max-width:380px}.mpin-action-summary{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:10px;padding:12px 14px;margin-bottom:16px}.mpin-action-summary p{margin:0 0 8px;font-size:14px;color:var(--text-primary)}.mpin-action-details{display:flex;gap:6px;flex-wrap:wrap}.mpin-detail-chip{background:#6366f126;border:1px solid rgba(99,102,241,.3);color:var(--accent-primary);border-radius:6px;padding:3px 8px;font-size:12px;font-weight:600}.mpin-detail-chip.chip-sell{background:#ef444426;border-color:#ef44444d;color:#ef4444}.mpin-label{font-size:13px;color:var(--text-secondary);margin-bottom:8px}.mpin-input{width:100%;text-align:center;letter-spacing:12px;font-size:24px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);padding:12px;outline:none;margin-bottom:16px;box-sizing:border-box}.mpin-input:focus{border-color:var(--accent-primary)}.alert-modal{max-width:440px}.alert-modal .modal-body{padding:20px 24px 24px}.alert-modal-hint{font-size:12px;color:var(--text-muted);margin:12px 0 16px}.label-unit{font-weight:400;color:var(--text-muted)}.btn-outline-alert{background:transparent;border:1px solid #f59e0b;color:#f59e0b;padding:6px 14px;border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition-fast);margin-top:8px}.btn-outline-alert:hover{background:#f59e0b1f;border-color:#fbbf24;color:#fbbf24}.alerts-empty-state{display:flex;align-items:center;gap:12px;padding:24px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.alerts-empty-icon{font-size:28px;flex-shrink:0}.alerts-empty-text{font-size:13px;color:var(--text-muted);line-height:1.5}.alerts-list{display:flex;flex-direction:column;gap:8px}.alert-row{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:border-color var(--transition-fast)}.alert-row:hover{border-color:var(--border-light)}.alert-triggered{opacity:.6}.alert-row-left{display:flex;align-items:center;gap:12px}.alert-stock-badge{font-size:12px;font-weight:700;color:var(--accent-primary);background:#6366f11f;padding:4px 10px;border-radius:var(--radius-sm);letter-spacing:.5px}.alert-info{display:flex;align-items:center;gap:8px}.alert-condition{font-size:13px;font-weight:600;color:var(--text-primary);text-transform:capitalize}.alert-threshold{font-size:12px;color:var(--text-secondary);background:var(--bg-tertiary);padding:2px 8px;border-radius:var(--radius-sm)}.alert-row-right{display:flex;align-items:center;gap:8px}.alert-status-badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.4px}.alert-status-badge.active{background:#10b98126;color:#10b981}.alert-status-badge.triggered{background:#f59e0b26;color:#f59e0b}.btn-xs{padding:4px 10px;font-size:11px;font-weight:600;border-radius:var(--radius-sm)}.btn-danger{background:#ef44441f;color:#ef4444;border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.btn-danger:hover{background:#ef444438}.btn-outline{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.btn-outline:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.telegram-linked,.telegram-unlinked{padding:4px 0}.telegram-status-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}.telegram-status-badge{font-size:11px;font-weight:700;padding:4px 12px;border-radius:20px;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.telegram-status-badge.linked{background:#10b98126;color:#10b981}.telegram-code-box{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:16px}.telegram-code-display{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-sm);padding:12px 16px;font-size:16px;font-weight:600;color:var(--accent-primary);letter-spacing:1px;text-align:center;-webkit-user-select:all;user-select:all}.telegram-code-display code{background:none;padding:0;font-family:SF Mono,Monaco,Consolas,monospace}
