body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{background:linear-gradient(135deg,#667eea,#764ba2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh;padding:20px}.App{margin:0 auto;max-width:1200px}.view-switcher{display:flex;gap:10px;justify-content:center;margin-bottom:20px}.view-btn{background:#fff3;border:2px solid #ffffff4d;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s}.view-btn:hover{background:#ffffff4d}.view-btn.active{background:#fff;border-color:#fff;color:#667eea}.websocket-client{background:#fff;border-radius:15px;box-shadow:0 20px 60px #0000004d;padding:30px}h1{color:#333;font-size:2rem;margin-bottom:30px;text-align:center}h2{color:#555;font-size:1.2rem;margin-bottom:15px}.connection-section,.data-section,.message-section{background:#f8f9fa;border-radius:10px;margin-bottom:30px;padding:20px}.message-input-group,.url-input-group{display:flex;gap:10px;margin-bottom:15px}.message-input,.url-input{border:2px solid #e0e0e0;border-radius:8px;flex:1 1;font-size:16px;padding:12px;transition:border-color .3s}.message-input:focus,.url-input:focus{border-color:#667eea;outline:none}.message-input:disabled,.url-input:disabled{background:#e0e0e0;cursor:not-allowed}button{border:none;border-radius:8px;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s}.connect-btn{background:#4caf50;color:#fff}.connect-btn:hover{background:#45a049}.disconnect-btn{background:#f44336;color:#fff}.disconnect-btn:hover{background:#da190b}.send-btn{background:#2196f3;color:#fff}.send-btn:hover:not(:disabled){background:#0976d2}.send-btn:disabled{background:#ccc;cursor:not-allowed}.clear-btn{background:#ff9800;color:#fff;font-size:14px;padding:8px 16px}.clear-btn:hover{background:#e68900}.status{border-radius:8px;font-weight:600;padding:10px;text-align:center;transition:all .3s}.status.connected{background:#c8e6c9;color:#2e7d32}.status.disconnected{background:#ffcdd2;color:#c62828}.data-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.data-container{background:#fff;border:2px solid #e0e0e0;border-radius:8px;max-height:400px;overflow-y:auto;padding:15px}.no-data{color:#999;font-style:italic;padding:40px;text-align:center}.data-item{animation:fadeIn .3s;border-radius:6px;font-family:Courier New,monospace;margin-bottom:8px;padding:10px}.data-item.received{background:#e3f2fd;border-left:4px solid #2196f3}.data-item.sent{background:#f3e5f5;border-left:4px solid #9c27b0}.timestamp{color:#666;font-size:12px;margin-right:10px}.data-content{color:#333;word-break:break-all}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:600px){.websocket-client{padding:20px}h1{font-size:1.5rem}.message-input-group,.url-input-group{flex-direction:column}button{width:100%}}.forex-dashboard{background:#fff;border-radius:15px;box-shadow:0 20px 60px #0000004d;padding:30px}.forex-grid{background:#f8f9fa;border-radius:10px;margin:30px 0;padding:20px}.forex-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.clear-forex-btn{background:#ff5722;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background .3s}.clear-forex-btn:hover{background:#e64919}.update-indicator{color:#666;font-size:11px;font-weight:500;margin-top:5px}.currency-card.stale .update-indicator{color:#ff9800}.currency-card.fresh .update-indicator{color:#4caf50}.currency-card.fresh{animation:pulse 2s infinite;border-left:4px solid #4caf50}.currency-card.stale{border-left:4px solid #ff9800;opacity:.8}@keyframes pulse{0%{border-left-color:#4caf50}50%{border-left-color:#81c784}to{border-left-color:#4caf50}}.currency-cards{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-top:20px}.currency-card{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;padding:20px;transition:transform .2s,box-shadow .2s}.currency-card:hover{box-shadow:0 5px 20px #0003;transform:translateY(-5px)}.currency-header{border-bottom:2px solid #f0f0f0;margin-bottom:15px;padding-bottom:10px}.currency-header h3{color:#333;font-size:1.4rem;margin:0}.currency-desc{color:#666;display:block;font-size:.85rem;margin-top:5px}.currency-price{margin:20px 0;text-align:center}.main-price{color:#333;font-size:2rem;font-weight:700;margin-bottom:5px}.price-change{font-size:1.1rem;font-weight:600}.currency-details{margin-top:20px}.detail-row{border-bottom:1px solid #f5f5f5;display:flex;font-size:.9rem;justify-content:space-between;padding:8px 0}.detail-row:last-child{border-bottom:none}.detail-row span:first-child{color:#666;font-weight:500}.detail-row span:last-child{color:#333;font-weight:600}.symbol-controls{background:#e8f4f8;border-radius:8px;margin:20px 0;padding:15px}.symbol-controls h3{color:#2196f3;font-size:1rem;margin:0 0 10px}.symbol-buttons{display:flex;flex-wrap:wrap;gap:10px}.symbol-btn{background:#fff;border:2px solid #2196f3;border-radius:6px;color:#2196f3;cursor:pointer;font-size:14px;font-weight:600;padding:10px 16px;transition:all .3s}.symbol-btn.active,.symbol-btn:hover:not(:disabled){background:#2196f3;color:#fff}.symbol-btn:disabled{background:#f5f5f5;border-color:#ccc;color:#999;cursor:not-allowed}.data-controls{gap:15px}.auto-scroll,.data-controls{align-items:center;display:flex}.auto-scroll{color:#666;font-size:14px;gap:5px}.auto-scroll input[type=checkbox]{cursor:pointer}.parsed-info{background:#f0f4f8;border-radius:5px;margin-bottom:8px;padding:8px}.parsed-item{margin-bottom:4px}.quote-info{color:#2196f3;font-size:14px;font-weight:600}.connection-info{color:#4caf50;font-size:14px}.completion-info{color:#9c27b0;font-size:14px}.data-time{color:#666;font-size:12px;margin-bottom:5px}.raw-content{color:#999;font-family:Courier New,monospace;font-size:11px;margin-top:5px;word-break:break-all}.debug-section{background:#f0f4f8;border-left:4px solid #2196f3;border-radius:8px;margin:20px 0;padding:15px}.debug-section h3{color:#2196f3;font-size:1rem;margin:0 0 15px}.debug-controls{display:flex;gap:10px;margin-bottom:15px}.clear-debug-btn,.test-btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 16px;transition:background .3s}.test-btn{background:#ff9800;color:#fff}.test-btn:hover{background:#e68900}.clear-debug-btn{background:#9e9e9e;color:#fff}.clear-debug-btn:hover{background:#757575}.debug-log{background:#fff;border:1px solid #ddd;border-radius:6px;padding:10px}.debug-log h4{color:#333;font-size:14px;margin:0 0 10px}.debug-messages{font-family:Courier New,monospace;font-size:12px;max-height:200px;overflow-y:auto}.debug-message{border-bottom:1px solid #f0f0f0;padding:4px 0}.debug-message:last-child{border-bottom:none}.debug-time{color:#666;margin-right:8px}.debug-text{color:#333;font-weight:500}.debug-data{color:#2196f3;margin-left:8px;word-break:break-all}.url-info{background:#e8f4f8;border:1px solid #2196f3;border-radius:6px;margin:15px 0;padding:10px}.url-info h4{color:#2196f3;font-size:14px;margin:0 0 10px}.url-details{font-family:Courier New,monospace;font-size:12px}.url-details div{margin-bottom:5px;padding:2px 0}.url-details strong{color:#333;font-weight:600}.url-details code{background:#fff;border-radius:3px;color:#2196f3;font-size:11px;padding:2px 4px;word-break:break-all}@media (max-width:768px){.currency-cards{grid-template-columns:1fr}.main-price{font-size:1.5rem}.debug-controls{flex-direction:column}.clear-debug-btn,.test-btn{width:100%}}