/* Parking Map Component - Kompakt */
parking-map {
  display: block;
}

.parking-map {
  position: relative;
  background: linear-gradient(135deg, #f5f5f5 0%, #e0e0e0 100%);
  border-radius: var(--radius-md);
  padding: var(--spacing-sm);
}

.parking-map-title {
  text-align: center;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: var(--spacing-sm);
  padding: var(--spacing-xs) var(--spacing-sm);
}

.parking-layout {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--spacing-md);
  padding: var(--spacing-sm);
}

/* Entry/Exit Gates - Kompakt */
.gate {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-sm);
  background: var(--hw-color);
  border: 2px solid var(--hw-border);
  border-radius: var(--radius-md);
  min-width: 120px;
}

.gate-title {
  font-weight: 600;
  color: var(--hw-border);
  font-size: 0.75rem;
}

.gate-barrier {
  position: relative;
  width: var(--barrier-size);
  height: 50px;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}

.barrier-post {
  width: 8px;
  height: 30px;
  background: #424242;
  border-radius: 2px;
}

.barrier-arm {
  position: absolute;
  bottom: 22px;
  left: 8px;
  width: 45px;
  height: 5px;
  background: linear-gradient(90deg, #f44336 0%, #f44336 50%, #fff 50%, #fff 100%);
  background-size: 10px 5px;
  border-radius: 2px;
  transform-origin: left center;
  transition: transform var(--transition-slow);
}

.barrier-arm.open {
  transform: rotate(-90deg);
}

.barrier-arm.moving {
  animation: barrier-move 0.5s ease-in-out;
}

@keyframes barrier-move {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; }
}

.gate-sensor {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  font-size: 0.6875rem;
  color: var(--text-secondary);
}

.sensor-indicator {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #9e9e9e;
  transition: background var(--transition-fast);
}

.sensor-indicator.active {
  background: var(--color-success);
  box-shadow: 0 0 6px var(--color-success);
}

.gate-action {
  margin-top: var(--spacing-xs);
}

.vehicle-btn {
  padding: 2px var(--spacing-xs);
  font-size: 0.6875rem;
}

/* Totem in center - Kompakt */
.totem-indicator {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-xs);
  padding: var(--spacing-sm);
  background: var(--sw-color);
  border: 2px solid var(--sw-border);
  border-radius: var(--radius-md);
}

.totem-icon {
  width: 45px;
  height: 60px;
  background: #37474f;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  font-size: 0.5rem;
  text-align: center;
  padding: 2px;
}

.totem-label {
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--sw-border);
}

/* Status bar - Kompakt */
.parking-status {
  display: flex;
  justify-content: center;
  gap: var(--spacing-md);
  margin-top: var(--spacing-sm);
  padding-top: var(--spacing-xs);
  border-top: 1px solid #e0e0e0;
}

.status-item {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  font-size: 0.6875rem;
}

.status-label {
  color: var(--text-secondary);
}

.status-value {
  font-weight: 600;
}

.status-value.ok {
  color: var(--color-success);
}

.status-value.blocked {
  color: var(--color-error);
}

.status-value.open {
  color: var(--color-warning);
}

.status-value.closed {
  color: var(--text-secondary);
}
