@charset "UTF-8";
.electric-info-container[data-v-6585dea2] {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
  background: #f5f7fa;
  min-height: 500px;
  padding: 20px;
}

/* 左侧地图 */
.map-section[data-v-6585dea2] {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.map-header[data-v-6585dea2] {
  padding: 14px 16px;
  font-size: 15px;
  font-weight: 500;
  color: #303133;
  border-bottom: 1px solid #ebeef5;
}
.map-content[data-v-6585dea2] {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  min-height: 450px;
  position: relative;
}
.no-location[data-v-6585dea2] {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background: #fafafa;
  color: #909399;
}
.no-location i[data-v-6585dea2] {
  font-size: 60px;
  color: #dcdfe6;
  margin-bottom: 16px;
}
.no-location p[data-v-6585dea2] {
  font-size: 15px;
  color: #606266;
  margin: 0 0 8px 0;
}
.no-location span[data-v-6585dea2] {
  font-size: 13px;
}

/* 右侧信息 */
.info-section[data-v-6585dea2] {
  width: 320px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 16px;
}
.info-block[data-v-6585dea2] {
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
}
.block-title[data-v-6585dea2] {
  padding: 14px 16px;
  font-size: 15px;
  font-weight: 500;
  color: #303133;
  border-bottom: 1px solid #ebeef5;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.status-tag[data-v-6585dea2] {
  font-size: 12px;
  padding: 2px 10px;
  border-radius: 10px;
  font-weight: normal;
}
.status-tag.online[data-v-6585dea2] {
  background: #e1f3d8;
  color: #67c23a;
}
.status-tag.offline[data-v-6585dea2] {
  background: #fef0f0;
  color: #f56c6c;
}
.info-list[data-v-6585dea2] {
  padding: 8px 0;
}
.info-row[data-v-6585dea2] {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 10px 16px;
}
.info-row label[data-v-6585dea2] {
  font-size: 14px;
  color: #909399;
}
.info-row span[data-v-6585dea2] {
  font-size: 14px;
  color: #303133;
  text-align: right;
  max-width: 180px;
  word-break: break-all;
}
.info-row .lonlat-text[data-v-6585dea2] {
  font-size: 12px;
}
.text-green[data-v-6585dea2] {
  color: #67c23a !important;
}
.text-orange[data-v-6585dea2] {
  color: #e6a23c !important;
}

/* 响应式 */
@media screen and (max-width: 900px) {
.electric-info-container[data-v-6585dea2] {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
}
.info-section[data-v-6585dea2] {
    width: 100%;
}
.map-content[data-v-6585dea2] {
    min-height: 350px;
}
}
@charset "UTF-8";
.control-page[data-v-13624728] {
  padding: 20px;
  background: #f5f7fa;
  min-height: 500px;
}
.page-header[data-v-13624728] {
  font-size: 18px;
  font-weight: 600;
  color: #303133;
  margin-bottom: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
}
.page-header i[data-v-13624728] {
  font-size: 22px;
  color: #67c23a;
}
.control-layout[data-v-13624728] {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
}
.control-card[data-v-13624728] {
  background: #fff;
  border-radius: 8px;
  overflow: hidden;
  -webkit-box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
          box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04);
}
.operation-card[data-v-13624728] {
  width: 380px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.config-card[data-v-13624728] {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  max-width: 500px;
}
.card-header[data-v-13624728] {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 8px;
  padding: 16px 20px;
  font-size: 15px;
  font-weight: 500;
  color: #303133;
  border-bottom: 1px solid #ebeef5;
}
.card-header i[data-v-13624728] {
  font-size: 18px;
  color: #67c23a;
}
.card-body[data-v-13624728] {
  padding: 20px;
}

/* 控制按钮网格 */
.control-grid[data-v-13624728] {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.control-item[data-v-13624728] {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 24px 16px;
  border-radius: 12px;
  background: #f9fafb;
  border: 1px solid #ebeef5;
  cursor: pointer;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
  position: relative;
}
.control-item[data-v-13624728]:hover:not(.disabled) {
  background: #f0f9eb;
  border-color: #c2e7b0;
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
  -webkit-box-shadow: 0 4px 12px rgba(103, 194, 58, 0.15);
          box-shadow: 0 4px 12px rgba(103, 194, 58, 0.15);
}
.control-item[data-v-13624728]:active:not(.disabled) {
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
.control-item.disabled[data-v-13624728] {
  opacity: 0.6;
  cursor: not-allowed;
}
.control-icon[data-v-13624728] {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 12px;
}
.control-icon i[data-v-13624728] {
  font-size: 24px;
  color: #fff;
}
.control-icon.lock[data-v-13624728] {
  background: linear-gradient(135deg, #909399 0%, #606266 100%);
}
.control-icon.unlock[data-v-13624728] {
  background: linear-gradient(135deg, #67c23a 0%, #5daf34 100%);
}
.control-icon.start[data-v-13624728] {
  background: linear-gradient(135deg, #67c23a 0%, #5daf34 100%);
}
.control-icon.stop[data-v-13624728] {
  background: linear-gradient(135deg, #909399 0%, #606266 100%);
}
.control-label[data-v-13624728] {
  font-size: 14px;
  color: #606266;
  text-align: center;
  line-height: 1.4;
  font-weight: 500;
}
.btn-spinner[data-v-13624728] {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

/* 配置表单 */
.config-form[data-v-13624728] {
  max-width: 400px;
}
.config-form .el-form-item[data-v-13624728] {
  margin-bottom: 20px;
}
.config-form .el-form-item[data-v-13624728]:last-child {
  margin-bottom: 0;
}
.config-form[data-v-13624728] .el-form-item__label {
  font-size: 14px;
  color: #606266;
  padding-bottom: 8px;
  line-height: 1.4;
}
.config-form[data-v-13624728] .el-input__inner {
  border-radius: 8px;
  height: 42px;
}
.config-form[data-v-13624728] .el-input__inner:focus {
  border-color: #67c23a;
}
.config-form[data-v-13624728] .el-input__prefix {
  color: #909399;
}
.save-btn[data-v-13624728] {
  background: #67c23a;
  border-color: #67c23a;
  border-radius: 8px;
  padding: 12px 24px;
  font-size: 14px;
}
.save-btn[data-v-13624728]:hover, .save-btn[data-v-13624728]:focus {
  background: #85ce61;
  border-color: #85ce61;
}
.save-btn[data-v-13624728]:active {
  background: #5daf34;
  border-color: #5daf34;
}
.save-btn i[data-v-13624728] {
  margin-right: 4px;
}

/* 响应式 */
@media screen and (max-width: 900px) {
.control-layout[data-v-13624728] {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
}
.operation-card[data-v-13624728] {
    width: 100%;
}
.config-card[data-v-13624728] {
    max-width: 100%;
}
}
@media screen and (max-width: 480px) {
.control-grid[data-v-13624728] {
    grid-template-columns: 1fr;
}
}
.electric-detail-page[data-v-b7c276dc] {
  min-height: 100%;
  background-color: #fff;
  padding: 20px;
}
.detail-tabs[data-v-b7c276dc] {
  margin-bottom: 16px;
}
.detail-content[data-v-b7c276dc] {
  min-height: calc(100vh - 200px);
}
