@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:400;src:url(/static/media/inter-cyrillic-ext-400-normal.39fbf8d2c4abc46f721f.woff2) format("woff2"),url(/static/media/inter-cyrillic-ext-400-normal.818b84180553acc613f3.woff) format("woff");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:400;src:url(/static/media/inter-cyrillic-400-normal.89455522650c3fb3654c.woff2) format("woff2"),url(/static/media/inter-cyrillic-400-normal.dd21c71421d58232ef03.woff) format("woff");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:400;src:url(/static/media/inter-greek-ext-400-normal.f2ef63e732b18d636044.woff2) format("woff2"),url(/static/media/inter-greek-ext-400-normal.fc80974ec6969ee03fd2.woff) format("woff");unicode-range:u+1f??}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:400;src:url(/static/media/inter-greek-400-normal.e685387f69602567b1da.woff2) format("woff2"),url(/static/media/inter-greek-400-normal.b412faded087fbcfa4ff.woff) format("woff");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:400;src:url(/static/media/inter-vietnamese-400-normal.44c9df135eec470b0ab6.woff2) format("woff2"),url(/static/media/inter-vietnamese-400-normal.aaa15d735e3826061950.woff) format("woff");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:400;src:url(/static/media/inter-latin-ext-400-normal.210fb826cb25acbd4094.woff2) format("woff2"),url(/static/media/inter-latin-ext-400-normal.c616205185f0d3677df9.woff) format("woff");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:400;src:url(/static/media/inter-latin-400-normal.eca1e21531598d5db58f.woff2) format("woff2"),url(/static/media/inter-latin-400-normal.2ea1079c0069eb040a52.woff) format("woff");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:500;src:url(/static/media/inter-cyrillic-ext-500-normal.b2740f247d3be4a05ca0.woff2) format("woff2"),url(/static/media/inter-cyrillic-ext-500-normal.e9974e820735012b025b.woff) format("woff");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:500;src:url(/static/media/inter-cyrillic-500-normal.33a76a7cbcfcb7076534.woff2) format("woff2"),url(/static/media/inter-cyrillic-500-normal.72f7a9db87626ca30c76.woff) format("woff");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:500;src:url(/static/media/inter-greek-ext-500-normal.4c6d520b97e3bb4ef613.woff2) format("woff2"),url(/static/media/inter-greek-ext-500-normal.47cc2391a7edf82cf4e1.woff) format("woff");unicode-range:u+1f??}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:500;src:url(/static/media/inter-greek-500-normal.e7cec4ef4f6780e90a52.woff2) format("woff2"),url(/static/media/inter-greek-500-normal.6d34bacda2be54829b97.woff) format("woff");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:500;src:url(/static/media/inter-vietnamese-500-normal.63d02ea896a7406849b6.woff2) format("woff2"),url(/static/media/inter-vietnamese-500-normal.296d66c0bba9086788b9.woff) format("woff");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:500;src:url(/static/media/inter-latin-ext-500-normal.cdb4dd5dc508fe6e7398.woff2) format("woff2"),url(/static/media/inter-latin-ext-500-normal.2f93aaa35e870cec4704.woff) format("woff");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:500;src:url(/static/media/inter-latin-500-normal.b7c27c60f848f2083f45.woff2) format("woff2"),url(/static/media/inter-latin-500-normal.5014db633e71a7741bf5.woff) format("woff");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:600;src:url(/static/media/inter-cyrillic-ext-600-normal.8c6413cdd8004fde0a19.woff2) format("woff2"),url(/static/media/inter-cyrillic-ext-600-normal.d6d44e8705a633436dfe.woff) format("woff");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:600;src:url(/static/media/inter-cyrillic-600-normal.fdee7b66c2d88216b75f.woff2) format("woff2"),url(/static/media/inter-cyrillic-600-normal.8609e1b95284125f21cb.woff) format("woff");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:600;src:url(/static/media/inter-greek-ext-600-normal.c3c138d889b8c929822c.woff2) format("woff2"),url(/static/media/inter-greek-ext-600-normal.c7983dac0ad6a359aef0.woff) format("woff");unicode-range:u+1f??}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:600;src:url(/static/media/inter-greek-600-normal.984050ecee12eabe9366.woff2) format("woff2"),url(/static/media/inter-greek-600-normal.d8b0044cf6afdd52b07b.woff) format("woff");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:600;src:url(/static/media/inter-vietnamese-600-normal.6984cf5e8583fac83be3.woff2) format("woff2"),url(/static/media/inter-vietnamese-600-normal.04bb56ffa463ab55708d.woff) format("woff");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:600;src:url(/static/media/inter-latin-ext-600-normal.8148c3ae14dfaefc62ca.woff2) format("woff2"),url(/static/media/inter-latin-ext-600-normal.4d0d5017d71ea1750fc1.woff) format("woff");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:600;src:url(/static/media/inter-latin-600-normal.69a8d1d484967aba2389.woff2) format("woff2"),url(/static/media/inter-latin-600-normal.f10265da6bd8d66999ac.woff) format("woff");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:700;src:url(/static/media/inter-cyrillic-ext-700-normal.b0c28c6752a13fa5abaf.woff2) format("woff2"),url(/static/media/inter-cyrillic-ext-700-normal.43f6f7e8a4205f05e58c.woff) format("woff");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:700;src:url(/static/media/inter-cyrillic-700-normal.533055ff3700190d8dfa.woff2) format("woff2"),url(/static/media/inter-cyrillic-700-normal.9f2de06ca9a7c8458434.woff) format("woff");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:700;src:url(/static/media/inter-greek-ext-700-normal.c9429f4b77b1f85e999d.woff2) format("woff2"),url(/static/media/inter-greek-ext-700-normal.0f8675bdd7f3fe3a3dba.woff) format("woff");unicode-range:u+1f??}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:700;src:url(/static/media/inter-greek-700-normal.3f04511ca7c0cea0cc2f.woff2) format("woff2"),url(/static/media/inter-greek-700-normal.8b95c1e2b193d0541864.woff) format("woff");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:700;src:url(/static/media/inter-vietnamese-700-normal.d1c85cabbe96efcaeb68.woff2) format("woff2"),url(/static/media/inter-vietnamese-700-normal.05b640f829d1ac5ff29d.woff) format("woff");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:700;src:url(/static/media/inter-latin-ext-700-normal.bc59219ed344909a4f53.woff2) format("woff2"),url(/static/media/inter-latin-ext-700-normal.d4a91814dd3f1e022ab1.woff) format("woff");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-display:swap;font-family:Inter;font-style:normal;font-weight:700;src:url(/static/media/inter-latin-700-normal.1104236696a5d2d1f236.woff2) format("woff2"),url(/static/media/inter-latin-700-normal.c73ae7252669254d2588.woff) format("woff");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:400;src:url(/static/media/jetbrains-mono-cyrillic-ext-400-normal.7347c7bfed47f1ef0b25.woff2) format("woff2"),url(/static/media/jetbrains-mono-cyrillic-ext-400-normal.831e0db23a3b56373d02.woff) format("woff");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:400;src:url(/static/media/jetbrains-mono-cyrillic-400-normal.f69e1e24f04a6ce942c0.woff2) format("woff2"),url(/static/media/jetbrains-mono-cyrillic-400-normal.d0dbe121eb8ccfff69fd.woff) format("woff");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:400;src:url(/static/media/jetbrains-mono-greek-400-normal.3a4578ae9901384175e2.woff2) format("woff2"),url(/static/media/jetbrains-mono-greek-400-normal.55220d4dce9386883dd6.woff) format("woff");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:400;src:url(/static/media/jetbrains-mono-vietnamese-400-normal.aa664ef15f2e285e9dda.woff2) format("woff2"),url(/static/media/jetbrains-mono-vietnamese-400-normal.411bbf704034dd802498.woff) format("woff");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:400;src:url(/static/media/jetbrains-mono-latin-ext-400-normal.e83b764e84e73968db26.woff2) format("woff2"),url(/static/media/jetbrains-mono-latin-ext-400-normal.dfdc51c009ca3dea7613.woff) format("woff");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:400;src:url(/static/media/jetbrains-mono-latin-400-normal.d04352f240062b100fba.woff2) format("woff2"),url(/static/media/jetbrains-mono-latin-400-normal.1fef352a4021940e309a.woff) format("woff");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:500;src:url(/static/media/jetbrains-mono-cyrillic-ext-500-normal.12b2790f450a0135a4cd.woff2) format("woff2"),url(/static/media/jetbrains-mono-cyrillic-ext-500-normal.7d1c47b77c64589c778c.woff) format("woff");unicode-range:u+0460-052f,u+1c80-1c8a,u+20b4,u+2de0-2dff,u+a640-a69f,u+fe2e-fe2f}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:500;src:url(/static/media/jetbrains-mono-cyrillic-500-normal.c859e1163e47db816b3f.woff2) format("woff2"),url(/static/media/jetbrains-mono-cyrillic-500-normal.508a23756dc3eb0a5f3f.woff) format("woff");unicode-range:u+0301,u+0400-045f,u+0490-0491,u+04b0-04b1,u+2116}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:500;src:url(/static/media/jetbrains-mono-greek-500-normal.4ab6aec659058b6da634.woff2) format("woff2"),url(/static/media/jetbrains-mono-greek-500-normal.00b2594f4631af11e7ec.woff) format("woff");unicode-range:u+0370-0377,u+037a-037f,u+0384-038a,u+038c,u+038e-03a1,u+03a3-03ff}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:500;src:url(/static/media/jetbrains-mono-vietnamese-500-normal.e8fe161b5afbc431d03f.woff2) format("woff2"),url(/static/media/jetbrains-mono-vietnamese-500-normal.61b340037f78bc2cdd7f.woff) format("woff");unicode-range:u+0102-0103,u+0110-0111,u+0128-0129,u+0168-0169,u+01a0-01a1,u+01af-01b0,u+0300-0301,u+0303-0304,u+0308-0309,u+0323,u+0329,u+1ea0-1ef9,u+20ab}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:500;src:url(/static/media/jetbrains-mono-latin-ext-500-normal.4a98f2079d9f35ae42c1.woff2) format("woff2"),url(/static/media/jetbrains-mono-latin-ext-500-normal.a9148377892cf3386f26.woff) format("woff");unicode-range:u+0100-02ba,u+02bd-02c5,u+02c7-02cc,u+02ce-02d7,u+02dd-02ff,u+0304,u+0308,u+0329,u+1d00-1dbf,u+1e00-1e9f,u+1ef2-1eff,u+2020,u+20a0-20ab,u+20ad-20c0,u+2113,u+2c60-2c7f,u+a720-a7ff}@font-face{font-display:swap;font-family:JetBrains Mono;font-style:normal;font-weight:500;src:url(/static/media/jetbrains-mono-latin-500-normal.bb50084be2b43ba7b98c.woff2) format("woff2"),url(/static/media/jetbrains-mono-latin-500-normal.b6ddca2679c2b4a27c68.woff) format("woff");unicode-range:u+00??,u+0131,u+0152-0153,u+02bb-02bc,u+02c6,u+02da,u+02dc,u+0304,u+0308,u+0329,u+2000-206f,u+20ac,u+2122,u+2191,u+2193,u+2212,u+2215,u+feff,u+fffd}:root{--bg-primary:#070b14;--bg-secondary:#0f1629;--bg-tertiary:#1a2342;--bg-elevated:#243056;--border-primary:#6366f126;--border-secondary:#6366f11a;--border-active:#6366f166;--text-primary:#e0e7ff;--text-secondary:#a5b4fc;--text-muted:#6366f1;--text-placeholder:#4338ca;--accent-blue:#6366f1;--accent-blue-hover:#818cf8;--accent-blue-bg:#6366f126;--color-success:#34d399;--color-success-bg:#34d39926;--color-error:#f87171;--color-error-bg:#f8717126;--color-warning:#fbbf24;--color-warning-bg:#fbbf2426;--btn-primary-bg:#6366f1;--btn-primary-hover:#818cf8;--btn-secondary-bg:#6366f11a;--btn-secondary-hover:#6366f133;--btn-danger-bg:#dc2626;--btn-danger-hover:#ef4444;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono","SF Mono","Consolas",monospace;--text-xs:11px;--text-sm:12px;--text-base:14px;--text-lg:16px;--text-xl:18px;--text-2xl:20px;--text-3xl:24px;--font-normal:400;--font-medium:500;--font-semibold:600;--font-bold:700;--leading-tight:1.25;--leading-normal:1.5;--leading-relaxed:1.75;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--shadow-xl:0 12px 40px #0009;--transition-fast:0.15s ease;--transition-normal:0.2s ease;--transition-slow:0.3s ease;--z-dropdown:100;--z-sticky:200;--z-modal:500;--z-tooltip:600;--z-toast:700;--navbar-height:56px;--sidebar-width:380px;--max-width:1400px;--gap-sm:8px;--gap-md:12px;--gap-lg:16px}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#0f1629;background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#243056;background:var(--bg-elevated);border-radius:4px;border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:#6366f1;background:var(--text-muted)}::selection{background:#6366f1;background:var(--accent-blue);color:#e0e7ff;color:var(--text-primary)}:focus-visible{outline:2px solid #6366f1;outline:2px solid var(--accent-blue);outline-offset:2px}.text-primary{color:#e0e7ff;color:var(--text-primary)}.text-secondary{color:#a5b4fc;color:var(--text-secondary)}.text-muted{color:#6366f1;color:var(--text-muted)}.text-success{color:#34d399;color:var(--color-success)}.text-error{color:#f87171;color:var(--color-error)}.text-warning{color:#fbbf24;color:var(--color-warning)}.text-accent{color:#6366f1;color:var(--accent-blue)}.bg-primary{background-color:#070b14;background-color:var(--bg-primary)}.bg-secondary{background-color:#0f1629;background-color:var(--bg-secondary)}.bg-tertiary{background-color:#1a2342;background-color:var(--bg-tertiary)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.font-normal{font-weight:400;font-weight:var(--font-normal)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}*,::backdrop,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }
/* ! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com */*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-variation-settings:normal;line-height:1.5;tab-size:4}body{line-height:inherit;margin:0}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:JetBrains Mono,SF Mono,Consolas,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.glass-card{--tw-shadow:0 4px 24px #0000004d;--tw-shadow-colored:0 4px 24px var(--tw-shadow-color);--tw-backdrop-blur:blur(12px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);background-color:#0f1629b3;border-color:#6366f126;border-radius:12px;border-width:1px;box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.btn-gradient{--tw-gradient-from:#6366f1 var(--tw-gradient-from-position);--tw-gradient-to:#6366f100 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to);--tw-gradient-to:#a855f7 var(--tw-gradient-to-position);--tw-text-opacity:1;background-image:linear-gradient(to right,var(--tw-gradient-stops));border-radius:8px;color:#fff;color:rgb(255 255 255/var(--tw-text-opacity,1));font-weight:500;padding:.625rem 1rem;transition-duration:.2s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.btn-gradient:hover{--tw-gradient-from:#818cf8 var(--tw-gradient-from-position);--tw-gradient-to:#818cf800 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to);--tw-gradient-to:#c084fc var(--tw-gradient-to-position);--tw-shadow:0 0 20px #6366f126;--tw-shadow-colored:0 0 20px var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.bottom-0{bottom:0}.left-0{left:0}.left-1\/2{left:50%}.right-0{right:0}.top-0{top:0}.top-1{top:.25rem}.top-full{top:100%}.z-dropdown{z-index:100}.z-sticky{z-index:200}.m-3{margin:.75rem}.mx-auto{margin-left:auto;margin-right:auto}.my-2{margin-bottom:.5rem;margin-top:.5rem}.my-3{margin-bottom:.75rem;margin-top:.75rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-2{margin-left:.5rem}.ml-auto{margin-left:auto}.mr-0{margin-right:0}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-1\.5{margin-top:.375rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-8{margin-top:2rem}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.table{display:table}.hidden{display:none}.h-0\.5{height:.125rem}.h-1{height:.25rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-6{height:1.5rem}.h-\[calc\(100vh-56px\)\]{height:calc(100vh - 56px)}.h-full{height:100%}.w-1{width:.25rem}.w-2{width:.5rem}.w-4\/5{width:80%}.w-6{width:1.5rem}.w-\[380px\]{width:380px}.w-full{width:100%}.min-w-\[180px\]{min-width:180px}.min-w-\[52px\]{min-width:52px}.max-w-3xl{max-width:48rem}.max-w-\[1400px\]{max-width:1400px}.flex-1{flex:1 1}.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x:-50%}.-translate-x-1\/2,.rotate-180{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.rotate-180{--tw-rotate:180deg}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-pointer{cursor:pointer}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.items-start{align-items:flex-start}.items-center{align-items:center}.items-baseline{align-items:baseline}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-2\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(1rem*var(--tw-space-y-reverse));margin-top:calc(1rem*(1 - var(--tw-space-y-reverse)))}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:8px}.rounded-md{border-radius:6px}.rounded-xl{border-radius:12px}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-red-500\/30{border-color:#ef44444d}.border-viz-border{border-color:#6366f126}.border-viz-border-hover{border-color:#6366f140}.border-viz-border\/50{border-color:#6366f180}.border-viz-error{--tw-border-opacity:1;border-color:#f87171;border-color:rgb(248 113 113/var(--tw-border-opacity,1))}.bg-red-500\/10{background-color:#ef44441a}.bg-viz-accent{--tw-bg-opacity:1;background-color:#6366f1;background-color:rgb(99 102 241/var(--tw-bg-opacity,1))}.bg-viz-accent\/10{background-color:#6366f11a}.bg-viz-bg-primary\/50{background-color:#070b1480}.bg-viz-bg-primary\/80{background-color:#070b14cc}.bg-viz-bg-primary\/85{background-color:#070b14d9}.bg-viz-bg-secondary{--tw-bg-opacity:1;background-color:#0f1629;background-color:rgb(15 22 41/var(--tw-bg-opacity,1))}.bg-viz-bg-tertiary{--tw-bg-opacity:1;background-color:#1a2342;background-color:rgb(26 35 66/var(--tw-bg-opacity,1))}.bg-viz-bg-tertiary\/50{background-color:#1a234280}.bg-viz-error{--tw-bg-opacity:1;background-color:#f87171;background-color:rgb(248 113 113/var(--tw-bg-opacity,1))}.bg-viz-error-bg{background-color:#f8717126}.bg-viz-success{--tw-bg-opacity:1;background-color:#34d399;background-color:rgb(52 211 153/var(--tw-bg-opacity,1))}.bg-viz-success-bg{background-color:#34d39926}.bg-viz-warning{--tw-bg-opacity:1;background-color:#fbbf24;background-color:rgb(251 191 36/var(--tw-bg-opacity,1))}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-indigo-400{--tw-gradient-from:#818cf8 var(--tw-gradient-from-position);--tw-gradient-to:#818cf800 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.from-indigo-500{--tw-gradient-from:#6366f1 var(--tw-gradient-from-position);--tw-gradient-to:#6366f100 var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.to-purple-400{--tw-gradient-to:#c084fc var(--tw-gradient-to-position)}.to-purple-500{--tw-gradient-to:#a855f7 var(--tw-gradient-to-position)}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.p-1\.5{padding:.375rem}.p-12{padding:3rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.\!px-4{padding-left:1rem!important;padding-right:1rem!important}.\!py-1\.5{padding-bottom:.375rem!important;padding-top:.375rem!important}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-0\.5{padding-bottom:.125rem;padding-top:.125rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-1\.5{padding-bottom:.375rem;padding-top:.375rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-2\.5{padding-bottom:.625rem;padding-top:.625rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.pb-24{padding-bottom:6rem}.pb-4{padding-bottom:1rem}.pt-20{padding-top:5rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pt-6{padding-top:1.5rem}.text-left{text-align:left}.text-center{text-align:center}.font-mono{font-family:JetBrains Mono,SF Mono,Consolas,monospace}.text-2xl{font-size:20px}.text-3xl{font-size:24px}.text-4xl{font-size:32px}.text-\[10px\]{font-size:10px}.text-base{font-size:14px}.text-lg{font-size:16px}.text-sm{font-size:12px}.text-xl{font-size:18px}.text-xs{font-size:11px}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.text-red-400{--tw-text-opacity:1;color:#f87171;color:rgb(248 113 113/var(--tw-text-opacity,1))}.text-transparent{color:#0000}.text-viz-accent{--tw-text-opacity:1;color:#6366f1;color:rgb(99 102 241/var(--tw-text-opacity,1))}.text-viz-error{--tw-text-opacity:1;color:#f87171;color:rgb(248 113 113/var(--tw-text-opacity,1))}.text-viz-success{--tw-text-opacity:1;color:#34d399;color:rgb(52 211 153/var(--tw-text-opacity,1))}.text-viz-text-primary{--tw-text-opacity:1;color:#e0e7ff;color:rgb(224 231 255/var(--tw-text-opacity,1))}.text-viz-text-secondary{--tw-text-opacity:1;color:#a5b4fc;color:rgb(165 180 252/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:#fff;color:rgb(255 255 255/var(--tw-text-opacity,1))}.accent-viz-accent{accent-color:#6366f1}.shadow-card{--tw-shadow:0 4px 24px #0000004d;--tw-shadow-colored:0 4px 24px var(--tw-shadow-color)}.shadow-card,.shadow-elevated{box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-elevated{--tw-shadow:0 8px 32px #0006;--tw-shadow-colored:0 8px 32px var(--tw-shadow-color)}.shadow-glow{--tw-shadow:0 0 20px #6366f126;--tw-shadow-colored:0 0 20px var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur-glass{--tw-backdrop-blur:blur(12px)}.backdrop-blur-glass,.backdrop-blur-nav{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-nav{--tw-backdrop-blur:blur(16px)}.transition{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-duration:.15s;transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-200{transition-duration:.2s}.pb-safe{padding-bottom:env(safe-area-inset-bottom,0)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-family);font-size:var(--text-base);line-height:var(--leading-normal)}#root{display:flex;flex-direction:column;min-height:100vh}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:var(--font-semibold);line-height:var(--leading-tight)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}h5{font-size:var(--text-base)}h6{font-size:var(--text-sm)}p{color:var(--text-secondary);line-height:var(--leading-relaxed)}a{color:var(--accent-blue);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-blue-hover)}code{background:var(--bg-tertiary);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:var(--text-sm);padding:2px 6px}button{align-items:center;border:none;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:inherit;font-size:var(--text-base);font-weight:var(--font-medium);gap:var(--space-2);justify-content:center;padding:var(--space-3) var(--space-4);transition:all var(--transition-fast)}button:disabled{cursor:not-allowed;opacity:.5}.btn-primary,button.primary{background:var(--btn-primary-bg);color:var(--text-primary)}.btn-primary:hover:not(:disabled),button.primary:hover:not(:disabled){background:var(--btn-primary-hover)}.btn-secondary,button.secondary{background:var(--btn-secondary-bg);border:1px solid var(--border-primary);color:var(--text-primary)}.btn-secondary:hover:not(:disabled),button.secondary:hover:not(:disabled){background:var(--btn-secondary-hover);border-color:var(--text-muted)}.btn-danger,button.danger{background:var(--btn-danger-bg);color:var(--text-primary)}.btn-danger:hover:not(:disabled),button.danger:hover:not(:disabled){background:var(--btn-danger-hover)}.btn-ghost,button.ghost{background:#0000;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled),button.ghost:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}input,select,textarea{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);font-family:inherit;font-size:var(--text-base);padding:var(--space-3) var(--space-3);transition:border-color var(--transition-fast),background-color var(--transition-fast);width:100%}input::placeholder,textarea::placeholder{color:var(--text-placeholder)}input:focus,select:focus,textarea:focus{background:var(--bg-tertiary);border-color:var(--accent-blue);outline:none}input:disabled,select:disabled,textarea:disabled{cursor:not-allowed;opacity:.5}select{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%236e7681' viewBox='0 0 24 24'%3E%3Cpath d='m7 10 5 5 5-5z'/%3E%3C/svg%3E");background-position:right var(--space-3) center;background-repeat:no-repeat;background-size:20px;cursor:pointer;padding-right:var(--space-10)}.card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--space-4)}.badge{align-items:center;background:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--text-secondary);display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-medium);gap:var(--space-1);padding:var(--space-1) var(--space-2)}.badge.success{background:var(--color-success-bg);color:var(--color-success)}.badge.error{background:var(--color-error-bg);color:var(--color-error)}.badge.warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge.info{background:var(--accent-blue-bg);color:var(--accent-blue)}.status-dot{background:currentColor;border-radius:var(--radius-full);height:6px;width:6px}.spinner{border:2px solid var(--border-primary);border-radius:var(--radius-full)}.message{border-radius:var(--radius-md);font-size:var(--text-sm);padding:var(--space-3) var(--space-4)}.message.error{background:var(--color-error-bg);border:1px solid var(--color-error);color:var(--color-error)}.message.success{background:var(--color-success-bg);border:1px solid var(--color-success);color:var(--color-success)}.container{margin:0 auto;max-width:var(--max-width);padding:0 var(--space-5)}[dir=rtl]{direction:rtl}@media (max-width:768px){html{font-size:14px}.container{padding:0 var(--space-3)}button{min-height:44px;padding:var(--space-3) var(--space-4)}input,select,textarea{font-size:16px;min-height:44px}}.hover\:border-viz-border-active:hover{border-color:#6366f166}.hover\:border-viz-border-hover:hover{border-color:#6366f140}.hover\:border-viz-error:hover{--tw-border-opacity:1;border-color:#f87171;border-color:rgb(248 113 113/var(--tw-border-opacity,1))}.hover\:bg-viz-accent-hover:hover{--tw-bg-opacity:1;background-color:#818cf8;background-color:rgb(129 140 248/var(--tw-bg-opacity,1))}.hover\:bg-viz-accent\/20:hover{background-color:#6366f133}.hover\:bg-viz-bg-tertiary:hover{--tw-bg-opacity:1;background-color:#1a2342;background-color:rgb(26 35 66/var(--tw-bg-opacity,1))}.hover\:bg-viz-bg-tertiary\/30:hover{background-color:#1a23424d}.hover\:bg-viz-bg-tertiary\/50:hover{background-color:#1a234280}.hover\:bg-viz-bg-tertiary\/80:hover{background-color:#1a2342cc}.hover\:bg-viz-error-bg:hover{background-color:#f8717126}.hover\:bg-viz-error\/20:hover{background-color:#f8717133}.hover\:bg-viz-error\/80:hover{background-color:#f87171cc}.hover\:bg-viz-success\/80:hover{background-color:#34d399cc}.hover\:bg-viz-warning\/80:hover{background-color:#fbbf24cc}.hover\:text-viz-accent-hover:hover{--tw-text-opacity:1;color:#818cf8;color:rgb(129 140 248/var(--tw-text-opacity,1))}.hover\:text-viz-text-primary:hover{--tw-text-opacity:1;color:#e0e7ff;color:rgb(224 231 255/var(--tw-text-opacity,1))}.hover\:underline:hover{text-decoration-line:underline}.hover\:shadow-glow-lg:hover{--tw-shadow:0 0 40px #6366f133;--tw-shadow-colored:0 0 40px var(--tw-shadow-color);box-shadow:0 0 #0000,0 0 #0000,var(--tw-shadow);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.focus\:border-viz-accent:focus{--tw-border-opacity:1;border-color:#6366f1;border-color:rgb(99 102 241/var(--tw-border-opacity,1))}.focus\:border-viz-border-active:focus{border-color:#6366f166}.focus\:outline-none:focus{outline:2px solid #0000;outline-offset:2px}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}@media (min-width:640px){.sm\:inline{display:inline}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width:768px){.md\:flex{display:flex}.md\:hidden{display:none}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width:1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.App{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1 1;overflow:auto;padding-top:var(--navbar-height)}.page-container{margin:0 auto;max-width:var(--max-width);padding:var(--space-5)}.page-header{margin-bottom:var(--space-8)}.page-header h1{font-size:var(--text-3xl);font-weight:var(--font-semibold);margin-bottom:var(--space-2)}.page-header p{color:var(--text-secondary);font-size:var(--text-base)}.grid{grid-gap:var(--space-5);display:grid;gap:var(--space-5)}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.grid-4{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}@media (max-width:768px){.main-content{padding-bottom:72px;padding-top:var(--navbar-height)}.page-container{padding:var(--space-3)}.page-header{margin-bottom:var(--space-5)}.page-header h1{font-size:var(--text-2xl)}.page-header button,.page-header p{font-size:var(--text-sm)}.page-header button{padding:var(--space-2) var(--space-4)}.grid{gap:var(--space-3)}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.create-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.input-section,.output-section,.placeholder-section{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background-color:var(--bg-secondary)}.input-section h2,.output-section h2{font-size:18px;margin-bottom:20px}.model-selector{align-items:center;display:flex;gap:12px;margin-bottom:16px}.model-selector label{color:var(--text-secondary);font-size:14px}.model-selector select{flex:1 1;max-width:300px}.strategy-input{background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:14px;min-height:200px;padding:16px;resize:vertical;width:100%}.strategy-input:focus{border-color:var(--border-active);outline:none}.input-actions{display:flex;gap:12px;margin-top:16px}.voice-button{background-color:var(--bg-tertiary);border:none;border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s}.voice-button:hover{background-color:var(--accent-blue-bg)}.voice-button.recording{animation:pulse 1.5s infinite;background-color:var(--color-error)}.generate-button{flex:1 1;padding:12px 24px}.loading-indicator{align-items:center;background-color:var(--accent-blue-bg);border:1px solid var(--accent-blue);border-radius:6px;display:flex;gap:12px;margin-top:20px;padding:16px}.spinner{animation:spin .8s linear infinite;border:3px solid var(--border-primary);border-top-color:var(--accent-blue);height:20px;width:20px}.strategy-preview{display:flex;flex-direction:column;gap:20px}.strategy-preview h3{font-size:20px;margin-bottom:8px}.strategy-preview>p{color:var(--text-secondary);margin-bottom:12px}.strategy-code{background-color:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;padding:16px}.strategy-code h4{color:var(--text-secondary);font-size:14px;margin-bottom:12px}.strategy-code pre{color:var(--text-primary);font-family:Courier New,monospace;font-size:13px;line-height:1.6;overflow-x:auto}.strategy-actions{display:flex;gap:12px;margin-top:20px}.strategy-actions button{flex:1 1;padding:12px}.placeholder-section{align-items:center;display:flex;justify-content:center;min-height:500px}.placeholder-content{max-width:500px;text-align:left}.placeholder-content h3{font-size:18px;margin-bottom:12px;margin-top:24px}.placeholder-content h3:first-child{margin-top:0}.placeholder-content ul{list-style:none;margin-bottom:16px;padding:0}.placeholder-content li{color:var(--text-secondary);font-size:14px;padding:8px 0}.placeholder-content li:before{color:var(--accent-blue);content:"•";display:inline-block;font-weight:700;margin-right:8px;width:1em}.example-prompts{display:flex;flex-direction:column;gap:8px}.example-prompts button{background-color:var(--bg-tertiary);border:none;border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:13px;padding:12px 16px;text-align:left;transition:all .2s}.example-prompts button:hover{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:var(--text-primary)}@media (max-width:1024px){.create-grid{grid-template-columns:1fr}}@media (max-width:768px){.input-section,.output-section,.placeholder-section{padding:16px}.input-section h2,.output-section h2{font-size:16px;margin-bottom:16px}.model-selector{align-items:flex-start;flex-direction:column}.model-selector select{max-width:100%;width:100%}.strategy-input{font-size:16px;min-height:150px}.input-actions{flex-direction:column;gap:10px}.generate-button,.voice-button{padding:14px 20px;width:100%}.strategy-preview h3{font-size:18px}.strategy-code{padding:12px}.strategy-code pre{font-size:12px;overflow-x:auto}.strategy-actions{flex-direction:column}.strategy-actions button{width:100%}.placeholder-content h3{font-size:16px}.example-prompts button{font-size:14px;padding:14px 16px}}.backtest-chart-container{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;display:flex;flex-direction:column;gap:16px;padding:20px}.chart-wrapper{border-radius:8px;min-height:500px;overflow:hidden;width:100%}.playback-controls{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:8px;display:flex;flex-direction:column;gap:16px;padding:16px}.control-buttons{gap:8px}.control-btn,.control-buttons{align-items:center;display:flex}.control-btn{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);cursor:pointer;font-size:20px;height:48px;justify-content:center;transition:all .2s;width:48px}.control-btn:hover{background:var(--bg-tertiary);border-color:var(--border-active);transform:scale(1.05)}.control-btn.primary,.control-btn.primary:hover{background:var(--accent-blue);border-color:var(--accent-blue)}.control-btn.primary:hover{opacity:.9}.timeline{display:flex;flex:1 1;flex-direction:column;gap:8px}.timeline-slider{appearance:none;background:var(--bg-secondary);border-radius:3px;cursor:pointer;height:6px;outline:none;width:100%}.timeline-slider::-webkit-slider-thumb{appearance:none;background:var(--accent-blue);border-radius:50%;cursor:pointer;height:16px;-webkit-transition:all .2s;transition:all .2s;width:16px}.timeline-slider::-webkit-slider-thumb:hover{background:var(--accent-blue);opacity:.9;transform:scale(1.2)}.timeline-slider::-moz-range-thumb{background:var(--accent-blue);border:none;border-radius:50%;cursor:pointer;height:16px;-moz-transition:all .2s;transition:all .2s;width:16px}.timeline-slider::-moz-range-thumb:hover{background:var(--accent-blue);opacity:.9;transform:scale(1.2)}.timeline-info{align-items:center;display:flex;justify-content:space-between}.timeline-text{color:var(--text-secondary);font-size:13px}.speed-controls{align-items:center;display:flex;gap:8px}.speed-label{color:var(--text-secondary);font-size:14px;margin-right:8px}.speed-btn{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .2s}.speed-btn:hover{background:var(--bg-tertiary);border-color:var(--border-active)}.speed-btn.active{background:var(--accent-blue);border-color:var(--accent-blue);color:var(--text-primary)}@media (max-width:768px){.playback-controls{padding:12px}.control-btn{font-size:18px;height:40px;width:40px}.speed-controls{flex-wrap:wrap}.speed-btn{font-size:12px;padding:6px 12px}}.trades-table-container{display:flex;flex-direction:column;gap:20px}.trades-stats{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-card{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;display:flex;flex-direction:column;gap:8px;padding:16px;transition:all .2s}.stat-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f61a;transform:translateY(-2px)}.stat-label{color:#9ca3af;font-size:12px;letter-spacing:.5px;text-transform:uppercase}.stat-value{color:#e5e7eb;font-size:24px;font-weight:700}.stat-value.positive{color:#22c55e}.stat-value.negative{color:#ef4444}.trades-table-wrapper{background:#1a1a1a;border:1px solid #2a2a2a;border-radius:8px;overflow-x:auto;width:100%}.trades-table{border-collapse:collapse;font-size:14px;width:100%}.trades-table thead{background:#0f0f0f;position:sticky;top:0;z-index:1}.trades-table th{border-bottom:2px solid #2a2a2a;color:#e5e7eb;font-weight:600;padding:16px 12px;text-align:left;white-space:nowrap}.trades-table tbody tr{border-bottom:1px solid #2a2a2a;transition:all .2s}.trades-table tbody tr:hover{background:#2a2a2a}.trades-table tbody tr:last-child{border-bottom:none}.trades-table td{color:#e5e7eb;padding:14px 12px}.trade-time{color:#9ca3af;font-size:13px;white-space:nowrap}.trade-type{align-items:center;border-radius:4px;display:inline-flex;font-size:12px;font-weight:600;gap:4px;padding:4px 8px;white-space:nowrap}.trade-type.buy{background:#22c55e1a;color:#22c55e}.trade-type.sell{background:#ef44441a;color:#ef4444}.trade-price{font-family:Courier New,monospace;font-weight:600}.trade-quantity{text-align:center}.trade-cumulative,.trade-pnl{font-family:Courier New,monospace;font-weight:700;text-align:right}.trade-cumulative.positive,.trade-pnl.positive{color:#22c55e}.trade-cumulative.negative,.trade-pnl.negative{color:#ef4444}.trade-commission{color:#ef4444;font-family:Courier New,monospace;text-align:right}.trade-reason{font-size:13px}.empty-message,.trade-reason{color:#9ca3af;font-style:italic}.empty-message{padding:40px!important;text-align:center}@media (max-width:1024px){.trades-stats{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.stat-value{font-size:20px}.trades-table{font-size:13px}.trades-table td,.trades-table th{padding:12px 8px}}@media (max-width:768px){.trades-stats{grid-template-columns:1fr 1fr}.trades-table{font-size:12px}.trades-table td,.trades-table th{padding:10px 6px}.trade-type{font-size:11px;padding:3px 6px}}.data-availability{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;box-shadow:0 4px 6px #0000004d;margin-bottom:24px;padding:20px}.data-availability h3{color:var(--text-primary);font-size:18px;margin:0 0 16px}.availability-info{display:flex;flex-direction:column;gap:16px}.availability-status{align-items:center;border-radius:8px;display:flex;font-weight:500;gap:8px;padding:12px 16px}.availability-status.success{background:#34d3991a;border:1px solid var(--color-success);color:var(--color-success)}.availability-status.warning{background:#fbbf241a;border:1px solid #fbbf24;color:#fbbf24}.status-icon{font-size:20px}.intervals-list{display:flex;flex-direction:column;gap:8px}.interval-item{align-items:center;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;display:flex;gap:12px;padding:12px}.interval-badge{background:var(--accent-blue);border-radius:4px;color:#fff;font-size:12px;font-weight:600;min-width:40px;padding:4px 8px;text-align:center}.interval-range{color:var(--text-primary);flex:1 1;font-size:14px}.interval-count{color:var(--text-secondary);font-size:13px}.btn-download,.btn-refresh{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s}.btn-download.primary{background:var(--accent-blue);color:#fff}.btn-download.primary:hover{background:var(--accent-blue);box-shadow:0 4px 12px var(--accent-blue-bg);filter:brightness(1.1);transform:translateY(-1px)}.btn-refresh{background:#0000;border:1px solid var(--border-primary);color:var(--text-primary)}.btn-refresh:hover{background:var(--bg-tertiary);border-color:var(--accent-blue)}.download-progress{display:flex;flex-direction:column;gap:8px}.progress-bar{background:var(--bg-tertiary);border-radius:4px;height:8px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,var(--accent-blue),var(--text-muted));height:100%;transition:width .3s ease}.progress-text{color:var(--text-secondary);font-size:14px;text-align:center}.error-message{border-radius:6px}.info-text{color:var(--text-secondary);font-size:13px;font-style:italic;margin:0}@media (max-width:768px){.interval-item{align-items:flex-start;flex-direction:column;gap:8px}.interval-badge{align-self:flex-start}}.backtest-container{display:flex;flex-direction:column;gap:24px}.grid-bot-params{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;margin-top:12px;padding:20px}.grid-bot-params h3{color:var(--text-primary);font-size:16px;margin:0 0 16px}.grid-bot-params-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.grid-bot-params small{color:var(--text-secondary);display:block;font-size:12px;margin-top:4px}.backtest-error{background:#f871711a;border:1px solid var(--color-error);border-radius:6px;color:var(--color-error);font-size:14px;padding:12px}.backtest-results{gap:16px}.backtest-results,.result-item{display:flex;flex-direction:column}.result-item{gap:4px}.result-label{color:var(--text-secondary);font-size:13px}.result-value{color:var(--text-primary);font-size:24px;font-weight:700}.result-value.positive{color:var(--color-success)}.result-value.negative{color:var(--color-error)}.backtest-container .card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.live-bot-chart{background:var(--bg-primary);border-radius:var(--radius-lg);display:flex;flex-direction:column;height:100%;overflow:hidden;position:relative;width:100%}.chart-controls{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);justify-content:space-between;padding:var(--space-2) var(--space-3)}.chart-controls,.chart-controls-left{align-items:center;display:flex;gap:var(--space-3)}.chart-controls-left{min-width:0}.chart-symbol-info{align-items:center;display:flex;gap:var(--space-2)}.chart-symbol-name{color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-semibold);white-space:nowrap}.trading-status-badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:11px;font-weight:var(--font-medium);gap:6px;padding:4px 10px;white-space:nowrap}.trading-status-dot{border-radius:50%;flex-shrink:0;height:6px;width:6px}.trading-status-badge[data-status=trading] .trading-status-dot{animation:pulse 2s ease-in-out infinite}.timeframe-selector{display:flex;gap:var(--space-1)}.tf-btn{background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);padding:var(--space-1) var(--space-3);transition:all var(--transition-fast)}.tf-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.tf-btn.active{background:var(--accent-blue);color:var(--text-primary)}.chart-type-selector{display:flex;gap:var(--space-1)}.type-btn{align-items:center;background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:flex;height:28px;justify-content:center;padding:0;transition:all var(--transition-fast);width:32px}.type-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.type-btn.active{background:var(--bg-tertiary);color:var(--accent-blue)}.type-btn svg{height:16px;width:16px}.live-bot-chart-wrapper{flex:1 1;min-height:0;width:100%}.live-bot-chart-empty,.live-bot-chart-loading{align-items:center;background:var(--bg-secondary);border-radius:var(--radius-lg);color:var(--text-secondary);display:flex;flex-direction:column;font-size:var(--text-base);gap:var(--space-3);left:50%;padding:var(--space-6) var(--space-8);position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%);z-index:20}.live-bot-chart-empty{pointer-events:auto}.loading-spinner{animation:spin .8s linear infinite;border:2px solid var(--border-primary);border-radius:var(--radius-full);border-top-color:var(--accent-blue);height:24px;width:24px}.live-bot-chart-loading-more{align-items:center;background:var(--bg-elevated);border-radius:var(--radius-sm);color:var(--text-secondary);display:flex;font-size:var(--text-sm);gap:var(--space-2);left:var(--space-3);padding:var(--space-2) var(--space-3);pointer-events:none;position:absolute;top:50px;z-index:10}.loading-spinner.small{border-width:2px;height:14px;width:14px}.download-data-btn{background:var(--btn-primary-bg);border:none;border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:var(--text-sm);margin-top:var(--space-3);padding:var(--space-2) var(--space-4);transition:background var(--transition-fast)}.download-data-btn:hover{background:var(--btn-primary-hover)}.config-panel{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);flex-direction:column;grid-area:config;height:100%;min-height:0}.config-panel,.config-panel-title{display:flex;justify-content:space-between}.config-panel-title{align-items:center;border-bottom:1px solid var(--border-primary);color:var(--text-primary);flex-shrink:0;font-size:var(--text-lg);font-weight:var(--font-semibold);padding:var(--space-4) var(--space-5)}.info-icon{color:var(--text-muted);cursor:help;font-size:var(--text-base)}.info-icon.small{font-size:var(--text-sm)}.config-panel-body{flex:1 1;min-height:0;overflow-y:auto;padding:var(--space-4) var(--space-5) var(--space-6)}.config-field{margin-bottom:var(--space-4)}.config-field label{color:var(--text-muted);display:block;font-size:var(--text-sm);margin-bottom:var(--space-2)}.config-field input,.config-field select{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-base);padding:var(--space-3) var(--space-4);transition:border-color var(--transition-fast);width:100%}.config-field input:focus,.config-field select:focus{border-color:var(--accent-blue);outline:none}.config-hint{color:var(--text-muted);display:block;font-size:var(--text-xs);margin-top:var(--space-2)}.sandbox-fund-row{align-items:center;display:flex;gap:var(--space-3);margin-top:var(--space-3)}.sandbox-fund-btn{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-size:var(--text-xs);padding:var(--space-2) var(--space-3);transition:all var(--transition-fast)}.sandbox-fund-btn:hover:not(:disabled){background:var(--bg-elevated);border-color:var(--accent-blue);color:var(--text-primary)}.sandbox-fund-btn:disabled{cursor:not-allowed;opacity:.5}.funding-message{color:var(--color-success);font-size:var(--text-xs)}.config-field select{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%236e7681' viewBox='0 0 24 24'%3E%3Cpath d='m7 10 5 5 5-5z'/%3E%3C/svg%3E");background-position:right var(--space-3) center;background-repeat:no-repeat;background-size:20px;cursor:pointer;padding-right:var(--space-10)}.asset-selector{position:relative}.asset-selector-trigger{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);color:var(--text-primary);cursor:pointer;display:flex;font-size:var(--text-base);justify-content:space-between;padding:var(--space-3) var(--space-4);transition:border-color var(--transition-fast);width:100%}.asset-selector-trigger.open,.asset-selector-trigger:hover{border-color:var(--accent-blue)}.asset-selector-label{color:var(--text-muted);font-size:var(--text-xs);margin-bottom:2px}.asset-selector-value{font-weight:var(--font-medium)}.asset-selector-arrow{color:var(--text-muted);font-size:var(--text-xs);transition:transform var(--transition-fast)}.asset-selector-arrow.open{transform:rotate(180deg)}.asset-dropdown{background:var(--bg-secondary);border:1px solid var(--accent-blue);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);left:0;overflow:hidden;position:absolute;right:0;top:calc(100% + var(--space-2));z-index:var(--z-dropdown)}.asset-search{align-items:center;border-bottom:1px solid var(--border-primary);display:flex;gap:var(--space-2);padding:var(--space-3) var(--space-4)}.asset-search-icon{color:var(--text-muted);font-size:var(--text-sm)}.asset-search input{background:#0000;border:none;color:var(--text-primary);flex:1 1;font-size:var(--text-sm);outline:none}.asset-search input::placeholder,.asset-table-header{color:var(--text-muted)}.asset-table-header{grid-gap:var(--space-2);background:var(--bg-tertiary);border-bottom:1px solid var(--border-primary);display:grid;font-size:var(--text-xs);gap:var(--space-2);grid-template-columns:1fr 100px 90px;padding:var(--space-2) var(--space-4)}.asset-table-header span{align-items:center;cursor:pointer;display:flex;gap:4px}.asset-table-header span:hover{color:var(--text-secondary)}.asset-list{max-height:320px;overflow-y:auto}.asset-row{grid-gap:var(--space-2);border-left:3px solid #0000;cursor:pointer;display:grid;gap:var(--space-2);grid-template-columns:1fr 100px 90px;padding:var(--space-3) var(--space-4);transition:background var(--transition-fast)}.asset-row.selected,.asset-row:hover{background:var(--bg-tertiary)}.asset-row.selected{border-left-color:var(--accent-blue)}.asset-info{display:flex;flex-direction:column;gap:2px;min-width:0}.asset-ticker{color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-semibold)}.asset-name{color:var(--text-muted);font-size:var(--text-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.asset-price{align-items:flex-end;display:flex;flex-direction:column;font-size:var(--text-sm);gap:2px}.asset-price-value{color:var(--text-primary);font-weight:var(--font-medium)}.asset-price-usd{color:var(--text-muted);font-size:var(--text-xs)}.asset-change{align-items:center;display:flex;font-size:var(--text-sm);font-weight:var(--font-medium);justify-content:flex-end}.asset-change.positive{color:var(--color-success)}.asset-change.negative{color:var(--color-error)}.asset-type{background:var(--bg-elevated);border-radius:var(--radius-sm);color:var(--text-muted);font-size:9px;margin-left:var(--space-2);padding:2px 6px;text-transform:uppercase}.config-slider{align-items:center;display:flex;gap:var(--space-4);margin-bottom:var(--space-5)}.slider-track{background:var(--bg-elevated);border-radius:var(--radius-sm);flex:1 1;height:6px;position:relative}.slider-track input[type=range]{cursor:pointer;height:100%;opacity:0;position:absolute;width:100%;z-index:2}.slider-fill{background:linear-gradient(90deg,var(--accent-blue),var(--accent-blue-hover));border-radius:var(--radius-sm);height:100%;left:0;pointer-events:none;position:absolute;top:0}.slider-value{color:var(--text-primary);font-size:var(--text-lg);font-weight:var(--font-medium);min-width:50px;text-align:right}.config-section{background:var(--bg-tertiary);border-radius:var(--radius-xl);margin-bottom:var(--space-4);padding:var(--space-4)}.config-section-title{color:var(--text-muted);font-size:var(--text-sm);margin-bottom:var(--space-4)}.config-row{display:flex;gap:var(--space-3)}.config-field.half{flex:1 1;margin-bottom:var(--space-3)}.config-field.half:last-child{margin-bottom:0}.config-toggle{border-top:1px solid var(--border-secondary);justify-content:space-between;margin-bottom:var(--space-4);padding:var(--space-3) 0}.config-toggle,.toggle-info{align-items:center;display:flex}.toggle-info{color:var(--text-primary);font-size:var(--text-base);gap:var(--space-2)}.toggle-switch{cursor:pointer;height:24px;position:relative;width:44px}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background:var(--bg-elevated);inset:0;transition:background var(--transition-fast)}.toggle-slider,.toggle-slider:before{border-radius:var(--radius-full);position:absolute}.toggle-slider:before{background:var(--text-primary);content:"";height:18px;left:3px;top:3px;transition:transform var(--transition-fast);width:18px}.toggle-switch input:checked+.toggle-slider{background:var(--accent-blue)}.toggle-switch input:checked+.toggle-slider:before{transform:translateX(20px)}.config-error{background:var(--color-error-bg);border:1px solid var(--color-error);border-radius:var(--radius-md);color:var(--color-error);font-size:var(--text-sm);margin-top:var(--space-3);padding:var(--space-3) var(--space-4)}.config-panel-footer{border-top:1px solid var(--border-primary);flex-shrink:0;padding:var(--space-4) var(--space-5)}.config-action-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:var(--radius-lg);color:var(--text-primary);cursor:pointer;font-size:var(--text-base);font-weight:var(--font-semibold);padding:var(--space-4);transition:all var(--transition-fast);width:100%}.config-action-btn:hover:not(:disabled){background:linear-gradient(135deg,#818cf8,#a78bfa);box-shadow:0 0 20px #6366f14d;transform:translateY(-1px)}.config-action-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}@media (max-width:900px){.config-panel-body,.config-panel-footer{padding:var(--space-3) var(--space-4)}.config-row{flex-direction:column;gap:0}.config-field.half{margin-bottom:var(--space-3)}}.bot-list{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-xl);display:flex;flex-direction:column;grid-area:bots;height:100%;min-height:0;overflow:hidden}.bot-list-tabs{align-items:center;border-bottom:1px solid var(--border-primary);display:flex;flex-shrink:0;justify-content:space-between;padding:var(--space-3) var(--space-4)}.bot-list-tabs-left{align-items:center;display:flex;gap:var(--space-1)}.bot-list-tab{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;font-size:var(--text-sm);font-weight:var(--font-medium);gap:var(--space-2);padding:var(--space-2) var(--space-4);transition:all var(--transition-fast);white-space:nowrap}.bot-list-tab.active,.bot-list-tab:hover{background:var(--bg-tertiary);color:var(--text-primary)}.tab-count{background:var(--accent-blue);border-radius:var(--radius-full);color:var(--text-primary);font-size:var(--text-xs);font-weight:var(--font-semibold);padding:2px var(--space-2)}.bot-list-empty{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:var(--space-3);justify-content:center;padding:var(--space-10)}.bot-list-empty-icon{color:var(--bg-elevated)}.bot-list-empty-text{color:var(--text-secondary);font-size:var(--text-base);margin:0}.bot-list-empty-hint{color:var(--text-muted);font-size:var(--text-sm);margin:0}.bot-list-content{display:flex;flex:1 1;flex-direction:column;gap:var(--space-2);overflow-y:auto;padding:var(--space-3)}.bot-list .bot-card{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);overflow:hidden;padding:0;transition:border-color var(--transition-fast)}.bot-list .bot-card:hover{border-color:var(--text-muted)}.bot-list .bot-card.selected{background:var(--accent-blue-bg);border-color:var(--accent-blue)}.bot-list .bot-card-header{align-items:center;cursor:pointer;display:flex;gap:var(--space-3);padding:var(--space-4)}.bot-list .bot-expand-icon{color:var(--text-muted);flex-shrink:0;font-size:var(--text-xs);transition:transform var(--transition-fast)}.bot-list .bot-expand-icon.expanded{transform:rotate(90deg)}.bot-list .bot-info{display:flex;flex-direction:column;gap:2px;min-width:100px}.bot-list .bot-symbol{color:var(--text-primary);font-size:var(--text-base);font-weight:var(--font-semibold)}.bot-list .bot-strategy{color:var(--text-muted);font-size:var(--text-sm)}.bot-list .bot-status-badge{align-items:center;border-radius:var(--radius-sm);display:flex;flex-shrink:0;font-size:var(--text-sm);font-weight:var(--font-medium);gap:var(--space-2);padding:var(--space-1) var(--space-3)}.bot-list .bot-status-badge.running{background:var(--color-success-bg);box-shadow:0 0 8px #34d3994d;color:var(--color-success)}.bot-list .bot-status-badge.paused{background:var(--color-warning-bg);color:var(--color-warning)}.bot-list .bot-status-badge.stopped{background:var(--bg-elevated);color:var(--text-muted)}.bot-list .status-dot{background:currentColor;border-radius:var(--radius-full);height:6px;width:6px}.bot-list .bot-stats{display:flex;flex-shrink:0;gap:var(--space-6);margin-left:auto}.bot-list .bot-stat{align-items:flex-end;display:flex;flex-direction:column;gap:2px}.bot-list .bot-stat .stat-value{color:var(--text-primary);font-size:var(--text-base);font-weight:var(--font-semibold)}.bot-list .bot-stat .stat-label{color:var(--text-muted);font-size:var(--text-xs)}.bot-list .bot-stat.pnl.positive .stat-value{color:var(--color-success)}.bot-list .bot-stat.pnl.negative .stat-value{color:var(--color-error)}.bot-list .bot-controls{display:flex;flex-shrink:0;gap:var(--space-2);margin-left:var(--space-4)}.bot-list .bot-control-btn{align-items:center;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;display:flex;font-size:var(--text-base);height:32px;justify-content:center;transition:all var(--transition-fast);width:32px}.bot-list .bot-control-btn:hover{background:var(--bg-elevated)}.bot-list .bot-control-btn.pause:hover{background:var(--color-warning-bg);border-color:var(--color-warning);color:var(--color-warning)}.bot-list .bot-control-btn.resume:hover{background:var(--color-success-bg);border-color:var(--color-success);color:var(--color-success)}.bot-list .bot-control-btn.stop:hover{background:var(--color-error-bg);border-color:var(--color-error);color:var(--color-error)}.bot-list .bot-card-content{border-top:1px solid var(--border-primary);padding:0 var(--space-4) var(--space-4)}.bot-list .bot-details{border-bottom:1px solid var(--border-primary);display:flex;flex-wrap:wrap;gap:var(--space-4);margin-bottom:var(--space-3);padding:var(--space-3) 0}.bot-list .detail-item{display:flex;font-size:var(--text-sm);gap:var(--space-2)}.bot-list .detail-label{color:var(--text-muted)}.bot-list .detail-value{color:var(--text-primary);font-weight:var(--font-medium)}.bot-list .bot-trades-table-container{max-height:300px;overflow-y:auto}.bot-list .bot-trades-table{border-collapse:collapse;font-size:var(--text-sm);width:100%}.bot-list .bot-trades-table th{background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);color:var(--text-muted);font-weight:var(--font-medium);padding:var(--space-2) var(--space-3);position:sticky;text-align:left;top:0}.bot-list .bot-trades-table td{border-bottom:1px solid var(--border-secondary);color:var(--text-primary);padding:var(--space-2) var(--space-3)}.bot-list .bot-trades-table tbody tr:hover{background:var(--bg-elevated)}.bot-list .trade-badge{border-radius:var(--radius-sm);display:inline-block;font-size:var(--text-xs);font-weight:var(--font-medium);padding:2px var(--space-2)}.bot-list .trade-badge.buy{background:var(--accent-blue-bg);color:var(--accent-blue)}.bot-list .trade-badge.sell{background:var(--color-error-bg);color:var(--color-error)}.bot-list .bot-trades-table .positive{color:var(--color-success)}.bot-list .bot-trades-table .negative{color:var(--color-error)}.bot-list .empty-trades{color:var(--text-muted);padding:var(--space-5)!important;text-align:center}.bot-list .trades-more{color:var(--text-muted);font-size:var(--text-sm);padding:var(--space-2);text-align:center}@media (max-width:900px){.bot-list-tabs-left{-webkit-overflow-scrolling:touch;overflow-x:auto}.bot-list .bot-card-header{flex-wrap:wrap;gap:var(--space-2)}.bot-list .bot-stats{justify-content:space-between;margin-left:0;margin-top:var(--space-2);width:100%}.bot-list .bot-controls{margin-left:auto}}.live-trading-page{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-areas:"chart config" "bots config";grid-template-columns:1fr 340px;grid-template-rows:1fr auto;height:calc(100vh - var(--navbar-height) - 40px);margin:0 auto;max-width:var(--max-width);padding:var(--space-4)}.chart-area{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);display:flex;flex-direction:column;grid-area:chart;min-height:0;overflow:hidden}.config-area{grid-area:config;overflow-y:auto}.bots-area{grid-area:bots;max-height:350px;overflow-y:auto}.chart-empty-state,.chart-loading-state{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;font-size:var(--text-sm);gap:var(--space-3);height:100%;justify-content:center}.chart-empty-state .icon{font-size:48px;opacity:.5}.error-message{background:var(--color-error-bg);border-radius:var(--radius-md);font-size:var(--text-sm);margin:var(--space-3);padding:var(--space-3) var(--space-4)}.ws-status{align-items:center;color:var(--text-secondary);display:flex;font-size:var(--text-xs);gap:var(--space-2);padding:var(--space-2) var(--space-3)}.ws-status .status-dot{border-radius:50%;height:6px;width:6px}.ws-status .status-dot.connected{background:var(--color-success);box-shadow:0 0 8px var(--color-success)}.ws-status .status-dot.disconnected{background:var(--color-error)}.ws-status .status-dot.connecting{animation:pulse 1.5s ease-in-out infinite;background:var(--color-warning)}@media (max-width:1024px){.live-trading-page{grid-template-areas:"chart" "config" "bots";grid-template-columns:1fr;grid-template-rows:minmax(400px,50vh) auto auto;height:auto}.bots-area,.config-area{max-height:none}}@media (max-width:768px){.live-trading-page{gap:var(--space-3);grid-template-rows:minmax(300px,40vh) auto auto;padding:var(--space-3)}}.market-list-item{background-color:initial;border:1px solid #0000;border-radius:6px;cursor:pointer;margin-bottom:8px;padding:12px;transition:all .3s ease}.market-list-item:hover{background-color:var(--accent-blue-bg);border-color:var(--border-primary)}.market-list-item.selected{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background-color:var(--bg-tertiary);border-color:var(--border-primary)}.market-list-item-row{display:flex;justify-content:space-between;margin-bottom:4px}.market-list-item-symbol{color:var(--text-primary);font-weight:600}.market-list-item-price{color:var(--text-secondary);font-weight:500}.market-list-item-change{font-size:14px;font-weight:500}.market-list-item-change.positive{color:var(--color-success)}.market-list-item-change.negative{color:var(--color-error)}.market-card{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;box-shadow:0 4px 6px #0000004d;padding:20px}.market-card h2{color:var(--text-primary);font-size:18px;font-weight:600;margin-bottom:16px}.broker-connection{width:100%}.broker-connection .card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:24px}.broker-connection h2{font-size:20px;font-weight:600;margin-bottom:24px}.connection-form{display:flex;flex-direction:column;gap:20px;max-width:600px}.form-group input[type=password],.form-group input[type=text]{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);font-size:14px;padding:12px}.form-group input[type=password]:focus,.form-group input[type=text]:focus{border-color:var(--accent-blue);outline:none}.form-group input[type=password]:disabled,.form-group input[type=text]:disabled{cursor:not-allowed;opacity:.5}.form-group small{color:var(--text-secondary);font-size:12px}.form-group small a{color:var(--accent-blue);text-decoration:none}.form-group small a:hover{text-decoration:underline}.checkbox-group label{align-items:center;cursor:pointer;display:flex;font-weight:400;gap:8px}.checkbox-group input[type=checkbox]{cursor:pointer;height:18px;width:18px}.error-message{background:#f871711a;border:1px solid var(--color-error);color:var(--color-error);font-size:14px}.connection-info{display:flex;flex-direction:column;gap:24px}.status-badge{align-items:center;border-radius:6px;display:inline-flex;font-size:14px;font-weight:500;padding:6px 12px;width:fit-content}.status-badge.connected{background:#34d3991a;border:1px solid var(--color-success);color:var(--color-success)}.account-details{display:flex;flex-direction:column;gap:16px}.account-details h3{font-size:16px;font-weight:600;margin:0}.info-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.info-item{background:var(--bg-secondary);border-radius:8px;display:flex;flex-direction:column;gap:4px;padding:12px}.info-item .label{color:var(--text-secondary);font-size:12px}.info-item .value{color:var(--text-primary);font-size:16px;font-weight:600}.futures-list{display:flex;flex-direction:column;gap:16px}.futures-list h3{font-size:16px;font-weight:600;margin:0}.search-box{align-items:center;display:flex;position:relative}.search-input{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);font-size:14px;padding:12px 40px 12px 16px;transition:all .2s;width:100%}.search-input:focus{background:var(--bg-primary);border-color:var(--accent-blue);outline:none}.search-input::placeholder{color:var(--text-muted)}.clear-search{align-items:center;background:#0000;border:none;color:var(--text-secondary);cursor:pointer;display:flex;font-size:18px;height:24px;justify-content:center;padding:0;position:absolute;right:12px;transition:all .2s;width:24px}.clear-search:hover{background:#f871711a;border-radius:4px;color:var(--color-error)}.futures-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.future-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;display:flex;flex-direction:column;gap:8px;padding:16px;transition:all .2s}.future-card:hover{border-color:var(--accent-blue);transform:translateY(-2px)}.future-header{align-items:center;display:flex;justify-content:space-between}.future-ticker{color:var(--accent-blue);font-size:18px;font-weight:700}.future-currency{background:var(--accent-blue-bg);border-radius:4px;color:var(--text-secondary);font-size:12px;padding:4px 8px}.future-name{color:var(--text-primary);font-size:14px}.future-details{border-top:1px solid var(--border-primary);display:flex;flex-direction:column;gap:4px;margin-top:8px;padding-top:8px}.future-details small{color:var(--text-secondary);font-size:12px}button.primary,button.secondary{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s;width:fit-content}button.primary:hover:not(:disabled){background:var(--btn-primary-hover)}button.primary:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.broker-connection .card{padding:16px}.futures-grid,.info-grid{grid-template-columns:1fr}.form-group input[type=password],.form-group input[type=text]{font-size:16px}}.profile-content{display:flex;flex-direction:column;gap:24px}.profile-content .card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:24px}.profile-content h2{font-size:20px;font-weight:600;margin-bottom:24px}.form-section{display:flex;flex-direction:column;gap:20px;max-width:500px}.form-group input,.form-group select{background:var(--bg-secondary)}.subscription-info{display:flex;flex-direction:column;gap:24px}.current-plan{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;padding:16px}.plan-badge{border-radius:6px;display:inline-block;font-size:14px;font-weight:600;margin-bottom:12px;padding:6px 12px}.plan-badge.free{background:#9ca3af1a;border:1px solid var(--text-secondary);color:var(--text-secondary)}.current-plan p{color:var(--text-secondary);margin:0}.plan-features h3,.upgrade-section h3{font-size:16px;font-weight:600;margin-bottom:12px}.plan-features ul,.upgrade-section ul{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.plan-features li,.upgrade-section li{color:var(--text-primary);font-size:14px}.upgrade-section{background:linear-gradient(135deg,#6366f11a,#6366f10d);border:1px solid var(--accent-blue);border-radius:12px;padding:24px}.price{color:var(--accent-blue);font-size:32px;font-weight:700;margin:12px 0 16px}.upgrade-btn{margin-top:16px;width:100%}.danger-zone{border-top:1px solid var(--border-primary);margin-top:32px;padding-top:24px}.danger-zone h3{color:var(--color-error);font-size:16px;font-weight:600;margin-bottom:8px}.danger-zone p{color:var(--text-secondary);font-size:14px;margin-bottom:16px}button.danger,button.primary,button.secondary{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s;width:fit-content}button.primary{background:var(--btn-primary-bg);color:#fff}button.primary:hover{background:var(--btn-primary-hover)}button.secondary{background:#0000;border:1px solid var(--border-primary);color:var(--text-primary)}button.secondary:hover{background:var(--bg-secondary);border-color:var(--accent-blue)}button.danger{background:#0000;border:1px solid var(--color-error);color:var(--color-error)}button.danger:hover{background:#f871711a}@media (max-width:768px){.profile-content .card{padding:16px}.form-section{max-width:100%}.upgrade-btn{width:100%}}.yandex-login-button{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:12px;justify-content:center;max-width:400px;padding:12px 24px;transition:all .2s ease;width:100%}.yandex-login-button:hover{background:linear-gradient(135deg,#818cf8,#a78bfa);box-shadow:0 4px 12px #6366f14d;transform:translateY(-2px)}.yandex-login-button:active{transform:translateY(0)}.yandex-login-button svg{flex-shrink:0}@media (max-width:768px){.yandex-login-button{font-size:16px;max-width:none;width:100%}}.login-container{align-items:center;background:var(--bg-primary);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:16px;box-shadow:0 20px 40px #0000004d;max-width:480px;overflow:hidden;width:100%}.login-header{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;padding:32px;text-align:center}.login-header h1{font-size:36px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px}.login-header p{font-size:14px;font-weight:500;margin:0;opacity:.9}.login-content{padding:32px}.login-content h2{color:var(--text-primary);font-size:24px;font-weight:600;margin:0 0 8px;text-align:center}.subtitle{color:var(--text-secondary);font-size:14px;margin:0 0 32px;text-align:center}.auth-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}.telegram-login-button{align-items:center;background:#08c;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:12px;justify-content:center;padding:12px 24px;transition:all .2s ease;width:100%}.telegram-login-button:hover{background:#0077b3;box-shadow:0 4px 12px #0088cc4d;transform:translateY(-2px)}.telegram-login-button:active{transform:translateY(0)}.telegram-login-button svg{flex-shrink:0}.login-footer{border-top:1px solid var(--border-primary);padding-top:24px;text-align:center}.login-footer p{color:var(--text-muted);font-size:12px;margin:0 0 8px}.login-footer .links{align-items:center;display:flex;font-size:12px;gap:6px;justify-content:center}.login-footer .links span{color:var(--text-muted)}.login-footer .links a{color:var(--accent-blue);font-weight:500;text-decoration:none}.login-footer .links a:hover{text-decoration:underline}@media (max-width:768px){.login-container{align-items:stretch;padding:0}.login-card{border-radius:0;display:flex;flex-direction:column;min-height:100vh}.login-header{padding:48px 24px 32px}.login-content{display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:24px}.telegram-login-button{font-size:16px}}.yandex-callback-container{align-items:center;background:#0f0f0f;display:flex;justify-content:center;min-height:100vh;padding:20px}.callback-content{align-items:center;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:12px;display:flex;flex-direction:column;gap:20px;max-width:500px;padding:48px;text-align:center;width:100%}.callback-content h2{color:#e5e7eb;font-size:24px;font-weight:600;margin:0}.callback-content p{color:#9ca3af;font-size:16px;margin:0}.spinner{animation:spin 1s linear infinite;border:4px solid #2a2a2a;border-radius:50%;border-top-color:#fc0;height:48px;width:48px}@keyframes spin{to{transform:rotate(1turn)}}.error-icon,.success-icon{align-items:center;border-radius:50%;display:flex;font-size:36px;height:64px;justify-content:center;width:64px}.error-icon{background:#ef44441a;color:#ef4444}.success-icon{background:#22c55e1a;color:#22c55e;font-weight:700}.error-message{background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#ef4444!important;padding:12px}.callback-content button{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:8px;padding:12px 24px;transition:all .2s}.callback-content button:hover{background:#2563eb}@media (max-width:768px){.callback-content{padding:32px 24px}.callback-content h2{font-size:20px}.callback-content p{font-size:14px}}.strategy-badge{border:1px solid;border-radius:6px;display:inline-block;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.strategy-volume{background:#6366f126;border-color:#6366f166;color:#818cf8}.strategy-ob{background:#34d39926;border-color:#34d39966;color:#34d399}.strategy-momentum{background:#fbbf2426;border-color:#fbbf2466;color:#fbbf24}.strategy-funding{background:#a855f726;border-color:#a855f766;color:#a855f7}.status-led{border-radius:50%;flex-shrink:0;height:12px;position:relative;width:12px}.status-led:before{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite;border-radius:50%;content:"";height:100%;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:100%}.status-led.status-running{background-color:#34d399;box-shadow:0 0 8px #34d39999}.status-led.status-running:before{background-color:#34d399}@keyframes pulse{0%,to{opacity:1;transform:translate(-50%,-50%) scale(1)}50%{opacity:0;transform:translate(-50%,-50%) scale(1.8)}}.status-led.status-paused{background-color:#fbbf24;box-shadow:0 0 8px #fbbf2499}.status-led.status-paused:before{animation:pulse-slow 3s cubic-bezier(.4,0,.6,1) infinite;background-color:#fbbf24}@keyframes pulse-slow{0%,to{opacity:.6;transform:translate(-50%,-50%) scale(1)}50%{opacity:0;transform:translate(-50%,-50%) scale(1.5)}}.status-led.status-error{background-color:#f87171;box-shadow:0 0 8px #f8717199}.status-led.status-error:before{animation:blink 1s ease-in-out infinite;background-color:#f87171}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.status-led.status-stopped{background-color:#6b7280;box-shadow:0 0 4px #6b748066}.status-led.status-stopped:before{display:none}.status-running{color:#34d399}.status-paused{color:#fbbf24}.status-error{color:#f87171}.status-stopped{color:#a5b4fc}@media (max-width:768px){.strategy-badge{font-size:10px;padding:3px 10px}.status-led{height:10px;width:10px}}.bot-create-step-indicator{gap:12px;margin-bottom:32px}.bot-create-step-indicator,.step-circle{align-items:center;display:flex;justify-content:center}.step-circle{background:#ffffff0d;border:2px solid #ffffff1a;border-radius:50%;color:#fff6;font-size:14px;font-weight:600;height:40px;transition:all .3s ease;width:40px}.step-circle.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 0 20px #667eea66;color:#fff}.step-label{color:#ffffff80;font-size:12px;position:absolute;top:50px;white-space:nowrap}.step-line{background:#ffffff1a;height:2px;transition:all .3s ease;width:60px}.step-line.active{background:linear-gradient(90deg,#667eea,#764ba2);box-shadow:0 0 10px #667eea4d}.bot-create-step{min-height:300px}.strategy-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.strategy-card{background:#ffffff08;border:1px solid #ffffff1a;border-radius:12px;cursor:pointer;overflow:hidden;padding:24px;position:relative;transition:all .3s ease}.strategy-card:before{background:linear-gradient(135deg,#667eea1a,#764ba21a);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.strategy-card:hover:before{opacity:1}.strategy-card:hover{border-color:#667eea66;box-shadow:0 8px 24px #0000004d;transform:translateY(-2px)}.strategy-card.selected{background:linear-gradient(135deg,#667eea26,#764ba226);border-color:#667eea;box-shadow:0 0 20px #667eea4d}.strategy-card.selected:after{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;content:"✓";display:flex;font-size:14px;font-weight:700;height:24px;justify-content:center;position:absolute;right:12px;top:12px;width:24px}.strategy-card h3,.strategy-card p{position:relative;z-index:1}@media (max-width:768px){.strategy-grid{grid-template-columns:1fr}.bot-create-step-indicator{gap:8px}.step-circle{font-size:12px;height:32px;width:32px}.step-line{width:40px}.step-label{font-size:10px;top:40px}}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:32px}.btn-primary{background:var(--btn-primary-bg);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 20px;transition:all .2s}.btn-primary:hover{background:var(--btn-primary-hover);box-shadow:0 0 12px #6366f166}.btn-primary:disabled{cursor:not-allowed;opacity:.5}.btn-secondary{background:#0000;border:1px solid var(--border-primary);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.btn-secondary:hover{background:var(--bg-secondary);border-color:var(--accent-blue)}.btn-secondary:disabled{cursor:not-allowed;opacity:.5}.btn-danger{background:#f871711a;border:1px solid #0000;border-radius:6px;color:var(--color-error);cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.btn-danger:hover{background:#f8717133;border-color:var(--color-error)}.credential-form{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;margin-bottom:24px;padding:24px}.credential-form h2{color:var(--text-primary);font-size:20px;font-weight:600;margin-bottom:24px}.credential-form form{display:flex;flex-direction:column;gap:20px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:var(--text-primary);font-size:14px;font-weight:500}.form-group input,.form-group select{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:8px;color:var(--text-primary);font-size:14px;padding:12px;transition:all .2s}.form-group input:focus,.form-group select:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #6366f11a;outline:none}.form-group input::placeholder{color:var(--text-secondary);opacity:.6}.credentials-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}.credential-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;padding:20px;transition:all .3s}.credential-card:hover{border-color:var(--accent-blue);box-shadow:0 4px 12px #0000004d}.credential-header{align-items:flex-start;border-bottom:1px solid var(--border-primary);display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:16px}.credential-info{display:flex;flex-direction:column;gap:8px}.credential-info h3{color:var(--text-primary);font-size:18px;font-weight:600;margin:0}.exchange-badge{border-radius:6px;display:inline-block;font-size:12px;font-weight:700;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase;width:fit-content}.exchange-badge.bybit{background:#ffc10726;border:1px solid #ffc1074d;color:#ffc107}.exchange-badge.mexc{background:#10b98126;border:1px solid #10b9814d;color:#10b981}.exchange-badge.okx{background:#6366f126;border:1px solid #6366f14d;color:#6366f1}.credential-status{align-items:center;display:flex;gap:6px}.status-dot{border-radius:50%;height:8px;width:8px}.status-dot.valid{background:var(--color-success);box-shadow:0 0 6px var(--color-success)}.status-dot.invalid{background:var(--color-error);box-shadow:0 0 6px var(--color-error)}.status-text{color:var(--text-secondary);font-size:13px;font-weight:500}.credential-details{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.detail-item{align-items:center;display:flex;justify-content:space-between}.detail-label{color:var(--text-secondary);font-size:13px;font-weight:500}.detail-value{color:var(--text-primary);font-size:13px;font-weight:600}.credential-actions{border-top:1px solid var(--border-primary);display:flex;gap:10px;padding-top:16px}.empty-state{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;padding:60px 40px;text-align:center}.empty-state h3{color:var(--text-primary);font-size:20px;font-weight:600;margin-bottom:12px}.empty-state p{color:var(--text-secondary);font-size:15px;line-height:1.6;margin-bottom:24px}@media (max-width:768px){.page-header{align-items:flex-start;flex-direction:column;gap:16px}.page-header .btn-primary{width:100%}.credentials-list,.form-row{grid-template-columns:1fr}.credential-card,.credential-form{padding:16px}.credential-actions{flex-direction:column}.credential-actions button{width:100%}}
/*# sourceMappingURL=main.c4430a0d.css.map*/