*{box-sizing:border-box;margin:0;padding:0}:root,html{color-scheme:light only}:root{--color-primary:#10b981;--color-primary-dark:#059669;--color-primary-light:#34d399;--color-secondary:#3b82f6;--color-success:#22c55e;--color-danger:#ef4444;--color-warning:#f59e0b;--color-gray-50:#f9fafb;--color-gray-100:#f3f4f6;--color-gray-200:#e5e7eb;--color-gray-500:#6b7280;--color-gray-700:#374151;--color-gray-900:#111827;--color-background:#f9fafb;--color-card-background:#fff;--color-text:#111827;--color-text-secondary:#6b7280;--color-border:#e5e7eb}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f9fafb;background:var(--color-gray-50);color:#111827;color:var(--color-gray-900);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}.card{background:#fff;border:1px solid #f3f4f6;border:1px solid var(--color-gray-100);border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:16px}.card-hover{cursor:pointer;transition:transform .2s,box-shadow .2s}.card-hover:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:8px 16px;transition:all .2s}.btn-primary{background:#10b981;background:var(--color-primary);color:#fff}.btn-primary:hover{background:#059669;background:var(--color-primary-dark)}.btn-primary:disabled{background:#e5e7eb;background:var(--color-gray-200);cursor:not-allowed}.btn-secondary{background:#f3f4f6;background:var(--color-gray-100);color:#374151;color:var(--color-gray-700)}.btn-secondary:hover{background:#e5e7eb;background:var(--color-gray-200)}.btn-outline{background:#0000;border:1px solid #10b981;border:1px solid var(--color-primary);color:#10b981;color:var(--color-primary)}.btn-outline:hover{background:#10b981;background:var(--color-primary);color:#fff}.input{background-color:#fff;border:1px solid #e5e7eb;border:1px solid var(--color-gray-200);border-radius:8px;color:#111827;color:var(--color-gray-900);font-size:14px;outline:none;padding:10px 14px;transition:all .2s;width:100%}.input:focus{border-color:#10b981;border-color:var(--color-primary);box-shadow:0 0 0 3px #10b9811a}input,select,textarea{background-color:#fff;color-scheme:light only}select option{background-color:#fff;color:#111827}.form-group{margin-bottom:16px}.form-label{color:#374151;color:var(--color-gray-700);display:block;font-size:14px;font-weight:500;margin-bottom:6px}.container{margin:0 auto;max-width:1200px;padding:0 16px}.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-2{gap:8px}.gap-4{gap:16px}.gap-6{gap:24px}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.p-4{padding:16px}.p-6{padding:24px}.px-4{padding-left:16px;padding-right:16px}.py-2{padding-bottom:8px;padding-top:8px}.py-4{padding-bottom:16px;padding-top:16px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.text-sm{font-size:14px}.text-lg{font-size:18px}.text-xl{font-size:20px}.text-2xl{font-size:24px}.font-medium{font-weight:500}.font-semibold{font-weight:600}.text-center{text-align:center}.text-gray-500{color:#6b7280;color:var(--color-gray-500)}.text-gray-700{color:#374151;color:var(--color-gray-700)}.profit{color:#22c55e;color:var(--color-success)}.error-text,.loss{color:#ef4444;color:var(--color-danger)}.error-text{font-size:14px;margin-top:8px}a{color:#10b981;color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}@media (max-width:768px){.grid-cols-2,.grid-cols-3{grid-template-columns:1fr}}.toast{align-items:center;animation:slideDown .3s ease;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;font-size:14px;gap:12px;left:50%;padding:12px 20px;position:fixed;top:20px;transform:translateX(-50%);z-index:9999}@keyframes slideDown{0%{opacity:0;transform:translateX(-50%) translateY(-20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.toast button{background:none;border:none;cursor:pointer;font-size:14px;opacity:.7;padding:0}.toast button:hover{opacity:1}.toast-info{background:#3b82f6;color:#fff}.toast-warning{background:#f59e0b;color:#fff}.toast-error{background:#ef4444;color:#fff}.toast-success{background:#22c55e;color:#fff}.auth-page{align-items:center;background:linear-gradient(135deg,#ecfdf5,#fff 50%,#eff6ff);display:flex;justify-content:center;min-height:100vh;padding:16px}.auth-container{max-width:400px;width:100%}.auth-logo{margin-bottom:32px;text-align:center}.auth-logo h1{color:var(--color-gray-900);font-size:28px;font-weight:700}.auth-logo h1 span{color:var(--color-primary)}.auth-logo p{color:var(--color-gray-500);margin-top:8px}.auth-card{padding:32px}.auth-card h2{color:var(--color-gray-900);font-size:20px;font-weight:600;margin-bottom:24px}.error-box{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:var(--color-danger);display:flex;font-size:14px;justify-content:space-between;margin-bottom:16px;padding:12px}.error-box button{background:none;border:none;color:var(--color-danger);cursor:pointer;opacity:.7}.error-box button:hover{opacity:1}.btn-block{margin-top:8px;padding:12px;width:100%}.auth-footer{color:var(--color-gray-500);font-size:14px;margin-top:24px;text-align:center}.auth-footer a{margin-left:4px}.modal-overlay{align-items:center;animation:modalFadeIn .2s ease;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#0009;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-container{animation:modalSlideUp .25s ease;background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;max-width:420px;overflow:hidden;width:100%}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:20px 24px}.modal-title{color:var(--color-text);font-size:18px;font-weight:600;margin:0}.modal-close{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;transition:background .2s,color .2s;width:32px}.modal-close:hover{background:#f3f4f6;color:var(--color-text)}.modal-body{padding:20px 24px}.modal-footer{background:#f9fafb;border-top:1px solid var(--color-border);display:flex;gap:12px;padding:16px 24px}.modal-footer .btn{flex:1 1;font-size:14px;font-weight:500;padding:12px 16px}.modal-confirm{max-width:380px}.confirm-message{color:var(--color-text-secondary);font-size:15px;line-height:1.6;margin:0;text-align:center}.modal-body .form-group{margin-bottom:16px}.modal-body .form-group:last-child{margin-bottom:0}.modal-body .form-group label{color:var(--color-text);display:block;font-size:14px;font-weight:500;margin-bottom:8px}.modal-body .form-group input,.modal-body .form-group select{border:1px solid var(--color-border);border-radius:10px;font-size:14px;padding:12px 14px;transition:border-color .2s,box-shadow .2s;width:100%}.modal-body .form-group input:focus,.modal-body .form-group select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #10b9811a;outline:none}.modal-body .info-list{background:#f9fafb;border-radius:10px;padding:14px 16px}.modal-body .info-item{align-items:center;display:flex;font-size:14px;justify-content:space-between;padding:8px 0}.modal-body .info-item:not(:last-child){border-bottom:1px solid #e5e7eb}.modal-body .info-item .label{color:var(--color-text-secondary)}.modal-body .info-item .value{color:var(--color-text);font-weight:500}.modal-body .info-item .value.profit{color:var(--color-success)}.modal-body .info-item .value.loss{color:var(--color-danger)}.modal-container.modal-small{max-width:320px}.modal-container.modal-default{max-width:420px}.modal-container.modal-large{display:flex;flex-direction:column;max-height:85vh;max-width:680px}.modal-container.modal-large .modal-body{flex:1 1;overflow-y:auto}@media (max-width:640px){.modal-container.modal-large{max-height:90vh;max-width:100%}}.navbar{background:#fff;border-bottom:1px solid var(--color-gray-100);position:-webkit-sticky;position:sticky;top:0;z-index:50}.navbar-container{margin:0 auto;max-width:1200px;padding:0 16px}.navbar-content{align-items:center;display:flex;height:56px;justify-content:space-between}.navbar-logo{color:var(--color-gray-900);flex-shrink:0;font-size:20px;font-weight:700;text-decoration:none;white-space:nowrap}.navbar-logo span{color:var(--color-primary)}.navbar-links{display:flex;flex-shrink:1;gap:4px;min-width:0}.navbar-link{border-radius:8px;color:var(--color-gray-500);font-size:14px;font-weight:500;padding:8px 16px;text-decoration:none;transition:all .2s;white-space:nowrap}.navbar-link:hover{background:var(--color-gray-100);color:var(--color-gray-700);text-decoration:none}.navbar-link.active{background:#10b9811a;color:var(--color-primary)}.navbar-user{align-items:center;display:flex;flex-shrink:0;gap:12px}.navbar-logout,.navbar-username{color:var(--color-gray-500);font-size:14px;white-space:nowrap}.navbar-logout{background:none;border:none;border-radius:8px;cursor:pointer;padding:6px 12px;transition:all .2s}.navbar-logout:hover{background:var(--color-gray-100);color:var(--color-gray-700)}@media (max-width:900px){.navbar-link{font-size:13px;padding:8px 10px}}@media (max-width:640px){.navbar-username{display:none}.navbar-content{align-items:center;flex-wrap:wrap;gap:0;height:auto;padding:8px 0}.navbar-logo{font-size:17px}.navbar-links{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:2px;justify-content:center;order:3;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;width:100%}.navbar-links::-webkit-scrollbar{display:none}.navbar-link{flex-shrink:0;font-size:12px;padding:6px 10px}.navbar-user{gap:6px;order:2}.navbar-logout{font-size:12px;padding:5px 8px}}@media (max-width:360px){.navbar-logo{font-size:15px}.navbar-link{font-size:11px;padding:5px 8px}}.strategy-card{border:2px solid #0000!important;box-shadow:inset 0 0 0 1px var(--color-gray-100),0 1px 3px #0000001a;cursor:pointer;position:relative}.strategy-card.selected{border-color:var(--color-primary)!important;box-shadow:0 0 0 3px #10b9811a,0 1px 3px #0000001a}.strategy-card-content{display:flex;gap:16px}.strategy-icon{flex-shrink:0;font-size:32px}.strategy-info{flex:1 1;min-width:0}.strategy-info h3{color:var(--color-gray-900);font-size:16px;font-weight:600;margin:0}.strategy-info p{color:var(--color-gray-500);font-size:14px;margin:4px 0 0}.strategy-params{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.param-tag{align-items:center;background:var(--color-gray-100);border-radius:4px;color:var(--color-gray-500);display:inline-flex;font-size:12px;padding:4px 8px}.strategy-selected{position:absolute;right:10px;top:10px}.strategy-selected span{align-items:center;background:var(--color-primary);border-radius:4px;color:#fff;display:inline-flex;font-size:11px;font-weight:500;gap:4px;padding:4px 8px}.leaderboard-card{background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid var(--color-gray-100);border-radius:16px;overflow:hidden;padding:0}.leaderboard-header{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:16px 20px}.leaderboard-header h3{align-items:center;display:flex;font-size:18px;font-weight:600;gap:8px;margin:0}.leaderboard-error,.leaderboard-loading{color:var(--color-gray-500);padding:40px 20px;text-align:center}.leaderboard-list{padding:12px 16px}.leaderboard-item{align-items:center;animation:slideIn .3s ease-out forwards;background:#0000;border-radius:10px;display:flex;margin-bottom:6px;opacity:0;padding:10px 12px;transition:all .2s ease}@keyframes slideIn{0%{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}.leaderboard-item:hover{background:#10b98114}.leaderboard-item.top3{background:linear-gradient(90deg,#10b9811a,#0000)}.leaderboard-item:last-child{margin-bottom:0}.rank-badge{align-items:center;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.rank-icon{font-size:20px}.rank-number{background:var(--color-gray-100);border-radius:50%;color:var(--color-gray-500);font-size:14px;font-weight:600;height:24px;justify-content:center;width:24px}.rank-number,.user-info{align-items:center;display:flex}.user-info{flex:1 1;gap:10px;min-width:0}.user-avatar{align-items:center;display:flex;flex-shrink:0;font-size:20px;height:28px;justify-content:center;width:28px}.user-avatar.default{background:var(--color-gray-100);border-radius:50%;font-size:14px}.user-name{color:var(--color-gray-900);font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mock-badge{background:#10b98126;border-radius:4px;color:var(--color-primary);flex-shrink:0;font-size:10px;font-weight:600;padding:2px 6px}.return-rate{font-size:14px;font-weight:600;min-width:70px;text-align:right}.return-rate.profit{color:var(--color-success)}.return-rate.loss{color:var(--color-danger)}.my-ranking{align-items:center;background:linear-gradient(135deg,#10b9811a,#10b9810d);border:1px dashed var(--color-primary);border-radius:10px;display:flex;justify-content:space-between;margin:0 16px;padding:12px 16px}.my-ranking-label{color:var(--color-gray-700);font-size:13px;font-weight:500}.my-ranking-info{align-items:center;display:flex;gap:12px}.my-rank{color:var(--color-gray-900)}.my-rank,.my-rate{font-size:14px;font-weight:600}.my-rate.profit{color:var(--color-success)}.my-rate.loss{color:var(--color-danger)}.leaderboard-footer{border-top:1px solid var(--color-gray-100);margin-top:8px;padding:12px 16px;text-align:center}.leaderboard-footer p{color:var(--color-gray-500);font-size:12px;margin:0}@media (max-width:640px){.leaderboard-card{border-radius:12px}.leaderboard-header{padding:12px 16px}.leaderboard-header h3{font-size:16px}.leaderboard-item{padding:8px 10px}.return-rate,.user-name{font-size:13px}.return-rate{min-width:60px}}.code-block{background:#2d2d2d;border:1px solid var(--color-gray-200);border-radius:8px;overflow:hidden}.code-block-header{align-items:center;background:#1e1e1e;border-bottom:1px solid #3d3d3d;display:flex;justify-content:space-between;padding:8px 12px}.code-language{color:#888;font-size:12px;font-weight:500;text-transform:uppercase}.code-copy-btn{background:#0000;border:1px solid #555;border-radius:4px;color:#aaa;cursor:pointer;font-size:12px;padding:4px 10px;transition:all .2s}.code-copy-btn:hover{background:#3d3d3d;border-color:#666;color:#fff}.code-copy-btn.copied{background:#059669;border-color:#059669;color:#fff}.code-block-content{overflow-y:auto}.code-block-content::-webkit-scrollbar{width:8px}.code-block-content::-webkit-scrollbar-track{background:#1e1e1e}.code-block-content::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.code-block-content::-webkit-scrollbar-thumb:hover{background:#666}.code-block pre{margin:0!important}.code-block code{font-family:JetBrains Mono,Fira Code,Consolas,monospace!important}.strategy-detail-modal{display:flex;flex-direction:column;gap:20px}.detail-section{display:flex;flex-direction:column;gap:12px}.detail-section h4{color:#334155;font-size:14px;font-weight:600;margin:0}.detail-description{background:#f8fafc;border-radius:8px;color:#475569;font-size:14px;line-height:1.6;margin:0;padding:12px}.detail-metrics{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.metric-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;gap:4px;padding:12px}.metric-label{color:#64748b;font-size:12px}.metric-value{color:#0f172a;font-size:16px;font-weight:600}.metric-item.profit .metric-value{color:#059669}.metric-item.loss .metric-value{color:#dc2626}.metric-item.warning .metric-value{color:#d97706}.detail-code-header{align-items:center;display:flex;justify-content:space-between}.copy-btn{align-items:center;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:6px;color:#475569;cursor:pointer;display:inline-flex;font-size:12px;font-weight:500;gap:4px;padding:6px 12px;transition:all .2s}.copy-btn:hover{background:#e2e8f0;color:#0f172a}.detail-code-block{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden}.detail-actions{border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;padding-top:12px}.detail-btn{align-items:center;border-radius:8px;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:6px;padding:10px 20px;transition:all .2s}.optimize-btn{background:#f5f3ff;border:1px solid #ddd6fe;color:#7c3aed}.optimize-btn:hover{background:#7c3aed;color:#fff}.backtest-btn{background:#10b981;background:var(--color-primary,#10b981);border:none;color:#fff}.backtest-btn:hover{background:#059669}@media (max-width:640px){.detail-metrics{grid-template-columns:repeat(2,1fr)}.detail-actions{flex-direction:column}.detail-btn{justify-content:center}}.page{background:var(--color-gray-50);min-height:100vh}.page-content{padding:24px 16px}.page-header h1{color:var(--color-gray-900);font-weight:700}.page-header p{color:var(--color-gray-500);font-size:14px;margin:4px 0 0}.dashboard-layout{grid-gap:24px;align-items:start;display:grid;gap:24px;grid-template-columns:1fr 320px}.strategy-area{min-width:0}.leaderboard-area{position:-webkit-sticky;position:sticky;top:80px}.loading{padding:48px 0}.spinner{border:3px solid var(--color-gray-200);height:32px;width:32px}.strategy-section{margin-bottom:32px}.strategy-section h2{border-bottom:1px solid var(--color-gray-200);color:var(--color-gray-700);font-size:16px;font-weight:600;margin:0 0 16px;padding-bottom:8px}.strategy-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.user-strategy-card{border:2px solid #0000!important;box-shadow:inset 0 0 0 1px var(--color-gray-100),0 1px 3px #0000001a;padding:16px;position:relative}.user-strategy-card .card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:8px}.user-strategy-card .card-header h3{color:var(--color-gray-900);font-size:16px;font-weight:600;margin:0}.user-strategy-card .delete-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:var(--color-gray-500);cursor:pointer;display:flex;font-size:18px;height:24px;justify-content:center;transition:background .2s,color .2s;width:24px}.user-strategy-card .delete-btn:hover{background:#fee2e2;color:var(--color-danger)}.user-strategy-card .card-desc{color:var(--color-gray-500);font-size:13px;margin:0 0 12px}.user-strategy-card .card-params{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.user-strategy-card .param-tag{background:var(--color-gray-100);border-radius:4px;color:var(--color-gray-700);font-size:12px;padding:3px 8px}.user-strategy-card .card-time{color:var(--color-gray-500);font-size:12px}.user-strategy-card .card-return-rate{font-size:13px;font-weight:600;margin-bottom:8px}.user-strategy-card .card-return-rate.profit{color:var(--color-success)}.user-strategy-card .card-return-rate.loss{color:var(--color-danger)}.user-strategy-card .card-actions{border-top:1px solid var(--color-gray-100);display:flex;gap:8px;margin-top:12px;padding-top:12px}.user-strategy-card .action-btn{align-items:center;border-radius:6px;cursor:pointer;display:flex;flex:1 1;font-size:12px;font-weight:500;gap:4px;justify-content:center;padding:6px 12px;transition:all .2s}.user-strategy-card .action-btn.detail-btn{background:#f1f5f9;border:1px solid #e2e8f0;color:#475569}.user-strategy-card .action-btn.detail-btn:hover{background:#e2e8f0;color:#0f172a}.user-strategy-card .action-btn.optimize-btn{background:#f5f3ff;border:1px solid #ddd6fe;color:#7c3aed}.user-strategy-card .action-btn.optimize-btn:hover{background:#7c3aed;color:#fff}.user-strategy-card.selected{border-color:var(--color-primary)!important;box-shadow:0 0 0 3px #10b9811a,0 1px 3px #0000001a}.user-strategy-card .selected-badge{align-items:center;background:var(--color-primary);border-radius:4px;color:#fff;display:inline-flex;font-size:11px;font-weight:500;gap:4px;padding:4px 8px;position:absolute;right:40px;top:10px}.empty-user-strategies{background:var(--color-gray-50);border:1px dashed var(--color-gray-200);border-radius:8px;padding:32px;text-align:center}.empty-user-strategies p{color:var(--color-gray-500);margin:0}.empty-user-strategies .hint{color:var(--color-gray-500);font-size:13px;margin-top:8px}.action-bar{display:flex;justify-content:flex-end;margin-top:24px}.openclaw-guide-banner{align-items:center;background:linear-gradient(135deg,#f0f9ff,#eef2ff);border:1px solid #bfdbfe;border-radius:12px;box-shadow:0 1px 2px #1e40af0f;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px;padding:14px 16px}.openclaw-guide-text{color:var(--color-gray-700);display:flex;flex:1 1;flex-direction:column;font-size:13px;gap:6px;line-height:1.5;min-width:0}.openclaw-guide-text strong{color:#1e3a5f;font-size:14px}.openclaw-guide-link{color:var(--color-primary);font-weight:600;margin:0 2px;text-decoration:none}.openclaw-guide-link:hover{text-decoration:underline}.openclaw-guide-btn{flex-shrink:0;min-height:40px;padding-left:16px;padding-right:16px;white-space:nowrap}.openclaw-guide-btn:disabled{cursor:not-allowed;opacity:.7}@media (max-width:1024px){.dashboard-layout{grid-template-columns:1fr}.leaderboard-area{margin-bottom:8px;order:-1;position:static}}@media (max-width:640px){.openclaw-guide-banner{align-items:stretch;flex-direction:column}.openclaw-guide-btn{width:100%}.strategy-grid{grid-template-columns:1fr}.action-bar{background:#fff;border-top:1px solid var(--color-gray-100);bottom:0;left:0;margin:0;padding:16px;position:fixed;right:0;z-index:100}.action-bar .btn{width:100%}.strategy-area{padding-bottom:80px}}.custom-checkbox{align-items:center;cursor:pointer;display:inline-flex;gap:12px;height:24px;outline:none;-webkit-user-select:none;user-select:none}.custom-checkbox:focus-visible .checkbox-box{box-shadow:0 0 0 3px #10b9814d}.custom-checkbox.disabled{cursor:not-allowed;opacity:.5}.checkbox-box{align-items:center;background:#fff;border:2px solid #d1d5db;border-radius:4px;display:flex;flex-shrink:0;height:18px;justify-content:center;position:relative;transition:background-color .15s ease,border-color .15s ease;width:18px}.custom-checkbox:hover:not(.disabled) .checkbox-box{border-color:#10b981}.custom-checkbox.checked .checkbox-box{background:#10b981;border-color:#10b981}.checkbox-icon{color:#fff;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.checkbox-text{color:#111827;font-size:14px;font-weight:500;line-height:24px}.custom-checkbox.disabled .checkbox-text{color:#9ca3af}.custom-select{position:relative;width:100%}.select-trigger{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;padding:10px 12px;transition:all .2s ease;-webkit-user-select:none;user-select:none}.select-trigger:hover{border-color:#d1d5db}.custom-select.open .select-trigger{border-color:#10b981;box-shadow:0 0 0 3px #10b98126}.custom-select.disabled .select-trigger{background:#f9fafb;cursor:not-allowed;opacity:.7}.select-value{color:#111827;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.select-value.placeholder{color:#9ca3af}.select-arrow{align-items:center;color:#6b7280;display:flex;transition:transform .2s ease}.custom-select.open .select-arrow{transform:rotate(180deg)}.select-dropdown{animation:dropdownFadeIn .15s ease;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 25px #0000001a;left:0;max-height:240px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 4px);z-index:1000}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.select-option{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:14px;justify-content:space-between;padding:10px 12px;transition:background-color .15s ease}.select-option:hover{background:#f3f4f6}.select-option.selected{background:#ecfdf5;color:#059669;font-weight:500}.check-icon{color:#10b981}.custom-datepicker{position:relative;width:100%}.datepicker-trigger{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;padding:10px 12px;transition:all .2s ease;-webkit-user-select:none;user-select:none}.datepicker-trigger:hover{border-color:#d1d5db}.custom-datepicker.open .datepicker-trigger{border-color:#10b981;box-shadow:0 0 0 3px #10b98126}.custom-datepicker.disabled .datepicker-trigger{background:#f9fafb;cursor:not-allowed;opacity:.7}.datepicker-value{color:#111827;font-size:14px}.datepicker-value.placeholder{color:#9ca3af}.datepicker-icon{align-items:center;color:#6b7280;display:flex}.datepicker-dropdown{animation:dropdownFadeIn .15s ease;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 40px #0000001f;left:0;min-width:280px;padding:12px;position:absolute;top:calc(100% + 4px);z-index:1000}.datepicker-header{align-items:center;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:12px}.datepicker-header .nav-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;height:28px;justify-content:center;transition:all .15s ease;width:28px}.datepicker-header .nav-btn:hover{background:#f3f4f6;color:#111827}.current-month{color:#111827;font-size:14px;font-weight:600}.datepicker-weekdays{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr);margin-bottom:8px}.weekday{align-items:center;color:#9ca3af;display:flex;font-size:12px;font-weight:500;height:32px;justify-content:center}.datepicker-days{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr)}.day{align-items:center;border-radius:6px;color:#374151;cursor:pointer;display:flex;font-size:13px;height:32px;justify-content:center;transition:all .15s ease}.day:hover:not(.empty):not(.disabled):not(.selected){background:#f3f4f6}.day.empty{cursor:default}.day.selected{background:#10b981;color:#fff;font-weight:500}.day.disabled{color:#d1d5db;cursor:not-allowed}.datepicker-footer{border-top:1px solid #f3f4f6;display:flex;justify-content:center;margin-top:12px;padding-top:12px}.today-btn{background:#0000;border:1px solid #10b981;border-radius:6px;color:#10b981;cursor:pointer;font-size:13px;font-weight:500;padding:6px 16px;transition:all .15s ease}.today-btn:hover{background:#10b981;color:#fff}.tool-call-card{align-items:center;animation:tcc-slideIn .3s ease;border-radius:8px;display:flex;font-size:13px;gap:10px;margin-bottom:8px;overflow:hidden;padding:10px 16px}.tool-call-card.compact{font-size:12px;margin-bottom:4px;padding:6px 12px}.tool-call-card.running{animation:tcc-slideIn .3s ease,tcc-pulse 2s ease-in-out infinite;background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fcd34d;color:#92400e}.tool-call-card.done{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1px solid #6ee7b7;color:#065f46}.tcc-spinner{animation:tcc-spin .8s linear infinite;border:2px solid #fbbf24;border-radius:50%;border-top-color:#0000;flex-shrink:0;height:14px;width:14px}.tool-call-card.compact .tcc-spinner{height:12px;width:12px}.tcc-check{color:#10b981;flex-shrink:0;font-size:14px;font-weight:700}.tcc-body{align-items:center;display:flex;flex:1 1;gap:8px;min-width:0;overflow:hidden}.tcc-label{flex-shrink:0;font-size:12px;font-weight:500;opacity:.7}.tcc-meta{color:#6b7280;color:var(--color-text-secondary,#6b7280);flex-shrink:0;font-size:11px;margin-left:4px}.tcc-name-scroll{flex:1 1;mask-image:linear-gradient(90deg,#0000,#000 8px,#000 calc(100% - 8px),#0000);-webkit-mask-image:linear-gradient(90deg,#0000,#000 8px,#000 calc(100% - 8px),#0000);min-width:0;overflow:hidden}.tool-call-card.running .tcc-name-scroll .tcc-name{animation:tcc-scroll 3s linear infinite;display:inline-block;white-space:nowrap}.tcc-name{background:#00000014;border-radius:4px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:.9em;font-weight:500;padding:2px 6px}.tcc-result{color:#6b7280;color:var(--color-text-secondary,#6b7280);flex-shrink:1;font-size:12px;margin-left:auto;max-width:50%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tool-call-card.compact .tcc-result{font-size:11px}.tool-call-card.compact .tcc-meta{font-size:10px}@keyframes tcc-slideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@keyframes tcc-pulse{0%,to{box-shadow:0 0 0 0 #fcd34d66}50%{box-shadow:0 0 0 4px #fcd34d00}}@keyframes tcc-spin{to{transform:rotate(1turn)}}@keyframes tcc-scroll{0%,20%{transform:translateX(0)}80%,to{transform:translateX(-30%)}}.backtest-stream-page{background:var(--color-background);min-height:100vh}.stream-container{display:flex;flex-direction:column;gap:24px;margin:0 auto;max-width:1000px;padding:24px 16px}.config-section{background:var(--color-card-background);border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:20px}.config-section h2{color:var(--color-text);font-size:18px;margin:0 0 16px}.config-row{margin-bottom:16px}.config-row label{color:var(--color-text-secondary);display:block;font-size:14px;margin-bottom:6px}.config-row input:not([type=checkbox]),.config-row select{-webkit-appearance:none;appearance:none;background-color:#fff!important;border:1px solid var(--color-border);border-radius:8px;color:var(--color-text)!important;color-scheme:light only;font-family:inherit;font-size:14px;forced-color-adjust:none;padding:10px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.config-row select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%236b7280' d='m2 4 4 4 4-4'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:12px;cursor:pointer;padding-right:36px}.config-row select option{background-color:#fff!important;color:#111827!important;padding:8px 12px}.config-row input[type=date]{cursor:pointer;position:relative}.config-row input[type=date]::-webkit-datetime-edit{color:var(--color-text)}.config-row input[type=date]::-webkit-datetime-edit-fields-wrapper{background-color:initial}.config-row input[type=date]::-webkit-calendar-picker-indicator{background-color:initial;border-radius:4px;cursor:pointer;opacity:.5;padding:4px;-webkit-transition:opacity .2s,background-color .2s;transition:opacity .2s,background-color .2s}.config-row input[type=date]::-webkit-calendar-picker-indicator:hover{background-color:#10b9811a;opacity:1}.config-row input[type=number]{-webkit-appearance:textfield;appearance:textfield}.config-row input[type=number]::-webkit-inner-spin-button,.config-row input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.config-row input:focus,.config-row select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #10b98126;outline:none}.config-row input:disabled,.config-row select:disabled{background-color:#f9fafb!important;color:#9ca3af!important;cursor:not-allowed;opacity:.8}.config-row.balance-position,.config-row.dates,.config-row.params{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr 1fr}.input-with-suffix{align-items:center;display:flex;gap:4px}.input-with-suffix input{flex:1 1;min-width:0}.input-with-suffix .suffix{color:var(--color-text-secondary);flex-shrink:0;font-size:14px}.config-actions{margin-top:20px}.config-actions .btn{font-size:16px;padding:12px;width:100%}.message-section{background:var(--color-card-background);border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.message-header{border-bottom:1px solid var(--color-border);padding:16px 20px}.message-header h3{color:var(--color-text);font-size:16px;margin:0}.progress-date{color:var(--color-primary);font-size:13px;font-weight:500}.message-list{max-height:400px;overflow-y:auto;padding:12px}.empty-message,.loading-message{color:var(--color-text-secondary);padding:40px 20px;text-align:center}.error-message{background:#fef2f2;border-radius:8px;color:var(--color-danger);margin:8px;padding:16px}.loading-message{align-items:center;display:flex;gap:10px;justify-content:center}.spinner{height:18px;width:18px}.trade-message{background:#f9fafb;border-left:4px solid;border-radius:8px;margin-bottom:8px;padding:12px 16px}.trade-message.buy{background:#f0fdf4;border-left-color:var(--color-success)}.trade-message.sell{background:#fef2f2;border-left-color:var(--color-danger)}.trade-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.trade-reason{margin-bottom:8px}.trade-finance{border-top:1px dashed #e5e7eb;display:flex;flex-wrap:wrap;gap:12px;margin-top:8px;padding-top:8px}.finance-item{align-items:center;display:flex;font-size:12px;gap:6px}.finance-label{color:var(--color-text-secondary)}.finance-value{color:var(--color-text);font-size:12px;font-weight:400}.finance-value.profit{color:var(--color-success)}.finance-value.loss{color:var(--color-danger)}.stats-section{background:var(--color-card-background);border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:20px}.stats-section h3{color:var(--color-text);font-size:16px;margin:0 0 16px}.stats-grid{margin-bottom:20px}.stat-card{background:#f9fafb;border-radius:8px;padding:16px;text-align:center}.stat-card.profit{background:#f0fdf4}.stat-card.loss{background:#fef2f2}.stat-card.profit .stat-value{color:var(--color-success)}.stat-card.loss .stat-value{color:var(--color-danger)}.stats-actions{display:flex;gap:12px}.stats-actions .btn{flex:1 1;padding:12px}.stats-actions .btn-optimize{background:linear-gradient(135deg,#7c3aed,#6d28d9);border:none;color:#fff}.stats-actions .btn-optimize:hover{background:linear-gradient(135deg,#6d28d9,#5b21b6)}@media (max-width:480px){.config-row.balance-position,.config-row.dates,.config-row.params{grid-template-columns:1fr 1fr}@media (max-width:480px){.config-row.balance-position{grid-template-columns:1fr}}.stats-actions{flex-direction:column}}.agent-config{align-items:center;border-top:1px solid var(--color-border);display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-top:8px;padding-top:16px}.agent-toggle{flex-shrink:0}.agent-interval-inline{align-items:center;display:flex;gap:8px;transition:opacity .2s}.agent-interval-inline.disabled{opacity:.4;pointer-events:none}.agent-interval-inline .interval-label{color:var(--color-text-secondary);font-size:13px;white-space:nowrap}.agent-interval-inline input{font-size:14px;padding:6px 8px;width:70px}.agent-interval-inline .interval-unit{color:var(--color-text-secondary);font-size:13px}.agent-badge{background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:12px;font-size:12px;padding:4px 10px}.agent-badge,.agent-strategy-badge{color:#fff;font-weight:500;margin-left:8px}.agent-strategy-badge{background:linear-gradient(135deg,#10b981,#059669);border-radius:10px;display:inline-block;font-size:11px;padding:2px 8px}.agent-tool-card{align-items:center;animation:slideIn .3s ease;border-radius:8px;display:flex;font-size:13px;gap:10px;margin-bottom:8px;padding:10px 16px}.agent-tool-card.running{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fcd34d;color:#92400e}.agent-tool-card.done{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1px solid #6ee7b7;color:#065f46}.agent-tool-card .tool-check{color:#10b981;font-size:14px;font-weight:700}.agent-tool-card .tool-text{font-weight:500}.agent-tool-card .tool-text code{background:#00000014;border-radius:4px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:.9em;padding:2px 6px}.agent-tool-card .tool-result{color:var(--color-text-secondary);font-size:12px;margin-left:auto;max-width:50%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.agent-message{animation:slideIn .3s ease;background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-left:4px solid #6366f1;border-radius:12px;margin-bottom:12px;padding:16px}.agent-message.analyzing{background:linear-gradient(135deg,#fffbeb,#fef3c7);border-left-color:#f59e0b}.agent-message.adjusted{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-left-color:#10b981}.agent-message.no_change{background:linear-gradient(135deg,#f9fafb,#f3f4f6);border-left-color:#6b7280}.agent-header{align-items:center;display:flex;gap:8px;margin-bottom:10px}.agent-icon{font-size:20px}.agent-title{color:#6366f1;font-weight:600}.agent-message.analyzing .agent-title{color:#f59e0b}.agent-message.adjusted .agent-title{color:#10b981}.agent-message.no_change .agent-title{color:#6b7280}.agent-time{color:var(--color-text-secondary);font-size:12px;margin-left:auto}.agent-bundle-tools{background:#ffffff73;border:1px solid #6366f11f;border-radius:10px;margin:0 0 12px 28px;padding:10px 12px}.agent-bundle .agent-content{margin-top:4px}.agent-content{padding-left:28px}.agent-text{color:var(--color-text);line-height:1.6;margin:0}.agent-params-change{align-items:center;background:#ffffffb3;border-radius:8px;display:flex;flex-wrap:wrap;font-size:13px;gap:12px;margin-top:12px;padding:10px 12px}.params-after,.params-before{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.params-after .label,.params-before .label{color:var(--color-text-secondary);font-weight:500}.params-before .param{background:#fee2e2;color:#dc2626}.params-after .param,.params-before .param{border-radius:4px;font-family:monospace;padding:2px 8px}.params-after .param{background:#dcfce7;color:#16a34a}.params-arrow{font-size:16px}.agent-reason,.params-arrow{color:var(--color-text-secondary)}.agent-reason{font-size:13px;font-style:italic;margin:10px 0 0}.agent-tool-loading{align-items:center;animation:pulse 1.5s ease-in-out infinite;background:#f59e0b1a;border-radius:12px;color:#f59e0b;display:flex;font-size:12px;gap:6px;padding:4px 10px}.tool-spinner{animation:spin .8s linear infinite;border:2px solid #fcd34d;border-radius:50%;border-top-color:#f59e0b;height:12px;width:12px}.agent-text code.inline-code{background:#00000014;border-radius:4px;padding:2px 6px}.agent-reason code.inline-code,.agent-text code.inline-code{font-family:SF Mono,Monaco,Consolas,monospace;font-size:.9em}.agent-reason code.inline-code{background:#0000000d;border-radius:3px;padding:1px 4px}.message-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.message-header .header-left{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.btn-detail{background:#fff;border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-secondary);cursor:pointer;font-size:13px;padding:6px 12px;transition:all .2s}.btn-detail:hover{background:var(--color-background);border-color:var(--color-primary);color:var(--color-primary)}.detail-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.detail-modal{animation:slideUp .25s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:85vh;max-width:900px;width:100%}.detail-modal-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;gap:16px;padding:20px 24px}.detail-modal-header h2{font-size:18px;font-weight:600;margin:0}.detail-stats{color:var(--color-text-secondary);display:flex;font-size:13px;gap:12px}.detail-modal-header .close-btn{background:#0000;border:none;border-radius:6px;color:var(--color-text-secondary);cursor:pointer;font-size:24px;height:32px;margin-left:auto;transition:all .2s;width:32px}.detail-modal-header .close-btn:hover{background:var(--color-background);color:var(--color-text)}.detail-modal-body{flex:1 1;overflow-y:auto;padding:16px 24px}.detail-trade{border-left:3px solid;border-radius:8px;display:flex;flex-direction:column;gap:6px;margin-bottom:8px;padding:12px 16px}.detail-trade.buy{background:#f0fdf4;border-left-color:#22c55e}.detail-trade.sell{background:#fef2f2;border-left-color:#ef4444}.detail-trade-main{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.detail-time{color:var(--color-text-secondary);font-family:monospace;font-size:12px}.detail-signal{font-size:13px;font-weight:600}.detail-signal.buy{color:#16a34a}.detail-signal.sell{color:#dc2626}.detail-price{font-family:monospace;font-weight:500}.detail-reason{color:var(--color-text-secondary);font-size:13px}.detail-trade-finance{color:var(--color-text-secondary);display:flex;font-size:12px;gap:16px}.detail-trade-finance .profit{color:#16a34a}.detail-trade-finance .loss{color:#dc2626}.detail-agent{align-items:center;background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-left:3px solid #6366f1;border-radius:8px;display:flex;flex-wrap:wrap;font-size:13px;gap:10px;margin-bottom:8px;padding:10px 16px}.detail-agent.adjusted{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-left-color:#10b981}.detail-agent.no_change{background:#f9fafb;border-left-color:#9ca3af}.detail-agent-icon{font-size:16px}.detail-agent-msg{color:var(--color-text)}.detail-params{background:#0000000d;border-radius:4px;font-family:monospace;font-size:12px;padding:2px 8px}.detail-agent-bundle{background:linear-gradient(135deg,#f5f3ff,#ede9fe);border:1px solid #6366f133;border-radius:10px;margin-bottom:10px;padding:12px 14px}.detail-agent-bundle-head{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.detail-bundle-pending{background:#f59e0b1f;border-radius:8px;color:#d97706;font-size:12px;padding:2px 8px}.detail-tool-input{color:var(--color-text-secondary);display:block;font-size:11px;margin-top:4px;word-break:break-all}.detail-agent-tool{align-items:center;background:#f0fdf4;border-left:3px solid #86efac;border-radius:6px;color:#065f46;display:flex;font-size:12px;gap:8px;margin-bottom:4px;padding:6px 16px}.detail-agent-tool code{background:#0000000f;border-radius:3px;font-family:SF Mono,Monaco,Consolas,monospace;padding:1px 5px}.detail-tool-result{color:var(--color-text-secondary);font-size:11px;margin-left:auto}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.help-btn{align-items:center;background:#f9fafb;border:1px solid #d1d5db;border-radius:50%;color:#6b7280;cursor:pointer;display:inline-flex;font-size:11px;font-weight:600;height:18px;justify-content:center;margin-left:8px;transition:all .2s ease;vertical-align:middle;width:18px}.help-btn:hover{background:#10b981;border-color:#10b981;color:#fff}.help-content{font-size:14px;line-height:1.6}.help-content h4{border-bottom:1px solid #e5e7eb;color:#111827;font-size:14px;font-weight:600;margin:0 0 12px;padding-bottom:8px}.help-content h4:not(:first-child){margin-top:20px}.help-section{gap:10px}.help-item,.help-section{display:flex;flex-direction:column}.help-item{background:#f9fafb;border-left:3px solid #10b981;border-radius:6px;gap:2px;padding:8px 12px}.help-label{color:#374151;font-size:13px;font-weight:600}.help-desc{color:#6b7280;font-size:12px}.help-note{align-items:flex-start;background:linear-gradient(135deg,#fffbeb,#fef3c7);border-radius:8px;color:#92400e;display:flex;font-size:12px;gap:8px;margin-top:16px;padding:12px}.note-icon{flex-shrink:0}.favorites-page{background:var(--color-background);min-height:100vh}.favorites-container{margin:0 auto;max-width:1000px;padding:24px 16px}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.page-header h1{color:var(--color-text);font-size:24px;margin:0}.empty-state{color:var(--color-text-secondary);padding:60px 20px;text-align:center}.empty-icon{font-size:48px;margin-bottom:16px}.empty-state p{margin:0 0 8px}.empty-state .hint{font-size:14px;opacity:.7}.favorites-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.favorite-card{background:var(--color-card-background);border-radius:12px;box-shadow:0 1px 3px #0000001a;cursor:pointer;padding:16px;transition:transform .2s,box-shadow .2s}.favorite-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.card-title{color:var(--color-text);flex:1 1;font-size:16px;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.delete-btn{align-items:center;background:#f3f4f6;border:none;border-radius:50%;color:var(--color-text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:16px;height:24px;justify-content:center;margin-left:8px;width:24px}.delete-btn:hover{background:var(--color-danger);color:#fff}.card-body{border-bottom:1px solid var(--color-border);border-top:1px solid var(--color-border);margin-bottom:12px;padding:12px 0}.card-row{display:flex;font-size:13px;justify-content:space-between;margin-bottom:6px}.card-row:last-child{margin-bottom:0}.card-row .label{color:var(--color-text-secondary)}.card-row .value{color:var(--color-text);font-weight:500}.card-footer{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.profit{font-size:12px}.profit.positive{color:var(--color-success)}.profit.negative{color:var(--color-danger)}.win-rate{font-size:13px}.card-time,.win-rate{color:var(--color-text-secondary)}.card-time{font-size:12px;opacity:.7}@media (max-width:480px){.page-header{align-items:flex-start;flex-direction:column;gap:12px}.page-header .btn{width:100%}}.favorite-detail-page{background:var(--color-background);min-height:100vh}.detail-container{margin:0 auto;max-width:800px;padding:24px 16px}.back-btn{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:14px;margin-bottom:16px;padding:0}.back-btn:hover{text-decoration:underline}.detail-title{color:var(--color-text);font-size:24px;margin:0 0 24px}.loading{align-items:center;color:var(--color-text-secondary);display:flex;gap:10px;justify-content:center;padding:60px 20px}.spinner{animation:spin .8s linear infinite;border:2px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.info-card,.stats-card,.trades-card{background:var(--color-card-background);border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:16px;padding:20px}.info-card h2,.stats-card h2,.trades-card h2{color:var(--color-text);font-size:16px;margin:0 0 16px}.info-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.info-item{display:flex;flex-direction:column}.info-item .label{color:var(--color-text-secondary);font-size:12px;margin-bottom:4px}.info-item .value{color:var(--color-text);font-size:14px;font-weight:500}.params-section{border-top:1px solid var(--color-border);margin-top:16px;padding-top:16px}.params-section h3{color:var(--color-text-secondary);font-size:14px;margin:0 0 12px}.params-grid{display:flex;flex-wrap:wrap;gap:12px}.param-item{background:#f3f4f6;border-radius:6px;padding:8px 12px}.param-item .label{color:var(--color-text-secondary);font-size:12px;margin-right:8px}.param-item .value{color:var(--color-text);font-size:14px;font-weight:600}.stats-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}.stat-item{background:#f9fafb;border-radius:8px;padding:16px;text-align:center}.stat-item.profit{background:#f0fdf4}.stat-item.loss{background:#fef2f2}.stat-value{color:var(--color-text);display:block;font-size:24px;font-weight:700;margin-bottom:4px}.stat-item.profit .stat-value{color:var(--color-success)}.stat-item.loss .stat-value{color:var(--color-danger)}.stat-label{color:var(--color-text-secondary);font-size:12px}.trades-list{max-height:500px;overflow-y:auto}.trade-item{background:#f9fafb;border-left:4px solid;border-radius:8px;margin-bottom:8px;padding:12px}.trade-item:last-child{margin-bottom:0}.trade-item.buy{background:#f0fdf4;border-left-color:var(--color-success)}.trade-item.sell{background:#fef2f2;border-left-color:var(--color-danger)}.trade-time{color:var(--color-text-secondary);font-size:12px;margin-bottom:4px}.trade-info{align-items:center;display:flex;gap:12px;margin-bottom:4px}.trade-info .signal{font-size:14px;font-weight:600}.trade-info .signal.buy{color:var(--color-success)}.trade-info .signal.sell{color:var(--color-danger)}.trade-info .price{color:var(--color-text);font-size:14px;font-weight:500}.trade-reason{color:var(--color-text-secondary);font-size:13px}.detail-footer{padding-top:16px;text-align:center}.created-time{color:var(--color-text-secondary);font-size:12px}@media (min-width:640px){.stats-grid{grid-template-columns:repeat(4,1fr)}}.strategy-preview-card{background:linear-gradient(135deg,#f8fffe,#f0fdf9);border:1px solid var(--color-primary-light);border-radius:12px;padding:16px;transition:all .2s}.strategy-preview-card:hover{box-shadow:0 4px 12px #10b98126}.preview-header{align-items:flex-start;display:flex;gap:12px;margin-bottom:12px}.preview-icon{align-items:center;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));border-radius:10px;display:flex;flex-shrink:0;font-size:20px;height:40px;justify-content:center;width:40px}.preview-title{flex:1 1;min-width:0}.preview-title h4{align-items:center;color:var(--color-gray-900);display:flex;font-size:15px;font-weight:600;gap:8px;margin:0 0 4px}.preview-badge{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:10px;color:#92400e;display:inline-block;font-size:10px;font-weight:600;padding:2px 8px}.preview-description{color:var(--color-gray-700);font-size:13px;line-height:1.5;margin:0 0 12px}.preview-code{border-radius:8px;margin-bottom:12px;overflow:hidden}.preview-code .code-block{margin:0}.preview-actions{display:flex;flex-wrap:wrap;gap:8px}.preview-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:4px;padding:8px 14px;transition:all .2s}.preview-btn-primary{background:var(--color-primary);color:#fff}.preview-btn-primary:hover{background:var(--color-primary-dark)}.preview-btn-outline{background:#0000;border:1px solid var(--color-primary);color:var(--color-primary)}.preview-btn-outline:hover{background:var(--color-primary);color:#fff}.preview-btn-secondary{background:var(--color-gray-100);color:var(--color-gray-700)}.preview-btn-secondary:hover{background:var(--color-gray-200)}.strategy-preview-card.compact{padding:12px}.strategy-preview-card.compact .preview-icon{font-size:16px;height:32px;width:32px}.strategy-preview-card.compact .preview-title h4{font-size:14px}.strategy-preview-card.compact .preview-description{font-size:12px;margin-bottom:12px}.strategy-preview-card.compact .preview-btn{font-size:12px;padding:6px 10px}@media (max-width:480px){.preview-actions{flex-direction:column}.preview-btn{justify-content:center;width:100%}}.chat-message{animation:fadeIn .3s ease;display:flex;gap:12px;padding:12px 0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message.user{flex-direction:row-reverse}.message-avatar{align-items:center;background:var(--color-gray-100);border-radius:50%;display:flex;flex-shrink:0;font-size:18px;height:36px;justify-content:center;width:36px}.chat-message.assistant .message-avatar{background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.chat-message.user .message-avatar{background:linear-gradient(135deg,#e3f2fd,#bbdefb)}.message-content-wrapper{display:flex;flex-direction:column;max-width:75%}.chat-message.user .message-content-wrapper{align-items:flex-end}.message-bubble{border-radius:16px;padding:12px 16px;position:relative}.chat-message.assistant .message-bubble{background:#fff;border:1px solid var(--color-gray-200);border-radius:16px 16px 16px 4px}.chat-message.user .message-bubble{background:var(--color-primary);border-radius:16px 16px 4px 16px;color:#fff}.message-text{word-wrap:break-word;font-size:14px;line-height:1.6}.message-text strong{font-weight:600}.message-time{color:var(--color-gray-500);font-size:11px;margin-top:4px;padding:0 4px}.message-code{margin:12px 0}.message-code:first-child{margin-top:0}.message-code:last-child{margin-bottom:0}.inline-code{background:#0000000f;border-radius:4px;font-family:Fira Code,Monaco,Consolas,monospace;font-size:13px;padding:2px 6px}.chat-message.user .inline-code{background:#fff3}.message-strategy{margin-top:12px}.streaming-cursor{animation:blink 1s step-end infinite;color:var(--color-primary);display:inline-block;font-weight:700;margin-left:2px}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.chat-message.streaming .message-bubble{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary-light)}@media (max-width:640px){.message-content-wrapper{max-width:85%}}.attached-strategy-card{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:1px solid #7dd3fc;border-radius:12px;margin-bottom:12px;padding:12px 16px}.attached-header{align-items:center;display:flex;gap:6px;margin-bottom:8px}.attached-icon{font-size:16px}.attached-label{color:#0284c7;flex:1 1;font-size:12px;font-weight:500}.attached-remove{align-items:center;background:#0000;border:none;border-radius:4px;color:#64748b;cursor:pointer;display:flex;font-size:16px;height:20px;justify-content:center;transition:all .2s;width:20px}.attached-remove:hover{background:#fee2e2;color:#dc2626}.attached-content{margin-bottom:10px}.attached-name{color:#0f172a;font-size:14px;font-weight:600;margin-bottom:4px}.attached-meta{color:#64748b;display:flex;flex-wrap:wrap;font-size:12px;gap:8px}.attached-lines{color:#0369a1}.attached-metrics{color:#059669}.attached-view-code{align-items:center;background:#fff;border:1px solid #7dd3fc;border-radius:6px;color:#0284c7;cursor:pointer;display:inline-flex;font-size:12px;font-weight:500;gap:4px;padding:6px 12px;transition:all .2s}.attached-view-code:hover{background:#0284c7;color:#fff}.attached-code-modal{display:flex;flex-direction:column;gap:16px}.attached-code-desc{background:#f8fafc;border-radius:8px;color:#475569;font-size:14px;padding:12px}.attached-code-block{border-radius:8px;max-height:400px;overflow:auto}.agent-page{background:var(--color-gray-50);display:flex;flex-direction:column;min-height:100vh}.agent-container{display:flex;flex:1 1;height:calc(100vh - 60px);overflow:hidden}.agent-sidebar{background:#fff;border-right:1px solid var(--color-gray-200);display:flex;flex-direction:column;transition:width .3s,margin .3s;width:280px}.agent-sidebar.collapsed{margin-left:-1px;overflow:hidden;width:0}.sidebar-header{align-items:center;border-bottom:1px solid var(--color-gray-100);display:flex;justify-content:space-between;padding:16px}.sidebar-header h3{color:var(--color-gray-900);font-size:15px;font-weight:600}.new-chat-btn{background:var(--color-primary);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px;transition:background .2s}.new-chat-btn:hover{background:var(--color-primary-dark)}.session-list{flex:1 1;overflow-y:auto;padding:8px}.empty-sessions{color:var(--color-gray-500);padding:40px 20px;text-align:center}.empty-sessions p{font-size:14px;margin-bottom:4px}.empty-sessions span{font-size:12px}.session-item{align-items:center;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;padding:12px;transition:background .2s}.session-item:hover{background:var(--color-gray-50)}.session-item.active{background:var(--color-primary);background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.session-info{flex:1 1;min-width:0}.session-title{color:var(--color-gray-900);display:block;font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-time{color:var(--color-gray-500);font-size:11px}.session-delete{background:#0000;border:none;border-radius:4px;color:var(--color-gray-500);cursor:pointer;font-size:18px;height:24px;opacity:0;transition:opacity .2s;width:24px}.session-item:hover .session-delete{opacity:1}.session-delete:hover{background:var(--color-gray-200);color:var(--color-danger)}.agent-main{display:flex;flex:1 1;flex-direction:column;min-width:0;position:relative}.toggle-sidebar-btn{background:var(--color-gray-200);border:none;border-radius:0 4px 4px 0;color:var(--color-gray-500);cursor:pointer;font-size:10px;height:60px;left:0;position:absolute;top:50%;transform:translateY(-50%);transition:background .2s;width:20px;z-index:10}.toggle-sidebar-btn:hover{background:var(--color-gray-300)}.chat-messages{flex:1 1;overflow-y:auto;padding:20px 40px}.welcome-message{align-items:center;animation:fadeIn .5s ease;display:flex;flex-direction:column;height:100%;justify-content:center;text-align:center}.welcome-icon{font-size:64px;margin-bottom:16px}.welcome-message h2{color:var(--color-gray-900);font-size:24px;font-weight:600;margin-bottom:8px}.welcome-message p{color:var(--color-gray-500);font-size:15px;margin-bottom:32px}.welcome-suggestions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.welcome-suggestions button{background:#fff;border:1px solid var(--color-gray-200);border-radius:20px;color:var(--color-gray-700);cursor:pointer;font-size:13px;padding:10px 16px;transition:all .2s}.welcome-suggestions button:hover{background:var(--color-gray-50);border-color:var(--color-primary);color:var(--color-primary)}.typing-indicator{display:flex;gap:4px;margin-left:48px;padding:16px 20px}.tool-call-stack{margin:8px 0 6px 48px;max-width:min(75%,900px)}.typing-indicator span{animation:typing 1.4s infinite;background:var(--color-gray-400);border-radius:50%;height:8px;width:8px}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-8px)}}.chat-input-area{background:var(--color-gray-50);border-top:1px solid var(--color-gray-200);padding:16px 40px 24px}.input-wrapper{background:#fff;border:1px solid var(--color-gray-200);border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;gap:12px;padding:8px 12px;transition:border-color .2s,box-shadow .2s}.input-wrapper:focus-within{border-color:var(--color-primary);box-shadow:0 2px 12px #10b98126}.input-wrapper textarea{border:none;flex:1 1;font-family:inherit;font-size:14px;line-height:1.5;max-height:120px;min-height:24px;outline:none;padding:4px 0;resize:none}.send-btn{background:var(--color-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;flex-shrink:0;font-size:18px;height:40px;transition:background .2s;width:40px}.send-btn:hover:not(:disabled){background:var(--color-primary-dark)}.send-btn:disabled{background:var(--color-gray-300);cursor:not-allowed}.send-btn.stop-btn{animation:pulse 1.5s infinite;background:#ef4444}.send-btn.stop-btn:hover{background:#dc2626}@keyframes pulse{0%,to{box-shadow:0 0 0 0 #ef444466}50%{box-shadow:0 0 0 8px #ef444400}}.input-hint{color:var(--color-gray-500);font-size:11px;margin-top:8px;text-align:center}.code-modal-content{min-width:500px}.code-modal-desc{color:var(--color-gray-700);font-size:14px;line-height:1.5;margin-bottom:16px}.code-modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:16px}.sidebar-overlay{display:none}@media (max-width:768px){.sidebar-overlay{animation:fadeIn .2s ease;background:#0006;display:block;inset:0;position:fixed;top:60px;z-index:99}.agent-sidebar{bottom:0;box-shadow:2px 0 10px #00000026;left:0;position:fixed;top:60px;transform:translateX(0);transition:transform .3s ease;z-index:100}.agent-sidebar.collapsed{margin-left:0;transform:translateX(-100%);width:280px}.toggle-sidebar-btn{background:var(--color-primary);border-radius:50%;box-shadow:0 2px 8px #0003;color:#fff;font-size:14px;height:36px;left:8px;position:fixed;top:70px;transform:none;width:36px;z-index:101}.toggle-sidebar-btn:hover{background:var(--color-primary-dark)}.agent-sidebar:not(.collapsed)~.agent-main .toggle-sidebar-btn{background:#fff;border:1px solid var(--color-gray-200);color:var(--color-gray-600);left:252px}.chat-messages{padding:16px 16px 16px 52px}.chat-input-area{padding:12px 16px 16px}.tool-call-stack{margin-left:48px;max-width:85%}.welcome-suggestions{flex-direction:column}.code-modal-content{min-width:auto}}@media (max-width:480px){.agent-sidebar,.agent-sidebar.collapsed{width:100%}.chat-messages{padding:12px 12px 12px 48px}.chat-input-area{padding:8px 12px 12px}.tool-call-stack{margin-left:44px;max-width:88%}.input-wrapper{padding:6px 10px}.send-btn{height:36px;width:36px}}.contact-page{background:var(--color-background);min-height:100vh}.contact-container{display:flex;justify-content:center;margin:0 auto;max-width:560px;padding:48px 16px}.contact-card{background:#fff;background:var(--color-card-background,#fff);border-radius:20px;box-shadow:0 4px 24px #00000014;padding:40px 36px;text-align:center;width:100%}.contact-avatar{font-size:56px;line-height:1;margin-bottom:16px}.contact-title{color:#111827;color:var(--color-text,#111827);font-size:26px;font-weight:700;margin:0 0 8px}.contact-subtitle{color:#6b7280;color:var(--color-text-secondary,#6b7280);font-size:14px;margin:0 0 24px}.contact-divider{background:#e5e7eb;background:var(--color-border,#e5e7eb);height:1px;margin:24px 0}.contact-item{align-items:center;background:#f9fafb;background:var(--color-gray-50,#f9fafb);border-radius:12px;display:flex;gap:16px;margin-bottom:12px;padding:14px 18px;text-align:left;transition:background .2s}.contact-item:last-of-type{margin-bottom:0}.contact-item:hover{background:#10b9810f}.contact-icon{flex-shrink:0;font-size:22px}.contact-info{display:flex;flex:1 1;flex-direction:column;gap:2px}.contact-label{color:#6b7280;color:var(--color-text-secondary,#6b7280);font-size:12px;font-weight:500;letter-spacing:.04em;text-transform:uppercase}.contact-value{color:#111827;color:var(--color-text,#111827);font-size:15px;font-weight:600;text-decoration:none}a.contact-value:hover{color:#10b981;color:var(--color-primary,#10b981);text-decoration:underline}.contact-highlight{color:#10b981!important;color:var(--color-primary,#10b981)!important}.contact-projects{text-align:left}.contact-projects-title{color:#111827;color:var(--color-text,#111827);font-size:15px;font-weight:600;margin:0 0 12px;text-align:center}.contact-project-link{align-items:center;background:linear-gradient(135deg,#10b98114,#10b9810a);border:1px solid #10b98133;border-radius:12px;display:flex;gap:14px;padding:14px 18px;text-decoration:none;transition:all .2s}.contact-project-link:hover{background:linear-gradient(135deg,#10b98126,#10b98114);border-color:#10b98166;box-shadow:0 4px 12px #10b98126;transform:translateY(-1px)}.project-icon{flex-shrink:0;font-size:28px}.project-info{display:flex;flex:1 1;flex-direction:column;gap:2px}.project-name{color:#111827;color:var(--color-text,#111827);font-size:15px;font-weight:600}.project-url{color:#6b7280;color:var(--color-text-secondary,#6b7280);font-size:12px}.project-arrow{color:#10b981;color:var(--color-primary,#10b981);flex-shrink:0;font-size:18px;font-weight:600}@media (max-width:480px){.contact-card{border-radius:16px;padding:28px 20px}.contact-container{padding:24px 12px}}
/*# sourceMappingURL=main.281286be.css.map*/