:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;--theme-background: #0a0a0a;--theme-text: #e8e8e8;--theme-text-secondary: #b0b0b0;--theme-text-muted: #808080;--theme-text-accent: #4f46e5;--theme-panel-bg: rgba(17, 17, 17, .95);--theme-border: #333333;--theme-input-bg: #111111;--theme-button-bg: #4f46e5;color-scheme:light dark;color:var(--theme-text);background-color:var(--theme-background);transition:background-color .3s ease,color .3s ease;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--theme-background);color:var(--theme-text);transition:background-color .3s ease,color .3s ease}#root{width:100%;height:100vh;margin:0;padding:0}.App{height:100vh;max-height:100vh;display:flex;flex-direction:column;width:100%;max-width:none;margin:0;padding:0;text-align:left;position:relative;overflow:hidden;transition:background-color .3s ease,color .3s ease}.App-header{background:var(--theme-header-bg);color:var(--theme-text);padding:.8rem 2rem;text-align:center;box-shadow:0 2px 10px #0000004d;border-bottom:1px solid var(--theme-border)}.App-header h1{margin:0;font-size:2rem;font-weight:600}.App-main{flex:1;padding:2rem;max-width:1400px;margin:0 auto;width:100%;box-sizing:border-box;position:relative;z-index:1}.config-section{background:var(--theme-panel-bg);border-radius:0;padding:.8rem;margin-bottom:0;border:none;border-bottom:1px solid var(--theme-config-border);box-shadow:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);height:100%;transition:all .3s ease}.two-column-layout.chart-view .config-section{padding:.6rem}.config-section h2{margin:0 0 .6rem;color:var(--theme-text-accent);font-size:.95rem;font-weight:600}.two-column-layout.chart-view .config-section h2{font-size:.9rem}.config-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.form-row label{display:flex;flex-direction:column;gap:.5rem;font-weight:500;color:var(--theme-text)}.form-row select,.form-row input{padding:.4rem;border:1px solid var(--theme-input-border);border-radius:6px;font-size:.85rem;background:var(--theme-input-bg);color:var(--theme-text);transition:all .3s ease}.form-row select:focus,.form-row input:focus{outline:none;border-color:var(--theme-primary-color);box-shadow:0 0 0 2px var(--theme-input-border);background:var(--theme-input-bg)}.form-actions{display:flex;gap:1rem;margin-top:1rem;flex-wrap:wrap}.primary-button{background:var(--theme-button-bg);color:var(--theme-button-text);border:none;padding:.75rem 1.5rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.primary-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #0003;opacity:.9}.primary-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.chart-section{flex:1;background:transparent;border-radius:0;padding:0;box-shadow:none;border:none;height:100%}.no-data-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--theme-text-secondary);padding:3rem}.no-data-placeholder h3{margin:0 0 .8rem;color:var(--theme-text-accent);font-size:1.4rem;font-weight:600}.no-data-placeholder p{margin:0;font-size:.95rem;line-height:1.4;color:var(--theme-text-secondary)}.current-symbol{margin-top:1rem!important;color:var(--theme-button-bg)!important;font-weight:500!important}.chart-header{position:absolute;top:1rem;left:1rem;z-index:10;background:#1a1d23e6;padding:.5rem 1rem;border-radius:6px;border:1px solid var(--theme-border)}.chart-header h3{margin:0;color:var(--theme-text);font-size:1rem;font-weight:500}#root{max-width:none;margin:0;padding:0;text-align:left;width:100vw;height:100vh}body{margin:0;padding:0;display:block;place-items:initial;min-width:initial;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;background:#0b0e14;color:var(--theme-text);overflow:hidden}@media (max-width: 768px){body{overflow:hidden}}.trading-platform{height:100vh;max-height:100vh;background:var(--theme-background);color:var(--theme-text);display:flex;flex-direction:column;overflow:hidden;transition:background-color .3s ease,color .3s ease}.auth-section{display:flex;align-items:center;gap:1rem}.user-info-container{display:flex;align-items:center;gap:.5rem;padding:.25rem .5rem .25rem .4rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:8px;transition:all .2s ease}.user-info-container:hover{background:#ffffff14;border-color:#ffffff26}.user-details{display:flex;align-items:center;gap:.4rem;font-size:.75rem}.user-type-icon{font-size:.9rem;display:flex;align-items:center}.user-id{display:flex;align-items:center;gap:.15rem}.uid-label{color:var(--theme-text-secondary);font-weight:400;font-size:.7rem}.uid-value{color:var(--theme-text);font-weight:600;font-family:SF Mono,monospace;font-size:.75rem}.logout-btn{font-size:.65rem;padding:.15rem .45rem;border-radius:4px;border:1px solid rgba(255,255,255,.1);background:transparent;color:var(--theme-text-secondary);cursor:pointer;transition:all .2s}.logout-btn:hover{background:#ef444426;border-color:#ef44444d;color:#ef4444}.vip-badge-hover:hover .vip-tooltip{opacity:1!important;visibility:visible!important;pointer-events:auto!important}.user-avatar-menu:hover .user-dropdown{opacity:1!important;visibility:visible!important;pointer-events:auto!important;transform:translateY(0)!important}.admin-status{padding:.15rem .4rem;background:#dc354526;border:1px solid rgba(220,53,69,.3);border-radius:10px}.admin-label{color:#dc3545;font-weight:600;font-size:.7rem}.logout-btn-container{position:relative}.auth-loading{color:var(--theme-text-secondary);font-size:.9rem}.login-btn{background:var(--theme-button-bg);color:var(--theme-button-text);border:none;padding:.5rem 1.25rem;border-radius:20px;cursor:pointer;font-weight:500;font-size:.9rem;transition:all .3s ease;box-shadow:0 2px 8px #0000001a}.login-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0003;opacity:.9}.logout-btn{background:linear-gradient(135deg,#dc354526,#ef44441a);color:#dc3545;border:1px solid rgba(220,53,69,.4);border-radius:18px;min-width:60px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;padding:0 .5rem;flex-shrink:0;gap:.3rem;font-size:.7rem;font-weight:500;box-shadow:0 2px 6px #dc354526}.logout-text{display:inline-block;color:#dc3545;font-weight:600}.platform-header.chart-view .logout-btn{min-width:55px;height:28px;padding:0 .4rem;font-size:.65rem}.logout-btn:hover{background:linear-gradient(135deg,#dc354540,#ef444433);border-color:#dc354599;transform:translateY(-2px);box-shadow:0 6px 16px #dc35454d}.logout-btn:active{transform:translateY(0);box-shadow:0 2px 8px #dc354533}.auth-prompt{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;background:var(--theme-panel-background);margin:2rem auto;max-width:600px;border-radius:16px;border:1px solid var(--theme-border);box-shadow:0 8px 32px #0000001a;min-height:400px;transition:background-color .3s ease}.auth-prompt h2{color:var(--theme-text);margin-bottom:1.2rem;font-size:2rem;font-weight:600}.auth-prompt p{color:var(--theme-text-secondary);margin-bottom:2rem;font-size:1.1rem;line-height:1.5;max-width:400px}.auth-prompt .primary-button{padding:1rem 2rem;font-size:1.1rem;font-weight:600;background:var(--theme-button-bg);border:none;border-radius:12px;color:var(--theme-button-text);cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #0000001a;min-width:200px}.auth-prompt .primary-button:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003;opacity:.9}.auth-prompt .primary-button:active{transform:translateY(0)}.main-content{flex:1;padding:0;max-width:none;margin:0;width:100%;overflow:hidden;height:calc(100vh - 54px);transition:all .3s ease}.main-content.chart-view{padding:0;height:calc(100vh - 54px)}.two-column-layout{display:flex;gap:0;height:calc(100vh - 54px);max-height:calc(100vh - 54px);overflow:hidden;transition:all .3s ease}.two-column-layout.chart-view{gap:0;height:calc(100vh - 54px);max-height:calc(100vh - 54px)}.left-sidebar{display:flex;flex-direction:column;gap:0rem;overflow:hidden;transition:all .3s ease}.center-chart{flex:1;display:flex;flex-direction:column;background:var(--theme-background);border-radius:0;border:none;border-left:1px solid var(--theme-border);overflow:hidden;height:100%;box-shadow:none;transition:all .3s ease}.market-tabs{display:flex;gap:.5rem;flex-wrap:wrap}.market-tabs.vertical{flex-direction:column;flex-wrap:nowrap}.market-tab{background:linear-gradient(135deg,#1119,#1a1a1a66);border:1px solid rgba(79,70,229,.2);color:var(--theme-text);padding:.55rem .75rem;border-radius:8px;cursor:pointer;font-weight:500;font-size:.8rem;transition:all .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative;overflow:hidden}.two-column-layout.chart-view .market-tab{font-size:.75rem;padding:.5rem .7rem}.market-tab:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(79,70,229,.1),transparent);transition:left .5s}.market-tab:hover:before{left:100%}.market-tab:hover{background:linear-gradient(135deg,#4f46e526,#6366f11a);border-color:#6366f166;color:var(--theme-primary-color);transform:translateY(-1px);box-shadow:0 4px 16px #4f46e540}.market-tab.active{background:linear-gradient(135deg,#4f46e540,#6366f126);border-color:var(--theme-primary-color);color:var(--theme-text);box-shadow:0 4px 20px #4f46e559;font-weight:600}.examples-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem;margin-top:.5rem;background:var(--theme-background)}.example-btn{display:flex;align-items:center;justify-content:center;background:var(--theme-input-bg);border:1px solid var(--theme-border);color:var(--theme-text);padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease}.example-btn:hover{background:var(--theme-button-bg);border-color:var(--theme-button-bg);color:var(--theme-button-text);transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.loading-section{text-align:center;padding:3rem 2rem;background:var(--theme-panel-bg);border-radius:12px;border:1px solid var(--theme-border);margin-bottom:1.5rem}.loading-spinner{border:3px solid var(--theme-border);border-top:3px solid var(--theme-button-bg);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-section p{color:var(--theme-text-secondary);font-size:1rem}.error-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.error-dialog{background:var(--theme-panel-bg);border:2px solid #dc3545;border-radius:12px;max-width:500px;width:90%;box-shadow:0 10px 30px #dc35454d;animation:errorSlideIn .3s ease-out}@keyframes errorSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.error-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-bottom:1px solid #374151}.error-header h3{margin:0;color:#dc3545;font-size:1.2rem}.close-error-btn{background:none;border:none;color:var(--theme-text-secondary);font-size:1.5rem;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.close-error-btn:hover{background:#374151;color:var(--theme-text)}.error-content{padding:1.5rem 2rem 2rem}.error-content p{margin:0 0 1.5rem;color:var(--theme-text);line-height:1.5}.error-actions{display:flex;gap:1rem;justify-content:flex-end}.retry-btn{background:var(--theme-button-bg);color:var(--theme-text);border:none;padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.retry-btn:hover{background:#1565c0;transform:translateY(-1px)}@media (max-width: 1200px){.left-sidebar{width:220px;min-width:220px;max-width:220px}}@media (max-width: 1024px){.two-column-layout{flex-direction:column;height:auto;min-height:auto;gap:.5rem}.left-sidebar{width:100%;min-width:auto;max-width:none;order:-1}.center-chart{min-height:500px;order:1}.market-tabs.vertical{flex-direction:row;flex-wrap:wrap;gap:.4rem}.config-section{padding:.6rem}}@media (max-width: 768px){.main-content{padding:.4rem}.user-info-container{gap:.5rem;padding:.25rem .5rem}.user-details{gap:.3rem;font-size:.65rem}.user-type-icon{font-size:.9rem;width:16px;height:16px}.uid-label,.uid-value,.vip-label,.permanent-label,.admin-label{font-size:.6rem}.logout-btn{min-width:50px;height:26px;font-size:.6rem;padding:0 .3rem}.logout-text{font-size:.6rem}.form-row{grid-template-columns:1fr}.examples-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:.3rem;background:var(--theme-background)}.left-sidebar{width:100%}.two-column-layout{gap:.4rem}.market-tab{padding:.4rem .6rem;font-size:.7rem}}.auth-modal-overlay{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;background:#000000b3!important;display:flex!important;align-items:center!important;justify-content:center!important;z-index:3000!important;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);width:100vw!important;height:100vh!important}.auth-modal{background:var(--theme-panel-background);border:1px solid var(--theme-border);border-radius:12px;width:100%;max-width:400px;margin:20px;box-shadow:0 10px 30px #00000080;animation:modalSlideIn .3s ease-out;position:relative}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--theme-border)}.auth-modal-header h2{margin:0;color:var(--theme-text);font-size:20px}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:var(--theme-text-secondary);padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.close-btn:hover{background:var(--theme-input-bg);color:var(--theme-text)}.auth-modal-content{padding:24px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;color:var(--theme-text);font-weight:500;font-size:.9rem}.form-group input{width:100%;padding:12px;border:1px solid #4a5568;border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box;background:var(--theme-input-bg);color:var(--theme-text)}.form-group input:focus{outline:none;border-color:var(--theme-button-bg);box-shadow:0 0 0 2px #2962ff40}.form-group input.error{border-color:#dc3545;box-shadow:0 0 0 2px #dc354540}.error-message{color:#dc3545;font-size:.8rem;margin-top:4px;display:block}.general-message{text-align:center;margin-bottom:16px;padding:10px;border-radius:6px;font-weight:500;font-size:.9rem;border:1px solid}.general-message.success{background:#22c55e1a;color:#22c55e;border-color:#22c55e}.general-message.error{background:#dc35451a;color:#dc3545;border-color:#dc3545}.submit-btn{width:100%;padding:12px;background:var(--theme-button-bg);color:var(--theme-text);border:none;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:background .2s}.submit-btn:hover:not(:disabled){background:#1565c0}.submit-btn:disabled{background:#4a5568;cursor:not-allowed}.mode-switch{text-align:center;margin-top:20px;padding-top:20px;border-top:1px solid #2a2e39}.mode-switch p{margin:0;color:var(--theme-text-secondary)}.switch-btn{background:none;border:none;color:var(--theme-button-bg);cursor:pointer;text-decoration:underline;margin-left:8px}.switch-btn:hover{color:#1565c0}.user-profile-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:4000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.user-profile-modal{background:var(--theme-panel-background);border:1px solid var(--theme-border);border-radius:12px;width:90%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px #00000080;animation:modalSlideIn .3s ease-out}.user-profile{padding:2rem}.profile-header{background:var(--theme-panel-background);border-radius:12px;padding:2rem;margin-bottom:2rem;border:1px solid var(--theme-border)}.profile-header h1{margin:0 0 1.5rem;color:var(--theme-text)}.user-basic-info{display:flex;align-items:center;gap:1.5rem}.avatar{width:80px;height:80px;border-radius:50%;overflow:hidden;background:var(--theme-input-bg)}.default-avatar{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--theme-button-bg);color:var(--theme-button-text);font-size:2rem;font-weight:700}.basic-info h2{margin:0 0 .5rem;color:var(--theme-text)}.basic-info p{margin:0 0 .5rem;color:var(--theme-text-secondary)}.user-type-badge{padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500}.user-type-badge.admin{background:#dc35451a;color:#dc3545}.user-type-badge.vip{background:#fbbf241a;color:#fbbf24}.user-type-badge.normal{background:#9ca3af1a;color:var(--theme-text-secondary)}.search-section{margin-top:.8rem;padding-top:.8rem;border-top:1px solid var(--theme-border)}.search-label{display:block;margin-bottom:.6rem;color:var(--theme-text);font-weight:600;font-size:.85rem;letter-spacing:-.01em}.two-column-layout.chart-view .search-label{font-size:.8rem;color:var(--theme-text)}.search-input{width:100%;padding:.45rem;border:1px solid var(--theme-input-border);border-radius:6px;font-size:.8rem;background:var(--theme-input-bg);color:var(--theme-text);margin-top:.4rem;transition:all .3s ease;box-sizing:border-box}.two-column-layout.chart-view .search-input{font-size:.75rem;padding:.4rem;color:var(--theme-text)}.search-input:focus{outline:none;border-color:var(--theme-button-bg);box-shadow:0 0 0 2px #0000001a;background:var(--theme-input-bg)}.search-btn{width:100%;padding:.75rem;background:var(--theme-button-bg);color:var(--theme-button-text);border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s;margin-top:.75rem}.search-btn:hover:not(:disabled){background:var(--theme-button-bg);opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px #0003}.search-btn:disabled{background:var(--theme-text-muted);cursor:not-allowed;transform:none;opacity:.6}.timeframe-info{margin-top:.75rem;padding:.5rem;background:var(--theme-input-bg);border-radius:4px;font-size:.85rem;color:var(--theme-text-secondary);text-align:center;font-weight:400;letter-spacing:-.01em}.examples-section{margin-top:.8rem;padding-top:.8rem;border-top:1px solid var(--theme-border)}.examples-section h3{margin:0 0 .6rem;color:var(--theme-text);font-size:.85rem;font-weight:600;letter-spacing:-.01em}.two-column-layout.chart-view .examples-section h3{font-size:.8rem;color:var(--theme-text)}.search-container{position:relative}.search-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--theme-panel-background);border:1px solid var(--theme-border);border-top:none;border-radius:0 0 6px 6px;max-height:300px;overflow-y:auto;z-index:1500;box-shadow:0 4px 12px #0000004d}.search-dropdown-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;border-bottom:1px solid var(--theme-border);cursor:pointer;transition:background-color .2s;font-size:.9rem}.search-dropdown-item:hover{background:var(--theme-input-bg);border-color:var(--theme-button-bg)}.search-dropdown-item:last-child{border-bottom:none}.symbol-text{flex:1;color:var(--theme-text);font-size:.8rem;font-weight:400}.symbol-text:hover{color:var(--theme-button-bg);font-weight:500}.favorite-btn{background:none;border:none;color:var(--theme-text-secondary);font-size:1.2rem;cursor:pointer;padding:.25rem;margin-left:.5rem;transition:all .2s;border-radius:4px;font-weight:400}.favorite-btn:hover{background:var(--theme-input-bg);color:#fbbf24;transform:scale(1.1)}.favorite-btn.favorited{color:#fbbf24;font-weight:600}.favorites-placeholder{text-align:center;padding:1.5rem .8rem;color:var(--theme-text-muted)}.tchan-watermark{position:relative}.tchan-watermark:after{content:"jijianchanlun.com";position:absolute;right:10px;bottom:8px;pointer-events:none;z-index:50;font-family:SF Mono,Consolas,Monaco,monospace;font-size:11px;font-weight:600;letter-spacing:.5px;color:#00000061;text-shadow:0 0 2px rgba(255,255,255,.8),1px 0 0 rgba(255,255,255,.8),-1px 0 0 rgba(255,255,255,.8),0 1px 0 rgba(255,255,255,.8),0 -1px 0 rgba(255,255,255,.8)}body.dark-theme .tchan-watermark:after{color:#fff6;text-shadow:0 0 2px rgba(0,0,0,.9),1px 0 0 rgba(0,0,0,.9),-1px 0 0 rgba(0,0,0,.9),0 1px 0 rgba(0,0,0,.9),0 -1px 0 rgba(0,0,0,.9)}.tchan-watermark-large:after{font-size:14px!important;right:16px!important;bottom:14px!important}.contact-page{max-width:1100px;margin:0 auto;padding:1.5rem 1.25rem 3rem;box-sizing:border-box}.contact-hero{text-align:center;padding:1.5rem 1rem 2rem}.contact-hero-badge{display:inline-flex;align-items:center;justify-content:center;width:72px;height:72px;font-size:2.4rem;background:linear-gradient(135deg,#ffd70033,#ff8c001a);border:2px solid rgba(255,215,0,.4);border-radius:50%;margin-bottom:1rem;box-shadow:0 0 30px #ffd70033}.contact-hero-title{font-size:2rem;font-weight:700;margin:0 0 .5rem;background:linear-gradient(135deg,#ffd700 0%,#ff8c00 50%,var(--theme-text) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.contact-hero-desc{color:var(--theme-text-secondary);font-size:.95rem;margin:0}.contact-notices{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:1.5rem}.contact-notice{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-radius:8px;font-size:.82rem;line-height:1.6;color:var(--theme-text);border:1px solid}.contact-notice b{font-weight:700}.notice-sep{margin:0 4px;opacity:.4}.notice-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}.notice-warn{background:#f59e0b14;border-color:#f59e0b40}.notice-vip{background:#6366f114;border-color:#6366f140}.notice-renew{background:#22c55e14;border-color:#22c55e40}.notice-guest{background:#ef444414;border-color:#ef444440}@media (max-width: 768px){.contact-notices{grid-template-columns:1fr}}.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.contact-col{display:flex;flex-direction:column;gap:1.25rem}.contact-card{background:var(--theme-panel-background);border:1px solid var(--theme-border);border-radius:14px;padding:1.5rem 1.25rem;box-shadow:0 4px 16px #0000001a}.contact-card-vip{background:linear-gradient(145deg,rgba(255,215,0,.04),transparent);border-color:#ffd70040}.contact-card-head{display:flex;align-items:center;gap:.6rem;margin-bottom:1.25rem;padding-bottom:.85rem;border-bottom:1px solid var(--theme-border)}.contact-card-icon{font-size:1.35rem;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ffd70026,#ff8c0014);border-radius:8px}.contact-card-title{font-size:1.05rem;font-weight:700;color:var(--theme-text)}.contact-items{display:flex;flex-direction:column;gap:.75rem}.contact-item{display:flex;align-items:center;gap:.9rem;padding:.9rem 1rem;background:var(--theme-input-bg);border:1px solid var(--theme-border);border-radius:10px;cursor:pointer;transition:all .2s ease;position:relative}.contact-item:hover{transform:translateY(-1px);border-color:#ffd70066;box-shadow:0 4px 14px #ffd7001a}.contact-item-static{cursor:default}.contact-item-static:hover{transform:none;border-color:var(--theme-border);box-shadow:none}.contact-item-logo{flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:10px;color:#fff;font-size:1.3rem;font-weight:700;box-shadow:0 2px 8px #0000001f}.contact-item-meta{flex:1;min-width:0}.contact-item-label{font-size:.8rem;color:var(--theme-text-secondary);margin-bottom:2px}.contact-item-value{font-size:.95rem;font-weight:600;color:var(--theme-text);font-family:SF Mono,Consolas,monospace}.contact-item-hint{font-size:.72rem;color:var(--theme-text-secondary);margin-top:2px;opacity:.85}.contact-item-copy{flex-shrink:0;padding:.35rem .75rem;font-size:.78rem;color:gold;background:#ffd7001a;border:1px solid rgba(255,215,0,.3);border-radius:6px;transition:all .2s}.contact-item:hover .contact-item-copy{background:#ffd70033}.vip-flow{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.85rem}.vip-flow li{display:flex;gap:.8rem;align-items:flex-start}.vip-flow-num{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,gold,#ff8c00);color:#1a1a1a;border-radius:50%;font-weight:800;font-size:.85rem;box-shadow:0 2px 6px #ff8c004d}.vip-flow b{color:var(--theme-text);font-size:.92rem;display:block}.vip-flow-desc{font-size:.78rem;color:var(--theme-text-secondary);margin-top:2px;line-height:1.4}.terms{display:flex;flex-direction:column;gap:1.25rem;max-height:640px;overflow-y:auto;padding-right:.5rem}.terms::-webkit-scrollbar{width:6px}.terms::-webkit-scrollbar-track{background:transparent}.terms::-webkit-scrollbar-thumb{background:var(--theme-border);border-radius:3px}.terms section h4{margin:0 0 .5rem;font-size:.92rem;font-weight:700;color:var(--theme-text);padding-left:.6rem;border-left:3px solid #ffd700}.terms section p{margin:0;font-size:.82rem;line-height:1.7;color:var(--theme-text-secondary)}.terms section p b{color:var(--theme-text);font-weight:600}.contact-footer{margin-top:2rem;text-align:center}.contact-disclaim{padding:1rem 1.25rem;background:#ff6b6b14;border:1px solid rgba(255,107,107,.25);border-radius:10px;color:var(--theme-text);font-size:.85rem;font-weight:500;margin-bottom:.75rem}.contact-copyright{font-size:.75rem;color:var(--theme-text-secondary);opacity:.7}@media (max-width: 860px){.contact-grid{grid-template-columns:1fr}.contact-hero-title{font-size:1.5rem}.contact-hero-badge{width:60px;height:60px;font-size:2rem}.contact-card{padding:1.25rem 1rem}.terms{max-height:none}}@media (max-width: 480px){.contact-page{padding:1rem .75rem 2rem}.contact-item{padding:.8rem;gap:.7rem}.contact-item-logo{width:38px;height:38px;font-size:1.15rem}.contact-item-copy{padding:.3rem .55rem;font-size:.72rem}}.vip-gate-wrap{display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem 3rem;box-sizing:border-box}.vip-gate-card{position:relative;width:100%;max-width:860px;background:linear-gradient(145deg,var(--theme-background) 0%,var(--theme-panel-background) 100%);border:1px solid var(--theme-border);border-radius:16px;padding:2rem 2rem 2.5rem;box-shadow:0 20px 60px #0000004d,0 0 0 1px #ffd70014;overflow:hidden}.vip-gate-glow{position:absolute;top:-2px;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,#ffd700,#ff8c00,#ffd700,transparent);background-size:200% 100%;animation:vipGlowSlide 3s ease-in-out infinite}@keyframes vipGlowSlide{0%,to{background-position:-100% 0}50%{background-position:100% 0}}.vip-gate-header{text-align:center;margin-bottom:1.75rem}.vip-gate-eyebrow{display:inline-block;padding:4px 14px;font-size:.72rem;letter-spacing:.15em;color:gold;background:#ffd70014;border:1px solid rgba(255,215,0,.3);border-radius:999px;margin-bottom:.75rem;font-weight:600;text-transform:uppercase}.vip-gate-lead{max-width:620px;margin:.75rem auto 1rem;font-size:.92rem;line-height:1.65;color:var(--theme-text-secondary)}.vip-gate-lead b{color:gold;font-weight:600}.vip-gate-notices{display:flex;flex-direction:column;gap:8px;margin-bottom:1.25rem}.vip-notice{padding:12px 16px;border-radius:8px;font-size:.82rem;line-height:1.6;color:var(--theme-text)}.vip-notice b{font-weight:700;margin-right:2px}.vip-notice-warn{background:#f59e0b1a;border-left:3px solid #f59e0b}.vip-notice-try{background:#6366f11a;border-left:3px solid #6366f1}.vip-notice-lock{background:#ef44441a;border-left:3px solid #ef4444}.vip-gate-highlights{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin:1.5rem 0 .25rem;padding:1rem;background:linear-gradient(135deg,#ffd7000f,#ff8c0008);border:1px solid rgba(255,215,0,.2);border-radius:12px}.vip-highlight{text-align:center;padding:.25rem}.vip-highlight-num{display:block;font-size:1.6rem;font-weight:800;background:linear-gradient(135deg,gold,#ff8c00);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1.2}.vip-highlight-lbl{display:block;font-size:.75rem;color:var(--theme-text-secondary);margin-top:2px}.vip-section-title{font-size:.95rem;font-weight:700;color:var(--theme-text);margin:1.5rem 0 .75rem;padding-left:.5rem;border-left:3px solid #ffd700}.vip-steps{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1rem}.vip-step{display:flex;align-items:center;gap:.85rem;padding:.85rem 1rem;background:var(--theme-input-bg);border:1px solid var(--theme-border);border-radius:10px;transition:all .2s}.vip-step:hover{border-color:#ffd70059;transform:translate(2px)}.vip-step-num{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,gold,#ff8c00);color:#1a1a1a;border-radius:50%;font-weight:800;font-size:.95rem;box-shadow:0 2px 8px #ff8c004d}.vip-step-content{flex:1;min-width:0}.vip-step-title{font-size:.9rem;font-weight:600;color:var(--theme-text);margin-bottom:2px}.vip-step-desc{font-size:.78rem;color:var(--theme-text-secondary);line-height:1.4}.vip-uid-hl{display:inline-block;padding:1px 8px;background:#ffd70026;border:1px solid rgba(255,215,0,.4);border-radius:4px;color:gold;font-family:SF Mono,Consolas,monospace;font-size:.82rem;margin:0 2px}.vip-gate-badge{display:inline-flex;align-items:center;justify-content:center;width:76px;height:76px;font-size:3rem;background:linear-gradient(135deg,#ffd70033,#ff8c001a);border:2px solid rgba(255,215,0,.4);border-radius:50%;margin-bottom:1rem;animation:vipBadgePulse 2.5s ease-in-out infinite;box-shadow:0 0 30px #ffd70040}@keyframes vipBadgePulse{0%,to{transform:scale(1);box-shadow:0 0 30px #ffd70040}50%{transform:scale(1.05);box-shadow:0 0 45px #ffd70073}}.vip-gate-title{font-size:1.75rem;font-weight:700;color:var(--theme-text);margin:0 0 .75rem;background:linear-gradient(135deg,#ffd700 0%,#ff8c00 50%,var(--theme-text) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:.02em}.vip-gate-subtitle{font-size:.9rem;color:var(--theme-text-secondary);display:inline-flex;flex-wrap:wrap;gap:.5rem;align-items:center;justify-content:center}.vip-gate-subtitle b{color:var(--theme-text);font-weight:600}.vip-gate-role,.vip-gate-uid{display:inline-block;padding:2px 10px;border-radius:999px;font-size:.75rem;border:1px solid var(--theme-border);background:var(--theme-input-bg);color:var(--theme-text-secondary)}.vip-feature-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem;margin:1.5rem 0}.vip-feature-item{display:flex;align-items:center;gap:.75rem;padding:.9rem 1rem;background:var(--theme-input-bg);border:1px solid var(--theme-border);border-radius:10px;transition:all .2s ease;cursor:default}.vip-feature-item:hover{transform:translateY(-2px);border-color:#ffd70066;box-shadow:0 6px 20px #ffd7001f}.vip-feature-icon{font-size:1.6rem;flex-shrink:0;width:38px;height:38px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#ffd70026,#ff8c0014);border-radius:8px}.vip-feature-meta{flex:1;min-width:0}.vip-feature-title{font-size:.92rem;font-weight:600;color:var(--theme-text);margin-bottom:2px}.vip-feature-desc{font-size:.78rem;color:var(--theme-text-secondary);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vip-gate-cta{margin-top:1.5rem;text-align:center}.vip-cta-btn{display:inline-flex;align-items:center;gap:.75rem;padding:.95rem 2.5rem;background:linear-gradient(135deg,gold,#ff8c00);color:#1a1a1a;border:none;border-radius:999px;font-size:1rem;font-weight:700;cursor:pointer;box-shadow:0 6px 24px #ff8c0059,0 0 0 1px #ffd7004d;transition:all .25s ease;position:relative;overflow:hidden}.vip-cta-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transition:left .6s}.vip-cta-btn:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 10px 32px #ff8c0080,0 0 0 2px #ffd70080}.vip-cta-btn:hover:before{left:100%}.vip-cta-btn:active{transform:translateY(0)}.vip-cta-icon{font-size:1.2rem}.vip-cta-arrow{font-size:1.2rem;transition:transform .2s}.vip-cta-btn:hover .vip-cta-arrow{transform:translate(4px)}.vip-cta-hint{margin-top:.75rem;font-size:.8rem;color:var(--theme-text-secondary);opacity:.8}.vip-learn-cta{margin-top:1.5rem;display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:linear-gradient(135deg,#64b4ff14,#508cff0a);border:1px dashed rgba(100,180,255,.4);border-radius:12px}.vip-learn-icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#64b4ff26;border-radius:10px;font-size:1.7rem}.vip-learn-meta{flex:1;min-width:0}.vip-learn-title{font-size:.92rem;font-weight:700;color:var(--theme-text);margin-bottom:2px}.vip-learn-desc{font-size:.78rem;color:var(--theme-text-secondary);line-height:1.45}.vip-learn-btn{flex-shrink:0;padding:.6rem 1.2rem;background:linear-gradient(135deg,#64b4ff,#508cff);color:#fff;border:none;border-radius:20px;font-size:.85rem;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #508cff40;transition:all .2s}.vip-learn-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #508cff66}@media (max-width: 560px){.vip-learn-cta{flex-direction:column;text-align:center}.vip-learn-btn{width:100%}}@media (max-width: 720px){.vip-gate-wrap{padding:1rem .75rem;min-height:calc(100vh - 80px)}.vip-gate-card{padding:1.5rem 1.1rem 1.75rem;border-radius:14px}.vip-gate-badge{width:64px;height:64px;font-size:2.5rem}.vip-gate-title{font-size:1.25rem;line-height:1.35}.vip-gate-lead{font-size:.85rem}.vip-gate-highlights{grid-template-columns:repeat(2,1fr);gap:.6rem;padding:.85rem}.vip-highlight-num{font-size:1.35rem}.vip-highlight-lbl{font-size:.7rem}.vip-feature-grid{grid-template-columns:1fr 1fr;gap:.55rem}.vip-feature-item{padding:.65rem .7rem;gap:.55rem}.vip-feature-icon{width:32px;height:32px;font-size:1.3rem}.vip-feature-title{font-size:.8rem}.vip-feature-desc{font-size:.68rem}.vip-step{padding:.7rem .8rem;gap:.7rem}.vip-step-num{width:28px;height:28px;font-size:.85rem}.vip-step-title{font-size:.82rem}.vip-step-desc{font-size:.72rem}.vip-cta-btn{padding:.9rem 1.5rem;font-size:.95rem;width:100%;max-width:360px;justify-content:center}}@media (max-width: 420px){.vip-feature-grid{grid-template-columns:1fr}.vip-gate-card{padding:1.25rem .95rem 1.5rem}}.vip-gate-container{display:flex;align-items:flex-start;justify-content:center;padding:2rem}.vip-gate-overlay{background:var(--theme-background);border-radius:20px;border:1px solid var(--theme-border);box-shadow:0 10px 40px #0006;max-width:600px;width:100%;overflow:hidden;position:relative}.vip-gate-overlay:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--theme-button-bg)}.vip-gate-content{padding:3rem 2rem;text-align:center;position:relative}.vip-gate-content .lock-icon{font-size:4rem;margin-bottom:1.5rem;display:block;animation:pulse 2s infinite;color:var(--theme-text)}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.8}}.vip-gate-content h3{color:var(--theme-text);font-size:2rem;font-weight:600;margin-bottom:1rem}.vip-gate-content p{color:var(--theme-text-secondary);font-size:1.1rem;line-height:1.6;margin-bottom:2rem;font-weight:400}.user-info{background:var(--theme-input-bg);padding:1rem 1.5rem;border-radius:12px;margin:1.5rem 0;color:var(--theme-text);font-weight:500;border-left:4px solid var(--theme-button-bg)}.vip-upgrade-hint{text-align:left;margin-top:2rem;padding:1.5rem;background:var(--theme-input-bg);border-radius:12px;border:1px solid var(--theme-border)}.vip-upgrade-hint p{color:var(--theme-text);font-weight:600;margin-bottom:1rem;text-align:center;font-size:1rem}.vip-upgrade-hint ul{list-style:none;padding:0;margin:0 0 1.5rem}.vip-upgrade-hint ul li{color:var(--theme-text-secondary);margin-bottom:.75rem;padding-left:.5rem;font-size:.9rem;line-height:1.4}.contact-admin{text-align:center;padding:1rem;background:var(--theme-button-bg);color:var(--theme-button-text);font-weight:600;border-radius:8px;font-size:.9rem}.vip-gate-hint{background:var(--theme-input-bg);color:var(--theme-text);padding:1rem 1.5rem;border-radius:12px;border:1px solid var(--theme-border);font-size:.9rem;margin-top:1rem}.favorites-placeholder p{margin:0 0 .5rem;font-size:.9rem;color:var(--theme-text-secondary)}.favorites-placeholder small{font-size:.8rem;color:var(--theme-text-muted);font-weight:400}.favorites-list-container{max-height:200px;overflow-y:auto;border:1px solid var(--theme-border);border-radius:10px;background:var(--theme-panel-background);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.favorites-list-container::-webkit-scrollbar{width:4px}.favorites-list-container::-webkit-scrollbar-track{background:transparent;border-radius:2px}.favorites-list-container::-webkit-scrollbar-thumb{background:var(--theme-button-bg);opacity:.3;border-radius:2px}.favorites-list-container::-webkit-scrollbar-thumb:hover{background:var(--theme-button-bg);opacity:.6}.favorites-list{display:flex;flex-direction:column;gap:.3rem;padding:.6rem;background:var(--theme-background)}.favorite-item{display:flex;align-items:center;justify-content:space-between;padding:.6rem;background:var(--theme-panel-background);border:1px solid var(--theme-border);border-radius:6px;transition:all .3s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:relative;overflow:hidden}.favorite-item:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(79,70,229,.05),transparent);transition:left .5s}.favorite-item:hover:before{left:100%}.favorite-item:hover{background:var(--theme-input-bg);border-color:var(--theme-button-bg);transform:translate(2px);box-shadow:0 2px 12px #0000001a}.favorite-symbol{flex:1;color:var(--theme-text);font-weight:500;cursor:pointer;display:flex;align-items:center;font-size:.9rem}.favorite-symbol:hover{color:var(--theme-button-bg);font-weight:600}.symbol-code{font-weight:600;font-size:.8rem;color:var(--theme-text);letter-spacing:-.01em}.two-column-layout.chart-view .symbol-code{font-size:.75rem;color:var(--theme-text)}.symbol-name{font-size:.7rem;color:var(--theme-text-secondary);margin-left:.2rem;font-weight:400}.two-column-layout.chart-view .symbol-name{font-size:.65rem;color:var(--theme-text-secondary)}.remove-favorite-btn{background:#dc35451a;border:1px solid rgba(220,53,69,.2);color:#dc3545;cursor:pointer;padding:.25rem;border-radius:6px;transition:all .3s ease;font-size:.9rem;width:24px;height:24px;display:flex;align-items:center;justify-content:center;opacity:.7;font-weight:600}.remove-favorite-btn:hover{background:#dc354533;border-color:#dc354566;opacity:1;transform:scale(1.1);box-shadow:0 2px 8px #dc354533}@media (max-width: 480px){.main-content{padding:.3rem;height:calc(100vh - 54px)}.two-column-layout{height:calc(100vh - 54px);max-height:calc(100vh - 54px);gap:.3rem}.user-info-container{gap:.4rem;padding:.2rem .4rem}.user-details{gap:.25rem;font-size:.6rem}.user-type-icon{font-size:.8rem;width:14px;height:14px}.uid-label{display:none}.logout-btn{min-width:45px;height:24px;font-size:.55rem;padding:0 .25rem}.logout-text{font-size:.55rem}.config-section{padding:.5rem;margin-bottom:.3rem}.config-section h2{font-size:.8rem;margin-bottom:.5rem}.market-tab{padding:.35rem .5rem;font-size:.65rem}.favorites-list{padding:.4rem;gap:.25rem}.favorite-item{padding:.5rem}.symbol-code{font-size:.7rem}.symbol-name{font-size:.6rem}.vip-gate-container{padding:.8rem;min-height:calc(100vh - 60px);color:var(--theme-text)}.vip-gate-content{padding:1.5rem 1rem;color:var(--theme-text)}.vip-gate-content h3{font-size:1.3rem;color:var(--theme-text)}.vip-gate-content .lock-icon{font-size:2.5rem;color:var(--theme-text)}.center-chart{min-height:400px}}@media (max-width: 768px){.vip-gate-overlay{border-radius:16px;margin:1rem;background:var(--theme-background)}.vip-upgrade-hint{padding:1rem;background:var(--theme-input-bg)}}.drawing-tools-section{background:var(--theme-panel-background);border-radius:8px;padding:12px;margin:8px 0;border:1px solid var(--theme-border);box-shadow:0 2px 8px #0000001a}.controls-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.section-header{font-weight:600;color:var(--theme-text);font-size:14px;margin-right:8px}.section-divider{color:var(--theme-text-muted);margin:0 4px}.small-divider{width:1px;height:20px;background:var(--theme-border);margin:0 4px;opacity:.6}.drawing-tool-btn{background:var(--theme-button-inactive-bg);color:var(--theme-button-inactive-text);border:1px solid var(--theme-border);padding:6px 12px;margin:2px;border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s ease;white-space:nowrap;position:relative;overflow:hidden}.drawing-tool-btn:hover{background:var(--theme-input-bg);color:var(--theme-text);transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.drawing-tool-btn.active{background:var(--theme-button-bg);color:var(--theme-button-text);border-color:var(--theme-button-bg);box-shadow:0 2px 4px #0003}.drawing-tool-btn.active:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,.1) 50%,transparent 70%);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.tool-group{display:flex;flex-wrap:wrap;align-items:center;gap:2px;padding:4px 0;border-bottom:1px solid var(--theme-border);margin-bottom:4px}.tool-group:last-child{border-bottom:none;margin-bottom:0}.drawing-undo-btn,.drawing-redo-btn{background:var(--theme-button-inactive-bg);color:var(--theme-button-inactive-text);border:1px solid var(--theme-border);padding:6px 12px;margin:2px;border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s ease;white-space:nowrap}.drawing-undo-btn:hover,.drawing-redo-btn:hover{background:var(--theme-input-bg);color:var(--theme-text);transform:translateY(-1px)}.drawing-undo-btn:disabled,.drawing-redo-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.drawing-clear-btn{background:#dc3545;color:#fff;border:1px solid #dc3545;padding:6px 12px;margin:2px;border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s ease;white-space:nowrap}.drawing-clear-btn:hover{background:#c82333;border-color:#c82333;transform:translateY(-1px);box-shadow:0 2px 8px #dc26264d}@media (max-width: 768px){.drawing-tools-section{padding:8px;background:var(--theme-panel-background)}.controls-row{gap:4px;align-items:center}.drawing-tool-btn{padding:4px 8px;font-size:11px;color:var(--theme-text)}.section-header{font-size:12px;color:var(--theme-text);font-weight:600}}.ws-status-indicator{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#0000001a;border-radius:20px;font-size:.85rem;margin-right:10px;transition:all .3s ease}.ws-dot{width:8px;height:8px;border-radius:50%;transition:all .3s ease}.ws-dot.connected{background:#2ecc71;box-shadow:0 0 8px #2ecc7199;animation:pulse 2s infinite}.ws-dot.connecting{background:#f39c12;animation:blink 1s infinite}.ws-dot.disconnected{background:#95a5a6}.ws-text{font-weight:500;color:var(--theme-text)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}
