
/* --- Fleet 2D Premium Map (v2.8.0) --- */
.fleet2d-wrap{
  position: relative;
  width: 100%;
  height: 520px;
  border-radius: 14px;
  overflow: hidden;
  background: radial-gradient(1200px 600px at 30% 20%, rgba(52,199,89,0.06), rgba(0,0,0,0)) ,
              radial-gradient(900px 500px at 70% 80%, rgba(64,156,255,0.05), rgba(0,0,0,0)),
              linear-gradient(180deg, rgba(10,16,32,1) 0%, rgba(6,10,18,1) 100%);
}

.fleet2d-bg{
  position:absolute; inset:0;
  background-image: url("/assets/plant_map.png");
  background-size: cover;
  background-position: center;
  opacity: 0.28;
  filter: contrast(1.08) saturate(1.05);
}

.fleet2d-overlay{
  position:absolute; inset:0;
}

.fleet2d-node{
  position:absolute;
  transform: translate(-50%, -50%);
  width: 120px;
  height: 64px;
  border-radius: 12px;
  background: rgba(15, 23, 42, 0.70);
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow: 0 10px 30px rgba(0,0,0,0.35);
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
  user-select: none;
}

.fleet2d-node:hover{
  transform: translate(-50%, -50%) scale(1.02);
  box-shadow: 0 14px 36px rgba(0,0,0,0.45);
  border-color: rgba(255,255,255,0.16);
}

.fleet2d-node.selected{
  outline: 2px solid rgba(64,156,255,0.65);
  box-shadow: 0 0 0 6px rgba(64,156,255,0.10), 0 18px 46px rgba(0,0,0,0.55);
}

.fleet2d-badge{
  position:absolute;
  left:10px; top:10px;
  width: 10px; height: 10px;
  border-radius: 50%;
  background: rgba(142,142,147,0.9);
  box-shadow: 0 0 0 4px rgba(142,142,147,0.16);
}

.fleet2d-label{
  position:absolute;
  left: 10px;
  right: 10px;
  top: 26px;
  font-size: 12px;
  color: rgba(229,231,235,0.92);
  line-height: 1.1;
  white-space: nowrap;
  overflow:hidden;
  text-overflow: ellipsis;
}
.fleet2d-label .sep{ opacity:0.35; margin:0 6px; }
.fleet2d-label .dot{
  display:inline-block;
  width:8px; height:8px;
  border-radius:50%;
  margin-right:6px;
  vertical-align: -1px;
  background: rgba(142,142,147,0.9);
}

/* State */
.stateOnline .dot{ background: rgba(52,199,89,0.95); box-shadow:0 0 0 4px rgba(52,199,89,0.12);}
.stateStale  .dot{ background: rgba(255,204,0,0.95); box-shadow:0 0 0 4px rgba(255,204,0,0.12);}
.stateOffline .dot{ background: rgba(255,59,48,0.95); box-shadow:0 0 0 4px rgba(255,59,48,0.12);}

/* Zone accent ring */
.fleet2d-node.zoneA .fleet2d-badge{ background: rgba(52,199,89,0.95); box-shadow:0 0 0 4px rgba(52,199,89,0.16); }
.fleet2d-node.zoneB .fleet2d-badge{ background: rgba(255,204,0,0.95); box-shadow:0 0 0 4px rgba(255,204,0,0.16); }
.fleet2d-node.zoneC .fleet2d-badge{ background: rgba(255,149,0,0.95); box-shadow:0 0 0 4px rgba(255,149,0,0.16); }
.fleet2d-node.zoneD .fleet2d-badge{ background: rgba(255,59,48,0.95); box-shadow:0 0 0 4px rgba(255,59,48,0.16); }

/* Offline dim */
.fleet2d-node.stateOffline{ opacity: 0.55; filter: grayscale(0.25); }
.fleet2d-node.stateStale{ opacity: 0.85; }

/* Details panel */
.fleet2d-details{
  position:absolute;
  right: 16px;
  top: 16px;
  width: 340px;
  z-index: 5;
}
.fleet2d-details.hidden{ display:none; }
.fleet2d-details-card{
  border-radius: 16px;
  background: rgba(12, 18, 34, 0.78);
  border: 1px solid rgba(255,255,255,0.12);
  box-shadow: 0 18px 60px rgba(0,0,0,0.55);
  backdrop-filter: blur(8px);
  padding: 14px;
}
.fleet2d-details-head{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
}
.fleet2d-details-title{
  font-size: 18px;
  font-weight: 900;
  letter-spacing: 0.3px;
  color: rgba(229,231,235,0.96);
}
.fleet2d-details-close{
  width: 30px;
  height: 30px;
  border-radius: 10px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
}
.fleet2d-details-close:hover{ background: rgba(255,255,255,0.10); }

.fleet2d-details-meta{
  display:flex;
  gap: 10px;
  margin-top: 10px;
  flex-wrap: wrap;
}
.fleet2d-pill{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.05);
}
.fleet2d-pill .dot{
  width:10px; height:10px; border-radius:50%;
  background: rgba(142,142,147,0.9);
}
.fleet2d-pill.stateOnline .dot{ background: rgba(52,199,89,0.95); }
.fleet2d-pill.stateStale .dot{ background: rgba(255,204,0,0.95); }
.fleet2d-pill.stateOffline .dot{ background: rgba(255,59,48,0.95); }

.fleet2d-details-grid{
  margin-top: 12px;
  display:grid;
  grid-template-columns: 110px 1fr;
  gap: 8px 10px;
  font-size: 12px;
  color: rgba(229,231,235,0.88);
}
.fleet2d-details-grid .k{ opacity:0.65; }
.fleet2d-details-grid .v{ font-weight: 800; opacity: 0.92; }

.fleet2d-details-hint{
  margin-top: 10px;
  font-size: 12px;
  opacity: 0.65;
}

/* Bottom strip */
.fleet2d-bottom{
  position:absolute;
  left:0; right:0; bottom:0;
  padding: 10px 12px;
  background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,0.35));
}
.fleet2d-strip{
  display:flex;
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 4px;
}
.fleet2d-strip::-webkit-scrollbar{ height: 8px; }
.fleet2d-strip::-webkit-scrollbar-thumb{ background: rgba(255,255,255,0.10); border-radius: 10px; }

.fleet2d-strip-item{
  flex: 0 0 auto;
  display:flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  font-size: 12px;
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(15,23,42,0.55);
  cursor:pointer;
  user-select:none;
}
.fleet2d-strip-item:hover{ background: rgba(15,23,42,0.75); }
.fleet2d-strip-item .dot{
  width:10px; height:10px; border-radius:50%;
  background: rgba(142,142,147,0.9);
}
.fleet2d-strip-item.stateOnline .dot{ background: rgba(52,199,89,0.95); }
.fleet2d-strip-item.stateStale .dot{ background: rgba(255,204,0,0.95); }
.fleet2d-strip-item.stateOffline .dot{ background: rgba(255,59,48,0.95); }
.fleet2d-strip-item .nm{ font-weight: 900; opacity:0.94; }
.fleet2d-strip-item .mini{ opacity:0.65; font-weight:800; }
