*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:#0f0f23;color:#e0e0e0;min-height:100vh}.app{min-height:100vh}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460)}.login-card{background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:3rem;width:100%;max-width:400px;text-align:center}.logo{font-size:4rem;margin-bottom:1rem}.login-card h1{font-size:2rem;margin-bottom:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{color:#888;margin-bottom:2rem}.form-group{margin-bottom:1.5rem;text-align:left}.form-group label{display:block;margin-bottom:.5rem;color:#aaa;font-size:.9rem}.form-group input{width:100%;padding:.75rem 1rem;border:1px solid rgba(255,255,255,.1);border-radius:8px;background:#0000004d;color:#fff;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#667eea}.error{color:#ff6b6b;margin-bottom:1rem;font-size:.9rem}.btn-primary{width:100%;padding:.75rem 1.5rem;border:none;border-radius:8px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:1rem;cursor:pointer;transition:transform .2s,box-shadow .2s}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 20px #667eea66}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.dashboard{min-height:100vh}.header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:#0000004d;border-bottom:1px solid rgba(255,255,255,.1)}.header-left{display:flex;align-items:center;gap:.75rem}.logo-small{font-size:1.5rem}.header h1{font-size:1.25rem;font-weight:500}.btn-logout{padding:.5rem 1rem;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:transparent;color:#aaa;cursor:pointer;transition:all .2s}.btn-logout:hover{background:#ffffff1a;color:#fff}.main{padding:2rem;max-width:1200px;margin:0 auto}.card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.card h2{font-size:1.1rem;font-weight:500;margin-bottom:1rem;color:#fff}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.card-header h2{margin-bottom:0}.status-row{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem}.label{color:#888;min-width:80px}.status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:500}.status-badge.online,.status-badge.connected{background:#2ed57333;color:#2ed573}.status-badge.offline,.status-badge.disconnected{background:#ff6b6b33;color:#ff6b6b}.status-badge.unknown,.status-badge.connecting{background:#ffc10733;color:#ffc107}.btn-small{padding:.375rem .75rem;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:transparent;color:#aaa;font-size:.85rem;cursor:pointer;transition:all .2s}.btn-small:hover{background:#ffffff1a;color:#fff}.btn-small.btn-danger{border-color:#ff6b6b80;color:#ff6b6b}.btn-small.btn-danger:hover{background:#ff6b6b33}.form-row{display:flex;gap:1rem;align-items:flex-end}.form-row .form-group{flex:1;margin-bottom:0}.form-row .btn-primary{width:auto;padding:.75rem 1.5rem}.test-result{margin-top:1rem;padding:.75rem;background:#0003;border-radius:6px;font-family:monospace;font-size:.9rem;color:#aaa}.logs-card{flex:1}.logs{max-height:400px;overflow-y:auto;background:#0003;border-radius:8px;padding:.5rem}.log-item{display:flex;gap:.75rem;padding:.5rem;border-radius:4px;font-family:monospace;font-size:.85rem}.log-item:hover{background:#ffffff08}.log-time{color:#666;flex-shrink:0}.log-message{word-break:break-all}.log-item.info .log-message{color:#aaa}.log-item.success .log-message{color:#2ed573}.log-item.error .log-message{color:#ff6b6b}.log-empty{padding:2rem;text-align:center;color:#666}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}
