.topic-list{display:flex;flex-direction:column;gap:10px}.no-topics{background:#fff;padding:60px 20px;border-radius:8px;text-align:center;color:#999;box-shadow:0 2px 4px #0000001a}.topic-item{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden;transition:all .3s ease}.topic-item:hover{box-shadow:0 4px 12px #00000026}.topic-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;cursor:pointer;-webkit-user-select:none;user-select:none;gap:15px}.topic-header:hover{background:#f8f9fa}.topic-name{display:flex;align-items:center;gap:10px;font-weight:500;color:#333;font-family:Courier New,monospace;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.expand-icon{color:#666;font-size:12px;flex-shrink:0}.topic-meta{display:flex;align-items:center;gap:10px;flex-shrink:0}.timestamp{color:#999;font-size:13px;font-family:Courier New,monospace}.json-badge{background:#2196f3;color:#fff;padding:3px 8px;border-radius:4px;font-size:11px;font-weight:600}.topic-content{padding:0 20px 20px;border-top:1px solid #e0e0e0;background:#f8f9fa}.payload-label{font-size:12px;color:#666;margin-bottom:8px;margin-top:15px;font-weight:600}.payload{background:#2d2d2d;color:#f8f8f2;padding:15px;border-radius:6px;font-family:Courier New,monospace;font-size:13px;overflow-x:auto;margin:0;white-space:pre-wrap;word-wrap:break-word}@media (max-width: 768px){.topic-header{flex-direction:column;align-items:flex-start;gap:8px}.topic-name{font-size:14px}.topic-meta{width:100%;justify-content:space-between}}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 0;box-shadow:0 4px 6px #0000001a}.header-content{max-width:1400px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px}.header h1{margin:0;font-size:28px;font-weight:600}.status-indicators{display:flex;gap:15px;align-items:center;flex-wrap:wrap}.status-badge{display:flex;align-items:center;gap:8px;padding:8px 15px;background:#fff3;border-radius:20px;font-size:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.status-badge.connected .status-dot{background-color:#4caf50;box-shadow:0 0 8px #4caf50}.status-badge.disconnected .status-dot{background-color:#f44336;box-shadow:0 0 8px #f44336}.broker-info{padding:8px 15px;background:#fff3;border-radius:20px;font-size:14px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@media (max-width: 768px){.header-content{flex-direction:column;align-items:flex-start}.header h1{font-size:24px}}.publish-form-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;overflow:hidden}.publish-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;cursor:pointer;-webkit-user-select:none;user-select:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.publish-header:hover{opacity:.95}.publish-header h3{margin:0;font-size:18px;font-weight:500}.publish-header .expand-icon{font-size:14px}.publish-form{padding:20px}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333;font-size:14px}.form-group input,.form-group textarea{width:100%;padding:10px 15px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px;font-family:Courier New,monospace;transition:border-color .3s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea}.form-group textarea{resize:vertical;min-height:80px}.form-actions{display:flex;justify-content:space-between;align-items:center;margin-top:20px}.retain-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.retain-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.retain-checkbox span{font-size:14px;color:#666}.publish-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 30px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.publish-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.publish-button:active{transform:translateY(0)}@media (max-width: 768px){.form-actions{flex-direction:column;gap:15px;align-items:stretch}.publish-button{width:100%}}.test-equipments{margin:20px 0;padding:20px;background:#1e1e1e;border-radius:8px;border:1px solid #333}.test-equipments h2{margin:0 0 15px;color:#61dafb;font-size:1.3em}.equipment-list{display:flex;flex-direction:column;gap:12px}.equipment-item{background:#252525;border:1px solid #3a3a3a;border-radius:6px;padding:12px;transition:all .2s}.equipment-item:hover{border-color:#4a4a4a}.equipment-header{display:flex;justify-content:space-between;align-items:center;gap:15px}.equipment-name{display:flex;align-items:center;gap:10px;flex:1}.equipment-name strong{color:#fff;font-size:1.1em}.equipment-topic{color:#888;font-family:Courier New,monospace;font-size:.9em}.message-count{color:#666;font-size:.85em}.expand-icon{cursor:pointer;-webkit-user-select:none;user-select:none;color:#61dafb;width:20px;display:inline-block}.expand-icon:hover{color:#4fa8c5}.equipment-actions{display:flex;gap:8px}.equipment-actions button{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:all .2s;font-size:.9em}.btn-good{background:#2ecc71;color:#fff}.btn-good:hover{background:#27ae60;transform:translateY(-1px)}.btn-bad{background:#e74c3c;color:#fff}.btn-bad:hover{background:#c0392b;transform:translateY(-1px)}.equipment-messages{margin-top:12px;padding-top:12px;border-top:1px solid #3a3a3a}.no-messages{color:#888;font-style:italic;margin:8px 0}.message-item{background:#2a2a2a;border:1px solid #3a3a3a;border-radius:4px;padding:10px;margin-bottom:8px}.message-item:last-child{margin-bottom:0}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.85em}.message-number{color:#61dafb;font-weight:600}.message-timestamp{color:#888;font-family:Courier New,monospace}.message-payload{background:#1a1a1a;padding:10px;border-radius:4px;border:1px solid #333;color:#d4d4d4;font-family:Courier New,monospace;font-size:.85em;overflow-x:auto;margin:0;white-space:pre-wrap;word-break:break-all}.app{min-height:100vh;background-color:#f5f5f5}.container{max-width:1400px;margin:0 auto;padding:20px}.controls{display:flex;gap:20px;align-items:center;margin-bottom:20px;background:#fff;padding:15px 20px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.filter-input{flex:1;padding:10px 15px;border:2px solid #e0e0e0;border-radius:6px;font-size:14px;transition:border-color .3s}.filter-input:focus{outline:none;border-color:#2196f3}.topic-count{color:#666;font-size:14px;white-space:nowrap}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}code{font-family:Courier New,monospace}
